@vendure/cli 2.2.0-next.7 → 2.2.0-next.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cli.js +17 -3
- package/dist/cli.js.map +1 -1
- package/dist/commands/add/add.js +42 -8
- package/dist/commands/add/add.js.map +1 -1
- package/dist/commands/add/api-extension/add-api-extension.d.ts +9 -0
- package/dist/commands/add/api-extension/add-api-extension.js +336 -0
- package/dist/commands/add/api-extension/add-api-extension.js.map +1 -0
- package/dist/commands/add/api-extension/templates/api-extensions.template.ts +3 -0
- package/dist/commands/add/api-extension/templates/crud-resolver.template.ts +109 -0
- package/dist/commands/add/api-extension/templates/simple-resolver.template.ts +22 -0
- package/dist/commands/add/codegen/add-codegen.d.ts +8 -0
- package/dist/commands/add/codegen/add-codegen.js +106 -0
- package/dist/commands/add/codegen/add-codegen.js.map +1 -0
- package/dist/commands/add/codegen/codegen-config-ref.d.ts +10 -0
- package/dist/commands/add/codegen/codegen-config-ref.js +53 -0
- package/dist/commands/add/codegen/codegen-config-ref.js.map +1 -0
- package/dist/commands/add/codegen/templates/codegen.template.ts +17 -0
- package/dist/commands/add/entity/add-entity.d.ts +15 -5
- package/dist/commands/add/entity/add-entity.js +130 -23
- package/dist/commands/add/entity/add-entity.js.map +1 -1
- package/dist/commands/add/entity/codemods/add-entity-to-plugin/add-entity-to-plugin.d.ts +3 -2
- package/dist/commands/add/entity/codemods/add-entity-to-plugin/add-entity-to-plugin.js +3 -27
- package/dist/commands/add/entity/codemods/add-entity-to-plugin/add-entity-to-plugin.js.map +1 -1
- package/dist/commands/add/entity/templates/entity-translation.template.ts +29 -0
- package/dist/commands/add/entity/templates/entity.template.ts +18 -4
- package/dist/commands/add/job-queue/add-job-queue.d.ts +9 -0
- package/dist/commands/add/job-queue/add-job-queue.js +130 -0
- package/dist/commands/add/job-queue/add-job-queue.js.map +1 -0
- package/dist/commands/add/plugin/create-new-plugin.d.ts +8 -0
- package/dist/commands/add/plugin/create-new-plugin.js +209 -0
- package/dist/commands/add/plugin/create-new-plugin.js.map +1 -0
- package/dist/commands/add/plugin/templates/constants.template.ts +2 -0
- package/dist/commands/add/plugin/templates/plugin.template.ts +18 -0
- package/dist/commands/add/plugin/templates/types.template.ts +7 -0
- package/dist/commands/add/plugin/types.d.ts +8 -0
- package/dist/commands/add/plugin/types.js.map +1 -0
- package/dist/commands/add/service/add-service.d.ts +5 -0
- package/dist/commands/add/service/add-service.js +279 -0
- package/dist/commands/add/service/add-service.js.map +1 -0
- package/dist/commands/add/service/templates/basic-service.template.ts +13 -0
- package/dist/commands/add/service/templates/entity-service.template.ts +147 -0
- package/dist/commands/add/ui-extensions/add-ui-extensions.d.ts +6 -1
- package/dist/commands/add/ui-extensions/add-ui-extensions.js +32 -42
- package/dist/commands/add/ui-extensions/add-ui-extensions.js.map +1 -1
- package/dist/commands/add/ui-extensions/codemods/add-ui-extension-static-prop/add-ui-extension-static-prop.d.ts +2 -2
- package/dist/commands/add/ui-extensions/codemods/add-ui-extension-static-prop/add-ui-extension-static-prop.js +6 -3
- package/dist/commands/add/ui-extensions/codemods/add-ui-extension-static-prop/add-ui-extension-static-prop.js.map +1 -1
- package/dist/commands/add/ui-extensions/codemods/update-admin-ui-plugin-init/update-admin-ui-plugin-init.d.ts +2 -2
- package/dist/commands/add/ui-extensions/codemods/update-admin-ui-plugin-init/update-admin-ui-plugin-init.js +10 -10
- package/dist/commands/add/ui-extensions/codemods/update-admin-ui-plugin-init/update-admin-ui-plugin-init.js.map +1 -1
- package/dist/commands/add/ui-extensions/templates/providers.template.ts +3 -0
- package/dist/commands/add/ui-extensions/templates/routes.template.ts +3 -0
- package/dist/commands/migrate/generate-migration/generate-migration.d.ts +2 -0
- package/dist/commands/migrate/generate-migration/generate-migration.js +48 -0
- package/dist/commands/migrate/generate-migration/generate-migration.js.map +1 -0
- package/dist/commands/migrate/load-vendure-config-file.d.ts +2 -0
- package/dist/commands/migrate/load-vendure-config-file.js +24 -0
- package/dist/commands/migrate/load-vendure-config-file.js.map +1 -0
- package/dist/commands/migrate/migrate.d.ts +2 -0
- package/dist/commands/migrate/migrate.js +56 -0
- package/dist/commands/migrate/migrate.js.map +1 -0
- package/dist/commands/migrate/revert-migration/revert-migration.d.ts +2 -0
- package/dist/commands/migrate/revert-migration/revert-migration.js +31 -0
- package/dist/commands/migrate/revert-migration/revert-migration.js.map +1 -0
- package/dist/commands/migrate/run-migration/run-migration.d.ts +2 -0
- package/dist/commands/migrate/run-migration/run-migration.js +34 -0
- package/dist/commands/migrate/run-migration/run-migration.js.map +1 -0
- package/dist/constants.d.ts +7 -0
- package/dist/constants.js +8 -1
- package/dist/constants.js.map +1 -1
- package/dist/shared/cli-command.d.ts +24 -0
- package/dist/shared/cli-command.js +22 -0
- package/dist/shared/cli-command.js.map +1 -0
- package/dist/shared/entity-ref.d.ts +16 -0
- package/dist/shared/entity-ref.js +55 -0
- package/dist/shared/entity-ref.js.map +1 -0
- package/dist/shared/package-json-ref.d.ts +17 -0
- package/dist/shared/package-json-ref.js +115 -0
- package/dist/shared/package-json-ref.js.map +1 -0
- package/dist/shared/service-ref.d.ts +25 -0
- package/dist/shared/service-ref.js +82 -0
- package/dist/shared/service-ref.js.map +1 -0
- package/dist/shared/shared-prompts.d.ts +13 -3
- package/dist/shared/shared-prompts.js +136 -24
- package/dist/shared/shared-prompts.js.map +1 -1
- package/dist/shared/vendure-config-ref.d.ts +14 -0
- package/dist/shared/vendure-config-ref.js +65 -0
- package/dist/shared/vendure-config-ref.js.map +1 -0
- package/dist/shared/vendure-plugin-ref.d.ts +18 -0
- package/dist/shared/vendure-plugin-ref.js +145 -0
- package/dist/shared/vendure-plugin-ref.js.map +1 -0
- package/dist/utilities/ast-utils.d.ts +7 -9
- package/dist/utilities/ast-utils.js +60 -39
- package/dist/utilities/ast-utils.js.map +1 -1
- package/dist/utilities/utils.d.ts +2 -0
- package/dist/utilities/utils.js +12 -0
- package/dist/utilities/utils.js.map +1 -0
- package/package.json +6 -4
- package/dist/commands/add/ui-extensions/scaffold/providers.d.ts +0 -1
- package/dist/commands/add/ui-extensions/scaffold/providers.js +0 -13
- package/dist/commands/add/ui-extensions/scaffold/providers.js.map +0 -1
- package/dist/commands/add/ui-extensions/scaffold/routes.d.ts +0 -1
- package/dist/commands/add/ui-extensions/scaffold/routes.js +0 -13
- package/dist/commands/add/ui-extensions/scaffold/routes.js.map +0 -1
- package/dist/commands/new/new.d.ts +0 -2
- package/dist/commands/new/new.js +0 -18
- package/dist/commands/new/new.js.map +0 -1
- package/dist/commands/new/plugin/new-plugin.d.ts +0 -3
- package/dist/commands/new/plugin/new-plugin.js +0 -158
- package/dist/commands/new/plugin/new-plugin.js.map +0 -1
- package/dist/commands/new/plugin/scaffold/api/admin.resolver.d.ts +0 -3
- package/dist/commands/new/plugin/scaffold/api/admin.resolver.js +0 -66
- package/dist/commands/new/plugin/scaffold/api/admin.resolver.js.map +0 -1
- package/dist/commands/new/plugin/scaffold/api/api-extensions.d.ts +0 -2
- package/dist/commands/new/plugin/scaffold/api/api-extensions.js +0 -82
- package/dist/commands/new/plugin/scaffold/api/api-extensions.js.map +0 -1
- package/dist/commands/new/plugin/scaffold/api/shop.resolver.d.ts +0 -3
- package/dist/commands/new/plugin/scaffold/api/shop.resolver.js +0 -57
- package/dist/commands/new/plugin/scaffold/api/shop.resolver.js.map +0 -1
- package/dist/commands/new/plugin/scaffold/constants.d.ts +0 -2
- package/dist/commands/new/plugin/scaffold/constants.js +0 -21
- package/dist/commands/new/plugin/scaffold/constants.js.map +0 -1
- package/dist/commands/new/plugin/scaffold/plugin.d.ts +0 -2
- package/dist/commands/new/plugin/scaffold/plugin.js +0 -51
- package/dist/commands/new/plugin/scaffold/plugin.js.map +0 -1
- package/dist/commands/new/plugin/scaffold/services/service.d.ts +0 -3
- package/dist/commands/new/plugin/scaffold/services/service.js +0 -80
- package/dist/commands/new/plugin/scaffold/services/service.js.map +0 -1
- package/dist/commands/new/plugin/scaffold/types.d.ts +0 -2
- package/dist/commands/new/plugin/scaffold/types.js +0 -15
- package/dist/commands/new/plugin/scaffold/types.js.map +0 -1
- package/dist/commands/new/plugin/types.d.ts +0 -22
- package/dist/commands/new/plugin/types.js.map +0 -1
- package/dist/shared/shared-scaffold/entity.d.ts +0 -5
- package/dist/shared/shared-scaffold/entity.js +0 -26
- package/dist/shared/shared-scaffold/entity.js.map +0 -1
- package/dist/utilities/package-utils.d.ts +0 -8
- package/dist/utilities/package-utils.js +0 -96
- package/dist/utilities/package-utils.js.map +0 -1
- package/dist/utilities/scaffolder.d.ts +0 -8
- package/dist/utilities/scaffolder.js +0 -50
- package/dist/utilities/scaffolder.js.map +0 -1
- /package/dist/commands/{new → add}/plugin/types.js +0 -0
package/dist/cli.js
CHANGED
|
@@ -1,15 +1,29 @@
|
|
|
1
1
|
#! /usr/bin/env node
|
|
2
2
|
"use strict";
|
|
3
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
4
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
5
|
+
};
|
|
3
6
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
7
|
const commander_1 = require("commander");
|
|
8
|
+
const picocolors_1 = __importDefault(require("picocolors"));
|
|
5
9
|
const add_1 = require("./commands/add/add");
|
|
6
|
-
const
|
|
10
|
+
const migrate_1 = require("./commands/migrate/migrate");
|
|
7
11
|
const program = new commander_1.Command();
|
|
8
12
|
const version = require('../package.json').version;
|
|
9
13
|
program
|
|
10
14
|
.version(version)
|
|
11
|
-
.
|
|
12
|
-
(
|
|
15
|
+
.usage(`vendure <command>`)
|
|
16
|
+
.description(picocolors_1.default.blue(`
|
|
17
|
+
888
|
|
18
|
+
888
|
|
19
|
+
888
|
|
20
|
+
888 888 .d88b. 88888b. .d88888 888 888 888d888 .d88b.
|
|
21
|
+
888 888 d8P Y8b 888 "88b d88" 888 888 888 888P" d8P Y8b
|
|
22
|
+
Y88 88P 88888888 888 888 888 888 888 888 888 88888888
|
|
23
|
+
Y8bd8P Y8b. 888 888 Y88b 888 Y88b 888 888 Y8b.
|
|
24
|
+
Y88P "Y8888 888 888 "Y88888 "Y88888 888 "Y8888
|
|
25
|
+
`));
|
|
13
26
|
(0, add_1.registerAddCommand)(program);
|
|
27
|
+
(0, migrate_1.registerMigrateCommand)(program);
|
|
14
28
|
void program.parseAsync(process.argv);
|
|
15
29
|
//# sourceMappingURL=cli.js.map
|
package/dist/cli.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cli.js","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"cli.js","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":";;;;;;AAEA,yCAAoC;AACpC,4DAA4B;AAE5B,4CAAwD;AACxD,wDAAoE;AAEpE,MAAM,OAAO,GAAG,IAAI,mBAAO,EAAE,CAAC;AAG9B,MAAM,OAAO,GAAG,OAAO,CAAC,iBAAiB,CAAC,CAAC,OAAO,CAAC;AAEnD,OAAO;KACF,OAAO,CAAC,OAAO,CAAC;KAChB,KAAK,CAAC,mBAAmB,CAAC;KAC1B,WAAW,CACR,oBAAE,CAAC,IAAI,CAAC;;;;;;;;;CASf,CAAC,CACG,CAAC;AAEN,IAAA,wBAAkB,EAAC,OAAO,CAAC,CAAC;AAC5B,IAAA,gCAAsB,EAAC,OAAO,CAAC,CAAC;AAEhC,KAAK,OAAO,CAAC,UAAU,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC"}
|
package/dist/commands/add/add.js
CHANGED
|
@@ -1,8 +1,18 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
2
5
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
6
|
exports.registerAddCommand = void 0;
|
|
4
7
|
const prompts_1 = require("@clack/prompts");
|
|
8
|
+
const picocolors_1 = __importDefault(require("picocolors"));
|
|
9
|
+
const utils_1 = require("../../utilities/utils");
|
|
10
|
+
const add_api_extension_1 = require("./api-extension/add-api-extension");
|
|
11
|
+
const add_codegen_1 = require("./codegen/add-codegen");
|
|
5
12
|
const add_entity_1 = require("./entity/add-entity");
|
|
13
|
+
const add_job_queue_1 = require("./job-queue/add-job-queue");
|
|
14
|
+
const create_new_plugin_1 = require("./plugin/create-new-plugin");
|
|
15
|
+
const add_service_1 = require("./service/add-service");
|
|
6
16
|
const add_ui_extensions_1 = require("./ui-extensions/add-ui-extensions");
|
|
7
17
|
const cancelledMessage = 'Add feature cancelled.';
|
|
8
18
|
function registerAddCommand(program) {
|
|
@@ -10,27 +20,51 @@ function registerAddCommand(program) {
|
|
|
10
20
|
.command('add')
|
|
11
21
|
.description('Add a feature to your Vendure project')
|
|
12
22
|
.action(async () => {
|
|
23
|
+
console.log(`\n`);
|
|
24
|
+
(0, prompts_1.intro)(picocolors_1.default.blue("✨ Let's add a new feature to your Vendure project!"));
|
|
25
|
+
const addCommands = [
|
|
26
|
+
create_new_plugin_1.createNewPluginCommand,
|
|
27
|
+
add_entity_1.addEntityCommand,
|
|
28
|
+
add_service_1.addServiceCommand,
|
|
29
|
+
add_api_extension_1.addApiExtensionCommand,
|
|
30
|
+
add_job_queue_1.addJobQueueCommand,
|
|
31
|
+
add_ui_extensions_1.addUiExtensionsCommand,
|
|
32
|
+
add_codegen_1.addCodegenCommand,
|
|
33
|
+
];
|
|
13
34
|
const featureType = await (0, prompts_1.select)({
|
|
14
35
|
message: 'Which feature would you like to add?',
|
|
15
|
-
options:
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
36
|
+
options: addCommands.map(c => ({
|
|
37
|
+
value: c.id,
|
|
38
|
+
label: `[${c.category}] ${c.description}`,
|
|
39
|
+
})),
|
|
19
40
|
});
|
|
20
41
|
if ((0, prompts_1.isCancel)(featureType)) {
|
|
21
42
|
(0, prompts_1.cancel)(cancelledMessage);
|
|
22
43
|
process.exit(0);
|
|
23
44
|
}
|
|
24
45
|
try {
|
|
25
|
-
|
|
26
|
-
|
|
46
|
+
const command = addCommands.find(c => c.id === featureType);
|
|
47
|
+
if (!command) {
|
|
48
|
+
throw new Error(`Could not find command with id "${featureType}"`);
|
|
27
49
|
}
|
|
28
|
-
|
|
29
|
-
|
|
50
|
+
const { modifiedSourceFiles, project } = await command.run();
|
|
51
|
+
if (modifiedSourceFiles.length) {
|
|
52
|
+
const importsSpinner = (0, prompts_1.spinner)();
|
|
53
|
+
importsSpinner.start('Organizing imports...');
|
|
54
|
+
await (0, utils_1.pauseForPromptDisplay)();
|
|
55
|
+
for (const sourceFile of modifiedSourceFiles) {
|
|
56
|
+
sourceFile.organizeImports();
|
|
57
|
+
}
|
|
58
|
+
await project.save();
|
|
59
|
+
importsSpinner.stop('Imports organized');
|
|
30
60
|
}
|
|
61
|
+
(0, prompts_1.outro)('✅ Done!');
|
|
31
62
|
}
|
|
32
63
|
catch (e) {
|
|
33
64
|
prompts_1.log.error(e.message);
|
|
65
|
+
if (e.stack) {
|
|
66
|
+
prompts_1.log.error(e.stack);
|
|
67
|
+
}
|
|
34
68
|
}
|
|
35
69
|
process.exit(0);
|
|
36
70
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"add.js","sourceRoot":"","sources":["../../../src/commands/add/add.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"add.js","sourceRoot":"","sources":["../../../src/commands/add/add.ts"],"names":[],"mappings":";;;;;;AAAA,4CAAsF;AAEtF,4DAA4B;AAG5B,iDAA8D;AAE9D,yEAA2E;AAC3E,uDAA0D;AAC1D,oDAAuD;AACvD,6DAA+D;AAC/D,kEAAoE;AACpE,uDAA0D;AAC1D,yEAA2E;AAE3E,MAAM,gBAAgB,GAAG,wBAAwB,CAAC;AAElD,SAAgB,kBAAkB,CAAC,OAAgB;IAC/C,OAAO;SACF,OAAO,CAAC,KAAK,CAAC;SACd,WAAW,CAAC,uCAAuC,CAAC;SACpD,MAAM,CAAC,KAAK,IAAI,EAAE;QAEf,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAClB,IAAA,eAAK,EAAC,oBAAE,CAAC,IAAI,CAAC,oDAAoD,CAAC,CAAC,CAAC;QACrE,MAAM,WAAW,GAA2B;YACxC,0CAAsB;YACtB,6BAAgB;YAChB,+BAAiB;YACjB,0CAAsB;YACtB,kCAAkB;YAClB,0CAAsB;YACtB,+BAAiB;SACpB,CAAC;QACF,MAAM,WAAW,GAAG,MAAM,IAAA,gBAAM,EAAC;YAC7B,OAAO,EAAE,sCAAsC;YAC/C,OAAO,EAAE,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;gBAC3B,KAAK,EAAE,CAAC,CAAC,EAAE;gBACX,KAAK,EAAE,IAAI,CAAC,CAAC,QAAQ,KAAK,CAAC,CAAC,WAAW,EAAE;aAC5C,CAAC,CAAC;SACN,CAAC,CAAC;QACH,IAAI,IAAA,kBAAQ,EAAC,WAAW,CAAC,EAAE,CAAC;YACxB,IAAA,gBAAM,EAAC,gBAAgB,CAAC,CAAC;YACzB,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACpB,CAAC;QACD,IAAI,CAAC;YACD,MAAM,OAAO,GAAG,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,WAAW,CAAC,CAAC;YAC5D,IAAI,CAAC,OAAO,EAAE,CAAC;gBACX,MAAM,IAAI,KAAK,CAAC,mCAAmC,WAAqB,GAAG,CAAC,CAAC;YACjF,CAAC;YACD,MAAM,EAAE,mBAAmB,EAAE,OAAO,EAAE,GAAG,MAAM,OAAO,CAAC,GAAG,EAAE,CAAC;YAE7D,IAAI,mBAAmB,CAAC,MAAM,EAAE,CAAC;gBAC7B,MAAM,cAAc,GAAG,IAAA,iBAAO,GAAE,CAAC;gBACjC,cAAc,CAAC,KAAK,CAAC,uBAAuB,CAAC,CAAC;gBAC9C,MAAM,IAAA,6BAAqB,GAAE,CAAC;gBAC9B,KAAK,MAAM,UAAU,IAAI,mBAAmB,EAAE,CAAC;oBAC3C,UAAU,CAAC,eAAe,EAAE,CAAC;gBACjC,CAAC;gBACD,MAAM,OAAO,CAAC,IAAI,EAAE,CAAC;gBACrB,cAAc,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;YAC7C,CAAC;YACD,IAAA,eAAK,EAAC,SAAS,CAAC,CAAC;QACrB,CAAC;QAAC,OAAO,CAAM,EAAE,CAAC;YACd,aAAG,CAAC,KAAK,CAAC,CAAC,CAAC,OAAiB,CAAC,CAAC;YAC/B,IAAI,CAAC,CAAC,KAAK,EAAE,CAAC;gBACV,aAAG,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;YACvB,CAAC;QACL,CAAC;QACD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACpB,CAAC,CAAC,CAAC;AACX,CAAC;AAtDD,gDAsDC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { CliCommand, CliCommandReturnVal } from '../../../shared/cli-command';
|
|
2
|
+
import { ServiceRef } from '../../../shared/service-ref';
|
|
3
|
+
import { VendurePluginRef } from '../../../shared/vendure-plugin-ref';
|
|
4
|
+
export interface AddApiExtensionOptions {
|
|
5
|
+
plugin?: VendurePluginRef;
|
|
6
|
+
}
|
|
7
|
+
export declare const addApiExtensionCommand: CliCommand<Record<string, any>, CliCommandReturnVal<{
|
|
8
|
+
serviceRef: ServiceRef;
|
|
9
|
+
}>>;
|
|
@@ -0,0 +1,336 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.addApiExtensionCommand = void 0;
|
|
7
|
+
const prompts_1 = require("@clack/prompts");
|
|
8
|
+
const change_case_1 = require("change-case");
|
|
9
|
+
const path_1 = __importDefault(require("path"));
|
|
10
|
+
const ts_morph_1 = require("ts-morph");
|
|
11
|
+
const cli_command_1 = require("../../../shared/cli-command");
|
|
12
|
+
const shared_prompts_1 = require("../../../shared/shared-prompts");
|
|
13
|
+
const ast_utils_1 = require("../../../utilities/ast-utils");
|
|
14
|
+
const utils_1 = require("../../../utilities/utils");
|
|
15
|
+
const cancelledMessage = 'Add API extension cancelled';
|
|
16
|
+
exports.addApiExtensionCommand = new cli_command_1.CliCommand({
|
|
17
|
+
id: 'add-api-extension',
|
|
18
|
+
category: 'Plugin: API',
|
|
19
|
+
description: 'Adds GraphQL API extensions to a plugin',
|
|
20
|
+
run: options => addApiExtension(options),
|
|
21
|
+
});
|
|
22
|
+
async function addApiExtension(options) {
|
|
23
|
+
const providedVendurePlugin = options === null || options === void 0 ? void 0 : options.plugin;
|
|
24
|
+
const project = await (0, shared_prompts_1.analyzeProject)({ providedVendurePlugin, cancelledMessage });
|
|
25
|
+
const plugin = providedVendurePlugin !== null && providedVendurePlugin !== void 0 ? providedVendurePlugin : (await (0, shared_prompts_1.selectPlugin)(project, cancelledMessage));
|
|
26
|
+
const serviceRef = await (0, shared_prompts_1.selectServiceRef)(project, plugin);
|
|
27
|
+
const serviceEntityRef = serviceRef.crudEntityRef;
|
|
28
|
+
const modifiedSourceFiles = [];
|
|
29
|
+
let resolver;
|
|
30
|
+
let apiExtensions;
|
|
31
|
+
const scaffoldSpinner = (0, prompts_1.spinner)();
|
|
32
|
+
scaffoldSpinner.start('Generating resolver file...');
|
|
33
|
+
await (0, utils_1.pauseForPromptDisplay)();
|
|
34
|
+
if (serviceEntityRef) {
|
|
35
|
+
resolver = createCrudResolver(project, plugin, serviceRef, serviceEntityRef);
|
|
36
|
+
modifiedSourceFiles.push(resolver.getSourceFile());
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
resolver = createSimpleResolver(project, plugin, serviceRef);
|
|
40
|
+
modifiedSourceFiles.push(resolver.getSourceFile());
|
|
41
|
+
}
|
|
42
|
+
scaffoldSpinner.message('Generating schema definitions...');
|
|
43
|
+
await (0, utils_1.pauseForPromptDisplay)();
|
|
44
|
+
if (serviceEntityRef) {
|
|
45
|
+
apiExtensions = createCrudApiExtension(project, plugin, serviceRef);
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
apiExtensions = createSimpleApiExtension(project, plugin, serviceRef);
|
|
49
|
+
}
|
|
50
|
+
if (apiExtensions) {
|
|
51
|
+
modifiedSourceFiles.push(apiExtensions.getSourceFile());
|
|
52
|
+
}
|
|
53
|
+
scaffoldSpinner.message('Registering API extension with plugin...');
|
|
54
|
+
await (0, utils_1.pauseForPromptDisplay)();
|
|
55
|
+
plugin.addAdminApiExtensions({
|
|
56
|
+
schema: apiExtensions,
|
|
57
|
+
resolvers: [resolver],
|
|
58
|
+
});
|
|
59
|
+
(0, ast_utils_1.addImportsToFile)(plugin.getSourceFile(), {
|
|
60
|
+
namedImports: [resolver.getName()],
|
|
61
|
+
moduleSpecifier: resolver.getSourceFile(),
|
|
62
|
+
});
|
|
63
|
+
if (apiExtensions) {
|
|
64
|
+
(0, ast_utils_1.addImportsToFile)(plugin.getSourceFile(), {
|
|
65
|
+
namedImports: [apiExtensions.getName()],
|
|
66
|
+
moduleSpecifier: apiExtensions.getSourceFile(),
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
scaffoldSpinner.stop(`API extensions added`);
|
|
70
|
+
await project.save();
|
|
71
|
+
return {
|
|
72
|
+
project,
|
|
73
|
+
modifiedSourceFiles: [serviceRef.classDeclaration.getSourceFile(), ...modifiedSourceFiles],
|
|
74
|
+
serviceRef,
|
|
75
|
+
};
|
|
76
|
+
}
|
|
77
|
+
function createSimpleResolver(project, plugin, serviceRef) {
|
|
78
|
+
var _a, _b;
|
|
79
|
+
const resolverSourceFile = (0, ast_utils_1.createFile)(project, path_1.default.join(__dirname, 'templates/simple-resolver.template.ts'));
|
|
80
|
+
resolverSourceFile.move(path_1.default.join(plugin.getPluginDir().getPath(), 'api', (0, change_case_1.paramCase)(serviceRef.name).replace('-service', '') + '-admin.resolver.ts'));
|
|
81
|
+
const resolverClassDeclaration = resolverSourceFile
|
|
82
|
+
.getClass('SimpleAdminResolver')
|
|
83
|
+
.rename(serviceRef.name.replace(/Service$/, '') + 'AdminResolver');
|
|
84
|
+
(_a = resolverClassDeclaration
|
|
85
|
+
.getConstructors()[0]
|
|
86
|
+
.getParameter('templateService')) === null || _a === void 0 ? void 0 : _a.rename(serviceRef.nameCamelCase).setType(serviceRef.name);
|
|
87
|
+
(_b = resolverSourceFile.getClass('TemplateService')) === null || _b === void 0 ? void 0 : _b.remove();
|
|
88
|
+
(0, ast_utils_1.addImportsToFile)(resolverSourceFile, {
|
|
89
|
+
namedImports: [serviceRef.name],
|
|
90
|
+
moduleSpecifier: serviceRef.classDeclaration.getSourceFile(),
|
|
91
|
+
});
|
|
92
|
+
return resolverClassDeclaration;
|
|
93
|
+
}
|
|
94
|
+
function createCrudResolver(project, plugin, serviceRef, serviceEntityRef) {
|
|
95
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
|
|
96
|
+
const resolverSourceFile = (0, ast_utils_1.createFile)(project, path_1.default.join(__dirname, 'templates/crud-resolver.template.ts'));
|
|
97
|
+
resolverSourceFile.move(path_1.default.join(plugin.getPluginDir().getPath(), 'api', (0, change_case_1.paramCase)(serviceEntityRef.name) + '-admin.resolver.ts'));
|
|
98
|
+
const resolverClassDeclaration = resolverSourceFile
|
|
99
|
+
.getClass('EntityAdminResolver')
|
|
100
|
+
.rename(serviceEntityRef.name + 'AdminResolver');
|
|
101
|
+
if (serviceRef.features.findOne) {
|
|
102
|
+
const findOneMethod = (_a = resolverClassDeclaration
|
|
103
|
+
.getMethod('entity')) === null || _a === void 0 ? void 0 : _a.rename(serviceEntityRef.nameCamelCase);
|
|
104
|
+
const serviceFindOneMethod = serviceRef.classDeclaration.getMethod('findOne');
|
|
105
|
+
if (serviceFindOneMethod) {
|
|
106
|
+
if (!serviceFindOneMethod
|
|
107
|
+
.getParameters()
|
|
108
|
+
.find(p => p.getName() === 'relations' && p.getType().getText().includes('RelationPaths'))) {
|
|
109
|
+
findOneMethod === null || findOneMethod === void 0 ? void 0 : findOneMethod.getParameters()[2].remove();
|
|
110
|
+
findOneMethod === null || findOneMethod === void 0 ? void 0 : findOneMethod.setBodyText(`return this.${serviceRef.nameCamelCase}.findOne(ctx, args.id);`);
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
else {
|
|
115
|
+
(_b = resolverClassDeclaration.getMethod('entity')) === null || _b === void 0 ? void 0 : _b.remove();
|
|
116
|
+
}
|
|
117
|
+
if (serviceRef.features.findAll) {
|
|
118
|
+
const findAllMethod = (_c = resolverClassDeclaration
|
|
119
|
+
.getMethod('entities')) === null || _c === void 0 ? void 0 : _c.rename(serviceEntityRef.nameCamelCase + 's');
|
|
120
|
+
const serviceFindAllMethod = serviceRef.classDeclaration.getMethod('findAll');
|
|
121
|
+
if (serviceFindAllMethod) {
|
|
122
|
+
if (!serviceFindAllMethod
|
|
123
|
+
.getParameters()
|
|
124
|
+
.find(p => p.getName() === 'relations' && p.getType().getText().includes('RelationPaths'))) {
|
|
125
|
+
findAllMethod === null || findAllMethod === void 0 ? void 0 : findAllMethod.getParameters()[2].remove();
|
|
126
|
+
findAllMethod === null || findAllMethod === void 0 ? void 0 : findAllMethod.setBodyText(`return this.${serviceRef.nameCamelCase}.findAll(ctx, args.options || undefined);`);
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
else {
|
|
131
|
+
(_d = resolverClassDeclaration.getMethod('entities')) === null || _d === void 0 ? void 0 : _d.remove();
|
|
132
|
+
}
|
|
133
|
+
if (serviceRef.features.create) {
|
|
134
|
+
(_e = resolverClassDeclaration.getMethod('createEntity')) === null || _e === void 0 ? void 0 : _e.rename('create' + serviceEntityRef.name);
|
|
135
|
+
}
|
|
136
|
+
else {
|
|
137
|
+
(_f = resolverClassDeclaration.getMethod('createEntity')) === null || _f === void 0 ? void 0 : _f.remove();
|
|
138
|
+
}
|
|
139
|
+
if (serviceRef.features.update) {
|
|
140
|
+
(_g = resolverClassDeclaration.getMethod('updateEntity')) === null || _g === void 0 ? void 0 : _g.rename('update' + serviceEntityRef.name);
|
|
141
|
+
}
|
|
142
|
+
else {
|
|
143
|
+
(_h = resolverClassDeclaration.getMethod('updateEntity')) === null || _h === void 0 ? void 0 : _h.remove();
|
|
144
|
+
}
|
|
145
|
+
if (serviceRef.features.delete) {
|
|
146
|
+
(_j = resolverClassDeclaration.getMethod('deleteEntity')) === null || _j === void 0 ? void 0 : _j.rename('delete' + serviceEntityRef.name);
|
|
147
|
+
}
|
|
148
|
+
else {
|
|
149
|
+
(_k = resolverClassDeclaration.getMethod('deleteEntity')) === null || _k === void 0 ? void 0 : _k.remove();
|
|
150
|
+
}
|
|
151
|
+
(0, ast_utils_1.customizeCreateUpdateInputInterfaces)(resolverSourceFile, serviceEntityRef);
|
|
152
|
+
(_l = resolverClassDeclaration
|
|
153
|
+
.getConstructors()[0]
|
|
154
|
+
.getParameter('templateService')) === null || _l === void 0 ? void 0 : _l.rename(serviceRef.nameCamelCase).setType(serviceRef.name);
|
|
155
|
+
(_m = resolverSourceFile.getClass('TemplateEntity')) === null || _m === void 0 ? void 0 : _m.rename(serviceEntityRef.name).remove();
|
|
156
|
+
(_o = resolverSourceFile.getClass('TemplateService')) === null || _o === void 0 ? void 0 : _o.remove();
|
|
157
|
+
(0, ast_utils_1.addImportsToFile)(resolverSourceFile, {
|
|
158
|
+
namedImports: [serviceRef.name],
|
|
159
|
+
moduleSpecifier: serviceRef.classDeclaration.getSourceFile(),
|
|
160
|
+
});
|
|
161
|
+
(0, ast_utils_1.addImportsToFile)(resolverSourceFile, {
|
|
162
|
+
namedImports: [serviceEntityRef.name],
|
|
163
|
+
moduleSpecifier: serviceEntityRef.classDeclaration.getSourceFile(),
|
|
164
|
+
});
|
|
165
|
+
return resolverClassDeclaration;
|
|
166
|
+
}
|
|
167
|
+
function createSimpleApiExtension(project, plugin, serviceRef) {
|
|
168
|
+
var _a;
|
|
169
|
+
const apiExtensionsFile = getOrCreateApiExtensionsFile(project, plugin);
|
|
170
|
+
const adminApiExtensionDocuments = apiExtensionsFile.getVariableDeclaration('adminApiExtensionDocuments');
|
|
171
|
+
const insertAtIndex = (_a = adminApiExtensionDocuments === null || adminApiExtensionDocuments === void 0 ? void 0 : adminApiExtensionDocuments.getParent().getParent().getChildIndex()) !== null && _a !== void 0 ? _a : 2;
|
|
172
|
+
const schemaVariableName = `${serviceRef.nameCamelCase.replace(/Service$/, '')}AdminApiExtensions`;
|
|
173
|
+
apiExtensionsFile.insertVariableStatement(insertAtIndex, {
|
|
174
|
+
declarationKind: ts_morph_1.VariableDeclarationKind.Const,
|
|
175
|
+
declarations: [
|
|
176
|
+
{
|
|
177
|
+
name: schemaVariableName,
|
|
178
|
+
initializer: writer => {
|
|
179
|
+
writer.writeLine(`gql\``);
|
|
180
|
+
writer.indent(() => {
|
|
181
|
+
writer.writeLine(` extend type Query {`);
|
|
182
|
+
writer.writeLine(` exampleQuery(id: ID!): Boolean!`);
|
|
183
|
+
writer.writeLine(` }`);
|
|
184
|
+
writer.newLine();
|
|
185
|
+
writer.writeLine(` extend type Mutation {`);
|
|
186
|
+
writer.writeLine(` exampleMutation(id: ID!): Boolean!`);
|
|
187
|
+
writer.writeLine(` }`);
|
|
188
|
+
});
|
|
189
|
+
writer.write(`\``);
|
|
190
|
+
},
|
|
191
|
+
},
|
|
192
|
+
],
|
|
193
|
+
});
|
|
194
|
+
const adminApiExtensions = apiExtensionsFile.getVariableDeclaration('adminApiExtensions');
|
|
195
|
+
addSchemaToApiExtensionsTemplateLiteral(adminApiExtensions, schemaVariableName);
|
|
196
|
+
return adminApiExtensions;
|
|
197
|
+
}
|
|
198
|
+
function createCrudApiExtension(project, plugin, serviceRef) {
|
|
199
|
+
var _a;
|
|
200
|
+
const apiExtensionsFile = getOrCreateApiExtensionsFile(project, plugin);
|
|
201
|
+
const adminApiExtensions = apiExtensionsFile.getVariableDeclaration('adminApiExtensions');
|
|
202
|
+
const insertAtIndex = (_a = adminApiExtensions === null || adminApiExtensions === void 0 ? void 0 : adminApiExtensions.getParent().getParent().getChildIndex()) !== null && _a !== void 0 ? _a : 2;
|
|
203
|
+
const schemaVariableName = `${serviceRef.nameCamelCase.replace(/Service$/, '')}AdminApiExtensions`;
|
|
204
|
+
apiExtensionsFile.insertVariableStatement(insertAtIndex, {
|
|
205
|
+
declarationKind: ts_morph_1.VariableDeclarationKind.Const,
|
|
206
|
+
declarations: [
|
|
207
|
+
{
|
|
208
|
+
name: schemaVariableName,
|
|
209
|
+
initializer: writer => {
|
|
210
|
+
writer.writeLine(`gql\``);
|
|
211
|
+
const entityRef = serviceRef.crudEntityRef;
|
|
212
|
+
if (entityRef) {
|
|
213
|
+
writer.indent(() => {
|
|
214
|
+
writer.writeLine(` type ${entityRef.name} implements Node {`);
|
|
215
|
+
writer.writeLine(` id: ID!`);
|
|
216
|
+
writer.writeLine(` createdAt: DateTime!`);
|
|
217
|
+
writer.writeLine(` updatedAt: DateTime!`);
|
|
218
|
+
for (const { name, type, nullable } of entityRef.getProps()) {
|
|
219
|
+
const graphQlType = getGraphQLType(type);
|
|
220
|
+
if (graphQlType) {
|
|
221
|
+
writer.writeLine(` ${name}: ${graphQlType}${nullable ? '' : '!'}`);
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
writer.writeLine(` }`);
|
|
225
|
+
writer.newLine();
|
|
226
|
+
writer.writeLine(` type ${entityRef.name}List implements PaginatedList {`);
|
|
227
|
+
writer.writeLine(` items: [${entityRef.name}!]!`);
|
|
228
|
+
writer.writeLine(` totalItems: Int!`);
|
|
229
|
+
writer.writeLine(` }`);
|
|
230
|
+
writer.newLine();
|
|
231
|
+
writer.writeLine(` # Generated at run-time by Vendure`);
|
|
232
|
+
writer.writeLine(` input ${entityRef.name}ListOptions`);
|
|
233
|
+
writer.newLine();
|
|
234
|
+
writer.writeLine(` extend type Query {`);
|
|
235
|
+
if (serviceRef.features.findOne) {
|
|
236
|
+
writer.writeLine(` ${entityRef.nameCamelCase}(id: ID!): ${entityRef.name}`);
|
|
237
|
+
}
|
|
238
|
+
if (serviceRef.features.findAll) {
|
|
239
|
+
writer.writeLine(` ${entityRef.nameCamelCase}s(options: ${entityRef.name}ListOptions): ${entityRef.name}List!`);
|
|
240
|
+
}
|
|
241
|
+
writer.writeLine(` }`);
|
|
242
|
+
writer.newLine();
|
|
243
|
+
if (serviceRef.features.create) {
|
|
244
|
+
writer.writeLine(` input Create${entityRef.name}Input {`);
|
|
245
|
+
for (const { name, type, nullable } of entityRef.getProps()) {
|
|
246
|
+
const graphQlType = getGraphQLType(type);
|
|
247
|
+
if (graphQlType) {
|
|
248
|
+
writer.writeLine(` ${name}: ${graphQlType}${nullable ? '' : '!'}`);
|
|
249
|
+
}
|
|
250
|
+
}
|
|
251
|
+
writer.writeLine(` }`);
|
|
252
|
+
writer.newLine();
|
|
253
|
+
}
|
|
254
|
+
if (serviceRef.features.update) {
|
|
255
|
+
writer.writeLine(` input Update${entityRef.name}Input {`);
|
|
256
|
+
writer.writeLine(` id: ID!`);
|
|
257
|
+
for (const { name, type } of entityRef.getProps()) {
|
|
258
|
+
const graphQlType = getGraphQLType(type);
|
|
259
|
+
if (graphQlType) {
|
|
260
|
+
writer.writeLine(` ${name}: ${graphQlType}`);
|
|
261
|
+
}
|
|
262
|
+
}
|
|
263
|
+
writer.writeLine(` }`);
|
|
264
|
+
writer.newLine();
|
|
265
|
+
}
|
|
266
|
+
if (serviceRef.features.create ||
|
|
267
|
+
serviceRef.features.update ||
|
|
268
|
+
serviceRef.features.delete) {
|
|
269
|
+
writer.writeLine(` extend type Mutation {`);
|
|
270
|
+
if (serviceRef.features.create) {
|
|
271
|
+
writer.writeLine(` create${entityRef.name}(input: Create${entityRef.name}Input!): ${entityRef.name}!`);
|
|
272
|
+
}
|
|
273
|
+
if (serviceRef.features.update) {
|
|
274
|
+
writer.writeLine(` update${entityRef.name}(input: Update${entityRef.name}Input!): ${entityRef.name}!`);
|
|
275
|
+
}
|
|
276
|
+
if (serviceRef.features.delete) {
|
|
277
|
+
writer.writeLine(` delete${entityRef.name}(id: ID!): DeletionResponse!`);
|
|
278
|
+
}
|
|
279
|
+
writer.writeLine(` }`);
|
|
280
|
+
}
|
|
281
|
+
});
|
|
282
|
+
}
|
|
283
|
+
writer.write(`\``);
|
|
284
|
+
},
|
|
285
|
+
},
|
|
286
|
+
],
|
|
287
|
+
});
|
|
288
|
+
addSchemaToApiExtensionsTemplateLiteral(adminApiExtensions, schemaVariableName);
|
|
289
|
+
return adminApiExtensions;
|
|
290
|
+
}
|
|
291
|
+
function addSchemaToApiExtensionsTemplateLiteral(adminApiExtensions, schemaVariableName) {
|
|
292
|
+
if (adminApiExtensions) {
|
|
293
|
+
const apiExtensionsInitializer = adminApiExtensions.getInitializer();
|
|
294
|
+
if (ts_morph_1.Node.isTaggedTemplateExpression(apiExtensionsInitializer)) {
|
|
295
|
+
adminApiExtensions
|
|
296
|
+
.setInitializer(writer => {
|
|
297
|
+
writer.writeLine(`gql\``);
|
|
298
|
+
const template = apiExtensionsInitializer.getTemplate();
|
|
299
|
+
if (ts_morph_1.Node.isNoSubstitutionTemplateLiteral(template)) {
|
|
300
|
+
writer.write(`${template.getLiteralValue()}`);
|
|
301
|
+
}
|
|
302
|
+
else {
|
|
303
|
+
writer.write(template.getText().replace(/^`/, '').replace(/`$/, ''));
|
|
304
|
+
}
|
|
305
|
+
writer.writeLine(` \${${schemaVariableName}}`);
|
|
306
|
+
writer.write(`\``);
|
|
307
|
+
})
|
|
308
|
+
.formatText();
|
|
309
|
+
}
|
|
310
|
+
}
|
|
311
|
+
}
|
|
312
|
+
function getGraphQLType(type) {
|
|
313
|
+
if (type.isString()) {
|
|
314
|
+
return 'String';
|
|
315
|
+
}
|
|
316
|
+
if (type.isBoolean()) {
|
|
317
|
+
return 'Boolean';
|
|
318
|
+
}
|
|
319
|
+
if (type.isNumber()) {
|
|
320
|
+
return 'Int';
|
|
321
|
+
}
|
|
322
|
+
if (type.isClass() && type.getText() === 'Date') {
|
|
323
|
+
return 'DateTime';
|
|
324
|
+
}
|
|
325
|
+
return;
|
|
326
|
+
}
|
|
327
|
+
function getOrCreateApiExtensionsFile(project, plugin) {
|
|
328
|
+
const existingApiExtensionsFile = project.getSourceFiles().find(sf => {
|
|
329
|
+
return sf.getBaseName() === 'api-extensions.ts' && sf.getDirectory().getPath().endsWith('/api');
|
|
330
|
+
});
|
|
331
|
+
if (existingApiExtensionsFile) {
|
|
332
|
+
return existingApiExtensionsFile;
|
|
333
|
+
}
|
|
334
|
+
return (0, ast_utils_1.createFile)(project, path_1.default.join(__dirname, 'templates/api-extensions.template.ts')).move(path_1.default.join(plugin.getPluginDir().getPath(), 'api', 'api-extensions.ts'));
|
|
335
|
+
}
|
|
336
|
+
//# sourceMappingURL=add-api-extension.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"add-api-extension.js","sourceRoot":"","sources":["../../../../src/commands/add/api-extension/add-api-extension.ts"],"names":[],"mappings":";;;;;;AAAA,4CAAyC;AACzC,6CAAwC;AACxC,gDAAwB;AACxB,uCAQkB;AAElB,6DAA8E;AAG9E,mEAAgG;AAEhG,4DAIsC;AACtC,oDAAiE;AAEjE,MAAM,gBAAgB,GAAG,6BAA6B,CAAC;AAM1C,QAAA,sBAAsB,GAAG,IAAI,wBAAU,CAAC;IACjD,EAAE,EAAE,mBAAmB;IACvB,QAAQ,EAAE,aAAa;IACvB,WAAW,EAAE,yCAAyC;IACtD,GAAG,EAAE,OAAO,CAAC,EAAE,CAAC,eAAe,CAAC,OAAO,CAAC;CAC3C,CAAC,CAAC;AAEH,KAAK,UAAU,eAAe,CAC1B,OAAgC;IAEhC,MAAM,qBAAqB,GAAG,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,MAAM,CAAC;IAC9C,MAAM,OAAO,GAAG,MAAM,IAAA,+BAAc,EAAC,EAAE,qBAAqB,EAAE,gBAAgB,EAAE,CAAC,CAAC;IAClF,MAAM,MAAM,GAAG,qBAAqB,aAArB,qBAAqB,cAArB,qBAAqB,GAAI,CAAC,MAAM,IAAA,6BAAY,EAAC,OAAO,EAAE,gBAAgB,CAAC,CAAC,CAAC;IACxF,MAAM,UAAU,GAAG,MAAM,IAAA,iCAAgB,EAAC,OAAO,EAAE,MAAM,CAAC,CAAC;IAE3D,MAAM,gBAAgB,GAAG,UAAU,CAAC,aAAa,CAAC;IAClD,MAAM,mBAAmB,GAAiB,EAAE,CAAC;IAC7C,IAAI,QAAsC,CAAC;IAC3C,IAAI,aAA8C,CAAC;IAEnD,MAAM,eAAe,GAAG,IAAA,iBAAO,GAAE,CAAC;IAElC,eAAe,CAAC,KAAK,CAAC,6BAA6B,CAAC,CAAC;IACrD,MAAM,IAAA,6BAAqB,GAAE,CAAC;IAC9B,IAAI,gBAAgB,EAAE,CAAC;QACnB,QAAQ,GAAG,kBAAkB,CAAC,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,gBAAgB,CAAC,CAAC;QAC7E,mBAAmB,CAAC,IAAI,CAAC,QAAQ,CAAC,aAAa,EAAE,CAAC,CAAC;IACvD,CAAC;SAAM,CAAC;QACJ,QAAQ,GAAG,oBAAoB,CAAC,OAAO,EAAE,MAAM,EAAE,UAAU,CAAC,CAAC;QAC7D,mBAAmB,CAAC,IAAI,CAAC,QAAQ,CAAC,aAAa,EAAE,CAAC,CAAC;IACvD,CAAC;IAED,eAAe,CAAC,OAAO,CAAC,kCAAkC,CAAC,CAAC;IAC5D,MAAM,IAAA,6BAAqB,GAAE,CAAC;IAE9B,IAAI,gBAAgB,EAAE,CAAC;QACnB,aAAa,GAAG,sBAAsB,CAAC,OAAO,EAAE,MAAM,EAAE,UAAU,CAAC,CAAC;IACxE,CAAC;SAAM,CAAC;QACJ,aAAa,GAAG,wBAAwB,CAAC,OAAO,EAAE,MAAM,EAAE,UAAU,CAAC,CAAC;IAC1E,CAAC;IACD,IAAI,aAAa,EAAE,CAAC;QAChB,mBAAmB,CAAC,IAAI,CAAC,aAAa,CAAC,aAAa,EAAE,CAAC,CAAC;IAC5D,CAAC;IAED,eAAe,CAAC,OAAO,CAAC,0CAA0C,CAAC,CAAC;IACpE,MAAM,IAAA,6BAAqB,GAAE,CAAC;IAE9B,MAAM,CAAC,qBAAqB,CAAC;QACzB,MAAM,EAAE,aAAa;QACrB,SAAS,EAAE,CAAC,QAAQ,CAAC;KACxB,CAAC,CAAC;IACH,IAAA,4BAAgB,EAAC,MAAM,CAAC,aAAa,EAAE,EAAE;QACrC,YAAY,EAAE,CAAC,QAAQ,CAAC,OAAO,EAAY,CAAC;QAC5C,eAAe,EAAE,QAAQ,CAAC,aAAa,EAAE;KAC5C,CAAC,CAAC;IACH,IAAI,aAAa,EAAE,CAAC;QAChB,IAAA,4BAAgB,EAAC,MAAM,CAAC,aAAa,EAAE,EAAE;YACrC,YAAY,EAAE,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC;YACvC,eAAe,EAAE,aAAa,CAAC,aAAa,EAAE;SACjD,CAAC,CAAC;IACP,CAAC;IAED,eAAe,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;IAE7C,MAAM,OAAO,CAAC,IAAI,EAAE,CAAC;IAErB,OAAO;QACH,OAAO;QACP,mBAAmB,EAAE,CAAC,UAAU,CAAC,gBAAgB,CAAC,aAAa,EAAE,EAAE,GAAG,mBAAmB,CAAC;QAC1F,UAAU;KACb,CAAC;AACN,CAAC;AAED,SAAS,oBAAoB,CAAC,OAAgB,EAAE,MAAwB,EAAE,UAAsB;;IAC5F,MAAM,kBAAkB,GAAG,IAAA,sBAAU,EACjC,OAAO,EACP,cAAI,CAAC,IAAI,CAAC,SAAS,EAAE,uCAAuC,CAAC,CAChE,CAAC;IACF,kBAAkB,CAAC,IAAI,CACnB,cAAI,CAAC,IAAI,CACL,MAAM,CAAC,YAAY,EAAE,CAAC,OAAO,EAAE,EAC/B,KAAK,EACL,IAAA,uBAAS,EAAC,UAAU,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,UAAU,EAAE,EAAE,CAAC,GAAG,oBAAoB,CAC5E,CACJ,CAAC;IAEF,MAAM,wBAAwB,GAAG,kBAAkB;SAC9C,QAAQ,CAAC,qBAAqB,CAAE;SAChC,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,EAAE,CAAC,GAAG,eAAe,CAAC,CAAC;IAEvE,MAAA,wBAAwB;SACnB,eAAe,EAAE,CAAC,CAAC,CAAC;SACpB,YAAY,CAAC,iBAAiB,CAAC,0CAC9B,MAAM,CAAC,UAAU,CAAC,aAAa,EAChC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;IAE9B,MAAA,kBAAkB,CAAC,QAAQ,CAAC,iBAAiB,CAAC,0CAAE,MAAM,EAAE,CAAC;IACzD,IAAA,4BAAgB,EAAC,kBAAkB,EAAE;QACjC,YAAY,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC;QAC/B,eAAe,EAAE,UAAU,CAAC,gBAAgB,CAAC,aAAa,EAAE;KAC/D,CAAC,CAAC;IAEH,OAAO,wBAAwB,CAAC;AACpC,CAAC;AAED,SAAS,kBAAkB,CACvB,OAAgB,EAChB,MAAwB,EACxB,UAAsB,EACtB,gBAA2B;;IAE3B,MAAM,kBAAkB,GAAG,IAAA,sBAAU,EACjC,OAAO,EACP,cAAI,CAAC,IAAI,CAAC,SAAS,EAAE,qCAAqC,CAAC,CAC9D,CAAC;IACF,kBAAkB,CAAC,IAAI,CACnB,cAAI,CAAC,IAAI,CACL,MAAM,CAAC,YAAY,EAAE,CAAC,OAAO,EAAE,EAC/B,KAAK,EACL,IAAA,uBAAS,EAAC,gBAAgB,CAAC,IAAI,CAAC,GAAG,oBAAoB,CAC1D,CACJ,CAAC;IAEF,MAAM,wBAAwB,GAAG,kBAAkB;SAC9C,QAAQ,CAAC,qBAAqB,CAAE;SAChC,MAAM,CAAC,gBAAgB,CAAC,IAAI,GAAG,eAAe,CAAC,CAAC;IAErD,IAAI,UAAU,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC;QAC9B,MAAM,aAAa,GAAG,MAAA,wBAAwB;aACzC,SAAS,CAAC,QAAQ,CAAC,0CAClB,MAAM,CAAC,gBAAgB,CAAC,aAAa,CAAC,CAAC;QAC7C,MAAM,oBAAoB,GAAG,UAAU,CAAC,gBAAgB,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QAC9E,IAAI,oBAAoB,EAAE,CAAC;YACvB,IACI,CAAC,oBAAoB;iBAChB,aAAa,EAAE;iBACf,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,EAAE,KAAK,WAAW,IAAI,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,EAAE,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAC,EAChG,CAAC;gBACC,aAAa,aAAb,aAAa,uBAAb,aAAa,CAAE,aAAa,GAAG,CAAC,EAAE,MAAM,EAAE,CAAC;gBAC3C,aAAa,aAAb,aAAa,uBAAb,aAAa,CAAE,WAAW,CAAC,eAAe,UAAU,CAAC,aAAa,yBAAyB,CAAC,CAAC;YACjG,CAAC;QACL,CAAC;IACL,CAAC;SAAM,CAAC;QACJ,MAAA,wBAAwB,CAAC,SAAS,CAAC,QAAQ,CAAC,0CAAE,MAAM,EAAE,CAAC;IAC3D,CAAC;IAED,IAAI,UAAU,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC;QAC9B,MAAM,aAAa,GAAG,MAAA,wBAAwB;aACzC,SAAS,CAAC,UAAU,CAAC,0CACpB,MAAM,CAAC,gBAAgB,CAAC,aAAa,GAAG,GAAG,CAAC,CAAC;QACnD,MAAM,oBAAoB,GAAG,UAAU,CAAC,gBAAgB,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC;QAC9E,IAAI,oBAAoB,EAAE,CAAC;YACvB,IACI,CAAC,oBAAoB;iBAChB,aAAa,EAAE;iBACf,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,EAAE,KAAK,WAAW,IAAI,CAAC,CAAC,OAAO,EAAE,CAAC,OAAO,EAAE,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAC,EAChG,CAAC;gBACC,aAAa,aAAb,aAAa,uBAAb,aAAa,CAAE,aAAa,GAAG,CAAC,EAAE,MAAM,EAAE,CAAC;gBAC3C,aAAa,aAAb,aAAa,uBAAb,aAAa,CAAE,WAAW,CACtB,eAAe,UAAU,CAAC,aAAa,2CAA2C,CACrF,CAAC;YACN,CAAC;QACL,CAAC;IACL,CAAC;SAAM,CAAC;QACJ,MAAA,wBAAwB,CAAC,SAAS,CAAC,UAAU,CAAC,0CAAE,MAAM,EAAE,CAAC;IAC7D,CAAC;IAED,IAAI,UAAU,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;QAC7B,MAAA,wBAAwB,CAAC,SAAS,CAAC,cAAc,CAAC,0CAAE,MAAM,CAAC,QAAQ,GAAG,gBAAgB,CAAC,IAAI,CAAC,CAAC;IACjG,CAAC;SAAM,CAAC;QACJ,MAAA,wBAAwB,CAAC,SAAS,CAAC,cAAc,CAAC,0CAAE,MAAM,EAAE,CAAC;IACjE,CAAC;IAED,IAAI,UAAU,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;QAC7B,MAAA,wBAAwB,CAAC,SAAS,CAAC,cAAc,CAAC,0CAAE,MAAM,CAAC,QAAQ,GAAG,gBAAgB,CAAC,IAAI,CAAC,CAAC;IACjG,CAAC;SAAM,CAAC;QACJ,MAAA,wBAAwB,CAAC,SAAS,CAAC,cAAc,CAAC,0CAAE,MAAM,EAAE,CAAC;IACjE,CAAC;IAED,IAAI,UAAU,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;QAC7B,MAAA,wBAAwB,CAAC,SAAS,CAAC,cAAc,CAAC,0CAAE,MAAM,CAAC,QAAQ,GAAG,gBAAgB,CAAC,IAAI,CAAC,CAAC;IACjG,CAAC;SAAM,CAAC;QACJ,MAAA,wBAAwB,CAAC,SAAS,CAAC,cAAc,CAAC,0CAAE,MAAM,EAAE,CAAC;IACjE,CAAC;IAED,IAAA,gDAAoC,EAAC,kBAAkB,EAAE,gBAAgB,CAAC,CAAC;IAE3E,MAAA,wBAAwB;SACnB,eAAe,EAAE,CAAC,CAAC,CAAC;SACpB,YAAY,CAAC,iBAAiB,CAAC,0CAC9B,MAAM,CAAC,UAAU,CAAC,aAAa,EAChC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;IAC9B,MAAA,kBAAkB,CAAC,QAAQ,CAAC,gBAAgB,CAAC,0CAAE,MAAM,CAAC,gBAAgB,CAAC,IAAI,EAAE,MAAM,EAAE,CAAC;IACtF,MAAA,kBAAkB,CAAC,QAAQ,CAAC,iBAAiB,CAAC,0CAAE,MAAM,EAAE,CAAC;IAEzD,IAAA,4BAAgB,EAAC,kBAAkB,EAAE;QACjC,YAAY,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC;QAC/B,eAAe,EAAE,UAAU,CAAC,gBAAgB,CAAC,aAAa,EAAE;KAC/D,CAAC,CAAC;IACH,IAAA,4BAAgB,EAAC,kBAAkB,EAAE;QACjC,YAAY,EAAE,CAAC,gBAAgB,CAAC,IAAI,CAAC;QACrC,eAAe,EAAE,gBAAgB,CAAC,gBAAgB,CAAC,aAAa,EAAE;KACrE,CAAC,CAAC;IAEH,OAAO,wBAAwB,CAAC;AACpC,CAAC;AAED,SAAS,wBAAwB,CAAC,OAAgB,EAAE,MAAwB,EAAE,UAAsB;;IAChG,MAAM,iBAAiB,GAAG,4BAA4B,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;IACxE,MAAM,0BAA0B,GAAG,iBAAiB,CAAC,sBAAsB,CAAC,4BAA4B,CAAC,CAAC;IAC1G,MAAM,aAAa,GAAG,MAAA,0BAA0B,aAA1B,0BAA0B,uBAA1B,0BAA0B,CAAE,SAAS,GAAG,SAAS,GAAG,aAAa,EAAE,mCAAI,CAAC,CAAC;IAC/F,MAAM,kBAAkB,GAAG,GAAG,UAAU,CAAC,aAAa,CAAC,OAAO,CAAC,UAAU,EAAE,EAAE,CAAC,oBAAoB,CAAC;IACnG,iBAAiB,CAAC,uBAAuB,CAAC,aAAa,EAAE;QACrD,eAAe,EAAE,kCAAuB,CAAC,KAAK;QAC9C,YAAY,EAAE;YACV;gBACI,IAAI,EAAE,kBAAkB;gBACxB,WAAW,EAAE,MAAM,CAAC,EAAE;oBAClB,MAAM,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;oBAC1B,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE;wBACf,MAAM,CAAC,SAAS,CAAC,uBAAuB,CAAC,CAAC;wBAC1C,MAAM,CAAC,SAAS,CAAC,qCAAqC,CAAC,CAAC;wBACxD,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;wBACxB,MAAM,CAAC,OAAO,EAAE,CAAC;wBACjB,MAAM,CAAC,SAAS,CAAC,0BAA0B,CAAC,CAAC;wBAC7C,MAAM,CAAC,SAAS,CAAC,wCAAwC,CAAC,CAAC;wBAC3D,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;oBAC5B,CAAC,CAAC,CAAC;oBACH,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;gBACvB,CAAC;aACJ;SACJ;KACJ,CAAC,CAAC;IAEH,MAAM,kBAAkB,GAAG,iBAAiB,CAAC,sBAAsB,CAAC,oBAAoB,CAAC,CAAC;IAC1F,uCAAuC,CAAC,kBAAkB,EAAE,kBAAkB,CAAC,CAAC;IAEhF,OAAO,kBAAkB,CAAC;AAC9B,CAAC;AAED,SAAS,sBAAsB,CAAC,OAAgB,EAAE,MAAwB,EAAE,UAAsB;;IAC9F,MAAM,iBAAiB,GAAG,4BAA4B,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;IACxE,MAAM,kBAAkB,GAAG,iBAAiB,CAAC,sBAAsB,CAAC,oBAAoB,CAAC,CAAC;IAC1F,MAAM,aAAa,GAAG,MAAA,kBAAkB,aAAlB,kBAAkB,uBAAlB,kBAAkB,CAAE,SAAS,GAAG,SAAS,GAAG,aAAa,EAAE,mCAAI,CAAC,CAAC;IACvF,MAAM,kBAAkB,GAAG,GAAG,UAAU,CAAC,aAAa,CAAC,OAAO,CAAC,UAAU,EAAE,EAAE,CAAC,oBAAoB,CAAC;IACnG,iBAAiB,CAAC,uBAAuB,CAAC,aAAa,EAAE;QACrD,eAAe,EAAE,kCAAuB,CAAC,KAAK;QAC9C,YAAY,EAAE;YACV;gBACI,IAAI,EAAE,kBAAkB;gBACxB,WAAW,EAAE,MAAM,CAAC,EAAE;oBAClB,MAAM,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;oBAC1B,MAAM,SAAS,GAAG,UAAU,CAAC,aAAa,CAAC;oBAC3C,IAAI,SAAS,EAAE,CAAC;wBACZ,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE;4BACf,MAAM,CAAC,SAAS,CAAC,UAAU,SAAS,CAAC,IAAI,oBAAoB,CAAC,CAAC;4BAC/D,MAAM,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;4BAChC,MAAM,CAAC,SAAS,CAAC,0BAA0B,CAAC,CAAC;4BAC7C,MAAM,CAAC,SAAS,CAAC,0BAA0B,CAAC,CAAC;4BAC7C,KAAK,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,SAAS,CAAC,QAAQ,EAAE,EAAE,CAAC;gCAC1D,MAAM,WAAW,GAAG,cAAc,CAAC,IAAI,CAAC,CAAC;gCACzC,IAAI,WAAW,EAAE,CAAC;oCACd,MAAM,CAAC,SAAS,CAAC,OAAO,IAAI,KAAK,WAAW,GAAG,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC;gCAC1E,CAAC;4BACL,CAAC;4BACD,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;4BACxB,MAAM,CAAC,OAAO,EAAE,CAAC;4BAEjB,MAAM,CAAC,SAAS,CAAC,UAAU,SAAS,CAAC,IAAI,iCAAiC,CAAC,CAAC;4BAC5E,MAAM,CAAC,SAAS,CAAC,eAAe,SAAS,CAAC,IAAI,KAAK,CAAC,CAAC;4BACrD,MAAM,CAAC,SAAS,CAAC,sBAAsB,CAAC,CAAC;4BACzC,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;4BACxB,MAAM,CAAC,OAAO,EAAE,CAAC;4BAEjB,MAAM,CAAC,SAAS,CAAC,sCAAsC,CAAC,CAAC;4BACzD,MAAM,CAAC,SAAS,CAAC,WAAW,SAAS,CAAC,IAAI,aAAa,CAAC,CAAC;4BACzD,MAAM,CAAC,OAAO,EAAE,CAAC;4BAEjB,MAAM,CAAC,SAAS,CAAC,uBAAuB,CAAC,CAAC;4BAE1C,IAAI,UAAU,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC;gCAC9B,MAAM,CAAC,SAAS,CACZ,OAAO,SAAS,CAAC,aAAa,cAAc,SAAS,CAAC,IAAI,EAAE,CAC/D,CAAC;4BACN,CAAC;4BACD,IAAI,UAAU,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC;gCAC9B,MAAM,CAAC,SAAS,CACZ,OAAO,SAAS,CAAC,aAAa,cAAc,SAAS,CAAC,IAAI,iBAAiB,SAAS,CAAC,IAAI,OAAO,CACnG,CAAC;4BACN,CAAC;4BACD,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;4BACxB,MAAM,CAAC,OAAO,EAAE,CAAC;4BAEjB,IAAI,UAAU,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;gCAC7B,MAAM,CAAC,SAAS,CAAC,iBAAiB,SAAS,CAAC,IAAI,SAAS,CAAC,CAAC;gCAC3D,KAAK,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,SAAS,CAAC,QAAQ,EAAE,EAAE,CAAC;oCAC1D,MAAM,WAAW,GAAG,cAAc,CAAC,IAAI,CAAC,CAAC;oCACzC,IAAI,WAAW,EAAE,CAAC;wCACd,MAAM,CAAC,SAAS,CAAC,OAAO,IAAI,KAAK,WAAW,GAAG,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC;oCAC1E,CAAC;gCACL,CAAC;gCACD,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;gCACxB,MAAM,CAAC,OAAO,EAAE,CAAC;4BACrB,CAAC;4BAED,IAAI,UAAU,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;gCAC7B,MAAM,CAAC,SAAS,CAAC,iBAAiB,SAAS,CAAC,IAAI,SAAS,CAAC,CAAC;gCAC3D,MAAM,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;gCAChC,KAAK,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,SAAS,CAAC,QAAQ,EAAE,EAAE,CAAC;oCAChD,MAAM,WAAW,GAAG,cAAc,CAAC,IAAI,CAAC,CAAC;oCACzC,IAAI,WAAW,EAAE,CAAC;wCACd,MAAM,CAAC,SAAS,CAAC,OAAO,IAAI,KAAK,WAAW,EAAE,CAAC,CAAC;oCACpD,CAAC;gCACL,CAAC;gCACD,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;gCACxB,MAAM,CAAC,OAAO,EAAE,CAAC;4BACrB,CAAC;4BAED,IACI,UAAU,CAAC,QAAQ,CAAC,MAAM;gCAC1B,UAAU,CAAC,QAAQ,CAAC,MAAM;gCAC1B,UAAU,CAAC,QAAQ,CAAC,MAAM,EAC5B,CAAC;gCACC,MAAM,CAAC,SAAS,CAAC,0BAA0B,CAAC,CAAC;gCAC7C,IAAI,UAAU,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;oCAC7B,MAAM,CAAC,SAAS,CACZ,aAAa,SAAS,CAAC,IAAI,iBAAiB,SAAS,CAAC,IAAI,YAAY,SAAS,CAAC,IAAI,GAAG,CAC1F,CAAC;gCACN,CAAC;gCACD,IAAI,UAAU,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;oCAC7B,MAAM,CAAC,SAAS,CACZ,aAAa,SAAS,CAAC,IAAI,iBAAiB,SAAS,CAAC,IAAI,YAAY,SAAS,CAAC,IAAI,GAAG,CAC1F,CAAC;gCACN,CAAC;gCACD,IAAI,UAAU,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;oCAC7B,MAAM,CAAC,SAAS,CACZ,aAAa,SAAS,CAAC,IAAI,8BAA8B,CAC5D,CAAC;gCACN,CAAC;gCACD,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;4BAC5B,CAAC;wBACL,CAAC,CAAC,CAAC;oBACP,CAAC;oBACD,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;gBACvB,CAAC;aACJ;SACJ;KACJ,CAAC,CAAC;IAEH,uCAAuC,CAAC,kBAAkB,EAAE,kBAAkB,CAAC,CAAC;IAEhF,OAAO,kBAAkB,CAAC;AAC9B,CAAC;AAED,SAAS,uCAAuC,CAC5C,kBAAmD,EACnD,kBAA0B;IAE1B,IAAI,kBAAkB,EAAE,CAAC;QACrB,MAAM,wBAAwB,GAAG,kBAAkB,CAAC,cAAc,EAAE,CAAC;QACrE,IAAI,eAAI,CAAC,0BAA0B,CAAC,wBAAwB,CAAC,EAAE,CAAC;YAC5D,kBAAkB;iBACb,cAAc,CAAC,MAAM,CAAC,EAAE;gBACrB,MAAM,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;gBAC1B,MAAM,QAAQ,GAAG,wBAAwB,CAAC,WAAW,EAAE,CAAC;gBACxD,IAAI,eAAI,CAAC,+BAA+B,CAAC,QAAQ,CAAC,EAAE,CAAC;oBACjD,MAAM,CAAC,KAAK,CAAC,GAAG,QAAQ,CAAC,eAAe,EAAE,EAAE,CAAC,CAAC;gBAClD,CAAC;qBAAM,CAAC;oBACJ,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC;gBACzE,CAAC;gBACD,MAAM,CAAC,SAAS,CAAC,QAAQ,kBAAkB,GAAG,CAAC,CAAC;gBAChD,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;YACvB,CAAC,CAAC;iBACD,UAAU,EAAE,CAAC;QACtB,CAAC;IACL,CAAC;AACL,CAAC;AAED,SAAS,cAAc,CAAC,IAAU;IAC9B,IAAI,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC;QAClB,OAAO,QAAQ,CAAC;IACpB,CAAC;IACD,IAAI,IAAI,CAAC,SAAS,EAAE,EAAE,CAAC;QACnB,OAAO,SAAS,CAAC;IACrB,CAAC;IACD,IAAI,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC;QAClB,OAAO,KAAK,CAAC;IACjB,CAAC;IACD,IAAI,IAAI,CAAC,OAAO,EAAE,IAAI,IAAI,CAAC,OAAO,EAAE,KAAK,MAAM,EAAE,CAAC;QAC9C,OAAO,UAAU,CAAC;IACtB,CAAC;IACD,OAAO;AACX,CAAC;AAED,SAAS,4BAA4B,CAAC,OAAgB,EAAE,MAAwB;IAC5E,MAAM,yBAAyB,GAAG,OAAO,CAAC,cAAc,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE;QACjE,OAAO,EAAE,CAAC,WAAW,EAAE,KAAK,mBAAmB,IAAI,EAAE,CAAC,YAAY,EAAE,CAAC,OAAO,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;IACpG,CAAC,CAAC,CAAC;IACH,IAAI,yBAAyB,EAAE,CAAC;QAC5B,OAAO,yBAAyB,CAAC;IACrC,CAAC;IACD,OAAO,IAAA,sBAAU,EAAC,OAAO,EAAE,cAAI,CAAC,IAAI,CAAC,SAAS,EAAE,sCAAsC,CAAC,CAAC,CAAC,IAAI,CACzF,cAAI,CAAC,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC,OAAO,EAAE,EAAE,KAAK,EAAE,mBAAmB,CAAC,CACzE,CAAC;AACN,CAAC"}
|
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
import { Args, Mutation, Query, Resolver } from '@nestjs/graphql';
|
|
2
|
+
import { DeletionResponse, Permission } from '@vendure/common/lib/generated-types';
|
|
3
|
+
import { CustomFieldsObject } from '@vendure/common/lib/shared-types';
|
|
4
|
+
import {
|
|
5
|
+
Allow,
|
|
6
|
+
Ctx,
|
|
7
|
+
PaginatedList,
|
|
8
|
+
RequestContext,
|
|
9
|
+
Transaction,
|
|
10
|
+
Relations,
|
|
11
|
+
VendureEntity,
|
|
12
|
+
ID,
|
|
13
|
+
TranslationInput,
|
|
14
|
+
ListQueryOptions,
|
|
15
|
+
RelationPaths,
|
|
16
|
+
} from '@vendure/core';
|
|
17
|
+
|
|
18
|
+
class TemplateEntity extends VendureEntity {
|
|
19
|
+
constructor() {
|
|
20
|
+
super();
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
class TemplateService {
|
|
25
|
+
findAll(ctx: RequestContext, options?: any, relations?: any): Promise<PaginatedList<TemplateEntity>> {
|
|
26
|
+
throw new Error('Method not implemented.');
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
findOne(ctx: RequestContext, id: ID, relations?: any): Promise<TemplateEntity | null> {
|
|
30
|
+
throw new Error('Method not implemented.');
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
create(ctx: RequestContext, input: any): Promise<TemplateEntity> {
|
|
34
|
+
throw new Error('Method not implemented.');
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
update(ctx: RequestContext, input: any): Promise<TemplateEntity> {
|
|
38
|
+
throw new Error('Method not implemented.');
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
delete(ctx: RequestContext, id: ID): Promise<DeletionResponse> {
|
|
42
|
+
throw new Error('Method not implemented.');
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
// These can be replaced by generated types if you set up code generation
|
|
47
|
+
interface CreateEntityInput {
|
|
48
|
+
// Define the input fields here
|
|
49
|
+
customFields?: CustomFieldsObject;
|
|
50
|
+
translations: Array<TranslationInput<TemplateEntity>>;
|
|
51
|
+
}
|
|
52
|
+
interface UpdateEntityInput {
|
|
53
|
+
id: ID;
|
|
54
|
+
// Define the input fields here
|
|
55
|
+
customFields?: CustomFieldsObject;
|
|
56
|
+
translations: Array<TranslationInput<TemplateEntity>>;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
@Resolver()
|
|
60
|
+
export class EntityAdminResolver {
|
|
61
|
+
constructor(private templateService: TemplateService) {}
|
|
62
|
+
|
|
63
|
+
@Query()
|
|
64
|
+
@Allow(Permission.SuperAdmin)
|
|
65
|
+
async entity(
|
|
66
|
+
@Ctx() ctx: RequestContext,
|
|
67
|
+
@Args() args: { id: ID },
|
|
68
|
+
@Relations(TemplateEntity) relations: RelationPaths<TemplateEntity>,
|
|
69
|
+
): Promise<TemplateEntity | null> {
|
|
70
|
+
return this.templateService.findOne(ctx, args.id, relations);
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
@Query()
|
|
74
|
+
@Allow(Permission.SuperAdmin)
|
|
75
|
+
async entities(
|
|
76
|
+
@Ctx() ctx: RequestContext,
|
|
77
|
+
@Args() args: { options: ListQueryOptions<TemplateEntity> },
|
|
78
|
+
@Relations(TemplateEntity) relations: RelationPaths<TemplateEntity>,
|
|
79
|
+
): Promise<PaginatedList<TemplateEntity>> {
|
|
80
|
+
return this.templateService.findAll(ctx, args.options || undefined, relations);
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
@Mutation()
|
|
84
|
+
@Transaction()
|
|
85
|
+
@Allow(Permission.SuperAdmin)
|
|
86
|
+
async createEntity(
|
|
87
|
+
@Ctx() ctx: RequestContext,
|
|
88
|
+
@Args() args: { input: CreateEntityInput },
|
|
89
|
+
): Promise<TemplateEntity> {
|
|
90
|
+
return this.templateService.create(ctx, args.input);
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
@Mutation()
|
|
94
|
+
@Transaction()
|
|
95
|
+
@Allow(Permission.SuperAdmin)
|
|
96
|
+
async updateEntity(
|
|
97
|
+
@Ctx() ctx: RequestContext,
|
|
98
|
+
@Args() args: { input: UpdateEntityInput },
|
|
99
|
+
): Promise<TemplateEntity> {
|
|
100
|
+
return this.templateService.update(ctx, args.input);
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
@Mutation()
|
|
104
|
+
@Transaction()
|
|
105
|
+
@Allow(Permission.SuperAdmin)
|
|
106
|
+
async deleteEntity(@Ctx() ctx: RequestContext, @Args() args: { id: ID }): Promise<DeletionResponse> {
|
|
107
|
+
return this.templateService.delete(ctx, args.id);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { Args, Mutation, Query, Resolver } from '@nestjs/graphql';
|
|
2
|
+
import { Permission } from '@vendure/common/lib/generated-types';
|
|
3
|
+
import { Allow, Ctx, RequestContext } from '@vendure/core';
|
|
4
|
+
|
|
5
|
+
class TemplateService {}
|
|
6
|
+
|
|
7
|
+
@Resolver()
|
|
8
|
+
export class SimpleAdminResolver {
|
|
9
|
+
constructor(private templateService: TemplateService) {}
|
|
10
|
+
|
|
11
|
+
@Query()
|
|
12
|
+
@Allow(Permission.SuperAdmin)
|
|
13
|
+
async exampleQuery(@Ctx() ctx: RequestContext, @Args() args: { id: string }): Promise<boolean> {
|
|
14
|
+
return true;
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
@Mutation()
|
|
18
|
+
@Allow(Permission.SuperAdmin)
|
|
19
|
+
async exampleMutation(@Ctx() ctx: RequestContext, @Args() args: { id: string }): Promise<boolean> {
|
|
20
|
+
return true;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { CliCommand, CliCommandReturnVal } from '../../../shared/cli-command';
|
|
2
|
+
import { VendurePluginRef } from '../../../shared/vendure-plugin-ref';
|
|
3
|
+
export interface AddCodegenOptions {
|
|
4
|
+
plugin?: VendurePluginRef;
|
|
5
|
+
}
|
|
6
|
+
export declare const addCodegenCommand: CliCommand<{
|
|
7
|
+
plugin: VendurePluginRef;
|
|
8
|
+
}, CliCommandReturnVal>;
|