sonamu 0.5.6 → 0.6.0
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/api/base-frame.js +12 -2
- package/dist/api/caster.js +66 -2
- package/dist/api/code-converters.js +489 -2
- package/dist/api/config.d.ts +76 -0
- package/dist/api/config.d.ts.map +1 -0
- package/dist/api/config.js +32 -0
- package/dist/api/context.d.ts +1 -0
- package/dist/api/context.d.ts.map +1 -1
- package/dist/api/context.js +3 -2
- package/dist/api/decorators.d.ts +1 -0
- package/dist/api/decorators.d.ts.map +1 -1
- package/dist/api/decorators.js +142 -2
- package/dist/api/index.js +9 -2
- package/dist/api/sonamu.d.ts +8 -22
- package/dist/api/sonamu.d.ts.map +1 -1
- package/dist/api/sonamu.js +482 -2
- package/dist/bin/build-config.d.ts +2 -1
- package/dist/bin/build-config.d.ts.map +1 -1
- package/dist/bin/build-config.js +12 -2
- package/dist/bin/cli-wrapper.js +71 -2
- package/dist/bin/cli.js +418 -2
- package/dist/bin/hot-hook-register.d.ts +11 -0
- package/dist/bin/hot-hook-register.d.ts.map +1 -0
- package/dist/bin/hot-hook-register.js +21 -0
- package/dist/database/_batch_update.js +78 -2
- package/dist/database/base-model.js +247 -2
- package/dist/database/code-generator.js +53 -2
- package/dist/database/db.d.ts +5 -16
- package/dist/database/db.d.ts.map +1 -1
- package/dist/database/db.js +132 -2
- package/dist/database/knex-plugins/knex-on-duplicate-update.js +39 -2
- package/dist/database/puri-wrapper.d.ts +22 -10
- package/dist/database/puri-wrapper.d.ts.map +1 -1
- package/dist/database/puri-wrapper.js +109 -2
- package/dist/database/puri.d.ts +105 -73
- package/dist/database/puri.d.ts.map +1 -1
- package/dist/database/puri.js +539 -2
- package/dist/database/puri.types.d.ts +33 -42
- package/dist/database/puri.types.d.ts.map +1 -1
- package/dist/database/puri.types.js +3 -2
- package/dist/database/transaction-context.d.ts +3 -3
- package/dist/database/transaction-context.d.ts.map +1 -1
- package/dist/database/transaction-context.js +14 -2
- package/dist/database/upsert-builder.js +215 -2
- package/dist/entity/entity-manager.d.ts +3 -1
- package/dist/entity/entity-manager.d.ts.map +1 -1
- package/dist/entity/entity-manager.js +114 -2
- package/dist/entity/entity-utils.js +210 -2
- package/dist/entity/entity.d.ts.map +1 -1
- package/dist/entity/entity.js +651 -2
- package/dist/exceptions/error-handler.js +29 -2
- package/dist/exceptions/so-exceptions.js +85 -2
- package/dist/file-storage/driver.js +79 -2
- package/dist/file-storage/file-storage.js +75 -2
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +28 -2
- package/dist/migration/code-generation.js +558 -2
- package/dist/migration/migration-set.js +364 -2
- package/dist/migration/migrator.d.ts +0 -9
- package/dist/migration/migrator.d.ts.map +1 -1
- package/dist/migration/migrator.js +510 -2
- package/dist/migration/types.js +3 -2
- package/dist/naite/naite.d.ts +12 -0
- package/dist/naite/naite.d.ts.map +1 -0
- package/dist/naite/naite.js +72 -0
- package/dist/stream/index.js +3 -2
- package/dist/stream/sse.js +38 -2
- package/dist/syncer/api-parser.d.ts +20 -0
- package/dist/syncer/api-parser.d.ts.map +1 -0
- package/dist/syncer/api-parser.js +229 -0
- package/dist/syncer/checksum.d.ts +21 -0
- package/dist/syncer/checksum.d.ts.map +1 -0
- package/dist/syncer/checksum.js +98 -0
- package/dist/syncer/code-generator.d.ts +20 -0
- package/dist/syncer/code-generator.d.ts.map +1 -0
- package/dist/syncer/code-generator.js +141 -0
- package/dist/syncer/entity-operations.d.ts +17 -0
- package/dist/syncer/entity-operations.d.ts.map +1 -0
- package/dist/syncer/entity-operations.js +58 -0
- package/dist/syncer/file-patterns.d.ts +29 -0
- package/dist/syncer/file-patterns.d.ts.map +1 -0
- package/dist/syncer/file-patterns.js +38 -0
- package/dist/syncer/index.d.ts +6 -0
- package/dist/syncer/index.d.ts.map +1 -1
- package/dist/syncer/index.js +9 -2
- package/dist/syncer/module-loader.d.ts +35 -0
- package/dist/syncer/module-loader.d.ts.map +1 -0
- package/dist/syncer/module-loader.js +82 -0
- package/dist/syncer/syncer.d.ts +93 -108
- package/dist/syncer/syncer.d.ts.map +1 -1
- package/dist/syncer/syncer.js +375 -2
- package/dist/template/entity-converter.d.ts +14 -0
- package/dist/template/entity-converter.d.ts.map +1 -0
- package/dist/template/entity-converter.js +101 -0
- package/dist/template/helpers.d.ts +23 -0
- package/dist/template/helpers.d.ts.map +1 -0
- package/dist/template/helpers.js +64 -0
- package/dist/{templates → template/implementations}/entity.template.d.ts +3 -3
- package/dist/template/implementations/entity.template.d.ts.map +1 -0
- package/dist/template/implementations/entity.template.js +87 -0
- package/dist/{templates → template/implementations}/generated.template.d.ts +3 -3
- package/dist/template/implementations/generated.template.d.ts.map +1 -0
- package/dist/template/implementations/generated.template.js +232 -0
- package/dist/{templates → template/implementations}/generated_http.template.d.ts +3 -3
- package/dist/template/implementations/generated_http.template.d.ts.map +1 -0
- package/dist/template/implementations/generated_http.template.js +131 -0
- package/dist/{templates → template/implementations}/generated_sso.template.d.ts +3 -3
- package/dist/template/implementations/generated_sso.template.d.ts.map +1 -0
- package/dist/template/implementations/generated_sso.template.js +105 -0
- package/dist/{templates → template/implementations}/init_types.template.d.ts +3 -3
- package/dist/template/implementations/init_types.template.d.ts.map +1 -0
- package/dist/template/implementations/init_types.template.js +38 -0
- package/dist/template/implementations/model.template.d.ts +17 -0
- package/dist/template/implementations/model.template.d.ts.map +1 -0
- package/dist/template/implementations/model.template.js +171 -0
- package/dist/{templates → template/implementations}/model_test.template.d.ts +3 -3
- package/dist/template/implementations/model_test.template.d.ts.map +1 -0
- package/dist/template/implementations/model_test.template.js +35 -0
- package/dist/{templates → template/implementations}/service.template.d.ts +6 -6
- package/dist/template/implementations/service.template.d.ts.map +1 -0
- package/dist/template/implementations/service.template.js +193 -0
- package/dist/{templates → template/implementations}/view_enums_buttonset.template.d.ts +3 -3
- package/dist/template/implementations/view_enums_buttonset.template.d.ts.map +1 -0
- package/dist/template/implementations/view_enums_buttonset.template.js +31 -0
- package/dist/{templates → template/implementations}/view_enums_dropdown.template.d.ts +3 -4
- package/dist/template/implementations/view_enums_dropdown.template.d.ts.map +1 -0
- package/dist/template/implementations/view_enums_dropdown.template.js +50 -0
- package/dist/{templates → template/implementations}/view_enums_select.template.d.ts +3 -3
- package/dist/template/implementations/view_enums_select.template.d.ts.map +1 -0
- package/dist/template/implementations/view_enums_select.template.js +55 -0
- package/dist/{templates → template/implementations}/view_form.template.d.ts +5 -5
- package/dist/template/implementations/view_form.template.d.ts.map +1 -0
- package/dist/template/implementations/view_form.template.js +337 -0
- package/dist/{templates → template/implementations}/view_id_all_select.template.d.ts +3 -3
- package/dist/template/implementations/view_id_all_select.template.d.ts.map +1 -0
- package/dist/template/implementations/view_id_all_select.template.js +31 -0
- package/dist/{templates → template/implementations}/view_id_async_select.template.d.ts +3 -3
- package/dist/template/implementations/view_id_async_select.template.d.ts.map +1 -0
- package/dist/template/implementations/view_id_async_select.template.js +105 -0
- package/dist/{templates → template/implementations}/view_list.template.d.ts +5 -13
- package/dist/template/implementations/view_list.template.d.ts.map +1 -0
- package/dist/template/implementations/view_list.template.js +465 -0
- package/dist/{templates → template/implementations}/view_list_columns.template.d.ts +3 -3
- package/dist/template/implementations/view_list_columns.template.d.ts.map +1 -0
- package/dist/template/implementations/view_list_columns.template.js +49 -0
- package/dist/{templates → template/implementations}/view_search_input.template.d.ts +3 -3
- package/dist/template/implementations/view_search_input.template.d.ts.map +1 -0
- package/dist/template/implementations/view_search_input.template.js +64 -0
- package/dist/template/index.d.ts +5 -0
- package/dist/template/index.d.ts.map +1 -0
- package/dist/template/index.js +6 -0
- package/dist/template/template.d.ts +39 -0
- package/dist/template/template.d.ts.map +1 -0
- package/dist/template/template.js +47 -0
- package/dist/template/zod-converter.d.ts +18 -0
- package/dist/template/zod-converter.d.ts.map +1 -0
- package/dist/template/zod-converter.js +166 -0
- package/dist/testing/_relation-graph.js +80 -2
- package/dist/testing/fixture-manager.d.ts.map +1 -1
- package/dist/testing/fixture-manager.js +521 -2
- package/dist/types/types.d.ts +39 -40
- package/dist/types/types.d.ts.map +1 -1
- package/dist/types/types.js +289 -2
- package/dist/typings/knex.d.js +3 -2
- package/dist/utils/async-utils.d.ts +7 -0
- package/dist/utils/async-utils.d.ts.map +1 -1
- package/dist/utils/async-utils.js +57 -2
- package/dist/utils/console-util.d.ts +2 -0
- package/dist/utils/console-util.d.ts.map +1 -0
- package/dist/utils/console-util.js +6 -0
- package/dist/utils/controller.js +26 -2
- package/dist/utils/esm-utils.d.ts +45 -0
- package/dist/utils/esm-utils.d.ts.map +1 -0
- package/dist/utils/esm-utils.js +56 -0
- package/dist/utils/fs-utils.js +17 -2
- package/dist/utils/lodash-able.js +6 -2
- package/dist/utils/model.js +22 -2
- package/dist/utils/path-utils.d.ts +89 -0
- package/dist/utils/path-utils.d.ts.map +1 -0
- package/dist/utils/path-utils.js +60 -0
- package/dist/utils/process-utils.d.ts +13 -0
- package/dist/utils/process-utils.d.ts.map +1 -0
- package/dist/utils/process-utils.js +36 -0
- package/dist/utils/sql-parser.js +35 -2
- package/dist/utils/utils.d.ts +4 -7
- package/dist/utils/utils.d.ts.map +1 -1
- package/dist/utils/utils.js +33 -2
- package/dist/utils/zod-error.d.ts.map +1 -1
- package/dist/utils/zod-error.js +19 -2
- package/package.json +21 -9
- package/src/api/code-converters.ts +2 -2
- package/src/api/config.ts +142 -0
- package/src/api/context.ts +1 -0
- package/src/api/decorators.ts +15 -5
- package/src/api/sonamu.ts +102 -87
- package/src/bin/build-config.ts +2 -1
- package/src/bin/cli-wrapper.ts +10 -3
- package/src/bin/cli.ts +108 -56
- package/src/bin/hot-hook-register.ts +22 -0
- package/src/database/base-model.ts +1 -1
- package/src/database/code-generator.ts +1 -1
- package/src/database/db.ts +53 -60
- package/src/database/puri-wrapper.ts +104 -26
- package/src/database/puri.ts +477 -580
- package/src/database/puri.types.ts +111 -201
- package/src/database/transaction-context.ts +4 -4
- package/src/database/upsert-builder.ts +1 -1
- package/src/entity/entity-manager.ts +19 -15
- package/src/entity/entity.ts +4 -3
- package/src/index.ts +2 -0
- package/src/migration/code-generation.ts +1 -1
- package/src/migration/migration-set.ts +1 -1
- package/src/migration/migrator.ts +23 -152
- package/src/naite/naite.ts +70 -0
- package/src/syncer/api-parser.ts +299 -0
- package/src/syncer/checksum.ts +152 -0
- package/src/syncer/code-generator.ts +202 -0
- package/src/syncer/entity-operations.ts +68 -0
- package/src/syncer/file-patterns.ts +56 -0
- package/src/syncer/index.ts +6 -0
- package/src/syncer/module-loader.ts +125 -0
- package/src/syncer/syncer.ts +363 -1420
- package/src/template/entity-converter.ts +123 -0
- package/src/template/helpers.ts +84 -0
- package/src/{templates → template/implementations}/entity.template.ts +4 -4
- package/src/{templates → template/implementations}/generated.template.ts +9 -9
- package/src/{templates → template/implementations}/generated_http.template.ts +9 -6
- package/src/{templates → template/implementations}/generated_sso.template.ts +7 -7
- package/src/{templates → template/implementations}/init_types.template.ts +4 -4
- package/src/{templates → template/implementations}/model.template.ts +9 -9
- package/src/{templates → template/implementations}/model_test.template.ts +5 -5
- package/src/{templates → template/implementations}/service.template.ts +29 -12
- package/src/{templates → template/implementations}/view_enums_buttonset.template.ts +3 -3
- package/src/{templates → template/implementations}/view_enums_dropdown.template.ts +5 -21
- package/src/{templates → template/implementations}/view_enums_select.template.ts +4 -4
- package/src/{templates → template/implementations}/view_form.template.ts +11 -13
- package/src/{templates → template/implementations}/view_id_all_select.template.ts +3 -3
- package/src/{templates → template/implementations}/view_id_async_select.template.ts +3 -3
- package/src/{templates → template/implementations}/view_list.template.ts +13 -64
- package/src/{templates → template/implementations}/view_list_columns.template.ts +3 -3
- package/src/{templates → template/implementations}/view_search_input.template.ts +3 -3
- package/src/template/index.ts +4 -0
- package/src/template/template.ts +86 -0
- package/src/template/zod-converter.ts +219 -0
- package/src/testing/fixture-manager.ts +8 -1
- package/src/types/types.ts +39 -62
- package/src/utils/async-utils.ts +17 -0
- package/src/utils/console-util.ts +4 -0
- package/src/utils/esm-utils.ts +69 -0
- package/src/utils/path-utils.ts +102 -0
- package/src/utils/process-utils.ts +46 -0
- package/src/utils/sql-parser.ts +1 -1
- package/src/utils/utils.ts +14 -40
- package/src/utils/zod-error.ts +0 -1
- package/dist/api/base-frame.js.map +0 -1
- package/dist/api/caster.js.map +0 -1
- package/dist/api/code-converters.js.map +0 -1
- package/dist/api/context.js.map +0 -1
- package/dist/api/decorators.js.map +0 -1
- package/dist/api/index.js.map +0 -1
- package/dist/api/sonamu.js.map +0 -1
- package/dist/bin/build-config.js.map +0 -1
- package/dist/bin/cli-wrapper.js.map +0 -1
- package/dist/bin/cli.js.map +0 -1
- package/dist/database/_batch_update.js.map +0 -1
- package/dist/database/base-model.js.map +0 -1
- package/dist/database/code-generator.js.map +0 -1
- package/dist/database/db.js.map +0 -1
- package/dist/database/knex-plugins/knex-on-duplicate-update.js.map +0 -1
- package/dist/database/puri-wrapper.js.map +0 -1
- package/dist/database/puri.js.map +0 -1
- package/dist/database/puri.types.js.map +0 -1
- package/dist/database/transaction-context.js.map +0 -1
- package/dist/database/upsert-builder.js.map +0 -1
- package/dist/entity/entity-manager.js.map +0 -1
- package/dist/entity/entity-utils.js.map +0 -1
- package/dist/entity/entity.js.map +0 -1
- package/dist/exceptions/error-handler.js.map +0 -1
- package/dist/exceptions/so-exceptions.js.map +0 -1
- package/dist/file-storage/driver.js.map +0 -1
- package/dist/file-storage/file-storage.js.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/migration/code-generation.js.map +0 -1
- package/dist/migration/migration-set.js.map +0 -1
- package/dist/migration/migrator.js.map +0 -1
- package/dist/migration/types.js.map +0 -1
- package/dist/stream/index.js.map +0 -1
- package/dist/stream/sse.js.map +0 -1
- package/dist/syncer/index.js.map +0 -1
- package/dist/syncer/syncer.js.map +0 -1
- package/dist/templates/base-template.d.ts +0 -13
- package/dist/templates/base-template.d.ts.map +0 -1
- package/dist/templates/base-template.js +0 -2
- package/dist/templates/base-template.js.map +0 -1
- package/dist/templates/entity.template.d.ts.map +0 -1
- package/dist/templates/entity.template.js +0 -2
- package/dist/templates/entity.template.js.map +0 -1
- package/dist/templates/generated.template.d.ts.map +0 -1
- package/dist/templates/generated.template.js +0 -2
- package/dist/templates/generated.template.js.map +0 -1
- package/dist/templates/generated_http.template.d.ts.map +0 -1
- package/dist/templates/generated_http.template.js +0 -2
- package/dist/templates/generated_http.template.js.map +0 -1
- package/dist/templates/generated_sso.template.d.ts.map +0 -1
- package/dist/templates/generated_sso.template.js +0 -2
- package/dist/templates/generated_sso.template.js.map +0 -1
- package/dist/templates/index.d.ts +0 -2
- package/dist/templates/index.d.ts.map +0 -1
- package/dist/templates/index.js +0 -2
- package/dist/templates/index.js.map +0 -1
- package/dist/templates/init_types.template.d.ts.map +0 -1
- package/dist/templates/init_types.template.js +0 -2
- package/dist/templates/init_types.template.js.map +0 -1
- package/dist/templates/model.template.d.ts +0 -17
- package/dist/templates/model.template.d.ts.map +0 -1
- package/dist/templates/model.template.js +0 -2
- package/dist/templates/model.template.js.map +0 -1
- package/dist/templates/model_test.template.d.ts.map +0 -1
- package/dist/templates/model_test.template.js +0 -2
- package/dist/templates/model_test.template.js.map +0 -1
- package/dist/templates/service.template.d.ts.map +0 -1
- package/dist/templates/service.template.js +0 -2
- package/dist/templates/service.template.js.map +0 -1
- package/dist/templates/view_enums_buttonset.template.d.ts.map +0 -1
- package/dist/templates/view_enums_buttonset.template.js +0 -2
- package/dist/templates/view_enums_buttonset.template.js.map +0 -1
- package/dist/templates/view_enums_dropdown.template.d.ts.map +0 -1
- package/dist/templates/view_enums_dropdown.template.js +0 -2
- package/dist/templates/view_enums_dropdown.template.js.map +0 -1
- package/dist/templates/view_enums_select.template.d.ts.map +0 -1
- package/dist/templates/view_enums_select.template.js +0 -2
- package/dist/templates/view_enums_select.template.js.map +0 -1
- package/dist/templates/view_form.template.d.ts.map +0 -1
- package/dist/templates/view_form.template.js +0 -2
- package/dist/templates/view_form.template.js.map +0 -1
- package/dist/templates/view_id_all_select.template.d.ts.map +0 -1
- package/dist/templates/view_id_all_select.template.js +0 -2
- package/dist/templates/view_id_all_select.template.js.map +0 -1
- package/dist/templates/view_id_async_select.template.d.ts.map +0 -1
- package/dist/templates/view_id_async_select.template.js +0 -2
- package/dist/templates/view_id_async_select.template.js.map +0 -1
- package/dist/templates/view_list.template.d.ts.map +0 -1
- package/dist/templates/view_list.template.js +0 -2
- package/dist/templates/view_list.template.js.map +0 -1
- package/dist/templates/view_list_columns.template.d.ts.map +0 -1
- package/dist/templates/view_list_columns.template.js +0 -2
- package/dist/templates/view_list_columns.template.js.map +0 -1
- package/dist/templates/view_search_input.template.d.ts.map +0 -1
- package/dist/templates/view_search_input.template.js +0 -2
- package/dist/templates/view_search_input.template.js.map +0 -1
- package/dist/testing/_relation-graph.js.map +0 -1
- package/dist/testing/fixture-manager.js.map +0 -1
- package/dist/types/types.js.map +0 -1
- package/dist/typings/knex.d.js.map +0 -1
- package/dist/utils/async-utils.js.map +0 -1
- package/dist/utils/controller.js.map +0 -1
- package/dist/utils/fs-utils.js.map +0 -1
- package/dist/utils/lodash-able.js.map +0 -1
- package/dist/utils/model.js.map +0 -1
- package/dist/utils/sql-parser.js.map +0 -1
- package/dist/utils/utils.js.map +0 -1
- package/dist/utils/zod-error.js.map +0 -1
- package/src/templates/base-template.ts +0 -19
- package/src/templates/index.ts +0 -1
|
@@ -0,0 +1,465 @@
|
|
|
1
|
+
import inflection from "inflection";
|
|
2
|
+
import * as _ from "lodash-es";
|
|
3
|
+
import { z } from "zod";
|
|
4
|
+
import { EntityManager } from "../../entity/entity-manager.js";
|
|
5
|
+
import { getRelationPropFromColName, getEnumInfoFromColName } from "../helpers.js";
|
|
6
|
+
import { Template } from "../template.js";
|
|
7
|
+
import { zodTypeToRenderingNode, getZodTypeById } from "../zod-converter.js";
|
|
8
|
+
import { getColumnsNode } from "../entity-converter.js";
|
|
9
|
+
export class Template__view_list extends Template {
|
|
10
|
+
constructor(){
|
|
11
|
+
super("view_list");
|
|
12
|
+
}
|
|
13
|
+
getTargetAndPath(names) {
|
|
14
|
+
return {
|
|
15
|
+
target: "web/src/pages/admin",
|
|
16
|
+
path: `${names.fsPlural}/index.tsx`
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
wrapTc(body, key, collapsing = true, className = "") {
|
|
20
|
+
return `<Table.Cell key="${key}"${collapsing ? " collapsing" : ""}${className ? ` className={\`${className}\`}` : ""}>${body}</Table.Cell>`;
|
|
21
|
+
}
|
|
22
|
+
renderColumn(entityId, col, names, parentObj = "row", withoutName = false) {
|
|
23
|
+
const colName = withoutName ? `${parentObj}` : `${parentObj}.${col.name}`;
|
|
24
|
+
switch(col.renderType){
|
|
25
|
+
case "string-plain":
|
|
26
|
+
case "string-date":
|
|
27
|
+
case "number-id":
|
|
28
|
+
return `<>{${colName}}</>`;
|
|
29
|
+
case "number-fk_id":
|
|
30
|
+
const relPropFk = getRelationPropFromColName(entityId, col.name.replace("_id", ""));
|
|
31
|
+
return `<>${relPropFk.with}#{${colName}}</>`;
|
|
32
|
+
case "string-image":
|
|
33
|
+
return `<>{${col.nullable ? `${colName} && ` : ""}<img src={${colName}} />}</>`;
|
|
34
|
+
case "datetime":
|
|
35
|
+
if (col.nullable) {
|
|
36
|
+
return `<span className="text-tiny">{${colName} === null ? '-' : formatDateTime(${colName})}</span>`;
|
|
37
|
+
} else {
|
|
38
|
+
return `<span className="text-tiny">{formatDateTime(${colName})}</span>`;
|
|
39
|
+
}
|
|
40
|
+
case "string-datetime":
|
|
41
|
+
if (col.nullable) {
|
|
42
|
+
return `<span className="text-tiny">{${colName} === null ? '-' : dateF(${colName})}</span>`;
|
|
43
|
+
} else {
|
|
44
|
+
return `<span className="text-tiny">{dateF(${colName})}</span>`;
|
|
45
|
+
}
|
|
46
|
+
case "boolean":
|
|
47
|
+
return `<>{${colName} ? <Label color='green' circular>O</Label> : <Label color='grey' circular>X</Label> }</>`;
|
|
48
|
+
case "enums":
|
|
49
|
+
const { id: enumId } = getEnumInfoFromColName(entityId, col.name);
|
|
50
|
+
return `<>{${col.nullable ? `${colName} && ` : ""}${enumId}Label[${colName}]}</>`;
|
|
51
|
+
case "array-images":
|
|
52
|
+
return `<>{ ${colName}.map(r => ${col.nullable ? `r && ` : ""}<img src={r} />) }</>`;
|
|
53
|
+
case "number-plain":
|
|
54
|
+
return `<>{${col.nullable ? `${colName} && ` : ""}numF(${colName})}</>`;
|
|
55
|
+
case "object":
|
|
56
|
+
return `<>{/* object ${colName} */}</>`;
|
|
57
|
+
case "object-pick":
|
|
58
|
+
const pickedChild = col.children.find((child)=>child.name === col.config?.picked);
|
|
59
|
+
if (!pickedChild) {
|
|
60
|
+
throw new Error(`object-pick 선택 실패 (오브젝트: ${col.name})`);
|
|
61
|
+
}
|
|
62
|
+
return this.renderColumn(entityId, pickedChild, names, `${colName}${col.nullable ? "?" : ""}`);
|
|
63
|
+
case "array":
|
|
64
|
+
return `<>{ /* array ${colName} */ }</>`;
|
|
65
|
+
default:
|
|
66
|
+
throw new Error(`렌더 불가 컬럼 ${col.renderType}`);
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
renderColumnImport(entityId, col, names) {
|
|
70
|
+
if (col.renderType === "enums") {
|
|
71
|
+
const { id: enumId } = getEnumInfoFromColName(names.capital, col.name);
|
|
72
|
+
return [
|
|
73
|
+
`import { ${enumId}Label } from 'src/services/sonamu.generated';`
|
|
74
|
+
];
|
|
75
|
+
} else if (col.renderType === "object") {
|
|
76
|
+
try {
|
|
77
|
+
const relProp = getRelationPropFromColName(entityId, col.name);
|
|
78
|
+
const result = col.children.map((child)=>{
|
|
79
|
+
entityId = relProp.with;
|
|
80
|
+
names = EntityManager.getNamesFromId(relProp.with);
|
|
81
|
+
return this.renderColumnImport(entityId, child, names);
|
|
82
|
+
});
|
|
83
|
+
return _.flattenDeep(result);
|
|
84
|
+
} catch {
|
|
85
|
+
return [
|
|
86
|
+
null
|
|
87
|
+
];
|
|
88
|
+
}
|
|
89
|
+
} else if (col.renderType === "array") {
|
|
90
|
+
return this.renderColumnImport(entityId, col.element, names);
|
|
91
|
+
}
|
|
92
|
+
return [
|
|
93
|
+
null
|
|
94
|
+
];
|
|
95
|
+
}
|
|
96
|
+
renderFilterImport(entityId, col, names) {
|
|
97
|
+
if (col.name === "search") {
|
|
98
|
+
return `import { ${names.capital}SearchInput } from "src/components/${names.fs}/${names.capital}SearchInput";`;
|
|
99
|
+
} else if (col.renderType === "enums") {
|
|
100
|
+
if (col.name === "orderBy") {
|
|
101
|
+
const componentId = `${names.capital}${inflection.camelize(col.name)}Select`;
|
|
102
|
+
return `import { ${componentId} } from "src/components/${names.fs}/${componentId}";`;
|
|
103
|
+
} else {
|
|
104
|
+
try {
|
|
105
|
+
const { id, targetEntityNames: targetMDNames } = getEnumInfoFromColName(entityId, col.name);
|
|
106
|
+
const componentId = `${id}Select`;
|
|
107
|
+
return `import { ${componentId} } from "src/components/${targetMDNames.fs}/${componentId}";`;
|
|
108
|
+
} catch {
|
|
109
|
+
return "";
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
} else if (col.renderType === "number-fk_id") {
|
|
113
|
+
try {
|
|
114
|
+
const relProp = getRelationPropFromColName(entityId, col.name.replace("_id", ""));
|
|
115
|
+
const targetNames = EntityManager.getNamesFromId(relProp.with);
|
|
116
|
+
const componentId = `${relProp.with}IdAsyncSelect`;
|
|
117
|
+
return `import { ${componentId} } from "src/components/${targetNames.fs}/${componentId}";`;
|
|
118
|
+
} catch {
|
|
119
|
+
return "";
|
|
120
|
+
}
|
|
121
|
+
} else {
|
|
122
|
+
throw new Error(`렌더 불가능한 필터 임포트 ${col.name} ${col.renderType}`);
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
renderFilter(entityId, col, names) {
|
|
126
|
+
if (col.name === "search") {
|
|
127
|
+
return "";
|
|
128
|
+
}
|
|
129
|
+
const isClearable = col.optional === true && col.name !== "orderBy";
|
|
130
|
+
let componentId;
|
|
131
|
+
if (col.renderType === "enums") {
|
|
132
|
+
if (col.name === "orderBy") {
|
|
133
|
+
componentId = `${names.capital}${inflection.camelize(col.name)}Select`;
|
|
134
|
+
} else {
|
|
135
|
+
try {
|
|
136
|
+
const { id } = getEnumInfoFromColName(entityId, col.name);
|
|
137
|
+
componentId = `${id}Select`;
|
|
138
|
+
} catch {
|
|
139
|
+
return "";
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
return `<${componentId} {...register('${col.name}')} ${isClearable ? "clearable" : ""} />`;
|
|
143
|
+
} else if (col.renderType === "number-fk_id") {
|
|
144
|
+
try {
|
|
145
|
+
const relProp = getRelationPropFromColName(entityId, col.name.replace("_id", ""));
|
|
146
|
+
componentId = `${relProp.with}IdAsyncSelect`;
|
|
147
|
+
return `<${componentId} {...register('${col.name}')} ${isClearable ? "clearable" : ""} subset="A" />`;
|
|
148
|
+
} catch {
|
|
149
|
+
return "";
|
|
150
|
+
}
|
|
151
|
+
} else {
|
|
152
|
+
throw new Error(`렌더 불가능한 필터 임포트 ${col.name} ${col.renderType}`);
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
getDefault(columns) {
|
|
156
|
+
const def = {
|
|
157
|
+
orderBy: "id-desc",
|
|
158
|
+
search: "title"
|
|
159
|
+
};
|
|
160
|
+
const orderByZodType = columns.find((col)=>col.name === "orderBy")?.zodType;
|
|
161
|
+
if (orderByZodType && orderByZodType instanceof z.ZodEnum) {
|
|
162
|
+
def.orderBy = orderByZodType.options[0].toString();
|
|
163
|
+
}
|
|
164
|
+
const searchZodType = columns.find((col)=>col.name === "search")?.zodType;
|
|
165
|
+
if (searchZodType && searchZodType instanceof z.ZodEnum) {
|
|
166
|
+
def.search = searchZodType.options[0].toString();
|
|
167
|
+
}
|
|
168
|
+
return def;
|
|
169
|
+
}
|
|
170
|
+
async render({ entityId }) {
|
|
171
|
+
const columnsNode = await getColumnsNode(entityId, "A");
|
|
172
|
+
const listParamsZodType = await getZodTypeById(`${entityId}ListParams`);
|
|
173
|
+
const listParamsNode = zodTypeToRenderingNode(listParamsZodType);
|
|
174
|
+
const names = EntityManager.getNamesFromId(entityId);
|
|
175
|
+
const entity = EntityManager.get(entityId);
|
|
176
|
+
// 실제 리스트 컬럼
|
|
177
|
+
const columns = columnsNode.children.filter((col)=>col.name !== "id").map((col)=>{
|
|
178
|
+
const propCandidate = entity.props.find((p)=>p.name === col.name);
|
|
179
|
+
return {
|
|
180
|
+
name: col.name,
|
|
181
|
+
label: propCandidate?.desc ?? col.label,
|
|
182
|
+
tc: `(row) => ${this.renderColumn(entityId, col, names)}`
|
|
183
|
+
};
|
|
184
|
+
});
|
|
185
|
+
// 필터 컬럼
|
|
186
|
+
const filterColumns = listParamsNode.children.filter((col)=>col.name !== "id" && col.name !== "queryMode" && ([
|
|
187
|
+
"enums",
|
|
188
|
+
"number-id"
|
|
189
|
+
].includes(col.renderType) || col.name.endsWith("_id")))// orderBy가 가장 뒤로 오게 순서 조정
|
|
190
|
+
.sort((a)=>{
|
|
191
|
+
return a.name == "orderBy" ? 1 : -1;
|
|
192
|
+
});
|
|
193
|
+
// 필터 컬럼을 프리 템플릿으로 설정
|
|
194
|
+
const preTemplates = [];
|
|
195
|
+
for (let col of filterColumns){
|
|
196
|
+
let key;
|
|
197
|
+
let targetEntityId = entityId;
|
|
198
|
+
let enumId;
|
|
199
|
+
if (col.renderType === "enums") {
|
|
200
|
+
if (col.name === "search") {
|
|
201
|
+
key = "view_enums_dropdown";
|
|
202
|
+
enumId = `${names.capital}SearchField`;
|
|
203
|
+
targetEntityId = names.capital;
|
|
204
|
+
} else {
|
|
205
|
+
key = "view_enums_select";
|
|
206
|
+
try {
|
|
207
|
+
const { targetEntityNames, id } = getEnumInfoFromColName(entityId, col.name);
|
|
208
|
+
targetEntityId = targetEntityNames.capital;
|
|
209
|
+
enumId = id;
|
|
210
|
+
} catch {
|
|
211
|
+
continue;
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
} else {
|
|
215
|
+
key = "view_id_async_select";
|
|
216
|
+
try {
|
|
217
|
+
const relProp = getRelationPropFromColName(entityId, col.name.replace("_id", ""));
|
|
218
|
+
targetEntityId = relProp.with;
|
|
219
|
+
} catch {
|
|
220
|
+
continue;
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
preTemplates.push({
|
|
224
|
+
key,
|
|
225
|
+
options: {
|
|
226
|
+
entityId: targetEntityId,
|
|
227
|
+
enumId
|
|
228
|
+
}
|
|
229
|
+
});
|
|
230
|
+
}
|
|
231
|
+
// 리스트 컬럼
|
|
232
|
+
const columnImports = _.uniq(columnsNode.children.map((col)=>{
|
|
233
|
+
return this.renderColumnImport(entityId, col, names);
|
|
234
|
+
}).flat().filter((col)=>col !== null)).join("\n");
|
|
235
|
+
// SearchInput
|
|
236
|
+
preTemplates.push({
|
|
237
|
+
key: "view_search_input",
|
|
238
|
+
options: {
|
|
239
|
+
entityId
|
|
240
|
+
}
|
|
241
|
+
});
|
|
242
|
+
// 디폴트 파라미터
|
|
243
|
+
const def = this.getDefault(filterColumns);
|
|
244
|
+
return {
|
|
245
|
+
...this.getTargetAndPath(names),
|
|
246
|
+
body: `
|
|
247
|
+
import React from 'react';
|
|
248
|
+
import { Link } from 'react-router-dom';
|
|
249
|
+
import {
|
|
250
|
+
Breadcrumb,
|
|
251
|
+
Checkbox,
|
|
252
|
+
Pagination,
|
|
253
|
+
Segment,
|
|
254
|
+
Table,
|
|
255
|
+
TableRow,
|
|
256
|
+
Message,
|
|
257
|
+
Transition,
|
|
258
|
+
Button,
|
|
259
|
+
Label,
|
|
260
|
+
} from 'semantic-ui-react';
|
|
261
|
+
import classNames from 'classnames';
|
|
262
|
+
import { DateTime } from "luxon";
|
|
263
|
+
import { DelButton, EditButton, AppBreadcrumbs, AddButton, useSelection, useListParams, SonamuCol, numF, formatDate, formatDateTime } from '@sonamu-kit/react-sui';
|
|
264
|
+
|
|
265
|
+
import { ${names.capital}SubsetA } from "src/services/sonamu.generated";
|
|
266
|
+
import { ${names.capital}Service } from 'src/services/${names.fs}/${names.fs}.service';
|
|
267
|
+
import { ${names.capital}ListParams } from 'src/services/${names.fs}/${names.fs}.types';
|
|
268
|
+
${columnImports}
|
|
269
|
+
${filterColumns.map((col)=>{
|
|
270
|
+
return this.renderFilterImport(entityId, col, names);
|
|
271
|
+
}).join("\n")}
|
|
272
|
+
|
|
273
|
+
type ${names.capital}ListProps = {};
|
|
274
|
+
export default function ${names.capital}List({}: ${names.capital}ListProps) {
|
|
275
|
+
// 리스트 필터
|
|
276
|
+
const { listParams, register } = useListParams(${names.capital}ListParams, {
|
|
277
|
+
num: 12,
|
|
278
|
+
page: 1,
|
|
279
|
+
orderBy: '${def.orderBy}',
|
|
280
|
+
search: '${def.search}',
|
|
281
|
+
});
|
|
282
|
+
|
|
283
|
+
// 리스트 쿼리
|
|
284
|
+
const { data, mutate, error, isLoading } = ${names.capital}Service.use${names.capitalPlural}('A', listParams);
|
|
285
|
+
const { rows, total } = data ?? {};
|
|
286
|
+
|
|
287
|
+
// 삭제
|
|
288
|
+
const confirmDel = (ids: number[]) => {
|
|
289
|
+
const answer = confirm('삭제하시겠습니까?');
|
|
290
|
+
if (!answer) {
|
|
291
|
+
return;
|
|
292
|
+
}
|
|
293
|
+
|
|
294
|
+
${names.capital}Service.del(ids).then(() => {
|
|
295
|
+
mutate();
|
|
296
|
+
});
|
|
297
|
+
};
|
|
298
|
+
|
|
299
|
+
// 일괄 삭제
|
|
300
|
+
const confirmDelSelected = () => {
|
|
301
|
+
const answer = confirm(\`\${selectedKeys.length}건을 일괄 삭제하시겠습니까?\`);
|
|
302
|
+
if (!answer) {
|
|
303
|
+
return;
|
|
304
|
+
}
|
|
305
|
+
|
|
306
|
+
${names.capital}Service.del(selectedKeys).then(() => {
|
|
307
|
+
mutate();
|
|
308
|
+
});
|
|
309
|
+
};
|
|
310
|
+
|
|
311
|
+
// 현재 경로와 타이틀
|
|
312
|
+
const PAGE = {
|
|
313
|
+
route: '/admin/${names.fsPlural}',
|
|
314
|
+
title: '${entity.title ?? names.capital}',
|
|
315
|
+
};
|
|
316
|
+
|
|
317
|
+
// 선택
|
|
318
|
+
const {
|
|
319
|
+
getSelected,
|
|
320
|
+
isAllSelected,
|
|
321
|
+
selectedKeys,
|
|
322
|
+
toggle,
|
|
323
|
+
selectAll,
|
|
324
|
+
deselectAll,
|
|
325
|
+
handleCheckboxClick,
|
|
326
|
+
} = useSelection((rows ?? []).map((row) => row.id));
|
|
327
|
+
|
|
328
|
+
// 컬럼
|
|
329
|
+
const columns:SonamuCol<${names.capital}SubsetA>[] = [${columns.map((col)=>{
|
|
330
|
+
return [
|
|
331
|
+
`{ label: "${col.label}",`,
|
|
332
|
+
`tc: ${col.tc}, `,
|
|
333
|
+
`collapsing: ${[
|
|
334
|
+
"Title",
|
|
335
|
+
"Name"
|
|
336
|
+
].includes(col.label) === false}, }`
|
|
337
|
+
].join("\n");
|
|
338
|
+
}).join(",\n")}];
|
|
339
|
+
|
|
340
|
+
return (
|
|
341
|
+
<div className="list ${names.fsPlural}-index">
|
|
342
|
+
<div className="top-nav">
|
|
343
|
+
<div className="header-row">
|
|
344
|
+
<div className="header">{PAGE.title}</div>
|
|
345
|
+
<AppBreadcrumbs>
|
|
346
|
+
<Breadcrumb.Section active>{PAGE.title}</Breadcrumb.Section>
|
|
347
|
+
</AppBreadcrumbs>
|
|
348
|
+
<${names.capital}SearchInput
|
|
349
|
+
input={register('keyword')}
|
|
350
|
+
dropdown={register('search')}
|
|
351
|
+
/>
|
|
352
|
+
</div>
|
|
353
|
+
<div className="filters-row">
|
|
354
|
+
${filterColumns.map((col)=>{
|
|
355
|
+
return this.renderFilter(entityId, col, names);
|
|
356
|
+
}).join(" \n")}
|
|
357
|
+
</div>
|
|
358
|
+
</div>
|
|
359
|
+
|
|
360
|
+
<Segment basic padded className="contents-segment" loading={isLoading}>
|
|
361
|
+
<div className="buttons-row">
|
|
362
|
+
<div className={classNames('count', { hidden: isLoading })}>
|
|
363
|
+
{total} 건
|
|
364
|
+
</div>
|
|
365
|
+
<div className="buttons">
|
|
366
|
+
<AddButton currentRoute={PAGE.route} icon="write" label="추가" />
|
|
367
|
+
</div>
|
|
368
|
+
</div>
|
|
369
|
+
|
|
370
|
+
<Table
|
|
371
|
+
celled
|
|
372
|
+
compact
|
|
373
|
+
selectable
|
|
374
|
+
className={classNames({ hidden: total === undefined || total === 0 })}
|
|
375
|
+
>
|
|
376
|
+
<Table.Header>
|
|
377
|
+
<TableRow>
|
|
378
|
+
<Table.HeaderCell collapsing>
|
|
379
|
+
<Checkbox
|
|
380
|
+
label="ID"
|
|
381
|
+
checked={isAllSelected}
|
|
382
|
+
onChange={isAllSelected ? deselectAll : selectAll}
|
|
383
|
+
/>
|
|
384
|
+
</Table.HeaderCell>
|
|
385
|
+
{
|
|
386
|
+
/* Header */
|
|
387
|
+
columns.map((col, index) => col.th ?? <Table.HeaderCell key={index} collapsing={col.collapsing}>{ col.label }</Table.HeaderCell>)
|
|
388
|
+
}
|
|
389
|
+
<Table.HeaderCell>관리</Table.HeaderCell>
|
|
390
|
+
</TableRow>
|
|
391
|
+
</Table.Header>
|
|
392
|
+
<Table.Body>
|
|
393
|
+
{rows &&
|
|
394
|
+
rows.map((row, rowIndex) => (
|
|
395
|
+
<Table.Row key={row.id}>
|
|
396
|
+
<Table.Cell>
|
|
397
|
+
<Checkbox
|
|
398
|
+
label={row.id}
|
|
399
|
+
checked={getSelected(row.id)}
|
|
400
|
+
onChange={() => toggle(row.id)}
|
|
401
|
+
onClick={(e) =>
|
|
402
|
+
handleCheckboxClick(e, rowIndex)
|
|
403
|
+
}
|
|
404
|
+
/>
|
|
405
|
+
</Table.Cell>
|
|
406
|
+
{
|
|
407
|
+
/* Body */
|
|
408
|
+
columns.map((col, colIndex) => (
|
|
409
|
+
<Table.Cell key={colIndex} collapsing={col.collapsing} className={col.className}>
|
|
410
|
+
{col.tc(row, rowIndex)}
|
|
411
|
+
</Table.Cell>
|
|
412
|
+
))
|
|
413
|
+
}
|
|
414
|
+
<Table.Cell collapsing>
|
|
415
|
+
<EditButton
|
|
416
|
+
as={Link}
|
|
417
|
+
to={\`\${PAGE.route}/form?id=\${row.id}\`}
|
|
418
|
+
state={{ from: PAGE.route }}
|
|
419
|
+
/>
|
|
420
|
+
<DelButton onClick={() => confirmDel([row.id])} />
|
|
421
|
+
</Table.Cell>
|
|
422
|
+
</Table.Row>
|
|
423
|
+
))}
|
|
424
|
+
</Table.Body>
|
|
425
|
+
</Table>
|
|
426
|
+
<div
|
|
427
|
+
className={classNames('pagination-row', {
|
|
428
|
+
hidden: (total ?? 0) === 0,
|
|
429
|
+
})}
|
|
430
|
+
>
|
|
431
|
+
<Pagination
|
|
432
|
+
totalPages={Math.ceil((total ?? 0) / (listParams.num ?? 24))}
|
|
433
|
+
{...register('page')}
|
|
434
|
+
/>
|
|
435
|
+
</div>
|
|
436
|
+
</Segment>
|
|
437
|
+
|
|
438
|
+
<div className="fixed-menu">
|
|
439
|
+
<Transition
|
|
440
|
+
visible={selectedKeys.length > 0}
|
|
441
|
+
animation="slide left"
|
|
442
|
+
duration={500}
|
|
443
|
+
>
|
|
444
|
+
<Message size="small" color="violet" className="text-center">
|
|
445
|
+
<span className="px-4">{selectedKeys.length}개 선택됨</span>
|
|
446
|
+
<Button size="tiny" color="violet" onClick={() => deselectAll()}>
|
|
447
|
+
선택 해제
|
|
448
|
+
</Button>
|
|
449
|
+
<Button size="tiny" color="red" onClick={confirmDelSelected}>
|
|
450
|
+
일괄 삭제
|
|
451
|
+
</Button>
|
|
452
|
+
</Message>
|
|
453
|
+
</Transition>
|
|
454
|
+
</div>
|
|
455
|
+
</div>
|
|
456
|
+
);
|
|
457
|
+
}
|
|
458
|
+
`.trim(),
|
|
459
|
+
importKeys: [],
|
|
460
|
+
preTemplates
|
|
461
|
+
};
|
|
462
|
+
}
|
|
463
|
+
}
|
|
464
|
+
|
|
465
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy90ZW1wbGF0ZS9pbXBsZW1lbnRhdGlvbnMvdmlld19saXN0LnRlbXBsYXRlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBpbmZsZWN0aW9uIGZyb20gXCJpbmZsZWN0aW9uXCI7XG5pbXBvcnQgKiBhcyBfIGZyb20gXCJsb2Rhc2gtZXNcIjtcbmltcG9ydCB7IHogfSBmcm9tIFwiem9kXCI7XG5pbXBvcnQgeyBSZW5kZXJpbmdOb2RlLCBUZW1wbGF0ZUtleSwgVGVtcGxhdGVPcHRpb25zIH0gZnJvbSBcIi4uLy4uL3R5cGVzL3R5cGVzXCI7XG5pbXBvcnQgeyBFbnRpdHlNYW5hZ2VyLCBFbnRpdHlOYW1lc1JlY29yZCB9IGZyb20gXCIuLi8uLi9lbnRpdHkvZW50aXR5LW1hbmFnZXJcIjtcbmltcG9ydCB7IGdldFJlbGF0aW9uUHJvcEZyb21Db2xOYW1lLCBnZXRFbnVtSW5mb0Zyb21Db2xOYW1lIH0gZnJvbSBcIi4uL2hlbHBlcnNcIjtcbmltcG9ydCB7IFJlbmRlcmVkVGVtcGxhdGUgfSBmcm9tIFwiLi4vdGVtcGxhdGVcIjtcbmltcG9ydCB7IFRlbXBsYXRlIH0gZnJvbSBcIi4uL3RlbXBsYXRlXCI7XG5pbXBvcnQgeyB6b2RUeXBlVG9SZW5kZXJpbmdOb2RlLCBnZXRab2RUeXBlQnlJZCB9IGZyb20gXCIuLi96b2QtY29udmVydGVyXCI7XG5pbXBvcnQgeyBnZXRDb2x1bW5zTm9kZSB9IGZyb20gXCIuLi9lbnRpdHktY29udmVydGVyXCI7XG5cbmV4cG9ydCBjbGFzcyBUZW1wbGF0ZV9fdmlld19saXN0IGV4dGVuZHMgVGVtcGxhdGUge1xuICBjb25zdHJ1Y3RvcigpIHtcbiAgICBzdXBlcihcInZpZXdfbGlzdFwiKTtcbiAgfVxuXG4gIGdldFRhcmdldEFuZFBhdGgobmFtZXM6IEVudGl0eU5hbWVzUmVjb3JkKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIHRhcmdldDogXCJ3ZWIvc3JjL3BhZ2VzL2FkbWluXCIsXG4gICAgICBwYXRoOiBgJHtuYW1lcy5mc1BsdXJhbH0vaW5kZXgudHN4YCxcbiAgICB9O1xuICB9XG5cbiAgd3JhcFRjKFxuICAgIGJvZHk6IHN0cmluZyxcbiAgICBrZXk6IHN0cmluZyxcbiAgICBjb2xsYXBzaW5nOiBib29sZWFuID0gdHJ1ZSxcbiAgICBjbGFzc05hbWU6IHN0cmluZyA9IFwiXCJcbiAgKSB7XG4gICAgcmV0dXJuIGA8VGFibGUuQ2VsbCBrZXk9XCIke2tleX1cIiR7Y29sbGFwc2luZyA/IFwiIGNvbGxhcHNpbmdcIiA6IFwiXCJ9JHtcbiAgICAgIGNsYXNzTmFtZSA/IGAgY2xhc3NOYW1lPXtcXGAke2NsYXNzTmFtZX1cXGB9YCA6IFwiXCJcbiAgICB9PiR7Ym9keX08L1RhYmxlLkNlbGw+YDtcbiAgfVxuXG4gIHJlbmRlckNvbHVtbihcbiAgICBlbnRpdHlJZDogc3RyaW5nLFxuICAgIGNvbDogUmVuZGVyaW5nTm9kZSxcbiAgICBuYW1lczogRW50aXR5TmFtZXNSZWNvcmQsXG4gICAgcGFyZW50T2JqOiBzdHJpbmcgPSBcInJvd1wiLFxuICAgIHdpdGhvdXROYW1lOiBib29sZWFuID0gZmFsc2VcbiAgKTogc3RyaW5nIHtcbiAgICBjb25zdCBjb2xOYW1lID0gd2l0aG91dE5hbWUgPyBgJHtwYXJlbnRPYmp9YCA6IGAke3BhcmVudE9ian0uJHtjb2wubmFtZX1gO1xuXG4gICAgc3dpdGNoIChjb2wucmVuZGVyVHlwZSkge1xuICAgICAgY2FzZSBcInN0cmluZy1wbGFpblwiOlxuICAgICAgY2FzZSBcInN0cmluZy1kYXRlXCI6XG4gICAgICBjYXNlIFwibnVtYmVyLWlkXCI6XG4gICAgICAgIHJldHVybiBgPD57JHtjb2xOYW1lfX08Lz5gO1xuICAgICAgY2FzZSBcIm51bWJlci1ma19pZFwiOlxuICAgICAgICBjb25zdCByZWxQcm9wRmsgPSBnZXRSZWxhdGlvblByb3BGcm9tQ29sTmFtZShcbiAgICAgICAgICBlbnRpdHlJZCxcbiAgICAgICAgICBjb2wubmFtZS5yZXBsYWNlKFwiX2lkXCIsIFwiXCIpXG4gICAgICAgICk7XG4gICAgICAgIHJldHVybiBgPD4ke3JlbFByb3BGay53aXRofSN7JHtjb2xOYW1lfX08Lz5gO1xuICAgICAgY2FzZSBcInN0cmluZy1pbWFnZVwiOlxuICAgICAgICByZXR1cm4gYDw+eyR7XG4gICAgICAgICAgY29sLm51bGxhYmxlID8gYCR7Y29sTmFtZX0gJiYgYCA6IFwiXCJcbiAgICAgICAgfTxpbWcgc3JjPXske2NvbE5hbWV9fSAvPn08Lz5gO1xuICAgICAgY2FzZSBcImRhdGV0aW1lXCI6XG4gICAgICAgIGlmIChjb2wubnVsbGFibGUpIHtcbiAgICAgICAgICByZXR1cm4gYDxzcGFuIGNsYXNzTmFtZT1cInRleHQtdGlueVwiPnske2NvbE5hbWV9ID09PSBudWxsID8gJy0nIDogZm9ybWF0RGF0ZVRpbWUoJHtjb2xOYW1lfSl9PC9zcGFuPmA7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgcmV0dXJuIGA8c3BhbiBjbGFzc05hbWU9XCJ0ZXh0LXRpbnlcIj57Zm9ybWF0RGF0ZVRpbWUoJHtjb2xOYW1lfSl9PC9zcGFuPmA7XG4gICAgICAgIH1cbiAgICAgIGNhc2UgXCJzdHJpbmctZGF0ZXRpbWVcIjpcbiAgICAgICAgaWYgKGNvbC5udWxsYWJsZSkge1xuICAgICAgICAgIHJldHVybiBgPHNwYW4gY2xhc3NOYW1lPVwidGV4dC10aW55XCI+eyR7Y29sTmFtZX0gPT09IG51bGwgPyAnLScgOiBkYXRlRigke2NvbE5hbWV9KX08L3NwYW4+YDtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICByZXR1cm4gYDxzcGFuIGNsYXNzTmFtZT1cInRleHQtdGlueVwiPntkYXRlRigke2NvbE5hbWV9KX08L3NwYW4+YDtcbiAgICAgICAgfVxuICAgICAgY2FzZSBcImJvb2xlYW5cIjpcbiAgICAgICAgcmV0dXJuIGA8Pnske2NvbE5hbWV9ID8gPExhYmVsIGNvbG9yPSdncmVlbicgY2lyY3VsYXI+TzwvTGFiZWw+IDogPExhYmVsIGNvbG9yPSdncmV5JyBjaXJjdWxhcj5YPC9MYWJlbD4gfTwvPmA7XG4gICAgICBjYXNlIFwiZW51bXNcIjpcbiAgICAgICAgY29uc3QgeyBpZDogZW51bUlkIH0gPSBnZXRFbnVtSW5mb0Zyb21Db2xOYW1lKGVudGl0eUlkLCBjb2wubmFtZSk7XG4gICAgICAgIHJldHVybiBgPD57JHtcbiAgICAgICAgICBjb2wubnVsbGFibGUgPyBgJHtjb2xOYW1lfSAmJiBgIDogXCJcIlxuICAgICAgICB9JHtlbnVtSWR9TGFiZWxbJHtjb2xOYW1lfV19PC8+YDtcbiAgICAgIGNhc2UgXCJhcnJheS1pbWFnZXNcIjpcbiAgICAgICAgcmV0dXJuIGA8PnsgJHtjb2xOYW1lfS5tYXAociA9PiAke1xuICAgICAgICAgIGNvbC5udWxsYWJsZSA/IGByICYmIGAgOiBcIlwiXG4gICAgICAgIH08aW1nIHNyYz17cn0gLz4pIH08Lz5gO1xuICAgICAgY2FzZSBcIm51bWJlci1wbGFpblwiOlxuICAgICAgICByZXR1cm4gYDw+eyR7Y29sLm51bGxhYmxlID8gYCR7Y29sTmFtZX0gJiYgYCA6IFwiXCJ9bnVtRigke2NvbE5hbWV9KX08Lz5gO1xuICAgICAgY2FzZSBcIm9iamVjdFwiOlxuICAgICAgICByZXR1cm4gYDw+ey8qIG9iamVjdCAke2NvbE5hbWV9ICovfTwvPmA7XG4gICAgICBjYXNlIFwib2JqZWN0LXBpY2tcIjpcbiAgICAgICAgY29uc3QgcGlja2VkQ2hpbGQgPSBjb2wuY2hpbGRyZW4hLmZpbmQoXG4gICAgICAgICAgKGNoaWxkKSA9PiBjaGlsZC5uYW1lID09PSBjb2wuY29uZmlnPy5waWNrZWRcbiAgICAgICAgKTtcbiAgICAgICAgaWYgKCFwaWNrZWRDaGlsZCkge1xuICAgICAgICAgIHRocm93IG5ldyBFcnJvcihgb2JqZWN0LXBpY2sg7ISg7YOdIOyLpO2MqCAo7Jik67iM7KCd7Yq4OiAke2NvbC5uYW1lfSlgKTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gdGhpcy5yZW5kZXJDb2x1bW4oXG4gICAgICAgICAgZW50aXR5SWQsXG4gICAgICAgICAgcGlja2VkQ2hpbGQsXG4gICAgICAgICAgbmFtZXMsXG4gICAgICAgICAgYCR7Y29sTmFtZX0ke2NvbC5udWxsYWJsZSA/IFwiP1wiIDogXCJcIn1gXG4gICAgICAgICk7XG4gICAgICBjYXNlIFwiYXJyYXlcIjpcbiAgICAgICAgcmV0dXJuIGA8PnsgLyogYXJyYXkgJHtjb2xOYW1lfSAqLyB9PC8+YDtcbiAgICAgIGRlZmF1bHQ6XG4gICAgICAgIHRocm93IG5ldyBFcnJvcihg66CM642UIOu2iOqwgCDsu6zrn7wgJHtjb2wucmVuZGVyVHlwZX1gKTtcbiAgICB9XG4gIH1cblxuICByZW5kZXJDb2x1bW5JbXBvcnQoXG4gICAgZW50aXR5SWQ6IHN0cmluZyxcbiAgICBjb2w6IFJlbmRlcmluZ05vZGUsXG4gICAgbmFtZXM6IEVudGl0eU5hbWVzUmVjb3JkXG4gICk6IChzdHJpbmcgfCBudWxsKVtdIHtcbiAgICBpZiAoY29sLnJlbmRlclR5cGUgPT09IFwiZW51bXNcIikge1xuICAgICAgY29uc3QgeyBpZDogZW51bUlkIH0gPSBnZXRFbnVtSW5mb0Zyb21Db2xOYW1lKG5hbWVzLmNhcGl0YWwsIGNvbC5uYW1lKTtcbiAgICAgIHJldHVybiBbXG4gICAgICAgIGBpbXBvcnQgeyAke2VudW1JZH1MYWJlbCB9IGZyb20gJ3NyYy9zZXJ2aWNlcy9zb25hbXUuZ2VuZXJhdGVkJztgLFxuICAgICAgXTtcbiAgICB9IGVsc2UgaWYgKGNvbC5yZW5kZXJUeXBlID09PSBcIm9iamVjdFwiKSB7XG4gICAgICB0cnkge1xuICAgICAgICBjb25zdCByZWxQcm9wID0gZ2V0UmVsYXRpb25Qcm9wRnJvbUNvbE5hbWUoZW50aXR5SWQsIGNvbC5uYW1lKTtcbiAgICAgICAgY29uc3QgcmVzdWx0ID0gY29sLmNoaWxkcmVuIS5tYXAoKGNoaWxkKSA9PiB7XG4gICAgICAgICAgZW50aXR5SWQgPSByZWxQcm9wLndpdGg7XG4gICAgICAgICAgbmFtZXMgPSBFbnRpdHlNYW5hZ2VyLmdldE5hbWVzRnJvbUlkKHJlbFByb3Aud2l0aCk7XG4gICAgICAgICAgcmV0dXJuIHRoaXMucmVuZGVyQ29sdW1uSW1wb3J0KGVudGl0eUlkLCBjaGlsZCwgbmFtZXMpO1xuICAgICAgICB9KTtcbiAgICAgICAgcmV0dXJuIF8uZmxhdHRlbkRlZXAocmVzdWx0KTtcbiAgICAgIH0gY2F0Y2gge1xuICAgICAgICByZXR1cm4gW251bGxdO1xuICAgICAgfVxuICAgIH0gZWxzZSBpZiAoY29sLnJlbmRlclR5cGUgPT09IFwiYXJyYXlcIikge1xuICAgICAgcmV0dXJuIHRoaXMucmVuZGVyQ29sdW1uSW1wb3J0KGVudGl0eUlkLCBjb2wuZWxlbWVudCEsIG5hbWVzKTtcbiAgICB9XG5cbiAgICByZXR1cm4gW251bGxdO1xuICB9XG5cbiAgcmVuZGVyRmlsdGVySW1wb3J0KFxuICAgIGVudGl0eUlkOiBzdHJpbmcsXG4gICAgY29sOiBSZW5kZXJpbmdOb2RlLFxuICAgIG5hbWVzOiBFbnRpdHlOYW1lc1JlY29yZFxuICApIHtcbiAgICBpZiAoY29sLm5hbWUgPT09IFwic2VhcmNoXCIpIHtcbiAgICAgIHJldHVybiBgaW1wb3J0IHsgJHtuYW1lcy5jYXBpdGFsfVNlYXJjaElucHV0IH0gZnJvbSBcInNyYy9jb21wb25lbnRzLyR7bmFtZXMuZnN9LyR7bmFtZXMuY2FwaXRhbH1TZWFyY2hJbnB1dFwiO2A7XG4gICAgfSBlbHNlIGlmIChjb2wucmVuZGVyVHlwZSA9PT0gXCJlbnVtc1wiKSB7XG4gICAgICBpZiAoY29sLm5hbWUgPT09IFwib3JkZXJCeVwiKSB7XG4gICAgICAgIGNvbnN0IGNvbXBvbmVudElkID0gYCR7bmFtZXMuY2FwaXRhbH0ke2luZmxlY3Rpb24uY2FtZWxpemUoXG4gICAgICAgICAgY29sLm5hbWVcbiAgICAgICAgKX1TZWxlY3RgO1xuICAgICAgICByZXR1cm4gYGltcG9ydCB7ICR7Y29tcG9uZW50SWR9IH0gZnJvbSBcInNyYy9jb21wb25lbnRzLyR7bmFtZXMuZnN9LyR7Y29tcG9uZW50SWR9XCI7YDtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgY29uc3QgeyBpZCwgdGFyZ2V0RW50aXR5TmFtZXM6IHRhcmdldE1ETmFtZXMgfSA9XG4gICAgICAgICAgICBnZXRFbnVtSW5mb0Zyb21Db2xOYW1lKGVudGl0eUlkLCBjb2wubmFtZSk7XG4gICAgICAgICAgY29uc3QgY29tcG9uZW50SWQgPSBgJHtpZH1TZWxlY3RgO1xuICAgICAgICAgIHJldHVybiBgaW1wb3J0IHsgJHtjb21wb25lbnRJZH0gfSBmcm9tIFwic3JjL2NvbXBvbmVudHMvJHt0YXJnZXRNRE5hbWVzLmZzfS8ke2NvbXBvbmVudElkfVwiO2A7XG4gICAgICAgIH0gY2F0Y2gge1xuICAgICAgICAgIHJldHVybiBcIlwiO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfSBlbHNlIGlmIChjb2wucmVuZGVyVHlwZSA9PT0gXCJudW1iZXItZmtfaWRcIikge1xuICAgICAgdHJ5IHtcbiAgICAgICAgY29uc3QgcmVsUHJvcCA9IGdldFJlbGF0aW9uUHJvcEZyb21Db2xOYW1lKFxuICAgICAgICAgIGVudGl0eUlkLFxuICAgICAgICAgIGNvbC5uYW1lLnJlcGxhY2UoXCJfaWRcIiwgXCJcIilcbiAgICAgICAgKTtcbiAgICAgICAgY29uc3QgdGFyZ2V0TmFtZXMgPSBFbnRpdHlNYW5hZ2VyLmdldE5hbWVzRnJvbUlkKHJlbFByb3Aud2l0aCk7XG4gICAgICAgIGNvbnN0IGNvbXBvbmVudElkID0gYCR7cmVsUHJvcC53aXRofUlkQXN5bmNTZWxlY3RgO1xuICAgICAgICByZXR1cm4gYGltcG9ydCB7ICR7Y29tcG9uZW50SWR9IH0gZnJvbSBcInNyYy9jb21wb25lbnRzLyR7dGFyZ2V0TmFtZXMuZnN9LyR7Y29tcG9uZW50SWR9XCI7YDtcbiAgICAgIH0gY2F0Y2gge1xuICAgICAgICByZXR1cm4gXCJcIjtcbiAgICAgIH1cbiAgICB9IGVsc2Uge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgICBg66CM642UIOu2iOqwgOuKpe2VnCDtlYTthLAg7J6E7Y+s7Yq4ICR7Y29sLm5hbWV9ICR7Y29sLnJlbmRlclR5cGV9YFxuICAgICAgKTtcbiAgICB9XG4gIH1cblxuICByZW5kZXJGaWx0ZXIoZW50aXR5SWQ6IHN0cmluZywgY29sOiBSZW5kZXJpbmdOb2RlLCBuYW1lczogRW50aXR5TmFtZXNSZWNvcmQpIHtcbiAgICBpZiAoY29sLm5hbWUgPT09IFwic2VhcmNoXCIpIHtcbiAgICAgIHJldHVybiBcIlwiO1xuICAgIH1cblxuICAgIGNvbnN0IGlzQ2xlYXJhYmxlID0gY29sLm9wdGlvbmFsID09PSB0cnVlICYmIGNvbC5uYW1lICE9PSBcIm9yZGVyQnlcIjtcbiAgICBsZXQgY29tcG9uZW50SWQ6IHN0cmluZztcbiAgICBpZiAoY29sLnJlbmRlclR5cGUgPT09IFwiZW51bXNcIikge1xuICAgICAgaWYgKGNvbC5uYW1lID09PSBcIm9yZGVyQnlcIikge1xuICAgICAgICBjb21wb25lbnRJZCA9IGAke25hbWVzLmNhcGl0YWx9JHtpbmZsZWN0aW9uLmNhbWVsaXplKGNvbC5uYW1lKX1TZWxlY3RgO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgdHJ5IHtcbiAgICAgICAgICBjb25zdCB7IGlkIH0gPSBnZXRFbnVtSW5mb0Zyb21Db2xOYW1lKGVudGl0eUlkLCBjb2wubmFtZSk7XG4gICAgICAgICAgY29tcG9uZW50SWQgPSBgJHtpZH1TZWxlY3RgO1xuICAgICAgICB9IGNhdGNoIHtcbiAgICAgICAgICByZXR1cm4gXCJcIjtcbiAgICAgICAgfVxuICAgICAgfVxuICAgICAgcmV0dXJuIGA8JHtjb21wb25lbnRJZH0gey4uLnJlZ2lzdGVyKCcke2NvbC5uYW1lfScpfSAke1xuICAgICAgICBpc0NsZWFyYWJsZSA/IFwiY2xlYXJhYmxlXCIgOiBcIlwiXG4gICAgICB9IC8+YDtcbiAgICB9IGVsc2UgaWYgKGNvbC5yZW5kZXJUeXBlID09PSBcIm51bWJlci1ma19pZFwiKSB7XG4gICAgICB0cnkge1xuICAgICAgICBjb25zdCByZWxQcm9wID0gZ2V0UmVsYXRpb25Qcm9wRnJvbUNvbE5hbWUoXG4gICAgICAgICAgZW50aXR5SWQsXG4gICAgICAgICAgY29sLm5hbWUucmVwbGFjZShcIl9pZFwiLCBcIlwiKVxuICAgICAgICApO1xuICAgICAgICBjb21wb25lbnRJZCA9IGAke3JlbFByb3Aud2l0aH1JZEFzeW5jU2VsZWN0YDtcbiAgICAgICAgcmV0dXJuIGA8JHtjb21wb25lbnRJZH0gey4uLnJlZ2lzdGVyKCcke2NvbC5uYW1lfScpfSAke1xuICAgICAgICAgIGlzQ2xlYXJhYmxlID8gXCJjbGVhcmFibGVcIiA6IFwiXCJcbiAgICAgICAgfSBzdWJzZXQ9XCJBXCIgLz5gO1xuICAgICAgfSBjYXRjaCB7XG4gICAgICAgIHJldHVybiBcIlwiO1xuICAgICAgfVxuICAgIH0gZWxzZSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICAgIGDroIzrjZQg67aI6rCA64ql7ZWcIO2VhO2EsCDsnoTtj6ztirggJHtjb2wubmFtZX0gJHtjb2wucmVuZGVyVHlwZX1gXG4gICAgICApO1xuICAgIH1cbiAgfVxuXG4gIGdldERlZmF1bHQoY29sdW1uczogUmVuZGVyaW5nTm9kZVtdKToge1xuICAgIG9yZGVyQnk6IHN0cmluZztcbiAgICBzZWFyY2g6IHN0cmluZztcbiAgfSB7XG4gICAgY29uc3QgZGVmID0ge1xuICAgICAgb3JkZXJCeTogXCJpZC1kZXNjXCIsXG4gICAgICBzZWFyY2g6IFwidGl0bGVcIixcbiAgICB9O1xuICAgIGNvbnN0IG9yZGVyQnlab2RUeXBlID0gY29sdW1ucy5maW5kKFxuICAgICAgKGNvbCkgPT4gY29sLm5hbWUgPT09IFwib3JkZXJCeVwiXG4gICAgKT8uem9kVHlwZTtcbiAgICBpZiAob3JkZXJCeVpvZFR5cGUgJiYgb3JkZXJCeVpvZFR5cGUgaW5zdGFuY2VvZiB6LlpvZEVudW0pIHtcbiAgICAgIGRlZi5vcmRlckJ5ID0gb3JkZXJCeVpvZFR5cGUub3B0aW9uc1swXS50b1N0cmluZygpO1xuICAgIH1cbiAgICBjb25zdCBzZWFyY2hab2RUeXBlID0gY29sdW1ucy5maW5kKChjb2wpID0+IGNvbC5uYW1lID09PSBcInNlYXJjaFwiKT8uem9kVHlwZTtcbiAgICBpZiAoc2VhcmNoWm9kVHlwZSAmJiBzZWFyY2hab2RUeXBlIGluc3RhbmNlb2Ygei5ab2RFbnVtKSB7XG4gICAgICBkZWYuc2VhcmNoID0gc2VhcmNoWm9kVHlwZS5vcHRpb25zWzBdLnRvU3RyaW5nKCk7XG4gICAgfVxuICAgIHJldHVybiBkZWY7XG4gIH1cblxuICBhc3luYyByZW5kZXIoeyBlbnRpdHlJZCB9OiBUZW1wbGF0ZU9wdGlvbnNbXCJ2aWV3X2xpc3RcIl0pIHtcbiAgICBjb25zdCBjb2x1bW5zTm9kZSA9IGF3YWl0IGdldENvbHVtbnNOb2RlKGVudGl0eUlkLCBcIkFcIik7XG4gICAgY29uc3QgbGlzdFBhcmFtc1pvZFR5cGUgPSBhd2FpdCBnZXRab2RUeXBlQnlJZChgJHtlbnRpdHlJZH1MaXN0UGFyYW1zYCk7XG4gICAgY29uc3QgbGlzdFBhcmFtc05vZGUgPSB6b2RUeXBlVG9SZW5kZXJpbmdOb2RlKGxpc3RQYXJhbXNab2RUeXBlKTtcblxuICAgIGNvbnN0IG5hbWVzID0gRW50aXR5TWFuYWdlci5nZXROYW1lc0Zyb21JZChlbnRpdHlJZCk7XG4gICAgY29uc3QgZW50aXR5ID0gRW50aXR5TWFuYWdlci5nZXQoZW50aXR5SWQpO1xuXG4gICAgLy8g7Iuk7KCcIOumrOyKpO2KuCDsu6zrn7xcbiAgICBjb25zdCBjb2x1bW5zID0gKGNvbHVtbnNOb2RlLmNoaWxkcmVuIGFzIFJlbmRlcmluZ05vZGVbXSlcbiAgICAgIC5maWx0ZXIoKGNvbCkgPT4gY29sLm5hbWUgIT09IFwiaWRcIilcbiAgICAgIC5tYXAoKGNvbCkgPT4ge1xuICAgICAgICBjb25zdCBwcm9wQ2FuZGlkYXRlID0gZW50aXR5LnByb3BzLmZpbmQoKHApID0+IHAubmFtZSA9PT0gY29sLm5hbWUpO1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgIG5hbWU6IGNvbC5uYW1lLFxuICAgICAgICAgIGxhYmVsOiBwcm9wQ2FuZGlkYXRlPy5kZXNjID8/IGNvbC5sYWJlbCxcbiAgICAgICAgICB0YzogYChyb3cpID0+ICR7dGhpcy5yZW5kZXJDb2x1bW4oZW50aXR5SWQsIGNvbCwgbmFtZXMpfWAsXG4gICAgICAgIH07XG4gICAgICB9KTtcblxuICAgIC8vIO2VhO2EsCDsu6zrn7xcbiAgICBjb25zdCBmaWx0ZXJDb2x1bW5zID0gKGxpc3RQYXJhbXNOb2RlLmNoaWxkcmVuIGFzIFJlbmRlcmluZ05vZGVbXSlcbiAgICAgIC5maWx0ZXIoXG4gICAgICAgIChjb2wpID0+XG4gICAgICAgICAgY29sLm5hbWUgIT09IFwiaWRcIiAmJlxuICAgICAgICAgIGNvbC5uYW1lICE9PSBcInF1ZXJ5TW9kZVwiICYmXG4gICAgICAgICAgKFtcImVudW1zXCIsIFwibnVtYmVyLWlkXCJdLmluY2x1ZGVzKGNvbC5yZW5kZXJUeXBlKSB8fFxuICAgICAgICAgICAgY29sLm5hbWUuZW5kc1dpdGgoXCJfaWRcIikpXG4gICAgICApXG4gICAgICAvLyBvcmRlckJ56rCAIOqwgOyepSDrkqTroZwg7Jik6rKMIOyInOyEnCDsobDsoJVcbiAgICAgIC5zb3J0KChhKSA9PiB7XG4gICAgICAgIHJldHVybiBhLm5hbWUgPT0gXCJvcmRlckJ5XCIgPyAxIDogLTE7XG4gICAgICB9KTtcblxuICAgIC8vIO2VhO2EsCDsu6zrn7zsnYQg7ZSE66asIO2FnO2UjOumv+ycvOuhnCDshKTsoJVcbiAgICBjb25zdCBwcmVUZW1wbGF0ZXM6IFJlbmRlcmVkVGVtcGxhdGVbXCJwcmVUZW1wbGF0ZXNcIl0gPSBbXTtcbiAgICBmb3IgKGxldCBjb2wgb2YgZmlsdGVyQ29sdW1ucykge1xuICAgICAgbGV0IGtleTogVGVtcGxhdGVLZXk7XG4gICAgICBsZXQgdGFyZ2V0RW50aXR5SWQgPSBlbnRpdHlJZDtcbiAgICAgIGxldCBlbnVtSWQ6IHN0cmluZyB8IHVuZGVmaW5lZDtcblxuICAgICAgaWYgKGNvbC5yZW5kZXJUeXBlID09PSBcImVudW1zXCIpIHtcbiAgICAgICAgaWYgKGNvbC5uYW1lID09PSBcInNlYXJjaFwiKSB7XG4gICAgICAgICAga2V5ID0gXCJ2aWV3X2VudW1zX2Ryb3Bkb3duXCI7XG4gICAgICAgICAgZW51bUlkID0gYCR7bmFtZXMuY2FwaXRhbH1TZWFyY2hGaWVsZGA7XG4gICAgICAgICAgdGFyZ2V0RW50aXR5SWQgPSBuYW1lcy5jYXBpdGFsO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGtleSA9IFwidmlld19lbnVtc19zZWxlY3RcIjtcbiAgICAgICAgICB0cnkge1xuICAgICAgICAgICAgY29uc3QgeyB0YXJnZXRFbnRpdHlOYW1lcywgaWQgfSA9IGdldEVudW1JbmZvRnJvbUNvbE5hbWUoXG4gICAgICAgICAgICAgIGVudGl0eUlkLFxuICAgICAgICAgICAgICBjb2wubmFtZVxuICAgICAgICAgICAgKTtcbiAgICAgICAgICAgIHRhcmdldEVudGl0eUlkID0gdGFyZ2V0RW50aXR5TmFtZXMuY2FwaXRhbDtcbiAgICAgICAgICAgIGVudW1JZCA9IGlkO1xuICAgICAgICAgIH0gY2F0Y2gge1xuICAgICAgICAgICAgY29udGludWU7XG4gICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBrZXkgPSBcInZpZXdfaWRfYXN5bmNfc2VsZWN0XCI7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgY29uc3QgcmVsUHJvcCA9IGdldFJlbGF0aW9uUHJvcEZyb21Db2xOYW1lKFxuICAgICAgICAgICAgZW50aXR5SWQsXG4gICAgICAgICAgICBjb2wubmFtZS5yZXBsYWNlKFwiX2lkXCIsIFwiXCIpXG4gICAgICAgICAgKTtcbiAgICAgICAgICB0YXJnZXRFbnRpdHlJZCA9IHJlbFByb3Aud2l0aDtcbiAgICAgICAgfSBjYXRjaCB7XG4gICAgICAgICAgY29udGludWU7XG4gICAgICAgIH1cbiAgICAgIH1cblxuICAgICAgcHJlVGVtcGxhdGVzLnB1c2goe1xuICAgICAgICBrZXksXG4gICAgICAgIG9wdGlvbnM6IHtcbiAgICAgICAgICBlbnRpdHlJZDogdGFyZ2V0RW50aXR5SWQsXG4gICAgICAgICAgZW51bUlkLFxuICAgICAgICB9LFxuICAgICAgfSk7XG4gICAgfVxuXG4gICAgLy8g66as7Iqk7Yq4IOy7rOufvFxuICAgIGNvbnN0IGNvbHVtbkltcG9ydHMgPSBfLnVuaXEoXG4gICAgICBjb2x1bW5zTm9kZVxuICAgICAgICAuY2hpbGRyZW4hLm1hcCgoY29sKSA9PiB7XG4gICAgICAgICAgcmV0dXJuIHRoaXMucmVuZGVyQ29sdW1uSW1wb3J0KGVudGl0eUlkLCBjb2wsIG5hbWVzKTtcbiAgICAgICAgfSlcbiAgICAgICAgLmZsYXQoKVxuICAgICAgICAuZmlsdGVyKChjb2wpID0+IGNvbCAhPT0gbnVsbClcbiAgICApLmpvaW4oXCJcXG5cIik7XG5cbiAgICAvLyBTZWFyY2hJbnB1dFxuICAgIHByZVRlbXBsYXRlcyEucHVzaCh7XG4gICAgICBrZXk6IFwidmlld19zZWFyY2hfaW5wdXRcIixcbiAgICAgIG9wdGlvbnM6IHtcbiAgICAgICAgZW50aXR5SWQsXG4gICAgICB9LFxuICAgIH0pO1xuXG4gICAgLy8g65SU7Y+07Yq4IO2MjOudvOuvuO2EsFxuICAgIGNvbnN0IGRlZiA9IHRoaXMuZ2V0RGVmYXVsdChmaWx0ZXJDb2x1bW5zKTtcblxuICAgIHJldHVybiB7XG4gICAgICAuLi50aGlzLmdldFRhcmdldEFuZFBhdGgobmFtZXMpLFxuICAgICAgYm9keTogYFxuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExpbmsgfSBmcm9tICdyZWFjdC1yb3V0ZXItZG9tJztcbmltcG9ydCB7XG4gIEJyZWFkY3J1bWIsXG4gIENoZWNrYm94LFxuICBQYWdpbmF0aW9uLFxuICBTZWdtZW50LFxuICBUYWJsZSxcbiAgVGFibGVSb3csXG4gIE1lc3NhZ2UsXG4gIFRyYW5zaXRpb24sXG4gIEJ1dHRvbixcbiAgTGFiZWwsXG59IGZyb20gJ3NlbWFudGljLXVpLXJlYWN0JztcbmltcG9ydCBjbGFzc05hbWVzIGZyb20gJ2NsYXNzbmFtZXMnO1xuaW1wb3J0IHsgRGF0ZVRpbWUgfSBmcm9tIFwibHV4b25cIjtcbmltcG9ydCB7IERlbEJ1dHRvbiwgRWRpdEJ1dHRvbiwgQXBwQnJlYWRjcnVtYnMsIEFkZEJ1dHRvbiwgdXNlU2VsZWN0aW9uLCB1c2VMaXN0UGFyYW1zLCBTb25hbXVDb2wsIG51bUYsIGZvcm1hdERhdGUsIGZvcm1hdERhdGVUaW1lIH0gZnJvbSAnQHNvbmFtdS1raXQvcmVhY3Qtc3VpJztcblxuaW1wb3J0IHsgJHtuYW1lcy5jYXBpdGFsfVN1YnNldEEgfSBmcm9tIFwic3JjL3NlcnZpY2VzL3NvbmFtdS5nZW5lcmF0ZWRcIjtcbmltcG9ydCB7ICR7bmFtZXMuY2FwaXRhbH1TZXJ2aWNlIH0gZnJvbSAnc3JjL3NlcnZpY2VzLyR7bmFtZXMuZnN9LyR7XG4gICAgICAgIG5hbWVzLmZzXG4gICAgICB9LnNlcnZpY2UnO1xuaW1wb3J0IHsgJHtuYW1lcy5jYXBpdGFsfUxpc3RQYXJhbXMgfSBmcm9tICdzcmMvc2VydmljZXMvJHtuYW1lcy5mc30vJHtcbiAgICAgICAgbmFtZXMuZnNcbiAgICAgIH0udHlwZXMnO1xuJHtjb2x1bW5JbXBvcnRzfVxuJHtmaWx0ZXJDb2x1bW5zXG4gIC5tYXAoKGNvbCkgPT4ge1xuICAgIHJldHVybiB0aGlzLnJlbmRlckZpbHRlckltcG9ydChlbnRpdHlJZCwgY29sLCBuYW1lcyk7XG4gIH0pXG4gIC5qb2luKFwiXFxuXCIpfVxuXG50eXBlICR7bmFtZXMuY2FwaXRhbH1MaXN0UHJvcHMgPSB7fTtcbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uICR7bmFtZXMuY2FwaXRhbH1MaXN0KHt9OiAke25hbWVzLmNhcGl0YWx9TGlzdFByb3BzKSB7XG4gIC8vIOumrOyKpO2KuCDtlYTthLBcbiAgY29uc3QgeyBsaXN0UGFyYW1zLCByZWdpc3RlciB9ID0gdXNlTGlzdFBhcmFtcygke25hbWVzLmNhcGl0YWx9TGlzdFBhcmFtcywge1xuICAgIG51bTogMTIsXG4gICAgcGFnZTogMSxcbiAgICBvcmRlckJ5OiAnJHtkZWYub3JkZXJCeX0nLFxuICAgIHNlYXJjaDogJyR7ZGVmLnNlYXJjaH0nLFxuICB9KTtcblxuICAvLyDrpqzsiqTtirgg7L+866asXG4gIGNvbnN0IHsgZGF0YSwgbXV0YXRlLCBlcnJvciwgaXNMb2FkaW5nIH0gPSAke25hbWVzLmNhcGl0YWx9U2VydmljZS51c2Uke1xuICAgIG5hbWVzLmNhcGl0YWxQbHVyYWxcbiAgfSgnQScsIGxpc3RQYXJhbXMpO1xuICBjb25zdCB7IHJvd3MsIHRvdGFsIH0gPSBkYXRhID8/IHt9O1xuXG4gIC8vIOyCreygnFxuICBjb25zdCBjb25maXJtRGVsID0gKGlkczogbnVtYmVyW10pID0+IHtcbiAgICBjb25zdCBhbnN3ZXIgPSBjb25maXJtKCfsgq3soJztlZjsi5zqsqDsirXri4jquYw/Jyk7XG4gICAgaWYgKCFhbnN3ZXIpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICAke25hbWVzLmNhcGl0YWx9U2VydmljZS5kZWwoaWRzKS50aGVuKCgpID0+IHtcbiAgICAgIG11dGF0ZSgpO1xuICAgIH0pO1xuICB9O1xuXG4gIC8vIOydvOq0hCDsgq3soJxcbiAgY29uc3QgY29uZmlybURlbFNlbGVjdGVkID0gKCkgPT4ge1xuICAgIGNvbnN0IGFuc3dlciA9IGNvbmZpcm0oXFxgXFwke3NlbGVjdGVkS2V5cy5sZW5ndGh96rG07J2EIOydvOq0hCDsgq3soJztlZjsi5zqsqDsirXri4jquYw/XFxgKTtcbiAgICBpZiAoIWFuc3dlcikge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgICR7bmFtZXMuY2FwaXRhbH1TZXJ2aWNlLmRlbChzZWxlY3RlZEtleXMpLnRoZW4oKCkgPT4ge1xuICAgICAgbXV0YXRlKCk7XG4gICAgfSk7XG4gIH07XG5cbiAgLy8g7ZiE7J6sIOqyveuhnOyZgCDtg4DsnbTti4BcbiAgY29uc3QgUEFHRSA9IHtcbiAgICByb3V0ZTogJy9hZG1pbi8ke25hbWVzLmZzUGx1cmFsfScsXG4gICAgdGl0bGU6ICcke2VudGl0eS50aXRsZSA/PyBuYW1lcy5jYXBpdGFsfScsXG4gIH07XG5cbiAgLy8g7ISg7YOdXG4gIGNvbnN0IHtcbiAgICBnZXRTZWxlY3RlZCxcbiAgICBpc0FsbFNlbGVjdGVkLFxuICAgIHNlbGVjdGVkS2V5cyxcbiAgICB0b2dnbGUsXG4gICAgc2VsZWN0QWxsLFxuICAgIGRlc2VsZWN0QWxsLFxuICAgIGhhbmRsZUNoZWNrYm94Q2xpY2ssXG4gIH0gPSB1c2VTZWxlY3Rpb24oKHJvd3MgPz8gW10pLm1hcCgocm93KSA9PiByb3cuaWQpKTtcblxuICAvLyDsu6zrn7xcbiAgY29uc3QgY29sdW1uczpTb25hbXVDb2w8JHtuYW1lcy5jYXBpdGFsfVN1YnNldEE+W10gPSBbJHtjb2x1bW5zXG4gICAgLm1hcCgoY29sKSA9PiB7XG4gICAgICByZXR1cm4gW1xuICAgICAgICBgeyBsYWJlbDogXCIke2NvbC5sYWJlbH1cIixgLFxuICAgICAgICBgdGM6ICR7Y29sLnRjfSwgYCxcbiAgICAgICAgYGNvbGxhcHNpbmc6ICR7W1wiVGl0bGVcIiwgXCJOYW1lXCJdLmluY2x1ZGVzKGNvbC5sYWJlbCkgPT09IGZhbHNlfSwgfWAsXG4gICAgICBdLmpvaW4oXCJcXG5cIik7XG4gICAgfSlcbiAgICAuam9pbihcIixcXG5cIil9XTtcblxuICByZXR1cm4gKFxuICAgIDxkaXYgY2xhc3NOYW1lPVwibGlzdCAke25hbWVzLmZzUGx1cmFsfS1pbmRleFwiPlxuICAgICAgPGRpdiBjbGFzc05hbWU9XCJ0b3AtbmF2XCI+XG4gICAgICAgIDxkaXYgY2xhc3NOYW1lPVwiaGVhZGVyLXJvd1wiPlxuICAgICAgICAgIDxkaXYgY2xhc3NOYW1lPVwiaGVhZGVyXCI+e1BBR0UudGl0bGV9PC9kaXY+XG4gICAgICAgICAgPEFwcEJyZWFkY3J1bWJzPlxuICAgICAgICAgICAgPEJyZWFkY3J1bWIuU2VjdGlvbiBhY3RpdmU+e1BBR0UudGl0bGV9PC9CcmVhZGNydW1iLlNlY3Rpb24+XG4gICAgICAgICAgPC9BcHBCcmVhZGNydW1icz5cbiAgICAgICAgICA8JHtuYW1lcy5jYXBpdGFsfVNlYXJjaElucHV0XG4gICAgICAgICAgICBpbnB1dD17cmVnaXN0ZXIoJ2tleXdvcmQnKX1cbiAgICAgICAgICAgIGRyb3Bkb3duPXtyZWdpc3Rlcignc2VhcmNoJyl9XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxkaXYgY2xhc3NOYW1lPVwiZmlsdGVycy1yb3dcIj5cbiAgICAgICAgICAke2ZpbHRlckNvbHVtbnNcbiAgICAgICAgICAgIC5tYXAoKGNvbCkgPT4ge1xuICAgICAgICAgICAgICByZXR1cm4gdGhpcy5yZW5kZXJGaWx0ZXIoZW50aXR5SWQsIGNvbCwgbmFtZXMpO1xuICAgICAgICAgICAgfSlcbiAgICAgICAgICAgIC5qb2luKFwiJm5ic3A7XFxuXCIpfVxuICAgICAgICA8L2Rpdj5cbiAgICAgIDwvZGl2PlxuXG4gICAgICA8U2VnbWVudCBiYXNpYyBwYWRkZWQgY2xhc3NOYW1lPVwiY29udGVudHMtc2VnbWVudFwiIGxvYWRpbmc9e2lzTG9hZGluZ30+XG4gICAgICAgIDxkaXYgY2xhc3NOYW1lPVwiYnV0dG9ucy1yb3dcIj5cbiAgICAgICAgICA8ZGl2IGNsYXNzTmFtZT17Y2xhc3NOYW1lcygnY291bnQnLCB7IGhpZGRlbjogaXNMb2FkaW5nIH0pfT5cbiAgICAgICAgICAgIHt0b3RhbH0g6rG0XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgICAgPGRpdiBjbGFzc05hbWU9XCJidXR0b25zXCI+XG4gICAgICAgICAgICA8QWRkQnV0dG9uIGN1cnJlbnRSb3V0ZT17UEFHRS5yb3V0ZX0gaWNvbj1cIndyaXRlXCIgbGFiZWw9XCLstpTqsIBcIiAvPlxuICAgICAgICAgIDwvZGl2PlxuICAgICAgICA8L2Rpdj5cblxuICAgICAgICA8VGFibGVcbiAgICAgICAgICBjZWxsZWRcbiAgICAgICAgICBjb21wYWN0XG4gICAgICAgICAgc2VsZWN0YWJsZVxuICAgICAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lcyh7IGhpZGRlbjogdG90YWwgPT09IHVuZGVmaW5lZCB8fCB0b3RhbCA9PT0gMCB9KX1cbiAgICAgICAgPlxuICAgICAgICAgIDxUYWJsZS5IZWFkZXI+XG4gICAgICAgICAgICA8VGFibGVSb3c+XG4gICAgICAgICAgICAgIDxUYWJsZS5IZWFkZXJDZWxsIGNvbGxhcHNpbmc+XG4gICAgICAgICAgICAgICAgPENoZWNrYm94XG4gICAgICAgICAgICAgICAgICBsYWJlbD1cIklEXCJcbiAgICAgICAgICAgICAgICAgIGNoZWNrZWQ9e2lzQWxsU2VsZWN0ZWR9XG4gICAgICAgICAgICAgICAgICBvbkNoYW5nZT17aXNBbGxTZWxlY3RlZCA/IGRlc2VsZWN0QWxsIDogc2VsZWN0QWxsfVxuICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgIDwvVGFibGUuSGVhZGVyQ2VsbD5cbiAgICAgICAgICAgICAge1xuICAgICAgICAgICAgICAgIC8qIEhlYWRlciAqL1xuICAgICAgICAgICAgICAgIGNvbHVtbnMubWFwKChjb2wsIGluZGV4KSA9PiBjb2wudGggPz8gPFRhYmxlLkhlYWRlckNlbGwga2V5PXtpbmRleH0gY29sbGFwc2luZz17Y29sLmNvbGxhcHNpbmd9PnsgY29sLmxhYmVsIH08L1RhYmxlLkhlYWRlckNlbGw+KVxuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgIDxUYWJsZS5IZWFkZXJDZWxsPuq0gOumrDwvVGFibGUuSGVhZGVyQ2VsbD5cbiAgICAgICAgICAgIDwvVGFibGVSb3c+XG4gICAgICAgICAgPC9UYWJsZS5IZWFkZXI+XG4gICAgICAgICAgPFRhYmxlLkJvZHk+XG4gICAgICAgICAgICB7cm93cyAmJlxuICAgICAgICAgICAgICByb3dzLm1hcCgocm93LCByb3dJbmRleCkgPT4gKFxuICAgICAgICAgICAgICAgIDxUYWJsZS5Sb3cga2V5PXtyb3cuaWR9PlxuICAgICAgICAgICAgICAgICAgPFRhYmxlLkNlbGw+XG4gICAgICAgICAgICAgICAgICAgIDxDaGVja2JveFxuICAgICAgICAgICAgICAgICAgICAgIGxhYmVsPXtyb3cuaWR9XG4gICAgICAgICAgICAgICAgICAgICAgY2hlY2tlZD17Z2V0U2VsZWN0ZWQocm93LmlkKX1cbiAgICAgICAgICAgICAgICAgICAgICBvbkNoYW5nZT17KCkgPT4gdG9nZ2xlKHJvdy5pZCl9XG4gICAgICAgICAgICAgICAgICAgICAgb25DbGljaz17KGUpID0+XG4gICAgICAgICAgICAgICAgICAgICAgICBoYW5kbGVDaGVja2JveENsaWNrKGUsIHJvd0luZGV4KVxuICAgICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgLz5cbiAgICAgICAgICAgICAgICAgIDwvVGFibGUuQ2VsbD5cbiAgICAgICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICAgICAgLyogQm9keSAqL1xuICAgICAgICAgICAgICAgICAgICBjb2x1bW5zLm1hcCgoY29sLCBjb2xJbmRleCkgPT4gKFxuICAgICAgICAgICAgICAgICAgICAgIDxUYWJsZS5DZWxsIGtleT17Y29sSW5kZXh9IGNvbGxhcHNpbmc9e2NvbC5jb2xsYXBzaW5nfSBjbGFzc05hbWU9e2NvbC5jbGFzc05hbWV9PlxuICAgICAgICAgICAgICAgICAgICAgICAge2NvbC50Yyhyb3csIHJvd0luZGV4KX1cbiAgICAgICAgICAgICAgICAgICAgICA8L1RhYmxlLkNlbGw+XG4gICAgICAgICAgICAgICAgICAgICkpXG4gICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICA8VGFibGUuQ2VsbCBjb2xsYXBzaW5nPlxuICAgICAgICAgICAgICAgICAgICA8RWRpdEJ1dHRvblxuICAgICAgICAgICAgICAgICAgICAgIGFzPXtMaW5rfVxuICAgICAgICAgICAgICAgICAgICAgIHRvPXtcXGBcXCR7UEFHRS5yb3V0ZX0vZm9ybT9pZD1cXCR7cm93LmlkfVxcYH1cbiAgICAgICAgICAgICAgICAgICAgICBzdGF0ZT17eyBmcm9tOiBQQUdFLnJvdXRlIH19XG4gICAgICAgICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICAgICAgICAgIDxEZWxCdXR0b24gb25DbGljaz17KCkgPT4gY29uZmlybURlbChbcm93LmlkXSl9IC8+XG4gICAgICAgICAgICAgICAgICA8L1RhYmxlLkNlbGw+XG4gICAgICAgICAgICAgICAgPC9UYWJsZS5Sb3c+XG4gICAgICAgICAgICAgICkpfVxuICAgICAgICAgIDwvVGFibGUuQm9keT5cbiAgICAgICAgPC9UYWJsZT5cbiAgICAgICAgPGRpdlxuICAgICAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lcygncGFnaW5hdGlvbi1yb3cnLCB7XG4gICAgICAgICAgICBoaWRkZW46ICh0b3RhbCA/PyAwKSA9PT0gMCxcbiAgICAgICAgICB9KX1cbiAgICAgICAgPlxuICAgICAgICAgIDxQYWdpbmF0aW9uXG4gICAgICAgICAgICB0b3RhbFBhZ2VzPXtNYXRoLmNlaWwoKHRvdGFsID8/IDApIC8gKGxpc3RQYXJhbXMubnVtID8/IDI0KSl9XG4gICAgICAgICAgICB7Li4ucmVnaXN0ZXIoJ3BhZ2UnKX1cbiAgICAgICAgICAvPlxuICAgICAgICA8L2Rpdj5cbiAgICAgIDwvU2VnbWVudD5cblxuICAgICAgPGRpdiBjbGFzc05hbWU9XCJmaXhlZC1tZW51XCI+XG4gICAgICAgIDxUcmFuc2l0aW9uXG4gICAgICAgICAgdmlzaWJsZT17c2VsZWN0ZWRLZXlzLmxlbmd0aCA+IDB9XG4gICAgICAgICAgYW5pbWF0aW9uPVwic2xpZGUgbGVmdFwiXG4gICAgICAgICAgZHVyYXRpb249ezUwMH1cbiAgICAgICAgPlxuICAgICAgICAgIDxNZXNzYWdlIHNpemU9XCJzbWFsbFwiIGNvbG9yPVwidmlvbGV0XCIgY2xhc3NOYW1lPVwidGV4dC1jZW50ZXJcIj5cbiAgICAgICAgICAgIDxzcGFuIGNsYXNzTmFtZT1cInB4LTRcIj57c2VsZWN0ZWRLZXlzLmxlbmd0aH3qsJwg7ISg7YOd65CoPC9zcGFuPlxuICAgICAgICAgICAgPEJ1dHRvbiBzaXplPVwidGlueVwiIGNvbG9yPVwidmlvbGV0XCIgb25DbGljaz17KCkgPT4gZGVzZWxlY3RBbGwoKX0+XG4gICAgICAgICAgICAgIOyEoO2DnSDtlbTsoJxcbiAgICAgICAgICAgIDwvQnV0dG9uPlxuICAgICAgICAgICAgPEJ1dHRvbiBzaXplPVwidGlueVwiIGNvbG9yPVwicmVkXCIgb25DbGljaz17Y29uZmlybURlbFNlbGVjdGVkfT5cbiAgICAgICAgICAgICAg7J286rSEIOyCreygnFxuICAgICAgICAgICAgPC9CdXR0b24+XG4gICAgICAgICAgPC9NZXNzYWdlPlxuICAgICAgICA8L1RyYW5zaXRpb24+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgKTtcbn1cbiAgICAgIGAudHJpbSgpLFxuICAgICAgaW1wb3J0S2V5czogW10sXG4gICAgICBwcmVUZW1wbGF0ZXMsXG4gICAgfTtcbiAgfVxufVxuIl0sIm5hbWVzIjpbImluZmxlY3Rpb24iLCJfIiwieiIsIkVudGl0eU1hbmFnZXIiLCJnZXRSZWxhdGlvblByb3BGcm9tQ29sTmFtZSIsImdldEVudW1JbmZvRnJvbUNvbE5hbWUiLCJUZW1wbGF0ZSIsInpvZFR5cGVUb1JlbmRlcmluZ05vZGUiLCJnZXRab2RUeXBlQnlJZCIsImdldENvbHVtbnNOb2RlIiwiVGVtcGxhdGVfX3ZpZXdfbGlzdCIsImdldFRhcmdldEFuZFBhdGgiLCJuYW1lcyIsInRhcmdldCIsInBhdGgiLCJmc1BsdXJhbCIsIndyYXBUYyIsImJvZHkiLCJrZXkiLCJjb2xsYXBzaW5nIiwiY2xhc3NOYW1lIiwicmVuZGVyQ29sdW1uIiwiZW50aXR5SWQiLCJjb2wiLCJwYXJlbnRPYmoiLCJ3aXRob3V0TmFtZSIsImNvbE5hbWUiLCJuYW1lIiwicmVuZGVyVHlwZSIsInJlbFByb3BGayIsInJlcGxhY2UiLCJ3aXRoIiwibnVsbGFibGUiLCJpZCIsImVudW1JZCIsInBpY2tlZENoaWxkIiwiY2hpbGRyZW4iLCJmaW5kIiwiY2hpbGQiLCJjb25maWciLCJwaWNrZWQiLCJFcnJvciIsInJlbmRlckNvbHVtbkltcG9ydCIsImNhcGl0YWwiLCJyZWxQcm9wIiwicmVzdWx0IiwibWFwIiwiZ2V0TmFtZXNGcm9tSWQiLCJmbGF0dGVuRGVlcCIsImVsZW1lbnQiLCJyZW5kZXJGaWx0ZXJJbXBvcnQiLCJmcyIsImNvbXBvbmVudElkIiwiY2FtZWxpemUiLCJ0YXJnZXRFbnRpdHlOYW1lcyIsInRhcmdldE1ETmFtZXMiLCJ0YXJnZXROYW1lcyIsInJlbmRlckZpbHRlciIsImlzQ2xlYXJhYmxlIiwib3B0aW9uYWwiLCJnZXREZWZhdWx0IiwiY29sdW1ucyIsImRlZiIsIm9yZGVyQnkiLCJzZWFyY2giLCJvcmRlckJ5Wm9kVHlwZSIsInpvZFR5cGUiLCJab2RFbnVtIiwib3B0aW9ucyIsInRvU3RyaW5nIiwic2VhcmNoWm9kVHlwZSIsInJlbmRlciIsImNvbHVtbnNOb2RlIiwibGlzdFBhcmFtc1pvZFR5cGUiLCJsaXN0UGFyYW1zTm9kZSIsImVudGl0eSIsImdldCIsImZpbHRlciIsInByb3BDYW5kaWRhdGUiLCJwcm9wcyIsInAiLCJsYWJlbCIsImRlc2MiLCJ0YyIsImZpbHRlckNvbHVtbnMiLCJpbmNsdWRlcyIsImVuZHNXaXRoIiwic29ydCIsImEiLCJwcmVUZW1wbGF0ZXMiLCJ0YXJnZXRFbnRpdHlJZCIsInB1c2giLCJjb2x1bW5JbXBvcnRzIiwidW5pcSIsImZsYXQiLCJqb2luIiwiY2FwaXRhbFBsdXJhbCIsInRpdGxlIiwidHJpbSIsImltcG9ydEtleXMiXSwibWFwcGluZ3MiOiJBQUFBLE9BQU9BLGdCQUFnQixhQUFhO0FBQ3BDLFlBQVlDLE9BQU8sWUFBWTtBQUMvQixTQUFTQyxDQUFDLFFBQVEsTUFBTTtBQUV4QixTQUFTQyxhQUFhLFFBQTJCLGlDQUE4QjtBQUMvRSxTQUFTQywwQkFBMEIsRUFBRUMsc0JBQXNCLFFBQVEsZ0JBQWE7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
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { TemplateOptions } from "
|
|
2
|
-
import { EntityNamesRecord } from "
|
|
3
|
-
import { Template } from "
|
|
1
|
+
import { TemplateOptions } from "../../types/types";
|
|
2
|
+
import { EntityNamesRecord } from "../../entity/entity-manager";
|
|
3
|
+
import { Template } from "../template";
|
|
4
4
|
export declare class Template__view_list_columns extends Template {
|
|
5
5
|
constructor();
|
|
6
6
|
getTargetAndPath(names: EntityNamesRecord): {
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"view_list_columns.template.d.ts","sourceRoot":"","sources":["../../../src/template/implementations/view_list_columns.template.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAiB,iBAAiB,EAAE,MAAM,6BAA6B,CAAC;AAC/E,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAEvC,qBAAa,2BAA4B,SAAQ,QAAQ;;IAKvD,gBAAgB,CAAC,KAAK,EAAE,iBAAiB;;;;IAQzC,MAAM,CAAC,EACL,QAAQ,EACR,OAAO,EACP,aAAa,GACd,EAAE,eAAe,CAAC,mBAAmB,CAAC;;;;;;CAqCxC"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { EntityManager } from "../../entity/entity-manager.js";
|
|
2
|
+
import { Template } from "../template.js";
|
|
3
|
+
export class Template__view_list_columns extends Template {
|
|
4
|
+
constructor(){
|
|
5
|
+
super("view_list_columns");
|
|
6
|
+
}
|
|
7
|
+
getTargetAndPath(names) {
|
|
8
|
+
return {
|
|
9
|
+
target: "web/src/pages/admin",
|
|
10
|
+
path: `${names.fsPlural}/_columns.tsx`
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
// 컬럼
|
|
14
|
+
render({ entityId, columns, columnImports }) {
|
|
15
|
+
const names = EntityManager.getNamesFromId(entityId);
|
|
16
|
+
return {
|
|
17
|
+
...this.getTargetAndPath(names),
|
|
18
|
+
body: `
|
|
19
|
+
import React from 'react';
|
|
20
|
+
import {
|
|
21
|
+
Segment,
|
|
22
|
+
Table,
|
|
23
|
+
TableRow,
|
|
24
|
+
Button,
|
|
25
|
+
Label,
|
|
26
|
+
} from 'semantic-ui-react';
|
|
27
|
+
import { DateTime } from "luxon";
|
|
28
|
+
import { TFColumn } from "src/typeframe/iso-types";
|
|
29
|
+
import { ${names.capital}SubsetA } from "src/services/${names.fs}/${names.fs}.generated";
|
|
30
|
+
${columnImports}
|
|
31
|
+
|
|
32
|
+
const columns: { [key in Exclude<keyof ${names.capital}SubsetA, 'id'>]: TFColumn<${names.capital}SubsetA> } = {${columns.map((col)=>{
|
|
33
|
+
return [
|
|
34
|
+
`${col.name}: { label: "${col.label}",`,
|
|
35
|
+
`tc: ${col.tc}, `,
|
|
36
|
+
`collapsing: ${[
|
|
37
|
+
"Title",
|
|
38
|
+
"Name"
|
|
39
|
+
].includes(col.label) === false}, }`
|
|
40
|
+
].join("\n");
|
|
41
|
+
}).join(",\n")}};
|
|
42
|
+
export default columns;
|
|
43
|
+
`.trim(),
|
|
44
|
+
importKeys: []
|
|
45
|
+
};
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy90ZW1wbGF0ZS9pbXBsZW1lbnRhdGlvbnMvdmlld19saXN0X2NvbHVtbnMudGVtcGxhdGUudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGVtcGxhdGVPcHRpb25zIH0gZnJvbSBcIi4uLy4uL3R5cGVzL3R5cGVzXCI7XG5pbXBvcnQgeyBFbnRpdHlNYW5hZ2VyLCBFbnRpdHlOYW1lc1JlY29yZCB9IGZyb20gXCIuLi8uLi9lbnRpdHkvZW50aXR5LW1hbmFnZXJcIjtcbmltcG9ydCB7IFRlbXBsYXRlIH0gZnJvbSBcIi4uL3RlbXBsYXRlXCI7XG5cbmV4cG9ydCBjbGFzcyBUZW1wbGF0ZV9fdmlld19saXN0X2NvbHVtbnMgZXh0ZW5kcyBUZW1wbGF0ZSB7XG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIHN1cGVyKFwidmlld19saXN0X2NvbHVtbnNcIik7XG4gIH1cblxuICBnZXRUYXJnZXRBbmRQYXRoKG5hbWVzOiBFbnRpdHlOYW1lc1JlY29yZCkge1xuICAgIHJldHVybiB7XG4gICAgICB0YXJnZXQ6IFwid2ViL3NyYy9wYWdlcy9hZG1pblwiLFxuICAgICAgcGF0aDogYCR7bmFtZXMuZnNQbHVyYWx9L19jb2x1bW5zLnRzeGAsXG4gICAgfTtcbiAgfVxuXG4gIC8vIOy7rOufvFxuICByZW5kZXIoe1xuICAgIGVudGl0eUlkLFxuICAgIGNvbHVtbnMsXG4gICAgY29sdW1uSW1wb3J0cyxcbiAgfTogVGVtcGxhdGVPcHRpb25zW1widmlld19saXN0X2NvbHVtbnNcIl0pIHtcbiAgICBjb25zdCBuYW1lcyA9IEVudGl0eU1hbmFnZXIuZ2V0TmFtZXNGcm9tSWQoZW50aXR5SWQpO1xuXG4gICAgcmV0dXJuIHtcbiAgICAgIC4uLnRoaXMuZ2V0VGFyZ2V0QW5kUGF0aChuYW1lcyksXG4gICAgICBib2R5OiBgXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHtcbiAgU2VnbWVudCxcbiAgVGFibGUsXG4gIFRhYmxlUm93LFxuICBCdXR0b24sXG4gIExhYmVsLFxufSBmcm9tICdzZW1hbnRpYy11aS1yZWFjdCc7XG5pbXBvcnQgeyBEYXRlVGltZSB9IGZyb20gXCJsdXhvblwiO1xuaW1wb3J0IHsgVEZDb2x1bW4gfSBmcm9tIFwic3JjL3R5cGVmcmFtZS9pc28tdHlwZXNcIjtcbmltcG9ydCB7ICR7bmFtZXMuY2FwaXRhbH1TdWJzZXRBIH0gZnJvbSBcInNyYy9zZXJ2aWNlcy8ke25hbWVzLmZzfS8ke1xuICAgICAgICBuYW1lcy5mc1xuICAgICAgfS5nZW5lcmF0ZWRcIjtcbiR7Y29sdW1uSW1wb3J0c31cblxuY29uc3QgY29sdW1uczogeyBba2V5IGluIEV4Y2x1ZGU8a2V5b2YgJHtcbiAgICAgICAgbmFtZXMuY2FwaXRhbFxuICAgICAgfVN1YnNldEEsICdpZCc+XTogVEZDb2x1bW48JHtuYW1lcy5jYXBpdGFsfVN1YnNldEE+IH0gPSB7JHtjb2x1bW5zXG4gICAgICAgIC5tYXAoKGNvbCkgPT4ge1xuICAgICAgICAgIHJldHVybiBbXG4gICAgICAgICAgICBgJHtjb2wubmFtZX06IHsgbGFiZWw6IFwiJHtjb2wubGFiZWx9XCIsYCxcbiAgICAgICAgICAgIGB0YzogJHtjb2wudGN9LCBgLFxuICAgICAgICAgICAgYGNvbGxhcHNpbmc6ICR7W1wiVGl0bGVcIiwgXCJOYW1lXCJdLmluY2x1ZGVzKGNvbC5sYWJlbCkgPT09IGZhbHNlfSwgfWAsXG4gICAgICAgICAgXS5qb2luKFwiXFxuXCIpO1xuICAgICAgICB9KVxuICAgICAgICAuam9pbihcIixcXG5cIil9fTtcbmV4cG9ydCBkZWZhdWx0IGNvbHVtbnM7XG4gICAgICBgLnRyaW0oKSxcbiAgICAgIGltcG9ydEtleXM6IFtdLFxuICAgIH07XG4gIH1cbn1cbiJdLCJuYW1lcyI6WyJFbnRpdHlNYW5hZ2VyIiwiVGVtcGxhdGUiLCJUZW1wbGF0ZV9fdmlld19saXN0X2NvbHVtbnMiLCJnZXRUYXJnZXRBbmRQYXRoIiwibmFtZXMiLCJ0YXJnZXQiLCJwYXRoIiwiZnNQbHVyYWwiLCJyZW5kZXIiLCJlbnRpdHlJZCIsImNvbHVtbnMiLCJjb2x1bW5JbXBvcnRzIiwiZ2V0TmFtZXNGcm9tSWQiLCJib2R5IiwiY2FwaXRhbCIsImZzIiwibWFwIiwiY29sIiwibmFtZSIsImxhYmVsIiwidGMiLCJpbmNsdWRlcyIsImpvaW4iLCJ0cmltIiwiaW1wb3J0S2V5cyJdLCJtYXBwaW5ncyI6IkFBQ0EsU0FBU0EsYUFBYSxRQUEyQixpQ0FBOEI7QUFDL0UsU0FBU0MsUUFBUSxRQUFRLGlCQUFjO0FBRXZDLE9BQU8sTUFBTUMsb0NBQW9DRDtJQUMvQyxhQUFjO1FBQ1osS0FBSyxDQUFDO0lBQ1I7SUFFQUUsaUJBQWlCQyxLQUF3QixFQUFFO1FBQ3pDLE9BQU87WUFDTEMsUUFBUTtZQUNSQyxNQUFNLEdBQUdGLE1BQU1HLFFBQVEsQ0FBQyxhQUFhLENBQUM7UUFDeEM7SUFDRjtJQUVBLEtBQUs7SUFDTEMsT0FBTyxFQUNMQyxRQUFRLEVBQ1JDLE9BQU8sRUFDUEMsYUFBYSxFQUN3QixFQUFFO1FBQ3ZDLE1BQU1QLFFBQVFKLGNBQWNZLGNBQWMsQ0FBQ0g7UUFFM0MsT0FBTztZQUNMLEdBQUcsSUFBSSxDQUFDTixnQkFBZ0IsQ0FBQ0MsTUFBTTtZQUMvQlMsTUFBTSxDQUFDOzs7Ozs7Ozs7OztTQVdKLEVBQUVULE1BQU1VLE9BQU8sQ0FBQyw2QkFBNkIsRUFBRVYsTUFBTVcsRUFBRSxDQUFDLENBQUMsRUFDMURYLE1BQU1XLEVBQUUsQ0FDVDtBQUNQLEVBQUVKLGNBQWM7O3VDQUV1QixFQUMvQlAsTUFBTVUsT0FBTyxDQUNkLDBCQUEwQixFQUFFVixNQUFNVSxPQUFPLENBQUMsY0FBYyxFQUFFSixRQUN4RE0sR0FBRyxDQUFDLENBQUNDO2dCQUNKLE9BQU87b0JBQ0wsR0FBR0EsSUFBSUMsSUFBSSxDQUFDLFlBQVksRUFBRUQsSUFBSUUsS0FBSyxDQUFDLEVBQUUsQ0FBQztvQkFDdkMsQ0FBQyxJQUFJLEVBQUVGLElBQUlHLEVBQUUsQ0FBQyxFQUFFLENBQUM7b0JBQ2pCLENBQUMsWUFBWSxFQUFFO3dCQUFDO3dCQUFTO3FCQUFPLENBQUNDLFFBQVEsQ0FBQ0osSUFBSUUsS0FBSyxNQUFNLE1BQU0sR0FBRyxDQUFDO2lCQUNwRSxDQUFDRyxJQUFJLENBQUM7WUFDVCxHQUNDQSxJQUFJLENBQUMsT0FBTzs7TUFFZixDQUFDLENBQUNDLElBQUk7WUFDTkMsWUFBWSxFQUFFO1FBQ2hCO0lBQ0Y7QUFDRiJ9
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { TemplateOptions } from "
|
|
2
|
-
import { EntityNamesRecord } from "
|
|
3
|
-
import { Template } from "
|
|
1
|
+
import { TemplateOptions } from "../../types/types";
|
|
2
|
+
import { EntityNamesRecord } from "../../entity/entity-manager";
|
|
3
|
+
import { Template } from "../template";
|
|
4
4
|
export declare class Template__view_search_input extends Template {
|
|
5
5
|
constructor();
|
|
6
6
|
getTargetAndPath(names: EntityNamesRecord): {
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"view_search_input.template.d.ts","sourceRoot":"","sources":["../../../src/template/implementations/view_search_input.template.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAiB,iBAAiB,EAAE,MAAM,6BAA6B,CAAC;AAC/E,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAEvC,qBAAa,2BAA4B,SAAQ,QAAQ;;IAKvD,gBAAgB,CAAC,KAAK,EAAE,iBAAiB;;;;IAOzC,MAAM,CAAC,EAAE,QAAQ,EAAE,EAAE,eAAe,CAAC,mBAAmB,CAAC;;;;;;CAkD1D"}
|