mirror of
https://gitee.com/nocobase/nocobase.git
synced 2025-05-06 14:09:25 +08:00
* refactor: support api datasource * refactor: support api datasource * refactor: support api datasource * feat: url support preview (#4559) * feat: url support preview * feat: add settings for Input.Preview * refactor: refactor CollectionField.tsx to use dynamic component * Revert "refactor: refactor CollectionField.tsx to use dynamic component" This reverts commit 37719eb28e5866762459da3b269288340a21b661. * test: add e2e test * refactor(e2e): extract template --------- Co-authored-by: Zeke Zhang <958414905@qq.com> * fix(map): amap reset (#4574) * chore: volta node version * chore: data source api * refactor: support api datasource * chore: data source api * chore: data source api * chore: field options * refactor: support api data source * refactor: support api data source * refactor: support api data source * refactor: support api data source * refactor: support api data source * refactor: support api data source * refactor: support api data source * fix: load data source fields * refactor: support api data source * feat(data-vi): support for using url params and current role variables (#4586) * feat(data-vi): support for using url params and current role variable * fix: bug * fix(variable): should remove through collection field (#4590) * fix: style issues for gridCard in mobile client (#4593) * fix: style issiues for gridCard in mobile client * fix: bug * fix: bug * fix: bug * fix: style issues for gridCard in mobile client (#4599) * fix: style issiues for gridCard in mobile client * fix: bug * fix: bug * fix: bug * fix: style improve * chore: update lerna * chore(versions): 😊 publish v1.0.1-alpha.1 * chore: update changelog * chore: fix typo (#4589) * feat(plugin-workflow-smtp-mailer): add new plugin for sending email in workflow (#4584) * feat(plugin-workflow-smtp-mailer): add new plugin for sending email in workflow * refactor(plugin-workflow-mailer): change plugin name and locales * fix(plugin-workflow-mailer): fix parameters * fix(preset): add new plugin to preset * fix(plugin-workflow-mailer): fix locale namespace * fix: iframe block loses height when set to default (#4602) * fix: iframe block loses height when set to default * refactor: local improve * feat(client): allow JSON5 value in Form Input of type JSONTextArea (#4600) * feat(client): allow json5 value in form-item type json component * test: fix tests * chore: set json5 default as false * chore: add demo --------- Co-authored-by: xilesun <2013xile@gmail.com> * fix: remove grid wrap (#4612) * refactor(plugin-workflow): change variable getter from collection fields (#4567) * refactor(plugin-workflow): change variable getter from collection fields * fix(plugin-workflow): fix import * chore(plugin-workflow-action-trigger): remove unused import * fix(plugin-workflow): fix collection field in workflow variable * refactor(plugin-workflow-manual): avoid tslint error * fix(client): fix text wrap in variable input (#4605) * fix(client): fix text wrap in variable input * fix(client): revert css * feat(tree-block): support filtering child nodes (#4603) * feat(tree-block): support filtering child nodes * test: add list test * test: remove only * fix: use isValidFilter * fix(export): export button remaining in loading state after cancel (#4615) * chore: rebase * chore: collection option * fix: update data source fields * chore: console.log * refactor: support api data source * fix: data source test * fix: sync field in data source * chore: unavailableActions in collection option * chore: unavailableActions in data source collections * chore: file collection unavailableActions * fix: test * chore: unavailableActions in actionInitializers * fix: bug * fix: destroy action * chore: unavailableActions in plugin actionInitializers * fix: view * chore: unavailableActions in actionInitializers * fix: missing removeCollection * chore: test name * fix: bug * fix: bug * chore: test * refactor: availableTypes * refactor: availableTypes * chore: datasource options * refactor: get current data source * refactor: code improve * fix: update collection with fields * refactor: code improve * refactor: code improve * refactor: code improve * refactor: code improve * chore: datasource logger * chore: export Schema * refactor: rawTextArea * refactor: loadFilterTargetKeys in external data source * chore: unavailableFunctions * refactor: support unAvailableFunctions * refactor: support unAvailableFunctions * refactor: support unAvailableFunctions * refactor: support unAvailableFunctions * refactor: support unAvailableFunctions * revert: unavailableFunctions * refactor: code improve * fix: test * chore: operation * chore: operation * fix: input support json field * refactor: blockInitializers support unavailableActions * chore: availableActions * chore: availableActions * refactor: support availableActions * refactor: support availableActions * chore: magic model test case * fix: unixTimestamp support integer * fix: disassociate * fix: input readPretty * fix: resolve error when opening modal via URL * style: input readPretty style improve * chore: support simple pagination * chore: skip test * refactor: details support pagination * refactor: details support pagination * chore: useActionAvailable * fix: bug * test: fix test * fix: detailsBlockInitializer useActionAvailable * chore: fix unit test * refactor: pagination * refactor: pagination * test: fix test --------- Co-authored-by: katherinehhh <katherine_15995@163.com> Co-authored-by: chenos <chenlinxh@gmail.com> Co-authored-by: Zeke Zhang <958414905@qq.com> Co-authored-by: YANG QIA <2013xile@gmail.com> Co-authored-by: Katherine <shunai.tang@hand-china.com> Co-authored-by: GitHub Actions Bot <actions@github.com> Co-authored-by: Junyi <mytharcher@users.noreply.github.com> Co-authored-by: David Fecke <david.fecke@eyecook.net>
118 lines
2.9 KiB
TypeScript
118 lines
2.9 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.
|
|
*/
|
|
|
|
/* istanbul ignore file -- @preserve */
|
|
|
|
import { Database } from '@nocobase/database';
|
|
import {
|
|
CollectionOptions,
|
|
ICollection,
|
|
ICollectionManager,
|
|
IFieldInterface,
|
|
IRepository,
|
|
MergeOptions,
|
|
} from './types';
|
|
|
|
export class SequelizeCollectionManager implements ICollectionManager {
|
|
db: Database;
|
|
options: any;
|
|
|
|
constructor(options) {
|
|
this.db = this.createDB(options);
|
|
this.options = options;
|
|
}
|
|
|
|
collectionsFilter() {
|
|
if (this.options.collectionsFilter) {
|
|
return this.options.collectionsFilter;
|
|
}
|
|
|
|
return (collection) => {
|
|
return collection.options.introspected;
|
|
};
|
|
}
|
|
|
|
createDB(options: any = {}) {
|
|
if (options.database instanceof Database) {
|
|
return options.database;
|
|
}
|
|
|
|
return new Database(options);
|
|
}
|
|
|
|
registerFieldTypes(types: Record<string, any>) {
|
|
this.db.registerFieldTypes(types);
|
|
}
|
|
|
|
registerFieldInterfaces() {}
|
|
|
|
registerCollectionTemplates() {}
|
|
|
|
registerModels(models: Record<string, any>) {
|
|
return this.db.registerModels(models);
|
|
}
|
|
|
|
registerRepositories(repositories: Record<string, any>) {
|
|
return this.db.registerModels(repositories);
|
|
}
|
|
|
|
getRegisteredRepository(key: any) {
|
|
if (typeof key !== 'string') {
|
|
return key;
|
|
}
|
|
return this.db.repositories.get(key);
|
|
}
|
|
|
|
defineCollection(options: CollectionOptions) {
|
|
const collection = this.db.collection(options);
|
|
// @ts-ignore
|
|
collection.model.refreshAttributes();
|
|
|
|
// @ts-ignore
|
|
collection.model._findAutoIncrementAttribute();
|
|
return collection;
|
|
}
|
|
|
|
extendCollection(collectionOptions: CollectionOptions, mergeOptions?: MergeOptions): ICollection {
|
|
return this.db.extendCollection(collectionOptions, mergeOptions) as unknown as ICollection;
|
|
}
|
|
|
|
hasCollection(name: string) {
|
|
return this.db.hasCollection(name);
|
|
}
|
|
|
|
getCollection(name: string) {
|
|
return this.db.getCollection(name);
|
|
}
|
|
|
|
removeCollection(name: string) {}
|
|
|
|
getCollections() {
|
|
const collectionsFilter = this.collectionsFilter();
|
|
|
|
return [...this.db.collections.values()].filter((collection) => collectionsFilter(collection));
|
|
}
|
|
|
|
getRepository<R = IRepository>(name: string, sourceId?: string | number): R {
|
|
return this.db.getRepository(name, sourceId) as R;
|
|
}
|
|
|
|
async sync() {
|
|
await this.db.sync();
|
|
}
|
|
|
|
registerFieldInterface(name: string, fieldInterface: new (options: any) => IFieldInterface): void {
|
|
this.db.interfaceManager.registerInterfaceType(name, fieldInterface);
|
|
}
|
|
|
|
getFieldInterface(name: string): { new (options: any): IFieldInterface | undefined } {
|
|
return this.db.interfaceManager.getInterfaceType(name);
|
|
}
|
|
}
|