@ai-table/grid 0.0.64 → 0.0.65

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.
@@ -1 +1 @@
1
- {"version":3,"file":"drag.component.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/components/drag/drag.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAA8C,UAAU,EAAU,SAAS,EAAE,MAAM,EAAqB,MAAM,eAAe,CAAC;AACrI,OAAO,EAAoB,WAAW,EAAY,MAAM,YAAY,CAAC;;AAKrE,qBASa,oBAAqB,YAAW,MAAM,EAAE,SAAS;IAC1D,OAAO,wDAAyB;IAEhC,OAAO,CAAC,2BAA2B,CAAuC;IAE1E,OAAO,CAAC,OAAO,CAAqB;IAEpC,UAAU,EAAE,UAAU,CAAC,WAAW,CAAC,CAAmC;IAEtE,OAAO,CAAC,IAAI,CAAe;IAE3B,OAAO,CAAC,aAAa,CAAe;IAEpC,OAAO,CAAC,WAAW,CAA4B;IAE/C,OAAO,CAAC,kBAAkB,CAAyC;IAEnE,OAAO,CAAC,WAAW,CAAiC;IAEpD,OAAO,CAAC,KAAK,CAAiB;IAE9B,OAAO,CAAC,gBAAgB,CAAa;IAErC,OAAO,CAAC,iBAAiB,CAAkB;IAE3C,OAAO,CAAC,iBAAiB,CAAC,CAAa;IACvC,OAAO,CAAC,iBAAiB,CAAC,CAAa;IACvC,OAAO,CAAC,eAAe,CAAC,CAAa;;IAMrC,QAAQ;IAKR,OAAO,CAAC,YAAY;IAKpB,OAAO,CAAC,mBAAmB;IAwC3B,OAAO,CAAC,qBAAqB;IAe7B,OAAO,CAAC,UAAU;IAoBlB,OAAO,CAAC,YAAY;IA6DpB,OAAO,CAAC,iBAAiB;IAwBzB,OAAO,CAAC,YAAY;IA6CpB,OAAO,CAAC,aAAa;IAOrB,OAAO,CAAC,cAAc;IAiBtB,OAAO,CAAC,kBAAkB;IAU1B,OAAO,CAAC,eAAe;IAIvB,OAAO,CAAC,cAAc;IAItB,OAAO,CAAC,aAAa;IAMrB,OAAO,CAAC,sBAAsB;IAM9B,OAAO,CAAC,kBAAkB;IAI1B,WAAW;yCAlTF,oBAAoB;2CAApB,oBAAoB;CA4ThC"}
1
+ {"version":3,"file":"drag.component.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/components/drag/drag.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAA8C,UAAU,EAAU,SAAS,EAAE,MAAM,EAAqB,MAAM,eAAe,CAAC;AACrI,OAAO,EAAoB,WAAW,EAAY,MAAM,YAAY,CAAC;;AAKrE,qBASa,oBAAqB,YAAW,MAAM,EAAE,SAAS;IAC1D,OAAO,wDAAyB;IAEhC,OAAO,CAAC,2BAA2B,CAAuC;IAE1E,OAAO,CAAC,OAAO,CAAqB;IAEpC,UAAU,EAAE,UAAU,CAAC,WAAW,CAAC,CAAmC;IAEtE,OAAO,CAAC,IAAI,CAAe;IAE3B,OAAO,CAAC,aAAa,CAAe;IAEpC,OAAO,CAAC,WAAW,CAA4B;IAE/C,OAAO,CAAC,kBAAkB,CAAyC;IAEnE,OAAO,CAAC,WAAW,CAAiC;IAEpD,OAAO,CAAC,KAAK,CAAiB;IAE9B,OAAO,CAAC,gBAAgB,CAAa;IAErC,OAAO,CAAC,iBAAiB,CAAkB;IAE3C,OAAO,CAAC,iBAAiB,CAAC,CAAa;IACvC,OAAO,CAAC,iBAAiB,CAAC,CAAa;IACvC,OAAO,CAAC,eAAe,CAAC,CAAa;;IAMrC,QAAQ;IAKR,OAAO,CAAC,YAAY;IAKpB,OAAO,CAAC,mBAAmB;IAwC3B,OAAO,CAAC,qBAAqB;IAe7B,OAAO,CAAC,UAAU;IAoBlB,OAAO,CAAC,YAAY;IAoEpB,OAAO,CAAC,iBAAiB;IAwBzB,OAAO,CAAC,YAAY;IA6CpB,OAAO,CAAC,aAAa;IAOrB,OAAO,CAAC,cAAc;IAiBtB,OAAO,CAAC,kBAAkB;IAU1B,OAAO,CAAC,eAAe;IAIvB,OAAO,CAAC,cAAc;IAItB,OAAO,CAAC,aAAa;IAMrB,OAAO,CAAC,sBAAsB;IAM9B,OAAO,CAAC,kBAAkB;IAI1B,WAAW;yCAzTF,oBAAoB;2CAApB,oBAAoB;CAmUhC"}
@@ -22,6 +22,7 @@ export declare class AITableFieldSetting implements OnInit {
22
22
  fieldOptions: import("@angular/core").Signal<AITableFieldOption[]>;
23
23
  aITableFieldType: typeof AITableFieldType;
24
24
  isMultipleMember: boolean;
25
+ private isManualInputName;
25
26
  protected thyPopoverRef: ThyPopoverRef<any, any, any>;
26
27
  ngOnInit(): void;
27
28
  checkUniqueName: (fieldName: string) => import("rxjs").Observable<boolean>;
@@ -29,6 +30,7 @@ export declare class AITableFieldSetting implements OnInit {
29
30
  editFieldProperty(): void;
30
31
  multipleMemberChange(): void;
31
32
  fieldTypeClick(e: Event): void;
33
+ nameChange(event: Event): void;
32
34
  cancel(): void;
33
35
  i18nTexts: import("@angular/core").Signal<{
34
36
  columnName: string;
@@ -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,EAGH,MAAM,EACN,WAAW,EAOd,MAAM,eAAe,CAAC;AAevB,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAGnD,OAAO,EACH,OAAO,EACP,YAAY,EACZ,kBAAkB,EAGlB,eAAe,EACf,gBAAgB,EAGnB,MAAM,YAAY,CAAC;;AAKpB,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;;;;;;;OASZ;IAEH,YAAY,uDAET;IAEH,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;IAazC,iBAAiB;IAYjB,oBAAoB;IAUpB,cAAc,CAAC,CAAC,EAAE,KAAK;IAKvB,MAAM;IAIN,SAAS;;;;;;;OASN;yCA3GM,mBAAmB;2CAAnB,mBAAmB;CA4G/B"}
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,EAQd,MAAM,eAAe,CAAC;AAevB,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAGnD,OAAO,EACH,OAAO,EACP,YAAY,EACZ,kBAAkB,EAGlB,eAAe,EACf,gBAAgB,EAGnB,MAAM,YAAY,CAAC;;AAKpB,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;;;;;;;OASZ;IAEH,YAAY,uDAET;IAEH,gBAAgB,0BAAoB;IAEpC,gBAAgB,UAAS;IAEzB,OAAO,CAAC,iBAAiB,CAAiB;IAE1C,SAAS,CAAC,aAAa,+BAA8C;IAErE,QAAQ,IAAI,IAAI;IAKhB,eAAe,cAAe,MAAM,wCAOlC;IAEF,eAAe,CAAC,KAAK,EAAE,kBAAkB;IAazC,iBAAiB;IAYjB,oBAAoB;IAUpB,cAAc,CAAC,CAAC,EAAE,KAAK;IAKvB,UAAU,CAAC,KAAK,EAAE,KAAK;IAIvB,MAAM;IAIN,SAAS;;;;;;;OASN;yCAjHM,mBAAmB;2CAAnB,mBAAmB;CAkH/B"}
@@ -28,7 +28,7 @@ export class SelectCellEditorComponent extends AbstractEditCellEditor {
28
28
  this.modelValue = computed(() => {
29
29
  const value = AITableQueries.getFieldValue(this.aiTable, [this.record()._id, this.field()._id]);
30
30
  if (!this.isMultiple) {
31
- return value[0];
31
+ return value?.length > 0 ? value[0] : null;
32
32
  }
33
33
  return value || [];
34
34
  })();
@@ -70,4 +70,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
70
70
  ThySelectModule
71
71
  ], template: "<thy-select\n [(ngModel)]=\"modelValue\"\n [thyAutoExpand]=\"true\"\n [thyAllowClear]=\"true\"\n [thyPlaceHolder]=\"''\"\n [thyPreset]=\"preset()\"\n [thyMode]=\"field().settings.is_multiple ? 'multiple' : ''\"\n (ngModelChange)=\"onModelChange($event)\"\n (thyOnExpandStatusChange)=\"onOpenChange($event)\"\n>\n <ng-template #selectedDisplay let-option>\n <select-option [field]=\"field()\" [displayOption]=\"option\"></select-option>\n </ng-template>\n @for (option of selectOptions(); track option._id) {\n <thy-option [thyValue]=\"option._id\" [thyRawValue]=\"option\" [thyShowOptionCustom]=\"true\" [thyLabelText]=\"option.text\">\n <select-option [field]=\"field()\" [displayOption]=\"option\"></select-option>\n </thy-option>\n }\n</thy-select>\n" }]
72
72
  }], ctorParameters: () => [] });
73
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-editor.component.js","sourceRoot":"","sources":["../../../../../../packages/grid/src/components/cell-editors/select/select-editor.component.ts","../../../../../../packages/grid/src/components/cell-editors/select/select-editor.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAC7E,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAC/D,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAC9C,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACtD,OAAO,EAAE,cAAc,EAAE,wBAAwB,EAAE,MAAM,eAAe,CAAC;AAEzE,OAAO,EAAE,qBAAqB,EAAE,MAAM,0CAA0C,CAAC;AACjF,OAAO,EAAE,sBAAsB,EAAE,MAAM,mCAAmC,CAAC;AAC3E,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;;;AAsBhD,MAAM,OAAO,yBAA0B,SAAQ,sBAA6D;IASxG,IAAI,UAAU;QACV,OAAO,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,QAAQ,CAAC,WAAW,CAAC;IAC/C,CAAC;IAED;QACI,KAAK,EAAE,CAAC;QAbZ,kBAAa,GAAG,QAAQ,CAAC,GAAG,EAAE;YAC1B,OAAO,IAAI,CAAC,KAAK,EAAE,CAAC,QAAQ,CAAC,OAAO,CAAC;QACzC,CAAC,CAAC,CAAC;QAEH,WAAM,GAAG,QAAQ,CAAC,GAAG,EAAE;YACnB,OAAO,IAAI,CAAC,KAAK,EAAE,CAAC,QAAQ,CAAC,WAAW,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC,QAAQ,CAAC,YAAY,KAAK,wBAAwB,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;QACjI,CAAC,CAAC,CAAC;IAQH,CAAC;IAEQ,QAAQ;QACb,IAAI,CAAC,UAAU,GAAG,QAAQ,CAAC,GAAG,EAAE;YAC5B,MAAM,KAAK,GAAG,cAAc,CAAC,aAAa,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;YAChG,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC;gBACnB,OAAO,KAAK,CAAC,CAAC,CAAC,CAAC;YACpB,CAAC;YACD,OAAO,KAAK,IAAI,EAAE,CAAC;QACvB,CAAC,CAAC,EAAE,CAAC;IACT,CAAC;IAED,YAAY,CAAC,KAAc;QACvB,IAAI,CAAC,KAAK,EAAE,CAAC;YACT,IAAI,CAAC,YAAY,EAAE,CAAC;QACxB,CAAC;IACL,CAAC;IAED,aAAa,CAAC,KAAU;QACpB,IAAI,CAAC,aAAa,EAAE,CAAC;IACzB,CAAC;IAED,aAAa;QACT,MAAM,KAAK,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,IAAK,CAAC,IAAI,CAAC,UAAU,CAAc,CAAC,IAAI,EAAE,CAAa,CAAC;QAC3H,MAAM,WAAW,GAAG,cAAc,CAAC,aAAa,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,GAAG,CAAC,CAAa,CAAC;QAClH,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,WAAW,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,MAAM,KAAK,WAAW,CAAC,MAAM,EAAE,CAAC;YACtF,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC;gBACvB,KAAK,EAAE,KAAK;gBACZ,IAAI,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,GAAG,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,GAAG,CAAC;aAC9C,CAAC,CAAC;QACP,CAAC;IACL,CAAC;+GA9CQ,yBAAyB;mGAAzB,yBAAyB,mKCjCtC,uzBAmBA,4CDGQ,SAAS,ymBACT,SAAS,gNACT,gBAAgB,+BAChB,qBAAqB,6FACrB,YAAY,8BACZ,cAAc,8BACd,aAAa,8BACb,WAAW,8VACX,eAAe;;4FAGV,yBAAyB;kBApBrC,SAAS;+BACI,oBAAoB,cAElB,IAAI,mBACC,uBAAuB,CAAC,MAAM,QACzC;wBACF,KAAK,EAAE,kCAAkC;qBAC5C,WACQ;wBACL,SAAS;wBACT,SAAS;wBACT,gBAAgB;wBAChB,qBAAqB;wBACrB,YAAY;wBACZ,cAAc;wBACd,aAAa;wBACb,WAAW;wBACX,eAAe;qBAClB","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, computed } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { ThyEmptyModule } from 'ngx-tethys/empty';\nimport { ThySelect, ThySelectModule } from 'ngx-tethys/select';\nimport { ThyOption } from 'ngx-tethys/shared';\nimport { ThyTooltipModule } from 'ngx-tethys/tooltip';\nimport { AITableQueries, AITableSelectOptionStyle } from '../../../core';\nimport { AITableSelectField } from '../../../types';\nimport { SelectOptionComponent } from '../../cell-views/select/option.component';\nimport { AbstractEditCellEditor } from '../abstract-cell-editor.component';\nimport { ThyFormModule } from 'ngx-tethys/form';\n\n@Component({\n    selector: 'select-cell-editor',\n    templateUrl: './select-editor.component.html',\n    standalone: true,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        class: 'd-block h-100 select-cell-editor'\n    },\n    imports: [\n        ThySelect,\n        ThyOption,\n        ThyTooltipModule,\n        SelectOptionComponent,\n        CommonModule,\n        ThyEmptyModule,\n        ThyFormModule,\n        FormsModule,\n        ThySelectModule\n    ]\n})\nexport class SelectCellEditorComponent extends AbstractEditCellEditor<string[] | string, AITableSelectField> {\n    selectOptions = computed(() => {\n        return this.field().settings.options;\n    });\n\n    preset = computed(() => {\n        return this.field().settings.is_multiple && this.field().settings.option_style === AITableSelectOptionStyle.tag ? 'tag' : '';\n    });\n\n    get isMultiple() {\n        return !!this.field().settings.is_multiple;\n    }\n\n    constructor() {\n        super();\n    }\n\n    override ngOnInit(): void {\n        this.modelValue = computed(() => {\n            const value = AITableQueries.getFieldValue(this.aiTable, [this.record()._id, this.field()._id]);\n            if (!this.isMultiple) {\n                return value[0];\n            }\n            return value || [];\n        })();\n    }\n\n    onOpenChange(value: boolean) {\n        if (!value) {\n            this.closePopover();\n        }\n    }\n\n    onModelChange(event: any) {\n        this.updateValueFn();\n    }\n\n    updateValueFn() {\n        const value = (this.isMultiple ? this.modelValue : (this.modelValue && ([this.modelValue] as string[])) || []) as string[];\n        const originValue = AITableQueries.getFieldValue(this.aiTable, [this.record()._id, this.field()._id]) as string[];\n        if (!value.every((v, i) => v === originValue[i]) || value.length !== originValue.length) {\n            this.updateFieldValue.emit({\n                value: value,\n                path: [this.record()._id, this.field()._id]\n            });\n        }\n    }\n}\n","<thy-select\n    [(ngModel)]=\"modelValue\"\n    [thyAutoExpand]=\"true\"\n    [thyAllowClear]=\"true\"\n    [thyPlaceHolder]=\"''\"\n    [thyPreset]=\"preset()\"\n    [thyMode]=\"field().settings.is_multiple ? 'multiple' : ''\"\n    (ngModelChange)=\"onModelChange($event)\"\n    (thyOnExpandStatusChange)=\"onOpenChange($event)\"\n>\n    <ng-template #selectedDisplay let-option>\n        <select-option [field]=\"field()\" [displayOption]=\"option\"></select-option>\n    </ng-template>\n    @for (option of selectOptions(); track option._id) {\n        <thy-option [thyValue]=\"option._id\" [thyRawValue]=\"option\" [thyShowOptionCustom]=\"true\" [thyLabelText]=\"option.text\">\n            <select-option [field]=\"field()\" [displayOption]=\"option\"></select-option>\n        </thy-option>\n    }\n</thy-select>\n"]}
73
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-editor.component.js","sourceRoot":"","sources":["../../../../../../packages/grid/src/components/cell-editors/select/select-editor.component.ts","../../../../../../packages/grid/src/components/cell-editors/select/select-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, computed } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { ThyEmptyModule } from 'ngx-tethys/empty';\nimport { ThySelect, ThySelectModule } from 'ngx-tethys/select';\nimport { ThyOption } from 'ngx-tethys/shared';\nimport { ThyTooltipModule } from 'ngx-tethys/tooltip';\nimport { AITableQueries, AITableSelectOptionStyle } from '../../../core';\nimport { AITableSelectField } from '../../../types';\nimport { SelectOptionComponent } from '../../cell-views/select/option.component';\nimport { AbstractEditCellEditor } from '../abstract-cell-editor.component';\nimport { ThyFormModule } from 'ngx-tethys/form';\n\n@Component({\n    selector: 'select-cell-editor',\n    templateUrl: './select-editor.component.html',\n    standalone: true,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        class: 'd-block h-100 select-cell-editor'\n    },\n    imports: [\n        ThySelect,\n        ThyOption,\n        ThyTooltipModule,\n        SelectOptionComponent,\n        CommonModule,\n        ThyEmptyModule,\n        ThyFormModule,\n        FormsModule,\n        ThySelectModule\n    ]\n})\nexport class SelectCellEditorComponent extends AbstractEditCellEditor<string[] | string, AITableSelectField> {\n    selectOptions = computed(() => {\n        return this.field().settings.options;\n    });\n\n    preset = computed(() => {\n        return this.field().settings.is_multiple && this.field().settings.option_style === AITableSelectOptionStyle.tag ? 'tag' : '';\n    });\n\n    get isMultiple() {\n        return !!this.field().settings.is_multiple;\n    }\n\n    constructor() {\n        super();\n    }\n\n    override ngOnInit(): void {\n        this.modelValue = computed(() => {\n            const value = AITableQueries.getFieldValue(this.aiTable, [this.record()._id, this.field()._id]);\n            if (!this.isMultiple) {\n                return value?.length > 0 ? value[0] : null;\n            }\n            return value || [];\n        })();\n    }\n\n    onOpenChange(value: boolean) {\n        if (!value) {\n            this.closePopover();\n        }\n    }\n\n    onModelChange(event: any) {\n        this.updateValueFn();\n    }\n\n    updateValueFn() {\n        const value = (this.isMultiple ? this.modelValue : (this.modelValue && ([this.modelValue] as string[])) || []) as string[];\n        const originValue = AITableQueries.getFieldValue(this.aiTable, [this.record()._id, this.field()._id]) as string[];\n        if (!value.every((v, i) => v === originValue[i]) || value.length !== originValue.length) {\n            this.updateFieldValue.emit({\n                value: value,\n                path: [this.record()._id, this.field()._id]\n            });\n        }\n    }\n}\n","<thy-select\n    [(ngModel)]=\"modelValue\"\n    [thyAutoExpand]=\"true\"\n    [thyAllowClear]=\"true\"\n    [thyPlaceHolder]=\"''\"\n    [thyPreset]=\"preset()\"\n    [thyMode]=\"field().settings.is_multiple ? 'multiple' : ''\"\n    (ngModelChange)=\"onModelChange($event)\"\n    (thyOnExpandStatusChange)=\"onOpenChange($event)\"\n>\n    <ng-template #selectedDisplay let-option>\n        <select-option [field]=\"field()\" [displayOption]=\"option\"></select-option>\n    </ng-template>\n    @for (option of selectOptions(); track option._id) {\n        <thy-option [thyValue]=\"option._id\" [thyRawValue]=\"option\" [thyShowOptionCustom]=\"true\" [thyLabelText]=\"option.text\">\n            <select-option [field]=\"field()\" [displayOption]=\"option\"></select-option>\n        </thy-option>\n    }\n</thy-select>\n"]}
@@ -2,7 +2,7 @@ import { ChangeDetectionStrategy, Component, effect, ElementRef, inject, output,
2
2
  import { DragType } from '../../core';
3
3
  import { AITableGridSelectionService } from '../../services/selection.service';
4
4
  import { MIN_COLUMN_WIDTH } from '../../constants/grid';
5
- import { AI_TABLE_FIELD_HEAD_HEIGHT, AI_TABLE_ROW_DRAG_ICON_WIDTH } from '../../constants/table';
5
+ import { AI_TABLE_FIELD_HEAD_HEIGHT, AI_TABLE_ROW_DRAG_ICON_WIDTH, AI_TABLE_ROW_HEAD_WIDTH } from '../../constants/table';
6
6
  import * as i0 from "@angular/core";
7
7
  export class AITableDragComponent {
8
8
  constructor() {
@@ -102,6 +102,7 @@ export class AITableDragComponent {
102
102
  const sourceColumnWidth = coordinate.getColumnWidth(sourceColumnIndex);
103
103
  // TODO: 目前默认第一列为冻结列,后期支持设置冻结列需要处理
104
104
  const isSourceColumnFrozen = sourceColumnIndex === 0;
105
+ const frozenColumnWidth = coordinate.getColumnWidth(0);
105
106
  const pointerX = moveX + sourceColumnStartX;
106
107
  // 拖拽中心点
107
108
  const dragCenter = sourceColumnWidth / 2;
@@ -125,22 +126,28 @@ export class AITableDragComponent {
125
126
  }
126
127
  if ((targetColumnIndex >= 0 && (targetColumnIndex - sourceColumnIndex > 1 || targetColumnIndex - sourceColumnIndex < 0)) ||
127
128
  isLastColumn) {
129
+ let lineLeft = targetColumnStartX - scroll.x;
130
+ const lineForFrozenX = lineLeft - frozenColumnWidth - AI_TABLE_ROW_HEAD_WIDTH;
131
+ if (lineForFrozenX < 0) {
132
+ lineLeft = coordinate.getColumnOffset(0);
133
+ targetColumnIndex = 0;
134
+ }
128
135
  this.setAuxiliaryLineStyles({
129
136
  width: '2px',
130
137
  height: '100%',
131
138
  top: 0,
132
- left: `${targetColumnStartX - scroll.x}px`
133
- });
134
- const fieldsIndex = [];
135
- drag.sourceIds.forEach((id) => {
136
- const index = visibleColumnIndexMap.get(id) || 0;
137
- fieldsIndex.push(index);
139
+ left: `${lineLeft}px`
138
140
  });
139
141
  // 向右移动目标在目标列的前一列
140
142
  if (targetColumnIndex > sourceColumnIndex) {
141
143
  targetColumnIndex -= 1;
142
144
  }
143
- this.draggedData = { type: DragType.field, targetIndex: targetColumnIndex, fieldIds: drag.sourceIds, fieldsIndex };
145
+ this.draggedData = {
146
+ type: DragType.field,
147
+ targetIndex: targetColumnIndex,
148
+ fieldIds: drag.sourceIds,
149
+ fieldsIndex: Array.from(drag.sourceIds).map((id) => visibleColumnIndexMap.get(id) || 0)
150
+ };
144
151
  }
145
152
  else {
146
153
  this.resetAuxiliaryLine();
@@ -283,4 +290,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
283
290
  class: 'drag-container'
284
291
  }, template: "<div class=\"rect\"></div>\n<div class=\"auxiliary-line\"></div>" }]
285
292
  }], ctorParameters: () => [] });
286
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drag.component.js","sourceRoot":"","sources":["../../../../../packages/grid/src/components/drag/drag.component.ts","../../../../../packages/grid/src/components/drag/drag.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, effect, ElementRef, inject, OnDestroy, OnInit, output, Renderer2 } from '@angular/core';\nimport { AITableDragState, DragEndData, DragType } from '../../core';\nimport { AITableGridSelectionService } from '../../services/selection.service';\nimport { MIN_COLUMN_WIDTH } from '../../constants/grid';\nimport { AI_TABLE_FIELD_HEAD_HEIGHT, AI_TABLE_ROW_DRAG_ICON_WIDTH } from '../../constants/table';\n\n@Component({\n    selector: 'ai-table-drag',\n    templateUrl: './drag.component.html',\n    standalone: true,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        class: 'drag-container'\n    }\n})\nexport class AITableDragComponent implements OnInit, OnDestroy {\n    dragEnd = output<DragEndData>();\n\n    private aiTableGridSelectionService = inject(AITableGridSelectionService);\n\n    private render2 = inject(Renderer2);\n\n    elementRef: ElementRef<HTMLElement> = inject(ElementRef<HTMLElement>);\n\n    private rect!: HTMLElement;\n\n    private auxiliaryLine!: HTMLElement;\n\n    private draggedData: DragEndData | null = null;\n\n    private mouseStartPosition: { x: number; y: number } | null = null;\n\n    private aiTableDrag: AITableDragState | null = null;\n\n    private timer!: number | null;\n\n    private mouseDownTimeout: any = null;\n\n    private isDraggingEnabled: boolean = false;\n\n    private mousedownListener?: () => void;\n    private mousemoveListener?: () => void;\n    private mouseupListener?: () => void;\n\n    constructor() {\n        effect(() => this.handleDragStateChange());\n    }\n\n    ngOnInit() {\n        this.initElements();\n        this.setupEventListeners();\n    }\n\n    private initElements(): void {\n        this.rect = this.elementRef.nativeElement.querySelector('.rect')!;\n        this.auxiliaryLine = this.elementRef.nativeElement.querySelector('.auxiliary-line')!;\n    }\n\n    private setupEventListeners(): void {\n        this.mousedownListener = this.render2.listen('window', 'mousedown', (e: MouseEvent) => {\n            this.mouseStartPosition = { x: e.x, y: e.y };\n\n            if (this.mouseDownTimeout) {\n                clearTimeout(this.mouseDownTimeout);\n            }\n            this.isDraggingEnabled = false;\n            this.mouseDownTimeout = setTimeout(() => {\n                this.isDraggingEnabled = true;\n            }, 200);\n        });\n\n        this.mousemoveListener = this.render2.listen('window', 'mousemove', (e: MouseEvent) => {\n            if (!this.isDraggingEnabled) {\n                return;\n            }\n            if (this.timer) {\n                cancelAnimationFrame(this.timer);\n            }\n            this.timer = requestAnimationFrame(() => {\n                if (this.aiTableDrag && this.mouseStartPosition) {\n                    this.handleDrag(e, this.aiTableDrag);\n                }\n            });\n        });\n\n        this.mouseupListener = this.render2.listen('window', 'mouseup', () => {\n            if (this.mouseDownTimeout) {\n                clearTimeout(this.mouseDownTimeout);\n                this.mouseDownTimeout = null;\n            }\n\n            this.isDraggingEnabled = false;\n            this.mouseStartPosition = null;\n            this.aiTableDrag = null;\n            this.handleDragEnd();\n        });\n    }\n\n    private handleDragStateChange(): void {\n        const drag = this.aiTableGridSelectionService.aiTable.dragState?.();\n\n        if (!drag) {\n            this.aiTableDrag = null;\n            return;\n        }\n\n        if (drag.type === DragType.none || !this.rect || !this.auxiliaryLine) {\n            return;\n        }\n\n        this.aiTableDrag = drag;\n    }\n\n    private handleDrag(e: MouseEvent, drag: AITableDragState) {\n        if (drag.type === DragType.none) {\n            return;\n        }\n        this.setDisplayStyle('block');\n        const moveX = e.x - (this.mouseStartPosition?.x || 0);\n        const moveY = e.y - (this.mouseStartPosition?.y || 0);\n        switch (drag.type) {\n            case DragType.field:\n                this.movingColumn(drag, moveX);\n                break;\n            case DragType.record:\n                this.movingRecord(drag, moveY);\n                break;\n            case DragType.columnWidth:\n                this.movingColumnWidth(drag, moveX);\n                break;\n        }\n    }\n\n    private movingColumn(drag: AITableDragState, moveX: number) {\n        const aiTable = this.aiTableGridSelectionService.aiTable;\n        const scroll = drag.scroll || { x: 0, y: 0 };\n        const coordinate = drag.coordinate!;\n        const fields = aiTable.gridData().fields;\n        const width = this.calculateDragWidth(fields, coordinate, drag);\n        const visibleColumnIndexMap = aiTable.context!.visibleColumnsIndexMap();\n        const sourceColumnIndex = visibleColumnIndexMap.get(drag.sourceIds.values().next().value!) || 0;\n        const sourceColumnStartX = coordinate.getColumnOffset(sourceColumnIndex);\n        const sourceColumnWidth = coordinate.getColumnWidth(sourceColumnIndex);\n        // TODO: 目前默认第一列为冻结列，后期支持设置冻结列需要处理\n        const isSourceColumnFrozen = sourceColumnIndex === 0;\n        const pointerX = moveX + sourceColumnStartX;\n        // 拖拽中心点\n        const dragCenter = sourceColumnWidth / 2;\n        this.setRectStyles({\n            cursor: 'move',\n            width: `${width}px`,\n            height: '100%',\n            top: '0',\n            left: `${pointerX - (isSourceColumnFrozen ? 0 : scroll.x)}px`\n        });\n\n        const lastColumnOffset = coordinate.getColumnOffset(coordinate.columnCount - 1);\n        const lastColumnWidth = coordinate.getColumnWidth(coordinate.columnCount - 1);\n\n        let targetColumnIndex = coordinate.getColumnStartIndex(pointerX + (isSourceColumnFrozen ? scroll.x : 0) + dragCenter);\n        let targetColumnStartX = coordinate.getColumnOffset(targetColumnIndex);\n        let isLastColumn = false;\n        // 处理最后一列\n        if (pointerX + dragCenter > lastColumnOffset + lastColumnWidth) {\n            targetColumnIndex = coordinate.columnCount;\n            targetColumnStartX = lastColumnOffset + lastColumnWidth;\n            isLastColumn = true;\n        }\n        if (\n            (targetColumnIndex >= 0 && (targetColumnIndex - sourceColumnIndex > 1 || targetColumnIndex - sourceColumnIndex < 0)) ||\n            isLastColumn\n        ) {\n            this.setAuxiliaryLineStyles({\n                width: '2px',\n                height: '100%',\n                top: 0,\n                left: `${targetColumnStartX - scroll.x}px`\n            });\n            const fieldsIndex: number[] = [];\n            drag.sourceIds.forEach((id) => {\n                const index = visibleColumnIndexMap.get(id) || 0;\n                fieldsIndex.push(index);\n            });\n            // 向右移动目标在目标列的前一列\n            if (targetColumnIndex > sourceColumnIndex) {\n                targetColumnIndex -= 1;\n            }\n            this.draggedData = { type: DragType.field, targetIndex: targetColumnIndex, fieldIds: drag.sourceIds, fieldsIndex };\n        } else {\n            this.resetAuxiliaryLine();\n            this.draggedData = null;\n        }\n    }\n\n    private movingColumnWidth(drag: AITableDragState, moveX: number) {\n        this.setCursorStyle('col-resize');\n        const aiTable = this.aiTableGridSelectionService.aiTable;\n        const visibleColumnIndexMap = aiTable.context!.visibleColumnsIndexMap();\n        const sourceColumnIndex = visibleColumnIndexMap.get(drag.sourceIds.values().next().value!) || 0;\n        const sourceColumnStartX = drag.coordinate!.getColumnOffset(sourceColumnIndex);\n        const sourceColumnWidth = drag.coordinate!.getColumnWidth(sourceColumnIndex);\n        const scroll = drag.scroll || { x: 0, y: 0 };\n        const pointerX = moveX + sourceColumnStartX;\n        const colResizeX = pointerX - (sourceColumnIndex === 0 ? 0 : scroll.x);\n        const left = `${colResizeX + sourceColumnWidth}px`;\n        this.setAuxiliaryLineStyles({\n            width: '2px',\n            height: '100%',\n            top: '0',\n            left\n        });\n        this.draggedData = {\n            type: DragType.columnWidth,\n            fieldIds: drag.sourceIds,\n            width: Math.max(MIN_COLUMN_WIDTH, sourceColumnWidth + moveX)\n        };\n    }\n\n    private movingRecord(drag: AITableDragState, moveY: number) {\n        const aiTable = this.aiTableGridSelectionService.aiTable;\n        const scroll = drag.scroll || { x: 0, y: 0 };\n        const coordinate = drag.coordinate!;\n\n        const visibleRowIndexMap = aiTable.context!.visibleRowsIndexMap();\n        const sourceRowId = drag.sourceIds.values().next().value!;\n        const sourceRowIndex = visibleRowIndexMap.get(sourceRowId) || 0;\n        const sourceRowStartY = coordinate.getRowOffset(sourceRowIndex);\n        const sourceRowHeight = coordinate.getRowHeight(sourceRowIndex);\n        const pointerY = sourceRowStartY + moveY;\n        this.setRectStyles({\n            width: '100%',\n            height: `${sourceRowHeight}px`,\n            top: `${pointerY - scroll.y}px`,\n            left: '0'\n        });\n        const dragCenter = sourceRowHeight / 2;\n        const targetRowIndex = coordinate.getRowStartIndex(pointerY + dragCenter);\n        const targetRowStartY = coordinate.getRowOffset(targetRowIndex);\n        const lineTop = targetRowStartY - scroll.y;\n        const lineHeight = 2;\n        if (\n            ((targetRowIndex >= 0 && sourceRowIndex > targetRowIndex && sourceRowIndex - targetRowIndex > 0) ||\n                (sourceRowIndex < targetRowIndex && targetRowIndex - sourceRowIndex > 1)) &&\n            lineTop > AI_TABLE_FIELD_HEAD_HEIGHT - lineHeight && // 限制可视范围内\n            lineTop < coordinate.containerHeight - lineHeight\n        ) {\n            this.setAuxiliaryLineStyles({\n                width: `calc(100% - ${AI_TABLE_ROW_DRAG_ICON_WIDTH}px)`,\n                height: `${lineHeight}px`,\n                top: `${lineTop}px`,\n                left: `${AI_TABLE_ROW_DRAG_ICON_WIDTH}px`\n            });\n            this.draggedData = {\n                type: DragType.record,\n                recordIds: drag.sourceIds,\n                targetIndex: targetRowIndex\n            };\n        } else {\n            this.resetAuxiliaryLine();\n            this.draggedData = null;\n        }\n    }\n\n    private handleDragEnd() {\n        if (this.draggedData) {\n            this.dragEnd.emit({ ...this.draggedData });\n        }\n        this.clearDragState();\n    }\n\n    private clearDragState() {\n        this.setDisplayStyle('none');\n        this.setRectStyles({\n            width: '0',\n            height: '0',\n            top: '0',\n            left: '0'\n        });\n        this.setAuxiliaryLineStyles({\n            width: '0',\n            height: '0',\n            top: '0',\n            left: '0'\n        });\n        this.draggedData = null;\n    }\n\n    private calculateDragWidth(fields: any[], coordinate: any, drag: AITableDragState): number {\n        let width = 0;\n        fields.forEach((field, index) => {\n            if (drag.sourceIds.has(field._id)) {\n                width += coordinate.columnIndicesSizeMap[index] || 0;\n            }\n        });\n        return width;\n    }\n\n    private setDisplayStyle(display: string) {\n        this.render2.setStyle(this.elementRef.nativeElement, 'display', display);\n    }\n\n    private setCursorStyle(cursor: string) {\n        this.render2.setStyle(this.elementRef.nativeElement, 'cursor', cursor);\n    }\n\n    private setRectStyles(styles: Record<string, any>) {\n        Object.entries(styles).forEach(([prop, value]) => {\n            this.render2.setStyle(this.rect, prop, value);\n        });\n    }\n\n    private setAuxiliaryLineStyles(styles: Record<string, any>) {\n        Object.entries(styles).forEach(([prop, value]) => {\n            this.render2.setStyle(this.auxiliaryLine, prop, value);\n        });\n    }\n\n    private resetAuxiliaryLine(): void {\n        this.setAuxiliaryLineStyles({ width: 0, height: 0, top: '0', left: '0' });\n    }\n\n    ngOnDestroy() {\n        if (this.mousedownListener) this.mousedownListener();\n        if (this.mousemoveListener) this.mousemoveListener();\n        if (this.mouseupListener) this.mouseupListener();\n\n        if (this.timer) {\n            cancelAnimationFrame(this.timer);\n            this.timer = null;\n        }\n    }\n}\n","<div class=\"rect\"></div>\n<div class=\"auxiliary-line\"></div>"]}
293
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drag.component.js","sourceRoot":"","sources":["../../../../../packages/grid/src/components/drag/drag.component.ts","../../../../../packages/grid/src/components/drag/drag.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, effect, ElementRef, inject, OnDestroy, OnInit, output, Renderer2 } from '@angular/core';\nimport { AITableDragState, DragEndData, DragType } from '../../core';\nimport { AITableGridSelectionService } from '../../services/selection.service';\nimport { MIN_COLUMN_WIDTH } from '../../constants/grid';\nimport { AI_TABLE_FIELD_HEAD_HEIGHT, AI_TABLE_ROW_DRAG_ICON_WIDTH, AI_TABLE_ROW_HEAD_WIDTH } from '../../constants/table';\n\n@Component({\n    selector: 'ai-table-drag',\n    templateUrl: './drag.component.html',\n    standalone: true,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        class: 'drag-container'\n    }\n})\nexport class AITableDragComponent implements OnInit, OnDestroy {\n    dragEnd = output<DragEndData>();\n\n    private aiTableGridSelectionService = inject(AITableGridSelectionService);\n\n    private render2 = inject(Renderer2);\n\n    elementRef: ElementRef<HTMLElement> = inject(ElementRef<HTMLElement>);\n\n    private rect!: HTMLElement;\n\n    private auxiliaryLine!: HTMLElement;\n\n    private draggedData: DragEndData | null = null;\n\n    private mouseStartPosition: { x: number; y: number } | null = null;\n\n    private aiTableDrag: AITableDragState | null = null;\n\n    private timer!: number | null;\n\n    private mouseDownTimeout: any = null;\n\n    private isDraggingEnabled: boolean = false;\n\n    private mousedownListener?: () => void;\n    private mousemoveListener?: () => void;\n    private mouseupListener?: () => void;\n\n    constructor() {\n        effect(() => this.handleDragStateChange());\n    }\n\n    ngOnInit() {\n        this.initElements();\n        this.setupEventListeners();\n    }\n\n    private initElements(): void {\n        this.rect = this.elementRef.nativeElement.querySelector('.rect')!;\n        this.auxiliaryLine = this.elementRef.nativeElement.querySelector('.auxiliary-line')!;\n    }\n\n    private setupEventListeners(): void {\n        this.mousedownListener = this.render2.listen('window', 'mousedown', (e: MouseEvent) => {\n            this.mouseStartPosition = { x: e.x, y: e.y };\n\n            if (this.mouseDownTimeout) {\n                clearTimeout(this.mouseDownTimeout);\n            }\n            this.isDraggingEnabled = false;\n            this.mouseDownTimeout = setTimeout(() => {\n                this.isDraggingEnabled = true;\n            }, 200);\n        });\n\n        this.mousemoveListener = this.render2.listen('window', 'mousemove', (e: MouseEvent) => {\n            if (!this.isDraggingEnabled) {\n                return;\n            }\n            if (this.timer) {\n                cancelAnimationFrame(this.timer);\n            }\n            this.timer = requestAnimationFrame(() => {\n                if (this.aiTableDrag && this.mouseStartPosition) {\n                    this.handleDrag(e, this.aiTableDrag);\n                }\n            });\n        });\n\n        this.mouseupListener = this.render2.listen('window', 'mouseup', () => {\n            if (this.mouseDownTimeout) {\n                clearTimeout(this.mouseDownTimeout);\n                this.mouseDownTimeout = null;\n            }\n\n            this.isDraggingEnabled = false;\n            this.mouseStartPosition = null;\n            this.aiTableDrag = null;\n            this.handleDragEnd();\n        });\n    }\n\n    private handleDragStateChange(): void {\n        const drag = this.aiTableGridSelectionService.aiTable.dragState?.();\n\n        if (!drag) {\n            this.aiTableDrag = null;\n            return;\n        }\n\n        if (drag.type === DragType.none || !this.rect || !this.auxiliaryLine) {\n            return;\n        }\n\n        this.aiTableDrag = drag;\n    }\n\n    private handleDrag(e: MouseEvent, drag: AITableDragState) {\n        if (drag.type === DragType.none) {\n            return;\n        }\n        this.setDisplayStyle('block');\n        const moveX = e.x - (this.mouseStartPosition?.x || 0);\n        const moveY = e.y - (this.mouseStartPosition?.y || 0);\n        switch (drag.type) {\n            case DragType.field:\n                this.movingColumn(drag, moveX);\n                break;\n            case DragType.record:\n                this.movingRecord(drag, moveY);\n                break;\n            case DragType.columnWidth:\n                this.movingColumnWidth(drag, moveX);\n                break;\n        }\n    }\n\n    private movingColumn(drag: AITableDragState, moveX: number) {\n        const aiTable = this.aiTableGridSelectionService.aiTable;\n        const scroll = drag.scroll || { x: 0, y: 0 };\n        const coordinate = drag.coordinate!;\n        const fields = aiTable.gridData().fields;\n        const width = this.calculateDragWidth(fields, coordinate, drag);\n        const visibleColumnIndexMap = aiTable.context!.visibleColumnsIndexMap();\n        const sourceColumnIndex = visibleColumnIndexMap.get(drag.sourceIds.values().next().value!) || 0;\n        const sourceColumnStartX = coordinate.getColumnOffset(sourceColumnIndex);\n        const sourceColumnWidth = coordinate.getColumnWidth(sourceColumnIndex);\n        // TODO: 目前默认第一列为冻结列，后期支持设置冻结列需要处理\n        const isSourceColumnFrozen = sourceColumnIndex === 0;\n        const frozenColumnWidth = coordinate.getColumnWidth(0);\n        const pointerX = moveX + sourceColumnStartX;\n        // 拖拽中心点\n        const dragCenter = sourceColumnWidth / 2;\n        this.setRectStyles({\n            cursor: 'move',\n            width: `${width}px`,\n            height: '100%',\n            top: '0',\n            left: `${pointerX - (isSourceColumnFrozen ? 0 : scroll.x)}px`\n        });\n\n        const lastColumnOffset = coordinate.getColumnOffset(coordinate.columnCount - 1);\n        const lastColumnWidth = coordinate.getColumnWidth(coordinate.columnCount - 1);\n\n        let targetColumnIndex = coordinate.getColumnStartIndex(pointerX + (isSourceColumnFrozen ? scroll.x : 0) + dragCenter);\n        let targetColumnStartX = coordinate.getColumnOffset(targetColumnIndex);\n        let isLastColumn = false;\n        // 处理最后一列\n        if (pointerX + dragCenter > lastColumnOffset + lastColumnWidth) {\n            targetColumnIndex = coordinate.columnCount;\n            targetColumnStartX = lastColumnOffset + lastColumnWidth;\n            isLastColumn = true;\n        }\n        if (\n            (targetColumnIndex >= 0 && (targetColumnIndex - sourceColumnIndex > 1 || targetColumnIndex - sourceColumnIndex < 0)) ||\n            isLastColumn\n        ) {\n            let lineLeft = targetColumnStartX - scroll.x;\n            const lineForFrozenX = lineLeft - frozenColumnWidth - AI_TABLE_ROW_HEAD_WIDTH;\n            if (lineForFrozenX < 0) {\n                lineLeft = coordinate.getColumnOffset(0);\n                targetColumnIndex = 0;\n            }\n            this.setAuxiliaryLineStyles({\n                width: '2px',\n                height: '100%',\n                top: 0,\n                left: `${lineLeft}px`\n            });\n            // 向右移动目标在目标列的前一列\n            if (targetColumnIndex > sourceColumnIndex) {\n                targetColumnIndex -= 1;\n            }\n            this.draggedData = {\n                type: DragType.field,\n                targetIndex: targetColumnIndex,\n                fieldIds: drag.sourceIds,\n                fieldsIndex: Array.from(drag.sourceIds).map((id) => visibleColumnIndexMap.get(id) || 0)\n            };\n        } else {\n            this.resetAuxiliaryLine();\n            this.draggedData = null;\n        }\n    }\n\n    private movingColumnWidth(drag: AITableDragState, moveX: number) {\n        this.setCursorStyle('col-resize');\n        const aiTable = this.aiTableGridSelectionService.aiTable;\n        const visibleColumnIndexMap = aiTable.context!.visibleColumnsIndexMap();\n        const sourceColumnIndex = visibleColumnIndexMap.get(drag.sourceIds.values().next().value!) || 0;\n        const sourceColumnStartX = drag.coordinate!.getColumnOffset(sourceColumnIndex);\n        const sourceColumnWidth = drag.coordinate!.getColumnWidth(sourceColumnIndex);\n        const scroll = drag.scroll || { x: 0, y: 0 };\n        const pointerX = moveX + sourceColumnStartX;\n        const colResizeX = pointerX - (sourceColumnIndex === 0 ? 0 : scroll.x);\n        const left = `${colResizeX + sourceColumnWidth}px`;\n        this.setAuxiliaryLineStyles({\n            width: '2px',\n            height: '100%',\n            top: '0',\n            left\n        });\n        this.draggedData = {\n            type: DragType.columnWidth,\n            fieldIds: drag.sourceIds,\n            width: Math.max(MIN_COLUMN_WIDTH, sourceColumnWidth + moveX)\n        };\n    }\n\n    private movingRecord(drag: AITableDragState, moveY: number) {\n        const aiTable = this.aiTableGridSelectionService.aiTable;\n        const scroll = drag.scroll || { x: 0, y: 0 };\n        const coordinate = drag.coordinate!;\n\n        const visibleRowIndexMap = aiTable.context!.visibleRowsIndexMap();\n        const sourceRowId = drag.sourceIds.values().next().value!;\n        const sourceRowIndex = visibleRowIndexMap.get(sourceRowId) || 0;\n        const sourceRowStartY = coordinate.getRowOffset(sourceRowIndex);\n        const sourceRowHeight = coordinate.getRowHeight(sourceRowIndex);\n        const pointerY = sourceRowStartY + moveY;\n        this.setRectStyles({\n            width: '100%',\n            height: `${sourceRowHeight}px`,\n            top: `${pointerY - scroll.y}px`,\n            left: '0'\n        });\n        const dragCenter = sourceRowHeight / 2;\n        const targetRowIndex = coordinate.getRowStartIndex(pointerY + dragCenter);\n        const targetRowStartY = coordinate.getRowOffset(targetRowIndex);\n        const lineTop = targetRowStartY - scroll.y;\n        const lineHeight = 2;\n        if (\n            ((targetRowIndex >= 0 && sourceRowIndex > targetRowIndex && sourceRowIndex - targetRowIndex > 0) ||\n                (sourceRowIndex < targetRowIndex && targetRowIndex - sourceRowIndex > 1)) &&\n            lineTop > AI_TABLE_FIELD_HEAD_HEIGHT - lineHeight && // 限制可视范围内\n            lineTop < coordinate.containerHeight - lineHeight\n        ) {\n            this.setAuxiliaryLineStyles({\n                width: `calc(100% - ${AI_TABLE_ROW_DRAG_ICON_WIDTH}px)`,\n                height: `${lineHeight}px`,\n                top: `${lineTop}px`,\n                left: `${AI_TABLE_ROW_DRAG_ICON_WIDTH}px`\n            });\n            this.draggedData = {\n                type: DragType.record,\n                recordIds: drag.sourceIds,\n                targetIndex: targetRowIndex\n            };\n        } else {\n            this.resetAuxiliaryLine();\n            this.draggedData = null;\n        }\n    }\n\n    private handleDragEnd() {\n        if (this.draggedData) {\n            this.dragEnd.emit({ ...this.draggedData });\n        }\n        this.clearDragState();\n    }\n\n    private clearDragState() {\n        this.setDisplayStyle('none');\n        this.setRectStyles({\n            width: '0',\n            height: '0',\n            top: '0',\n            left: '0'\n        });\n        this.setAuxiliaryLineStyles({\n            width: '0',\n            height: '0',\n            top: '0',\n            left: '0'\n        });\n        this.draggedData = null;\n    }\n\n    private calculateDragWidth(fields: any[], coordinate: any, drag: AITableDragState): number {\n        let width = 0;\n        fields.forEach((field, index) => {\n            if (drag.sourceIds.has(field._id)) {\n                width += coordinate.columnIndicesSizeMap[index] || 0;\n            }\n        });\n        return width;\n    }\n\n    private setDisplayStyle(display: string) {\n        this.render2.setStyle(this.elementRef.nativeElement, 'display', display);\n    }\n\n    private setCursorStyle(cursor: string) {\n        this.render2.setStyle(this.elementRef.nativeElement, 'cursor', cursor);\n    }\n\n    private setRectStyles(styles: Record<string, any>) {\n        Object.entries(styles).forEach(([prop, value]) => {\n            this.render2.setStyle(this.rect, prop, value);\n        });\n    }\n\n    private setAuxiliaryLineStyles(styles: Record<string, any>) {\n        Object.entries(styles).forEach(([prop, value]) => {\n            this.render2.setStyle(this.auxiliaryLine, prop, value);\n        });\n    }\n\n    private resetAuxiliaryLine(): void {\n        this.setAuxiliaryLineStyles({ width: 0, height: 0, top: '0', left: '0' });\n    }\n\n    ngOnDestroy() {\n        if (this.mousedownListener) this.mousedownListener();\n        if (this.mousemoveListener) this.mousemoveListener();\n        if (this.mouseupListener) this.mouseupListener();\n\n        if (this.timer) {\n            cancelAnimationFrame(this.timer);\n            this.timer = null;\n        }\n    }\n}\n","<div class=\"rect\"></div>\n<div class=\"auxiliary-line\"></div>"]}
@@ -1,5 +1,5 @@
1
1
  import { NgClass, NgTemplateOutlet } from '@angular/common';
2
- import { ChangeDetectionStrategy, Component, booleanAttribute, computed, inject, input, model, output } from '@angular/core';
2
+ import { ChangeDetectionStrategy, Component, booleanAttribute, computed, inject, input, model, output, signal } from '@angular/core';
3
3
  import { FormsModule } from '@angular/forms';
4
4
  import { ThyButton } from 'ngx-tethys/button';
5
5
  import { ThyDropdownDirective, ThyDropdownMenuComponent, ThyDropdownMenuItemDirective, ThyDropdownMenuItemExtendIconDirective, ThyDropdownMenuItemIconDirective, ThyDropdownMenuItemNameDirective } from 'ngx-tethys/dropdown';
@@ -43,6 +43,7 @@ export class AITableFieldSetting {
43
43
  });
44
44
  this.aITableFieldType = AITableFieldType;
45
45
  this.isMultipleMember = false;
46
+ this.isManualInputName = signal(false);
46
47
  this.thyPopoverRef = inject((ThyPopoverRef));
47
48
  this.checkUniqueName = (fieldName) => {
48
49
  fieldName = fieldName?.trim();
@@ -70,7 +71,7 @@ export class AITableFieldSetting {
70
71
  this.aiEditField.update((item) => {
71
72
  const width = fieldsSizeMap[item._id] ?? field.width;
72
73
  const settings = field.settings || {};
73
- const name = createDefaultFieldName(this.aiTable(), field);
74
+ const name = this.isManualInputName() ? item.name : createDefaultFieldName(this.aiTable(), field);
74
75
  return { ...item, ...field, width, name, settings };
75
76
  });
76
77
  setTimeout(() => {
@@ -102,11 +103,14 @@ export class AITableFieldSetting {
102
103
  e.preventDefault();
103
104
  e.stopPropagation();
104
105
  }
106
+ nameChange(event) {
107
+ this.isManualInputName.set(true);
108
+ }
105
109
  cancel() {
106
110
  this.thyPopoverRef.close();
107
111
  }
108
112
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableFieldSetting, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
109
- 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]=\"i18nTexts().columnName\">\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]=\"i18nTexts().columnNamePlaceholder\"\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]=\"i18nTexts().fieldType\">\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 {{i18nTexts().allowMultipleMembers}}\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\">{{i18nTexts().cancel}}</button>\n <button thyButton=\"primary\" (thyFormSubmit)=\"editFieldProperty()\" thySize=\"sm\">{{i18nTexts().confirm}}</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 }); }
113
+ 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]=\"i18nTexts().columnName\">\n <thy-input-group>\n <input\n thyInput\n [thyAutofocus]=\"true\"\n name=\"fieldName\"\n [maxlength]=\"fieldMaxLength\"\n [(ngModel)]=\"aiEditField().name\"\n (ngModelChange)=\"nameChange($event)\"\n required\n [placeholder]=\"i18nTexts().columnNamePlaceholder\"\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]=\"i18nTexts().fieldType\">\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 {{ i18nTexts().allowMultipleMembers }}\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\">{{ i18nTexts().cancel }}</button>\n <button thyButton=\"primary\" (thyFormSubmit)=\"editFieldProperty()\" thySize=\"sm\">{{ i18nTexts().confirm }}</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 }); }
110
114
  }
111
115
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableFieldSetting, decorators: [{
112
116
  type: Component,
@@ -132,6 +136,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
132
136
  AITableFieldIsSameOptionPipe
133
137
  ], host: {
134
138
  class: 'field-setting d-block pl-5 pr-5 pb-5 pt-4'
135
- }, template: "<form thyForm name=\"createPropertyForm\" [thyFormValidatorConfig]=\"validatorConfig()\" thyLayout=\"vertical\">\n <thy-form-group thyLabelRequired [thyLabelText]=\"i18nTexts().columnName\">\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]=\"i18nTexts().columnNamePlaceholder\"\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]=\"i18nTexts().fieldType\">\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 {{i18nTexts().allowMultipleMembers}}\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\">{{i18nTexts().cancel}}</button>\n <button thyButton=\"primary\" (thyFormSubmit)=\"editFieldProperty()\" thySize=\"sm\">{{i18nTexts().confirm}}</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"] }]
139
+ }, template: "<form thyForm name=\"createPropertyForm\" [thyFormValidatorConfig]=\"validatorConfig()\" thyLayout=\"vertical\">\n <thy-form-group thyLabelRequired [thyLabelText]=\"i18nTexts().columnName\">\n <thy-input-group>\n <input\n thyInput\n [thyAutofocus]=\"true\"\n name=\"fieldName\"\n [maxlength]=\"fieldMaxLength\"\n [(ngModel)]=\"aiEditField().name\"\n (ngModelChange)=\"nameChange($event)\"\n required\n [placeholder]=\"i18nTexts().columnNamePlaceholder\"\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]=\"i18nTexts().fieldType\">\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 {{ i18nTexts().allowMultipleMembers }}\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\">{{ i18nTexts().cancel }}</button>\n <button thyButton=\"primary\" (thyFormSubmit)=\"editFieldProperty()\" thySize=\"sm\">{{ i18nTexts().confirm }}</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"] }]
136
140
  }] });
137
- //# 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":"AAAA,OAAO,EAAE,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AAC5D,OAAO,EACH,uBAAuB,EACvB,SAAS,EAGT,gBAAgB,EAChB,QAAQ,EACR,MAAM,EACN,KAAK,EACL,KAAK,EACL,MAAM,EACT,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAC9C,OAAO,EACH,oBAAoB,EACpB,wBAAwB,EACxB,4BAA4B,EAC5B,sCAAsC,EACtC,gCAAgC,EAChC,gCAAgC,EACnC,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,aAAa,EAA0B,uBAAuB,EAAE,MAAM,iBAAiB,CAAC;AACjG,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAC1C,OAAO,EAAE,aAAa,EAAE,iBAAiB,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AACnF,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAC9C,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,qBAAqB,EAAE,MAAM,mBAAmB,CAAC;AAC1D,OAAO,EAAE,EAAE,EAAE,MAAM,MAAM,CAAC;AAC1B,OAAO,EAIH,sBAAsB,EACtB,qBAAqB,EAErB,gBAAgB,EAEhB,eAAe,EAClB,MAAM,YAAY,CAAC;AACpB,OAAO,EAAE,4BAA4B,EAAE,MAAM,aAAa,CAAC;AAE3D,OAAO,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,MAAM,kBAAkB,CAAC;;;;AAuCxE,MAAM,OAAO,mBAAmB;IArChC;QAsCI,gBAAW,GAAG,KAAK,CAAC,QAAQ,EAAgB,CAAC;QAE7C,YAAO,GAAG,KAAK,CAAC,QAAQ,EAAW,CAAC;QAEpC,uBAAkB,GAAG,KAAK,CAA0B,IAAI,CAAC,CAAC;QAE1D,aAAQ,GAAG,KAAK,CAAmB,KAAK,EAAE,EAAE,SAAS,EAAE,gBAAgB,EAAE,CAAC,CAAC;QAE3E,aAAQ,GAAG,MAAM,EAAgB,CAAC;QAElC,aAAQ,GAAG,MAAM,EAAmB,CAAC;QAErC,wBAAmB,GAAG,QAAQ,CAAC,GAAG,EAAE;YAChC,OAAO,qBAAqB,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,IAAI,CAAC,WAAW,EAAE,CAAE,CAAC;QACtE,CAAC,CAAC,CAAC;QAEH,mBAAc,GAAG,EAAE,CAAC;QAEpB,oBAAe,GAAG,QAAQ,CAAC,GAAG,EAAE;YAC5B,OAAO;gBACH,kBAAkB,EAAE;oBAChB,SAAS,EAAE;wBACP,QAAQ,EAAE,gBAAgB,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,kBAAkB,CAAC,iBAAiB,CAAC;wBAChF,cAAc,EAAE,gBAAgB,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,kBAAkB,CAAC,kBAAkB,CAAC;qBAC1F;iBACJ;aACJ,CAAC;QACN,CAAC,CAAC,CAAC;QAEH,iBAAY,GAAG,QAAQ,CAAC,GAAG,EAAE;YACzB,OAAO,eAAe,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;QAC3C,CAAC,CAAC,CAAC;QAEH,qBAAgB,GAAG,gBAAgB,CAAC;QAEpC,qBAAgB,GAAG,KAAK,CAAC;QAEf,kBAAa,GAAG,MAAM,CAAC,CAAA,aAAkC,CAAA,CAAC,CAAC;QAOrE,oBAAe,GAAG,CAAC,SAAiB,EAAE,EAAE;YACpC,SAAS,GAAG,SAAS,EAAE,IAAI,EAAE,CAAC;YAC9B,OAAO,EAAE,CACL,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE;iBACX,MAAM,EAAE;gBACT,EAAE,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,KAAK,SAAS,IAAI,IAAI,CAAC,WAAW,EAAE,EAAE,GAAG,KAAK,KAAK,CAAC,GAAG,CAAC,CAC3F,CAAC;QACN,CAAC,CAAC;QA8CF,cAAS,GAAG,QAAQ,CAAC,GAAG,EAAE;YACtB,OAAO;gBACH,UAAU,EAAE,gBAAgB,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,kBAAkB,CAAC,eAAe,CAAC;gBAChF,qBAAqB,EAAE,gBAAgB,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,kBAAkB,CAAC,0BAA0B,CAAC;gBACtG,SAAS,EAAE,gBAAgB,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,kBAAkB,CAAC,SAAS,CAAC;gBACzE,oBAAoB,EAAE,gBAAgB,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,kBAAkB,CAAC,oBAAoB,CAAC;gBAC/F,MAAM,EAAE,gBAAgB,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,kBAAkB,CAAC,MAAM,CAAC;gBACnE,OAAO,EAAE,gBAAgB,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,kBAAkB,CAAC,OAAO,CAAC;aACxE,CAAC;QACN,CAAC,CAAC,CAAC;KACN;IApEG,QAAQ;QACJ,IAAI,CAAC,gBAAgB;YACjB,IAAI,CAAC,WAAW,EAAE,CAAC,IAAI,KAAK,gBAAgB,CAAC,MAAM,IAAI,CAAC,CAAE,IAAI,CAAC,WAAW,EAAE,CAAC,QAA2B,EAAE,WAAW,CAAC;IAC9H,CAAC;IAWD,eAAe,CAAC,KAAyB;QACrC,MAAM,aAAa,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC,QAAQ,EAAE,CAAC,aAAa,CAAC;QAC9D,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE;YAC7B,MAAM,KAAK,GAAG,aAAa,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,KAAK,CAAC,KAAK,CAAC;YACrD,MAAM,QAAQ,GAAG,KAAK,CAAC,QAAQ,IAAI,EAAE,CAAC;YACtC,MAAM,IAAI,GAAG,sBAAsB,CAAC,IAAI,CAAC,OAAO,EAAE,EAAE,KAAK,CAAC,CAAC;YAC3D,OAAO,EAAE,GAAG,IAAI,EAAE,GAAG,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC;QACxD,CAAC,CAAC,CAAC;QACH,UAAU,CAAC,GAAG,EAAE;YACZ,IAAI,CAAC,aAAa,CAAC,cAAc,EAAE,CAAC;QACxC,CAAC,EAAE,CAAC,CAAC,CAAC;IACV,CAAC;IAED,iBAAiB;QACb,IAAI,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC;YAClB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;gBACf,KAAK,EAAE,IAAI,CAAC,WAAW,EAAE;gBACzB,IAAI,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,GAAG,CAAC;aACjC,CAAC,CAAC;QACP,CAAC;aAAM,CAAC;YACJ,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;QAC3C,CAAC;QACD,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IAC/B,CAAC;IAED,oBAAoB;QAChB,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC;YACjB,GAAG,IAAI,CAAC,WAAW,EAAE;YACrB,QAAQ,EAAE;gBACN,GAAG,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,QAAQ,IAAI,EAAE,CAAC;gBACtC,WAAW,EAAE,IAAI,CAAC,gBAAgB;aACrC;SACJ,CAAC,CAAC;IACP,CAAC;IAED,cAAc,CAAC,CAAQ;QACnB,CAAC,CAAC,cAAc,EAAE,CAAC;QACnB,CAAC,CAAC,eAAe,EAAE,CAAC;IACxB,CAAC;IAED,MAAM;QACF,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IAC/B,CAAC;+GAhGQ,mBAAmB;mGAAnB,mBAAmB,syBClFhC,2kGAyEA,8EDtBQ,OAAO,mFACP,WAAW,w6CACX,OAAO,sMACP,aAAa,+KACb,aAAa,kFACb,iBAAiB,+IACjB,uBAAuB,yFACvB,wBAAwB,0GACxB,oBAAoB,mRACpB,4BAA4B,sGAC5B,gCAAgC,sEAChC,gCAAgC,sEAChC,sCAAsC,4EACtC,SAAS,oLACT,SAAS,2IACT,aAAa,+rBACb,gBAAgB,oJAChB,qBAAqB,6HACrB,4BAA4B;;4FAavB,mBAAmB;kBArC/B,SAAS;+BACI,wBAAwB,cAEtB,IAAI,mBACC,uBAAuB,CAAC,MAAM,WACtC;wBACL,OAAO;wBACP,WAAW;wBACX,OAAO;wBACP,aAAa;wBACb,aAAa;wBACb,iBAAiB;wBACjB,uBAAuB;wBACvB,wBAAwB;wBACxB,oBAAoB;wBACpB,4BAA4B;wBAC5B,gCAAgC;wBAChC,gCAAgC;wBAChC,sCAAsC;wBACtC,SAAS;wBACT,SAAS;wBACT,aAAa;wBACb,gBAAgB;wBAChB,qBAAqB;wBACrB,4BAA4B;qBAC/B,QACK;wBACF,KAAK,EAAE,2CAA2C;qBACrD","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    createDefaultFieldName,\n    getFieldOptionByField,\n    SetFieldOptions,\n    AITableFieldType,\n    MemberSettings,\n    getFieldOptions\n} from '../../core';\nimport { AITableFieldIsSameOptionPipe } from '../../pipes';\nimport * as _ from 'lodash';\nimport { AITableGridI18nKey, getI18nTextByKey } from '../../utils/i18n';\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.aiTable(), this.aiEditField())!;\n    });\n\n    fieldMaxLength = 32;\n\n    validatorConfig = computed(() => {\n        return {\n            validationMessages: {\n                fieldName: {\n                    required: getI18nTextByKey(this.aiTable(), AITableGridI18nKey.fieldNameRequired),\n                    thyUniqueCheck: getI18nTextByKey(this.aiTable(), AITableGridI18nKey.fieldNameDuplicate)\n                }\n            }\n        };\n    });\n\n    fieldOptions = computed(() => {\n        return getFieldOptions(this.aiTable());\n    });\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        const fieldsSizeMap = this.aiTable().gridData().fieldsSizeMap;\n        this.aiEditField.update((item) => {\n            const width = fieldsSizeMap[item._id] ?? 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    i18nTexts = computed(() => {\n        return {\n            columnName: getI18nTextByKey(this.aiTable(), AITableGridI18nKey.fieldColumnName),\n            columnNamePlaceholder: getI18nTextByKey(this.aiTable(), AITableGridI18nKey.fieldColumnNamePlaceholder),\n            fieldType: getI18nTextByKey(this.aiTable(), AITableGridI18nKey.fieldType),\n            allowMultipleMembers: getI18nTextByKey(this.aiTable(), AITableGridI18nKey.allowMultipleMembers),\n            cancel: getI18nTextByKey(this.aiTable(), AITableGridI18nKey.cancel),\n            confirm: getI18nTextByKey(this.aiTable(), AITableGridI18nKey.confirm)\n        };\n    });\n}\n","<form thyForm name=\"createPropertyForm\" [thyFormValidatorConfig]=\"validatorConfig()\" thyLayout=\"vertical\">\n    <thy-form-group thyLabelRequired [thyLabelText]=\"i18nTexts().columnName\">\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]=\"i18nTexts().columnNamePlaceholder\"\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]=\"i18nTexts().fieldType\">\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                {{i18nTexts().allowMultipleMembers}}\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\">{{i18nTexts().cancel}}</button>\n        <button thyButton=\"primary\" (thyFormSubmit)=\"editFieldProperty()\" thySize=\"sm\">{{i18nTexts().confirm}}</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"]}
141
+ //# 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    signal\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, 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    createDefaultFieldName,\n    getFieldOptionByField,\n    SetFieldOptions,\n    AITableFieldType,\n    MemberSettings,\n    getFieldOptions\n} from '../../core';\nimport { AITableFieldIsSameOptionPipe } from '../../pipes';\nimport * as _ from 'lodash';\nimport { AITableGridI18nKey, getI18nTextByKey } from '../../utils/i18n';\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.aiTable(), this.aiEditField())!;\n    });\n\n    fieldMaxLength = 32;\n\n    validatorConfig = computed(() => {\n        return {\n            validationMessages: {\n                fieldName: {\n                    required: getI18nTextByKey(this.aiTable(), AITableGridI18nKey.fieldNameRequired),\n                    thyUniqueCheck: getI18nTextByKey(this.aiTable(), AITableGridI18nKey.fieldNameDuplicate)\n                }\n            }\n        };\n    });\n\n    fieldOptions = computed(() => {\n        return getFieldOptions(this.aiTable());\n    });\n\n    aITableFieldType = AITableFieldType;\n\n    isMultipleMember = false;\n\n    private isManualInputName = signal(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        const fieldsSizeMap = this.aiTable().gridData().fieldsSizeMap;\n        this.aiEditField.update((item) => {\n            const width = fieldsSizeMap[item._id] ?? field.width;\n            const settings = field.settings || {};\n            const name = this.isManualInputName() ? item.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    nameChange(event: Event) {\n        this.isManualInputName.set(true);\n    }\n\n    cancel() {\n        this.thyPopoverRef.close();\n    }\n\n    i18nTexts = computed(() => {\n        return {\n            columnName: getI18nTextByKey(this.aiTable(), AITableGridI18nKey.fieldColumnName),\n            columnNamePlaceholder: getI18nTextByKey(this.aiTable(), AITableGridI18nKey.fieldColumnNamePlaceholder),\n            fieldType: getI18nTextByKey(this.aiTable(), AITableGridI18nKey.fieldType),\n            allowMultipleMembers: getI18nTextByKey(this.aiTable(), AITableGridI18nKey.allowMultipleMembers),\n            cancel: getI18nTextByKey(this.aiTable(), AITableGridI18nKey.cancel),\n            confirm: getI18nTextByKey(this.aiTable(), AITableGridI18nKey.confirm)\n        };\n    });\n}\n","<form thyForm name=\"createPropertyForm\" [thyFormValidatorConfig]=\"validatorConfig()\" thyLayout=\"vertical\">\n    <thy-form-group thyLabelRequired [thyLabelText]=\"i18nTexts().columnName\">\n        <thy-input-group>\n            <input\n                thyInput\n                [thyAutofocus]=\"true\"\n                name=\"fieldName\"\n                [maxlength]=\"fieldMaxLength\"\n                [(ngModel)]=\"aiEditField().name\"\n                (ngModelChange)=\"nameChange($event)\"\n                required\n                [placeholder]=\"i18nTexts().columnNamePlaceholder\"\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]=\"i18nTexts().fieldType\">\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                {{ i18nTexts().allowMultipleMembers }}\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\">{{ i18nTexts().cancel }}</button>\n        <button thyButton=\"primary\" (thyFormSubmit)=\"editFieldProperty()\" thySize=\"sm\">{{ i18nTexts().confirm }}</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"]}