refactor: 移动群组面板管理到独立文件夹

pull/13/head
moonrailgun 4 years ago
parent 34e554ae9c
commit a2ed9363e5

@ -1,19 +1,16 @@
import React, { useCallback, useMemo, useRef, useState } from 'react'; import React, { useCallback, useMemo, useRef } from 'react';
import { import {
GroupPanelType, GroupPanelType,
useGroupInfo,
GroupPanel as GroupPanelInfo, GroupPanel as GroupPanelInfo,
showToasts, showToasts,
t,
} from 'tailchat-shared'; } from 'tailchat-shared';
import { Button, Tree } from 'antd'; import { Tree } from 'antd';
import type { NodeDragEventParams } from 'rc-tree/lib/contextTypes'; import type { NodeDragEventParams } from 'rc-tree/lib/contextTypes';
import type { DataNode, EventDataNode } from 'antd/lib/tree'; import type { DataNode, EventDataNode } from 'antd/lib/tree';
import type { Key } from 'rc-tree/lib/interface'; import type { Key } from 'rc-tree/lib/interface';
import type { AllowDrop } from 'rc-tree/lib/Tree'; import type { AllowDrop } from 'rc-tree/lib/Tree';
import _cloneDeep from 'lodash/cloneDeep'; import _cloneDeep from 'lodash/cloneDeep';
import _isNil from 'lodash/isNil'; import _isNil from 'lodash/isNil';
import _isEqual from 'lodash/isEqual';
/** /**
* *
@ -65,7 +62,7 @@ interface GroupPanelTree {
/** /**
* *
*/ */
const GroupPanelTree: React.FC<GroupPanelTree> = React.memo((props) => { export const GroupPanelTree: React.FC<GroupPanelTree> = React.memo((props) => {
const draggingNode = useRef<DataNode | null>(null); const draggingNode = useRef<DataNode | null>(null);
const treeData: DataNode[] = useMemo( const treeData: DataNode[] = useMemo(
() => buildTreeDataWithGroupPanel(props.groupPanels), () => buildTreeDataWithGroupPanel(props.groupPanels),
@ -192,36 +189,3 @@ const GroupPanelTree: React.FC<GroupPanelTree> = React.memo((props) => {
); );
}); });
GroupPanelTree.displayName = 'GroupPanelTree'; GroupPanelTree.displayName = 'GroupPanelTree';
export const GroupPanel: React.FC<{
groupId: string;
}> = React.memo((props) => {
const groupId = props.groupId;
const groupInfo = useGroupInfo(groupId);
const groupPanels = groupInfo?.panels ?? [];
const [editingGroupPanels, setEditingGroupPanels] = useState(groupPanels);
const handleChange = useCallback((newGroupPanels: GroupPanelInfo[]) => {
setEditingGroupPanels(newGroupPanels);
}, []);
const handleSave = useCallback(() => {
console.log('editingGroupPanels', editingGroupPanels);
}, [editingGroupPanels]);
return (
<div>
<GroupPanelTree
groupPanels={editingGroupPanels}
onChange={handleChange}
/>
{!_isEqual(groupPanels, editingGroupPanels) && (
<Button className="mt-2" onClick={handleSave}>
{t('保存')}
</Button>
)}
</div>
);
});
GroupPanel.displayName = 'GroupPanel';

@ -0,0 +1,38 @@
import React, { useCallback, useState } from 'react';
import { useGroupInfo, GroupPanel as GroupPanelInfo, t } from 'tailchat-shared';
import { Button } from 'antd';
import _isEqual from 'lodash/isEqual';
import { GroupPanelTree } from './GroupPanelTree';
export const GroupPanel: React.FC<{
groupId: string;
}> = React.memo((props) => {
const groupId = props.groupId;
const groupInfo = useGroupInfo(groupId);
const groupPanels = groupInfo?.panels ?? [];
const [editingGroupPanels, setEditingGroupPanels] = useState(groupPanels);
const handleChange = useCallback((newGroupPanels: GroupPanelInfo[]) => {
setEditingGroupPanels(newGroupPanels);
}, []);
const handleSave = useCallback(() => {
console.log('editingGroupPanels', editingGroupPanels);
}, [editingGroupPanels]);
return (
<div>
<GroupPanelTree
groupPanels={editingGroupPanels}
onChange={handleChange}
/>
{!_isEqual(groupPanels, editingGroupPanels) && (
<Button className="mt-2" onClick={handleSave}>
{t('保存')}
</Button>
)}
</div>
);
});
GroupPanel.displayName = 'GroupPanel';
Loading…
Cancel
Save