Back to Nocobase

CollectionManager

packages/core/client/src/collection-manager/index.md

2.0.482.9 KB
Original Source

CollectionManager

Components

CollectionManagerProvider_deprecated

jsx
<CollectionManagerProvider_deprecated interfaces={{}} collections={[]}></CollectionManagerProvider_deprecated>

CollectionProvider

jsx
const collection = {
  name: 'tests',
  fields: [
    {
      type: 'string',
      name: 'title',
      interface: 'input',
      uiSchema: {
        type: 'string',
        'x-component': 'Input'
      },
    },
  ],
};
<CollectionProvider collection={collection}></CollectionProvider>

如果没有传 collection 参数,从 CollectionManagerProvider_deprecated 里取对应 name 的 collection。

jsx
const collections = [
  {
    name: 'tests',
    fields: [
      {
        type: 'string',
        name: 'title',
        interface: 'input',
        uiSchema: {
          type: 'string',
          'x-component': 'Input'
        },
      },
    ],
  }
];
<CollectionManagerProvider_deprecated collections={collections}>
  <CollectionProvider name={'tests'}></CollectionProvider>
</CollectionManagerProvider_deprecated>

CollectionFieldProvider

jsx
const field = {
  type: 'string',
  name: 'title',
  interface: 'input',
  uiSchema: {
    type: 'string',
    'x-component': 'Input'
  },
};
<CollectionFieldProvider field={field}></CollectionFieldProvider>

如果没有传 field 参数,从 CollectionProvider 里取对应 name 的 field。

jsx
const collection = {
  name: 'tests',
  fields: [
    {
      type: 'string',
      name: 'title',
      interface: 'input',
      uiSchema: {
        type: 'string',
        'x-component': 'Input'
      },
    },
  ],
};
<CollectionProvider collection={collection}>
  <CollectionFieldProvider name={'title'}></CollectionFieldProvider>
</CollectionProvider>

CollectionField

万能字段组件,需要与 <CollectionProvider/> 搭配使用,仅限于在 Schema 场景使用。从 CollectionProvider 里取对应 name 的 field schema。可通过 CollectionField 所在的 schema 扩展配置。

ts
{
  name: 'title',
  'x-decorator': 'FormItem',
  'x-decorator-props': {},
  'x-component': 'CollectionField',
  'x-component-props': {},
  properties: {},
}

<code src="./demos/demo2.tsx"></code>

Hooks

useCollectionManager_deprecated()

<CollectionManagerProvider_deprecated/> 搭配使用

jsx
const { collections, get } = useCollectionManager_deprecated();

useCollection()

<CollectionProvider/> 搭配使用

jsx
const { name, fields, getField, findField, resource } = useCollection();

useCollectionField()

<CollectionFieldProvider/> 搭配使用

jsx
const { name, uiSchema, resource } = useCollectionField();

resource 需要与 <CollectionRecordProvider/> 搭配使用,用于提供当前数据表行记录的上下文。如:

<code src="./demos/demo3.tsx"></code> <code src="./demos/demo4.tsx"></code>

Initializer

<code src="./demos/demo5.tsx"></code>