mirror of
https://github.com/labring/FastGPT.git
synced 2025-07-23 21:13:50 +00:00

* feat: plugin run (#1950) * feat: plugin run * fix * ui * fix * change user input type * fix * fix * temp * split out plugin chat * perf: chatbox * perf: chatbox * fix: plugin runtime (#2032) * fix: plugin runtime * fix * fix build * fix build * perf: chat send prompt * perf: chat log ux * perf: chatbox context and share page plugin runtime * perf: plugin run time config * fix: ts * feat: doc * perf: isPc check * perf: variable input render * feat: app search * fix: response box height * fix: phone ui * perf: lock * perf: plugin route * fix: chat (#2049) --------- Co-authored-by: heheer <71265218+newfish-cmyk@users.noreply.github.com>
61 lines
1.6 KiB
TypeScript
61 lines
1.6 KiB
TypeScript
import { Box } from '@chakra-ui/react';
|
|
import React, { useState } from 'react';
|
|
import {
|
|
DragDropContext,
|
|
DroppableProps,
|
|
Droppable,
|
|
DraggableChildrenFn,
|
|
DragStart,
|
|
DropResult
|
|
} from 'react-beautiful-dnd';
|
|
export * from 'react-beautiful-dnd';
|
|
|
|
type Props<T = any> = {
|
|
onDragEndCb: (result: T[]) => void;
|
|
renderClone?: DraggableChildrenFn;
|
|
children: DroppableProps['children'];
|
|
dataList: T[];
|
|
};
|
|
|
|
function DndDrag<T>({ children, renderClone, onDragEndCb, dataList }: Props<T>) {
|
|
const [draggingItemHeight, setDraggingItemHeight] = useState(0);
|
|
|
|
const onDragStart = (start: DragStart) => {
|
|
const draggingNode = document.querySelector(`[data-rbd-draggable-id="${start.draggableId}"]`);
|
|
setDraggingItemHeight(draggingNode?.getBoundingClientRect().height || 0);
|
|
};
|
|
|
|
const onDragEnd = (result: DropResult) => {
|
|
if (!result.destination) {
|
|
return;
|
|
}
|
|
setDraggingItemHeight(0);
|
|
|
|
const startIndex = result.source.index;
|
|
const endIndex = result.destination.index;
|
|
|
|
const list = Array.from(dataList);
|
|
const [removed] = list.splice(startIndex, 1);
|
|
list.splice(endIndex, 0, removed);
|
|
|
|
onDragEndCb(list);
|
|
};
|
|
|
|
return (
|
|
<DragDropContext onDragStart={onDragStart} onDragEnd={onDragEnd}>
|
|
<Droppable droppableId="droppable" renderClone={renderClone}>
|
|
{(provided, snapshot) => {
|
|
return (
|
|
<Box {...provided.droppableProps} ref={provided.innerRef}>
|
|
{children(provided, snapshot)}
|
|
{snapshot.isDraggingOver && <Box height={draggingItemHeight} />}
|
|
</Box>
|
|
);
|
|
}}
|
|
</Droppable>
|
|
</DragDropContext>
|
|
);
|
|
}
|
|
|
|
export default DndDrag;
|