mirror of
https://github.com/nocobase/nocobase
synced 2024-11-15 18:46:55 +00:00
62b2b5c68b
* fix: add license code * fix: bug * fix: bug * fix: upgrade * fix: improve * chore: add copyright information to the file header * fix: d.ts bug * fix: bug * fix: e2e bug * fix: merge main --------- Co-authored-by: chenos <chenlinxh@gmail.com>
67 lines
2.4 KiB
TypeScript
67 lines
2.4 KiB
TypeScript
/**
|
|
* This file is part of the NocoBase (R) project.
|
|
* Copyright (c) 2020-2024 NocoBase Co., Ltd.
|
|
* Authors: NocoBase Team.
|
|
*
|
|
* This project is dual-licensed under AGPL-3.0 and NocoBase Commercial License.
|
|
* For more information, please refer to: https://www.nocobase.com/agreement.
|
|
*/
|
|
|
|
import { onFieldInputValueChange, onFormInitialValuesChange } from '@formily/core';
|
|
import { connect, mapReadPretty, observer, useField, useForm, useFormEffects } from '@formily/react';
|
|
import { Tag } from 'antd';
|
|
import React, { useMemo, useState } from 'react';
|
|
import { useTranslation } from 'react-i18next';
|
|
|
|
import { useCollectionManager_deprecated, useCompile, useRecord, Variable } from '@nocobase/client';
|
|
import { getCollectionFieldOptions } from '@nocobase/plugin-workflow/client';
|
|
|
|
import { NAMESPACE } from '../locale';
|
|
|
|
const InternalExpression = observer(
|
|
(props: any) => {
|
|
const { onChange } = props;
|
|
const field = useField<any>();
|
|
// TODO(refactor): better to provide another context like useFieldset()
|
|
const form = useForm();
|
|
const basePath = field.path.segments.slice(0, -1);
|
|
const collectionPath = [...basePath, 'sourceCollection'].join('.');
|
|
const [collection, setCollection] = useState(form.getValuesIn(collectionPath));
|
|
const compile = useCompile();
|
|
const { getCollectionFields } = useCollectionManager_deprecated();
|
|
|
|
useFormEffects(() => {
|
|
onFormInitialValuesChange((form) => {
|
|
setCollection(form.getValuesIn(collectionPath));
|
|
});
|
|
onFieldInputValueChange(collectionPath, (f) => {
|
|
setCollection(f.value);
|
|
onChange(null);
|
|
});
|
|
});
|
|
|
|
const options = getCollectionFieldOptions({ collection, compile, getCollectionFields });
|
|
|
|
return <Variable.TextArea {...props} scope={options} />;
|
|
},
|
|
{ displayName: 'InternalExpression' },
|
|
);
|
|
|
|
function Result(props) {
|
|
const { t } = useTranslation();
|
|
const values = useRecord();
|
|
const compile = useCompile();
|
|
const { getCollectionFields } = useCollectionManager_deprecated();
|
|
const options = useMemo(
|
|
() => getCollectionFieldOptions({ collection: values.sourceCollection, compile, getCollectionFields }),
|
|
[values.sourceCollection, values.sourceCollection],
|
|
);
|
|
return props.value ? (
|
|
<Variable.TextArea {...props} scope={options} />
|
|
) : (
|
|
<Tag>{t('Unconfigured', { ns: NAMESPACE })}</Tag>
|
|
);
|
|
}
|
|
|
|
export const DynamicExpression = connect(InternalExpression, mapReadPretty(Result));
|