mirror of
https://gitee.com/nocobase/nocobase.git
synced 2025-05-09 07:29:24 +08:00
* create-nocobase-app template from [develop] * change create-nocobase-app package.json config * feat: load configuration from directory * feat: configuration repository toObject * feat: create application from configuration dir * feat: application factory with plugins options * export type * feat: read application config & application with plugins options * feat: release command * fix: database release * chore: workflow package.json * feat: nocobase cli package * feat: console command * chore: load application in command * fix: load packages from process.cwd * feat: cli load env file * feat: create-nocobase-app * fix: gitignore create-nocobase-app lib * fix: sqlite path * feat: create plugin * chore: plugin files template * chore: move cli into application * chore: create-nocobase-app * fix: create plugin * chore: app-client && app-server * chore: package.json * feat: create-nocobase-app download template from npm * chore: create-nocobase-app template * fix: config of plugin-users * fix: yarn.lock * fix: database build error * fix: yarn.lock * fix: resourcer config * chore: cross-env * chore: app-client dependents * fix: env * chore: v0.6.0-alpha.1 * chore: verdaccio * chore(versions): 😊 publish v0.6.0 * chore(versions): 😊 publish v0.6.1-alpha.0 * chore(versions): 😊 publish v0.6.2-alpha.0 * chore(versions): 😊 publish v0.6.2-alpha.1 * chore: 0.6.2-alpha.2 * feat: workspaces * chore(versions): 😊 publish v0.6.2-alpha.3 * chore(versions): 😊 publish v0.6.2-alpha.4 * chore: create-nocobase-app * chore: create-nocobase-app lib * fix: update tsconfig.jest.json * chore: .env * chore(versions): 😊 publish v0.6.2-alpha.5 * chore(versions): 😊 publish v0.6.2-alpha.6 * feat: improve code * chore(versions): 😊 publish v0.6.2-alpha.7 * fix: cleanup * chore(versions): 😊 publish v0.6.2-alpha.8 * chore: tsconfig for app server package * fix: move files * fix: move files Co-authored-by: chenos <chenlinxh@gmail.com>
53 lines
1.3 KiB
TypeScript
53 lines
1.3 KiB
TypeScript
export class AsyncEmitter {
|
|
async emitAsync(event: string | symbol, ...args: any[]): Promise<boolean> {
|
|
// @ts-ignore
|
|
const events = this._events;
|
|
let callbacks = events[event];
|
|
if (!callbacks) {
|
|
return false;
|
|
}
|
|
// helper function to reuse as much code as possible
|
|
const run = (cb) => {
|
|
switch (args.length) {
|
|
// fast cases
|
|
case 0:
|
|
cb = cb.call(this);
|
|
break;
|
|
case 1:
|
|
cb = cb.call(this, args[0]);
|
|
break;
|
|
case 2:
|
|
cb = cb.call(this, args[0], args[1]);
|
|
break;
|
|
case 3:
|
|
cb = cb.call(this, args[0], args[1], args[2]);
|
|
break;
|
|
// slower
|
|
default:
|
|
cb = cb.apply(this, args);
|
|
}
|
|
|
|
if (cb && (cb instanceof Promise || typeof cb.then === 'function')) {
|
|
return cb;
|
|
}
|
|
|
|
return Promise.resolve(true);
|
|
};
|
|
|
|
if (typeof callbacks === 'function') {
|
|
await run(callbacks);
|
|
} else if (typeof callbacks === 'object') {
|
|
callbacks = callbacks.slice().filter(Boolean);
|
|
await callbacks.reduce((prev, next) => {
|
|
return prev.then((res) => {
|
|
return run(next).then((result) =>
|
|
Promise.resolve(res.concat(result)),
|
|
);
|
|
});
|
|
}, Promise.resolve([]));
|
|
}
|
|
|
|
return true;
|
|
}
|
|
}
|