mirror of
https://gitee.com/nocobase/nocobase.git
synced 2025-05-08 15:09:27 +08:00
* refactor: plugin manager page * fix: bug * feat: addByNpm api * fix: improve the addByNpm * feat: improve applicationPlugins:list api * fix: re-download npm package when restart app * fix: plugin delete api * feat: plugin detail api * feat: zipUrl add api * fix: upload api bug * fix: plugin detail info * feat: upgrade api * fix: upload api * feat: handle plugin load error * feat: support authToken * feat: muti lang * fix: build error * fix: self review * Update plugin-manager.ts * fix: bug * fix: bug * fix: bug * fix: bug * fix: bug * fix: bugs * fix: detail click and remove isOfficial * fix: upgrade no refresh * fix: file size and type check * fix: bug * fix: upgrade error * fix: bug * fix: bug * fix: plugin card layout * fix: handling exceptional cases * fix: tgz file support * fix: macos compress file * fix: bug * fix: bug * fix: bug * fix: bug * fix: add upgrade npm type * fix: bugs * fix: bug * fix: change plugins static expose url * fix: api prefix * fix: bug * fix: add nginx `/static/plugin/` path * fix: bugs and pr docker build no dts * fix: bug * fix: build tools bug * fix: improve code * fix: build bug * feat: improve plugin info * fix: ui bug * fix: plugin document bug * feat: improve code * feat: improve code * feat: process dev deps check * feat: improve code * feat: process.env.IS_DEV_CMD * fix: do not delete the plugin package * feat: plugin symlink * fix: tsx watch --ignore=./storage/plugins/** * fix: test error * fix: improve code * fix: improve code * fix: emitStartedEvent * fix: improve code * fix: type error * fix: test error * test: console.log * fix: createStoragePluginSymLink * fix: clientStaticMiddleware rename to clientStaticUtils * feat: build tools support plugins folder * fix: 350px * fix: error * feat: client dev support plugin folder * fix: clear cli options * fix: typeError: Converting circular structure to JSON * fix: plugin name * chore: restart application after command * feat: upgrade error & docs * Update v14-changelog.md * Update v14-changelog.md * Update v14-changelog.md * fix: gateway test * refactor(plugin-workflow): add ready state for gracefully tearing down * Revert "chore: restart application after command" This reverts commit 5015274f8e4e06e506e15754b672330330e8c7f8. * chore: stop application whe restart * T 1218 change plugin folder (#2629) * feat: change folder name * feat: change `pm create` command * feat: revert plugin name change * fix: delete samples * feat: change plugins folder * fix: pm create * feat: update docs * fix: link package error * fix: docs * fix: create command * fix: pm add error * fix: create add build * fix: pm creatre + add * feat: add tar command * fix: docs * fix: bug * fix: docs --------- Co-authored-by: chenos <chenlinxh@gmail.com> * feat: docs * Update your-fisrt-plugin.md * Update your-fisrt-plugin.md * chore: application reload * chore: test * fix: pm add error * chore: preset install skip exists plugin * fix: createIfNotExists --------- Co-authored-by: chenos <chenlinxh@gmail.com> Co-authored-by: chareice <chareice@live.com> Co-authored-by: Zhou <zhou.working@gmail.com> Co-authored-by: mytharcher <mytharcher@gmail.com>
130 lines
3.9 KiB
TypeScript
130 lines
3.9 KiB
TypeScript
import type { VoidField } from '@formily/core';
|
|
import { Cascader, css, useCollection } from '@nocobase/client';
|
|
import { useTranslation } from 'react-i18next';
|
|
import { NAMESPACE } from './constants';
|
|
import { useFields } from './useFields';
|
|
|
|
const INCLUDE_FILE_TYPE = [
|
|
'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
|
|
'application/vnd.ms-excel',
|
|
];
|
|
|
|
export const useShared = () => {
|
|
const { t } = useTranslation(NAMESPACE);
|
|
const { name } = useCollection();
|
|
const fields = useFields(name);
|
|
return {
|
|
importSettingsSchema: {
|
|
type: 'void',
|
|
'x-component': 'Grid',
|
|
properties: {
|
|
explain: {
|
|
type: 'string',
|
|
title: `{{ t("Import explain", {ns: "${NAMESPACE}"}) }}`,
|
|
'x-decorator': 'FormItem',
|
|
'x-component': 'Input.TextArea',
|
|
},
|
|
importColumns: {
|
|
type: 'array',
|
|
'x-component': 'ArrayItems',
|
|
'x-decorator': 'FormItem',
|
|
items: {
|
|
type: 'object',
|
|
properties: {
|
|
space: {
|
|
type: 'void',
|
|
'x-component': 'Space',
|
|
'x-component-props': {
|
|
className: css`
|
|
width: 100%;
|
|
& .ant-space-item:nth-child(2) {
|
|
flex: 1;
|
|
}
|
|
`,
|
|
},
|
|
properties: {
|
|
sort: {
|
|
type: 'void',
|
|
'x-decorator': 'FormItem',
|
|
'x-component': 'ArrayItems.SortHandle',
|
|
},
|
|
dataIndex: {
|
|
type: 'array',
|
|
'x-decorator': 'FormItem',
|
|
'x-component': Cascader,
|
|
required: true,
|
|
enum: fields,
|
|
'x-component-props': {
|
|
fieldNames: {
|
|
label: 'title',
|
|
value: 'name',
|
|
children: 'children',
|
|
},
|
|
changeOnSelect: false,
|
|
},
|
|
},
|
|
remove: {
|
|
type: 'void',
|
|
'x-decorator': 'FormItem',
|
|
'x-component': 'ArrayItems.Remove',
|
|
},
|
|
},
|
|
},
|
|
},
|
|
},
|
|
properties: {
|
|
add: {
|
|
type: 'void',
|
|
title: `{{ t("Add importable field", {ns: "${NAMESPACE}"}) }}`,
|
|
'x-component': 'ArrayItems.Addition',
|
|
'x-component-props': {
|
|
className: css`
|
|
border-color: var(--colorSettings);
|
|
color: var(--colorSettings);
|
|
&.ant-btn-dashed:hover {
|
|
border-color: var(--colorSettings);
|
|
color: var(--colorSettings);
|
|
}
|
|
`,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
},
|
|
},
|
|
beforeUploadHandler() {
|
|
return false;
|
|
},
|
|
uploadValidator(value, rule) {
|
|
if (value.length > 1) {
|
|
return {
|
|
type: 'error',
|
|
message: t('Only one file is allowed to be uploaded'),
|
|
};
|
|
}
|
|
const file = value[0] ?? {};
|
|
if (file.size > 10 * 1024 * 1024) {
|
|
return {
|
|
type: 'error',
|
|
message: t('File size cannot exceed 10M'),
|
|
};
|
|
}
|
|
if (!INCLUDE_FILE_TYPE.includes(file.type)) {
|
|
return {
|
|
type: 'error',
|
|
message: t('Please upload the file of Excel'),
|
|
};
|
|
}
|
|
return '';
|
|
},
|
|
validateUpload(form, submitField: VoidField, deps) {
|
|
const [upload] = deps;
|
|
submitField.disabled = upload?.length === 0;
|
|
submitField.componentProps = {
|
|
...submitField.componentProps,
|
|
disabled: upload?.length === 0 || form.errors?.length > 0,
|
|
};
|
|
},
|
|
};
|
|
};
|