-
Notifications
You must be signed in to change notification settings - Fork 1.8k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[feat] Introduced dnd-context factory to better override dnd properti…
…es (#2364) Signed-off-by: Ihor Dykhta <[email protected]> Co-authored-by: Giuseppe Macrì <[email protected]>
- Loading branch information
1 parent
673646a
commit c798961
Showing
18 changed files
with
248 additions
and
233 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -25,6 +25,7 @@ package-lock.json | |
|
||
npm-debug.log | ||
.history/ | ||
.yarn | ||
|
||
.pnp.* | ||
.yarn/* | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,151 @@ | ||
import React, {useCallback, useMemo, useState, PropsWithChildren} from 'react'; | ||
import styled from 'styled-components'; | ||
import {DndContext as DndKitContext, DragOverlay} from '@dnd-kit/core'; | ||
import {useDispatch} from 'react-redux'; | ||
import { | ||
DND_EMPTY_MODIFIERS, | ||
DND_MODIFIERS, | ||
DROPPABLE_MAP_CONTAINER_TYPE, | ||
SORTABLE_LAYER_TYPE, | ||
SORTABLE_SIDE_PANEL_TYPE | ||
} from '@kepler.gl/constants'; | ||
import {layerConfigChange, reorderLayer, toggleLayerForMap} from '@kepler.gl/actions'; | ||
import LayerPanelHeaderFactory from './side-panel/layer-panel/layer-panel-header'; | ||
import {withState} from './injector'; | ||
import {visStateLens} from '@kepler.gl/reducers'; | ||
import {reorderLayerOrder} from '@kepler.gl/reducers'; | ||
import {VisState} from '@kepler.gl/schemas'; | ||
import {Layer} from '@kepler.gl/layers'; | ||
|
||
export type DndContextProps = PropsWithChildren<{ | ||
visState: VisState; | ||
}>; | ||
|
||
export type DndContextComponent = React.FC<DndContextProps>; | ||
|
||
export const DragItem = styled.div` | ||
color: ${props => props.theme.textColorHl}; | ||
border-radius: ${props => props.theme.radioButtonRadius}px; | ||
padding: 5px 10px; | ||
display: inline; | ||
`; | ||
|
||
const nop = () => undefined; | ||
|
||
DndContextFactory.deps = [LayerPanelHeaderFactory]; | ||
|
||
function DndContextFactory( | ||
LayerPanelHeader: ReturnType<typeof LayerPanelHeaderFactory> | ||
): React.FC<PropsWithChildren> { | ||
const LayerPanelOverlay = ({layer, datasets}) => { | ||
const color = | ||
layer.config.dataId && datasets[layer.config.dataId] | ||
? datasets[layer.config.dataId].color | ||
: null; | ||
return ( | ||
<LayerPanelHeader | ||
isConfigActive={false} | ||
layerId={layer.id} | ||
isVisible={true} | ||
isValid={true} | ||
label={layer.config.label} | ||
labelRCGColorValues={color} | ||
onToggleVisibility={nop} | ||
onResetIsValid={nop} | ||
onUpdateLayerLabel={nop} | ||
onToggleEnableConfig={nop} | ||
onDuplicateLayer={nop} | ||
onRemoveLayer={nop} | ||
layerType={layer.type} | ||
allowDuplicate={false} | ||
isDragNDropEnabled={false} | ||
/> | ||
); | ||
}; | ||
|
||
const DndContext = ({children, visState}: DndContextProps) => { | ||
const {datasets, layerOrder, layers, splitMaps} = visState; | ||
|
||
const [activeLayer, setActiveLayer]: [ | ||
Layer | undefined, | ||
(l: Layer | undefined) => void | ||
] = useState(); | ||
|
||
const dispatch = useDispatch(); | ||
|
||
const isSplit = useMemo(() => splitMaps?.length > 1, [splitMaps]); | ||
const dndModifiers = useMemo(() => (isSplit ? DND_EMPTY_MODIFIERS : DND_MODIFIERS), [isSplit]); | ||
const onDragStart = useCallback( | ||
event => { | ||
const {active} = event; | ||
const newActiveLayer = layers.find(layer => layer.id === active.id); | ||
if (newActiveLayer) { | ||
setActiveLayer(newActiveLayer); | ||
|
||
if (newActiveLayer?.config.isConfigActive) { | ||
dispatch(layerConfigChange(newActiveLayer, {isConfigActive: false})); | ||
} | ||
} | ||
}, | ||
[dispatch, layers] | ||
); | ||
|
||
const onDragEnd = useCallback( | ||
event => { | ||
const {active, over} = event; | ||
|
||
const {id: activeLayerId} = active; | ||
const overType = over.data.current?.type; | ||
|
||
if (!overType) { | ||
setActiveLayer(undefined); | ||
return; | ||
} | ||
|
||
switch (overType) { | ||
// moving layers into maps | ||
case DROPPABLE_MAP_CONTAINER_TYPE: | ||
const mapIndex = over.data.current?.index ?? 0; | ||
dispatch(toggleLayerForMap(mapIndex, activeLayerId)); | ||
break; | ||
// swaping layers | ||
case SORTABLE_LAYER_TYPE: | ||
const newLayerOrder = reorderLayerOrder(layerOrder, activeLayerId, over.id); | ||
dispatch(reorderLayer(newLayerOrder)); | ||
break; | ||
// moving layers within side panel | ||
case SORTABLE_SIDE_PANEL_TYPE: | ||
// move layer to the end of the list | ||
dispatch( | ||
reorderLayer( | ||
reorderLayerOrder(layerOrder, activeLayerId, layerOrder[layerOrder.length - 1]) | ||
) | ||
); | ||
break; | ||
default: | ||
break; | ||
} | ||
|
||
setActiveLayer(undefined); | ||
}, | ||
[dispatch, layerOrder] | ||
); | ||
|
||
return ( | ||
<DndKitContext onDragStart={onDragStart} onDragEnd={onDragEnd} modifiers={dndModifiers}> | ||
{children} | ||
{activeLayer ? ( | ||
<DragOverlay modifiers={dndModifiers} dropAnimation={null}> | ||
<DragItem> | ||
<LayerPanelOverlay layer={activeLayer} datasets={datasets} /> | ||
</DragItem> | ||
</DragOverlay> | ||
) : null} | ||
</DndKitContext> | ||
); | ||
}; | ||
|
||
return withState([visStateLens], state => state)(DndContext) as React.FC<PropsWithChildren>; | ||
} | ||
|
||
export default DndContextFactory; |
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.