All actions
Table of Contents
forwardActions
A set of helpers to forward dispatch actions to a specific instance reducer
forwardTo
Returns an action dispatcher that wraps and forwards the actions to a specific instance
Parameters
Examples
isForwardAction
Whether an action is a forward action
Parameters
action
Object the action object
Returns boolean boolean - whether the action is a forward action
unwrap
Unwrap an action
Parameters
action
Object the action object
Returns Object unwrapped action
wrapTo
Wrap an action into a forward action that only modify the state of a specific kepler.gl instance. kepler.gl reducer will look for signatures in the action to determine whether it needs to be forwarded to a specific instance reducer.
wrapTo can be curried. You can create a curried action wrapper by only supply the id
argument
A forward action looks like this
Parameters
Examples
ActionTypes
Kepler.gl action types, can be listened by reducers to perform additional tasks whenever an action is called in kepler.gl
Type: Object
Examples
mapStyleActions
Actions handled mostly by mapStyle
reducer. They manage the display of base map, such as loading and receiving base map styles, hiding and showing map layers, user input of custom map style url.
addCustomMapStyle
Add map style from user input to reducer and set it to current style This action is called when user click confirm after putting in a valid style url in the custom map style dialog. It should not be called from outside kepler.gl without a valid inputStyle
in the mapStyle
reducer. param {void}
ActionTypes:
ActionTypes.ADD_CUSTOM_MAP_STYLE
inputMapStyle
Input a custom map style object
ActionTypes:
ActionTypes.INPUT_MAP_STYLE
Updaters:
mapStyleUpdaters.inputMapStyleUpdater
Parameters
inputStyle
ObjectinputStyle.url
string style url e.g.'mapbox://styles/heshan/xxxxxyyyyzzz'
inputStyle.id
string style url e.g.'custom_style_1'
inputStyle.style
Object actual mapbox style jsoninputStyle.name
string style nameinputStyle.layerGroups
Object layer groups that can be used to set map layer visibilityinputStyle.icon
Object icon image data url
mapState
Object mapState is optional
loadCustomMapStyle
Callback when a custom map style object is received
ActionTypes:
ActionTypes.LOAD_CUSTOM_MAP_STYLE
Parameters
loadMapStyleErr
Callback when load map style error
ActionTypes:
ActionTypes.LOAD_MAP_STYLE_ERR
Updaters:
mapStyleUpdaters.loadMapStyleErrUpdater
Parameters
error
any
loadMapStyles
Callback when load map style success
ActionTypes:
ActionTypes.LOAD_MAP_STYLES
Updaters:
mapStyleUpdaters.loadMapStylesUpdater
Parameters
newStyles
Object a{[id]: style}
mapping
mapConfigChange
Update visibleLayerGroups
to change layer group visibility
ActionTypes:
ActionTypes.MAP_CONFIG_CHANGE
Updaters:
mapStyleUpdaters.mapConfigChangeUpdater
Parameters
mapStyle
Object new config{visibleLayerGroups: {label: false, road: true, background: true}}
mapStyleChange
Change to another map style. The selected style should already been loaded into mapStyle.mapStyles
ActionTypes:
ActionTypes.MAP_STYLE_CHANGE
Updaters:
mapStyleUpdaters.mapStyleChangeUpdater
Parameters
styleType
string the style to change to
requestMapStyles
Request map style style object based on style.url.
ActionTypes:
ActionTypes.REQUEST_MAP_STYLES
Updaters:
mapStyleUpdaters.requestMapStylesUpdater
Parameters
set3dBuildingColor
Set 3d building layer group color
ActionTypes:
ActionTypes.SET_3D_BUILDING_COLOR
Parameters
color
Array [r, g, b]
main
Main kepler.gl actions, these actions handles loading data and config into kepler.gl reducer. These actions is listened by all subreducers,
addDataToMap
Add data to kepler.gl reducer, prepare map with preset configuration if config is passed. Kepler.gl provides a handy set of utils to parse data from different formats to the data
object required in dataset. You rarely need to manually format the data obejct.
Use KeplerGlSchema.getConfigToSave
to generate a json blob of the currents instance config. The config object value will always have higher precedence than the options properties.
Kepler.gl uses dataId
in the config to match with loaded dataset. If you pass a config object, you need to match the info.id
of your dataset to the dataId
in each layer
, filter
and interactionConfig.tooltips.fieldsToShow
ActionTypes:
ActionTypes.ADD_DATA_TO_MAP
Updaters:
combinedUpdaters.addDataToMapUpdater
Parameters
data
Objectdata.options
Objectdata.options.centerMap
booleandefault: true
ifcenterMap
is set totrue
kepler.gl will place the map view within the data points boundaries.options.centerMap
will overrideconfig.mapState
if passed in.data.options.readOnly
booleandefault: false
ifreadOnly
is set totrue
the left setting panel will be hiddendata.options.keepExistingConfig
boolean whether to keep exiting map data and associated layer filter interaction configdefault: false
.
data.config
Object this object will contain the full kepler.gl instance configuration {mapState, mapStyle, visState}
Examples
keplerGlInit
Initialize kepler.gl reducer. It is used to pass in mapboxApiAccessToken
to mapStyle
reducer.
ActionTypes:
ActionTypes.INIT
Updaters:
mapStyleUpdaters.initMapStyleUpdater
Parameters
receiveMapConfig
Pass config to kepler.gl instance, prepare the state with preset configs. Calling KeplerGlSchema.parseSavedConfig
to convert saved config before passing it in is required.
You can call receiveMapConfig
before passing in any data. The reducer will store layer and filter config, waiting for data to come in. When data arrives, you can call addDataToMap
without passing any config, and the reducer will try to match preloaded configs. This behavior is designed to allow asynchronous data loading.
It is also useful when you want to prepare the kepler.gl instance with some preset layer and filter settings. Note Sequence is important, receiveMapConfig
needs to be called before data is loaded. Currently kepler.gl doesn't allow calling receiveMapConfig
after data is loaded. It will reset current configuration first then apply config to it.
ActionTypes:
ActionTypes.RECEIVE_MAP_CONFIG
Parameters
config
Object *required The Config Objectoptions
Object *optional The Option objectoptions.centerMap
booleandefault: true
ifcenterMap
is set totrue
kepler.gl will place the map view within the data points boundariesoptions.readOnly
booleandefault: false
ifreadOnly
is set totrue
the left setting panel will be hiddenoptions.keepExistingConfig
boolean whether to keep exiting layer filter and interaction configdefault: false
.
Examples
resetMapConfig
Reset all sub-reducers to its initial state. This can be used to clear out all configuration in the reducer.
ActionTypes:
ActionTypes.RESET_MAP_CONFIG
visStateActions
Actions handled mostly by visState
reducer. They manage how data is processed, filtered and displayed on the map by operates on layers, filters and interaction settings.
addFilter
Add a new filter
ActionTypes:
ActionTypes.ADD_FILTER
Updaters:
visStateUpdaters.addFilterUpdater
Parameters
dataId
string datasetid
this new filter is associated with
Returns {type: ActionTypes.ADD_FILTER, dataId: dataId}
addLayer
Add a new layer
ActionTypes:
ActionTypes.ADD_LAYER
Updaters:
visStateUpdaters.addLayerUpdater
Parameters
props
Object new layer props
Returns {type: ActionTypes.ADD_LAYER, props: props}
applyCPUFilter
Trigger CPU filter of selected dataset
ActionTypes:
ActionTypes.APPLY_CPU_FILTER
Updaters:
visStateUpdaters.applyCPUFilterUpdater
Parameters
Returns {type: ActionTypes.APPLY_CPU_FILTER, dataId: string}
enlargeFilter
Show larger time filter at bottom for time playback (apply to time filter only)
ActionTypes:
ActionTypes.ENLARGE_FILTER
Updaters:
visStateUpdaters.enlargeFilterUpdater
Parameters
idx
Number index of filter to enlarge
Returns {type: ActionTypes.ENLARGE_FILTER, idx: idx}
interactionConfigChange
Update interactionConfig
ActionTypes:
ActionTypes.INTERACTION_CONFIG_CHANGE
Parameters
config
Object new config as key value map:{tooltip: {enabled: true}}
Returns {type: ActionTypes.INTERACTION_CONFIG_CHANGE, config: config}
layerConfigChange
Update layer base config: dataId, label, column, isVisible
ActionTypes:
ActionTypes.LAYER_CONFIG_CHANGE
Parameters
Returns {type: ActionTypes.LAYER_CONFIG_CHANGE, oldLayer: oldLayer, newConfig: newConfig}
layerTextLabelChange
Update layer text label
ActionTypes:
ActionTypes.LAYER_TEXT_LABEL_CHANGE
Parameters
oldLayer
Object layer to be updatedidx
Number -idx
of text label to be updatedprop
stringprop
of text label, e,g,anchor
,alignment
,color
,size
,field
value
any new value
layerTypeChange
Update layer type. Previews layer config will be copied if applicable.
ActionTypes:
ActionTypes.LAYER_TYPE_CHANGE
Updaters:
visStateUpdaters.layerTypeChangeUpdater
Parameters
Returns {type: ActionTypes.LAYER_TYPE_CHANGE, oldLayer: oldLayer, newType: newType}
layerVisConfigChange
Update layer visConfig
ActionTypes:
ActionTypes.LAYER_VIS_CONFIG_CHANGE
Parameters
oldLayer
Object layer to be updatednewVisConfig
Object new visConfig as a key value map: e.g.{opacity: 0.8}
Returns {type: ActionTypes.LAYER_VIS_CONFIG_CHANGE, oldLayer: oldLayer, newVisConfig: newVisConfig}
layerVisualChannelConfigChange
Update layer visual channel
ActionTypes:
ActionTypes.LAYER_VISUAL_CHANNEL_CHANGE
Parameters
oldLayer
Object layer to be updatednewConfig
Object new visual channel configchannel
string channel to be updated
Returns {type: ActionTypes.LAYER_VISUAL_CHANNEL_CHANGE, oldLayer: oldLayer, newConfig: newConfig, channel: channel}
loadFiles
Trigger file loading dispatch addDataToMap
if succeed, or loadFilesErr
if failed
ActionTypes:
ActionTypes.LOAD_FILES
Parameters
Returns {type: ActionTypes.LOAD_FILES, files: any}
loadFilesErr
Trigger loading file error
ActionTypes:
ActionTypes.LOAD_FILES_ERR
Parameters
error
any
Returns {type: ActionTypes.LOAD_FILES_ERR, error: Object}
onLayerClick
Trigger layer click event with clicked object
ActionTypes:
ActionTypes.LAYER_CLICK
Updaters:
visStateUpdaters.layerClickUpdater
Parameters
info
Object Object clicked, returned by deck.gl
Returns {type: ActionTypes.LAYER_CLICK, info: info}
onLayerHover
Trigger layer hover event with hovered object
ActionTypes:
ActionTypes.LAYER_HOVER
Updaters:
visStateUpdaters.layerHoverUpdater
Parameters
info
Object Object hovered, returned by deck.gl
Returns {type: ActionTypes.LAYER_HOVER, info: info}
onMapClick
Trigger map click event, unselect clicked object
ActionTypes:
ActionTypes.MAP_CLICK
Updaters:
visStateUpdaters.mapClickUpdater
Returns {type: ActionTypes.MAP_CLICK}
onMouseMove
Trigger map mouse moveevent, payload would be React-map-gl MapLayerMouseEvent https://visgl.github.io/react-map-gl/docs/api-reference/types#maplayermouseevent
ActionTypes:
ActionTypes.MOUSE_MOVE
Updaters:
visStateUpdaters.mouseMoveUpdater
Parameters
evt
Object MapLayerMouseEvent
Returns {type: ActionTypes.MAP_CLICK}
removeDataset
Remove a dataset and all layers, filters, tooltip configs that based on it
ActionTypes:
ActionTypes.REMOVE_DATASET
Updaters:
visStateUpdaters.removeDatasetUpdater
Parameters
key
string dataset id
Returns {type: ActionTypes.REMOVE_DATASET, key: key}
removeFilter
Remove a filter from visState.filters
, once a filter is removed, data will be re-filtered and layer will be updated
ActionTypes:
ActionTypes.REMOVE_FILTER
Updaters:
visStateUpdaters.removeFilterUpdater
Parameters
idx
Number idx of filter to be removed
Returns {type: ActionTypes.REMOVE_FILTER, idx: idx}
removeLayer
Remove a layer
ActionTypes:
ActionTypes.REMOVE_LAYER
Updaters:
visStateUpdaters.removeLayerUpdater
Parameters
idx
Number idx of layer to be removed
Returns {type: ActionTypes.REMOVE_LAYER, idx: idx}
reorderLayer
Reorder layer, order is an array of layer indexes, index 0 will be the one at the bottom
ActionTypes:
ActionTypes.REORDER_LAYER
Updaters:
visStateUpdaters.reorderLayerUpdater
Parameters
Examples
Returns {type: ActionTypes.REORDER_LAYER, order: order}
setEditorMode
Set the map mode
ActionTypes:
ActionTypes.SET_EDITOR_MODE
Updaters:
visStateUpdaters.setEditorModeUpdater
Parameters
mode
string one of EDITOR_MODES
Examples
setFilter
Update filter property
ActionTypes:
ActionTypes.SET_FILTER
Updaters:
visStateUpdaters.setFilterUpdater
Parameters
idx
Number -idx
of filter to be updatedprop
stringprop
of filter, e,g,dataId
,name
,value
value
any new valuevalueIndex
Number array properties like dataset require index in order to improve performance
Returns {type: ActionTypes.SET_FILTER, idx: idx, prop: prop, value: value}
setFilterPlot
Set the property of a filter plot
ActionTypes:
ActionTypes.SET_FILTER_PLOT
Updaters:
visStateUpdaters.setFilterPlotUpdater
Parameters
Returns {type: ActionTypes.SET_FILTER_PLOT, idx: any, newProp: any}
setMapInfo
Set the property of a filter plot
ActionTypes:
ActionTypes.SET_MAP_INFO
Updaters:
visStateUpdaters.setMapInfoUpdater
Parameters
Returns {type: ActionTypes.SET_FILTER_PLOT, idx: any, newProp: any}
showDatasetTable
Display dataset table in a modal
ActionTypes:
ActionTypes.SHOW_DATASET_TABLE
Updaters:
visStateUpdaters.showDatasetTableUpdater
Parameters
dataId
string dataset id to show in table
Returns {type: ActionTypes.SHOW_DATASET_TABLE, dataId: dataId}
toggleFilterAnimation
Start and end filter animation
ActionTypes:
ActionTypes.TOGGLE_FILTER_ANIMATION
Parameters
idx
Number idx of filter
Returns {type: ActionTypes.TOGGLE_FILTER_ANIMATION, idx: idx}
toggleLayerForMap
Toggle visibility of a layer in a split map
ActionTypes:
ActionTypes.TOGGLE_LAYER_FOR_MAP
Parameters
Returns {type: ActionTypes.TOGGLE_LAYER_FOR_MAP, mapIndex: any, layerId: any}
updateAnimationTime
Reset animation
ActionTypes:
ActionTypes.UPDATE_ANIMATION_TIME
Parameters
value
Number Current value of the slider
Returns {type: ActionTypes.UPDATE_ANIMATION_TIME, value: value}
updateFilterAnimationSpeed
Change filter animation speed
ActionTypes:
ActionTypes.UPDATE_FILTER_ANIMATION_SPEED
Parameters
Returns {type: ActionTypes.UPDATE_FILTER_ANIMATION_SPEED, idx: idx, speed: speed}
updateLayerAnimationSpeed
update trip layer animation speed
ActionTypes:
ActionTypes.UPDATE_LAYER_ANIMATION_SPEED
Parameters
speed
Numberspeed
to change it to.speed
is a multiplier
Returns {type: ActionTypes.UPDATE_LAYER_ANIMATION_SPEED, speed: speed}
updateLayerBlending
Update layer blending mode
ActionTypes:
ActionTypes.UPDATE_LAYER_BLENDING
Parameters
mode
string one ofadditive
,normal
andsubtractive
Returns {type: ActionTypes.UPDATE_LAYER_BLENDING, mode: mode}
updateVisData
Add new dataset to visState
, with option to load a map config along with the datasets
ActionTypes:
ActionTypes.UPDATE_VIS_DATA
Updaters:
visStateUpdaters.updateVisDataUpdater
Parameters
config
Object this object will contain the full kepler.gl instance configuration {mapState, mapStyle, visState}
Returns {type: ActionTypes.UPDATE_VIS_DATA, datasets: datasets, options: options, config: config}
uiStateActions
Actions handled mostly by uiState
reducer. They manage UI changes in tha app, such as open and close side panel, switch between tabs in the side panel, open and close modal dialog for exporting data / images etc. It also manges which settings are selected during image and map export
addNotification
Add a notification to be displayed. Existing notification is going to be updated in case of matching ids.
ActionTypes:
ActionTypes.ADD_NOTIFICATION
Updaters:
uiStateUpdaters.addNotificationUpdater
Parameters
notification
Object Thenotification
object to be added
cleanupExportImage
Delete cached export image
ActionTypes:
ActionTypes.CLEANUP_EXPORT_IMAGE
Updaters:
uiStateUpdaters.cleanupExportImage
hideExportDropdown
Hide side panel header dropdown, activated by clicking the share link on top of the side panel
ActionTypes:
ActionTypes.HIDE_EXPORT_DROPDOWN
openDeleteModal
Toggle active map control panel
ActionTypes:
ActionTypes.OPEN_DELETE_MODAL
Updaters:
uiStateUpdaters.openDeleteModalUpdater
Parameters
datasetId
stringid
of the dataset to be deleted
removeNotification
Remove a notification
ActionTypes:
ActionTypes.REMOVE_NOTIFICATION
Parameters
id
stringid
of the notification to be removed
setExportData
Whether to including data in map config, toggle between true
or false
ActionTypes:
ActionTypes.SET_EXPORT_DATA
Updaters:
uiStateUpdaters.setExportDataUpdater
setExportDataType
Set data format for exporting data
ActionTypes:
ActionTypes.SET_EXPORT_DATA_TYPE
Updaters:
uiStateUpdaters.setExportDataTypeUpdater
Parameters
dataType
string one of'text/csv'
setExportFiltered
Whether to export filtered data, true
or false
ActionTypes:
ActionTypes.SET_EXPORT_FILTERED
Updaters:
uiStateUpdaters.setExportFilteredUpdater
Parameters
payload
boolean settrue
to ony export filtered data
setExportImageDataUri
Set exportImage.setExportImageDataUri
to a dataUri
ActionTypes:
ActionTypes.SET_EXPORT_IMAGE_DATA_URI
Updaters:
uiStateUpdaters.setExportImageDataUri
Parameters
dataUri
string export image data uri
setExportImageSetting
Set exportImage
settings: ratio, resolution, legend
ActionTypes:
ActionTypes.SET_EXPORT_IMAGE_SETTING
Updaters:
uiStateUpdaters.setExportImageSetting
Parameters
newSetting
Object {ratio: '1x'}
setExportSelectedDataset
Set selected dataset for export
ActionTypes:
ActionTypes.SET_EXPORT_SELECTED_DATASET
Parameters
datasetId
string dataset id
setUserMapboxAccessToken
Whether we export a mapbox access token used to create a single map html file
ActionTypes:
ActionTypes.SET_USER_MAPBOX_ACCESS_TOKEN
Parameters
payload
string mapbox access token
showExportDropdown
Hide and show side panel header dropdown, activated by clicking the share link on top of the side panel
ActionTypes:
ActionTypes.SHOW_EXPORT_DROPDOWN
Parameters
id
string id of the dropdown
startExportingImage
Set exportImage.exporting
to true
ActionTypes:
ActionTypes.START_EXPORTING_IMAGE
Updaters:
uiStateUpdaters.startExportingImage
toggleMapControl
Toggle active map control panel
ActionTypes:
ActionTypes.TOGGLE_MAP_CONTROL
Updaters:
uiStateUpdaters.toggleMapControlUpdater
Parameters
panelId
string map control panel id, one of the keys of:DEFAULT_MAP_CONTROLS
toggleModal
Show and hide modal dialog
ActionTypes:
ActionTypes.TOGGLE_MODAL
Updaters:
uiStateUpdaters.toggleModalUpdater
Parameters
id
(string | null) id of modal to be shown, null to hide modals. One of:-DATA_TABLE_ID
toggleSidePanel
Toggle active side panel
ActionTypes:
ActionTypes.TOGGLE_SIDE_PANEL
Updaters:
uiStateUpdaters.toggleSidePanelUpdater
Parameters
id
string id of side panel to be shown, one oflayer
,filter
,interaction
,map
rootActions
Root actions managers adding and removing instances in root reducer. Under-the-hood, when a KeplerGl
component is mounted or unmounted, it will automatically calls these actions to add itself to the root reducer. However, sometimes the data is ready before the component is registered in the reducer, in this case, you can manually call these actions or the corresponding updater to add it to the reducer.
deleteEntry
Delete an instance from keplerGlReducer
. This action is called under-the-hood when a KeplerGl
component is un-mounted to the dom. If mint
is set to be true
in the component prop, the instance state will be deleted from the root reducer. Otherwise, the root reducer will keep the instance state and later transfer it to a newly mounted component with the same id
ActionTypes:
ActionTypes.DELETE_ENTRY
Updaters:
Parameters
id
string the id of the instance to be deleted
registerEntry
Add a new kepler.gl instance in keplerGlReducer
. This action is called under-the-hood when a KeplerGl
component is mounted to the dom. Note that if you dispatch actions such as adding data to a kepler.gl instance before the React component is mounted, the action will not be performed. Instance reducer can only handle actions when it is instantiated.
ActionTypes:
ActionTypes.REGISTER_ENTRY
Updaters:
Parameters
payload
Objectpayload.id
string *required The id of the instancepayload.mint
boolean Whether to use a fresh empty state, whenmint: true
it will always load a fresh state when the component is re-mounted. Whenmint: false
it will register with existing instance state under the sameid
, when the component is unmounted then mounted again. Default:true
payload.mapboxApiAccessToken
string mapboxApiAccessToken to be saved inmap-style
reducer.payload.mapboxApiUrl
string mapboxApiUrl to be saved inmap-style
reducer.payload.mapStylesReplaceDefault
Boolean mapStylesReplaceDefault to be saved inmap-style
reducer.
renameEntry
Rename an instance in the root reducer, keep its entire state
ActionTypes:
ActionTypes.RENAME_ENTRY
Updaters:
Parameters
mapStateActions
Actions handled mostly by mapState
reducer. They manage map viewport update, toggle between 2d and 3d map, toggle between single and split maps.
fitBounds
Fit map viewport to bounds
ActionTypes:
ActionTypes.FIT_BOUNDS
Updaters:
mapStateUpdaters.fitBoundsUpdater
Parameters
Examples
togglePerspective
Toggle between 3d and 2d map.
ActionTypes:
ActionTypes.TOGGLE_PERSPECTIVE
Examples
toggleSplitMap
Toggle between single map or split maps
ActionTypes:
ActionTypes.TOGGLE_SPLIT_MAP
Parameters
index
Number? index is provided, close split map at index
Examples
updateMap
Update map viewport
ActionTypes:
ActionTypes.UPDATE_MAP
Updaters:
mapStateUpdaters.updateMapUpdater
Parameters
viewport
Object viewport object container one or any of these propertieswidth
,height
,latitude
longitude
,zoom
,pitch
,bearing
,dragRotate
viewport.width
Number? Width of viewportviewport.height
Number? Height of viewportviewport.zoom
Number? Zoom of viewportviewport.pitch
Number? Camera angle in degrees (0 is straight down)viewport.bearing
Number? Map rotation in degrees (0 means north is up)viewport.latitude
Number? Latitude center of viewport on map in mercator projectionviewport.longitude
Number? Longitude Center of viewport on map in mercator projectionviewport.dragRotate
boolean? Whether to enable drag and rotate map into perspective viewport
Examples
layerColorUIChange
Set the color palette ui for layer color
ActionTypes:
ActionTypes.LAYER_COLOR_UI_CHANGE
Parameters
setExportMapFormat
Set the export map format (html, json)
ActionTypes:
ActionTypes.SET_EXPORT_MAP_FORMAT
Parameters
payload
string map format
Last updated