Skip to content

Commit

Permalink
feat: add layerAttributes to addLayer and refactor updateLayer
Browse files Browse the repository at this point in the history
This way they are both flexible to pass extra params to layers, and they both use the same destructuring approach
  • Loading branch information
VictorVelarde committed Dec 9, 2020
1 parent 9a956c0 commit 05b5f30
Show file tree
Hide file tree
Showing 2 changed files with 8 additions and 6 deletions.
5 changes: 3 additions & 2 deletions docs/api-reference/redux.md
Original file line number Diff line number Diff line change
Expand Up @@ -54,21 +54,22 @@ Action to add a Layer to the store
| --- | --- | --- |
| id | <code>string</code> | unique id for the layer |
| source | <code>string</code> | id of the source of the layer |
| layerAttributes | <code>object</code> | (optional) custom attributes to pass to the layer |

### updateLayer
Action to update a Layer in the store

| Param | Type | Description |
| --- | --- | --- |
| id | <code>string</code> | unique id for the layer |
| layerAttributes | <code>object</code> | layer attributes to update (source, or other custom attributes) |
| layerAttributes | <code>object</code> | custom attributes to pass to the layer |

### removeLayer
Action to remove a layer from the store

| Param | Type | Description |
| --- | --- | --- |
| layerId | <code>string</code> | id of the layer to remove |
| id | <code>string</code> | id of the layer to remove |

### setBaseMap
Action to set a basemap
Expand Down
9 changes: 5 additions & 4 deletions src/redux/cartoSlice.js
Original file line number Diff line number Diff line change
Expand Up @@ -128,21 +128,22 @@ export const removeSource = (sourceId) => ({ type: 'carto/removeSource', payload
* Action to add a Layer to the store
* @param {string} id - unique id for the layer
* @param {string} source - id of the source of the layer
* @param {object} layerAttributes - custom attributes to pass to the layer
*/
export const addLayer = ({id, source}) => ({ type: 'carto/addLayer', payload: {id, source} });
export const addLayer = ({id, source, layerAttributes = {}}) => ({ type: 'carto/addLayer', payload: {id, source, layerAttributes} });

/**
* Action to update a Layer in the store
* @param {string} id - id of the layer to update
* @param {object} layerAttributes - layer attributes to update (source, or other custom attributes)
*/
export const updateLayer = (id, layerAttributes) => ({ type: 'carto/updateLayer', payload: {id, layerAttributes} });
export const updateLayer = ({id, layerAttributes}) => ({ type: 'carto/updateLayer', payload: {id, layerAttributes} });

/**
* Action to remove a layer from the store
* @param {string} layerId - id of the layer to remove
* @param {string} id - id of the layer to remove
*/
export const removeLayer = (layerId) => ({ type: 'carto/removeLayer', payload: layerId});
export const removeLayer = (id) => ({ type: 'carto/removeLayer', payload: id});

/**
* Action to set a basemap
Expand Down

0 comments on commit 05b5f30

Please sign in to comment.