refactor: filter out the node itself when selecting parent

This commit is contained in:
katherinehhh 2023-03-16 10:50:07 +08:00
parent e02e4f6c4f
commit 3d2d73a221
3 changed files with 23 additions and 8 deletions

View File

@ -1,11 +1,10 @@
import { ArrayField } from '@formily/core'; import { ArrayField } from '@formily/core';
import { Schema, useField, useFieldSchema } from '@formily/react'; import { Schema, useField, useFieldSchema } from '@formily/react';
import uniq from 'lodash/uniq'; import uniq from 'lodash/uniq';
import React, { createContext, useContext, useEffect } from 'react'; import React, { createContext, useContext, useEffect, useState } from 'react';
import { useCollectionManager } from '../collection-manager'; import { useCollectionManager } from '../collection-manager';
import { RecordProvider, useRecord } from '../record-provider'; import { RecordProvider, useRecord } from '../record-provider';
import { BlockProvider, RenderChildrenWithAssociationFilter, useBlockRequestContext } from './BlockProvider'; import { BlockProvider, RenderChildrenWithAssociationFilter, useBlockRequestContext } from './BlockProvider';
import { useFormBlockContext } from './FormBlockProvider';
export const TableSelectorContext = createContext<any>({}); export const TableSelectorContext = createContext<any>({});
@ -13,6 +12,7 @@ const InternalTableSelectorProvider = (props) => {
const { params, rowKey, extraFilter } = props; const { params, rowKey, extraFilter } = props;
const field = useField(); const field = useField();
const { resource, service } = useBlockRequestContext(); const { resource, service } = useBlockRequestContext();
const [expandFlag, setExpandFlag] = useState(false);
// if (service.loading) { // if (service.loading) {
// return <Spin />; // return <Spin />;
// } // }
@ -26,6 +26,10 @@ const InternalTableSelectorProvider = (props) => {
params, params,
extraFilter, extraFilter,
rowKey, rowKey,
expandFlag,
setExpandFlag: () => {
setExpandFlag(!expandFlag);
},
}} }}
> >
<RenderChildrenWithAssociationFilter {...props} /> <RenderChildrenWithAssociationFilter {...props} />

View File

@ -10,7 +10,13 @@ import { default as classNames, default as cls } from 'classnames';
import React, { RefCallback, useCallback, useEffect, useMemo, useRef, useState } from 'react'; import React, { RefCallback, useCallback, useEffect, useMemo, useRef, useState } from 'react';
import { useTranslation } from 'react-i18next'; import { useTranslation } from 'react-i18next';
import { DndContext, useDesignable } from '../..'; import { DndContext, useDesignable } from '../..';
import { RecordIndexProvider, RecordProvider, useSchemaInitializer, useTableBlockContext } from '../../../'; import {
RecordIndexProvider,
RecordProvider,
useSchemaInitializer,
useTableBlockContext,
useTableSelectorContext,
} from '../../../';
import { useACLFieldWhitelist } from '../../../acl/ACLProvider'; import { useACLFieldWhitelist } from '../../../acl/ACLProvider';
import { isCollectionFieldComponent, isColumnComponent, extractIndex, getIdsWithChildren } from './utils'; import { isCollectionFieldComponent, isColumnComponent, extractIndex, getIdsWithChildren } from './utils';
@ -162,12 +168,14 @@ export const Table: any = observer((props: any) => {
required, required,
...others ...others
} = { ...others1, ...others2 } as any; } = { ...others1, ...others2 } as any;
const { expandFlag } = useTableBlockContext(); const schema = useFieldSchema();
const isTableSelector = schema?.parent?.['x-decorator'] === 'TableSelectorProvider';
const ctx = isTableSelector ? useTableSelectorContext() : useTableBlockContext();
const { expandFlag } = ctx;
const onRowDragEnd = useMemoizedFn(others.onRowDragEnd || (() => {})); const onRowDragEnd = useMemoizedFn(others.onRowDragEnd || (() => {}));
const paginationProps = usePaginationProps(pagination1, pagination2); const paginationProps = usePaginationProps(pagination1, pagination2);
const requiredValidator = field.required || required; const requiredValidator = field.required || required;
const schema = useFieldSchema(); const { treeTable } = schema?.parent?.['x-decorator-props'] || {};
const { treeTable } = schema?.parent?.['x-decorator-props']||{};
const [expandedKeys, setExpandesKeys] = useState([]); const [expandedKeys, setExpandesKeys] = useState([]);
const [allIncludesChildren, setAllIncludesChildren] = useState([]); const [allIncludesChildren, setAllIncludesChildren] = useState([]);
useEffect(() => { useEffect(() => {

View File

@ -2,8 +2,9 @@ import React from 'react';
import { Button } from 'antd'; import { Button } from 'antd';
import { css } from '@emotion/css'; import { css } from '@emotion/css';
import { useTranslation } from 'react-i18next'; import { useTranslation } from 'react-i18next';
import { useFieldSchema } from '@formily/react';
import { ActionInitializer } from './ActionInitializer'; import { ActionInitializer } from './ActionInitializer';
import { useTableBlockContext } from '../../'; import { useTableBlockContext, useTableSelectorContext } from '../../';
import { NodeCollapseOutlined, NodeExpandOutlined } from '@ant-design/icons'; import { NodeCollapseOutlined, NodeExpandOutlined } from '@ant-design/icons';
export const ExpandActionInitializer = (props) => { export const ExpandActionInitializer = (props) => {
@ -66,7 +67,9 @@ const actionDesignerCss = css`
export const ExpandActionComponent = (props) => { export const ExpandActionComponent = (props) => {
const { t } = useTranslation(); const { t } = useTranslation();
const ctx = useTableBlockContext(); const schema = useFieldSchema();
const isTableSelector = schema.parent?.parent?.['x-decorator'] === 'TableSelectorProvider';
const ctx = isTableSelector ? useTableSelectorContext() : useTableBlockContext();
return ( return (
<div className={actionDesignerCss}> <div className={actionDesignerCss}>
{ctx.params['tree'] && ( {ctx.params['tree'] && (