@ai-table/grid 0.0.38 → 0.0.39
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/components/cell-editors/text/text-editor.component.d.ts +1 -0
- package/components/cell-editors/text/text-editor.component.d.ts.map +1 -1
- package/components/field-setting/field-setting.component.d.ts +12 -8
- package/components/field-setting/field-setting.component.d.ts.map +1 -1
- package/core/constants/field.d.ts +4 -0
- package/core/constants/field.d.ts.map +1 -1
- package/core/utils/field.d.ts.map +1 -1
- package/esm2022/components/cell-editors/text/text-editor.component.mjs +6 -3
- package/esm2022/components/field-setting/field-setting.component.mjs +48 -28
- package/esm2022/core/constants/field.mjs +20 -22
- package/esm2022/core/utils/field.mjs +8 -4
- package/esm2022/pipes/grid.pipe.mjs +9 -11
- package/esm2022/renderer/drawers/cell-drawer.mjs +13 -6
- package/fesm2022/ai-table-grid.mjs +92 -65
- package/fesm2022/ai-table-grid.mjs.map +1 -1
- package/package.json +1 -1
- package/pipes/grid.pipe.d.ts +5 -5
- package/pipes/grid.pipe.d.ts.map +1 -1
- package/renderer/drawers/cell-drawer.d.ts +1 -0
- package/renderer/drawers/cell-drawer.d.ts.map +1 -1
@@ -4,6 +4,7 @@ import * as i0 from "@angular/core";
|
|
4
4
|
export declare class TextCellEditorComponent extends AbstractEditCellEditor<string> implements AfterViewInit {
|
5
5
|
private render2;
|
6
6
|
private maxHeight;
|
7
|
+
private minHeight;
|
7
8
|
constructor();
|
8
9
|
ngAfterViewInit(): void;
|
9
10
|
updateStyle(): void;
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"text-editor.component.d.ts","sourceRoot":"","sources":["../../../../../packages/grid/src/components/cell-editors/text/text-editor.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAyD,MAAM,eAAe,CAAC;AAIrG,OAAO,EAAE,sBAAsB,EAAE,MAAM,mCAAmC,CAAC;;AAE3E,qBAqBa,uBAAwB,SAAQ,sBAAsB,CAAC,MAAM,CAAE,YAAW,aAAa;IAChG,OAAO,CAAC,OAAO,CAAqB;
|
1
|
+
{"version":3,"file":"text-editor.component.d.ts","sourceRoot":"","sources":["../../../../../packages/grid/src/components/cell-editors/text/text-editor.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAyD,MAAM,eAAe,CAAC;AAIrG,OAAO,EAAE,sBAAsB,EAAE,MAAM,mCAAmC,CAAC;;AAE3E,qBAqBa,uBAAwB,SAAQ,sBAAsB,CAAC,MAAM,CAAE,YAAW,aAAa;IAChG,OAAO,CAAC,OAAO,CAAqB;IACpC,OAAO,CAAC,SAAS,CAAO;IAExB,OAAO,CAAC,SAAS,CAAM;;IAMvB,eAAe;IAMf,WAAW;IAaX,WAAW;IAIX,WAAW;yCAjCF,uBAAuB;2CAAvB,uBAAuB;CAqCnC"}
|
@@ -1,26 +1,30 @@
|
|
1
|
-
import { TemplateRef } from '@angular/core';
|
1
|
+
import { OnInit, TemplateRef } from '@angular/core';
|
2
2
|
import { ThyFormValidatorConfig } from 'ngx-tethys/form';
|
3
3
|
import { ThyPopoverRef } from 'ngx-tethys/popover';
|
4
|
-
import { AITable, AITableField, AITableFieldOption, SetFieldOptions } from '../../core';
|
4
|
+
import { AITable, AITableField, AITableFieldOption, SetFieldOptions, AITableFieldType } from '../../core';
|
5
5
|
import * as i0 from "@angular/core";
|
6
|
-
export declare class AITableFieldSetting {
|
6
|
+
export declare class AITableFieldSetting implements OnInit {
|
7
7
|
aiEditField: import("@angular/core").ModelSignal<AITableField>;
|
8
|
-
aiTable: AITable
|
9
|
-
aiExternalTemplate: TemplateRef<any> | null
|
10
|
-
isUpdate: boolean
|
8
|
+
aiTable: import("@angular/core").InputSignal<AITable>;
|
9
|
+
aiExternalTemplate: import("@angular/core").InputSignal<TemplateRef<any> | null>;
|
10
|
+
isUpdate: import("@angular/core").InputSignalWithTransform<boolean, unknown>;
|
11
11
|
addField: import("@angular/core").OutputEmitterRef<AITableField>;
|
12
12
|
setField: import("@angular/core").OutputEmitterRef<SetFieldOptions<unknown>>;
|
13
13
|
selectedFieldOption: import("@angular/core").Signal<AITableFieldOption>;
|
14
14
|
fieldMaxLength: number;
|
15
15
|
validatorConfig: ThyFormValidatorConfig;
|
16
16
|
fieldOptions: AITableFieldOption[];
|
17
|
+
aITableFieldType: typeof AITableFieldType;
|
18
|
+
isMultipleMember: boolean;
|
17
19
|
protected thyPopoverRef: ThyPopoverRef<any, any, any>;
|
20
|
+
ngOnInit(): void;
|
18
21
|
checkUniqueName: (fieldName: string) => import("rxjs").Observable<boolean>;
|
19
22
|
selectFieldType(field: AITableFieldOption): void;
|
20
23
|
editFieldProperty(): void;
|
24
|
+
multipleMemberChange(): void;
|
25
|
+
fieldTypeClick(e: Event): void;
|
21
26
|
cancel(): void;
|
22
27
|
static ɵfac: i0.ɵɵFactoryDeclaration<AITableFieldSetting, never>;
|
23
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<AITableFieldSetting, "ai-table-field-setting", never, { "aiEditField": { "alias": "aiEditField"; "required": true; "isSignal": true; }; "aiTable": { "alias": "aiTable"; "required": true; }; "aiExternalTemplate": { "alias": "aiExternalTemplate"; "required": false; }; "isUpdate": { "alias": "isUpdate"; "required": false; }; }, { "aiEditField": "aiEditFieldChange"; "addField": "addField"; "setField": "setField"; }, never, never, true, never>;
|
24
|
-
static ngAcceptInputType_isUpdate: unknown;
|
28
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<AITableFieldSetting, "ai-table-field-setting", never, { "aiEditField": { "alias": "aiEditField"; "required": true; "isSignal": true; }; "aiTable": { "alias": "aiTable"; "required": true; "isSignal": true; }; "aiExternalTemplate": { "alias": "aiExternalTemplate"; "required": false; "isSignal": true; }; "isUpdate": { "alias": "isUpdate"; "required": false; "isSignal": true; }; }, { "aiEditField": "aiEditFieldChange"; "addField": "addField"; "setField": "setField"; }, never, never, true, never>;
|
25
29
|
}
|
26
30
|
//# sourceMappingURL=field-setting.component.d.ts.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"field-setting.component.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/components/field-setting/field-setting.component.ts"],"names":[],"mappings":"AACA,OAAO,
|
1
|
+
{"version":3,"file":"field-setting.component.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/components/field-setting/field-setting.component.ts"],"names":[],"mappings":"AACA,OAAO,EAGH,MAAM,EACN,WAAW,EAOd,MAAM,eAAe,CAAC;AAWvB,OAAO,EAAiB,sBAAsB,EAA2B,MAAM,iBAAiB,CAAC;AAIjG,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAGnD,OAAO,EACH,OAAO,EACP,YAAY,EACZ,kBAAkB,EAIlB,eAAe,EACf,gBAAgB,EAEnB,MAAM,YAAY,CAAC;;AAIpB,qBAqCa,mBAAoB,YAAW,MAAM;IAC9C,WAAW,oDAAkC;IAE7C,OAAO,+CAA6B;IAEpC,kBAAkB,+DAAwC;IAE1D,QAAQ,qEAAmE;IAE3E,QAAQ,yDAA0B;IAElC,QAAQ,qEAA6B;IAErC,mBAAmB,qDAEhB;IAEH,cAAc,SAAM;IAEpB,eAAe,EAAE,sBAAsB,CAOrC;IAEF,YAAY,uBAA6B;IAEzC,gBAAgB,0BAAoB;IAEpC,gBAAgB,UAAS;IAEzB,SAAS,CAAC,aAAa,+BAA8C;IAErE,QAAQ,IAAI,IAAI;IAKhB,eAAe,cAAe,MAAM,wCAOlC;IAEF,eAAe,CAAC,KAAK,EAAE,kBAAkB;IAYzC,iBAAiB;IAYjB,oBAAoB;IAUpB,cAAc,CAAC,CAAC,EAAE,KAAK;IAKvB,MAAM;yCAzFG,mBAAmB;2CAAnB,mBAAmB;CA4F/B"}
|
@@ -1,3 +1,7 @@
|
|
1
1
|
import { AITableFieldOption } from '../types';
|
2
|
+
export declare const AI_TABLE_FIELD_MINI_WIDTH = 140;
|
3
|
+
export declare const AI_TABLE_FIELD_MIN_WIDTH = 160;
|
4
|
+
export declare const AI_TABLE_FIELD_MIDDLE_WIDTH = 200;
|
5
|
+
export declare const AI_TABLE_FIELD_MAX_WIDTH = 300;
|
2
6
|
export declare const FieldOptions: AITableFieldOption[];
|
3
7
|
//# sourceMappingURL=field.d.ts.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"field.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/core/constants/field.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAoB,MAAM,UAAU,CAAC;AAEhE,eAAO,MAAM,YAAY,EAAE,kBAAkB,
|
1
|
+
{"version":3,"file":"field.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/core/constants/field.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAoB,MAAM,UAAU,CAAC;AAEhE,eAAO,MAAM,yBAAyB,MAAM,CAAC;AAC7C,eAAO,MAAM,wBAAwB,MAAM,CAAC;AAC5C,eAAO,MAAM,2BAA2B,MAAM,CAAC;AAC/C,eAAO,MAAM,wBAAwB,MAAM,CAAC;AAE5C,eAAO,MAAM,YAAY,EAAE,kBAAkB,EAwF5C,CAAC"}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"field.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/core/utils/field.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,YAAY,EAAE,kBAAkB,EAAE,gBAAgB,
|
1
|
+
{"version":3,"file":"field.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/core/utils/field.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,YAAY,EAAE,kBAAkB,EAAE,gBAAgB,EAA8B,MAAM,UAAU,CAAC;AAGnH,eAAO,MAAM,YAAY,UAAW,YAAY,YAK/C,CAAC;AAEF,eAAO,MAAM,aAAa,UAAW,YAAY,YAIhD,CAAC;AAEF,eAAO,MAAM,aAAa,UAAW,YAAY,YAEhD,CAAC;AAEF,wBAAgB,oBAAoB,CAAC,KAAK,EAAE,YAAY,uBAQvD;AAED,wBAAgB,sBAAsB,CAAC,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,kBAAkB,UASjF;AAED,wBAAgB,qBAAqB,CAAC,KAAK,EAAE,OAAO,CAAC,YAAY,CAAC,kCAMjE;AAED,wBAAgB,iBAAiB,CAAC,WAAW,EAAE,kBAAkB,EAAE,KAAK,EAAE,OAAO,CAAC,YAAY,CAAC,GAAG,OAAO,CAOxG;AAED,wBAAgB,kBAAkB,CAAC,OAAO,EAAE,OAAO,EAAE,IAAI,GAAE,gBAAwC;;;;EAGlG"}
|
@@ -10,6 +10,7 @@ export class TextCellEditorComponent extends AbstractEditCellEditor {
|
|
10
10
|
super();
|
11
11
|
this.render2 = inject(Renderer2);
|
12
12
|
this.maxHeight = 148;
|
13
|
+
this.minHeight = 24;
|
13
14
|
}
|
14
15
|
ngAfterViewInit() {
|
15
16
|
setTimeout(() => {
|
@@ -19,9 +20,11 @@ export class TextCellEditorComponent extends AbstractEditCellEditor {
|
|
19
20
|
updateStyle() {
|
20
21
|
const textarea = this.elementRef.nativeElement.querySelector('textarea');
|
21
22
|
if (textarea) {
|
22
|
-
|
23
|
+
this.render2.setStyle(textarea, 'height', 'auto');
|
24
|
+
const scrollHeight = textarea.scrollHeight;
|
25
|
+
const newHeight = Math.max(this.minHeight, Math.min(scrollHeight, this.maxHeight)) + 4;
|
23
26
|
this.render2.setStyle(textarea, 'max-height', `${this.maxHeight}px`);
|
24
|
-
this.render2.setStyle(textarea, 'height', `${
|
27
|
+
this.render2.setStyle(textarea, 'height', `${newHeight}px`);
|
25
28
|
this.render2.setStyle(textarea, 'resize', 'none');
|
26
29
|
}
|
27
30
|
}
|
@@ -70,4 +73,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
70
73
|
}
|
71
74
|
}]
|
72
75
|
}], ctorParameters: () => [] });
|
73
|
-
//# sourceMappingURL=data:application/json;base64,
|
76
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dC1lZGl0b3IuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZ3JpZC9zcmMvY29tcG9uZW50cy9jZWxsLWVkaXRvcnMvdGV4dC90ZXh0LWVkaXRvci5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFpQix1QkFBdUIsRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNyRyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDckQsT0FBTyxFQUFFLHFCQUFxQixFQUFFLGlCQUFpQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDN0UsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7OztBQXVCM0UsTUFBTSxPQUFPLHVCQUF3QixTQUFRLHNCQUE4QjtJQU12RTtRQUNJLEtBQUssRUFBRSxDQUFDO1FBTkosWUFBTyxHQUFHLE1BQU0sQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUM1QixjQUFTLEdBQUcsR0FBRyxDQUFDO1FBRWhCLGNBQVMsR0FBRyxFQUFFLENBQUM7SUFJdkIsQ0FBQztJQUVELGVBQWU7UUFDWCxVQUFVLENBQUMsR0FBRyxFQUFFO1lBQ1osSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1FBQ3ZCLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELFdBQVc7UUFDUCxNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLGFBQWEsQ0FBQyxhQUFhLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDekUsSUFBSSxRQUFRLEVBQUUsQ0FBQztZQUNYLElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLFFBQVEsRUFBRSxRQUFRLEVBQUUsTUFBTSxDQUFDLENBQUM7WUFDbEQsTUFBTSxZQUFZLEdBQUcsUUFBUSxDQUFDLFlBQVksQ0FBQztZQUMzQyxNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsSUFBSSxDQUFDLEdBQUcsQ0FBQyxZQUFZLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBRXZGLElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLFFBQVEsRUFBRSxZQUFZLEVBQUUsR0FBRyxJQUFJLENBQUMsU0FBUyxJQUFJLENBQUMsQ0FBQztZQUNyRSxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxRQUFRLEVBQUUsUUFBUSxFQUFFLEdBQUcsU0FBUyxJQUFJLENBQUMsQ0FBQztZQUM1RCxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxRQUFRLEVBQUUsUUFBUSxFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBQ3RELENBQUM7SUFDTCxDQUFDO0lBRUQsV0FBVztRQUNQLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztJQUN2QixDQUFDO0lBRUQsV0FBVztRQUNQLEtBQUssQ0FBQyxNQUFNLEVBQUUsQ0FBQztRQUNmLElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQztJQUN4QixDQUFDOytHQXBDUSx1QkFBdUI7bUdBQXZCLHVCQUF1QixpSkFuQnRCOzs7Ozs7Ozs7OztLQVdULDJEQUdTLFdBQVcsK21CQUFFLHFCQUFxQixrSUFBRSxpQkFBaUIsK0lBQUUsaUJBQWlCOzs0RkFLekUsdUJBQXVCO2tCQXJCbkMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsa0JBQWtCO29CQUM1QixRQUFRLEVBQUU7Ozs7Ozs7Ozs7O0tBV1Q7b0JBQ0QsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO29CQUMvQyxPQUFPLEVBQUUsQ0FBQyxXQUFXLEVBQUUscUJBQXFCLEVBQUUsaUJBQWlCLEVBQUUsaUJBQWlCLENBQUM7b0JBQ25GLElBQUksRUFBRTt3QkFDRixLQUFLLEVBQUUsa0JBQWtCO3FCQUM1QjtpQkFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFmdGVyVmlld0luaXQsIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGluamVjdCwgUmVuZGVyZXIyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcbmltcG9ydCB7IFRoeUlucHV0RGlyZWN0aXZlIH0gZnJvbSAnbmd4LXRldGh5cy9pbnB1dCc7XG5pbXBvcnQgeyBUaHlBdXRvZm9jdXNEaXJlY3RpdmUsIFRoeUVudGVyRGlyZWN0aXZlIH0gZnJvbSAnbmd4LXRldGh5cy9zaGFyZWQnO1xuaW1wb3J0IHsgQWJzdHJhY3RFZGl0Q2VsbEVkaXRvciB9IGZyb20gJy4uL2Fic3RyYWN0LWNlbGwtZWRpdG9yLmNvbXBvbmVudCc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAndGV4dC1jZWxsLWVkaXRvcicsXG4gICAgdGVtcGxhdGU6IGBcbiAgICAgICAgPHRleHRhcmVhXG4gICAgICAgICAgICBwbGFjZWhvbGRlcj1cIlwiXG4gICAgICAgICAgICByb3dzPVwiMVwiXG4gICAgICAgICAgICB0aHlJbnB1dFxuICAgICAgICAgICAgW3RoeUF1dG9mb2N1c109XCJ0cnVlXCJcbiAgICAgICAgICAgIFsobmdNb2RlbCldPVwibW9kZWxWYWx1ZVwiXG4gICAgICAgICAgICAobmdNb2RlbENoYW5nZSk9XCJ2YWx1ZUNoYW5nZSgpXCJcbiAgICAgICAgICAgICh0aHlFbnRlcik9XCJ1cGRhdGVWYWx1ZSgpXCJcbiAgICAgICAgICAgIChibHVyKT1cInVwZGF0ZVZhbHVlKClcIlxuICAgICAgICA+PC90ZXh0YXJlYT5cbiAgICBgLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gICAgaW1wb3J0czogW0Zvcm1zTW9kdWxlLCBUaHlBdXRvZm9jdXNEaXJlY3RpdmUsIFRoeUlucHV0RGlyZWN0aXZlLCBUaHlFbnRlckRpcmVjdGl2ZV0sXG4gICAgaG9zdDoge1xuICAgICAgICBjbGFzczogJ3RleHQtY2VsbC1lZGl0b3InXG4gICAgfVxufSlcbmV4cG9ydCBjbGFzcyBUZXh0Q2VsbEVkaXRvckNvbXBvbmVudCBleHRlbmRzIEFic3RyYWN0RWRpdENlbGxFZGl0b3I8c3RyaW5nPiBpbXBsZW1lbnRzIEFmdGVyVmlld0luaXQge1xuICAgIHByaXZhdGUgcmVuZGVyMiA9IGluamVjdChSZW5kZXJlcjIpO1xuICAgIHByaXZhdGUgbWF4SGVpZ2h0ID0gMTQ4O1xuXG4gICAgcHJpdmF0ZSBtaW5IZWlnaHQgPSAyNDtcblxuICAgIGNvbnN0cnVjdG9yKCkge1xuICAgICAgICBzdXBlcigpO1xuICAgIH1cblxuICAgIG5nQWZ0ZXJWaWV3SW5pdCgpIHtcbiAgICAgICAgc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICAgICAgICB0aGlzLnVwZGF0ZVN0eWxlKCk7XG4gICAgICAgIH0pO1xuICAgIH1cblxuICAgIHVwZGF0ZVN0eWxlKCkge1xuICAgICAgICBjb25zdCB0ZXh0YXJlYSA9IHRoaXMuZWxlbWVudFJlZi5uYXRpdmVFbGVtZW50LnF1ZXJ5U2VsZWN0b3IoJ3RleHRhcmVhJyk7XG4gICAgICAgIGlmICh0ZXh0YXJlYSkge1xuICAgICAgICAgICAgdGhpcy5yZW5kZXIyLnNldFN0eWxlKHRleHRhcmVhLCAnaGVpZ2h0JywgJ2F1dG8nKTtcbiAgICAgICAgICAgIGNvbnN0IHNjcm9sbEhlaWdodCA9IHRleHRhcmVhLnNjcm9sbEhlaWdodDtcbiAgICAgICAgICAgIGNvbnN0IG5ld0hlaWdodCA9IE1hdGgubWF4KHRoaXMubWluSGVpZ2h0LCBNYXRoLm1pbihzY3JvbGxIZWlnaHQsIHRoaXMubWF4SGVpZ2h0KSkgKyA0O1xuXG4gICAgICAgICAgICB0aGlzLnJlbmRlcjIuc2V0U3R5bGUodGV4dGFyZWEsICdtYXgtaGVpZ2h0JywgYCR7dGhpcy5tYXhIZWlnaHR9cHhgKTtcbiAgICAgICAgICAgIHRoaXMucmVuZGVyMi5zZXRTdHlsZSh0ZXh0YXJlYSwgJ2hlaWdodCcsIGAke25ld0hlaWdodH1weGApO1xuICAgICAgICAgICAgdGhpcy5yZW5kZXIyLnNldFN0eWxlKHRleHRhcmVhLCAncmVzaXplJywgJ25vbmUnKTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHZhbHVlQ2hhbmdlKCkge1xuICAgICAgICB0aGlzLnVwZGF0ZVN0eWxlKCk7XG4gICAgfVxuXG4gICAgdXBkYXRlVmFsdWUoKSB7XG4gICAgICAgIHN1cGVyLnVwZGF0ZSgpO1xuICAgICAgICB0aGlzLmNsb3NlUG9wb3ZlcigpO1xuICAgIH1cbn1cbiJdfQ==
|
@@ -1,24 +1,27 @@
|
|
1
|
-
import { NgClass,
|
2
|
-
import { ChangeDetectionStrategy, Component,
|
1
|
+
import { NgClass, NgTemplateOutlet } from '@angular/common';
|
2
|
+
import { ChangeDetectionStrategy, Component, booleanAttribute, computed, inject, input, model, output } from '@angular/core';
|
3
3
|
import { FormsModule } from '@angular/forms';
|
4
4
|
import { ThyButton } from 'ngx-tethys/button';
|
5
|
-
import { ThyDropdownDirective, ThyDropdownMenuComponent, ThyDropdownMenuItemDirective, ThyDropdownMenuItemNameDirective } from 'ngx-tethys/dropdown';
|
5
|
+
import { ThyDropdownDirective, ThyDropdownMenuComponent, ThyDropdownMenuItemDirective, ThyDropdownMenuItemExtendIconDirective, ThyDropdownMenuItemIconDirective, ThyDropdownMenuItemNameDirective } from 'ngx-tethys/dropdown';
|
6
6
|
import { ThyFormModule, ThyUniqueCheckValidator } from 'ngx-tethys/form';
|
7
7
|
import { ThyIcon } from 'ngx-tethys/icon';
|
8
8
|
import { ThyInputCount, ThyInputDirective, ThyInputGroup } from 'ngx-tethys/input';
|
9
|
-
import {
|
9
|
+
import { ThySwitch } from 'ngx-tethys/switch';
|
10
10
|
import { ThyPopoverRef } from 'ngx-tethys/popover';
|
11
11
|
import { ThyAutofocusDirective } from 'ngx-tethys/shared';
|
12
12
|
import { of } from 'rxjs';
|
13
|
-
import { FieldOptions, createDefaultFieldName, getFieldOptionByField } from '../../core';
|
14
|
-
import {
|
13
|
+
import { FieldOptions, createDefaultFieldName, getFieldOptionByField, AITableFieldType } from '../../core';
|
14
|
+
import { AITableFieldIsSameOptionPipe } from '../../pipes';
|
15
|
+
import * as _ from 'lodash';
|
15
16
|
import * as i0 from "@angular/core";
|
16
17
|
import * as i1 from "@angular/forms";
|
17
18
|
import * as i2 from "ngx-tethys/form";
|
18
19
|
export class AITableFieldSetting {
|
19
20
|
constructor() {
|
20
21
|
this.aiEditField = model.required();
|
21
|
-
this.
|
22
|
+
this.aiTable = input.required();
|
23
|
+
this.aiExternalTemplate = input(null);
|
24
|
+
this.isUpdate = input(false, { transform: booleanAttribute });
|
22
25
|
this.addField = output();
|
23
26
|
this.setField = output();
|
24
27
|
this.selectedFieldOption = computed(() => {
|
@@ -33,23 +36,34 @@ export class AITableFieldSetting {
|
|
33
36
|
}
|
34
37
|
}
|
35
38
|
};
|
36
|
-
this.fieldOptions = FieldOptions;
|
39
|
+
this.fieldOptions = _.cloneDeep(FieldOptions);
|
40
|
+
this.aITableFieldType = AITableFieldType;
|
41
|
+
this.isMultipleMember = false;
|
37
42
|
this.thyPopoverRef = inject((ThyPopoverRef));
|
38
43
|
this.checkUniqueName = (fieldName) => {
|
39
44
|
fieldName = fieldName?.trim();
|
40
|
-
return of(!!this.aiTable
|
45
|
+
return of(!!this.aiTable()
|
46
|
+
.fields()
|
47
|
+
?.find((field) => field.name === fieldName && this.aiEditField()?._id !== field._id));
|
41
48
|
};
|
42
49
|
}
|
50
|
+
ngOnInit() {
|
51
|
+
this.isMultipleMember =
|
52
|
+
this.aiEditField().type === AITableFieldType.member && !!this.aiEditField().settings?.is_multiple;
|
53
|
+
}
|
43
54
|
selectFieldType(field) {
|
44
55
|
this.aiEditField.update((item) => {
|
45
56
|
const width = item.width ?? field.width;
|
46
57
|
const settings = field.settings || {};
|
47
|
-
const name = createDefaultFieldName(this.aiTable, field);
|
48
|
-
return { ...item, ...field, width, name,
|
58
|
+
const name = createDefaultFieldName(this.aiTable(), field);
|
59
|
+
return { ...item, ...field, width, name, settings };
|
49
60
|
});
|
61
|
+
setTimeout(() => {
|
62
|
+
this.thyPopoverRef.updatePosition();
|
63
|
+
}, 0);
|
50
64
|
}
|
51
65
|
editFieldProperty() {
|
52
|
-
if (this.isUpdate) {
|
66
|
+
if (this.isUpdate()) {
|
53
67
|
this.setField.emit({
|
54
68
|
field: this.aiEditField(),
|
55
69
|
path: [this.aiEditField()._id]
|
@@ -60,16 +74,28 @@ export class AITableFieldSetting {
|
|
60
74
|
}
|
61
75
|
this.thyPopoverRef.close();
|
62
76
|
}
|
77
|
+
multipleMemberChange() {
|
78
|
+
this.aiEditField.set({
|
79
|
+
...this.aiEditField(),
|
80
|
+
settings: {
|
81
|
+
...(this.aiEditField().settings || {}),
|
82
|
+
is_multiple: this.isMultipleMember
|
83
|
+
}
|
84
|
+
});
|
85
|
+
}
|
86
|
+
fieldTypeClick(e) {
|
87
|
+
e.preventDefault();
|
88
|
+
e.stopPropagation();
|
89
|
+
}
|
63
90
|
cancel() {
|
64
91
|
this.thyPopoverRef.close();
|
65
92
|
}
|
66
93
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableFieldSetting, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
67
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: AITableFieldSetting, isStandalone: true, selector: "ai-table-field-setting", inputs: { aiEditField: { classPropertyName: "aiEditField", publicName: "aiEditField", isSignal: true, isRequired: true, transformFunction: null }, aiTable: { classPropertyName: "aiTable", publicName: "aiTable", isSignal:
|
94
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: AITableFieldSetting, isStandalone: true, selector: "ai-table-field-setting", inputs: { aiEditField: { classPropertyName: "aiEditField", publicName: "aiEditField", isSignal: true, isRequired: true, transformFunction: null }, aiTable: { classPropertyName: "aiTable", publicName: "aiTable", isSignal: true, isRequired: true, transformFunction: null }, aiExternalTemplate: { classPropertyName: "aiExternalTemplate", publicName: "aiExternalTemplate", isSignal: true, isRequired: false, transformFunction: null }, isUpdate: { classPropertyName: "isUpdate", publicName: "isUpdate", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { aiEditField: "aiEditFieldChange", addField: "addField", setField: "setField" }, host: { classAttribute: "field-setting d-block pl-5 pr-5 pb-5 pt-4" }, ngImport: i0, template: "<form thyForm name=\"createPropertyForm\" [thyFormValidatorConfig]=\"validatorConfig\" thyLayout=\"vertical\">\n <thy-form-group thyLabelRequired thyLabelText=\"\u8868\u683C\u5217\u540D\">\n <thy-input-group>\n <input\n thyInput\n [thyAutofocus]=\"true\"\n name=\"fieldName\"\n [maxlength]=\"fieldMaxLength\"\n [(ngModel)]=\"aiEditField().name\"\n required\n placeholder=\"\u8F93\u5165\u5217\u540D\u79F0\"\n [thyUniqueCheck]=\"checkUniqueName\"\n />\n <ng-template #suffix>\n <thy-input-count></thy-input-count>\n </ng-template>\n </thy-input-group>\n </thy-form-group>\n <thy-form-group thyLabelText=\"\u5217\u7C7B\u578B\">\n <div class=\"thy-dropdown-menu py-0\">\n <div class=\"ml-n5 mr-n5\">\n <span\n thyDropdownMenuItem\n [thyDropdown]=\"menu\"\n [thyDisabled]=\"isUpdate()\"\n thyTrigger=\"hover\"\n thyPlacement=\"right\"\n (click)=\"fieldTypeClick($event)\"\n >\n <thy-icon thyDropdownMenuItemIcon [thyIconName]=\"selectedFieldOption().icon\"></thy-icon>\n <span thyDropdownMenuItemName>{{ selectedFieldOption().name }}</span>\n <thy-icon thyDropdownMenuItemExtendIcon thyIconName=\"angle-right\" class=\"text-desc\"></thy-icon>\n </span>\n </div>\n </div>\n\n @if (selectedFieldOption().type === aITableFieldType.member) {\n <div class=\"d-flex justify-content-between mt-3\">\n \u5141\u8BB8\u9009\u62E9\u591A\u4E2A\u6210\u5458\n <thy-switch\n name=\"isMultipleMember\"\n [thyDisabled]=\"isUpdate()\"\n [(ngModel)]=\"isMultipleMember\"\n (ngModelChange)=\"multipleMemberChange()\"\n thySize=\"sm\"\n ></thy-switch>\n </div>\n }\n </thy-form-group>\n @if (aiExternalTemplate()) {\n <ng-container *ngTemplateOutlet=\"aiExternalTemplate()\"></ng-container>\n }\n <thy-form-group-footer thyAlign=\"right\">\n <button thyButton=\"link-secondary\" (click)=\"cancel()\" thySize=\"sm\">\u53D6\u6D88</button>\n <button thyButton=\"primary\" (thyFormSubmit)=\"editFieldProperty()\" thySize=\"sm\">\u786E\u5B9A</button>\n </thy-form-group-footer>\n</form>\n\n<thy-dropdown-menu #menu>\n @for (item of fieldOptions; track $index) {\n <a\n thyDropdownMenuItem\n href=\"javascript:;\"\n [ngClass]=\"{\n active: (item | fieldIsSameOption: aiEditField())\n }\"\n (click)=\"selectFieldType(item)\"\n >\n <thy-icon [thyIconName]=\"item.icon!\"></thy-icon>\n <span thyDropdownMenuItemName>{{ item.name }}</span>\n </a>\n }\n</thy-dropdown-menu>\n", styles: [":host{width:350px}\n"], dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i1.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i1.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: ThyIcon, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "component", type: ThyInputGroup, selector: "thy-input-group", inputs: ["thyAppendText", "thyAppendTextTranslateKey", "thyPrependText", "thyPrependTextTranslateKey", "thySize"] }, { kind: "component", type: ThyInputCount, selector: "thy-input-count", inputs: ["thyInput"] }, { kind: "directive", type: ThyInputDirective, selector: "input[thyInput], select[thyInput], textarea[thyInput]", inputs: ["thySize"], exportAs: ["thyInput"] }, { kind: "directive", type: ThyUniqueCheckValidator, selector: "[thyUniqueCheck]", inputs: ["thyUniqueCheck"] }, { kind: "component", type: ThyDropdownMenuComponent, selector: "thy-dropdown-menu", inputs: ["thyWidth", "thyImmediateRender"] }, { kind: "directive", type: ThyDropdownDirective, selector: "[thyDropdown]", inputs: ["thyDropdownMenu", "thyDropdown", "thyTrigger", "thyShowDelay", "thyHideDelay", "thyActiveClass", "thyPopoverOptions", "thyPlacement", "thyMenuInsideClosable", "thyPanelClass"], outputs: ["thyActiveChange"] }, { kind: "directive", type: ThyDropdownMenuItemDirective, selector: "[thyDropdownMenuItem]", inputs: ["thyType", "thyDisabled"] }, { kind: "directive", type: ThyDropdownMenuItemIconDirective, selector: "[thyDropdownMenuItemIcon]" }, { kind: "directive", type: ThyDropdownMenuItemNameDirective, selector: "[thyDropdownMenuItemName]" }, { kind: "directive", type: ThyDropdownMenuItemExtendIconDirective, selector: "[thyDropdownMenuItemExtendIcon]" }, { kind: "component", type: ThyButton, selector: "thy-button,[thy-button],[thyButton]", inputs: ["thyButton", "thyType", "thyLoading", "thyLoadingText", "thySize", "thyIcon", "thyBlock"] }, { kind: "component", type: ThySwitch, selector: "thy-switch", inputs: ["thyType", "thySize", "thyDisabled", "thyLoading"], outputs: ["thyChange"] }, { kind: "ngmodule", type: ThyFormModule }, { kind: "directive", type: i2.ThyFormDirective, selector: "[thyForm],[thy-form]", inputs: ["thyLayout", "thyEnterKeyMode", "thyFormValidatorConfig"], exportAs: ["thyForm"] }, { kind: "component", type: i2.ThyFormGroup, selector: "thy-form-group", inputs: ["thyLabelText", "thyLabelTextTranslateKey", "thyLabelRequired", "thyLabelPaddingTopClear", "thyFeedbackIcon", "thyTipsMode", "thyTips", "thyTipsTranslateKey", "thyRowFill"] }, { kind: "directive", type: i2.ThyFormSubmitDirective, selector: "[thyFormSubmit],[thy-form-submit]", outputs: ["thyFormSubmit"] }, { kind: "component", type: i2.ThyFormGroupFooter, selector: "thy-form-group-footer", inputs: ["thyAlign"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: ThyAutofocusDirective, selector: "input[thyAutofocus],textarea[thyAutofocus]", inputs: ["thyAutofocus", "thyAutoSelect"] }, { kind: "pipe", type: AITableFieldIsSameOptionPipe, name: "fieldIsSameOption" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
68
95
|
}
|
69
96
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableFieldSetting, decorators: [{
|
70
97
|
type: Component,
|
71
98
|
args: [{ selector: 'ai-table-field-setting', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [
|
72
|
-
NgIf,
|
73
99
|
NgClass,
|
74
100
|
FormsModule,
|
75
101
|
ThyIcon,
|
@@ -77,26 +103,20 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
77
103
|
ThyInputCount,
|
78
104
|
ThyInputDirective,
|
79
105
|
ThyUniqueCheckValidator,
|
80
|
-
ThyDropdownDirective,
|
81
106
|
ThyDropdownMenuComponent,
|
107
|
+
ThyDropdownDirective,
|
82
108
|
ThyDropdownMenuItemDirective,
|
109
|
+
ThyDropdownMenuItemIconDirective,
|
83
110
|
ThyDropdownMenuItemNameDirective,
|
111
|
+
ThyDropdownMenuItemExtendIconDirective,
|
84
112
|
ThyButton,
|
113
|
+
ThySwitch,
|
85
114
|
ThyFormModule,
|
86
|
-
ThyListItem,
|
87
115
|
NgTemplateOutlet,
|
88
116
|
ThyAutofocusDirective,
|
89
|
-
|
117
|
+
AITableFieldIsSameOptionPipe
|
90
118
|
], host: {
|
91
119
|
class: 'field-setting d-block pl-5 pr-5 pb-5 pt-4'
|
92
|
-
}, template: "<form thyForm name=\"createPropertyForm\" [thyFormValidatorConfig]=\"validatorConfig\" thyLayout=\"vertical\">\n <thy-form-group thyLabelRequired thyLabelText=\"\u8868\u683C\u5217\u540D\">\n <thy-input-group>\n <input\n thyInput\n [thyAutofocus]=\"true\"\n name=\"fieldName\"\n [maxlength]=\"fieldMaxLength\"\n [(ngModel)]=\"aiEditField().name\"\n required\n placeholder=\"\u8F93\u5165\u5217\u540D\u79F0\"\n [thyUniqueCheck]=\"checkUniqueName\"\n />\n <ng-template #suffix>\n <thy-input-count></thy-input-count>\n </ng-template>\n </thy-input-group>\n </thy-form-group>\n <thy-form-group thyLabelText=\"\u5217\u7C7B\u578B\">\n <div class=\"ml-n5 mr-n5\">\n
|
93
|
-
}]
|
94
|
-
type: Input,
|
95
|
-
args: [{ required: true }]
|
96
|
-
}], aiExternalTemplate: [{
|
97
|
-
type: Input
|
98
|
-
}], isUpdate: [{
|
99
|
-
type: Input,
|
100
|
-
args: [{ transform: booleanAttribute }]
|
101
|
-
}] } });
|
102
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"field-setting.component.js","sourceRoot":"","sources":["../../../../../packages/grid/src/components/field-setting/field-setting.component.ts","../../../../../packages/grid/src/components/field-setting/field-setting.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgClass, NgIf, NgTemplateOutlet } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, Input, TemplateRef, booleanAttribute, computed, inject, model, output } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { ThyButton } from 'ngx-tethys/button';\nimport {\n    ThyDropdownDirective,\n    ThyDropdownMenuComponent,\n    ThyDropdownMenuItemDirective,\n    ThyDropdownMenuItemNameDirective\n} from 'ngx-tethys/dropdown';\nimport { ThyFormModule, ThyFormValidatorConfig, ThyUniqueCheckValidator } from 'ngx-tethys/form';\nimport { ThyIcon } from 'ngx-tethys/icon';\nimport { ThyInputCount, ThyInputDirective, ThyInputGroup } from 'ngx-tethys/input';\nimport { ThyListItem } from 'ngx-tethys/list';\nimport { ThyPopoverRef } from 'ngx-tethys/popover';\nimport { ThyAutofocusDirective } from 'ngx-tethys/shared';\nimport { of } from 'rxjs';\nimport {\n    AITable,\n    AITableField,\n    AITableFieldOption,\n    FieldOptions,\n    createDefaultFieldName,\n    getFieldOptionByField,\n    SetFieldOptions\n} from '../../core';\nimport { AITableFieldIsMultiplePipe } from '../../pipes';\n\n@Component({\n    selector: 'ai-table-field-setting',\n    templateUrl: './field-setting.component.html',\n    standalone: true,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    imports: [\n        NgIf,\n        NgClass,\n        FormsModule,\n        ThyIcon,\n        ThyInputGroup,\n        ThyInputCount,\n        ThyInputDirective,\n        ThyUniqueCheckValidator,\n        ThyDropdownDirective,\n        ThyDropdownMenuComponent,\n        ThyDropdownMenuItemDirective,\n        ThyDropdownMenuItemNameDirective,\n        ThyButton,\n        ThyFormModule,\n        ThyListItem,\n        NgTemplateOutlet,\n        ThyAutofocusDirective,\n        AITableFieldIsMultiplePipe\n    ],\n    host: {\n        class: 'field-setting d-block pl-5 pr-5 pb-5 pt-4'\n    },\n    styles: [\n        `\n            :host {\n                width: 350px;\n            }\n        `\n    ]\n})\nexport class AITableFieldSetting {\n    aiEditField = model.required<AITableField>();\n\n    @Input({ required: true }) aiTable!: AITable;\n\n    @Input() aiExternalTemplate: TemplateRef<any> | null = null;\n\n    @Input({ transform: booleanAttribute }) isUpdate!: boolean;\n\n    addField = output<AITableField>();\n\n    setField = output<SetFieldOptions>();\n\n    selectedFieldOption = computed(() => {\n        return getFieldOptionByField(this.aiEditField())!;\n    });\n\n    fieldMaxLength = 32;\n\n    validatorConfig: ThyFormValidatorConfig = {\n        validationMessages: {\n            fieldName: {\n                required: '列名不能为空',\n                thyUniqueCheck: '列名已存在'\n            }\n        }\n    };\n\n    fieldOptions = FieldOptions;\n\n    protected thyPopoverRef = inject(ThyPopoverRef<AITableFieldSetting>);\n\n    checkUniqueName = (fieldName: string) => {\n        fieldName = fieldName?.trim();\n        return of(!!this.aiTable.fields()?.find((field) => field.name === fieldName && this.aiEditField()?._id !== field._id));\n    };\n\n    selectFieldType(field: AITableFieldOption) {\n        this.aiEditField.update((item) => {\n            const width = item.width ?? field.width;\n            const settings = field.settings || {};\n            const name = createDefaultFieldName(this.aiTable, field);\n            return { ...item, ...field, width, name, ...settings };\n        });\n    }\n\n    editFieldProperty() {\n        if (this.isUpdate) {\n            this.setField.emit({\n                field: this.aiEditField(),\n                path: [this.aiEditField()._id]\n            });\n        } else {\n            this.addField.emit(this.aiEditField());\n        }\n        this.thyPopoverRef.close();\n    }\n\n    cancel() {\n        this.thyPopoverRef.close();\n    }\n}\n","<form thyForm name=\"createPropertyForm\" [thyFormValidatorConfig]=\"validatorConfig\" thyLayout=\"vertical\">\n    <thy-form-group thyLabelRequired thyLabelText=\"表格列名\">\n        <thy-input-group>\n            <input\n                thyInput\n                [thyAutofocus]=\"true\"\n                name=\"fieldName\"\n                [maxlength]=\"fieldMaxLength\"\n                [(ngModel)]=\"aiEditField().name\"\n                required\n                placeholder=\"输入列名称\"\n                [thyUniqueCheck]=\"checkUniqueName\"\n            />\n            <ng-template #suffix>\n                <thy-input-count></thy-input-count>\n            </ng-template>\n        </thy-input-group>\n    </thy-form-group>\n    <thy-form-group thyLabelText=\"列类型\">\n        <div class=\"ml-n5 mr-n5\">\n            <thy-list-item [thyDropdown]=\"menu\" thyTrigger=\"hover\" thyPlacement=\"right\" class=\"justify-content-between\">\n                <span>\n                    <thy-icon [thyIconName]=\"selectedFieldOption().icon\" class=\"text-desc mr-2\"></thy-icon>\n                    <span>{{ selectedFieldOption().name }}</span>\n                </span>\n                <thy-icon thyIconName=\"angle-right\" class=\"text-desc\"></thy-icon>\n            </thy-list-item>\n        </div>\n    </thy-form-group>\n    <ng-container *ngIf=\"aiExternalTemplate; else defaultTemplate\">\n        <ng-container *ngTemplateOutlet=\"aiExternalTemplate\"></ng-container>\n    </ng-container>\n    <ng-template #defaultTemplate>\n        <!-- TODO: 内部属性渲染 -->\n    </ng-template>\n    <thy-form-group-footer thyAlign=\"right\">\n        <button thyButton=\"link-secondary\" (click)=\"cancel()\" thySize=\"sm\">取消</button>\n        <button thyButton=\"primary\" (thyFormSubmit)=\"editFieldProperty()\" thySize=\"sm\">确定</button>\n    </thy-form-group-footer>\n</form>\n\n<thy-dropdown-menu #menu>\n    @for (item of fieldOptions; track $index) {\n        @let isSelectedField = aiEditField().type === item.type;\n        @let isSameMultipleMode = (item.settings! | fieldIsMultiple) === (aiEditField().settings! | fieldIsMultiple);\n        <a\n            thyDropdownMenuItem\n            href=\"javascript:;\"\n            [ngClass]=\"{\n                active: isSelectedField && isSameMultipleMode\n            }\"\n            (click)=\"selectFieldType(item)\"\n        >\n            <thy-icon [thyIconName]=\"item.icon!\"></thy-icon>\n            <span thyDropdownMenuItemName>{{ item.name }}</span>\n        </a>\n    }\n</thy-dropdown-menu>\n"]}
|
120
|
+
}, template: "<form thyForm name=\"createPropertyForm\" [thyFormValidatorConfig]=\"validatorConfig\" thyLayout=\"vertical\">\n <thy-form-group thyLabelRequired thyLabelText=\"\u8868\u683C\u5217\u540D\">\n <thy-input-group>\n <input\n thyInput\n [thyAutofocus]=\"true\"\n name=\"fieldName\"\n [maxlength]=\"fieldMaxLength\"\n [(ngModel)]=\"aiEditField().name\"\n required\n placeholder=\"\u8F93\u5165\u5217\u540D\u79F0\"\n [thyUniqueCheck]=\"checkUniqueName\"\n />\n <ng-template #suffix>\n <thy-input-count></thy-input-count>\n </ng-template>\n </thy-input-group>\n </thy-form-group>\n <thy-form-group thyLabelText=\"\u5217\u7C7B\u578B\">\n <div class=\"thy-dropdown-menu py-0\">\n <div class=\"ml-n5 mr-n5\">\n <span\n thyDropdownMenuItem\n [thyDropdown]=\"menu\"\n [thyDisabled]=\"isUpdate()\"\n thyTrigger=\"hover\"\n thyPlacement=\"right\"\n (click)=\"fieldTypeClick($event)\"\n >\n <thy-icon thyDropdownMenuItemIcon [thyIconName]=\"selectedFieldOption().icon\"></thy-icon>\n <span thyDropdownMenuItemName>{{ selectedFieldOption().name }}</span>\n <thy-icon thyDropdownMenuItemExtendIcon thyIconName=\"angle-right\" class=\"text-desc\"></thy-icon>\n </span>\n </div>\n </div>\n\n @if (selectedFieldOption().type === aITableFieldType.member) {\n <div class=\"d-flex justify-content-between mt-3\">\n \u5141\u8BB8\u9009\u62E9\u591A\u4E2A\u6210\u5458\n <thy-switch\n name=\"isMultipleMember\"\n [thyDisabled]=\"isUpdate()\"\n [(ngModel)]=\"isMultipleMember\"\n (ngModelChange)=\"multipleMemberChange()\"\n thySize=\"sm\"\n ></thy-switch>\n </div>\n }\n </thy-form-group>\n @if (aiExternalTemplate()) {\n <ng-container *ngTemplateOutlet=\"aiExternalTemplate()\"></ng-container>\n }\n <thy-form-group-footer thyAlign=\"right\">\n <button thyButton=\"link-secondary\" (click)=\"cancel()\" thySize=\"sm\">\u53D6\u6D88</button>\n <button thyButton=\"primary\" (thyFormSubmit)=\"editFieldProperty()\" thySize=\"sm\">\u786E\u5B9A</button>\n </thy-form-group-footer>\n</form>\n\n<thy-dropdown-menu #menu>\n @for (item of fieldOptions; track $index) {\n <a\n thyDropdownMenuItem\n href=\"javascript:;\"\n [ngClass]=\"{\n active: (item | fieldIsSameOption: aiEditField())\n }\"\n (click)=\"selectFieldType(item)\"\n >\n <thy-icon [thyIconName]=\"item.icon!\"></thy-icon>\n <span thyDropdownMenuItemName>{{ item.name }}</span>\n </a>\n }\n</thy-dropdown-menu>\n", styles: [":host{width:350px}\n"] }]
|
121
|
+
}] });
|
122
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"field-setting.component.js","sourceRoot":"","sources":["../../../../../packages/grid/src/components/field-setting/field-setting.component.ts","../../../../../packages/grid/src/components/field-setting/field-setting.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgClass, NgTemplateOutlet } from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    OnInit,\n    TemplateRef,\n    booleanAttribute,\n    computed,\n    inject,\n    input,\n    model,\n    output\n} from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { ThyButton } from 'ngx-tethys/button';\nimport {\n    ThyDropdownDirective,\n    ThyDropdownMenuComponent,\n    ThyDropdownMenuItemDirective,\n    ThyDropdownMenuItemExtendIconDirective,\n    ThyDropdownMenuItemIconDirective,\n    ThyDropdownMenuItemNameDirective\n} from 'ngx-tethys/dropdown';\nimport { ThyFormModule, ThyFormValidatorConfig, ThyUniqueCheckValidator } from 'ngx-tethys/form';\nimport { ThyIcon } from 'ngx-tethys/icon';\nimport { ThyInputCount, ThyInputDirective, ThyInputGroup } from 'ngx-tethys/input';\nimport { ThySwitch } from 'ngx-tethys/switch';\nimport { ThyPopoverRef } from 'ngx-tethys/popover';\nimport { ThyAutofocusDirective } from 'ngx-tethys/shared';\nimport { of } from 'rxjs';\nimport {\n    AITable,\n    AITableField,\n    AITableFieldOption,\n    FieldOptions,\n    createDefaultFieldName,\n    getFieldOptionByField,\n    SetFieldOptions,\n    AITableFieldType,\n    MemberSettings\n} from '../../core';\nimport { AITableFieldIsSameOptionPipe } from '../../pipes';\nimport * as _ from 'lodash';\n\n@Component({\n    selector: 'ai-table-field-setting',\n    templateUrl: './field-setting.component.html',\n    standalone: true,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    imports: [\n        NgClass,\n        FormsModule,\n        ThyIcon,\n        ThyInputGroup,\n        ThyInputCount,\n        ThyInputDirective,\n        ThyUniqueCheckValidator,\n        ThyDropdownMenuComponent,\n        ThyDropdownDirective,\n        ThyDropdownMenuItemDirective,\n        ThyDropdownMenuItemIconDirective,\n        ThyDropdownMenuItemNameDirective,\n        ThyDropdownMenuItemExtendIconDirective,\n        ThyButton,\n        ThySwitch,\n        ThyFormModule,\n        NgTemplateOutlet,\n        ThyAutofocusDirective,\n        AITableFieldIsSameOptionPipe\n    ],\n    host: {\n        class: 'field-setting d-block pl-5 pr-5 pb-5 pt-4'\n    },\n    styles: [\n        `\n            :host {\n                width: 350px;\n            }\n        `\n    ]\n})\nexport class AITableFieldSetting implements OnInit {\n    aiEditField = model.required<AITableField>();\n\n    aiTable = input.required<AITable>();\n\n    aiExternalTemplate = input<TemplateRef<any> | null>(null);\n\n    isUpdate = input<boolean, unknown>(false, { transform: booleanAttribute });\n\n    addField = output<AITableField>();\n\n    setField = output<SetFieldOptions>();\n\n    selectedFieldOption = computed(() => {\n        return getFieldOptionByField(this.aiEditField())!;\n    });\n\n    fieldMaxLength = 32;\n\n    validatorConfig: ThyFormValidatorConfig = {\n        validationMessages: {\n            fieldName: {\n                required: '列名不能为空',\n                thyUniqueCheck: '列名已存在'\n            }\n        }\n    };\n\n    fieldOptions = _.cloneDeep(FieldOptions);\n\n    aITableFieldType = AITableFieldType;\n\n    isMultipleMember = false;\n\n    protected thyPopoverRef = inject(ThyPopoverRef<AITableFieldSetting>);\n\n    ngOnInit(): void {\n        this.isMultipleMember =\n            this.aiEditField().type === AITableFieldType.member && !!(this.aiEditField().settings as MemberSettings)?.is_multiple;\n    }\n\n    checkUniqueName = (fieldName: string) => {\n        fieldName = fieldName?.trim();\n        return of(\n            !!this.aiTable()\n                .fields()\n                ?.find((field) => field.name === fieldName && this.aiEditField()?._id !== field._id)\n        );\n    };\n\n    selectFieldType(field: AITableFieldOption) {\n        this.aiEditField.update((item) => {\n            const width = item.width ?? field.width;\n            const settings = field.settings || {};\n            const name = createDefaultFieldName(this.aiTable(), field);\n            return { ...item, ...field, width, name, settings };\n        });\n        setTimeout(() => {\n            this.thyPopoverRef.updatePosition();\n        }, 0);\n    }\n\n    editFieldProperty() {\n        if (this.isUpdate()) {\n            this.setField.emit({\n                field: this.aiEditField(),\n                path: [this.aiEditField()._id]\n            });\n        } else {\n            this.addField.emit(this.aiEditField());\n        }\n        this.thyPopoverRef.close();\n    }\n\n    multipleMemberChange() {\n        this.aiEditField.set({\n            ...this.aiEditField(),\n            settings: {\n                ...(this.aiEditField().settings || {}),\n                is_multiple: this.isMultipleMember\n            }\n        });\n    }\n\n    fieldTypeClick(e: Event) {\n        e.preventDefault();\n        e.stopPropagation();\n    }\n\n    cancel() {\n        this.thyPopoverRef.close();\n    }\n}\n","<form thyForm name=\"createPropertyForm\" [thyFormValidatorConfig]=\"validatorConfig\" thyLayout=\"vertical\">\n    <thy-form-group thyLabelRequired thyLabelText=\"表格列名\">\n        <thy-input-group>\n            <input\n                thyInput\n                [thyAutofocus]=\"true\"\n                name=\"fieldName\"\n                [maxlength]=\"fieldMaxLength\"\n                [(ngModel)]=\"aiEditField().name\"\n                required\n                placeholder=\"输入列名称\"\n                [thyUniqueCheck]=\"checkUniqueName\"\n            />\n            <ng-template #suffix>\n                <thy-input-count></thy-input-count>\n            </ng-template>\n        </thy-input-group>\n    </thy-form-group>\n    <thy-form-group thyLabelText=\"列类型\">\n        <div class=\"thy-dropdown-menu py-0\">\n            <div class=\"ml-n5 mr-n5\">\n                <span\n                    thyDropdownMenuItem\n                    [thyDropdown]=\"menu\"\n                    [thyDisabled]=\"isUpdate()\"\n                    thyTrigger=\"hover\"\n                    thyPlacement=\"right\"\n                    (click)=\"fieldTypeClick($event)\"\n                >\n                    <thy-icon thyDropdownMenuItemIcon [thyIconName]=\"selectedFieldOption().icon\"></thy-icon>\n                    <span thyDropdownMenuItemName>{{ selectedFieldOption().name }}</span>\n                    <thy-icon thyDropdownMenuItemExtendIcon thyIconName=\"angle-right\" class=\"text-desc\"></thy-icon>\n                </span>\n            </div>\n        </div>\n\n        @if (selectedFieldOption().type === aITableFieldType.member) {\n            <div class=\"d-flex justify-content-between mt-3\">\n                允许选择多个成员\n                <thy-switch\n                    name=\"isMultipleMember\"\n                    [thyDisabled]=\"isUpdate()\"\n                    [(ngModel)]=\"isMultipleMember\"\n                    (ngModelChange)=\"multipleMemberChange()\"\n                    thySize=\"sm\"\n                ></thy-switch>\n            </div>\n        }\n    </thy-form-group>\n    @if (aiExternalTemplate()) {\n        <ng-container *ngTemplateOutlet=\"aiExternalTemplate()\"></ng-container>\n    }\n    <thy-form-group-footer thyAlign=\"right\">\n        <button thyButton=\"link-secondary\" (click)=\"cancel()\" thySize=\"sm\">取消</button>\n        <button thyButton=\"primary\" (thyFormSubmit)=\"editFieldProperty()\" thySize=\"sm\">确定</button>\n    </thy-form-group-footer>\n</form>\n\n<thy-dropdown-menu #menu>\n    @for (item of fieldOptions; track $index) {\n        <a\n            thyDropdownMenuItem\n            href=\"javascript:;\"\n            [ngClass]=\"{\n                active: (item | fieldIsSameOption: aiEditField())\n            }\"\n            (click)=\"selectFieldType(item)\"\n        >\n            <thy-icon [thyIconName]=\"item.icon!\"></thy-icon>\n            <span thyDropdownMenuItemName>{{ item.name }}</span>\n        </a>\n    }\n</thy-dropdown-menu>\n"]}
|
@@ -1,23 +1,27 @@
|
|
1
1
|
import { AITableFieldType } from '../types';
|
2
|
+
export const AI_TABLE_FIELD_MINI_WIDTH = 140;
|
3
|
+
export const AI_TABLE_FIELD_MIN_WIDTH = 160;
|
4
|
+
export const AI_TABLE_FIELD_MIDDLE_WIDTH = 200;
|
5
|
+
export const AI_TABLE_FIELD_MAX_WIDTH = 300;
|
2
6
|
export const FieldOptions = [
|
3
7
|
{
|
4
8
|
type: AITableFieldType.text,
|
5
9
|
name: '单行文本',
|
6
10
|
icon: 'font',
|
7
|
-
width:
|
11
|
+
width: AI_TABLE_FIELD_MAX_WIDTH
|
8
12
|
},
|
9
13
|
// 多行文本
|
10
14
|
{
|
11
15
|
type: AITableFieldType.select,
|
12
16
|
name: '单选',
|
13
17
|
icon: 'check-circle',
|
14
|
-
width:
|
18
|
+
width: AI_TABLE_FIELD_MIN_WIDTH
|
15
19
|
},
|
16
20
|
{
|
17
21
|
type: AITableFieldType.select,
|
18
22
|
name: '多选',
|
19
23
|
icon: 'list-check',
|
20
|
-
width:
|
24
|
+
width: AI_TABLE_FIELD_MIDDLE_WIDTH,
|
21
25
|
settings: {
|
22
26
|
is_multiple: true
|
23
27
|
}
|
@@ -26,27 +30,21 @@ export const FieldOptions = [
|
|
26
30
|
type: AITableFieldType.number,
|
27
31
|
name: '数字',
|
28
32
|
icon: 'hashtag',
|
29
|
-
width:
|
33
|
+
width: AI_TABLE_FIELD_MINI_WIDTH
|
30
34
|
},
|
31
35
|
{
|
32
36
|
type: AITableFieldType.date,
|
33
37
|
name: '日期',
|
34
38
|
icon: 'calendar',
|
35
|
-
width:
|
39
|
+
width: AI_TABLE_FIELD_MIDDLE_WIDTH
|
36
40
|
},
|
37
41
|
{
|
38
42
|
type: AITableFieldType.member,
|
39
|
-
name: '
|
43
|
+
name: '成员',
|
40
44
|
icon: 'user',
|
41
|
-
width:
|
42
|
-
},
|
43
|
-
{
|
44
|
-
type: AITableFieldType.member,
|
45
|
-
name: '多个成员',
|
46
|
-
icon: 'user',
|
47
|
-
width: 200,
|
45
|
+
width: AI_TABLE_FIELD_MIN_WIDTH,
|
48
46
|
settings: {
|
49
|
-
is_multiple:
|
47
|
+
is_multiple: false
|
50
48
|
}
|
51
49
|
},
|
52
50
|
// 级联单选
|
@@ -55,43 +53,43 @@ export const FieldOptions = [
|
|
55
53
|
type: AITableFieldType.progress,
|
56
54
|
name: '进度',
|
57
55
|
icon: 'progress',
|
58
|
-
width:
|
56
|
+
width: AI_TABLE_FIELD_MIDDLE_WIDTH
|
59
57
|
},
|
60
58
|
{
|
61
59
|
type: AITableFieldType.rate,
|
62
60
|
name: '评分',
|
63
61
|
icon: 'star-circle',
|
64
|
-
width:
|
62
|
+
width: AI_TABLE_FIELD_MIN_WIDTH
|
65
63
|
},
|
66
64
|
{
|
67
65
|
type: AITableFieldType.link,
|
68
66
|
name: '链接',
|
69
67
|
icon: 'link-insert',
|
70
|
-
width:
|
68
|
+
width: AI_TABLE_FIELD_MIDDLE_WIDTH
|
71
69
|
},
|
72
70
|
{
|
73
71
|
type: AITableFieldType.createdBy,
|
74
72
|
name: '创建人',
|
75
73
|
icon: 'user',
|
76
|
-
width:
|
74
|
+
width: AI_TABLE_FIELD_MIN_WIDTH
|
77
75
|
},
|
78
76
|
{
|
79
77
|
type: AITableFieldType.createdAt,
|
80
78
|
name: '创建时间',
|
81
79
|
icon: 'calendar',
|
82
|
-
width:
|
80
|
+
width: AI_TABLE_FIELD_MIDDLE_WIDTH
|
83
81
|
},
|
84
82
|
{
|
85
83
|
type: AITableFieldType.updatedBy,
|
86
84
|
name: '更新人',
|
87
85
|
icon: 'user',
|
88
|
-
width:
|
86
|
+
width: AI_TABLE_FIELD_MIN_WIDTH
|
89
87
|
},
|
90
88
|
{
|
91
89
|
type: AITableFieldType.updatedAt,
|
92
90
|
name: '更新时间',
|
93
91
|
icon: 'calendar',
|
94
|
-
width:
|
92
|
+
width: AI_TABLE_FIELD_MIDDLE_WIDTH
|
95
93
|
}
|
96
94
|
];
|
97
|
-
//# sourceMappingURL=data:application/json;base64,
|
95
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmllbGQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9ncmlkL3NyYy9jb3JlL2NvbnN0YW50cy9maWVsZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXNCLGdCQUFnQixFQUFFLE1BQU0sVUFBVSxDQUFDO0FBRWhFLE1BQU0sQ0FBQyxNQUFNLHlCQUF5QixHQUFHLEdBQUcsQ0FBQztBQUM3QyxNQUFNLENBQUMsTUFBTSx3QkFBd0IsR0FBRyxHQUFHLENBQUM7QUFDNUMsTUFBTSxDQUFDLE1BQU0sMkJBQTJCLEdBQUcsR0FBRyxDQUFDO0FBQy9DLE1BQU0sQ0FBQyxNQUFNLHdCQUF3QixHQUFHLEdBQUcsQ0FBQztBQUU1QyxNQUFNLENBQUMsTUFBTSxZQUFZLEdBQXlCO0lBQzlDO1FBQ0ksSUFBSSxFQUFFLGdCQUFnQixDQUFDLElBQUk7UUFDM0IsSUFBSSxFQUFFLE1BQU07UUFDWixJQUFJLEVBQUUsTUFBTTtRQUNaLEtBQUssRUFBRSx3QkFBd0I7S0FDbEM7SUFDRCxPQUFPO0lBQ1A7UUFDSSxJQUFJLEVBQUUsZ0JBQWdCLENBQUMsTUFBTTtRQUM3QixJQUFJLEVBQUUsSUFBSTtRQUNWLElBQUksRUFBRSxjQUFjO1FBQ3BCLEtBQUssRUFBRSx3QkFBd0I7S0FDbEM7SUFDRDtRQUNJLElBQUksRUFBRSxnQkFBZ0IsQ0FBQyxNQUFNO1FBQzdCLElBQUksRUFBRSxJQUFJO1FBQ1YsSUFBSSxFQUFFLFlBQVk7UUFDbEIsS0FBSyxFQUFFLDJCQUEyQjtRQUNsQyxRQUFRLEVBQUU7WUFDTixXQUFXLEVBQUUsSUFBSTtTQUNwQjtLQUNKO0lBQ0Q7UUFDSSxJQUFJLEVBQUUsZ0JBQWdCLENBQUMsTUFBTTtRQUM3QixJQUFJLEVBQUUsSUFBSTtRQUNWLElBQUksRUFBRSxTQUFTO1FBQ2YsS0FBSyxFQUFFLHlCQUF5QjtLQUNuQztJQUNEO1FBQ0ksSUFBSSxFQUFFLGdCQUFnQixDQUFDLElBQUk7UUFDM0IsSUFBSSxFQUFFLElBQUk7UUFDVixJQUFJLEVBQUUsVUFBVTtRQUNoQixLQUFLLEVBQUUsMkJBQTJCO0tBQ3JDO0lBQ0Q7UUFDSSxJQUFJLEVBQUUsZ0JBQWdCLENBQUMsTUFBTTtRQUM3QixJQUFJLEVBQUUsSUFBSTtRQUNWLElBQUksRUFBRSxNQUFNO1FBQ1osS0FBSyxFQUFFLHdCQUF3QjtRQUMvQixRQUFRLEVBQUU7WUFDTixXQUFXLEVBQUUsS0FBSztTQUNyQjtLQUNKO0lBQ0QsT0FBTztJQUNQLE9BQU87SUFDUDtRQUNJLElBQUksRUFBRSxnQkFBZ0IsQ0FBQyxRQUFRO1FBQy9CLElBQUksRUFBRSxJQUFJO1FBQ1YsSUFBSSxFQUFFLFVBQVU7UUFDaEIsS0FBSyxFQUFFLDJCQUEyQjtLQUNyQztJQUNEO1FBQ0ksSUFBSSxFQUFFLGdCQUFnQixDQUFDLElBQUk7UUFDM0IsSUFBSSxFQUFFLElBQUk7UUFDVixJQUFJLEVBQUUsYUFBYTtRQUNuQixLQUFLLEVBQUUsd0JBQXdCO0tBQ2xDO0lBQ0Q7UUFDSSxJQUFJLEVBQUUsZ0JBQWdCLENBQUMsSUFBSTtRQUMzQixJQUFJLEVBQUUsSUFBSTtRQUNWLElBQUksRUFBRSxhQUFhO1FBQ25CLEtBQUssRUFBRSwyQkFBMkI7S0FDckM7SUFDRDtRQUNJLElBQUksRUFBRSxnQkFBZ0IsQ0FBQyxTQUFTO1FBQ2hDLElBQUksRUFBRSxLQUFLO1FBQ1gsSUFBSSxFQUFFLE1BQU07UUFDWixLQUFLLEVBQUUsd0JBQXdCO0tBQ2xDO0lBQ0Q7UUFDSSxJQUFJLEVBQUUsZ0JBQWdCLENBQUMsU0FBUztRQUNoQyxJQUFJLEVBQUUsTUFBTTtRQUNaLElBQUksRUFBRSxVQUFVO1FBQ2hCLEtBQUssRUFBRSwyQkFBMkI7S0FDckM7SUFDRDtRQUNJLElBQUksRUFBRSxnQkFBZ0IsQ0FBQyxTQUFTO1FBQ2hDLElBQUksRUFBRSxLQUFLO1FBQ1gsSUFBSSxFQUFFLE1BQU07UUFDWixLQUFLLEVBQUUsd0JBQXdCO0tBQ2xDO0lBQ0Q7UUFDSSxJQUFJLEVBQUUsZ0JBQWdCLENBQUMsU0FBUztRQUNoQyxJQUFJLEVBQUUsTUFBTTtRQUNaLElBQUksRUFBRSxVQUFVO1FBQ2hCLEtBQUssRUFBRSwyQkFBMkI7S0FDckM7Q0FDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQUlUYWJsZUZpZWxkT3B0aW9uLCBBSVRhYmxlRmllbGRUeXBlIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG5leHBvcnQgY29uc3QgQUlfVEFCTEVfRklFTERfTUlOSV9XSURUSCA9IDE0MDtcbmV4cG9ydCBjb25zdCBBSV9UQUJMRV9GSUVMRF9NSU5fV0lEVEggPSAxNjA7XG5leHBvcnQgY29uc3QgQUlfVEFCTEVfRklFTERfTUlERExFX1dJRFRIID0gMjAwO1xuZXhwb3J0IGNvbnN0IEFJX1RBQkxFX0ZJRUxEX01BWF9XSURUSCA9IDMwMDtcblxuZXhwb3J0IGNvbnN0IEZpZWxkT3B0aW9uczogQUlUYWJsZUZpZWxkT3B0aW9uW10gPSBbXG4gICAge1xuICAgICAgICB0eXBlOiBBSVRhYmxlRmllbGRUeXBlLnRleHQsXG4gICAgICAgIG5hbWU6ICfljZXooYzmlofmnKwnLFxuICAgICAgICBpY29uOiAnZm9udCcsXG4gICAgICAgIHdpZHRoOiBBSV9UQUJMRV9GSUVMRF9NQVhfV0lEVEhcbiAgICB9LFxuICAgIC8vIOWkmuihjOaWh+acrFxuICAgIHtcbiAgICAgICAgdHlwZTogQUlUYWJsZUZpZWxkVHlwZS5zZWxlY3QsXG4gICAgICAgIG5hbWU6ICfljZXpgIknLFxuICAgICAgICBpY29uOiAnY2hlY2stY2lyY2xlJyxcbiAgICAgICAgd2lkdGg6IEFJX1RBQkxFX0ZJRUxEX01JTl9XSURUSFxuICAgIH0sXG4gICAge1xuICAgICAgICB0eXBlOiBBSVRhYmxlRmllbGRUeXBlLnNlbGVjdCxcbiAgICAgICAgbmFtZTogJ+WkmumAiScsXG4gICAgICAgIGljb246ICdsaXN0LWNoZWNrJyxcbiAgICAgICAgd2lkdGg6IEFJX1RBQkxFX0ZJRUxEX01JRERMRV9XSURUSCxcbiAgICAgICAgc2V0dGluZ3M6IHtcbiAgICAgICAgICAgIGlzX211bHRpcGxlOiB0cnVlXG4gICAgICAgIH1cbiAgICB9LFxuICAgIHtcbiAgICAgICAgdHlwZTogQUlUYWJsZUZpZWxkVHlwZS5udW1iZXIsXG4gICAgICAgIG5hbWU6ICfmlbDlrZcnLFxuICAgICAgICBpY29uOiAnaGFzaHRhZycsXG4gICAgICAgIHdpZHRoOiBBSV9UQUJMRV9GSUVMRF9NSU5JX1dJRFRIXG4gICAgfSxcbiAgICB7XG4gICAgICAgIHR5cGU6IEFJVGFibGVGaWVsZFR5cGUuZGF0ZSxcbiAgICAgICAgbmFtZTogJ+aXpeacnycsXG4gICAgICAgIGljb246ICdjYWxlbmRhcicsXG4gICAgICAgIHdpZHRoOiBBSV9UQUJMRV9GSUVMRF9NSURETEVfV0lEVEhcbiAgICB9LFxuICAgIHtcbiAgICAgICAgdHlwZTogQUlUYWJsZUZpZWxkVHlwZS5tZW1iZXIsXG4gICAgICAgIG5hbWU6ICfmiJDlkZgnLFxuICAgICAgICBpY29uOiAndXNlcicsXG4gICAgICAgIHdpZHRoOiBBSV9UQUJMRV9GSUVMRF9NSU5fV0lEVEgsXG4gICAgICAgIHNldHRpbmdzOiB7XG4gICAgICAgICAgICBpc19tdWx0aXBsZTogZmFsc2VcbiAgICAgICAgfVxuICAgIH0sXG4gICAgLy8g57qn6IGU5Y2V6YCJXG4gICAgLy8g57qn6IGU5aSa6YCJXG4gICAge1xuICAgICAgICB0eXBlOiBBSVRhYmxlRmllbGRUeXBlLnByb2dyZXNzLFxuICAgICAgICBuYW1lOiAn6L+b5bqmJyxcbiAgICAgICAgaWNvbjogJ3Byb2dyZXNzJyxcbiAgICAgICAgd2lkdGg6IEFJX1RBQkxFX0ZJRUxEX01JRERMRV9XSURUSFxuICAgIH0sXG4gICAge1xuICAgICAgICB0eXBlOiBBSVRhYmxlRmllbGRUeXBlLnJhdGUsXG4gICAgICAgIG5hbWU6ICfor4TliIYnLFxuICAgICAgICBpY29uOiAnc3Rhci1jaXJjbGUnLFxuICAgICAgICB3aWR0aDogQUlfVEFCTEVfRklFTERfTUlOX1dJRFRIXG4gICAgfSxcbiAgICB7XG4gICAgICAgIHR5cGU6IEFJVGFibGVGaWVsZFR5cGUubGluayxcbiAgICAgICAgbmFtZTogJ+mTvuaOpScsXG4gICAgICAgIGljb246ICdsaW5rLWluc2VydCcsXG4gICAgICAgIHdpZHRoOiBBSV9UQUJMRV9GSUVMRF9NSURETEVfV0lEVEhcbiAgICB9LFxuICAgIHtcbiAgICAgICAgdHlwZTogQUlUYWJsZUZpZWxkVHlwZS5jcmVhdGVkQnksXG4gICAgICAgIG5hbWU6ICfliJvlu7rkuronLFxuICAgICAgICBpY29uOiAndXNlcicsXG4gICAgICAgIHdpZHRoOiBBSV9UQUJMRV9GSUVMRF9NSU5fV0lEVEhcbiAgICB9LFxuICAgIHtcbiAgICAgICAgdHlwZTogQUlUYWJsZUZpZWxkVHlwZS5jcmVhdGVkQXQsXG4gICAgICAgIG5hbWU6ICfliJvlu7rml7bpl7QnLFxuICAgICAgICBpY29uOiAnY2FsZW5kYXInLFxuICAgICAgICB3aWR0aDogQUlfVEFCTEVfRklFTERfTUlERExFX1dJRFRIXG4gICAgfSxcbiAgICB7XG4gICAgICAgIHR5cGU6IEFJVGFibGVGaWVsZFR5cGUudXBkYXRlZEJ5LFxuICAgICAgICBuYW1lOiAn5pu05paw5Lq6JyxcbiAgICAgICAgaWNvbjogJ3VzZXInLFxuICAgICAgICB3aWR0aDogQUlfVEFCTEVfRklFTERfTUlOX1dJRFRIXG4gICAgfSxcbiAgICB7XG4gICAgICAgIHR5cGU6IEFJVGFibGVGaWVsZFR5cGUudXBkYXRlZEF0LFxuICAgICAgICBuYW1lOiAn5pu05paw5pe26Ze0JyxcbiAgICAgICAgaWNvbjogJ2NhbGVuZGFyJyxcbiAgICAgICAgd2lkdGg6IEFJX1RBQkxFX0ZJRUxEX01JRERMRV9XSURUSFxuICAgIH1cbl07XG4iXX0=
|
@@ -1,4 +1,4 @@
|
|
1
|
-
import { FieldOptions } from '../constants/field';
|
1
|
+
import { FieldOptions, AI_TABLE_FIELD_MIDDLE_WIDTH } from '../constants/field';
|
2
2
|
import { AITableFieldType } from '../types';
|
3
3
|
import { idCreator } from './id-creator';
|
4
4
|
export const isArrayField = (field) => {
|
@@ -31,11 +31,15 @@ export function createDefaultFieldName(aiTable, field) {
|
|
31
31
|
return FieldOptions[0].name;
|
32
32
|
}
|
33
33
|
export function getFieldOptionByField(field) {
|
34
|
-
|
34
|
+
let fieldOption = FieldOptions.find((item) => isSameFieldOption(item, field));
|
35
|
+
if (fieldOption && field.type === AITableFieldType.member && field.settings?.is_multiple) {
|
36
|
+
fieldOption.width = AI_TABLE_FIELD_MIDDLE_WIDTH;
|
37
|
+
}
|
38
|
+
return fieldOption;
|
35
39
|
}
|
36
40
|
export function isSameFieldOption(fieldOption, field) {
|
37
41
|
return (fieldOption.type === field.type &&
|
38
|
-
(fieldOption.type === AITableFieldType.select
|
42
|
+
(fieldOption.type === AITableFieldType.select
|
39
43
|
? !!fieldOption.settings?.is_multiple === !!field.settings?.is_multiple
|
40
44
|
: true));
|
41
45
|
}
|
@@ -43,4 +47,4 @@ export function createDefaultField(aiTable, type = AITableFieldType.text) {
|
|
43
47
|
const fieldOption = FieldOptions.find((item) => item.type === type);
|
44
48
|
return { _id: idCreator(), type, name: createDefaultFieldName(aiTable, fieldOption) };
|
45
49
|
}
|
46
|
-
//# sourceMappingURL=data:application/json;base64,
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmllbGQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9ncmlkL3NyYy9jb3JlL3V0aWxzL2ZpZWxkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUMvRSxPQUFPLEVBQTZDLGdCQUFnQixFQUE4QixNQUFNLFVBQVUsQ0FBQztBQUNuSCxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sY0FBYyxDQUFDO0FBRXpDLE1BQU0sQ0FBQyxNQUFNLFlBQVksR0FBRyxDQUFDLEtBQW1CLEVBQUUsRUFBRTtJQUNoRCxPQUFPLENBQ0gsQ0FBQyxnQkFBZ0IsQ0FBQyxNQUFNLEVBQUUsZ0JBQWdCLENBQUMsU0FBUyxFQUFFLGdCQUFnQixDQUFDLFNBQVMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDO1FBQ3RHLGdCQUFnQixDQUFDLE1BQU0sS0FBSyxLQUFLLENBQUMsSUFBSSxDQUN6QyxDQUFDO0FBQ04sQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sYUFBYSxHQUFHLENBQUMsS0FBbUIsRUFBRSxFQUFFO0lBQ2pELE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxTQUFTLEVBQUUsZ0JBQWdCLENBQUMsU0FBUyxFQUFFLGdCQUFnQixDQUFDLFNBQVMsRUFBRSxnQkFBZ0IsQ0FBQyxTQUFTLENBQUMsQ0FBQyxRQUFRLENBQzVILEtBQUssQ0FBQyxJQUFJLENBQ2IsQ0FBQztBQUNOLENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGFBQWEsR0FBRyxDQUFDLEtBQW1CLEVBQUUsRUFBRTtJQUNqRCxPQUFPLENBQUMsZ0JBQWdCLENBQUMsTUFBTSxFQUFFLGdCQUFnQixDQUFDLFFBQVEsRUFBRSxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDO0FBQzVHLENBQUMsQ0FBQztBQUVGLE1BQU0sVUFBVSxvQkFBb0IsQ0FBQyxLQUFtQjtJQUNwRCxJQUFJLFlBQVksQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDO1FBQ3RCLE9BQU8sRUFBRSxDQUFDO0lBQ2QsQ0FBQztJQUNELElBQUksYUFBYSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUM7UUFDdkIsT0FBTyxJQUFJLENBQUM7SUFDaEIsQ0FBQztJQUNELE9BQU8sRUFBRSxDQUFDO0FBQ2QsQ0FBQztBQUVELE1BQU0sVUFBVSxzQkFBc0IsQ0FBQyxPQUFnQixFQUFFLEtBQXlCO0lBQzlFLE1BQU0sV0FBVyxHQUFHLHFCQUFxQixDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2pELElBQUksV0FBVyxFQUFFLENBQUM7UUFDZCxNQUFNLEtBQUssR0FBRyxPQUFPLENBQUMsTUFBTSxFQUFFLENBQUMsTUFBTSxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUU7WUFDM0MsT0FBTyxpQkFBaUIsQ0FBQyxLQUFLLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFDMUMsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDO1FBQ1YsT0FBTyxLQUFLLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxXQUFXLENBQUMsSUFBSSxHQUFHLEdBQUcsR0FBRyxLQUFLLENBQUM7SUFDM0UsQ0FBQztJQUNELE9BQU8sWUFBWSxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQztBQUNoQyxDQUFDO0FBRUQsTUFBTSxVQUFVLHFCQUFxQixDQUFDLEtBQTRCO0lBQzlELElBQUksV0FBVyxHQUFHLFlBQVksQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLGlCQUFpQixDQUFDLElBQUksRUFBRSxLQUFLLENBQUMsQ0FBQyxDQUFDO0lBQzlFLElBQUksV0FBVyxJQUFJLEtBQUssQ0FBQyxJQUFJLEtBQUssZ0JBQWdCLENBQUMsTUFBTSxJQUFLLEtBQUssQ0FBQyxRQUEyQixFQUFFLFdBQVcsRUFBRSxDQUFDO1FBQzNHLFdBQVcsQ0FBQyxLQUFLLEdBQUcsMkJBQTJCLENBQUM7SUFDcEQsQ0FBQztJQUNELE9BQU8sV0FBVyxDQUFDO0FBQ3ZCLENBQUM7QUFFRCxNQUFNLFVBQVUsaUJBQWlCLENBQUMsV0FBK0IsRUFBRSxLQUE0QjtJQUMzRixPQUFPLENBQ0gsV0FBVyxDQUFDLElBQUksS0FBSyxLQUFLLENBQUMsSUFBSTtRQUMvQixDQUFDLFdBQVcsQ0FBQyxJQUFJLEtBQUssZ0JBQWdCLENBQUMsTUFBTTtZQUN6QyxDQUFDLENBQUMsQ0FBQyxDQUFFLFdBQVcsQ0FBQyxRQUF1QixFQUFFLFdBQVcsS0FBSyxDQUFDLENBQUUsS0FBSyxDQUFDLFFBQXVCLEVBQUUsV0FBVztZQUN2RyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQ2QsQ0FBQztBQUNOLENBQUM7QUFFRCxNQUFNLFVBQVUsa0JBQWtCLENBQUMsT0FBZ0IsRUFBRSxPQUF5QixnQkFBZ0IsQ0FBQyxJQUFJO0lBQy9GLE1BQU0sV0FBVyxHQUFHLFlBQVksQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxJQUFJLEtBQUssSUFBSSxDQUFFLENBQUM7SUFDckUsT0FBTyxFQUFFLEdBQUcsRUFBRSxTQUFTLEVBQUUsRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLHNCQUFzQixDQUFDLE9BQU8sRUFBRSxXQUFXLENBQUMsRUFBRSxDQUFDO0FBQzFGLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGaWVsZE9wdGlvbnMsIEFJX1RBQkxFX0ZJRUxEX01JRERMRV9XSURUSCB9IGZyb20gJy4uL2NvbnN0YW50cy9maWVsZCc7XG5pbXBvcnQgeyBBSVRhYmxlLCBBSVRhYmxlRmllbGQsIEFJVGFibGVGaWVsZE9wdGlvbiwgQUlUYWJsZUZpZWxkVHlwZSwgSXNNdWx0aXBsZSwgTWVtYmVyU2V0dGluZ3MgfSBmcm9tICcuLi90eXBlcyc7XG5pbXBvcnQgeyBpZENyZWF0b3IgfSBmcm9tICcuL2lkLWNyZWF0b3InO1xuXG5leHBvcnQgY29uc3QgaXNBcnJheUZpZWxkID0gKGZpZWxkOiBBSVRhYmxlRmllbGQpID0+IHtcbiAgICByZXR1cm4gKFxuICAgICAgICBbQUlUYWJsZUZpZWxkVHlwZS5tZW1iZXIsIEFJVGFibGVGaWVsZFR5cGUuY3JlYXRlZEJ5LCBBSVRhYmxlRmllbGRUeXBlLnVwZGF0ZWRCeV0uaW5jbHVkZXMoZmllbGQudHlwZSkgfHxcbiAgICAgICAgQUlUYWJsZUZpZWxkVHlwZS5zZWxlY3QgPT09IGZpZWxkLnR5cGVcbiAgICApO1xufTtcblxuZXhwb3J0IGNvbnN0IGlzU3lzdGVtRmllbGQgPSAoZmllbGQ6IEFJVGFibGVGaWVsZCkgPT4ge1xuICAgIHJldHVybiBbQUlUYWJsZUZpZWxkVHlwZS5jcmVhdGVkQXQsIEFJVGFibGVGaWVsZFR5cGUuY3JlYXRlZEJ5LCBBSVRhYmxlRmllbGRUeXBlLnVwZGF0ZWRBdCwgQUlUYWJsZUZpZWxkVHlwZS51cGRhdGVkQnldLmluY2x1ZGVzKFxuICAgICAgICBmaWVsZC50eXBlXG4gICAgKTtcbn07XG5cbmV4cG9ydCBjb25zdCBpc051bWJlckZpbGVkID0gKGZpZWxkOiBBSVRhYmxlRmllbGQpID0+IHtcbiAgICByZXR1cm4gW0FJVGFibGVGaWVsZFR5cGUubnVtYmVyLCBBSVRhYmxlRmllbGRUeXBlLnByb2dyZXNzLCBBSVRhYmxlRmllbGRUeXBlLnJhdGVdLmluY2x1ZGVzKGZpZWxkLnR5cGUpO1xufTtcblxuZXhwb3J0IGZ1bmN0aW9uIGdldERlZmF1bHRGaWVsZFZhbHVlKGZpZWxkOiBBSVRhYmxlRmllbGQpIHtcbiAgICBpZiAoaXNBcnJheUZpZWxkKGZpZWxkKSkge1xuICAgICAgICByZXR1cm4gW107XG4gICAgfVxuICAgIGlmIChpc051bWJlckZpbGVkKGZpZWxkKSkge1xuICAgICAgICByZXR1cm4gbnVsbDtcbiAgICB9XG4gICAgcmV0dXJuICcnO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlRGVmYXVsdEZpZWxkTmFtZShhaVRhYmxlOiBBSVRhYmxlLCBmaWVsZDogQUlUYWJsZUZpZWxkT3B0aW9uKSB7XG4gICAgY29uc3QgZmllbGRPcHRpb24gPSBnZXRGaWVsZE9wdGlvbkJ5RmllbGQoZmllbGQpO1xuICAgIGlmIChmaWVsZE9wdGlvbikge1xuICAgICAgICBjb25zdCBjb3VudCA9IGFpVGFibGUuZmllbGRzKCkuZmlsdGVyKChpdGVtKSA9PiB7XG4gICAgICAgICAgICByZXR1cm4gaXNTYW1lRmllbGRPcHRpb24oZmllbGQsIGl0ZW0pO1xuICAgICAgICB9KS5sZW5ndGg7XG4gICAgICAgIHJldHVybiBjb3VudCA9PT0gMCA/IGZpZWxkT3B0aW9uLm5hbWUgOiBmaWVsZE9wdGlvbi5uYW1lICsgJyAnICsgY291bnQ7XG4gICAgfVxuICAgIHJldHVybiBGaWVsZE9wdGlvbnNbMF0ubmFtZTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdldEZpZWxkT3B0aW9uQnlGaWVsZChmaWVsZDogUGFydGlhbDxBSVRhYmxlRmllbGQ+KSB7XG4gICAgbGV0IGZpZWxkT3B0aW9uID0gRmllbGRPcHRpb25zLmZpbmQoKGl0ZW0pID0+IGlzU2FtZUZpZWxkT3B0aW9uKGl0ZW0sIGZpZWxkKSk7XG4gICAgaWYgKGZpZWxkT3B0aW9uICYmIGZpZWxkLnR5cGUgPT09IEFJVGFibGVGaWVsZFR5cGUubWVtYmVyICYmIChmaWVsZC5zZXR0aW5ncyBhcyBNZW1iZXJTZXR0aW5ncyk/LmlzX211bHRpcGxlKSB7XG4gICAgICAgIGZpZWxkT3B0aW9uLndpZHRoID0gQUlfVEFCTEVfRklFTERfTUlERExFX1dJRFRIO1xuICAgIH1cbiAgICByZXR1cm4gZmllbGRPcHRpb247XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBpc1NhbWVGaWVsZE9wdGlvbihmaWVsZE9wdGlvbjogQUlUYWJsZUZpZWxkT3B0aW9uLCBmaWVsZDogUGFydGlhbDxBSVRhYmxlRmllbGQ+KTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIChcbiAgICAgICAgZmllbGRPcHRpb24udHlwZSA9PT0gZmllbGQudHlwZSAmJlxuICAgICAgICAoZmllbGRPcHRpb24udHlwZSA9PT0gQUlUYWJsZUZpZWxkVHlwZS5zZWxlY3RcbiAgICAgICAgICAgID8gISEoZmllbGRPcHRpb24uc2V0dGluZ3MgYXMgSXNNdWx0aXBsZSk/LmlzX211bHRpcGxlID09PSAhIShmaWVsZC5zZXR0aW5ncyBhcyBJc011bHRpcGxlKT8uaXNfbXVsdGlwbGVcbiAgICAgICAgICAgIDogdHJ1ZSlcbiAgICApO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlRGVmYXVsdEZpZWxkKGFpVGFibGU6IEFJVGFibGUsIHR5cGU6IEFJVGFibGVGaWVsZFR5cGUgPSBBSVRhYmxlRmllbGRUeXBlLnRleHQpIHtcbiAgICBjb25zdCBmaWVsZE9wdGlvbiA9IEZpZWxkT3B0aW9ucy5maW5kKChpdGVtKSA9PiBpdGVtLnR5cGUgPT09IHR5cGUpITtcbiAgICByZXR1cm4geyBfaWQ6IGlkQ3JlYXRvcigpLCB0eXBlLCBuYW1lOiBjcmVhdGVEZWZhdWx0RmllbGROYW1lKGFpVGFibGUsIGZpZWxkT3B0aW9uKSB9O1xufVxuIl19
|