@ai-table/grid 0.0.55 → 0.0.57

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.
Files changed (119) hide show
  1. package/components/cell-editors/abstract-cell-editor.component.d.ts.map +1 -1
  2. package/components/cell-editors/cell-editor.scss +0 -1
  3. package/components/drag/drag.component.d.ts +1 -0
  4. package/components/drag/drag.component.d.ts.map +1 -1
  5. package/components/index.d.ts +0 -1
  6. package/components/index.d.ts.map +1 -1
  7. package/constants/editor.d.ts.map +1 -1
  8. package/constants/grid.d.ts +0 -1
  9. package/constants/grid.d.ts.map +1 -1
  10. package/constants/icon.d.ts +1 -0
  11. package/constants/icon.d.ts.map +1 -1
  12. package/constants/table.d.ts +6 -2
  13. package/constants/table.d.ts.map +1 -1
  14. package/core/types/core.d.ts +17 -13
  15. package/core/types/core.d.ts.map +1 -1
  16. package/dom-grid.component.d.ts.map +1 -1
  17. package/esm2022/components/cell-editors/abstract-cell-editor.component.mjs +2 -4
  18. package/esm2022/components/cell-editors/date/date-editor.component.mjs +5 -5
  19. package/esm2022/components/drag/drag.component.mjs +42 -2
  20. package/esm2022/components/index.mjs +1 -2
  21. package/esm2022/constants/editor.mjs +3 -4
  22. package/esm2022/constants/grid.mjs +1 -2
  23. package/esm2022/constants/icon.mjs +2 -1
  24. package/esm2022/constants/table.mjs +7 -3
  25. package/esm2022/core/constants/field.mjs +2 -2
  26. package/esm2022/core/types/core.mjs +1 -1
  27. package/esm2022/dom-grid.component.mjs +2 -4
  28. package/esm2022/grid-base.component.mjs +9 -30
  29. package/esm2022/grid.component.mjs +49 -53
  30. package/esm2022/renderer/components/cells/attachment.component.mjs +9 -19
  31. package/esm2022/renderer/components/cells/index.mjs +3 -2
  32. package/esm2022/renderer/components/cells/link.component.mjs +3 -5
  33. package/esm2022/renderer/components/cells/progress.component.mjs +268 -0
  34. package/esm2022/renderer/components/cells/rich-text.component.mjs +90 -0
  35. package/esm2022/renderer/components/frozen-heads.component.mjs +17 -5
  36. package/esm2022/renderer/components/hover-row-heads.component.mjs +20 -3
  37. package/esm2022/renderer/components/icon.component.mjs +6 -2
  38. package/esm2022/renderer/drawers/add-row-layout-drawer.mjs +5 -5
  39. package/esm2022/renderer/drawers/cell-drawer.mjs +28 -29
  40. package/esm2022/renderer/drawers/record-row-layout-drawer.mjs +5 -5
  41. package/esm2022/utils/cell.mjs +5 -3
  42. package/esm2022/utils/clipboard/copy.mjs +11 -5
  43. package/esm2022/utils/clipboard/paste.mjs +1 -4
  44. package/esm2022/utils/field/model/attachment.mjs +8 -1
  45. package/esm2022/utils/field/model/date.mjs +13 -3
  46. package/esm2022/utils/field/model/field.mjs +1 -2
  47. package/esm2022/utils/field/model/link.mjs +16 -4
  48. package/esm2022/utils/field/model/member.mjs +1 -1
  49. package/esm2022/utils/field/model/number.mjs +11 -8
  50. package/esm2022/utils/field/model/progress.mjs +7 -7
  51. package/esm2022/utils/field/model/rate.mjs +3 -2
  52. package/esm2022/utils/field/model/rich-text.mjs +1 -1
  53. package/esm2022/utils/field/model/select.mjs +1 -1
  54. package/esm2022/utils/field/model/text.mjs +3 -2
  55. package/esm2022/utils/field/operate.mjs +4 -2
  56. package/esm2022/utils/i18n.mjs +3 -3
  57. package/esm2022/utils/index.mjs +2 -1
  58. package/esm2022/utils/match-keywords.mjs +9 -4
  59. package/esm2022/utils/style.mjs +9 -3
  60. package/fesm2022/ai-table-grid.mjs +2065 -1792
  61. package/fesm2022/ai-table-grid.mjs.map +1 -1
  62. package/grid-base.component.d.ts +6 -5
  63. package/grid-base.component.d.ts.map +1 -1
  64. package/grid.component.d.ts +2 -1
  65. package/grid.component.d.ts.map +1 -1
  66. package/package.json +1 -1
  67. package/renderer/components/cells/attachment.component.d.ts +0 -3
  68. package/renderer/components/cells/attachment.component.d.ts.map +1 -1
  69. package/renderer/components/cells/index.d.ts +2 -1
  70. package/renderer/components/cells/index.d.ts.map +1 -1
  71. package/renderer/components/cells/link.component.d.ts.map +1 -1
  72. package/renderer/components/cells/progress.component.d.ts +82 -0
  73. package/renderer/components/cells/progress.component.d.ts.map +1 -0
  74. package/renderer/components/cells/{richtext.component.d.ts → rich-text.component.d.ts} +4 -4
  75. package/renderer/components/cells/rich-text.component.d.ts.map +1 -0
  76. package/renderer/components/frozen-heads.component.d.ts +1 -0
  77. package/renderer/components/frozen-heads.component.d.ts.map +1 -1
  78. package/renderer/components/hover-row-heads.component.d.ts.map +1 -1
  79. package/renderer/components/icon.component.d.ts.map +1 -1
  80. package/renderer/drawers/add-row-layout-drawer.d.ts.map +1 -1
  81. package/renderer/drawers/cell-drawer.d.ts.map +1 -1
  82. package/renderer/drawers/record-row-layout-drawer.d.ts.map +1 -1
  83. package/utils/cell.d.ts +1 -1
  84. package/utils/cell.d.ts.map +1 -1
  85. package/utils/clipboard/paste.d.ts.map +1 -1
  86. package/utils/field/model/attachment.d.ts.map +1 -1
  87. package/utils/field/model/date.d.ts +1 -0
  88. package/utils/field/model/date.d.ts.map +1 -1
  89. package/utils/field/model/field.d.ts.map +1 -1
  90. package/utils/field/model/link.d.ts +3 -2
  91. package/utils/field/model/link.d.ts.map +1 -1
  92. package/utils/field/model/member.d.ts +1 -1
  93. package/utils/field/model/member.d.ts.map +1 -1
  94. package/utils/field/model/number.d.ts +5 -4
  95. package/utils/field/model/number.d.ts.map +1 -1
  96. package/utils/field/model/progress.d.ts +4 -4
  97. package/utils/field/model/progress.d.ts.map +1 -1
  98. package/utils/field/model/rate.d.ts +2 -2
  99. package/utils/field/model/rate.d.ts.map +1 -1
  100. package/utils/field/model/rich-text.d.ts +3 -3
  101. package/utils/field/model/rich-text.d.ts.map +1 -1
  102. package/utils/field/model/select.d.ts +1 -1
  103. package/utils/field/model/select.d.ts.map +1 -1
  104. package/utils/field/model/text.d.ts +3 -3
  105. package/utils/field/model/text.d.ts.map +1 -1
  106. package/utils/field/operate.d.ts +1 -1
  107. package/utils/field/operate.d.ts.map +1 -1
  108. package/utils/i18n.d.ts +1 -1
  109. package/utils/index.d.ts +1 -0
  110. package/utils/index.d.ts.map +1 -1
  111. package/utils/match-keywords.d.ts.map +1 -1
  112. package/utils/style.d.ts +1 -1
  113. package/utils/style.d.ts.map +1 -1
  114. package/components/cell-editors/progress/progress-editor.component.d.ts +0 -19
  115. package/components/cell-editors/progress/progress-editor.component.d.ts.map +0 -1
  116. package/components/cell-editors/progress/progress-editor.component.scss +0 -29
  117. package/esm2022/components/cell-editors/progress/progress-editor.component.mjs +0 -72
  118. package/esm2022/renderer/components/cells/richtext.component.mjs +0 -90
  119. package/renderer/components/cells/richtext.component.d.ts.map +0 -1
@@ -1,7 +1,7 @@
1
- import { ChangeDetectionStrategy, Component, computed, DestroyRef, ElementRef, inject, input, model, NgZone, output } from '@angular/core';
1
+ import { ChangeDetectionStrategy, Component, computed, DestroyRef, ElementRef, inject, input, model, NgZone, output, signal } from '@angular/core';
2
2
  import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
3
3
  import { mergeWith } from 'rxjs';
4
- import { DBL_CLICK_EDIT_TYPE, MOUSEOVER_EDIT_TYPE } from './constants';
4
+ import { DBL_CLICK_EDIT_TYPE } from './constants';
5
5
  import { AITableFieldType, AITableSelectOptionStyle, createAITable, createDefaultField } from './core';
6
6
  import { AITableGridEventService } from './services/event.service';
7
7
  import { AI_TABLE_GRID_FIELD_SERVICE_MAP, AITableGridFieldService } from './services/field.service';
@@ -15,11 +15,13 @@ export class AITableGridBase {
15
15
  this.aiContextMenuItems = input();
16
16
  this.aiFieldConfig = input();
17
17
  this.aiReadonly = input(false);
18
+ this.aiRowDragDisabled = input(false);
18
19
  this.aiPlugins = input();
19
20
  this.aiReferences = input.required();
20
21
  this.aiBuildRenderDataFn = input();
21
22
  this.aiGetI18nTextByKey = input();
22
23
  this.aiKeywords = input();
24
+ this.refreshRender = signal(0);
23
25
  this.AITableFieldType = AITableFieldType;
24
26
  this.AITableSelectOptionStyle = AITableSelectOptionStyle;
25
27
  this.isSelectedAll = computed(() => {
@@ -32,6 +34,7 @@ export class AITableGridBase {
32
34
  this.aiUpdateFieldValue = output();
33
35
  this.aiSetField = output();
34
36
  this.aiSetFieldWidth = output();
37
+ this.aiMoveRecords = output();
35
38
  this.aiClick = output();
36
39
  this.aiDbClick = output();
37
40
  this.fieldMenus = computed(() => {
@@ -42,6 +45,7 @@ export class AITableGridBase {
42
45
  return [];
43
46
  });
44
47
  this.gridData = computed(() => {
48
+ this.refreshRender();
45
49
  if (this.aiBuildRenderDataFn && this.aiBuildRenderDataFn() && this.aiTable) {
46
50
  return this.aiBuildRenderDataFn()(this.aiTable);
47
51
  }
@@ -80,7 +84,7 @@ export class AITableGridBase {
80
84
  AI_TABLE_GRID_FIELD_SERVICE_MAP.set(this.aiTable, this.aiTableGridFieldService);
81
85
  }
82
86
  addRecord() {
83
- const records = this.aiRecords();
87
+ const records = this.aiTable.gridData().records;
84
88
  const recordCount = records.length;
85
89
  this.aiAddRecord.emit({
86
90
  originId: recordCount > 0 ? records[records.length - 1]._id : ''
@@ -121,12 +125,6 @@ export class AITableGridBase {
121
125
  .subscribe((event) => {
122
126
  this.aiTableGridSelectionService.updateSelect(event);
123
127
  });
124
- this.aiTableGridEventService.mouseoverEvent$.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((event) => {
125
- this.mouseoverHandle(event);
126
- });
127
- this.aiTableGridEventService.globalMouseoverEvent$.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((event) => {
128
- this.closeHoverCellEditor(event);
129
- });
130
128
  });
131
129
  }
132
130
  dblClick(event) {
@@ -136,27 +134,8 @@ export class AITableGridBase {
136
134
  this.aiTableGridEventService.openEdit(cellDom);
137
135
  }
138
136
  }
139
- mouseoverHandle(event) {
140
- if (this.mouseoverRef) {
141
- this.mouseoverRef?.close();
142
- }
143
- const cellDom = event.target.closest('.grid-cell');
144
- const type = cellDom && cellDom.getAttribute('type');
145
- if (type && MOUSEOVER_EDIT_TYPE.includes(type)) {
146
- this.mouseoverRef = this.aiTableGridEventService.openEdit(cellDom);
147
- }
148
- }
149
- closeHoverCellEditor(e) {
150
- if (this.mouseoverRef) {
151
- const hasGrid = e.target && e.target.closest('.ai-table-grid');
152
- const hasCellEditor = e.target && e.target.closest('.grid-cell-editor');
153
- if (!hasGrid && !hasCellEditor) {
154
- this.mouseoverRef.close();
155
- }
156
- }
157
- }
158
137
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableGridBase, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
159
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: AITableGridBase, isStandalone: true, selector: "ai-table-grid-base", inputs: { aiRecords: { classPropertyName: "aiRecords", publicName: "aiRecords", isSignal: true, isRequired: true, transformFunction: null }, aiFields: { classPropertyName: "aiFields", publicName: "aiFields", isSignal: true, isRequired: true, transformFunction: null }, aiFieldsSizeMap: { classPropertyName: "aiFieldsSizeMap", publicName: "aiFieldsSizeMap", isSignal: true, isRequired: true, transformFunction: null }, aiContextMenuItems: { classPropertyName: "aiContextMenuItems", publicName: "aiContextMenuItems", isSignal: true, isRequired: false, transformFunction: null }, aiFieldConfig: { classPropertyName: "aiFieldConfig", publicName: "aiFieldConfig", isSignal: true, isRequired: false, transformFunction: null }, aiReadonly: { classPropertyName: "aiReadonly", publicName: "aiReadonly", isSignal: true, isRequired: false, transformFunction: null }, aiPlugins: { classPropertyName: "aiPlugins", publicName: "aiPlugins", isSignal: true, isRequired: false, transformFunction: null }, aiReferences: { classPropertyName: "aiReferences", publicName: "aiReferences", isSignal: true, isRequired: true, transformFunction: null }, aiBuildRenderDataFn: { classPropertyName: "aiBuildRenderDataFn", publicName: "aiBuildRenderDataFn", isSignal: true, isRequired: false, transformFunction: null }, aiGetI18nTextByKey: { classPropertyName: "aiGetI18nTextByKey", publicName: "aiGetI18nTextByKey", isSignal: true, isRequired: false, transformFunction: null }, aiKeywords: { classPropertyName: "aiKeywords", publicName: "aiKeywords", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { aiRecords: "aiRecordsChange", aiFields: "aiFieldsChange", aiFieldsSizeMap: "aiFieldsSizeMapChange", aiTableInitialized: "aiTableInitialized", aiAddRecord: "aiAddRecord", aiAddField: "aiAddField", aiMoveField: "aiMoveField", aiUpdateFieldValue: "aiUpdateFieldValue", aiSetField: "aiSetField", aiSetFieldWidth: "aiSetFieldWidth", aiClick: "aiClick", aiDbClick: "aiDbClick" }, ngImport: i0, template: '', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
138
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: AITableGridBase, isStandalone: true, selector: "ai-table-grid-base", inputs: { aiRecords: { classPropertyName: "aiRecords", publicName: "aiRecords", isSignal: true, isRequired: true, transformFunction: null }, aiFields: { classPropertyName: "aiFields", publicName: "aiFields", isSignal: true, isRequired: true, transformFunction: null }, aiFieldsSizeMap: { classPropertyName: "aiFieldsSizeMap", publicName: "aiFieldsSizeMap", isSignal: true, isRequired: true, transformFunction: null }, aiContextMenuItems: { classPropertyName: "aiContextMenuItems", publicName: "aiContextMenuItems", isSignal: true, isRequired: false, transformFunction: null }, aiFieldConfig: { classPropertyName: "aiFieldConfig", publicName: "aiFieldConfig", isSignal: true, isRequired: false, transformFunction: null }, aiReadonly: { classPropertyName: "aiReadonly", publicName: "aiReadonly", isSignal: true, isRequired: false, transformFunction: null }, aiRowDragDisabled: { classPropertyName: "aiRowDragDisabled", publicName: "aiRowDragDisabled", isSignal: true, isRequired: false, transformFunction: null }, aiPlugins: { classPropertyName: "aiPlugins", publicName: "aiPlugins", isSignal: true, isRequired: false, transformFunction: null }, aiReferences: { classPropertyName: "aiReferences", publicName: "aiReferences", isSignal: true, isRequired: true, transformFunction: null }, aiBuildRenderDataFn: { classPropertyName: "aiBuildRenderDataFn", publicName: "aiBuildRenderDataFn", isSignal: true, isRequired: false, transformFunction: null }, aiGetI18nTextByKey: { classPropertyName: "aiGetI18nTextByKey", publicName: "aiGetI18nTextByKey", isSignal: true, isRequired: false, transformFunction: null }, aiKeywords: { classPropertyName: "aiKeywords", publicName: "aiKeywords", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { aiRecords: "aiRecordsChange", aiFields: "aiFieldsChange", aiFieldsSizeMap: "aiFieldsSizeMapChange", aiTableInitialized: "aiTableInitialized", aiAddRecord: "aiAddRecord", aiAddField: "aiAddField", aiMoveField: "aiMoveField", aiUpdateFieldValue: "aiUpdateFieldValue", aiSetField: "aiSetField", aiSetFieldWidth: "aiSetFieldWidth", aiMoveRecords: "aiMoveRecords", aiClick: "aiClick", aiDbClick: "aiDbClick" }, ngImport: i0, template: '', isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
160
139
  }
161
140
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableGridBase, decorators: [{
162
141
  type: Component,
@@ -167,4 +146,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
167
146
  changeDetection: ChangeDetectionStrategy.OnPush
168
147
  }]
169
148
  }] });
170
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-base.component.js","sourceRoot":"","sources":["../../../packages/grid/src/grid-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    DestroyRef,\n    ElementRef,\n    inject,\n    input,\n    model,\n    NgZone,\n    OnInit,\n    output,\n    Signal\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { ThyPopoverRef } from 'ngx-tethys/popover';\nimport { mergeWith } from 'rxjs';\nimport { DBL_CLICK_EDIT_TYPE, MOUSEOVER_EDIT_TYPE } from './constants';\nimport {\n    AddFieldOptions,\n    AddRecordOptions,\n    AIPlugin,\n    AITable,\n    AITableField,\n    AITableFields,\n    AITableFieldType,\n    AITableRecords,\n    AITableSelectOptionStyle,\n    AITableValue,\n    createAITable,\n    createDefaultField,\n    MoveFieldOptions,\n    SetFieldWidthOptions,\n    UpdateFieldValueOptions\n} from './core';\nimport { AITableGridEventService } from './services/event.service';\nimport { AI_TABLE_GRID_FIELD_SERVICE_MAP, AITableGridFieldService } from './services/field.service';\nimport { AITableGridSelectionService } from './services/selection.service';\nimport { AIFieldConfig, AITableFieldMenuItem, AITableContextMenuItem, AITableReferences, AITableFieldsSizeMap } from './types';\nimport { AITableFieldSetting } from './components';\nimport { KoEventObjectOutput } from './angular-konva';\nimport { AITableGridI18nKey } from './utils/i18n';\n\n@Component({\n    selector: 'ai-table-grid-base',\n    template: '',\n    standalone: true,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableGridBase implements OnInit {\n    aiRecords = model.required<AITableRecords>();\n\n    aiFields = model.required<AITableFields>();\n\n    aiFieldsSizeMap = model.required<AITableFieldsSizeMap>();\n\n    aiContextMenuItems = input<(aiTable: AITable) => AITableContextMenuItem[]>();\n\n    aiFieldConfig = input<AIFieldConfig>();\n\n    aiReadonly = input<boolean>(false);\n\n    aiPlugins = input<AIPlugin[]>();\n\n    aiReferences = input.required<AITableReferences>();\n\n    aiBuildRenderDataFn = input<(aiTable: AITable) => AITableValue>();\n\n    aiGetI18nTextByKey = input<(key: AITableGridI18nKey | string) => string | undefined>();\n\n    aiKeywords = input<string>();\n\n    AITableFieldType = AITableFieldType;\n\n    AITableSelectOptionStyle = AITableSelectOptionStyle;\n\n    aiTable!: AITable;\n\n    isSelectedAll = computed(() => {\n        return this.aiTable.selection().selectedRecords.size === this.aiRecords().length;\n    });\n\n    aiTableInitialized = output<AITable>();\n\n    aiAddRecord = output<AddRecordOptions>();\n\n    aiAddField = output<AddFieldOptions>();\n\n    aiMoveField = output<MoveFieldOptions>();\n\n    aiUpdateFieldValue = output<UpdateFieldValueOptions>();\n\n    aiSetField = output<AITableField>();\n\n    aiSetFieldWidth = output<SetFieldWidthOptions>();\n\n    aiClick = output<KoEventObjectOutput<MouseEvent>>();\n\n    aiDbClick = output<KoEventObjectOutput<MouseEvent>>();\n\n    fieldMenus: Signal<AITableFieldMenuItem[]> = computed(() => {\n        const fieldMenusFn = this.aiFieldConfig()?.fieldMenus;\n        if (fieldMenusFn && this.aiTable) {\n            return fieldMenusFn(this.aiTable);\n        }\n        return [];\n    });\n\n    mouseoverRef!: ThyPopoverRef<any>;\n\n    gridData = computed(() => {\n        if (this.aiBuildRenderDataFn && this.aiBuildRenderDataFn() && this.aiTable) {\n            return this.aiBuildRenderDataFn()!(this.aiTable);\n        }\n        return {\n            records: this.aiRecords(),\n            fields: this.aiFields(),\n            fieldsSizeMap: this.aiFieldsSizeMap()\n        };\n    });\n\n    protected ngZone = inject(NgZone);\n    protected elementRef = inject(ElementRef);\n    protected destroyRef = inject(DestroyRef);\n    protected aiTableGridFieldService = inject(AITableGridFieldService);\n    protected aiTableGridEventService = inject(AITableGridEventService);\n    protected aiTableGridSelectionService = inject(AITableGridSelectionService);\n\n    ngOnInit(): void {\n        this.initAITable();\n        this.initService();\n    }\n\n    initAITable() {\n        this.aiTable = createAITable(this.aiRecords, this.aiFields, this.gridData);\n        if (this.aiGetI18nTextByKey()) {\n            this.aiTable.getI18nTextByKey = this.aiGetI18nTextByKey() as (key: AITableGridI18nKey | string) => string;\n        }\n        this.aiPlugins()?.forEach((plugin) => {\n            this.aiTable = plugin(this.aiTable);\n        });\n        this.aiTableInitialized.emit(this.aiTable);\n    }\n\n    initService() {\n        this.aiTableGridEventService.initialize(this.aiTable, this.aiFieldConfig()?.fieldRenderers);\n        this.aiTableGridSelectionService.initialize(this.aiTable);\n        this.aiTableGridEventService.registerEvents(this.elementRef.nativeElement);\n        this.aiTableGridFieldService.initAIFieldConfig(this.aiFieldConfig());\n        AI_TABLE_GRID_FIELD_SERVICE_MAP.set(this.aiTable, this.aiTableGridFieldService);\n    }\n\n    addRecord() {\n        const records = this.aiRecords();\n        const recordCount = records.length;\n        this.aiAddRecord.emit({\n            originId: recordCount > 0 ? records[records.length - 1]._id : ''\n        });\n    }\n\n    selectRecord(recordId: string) {\n        this.aiTableGridSelectionService.selectRecord(recordId);\n    }\n\n    toggleSelectAll(checked: boolean) {\n        this.aiTableGridSelectionService.toggleSelectAll(checked);\n    }\n\n    addField(gridColumnBlank?: HTMLElement, position?: { x: number; y: number }) {\n        const field = createDefaultField(this.aiTable, AITableFieldType.text);\n        const popoverRef = this.aiTableGridFieldService.editFieldProperty(this.aiTable, {\n            field,\n            isUpdate: false,\n            origin: gridColumnBlank!,\n            position\n        });\n        if (popoverRef && !this.aiFieldConfig()?.fieldSettingComponent) {\n            (popoverRef.componentInstance as AITableFieldSetting).addField.subscribe((defaultValue) => {\n                const fields = this.gridData().fields;\n                const fieldCount = fields.length;\n                this.aiAddField.emit({\n                    originId: fieldCount > 0 ? fields[fields.length - 1]._id : '',\n                    defaultValue\n                });\n            });\n        }\n    }\n\n    public subscribeEvents() {\n        this.ngZone.runOutsideAngular(() => {\n            this.aiTableGridEventService.dblClickEvent$.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((event) => {\n                this.dblClick(event);\n            });\n            this.aiTableGridEventService.mousedownEvent$\n                .pipe(mergeWith(this.aiTableGridEventService.globalMousedownEvent$), takeUntilDestroyed(this.destroyRef))\n                .subscribe((event) => {\n                    this.aiTableGridSelectionService.updateSelect(event);\n                });\n\n            this.aiTableGridEventService.mouseoverEvent$.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((event) => {\n                this.mouseoverHandle(event);\n            });\n            this.aiTableGridEventService.globalMouseoverEvent$.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((event) => {\n                this.closeHoverCellEditor(event);\n            });\n        });\n    }\n\n    private dblClick(event: MouseEvent) {\n        const cellDom = (event.target as HTMLElement).closest('.grid-cell') as HTMLElement;\n        const type = cellDom && (cellDom.getAttribute('type')! as AITableFieldType);\n        if (type && DBL_CLICK_EDIT_TYPE.includes(type)) {\n            this.aiTableGridEventService.openEdit(cellDom);\n        }\n    }\n\n    private mouseoverHandle(event: MouseEvent) {\n        if (this.mouseoverRef) {\n            this.mouseoverRef?.close();\n        }\n        const cellDom = (event.target as HTMLElement).closest('.grid-cell') as HTMLElement;\n        const type = cellDom && (cellDom.getAttribute('type')! as AITableFieldType);\n        if (type && MOUSEOVER_EDIT_TYPE.includes(type)) {\n            this.mouseoverRef = this.aiTableGridEventService.openEdit(cellDom);\n        }\n    }\n\n    private closeHoverCellEditor(e: MouseEvent) {\n        if (this.mouseoverRef) {\n            const hasGrid = e.target && (e.target as HTMLElement).closest('.ai-table-grid');\n            const hasCellEditor = e.target && (e.target as HTMLElement).closest('.grid-cell-editor');\n            if (!hasGrid && !hasCellEditor) {\n                this.mouseoverRef.close();\n            }\n        }\n    }\n}\n"]}
149
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-base.component.js","sourceRoot":"","sources":["../../../packages/grid/src/grid-base.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    DestroyRef,\n    ElementRef,\n    inject,\n    input,\n    model,\n    NgZone,\n    OnInit,\n    output,\n    signal,\n    Signal,\n    WritableSignal\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { ThyPopoverRef } from 'ngx-tethys/popover';\nimport { mergeWith } from 'rxjs';\nimport { DBL_CLICK_EDIT_TYPE } from './constants';\nimport {\n    AddFieldOptions,\n    AddRecordOptions,\n    AIPlugin,\n    AITable,\n    AITableField,\n    AITableFields,\n    AITableFieldType,\n    AITableRecords,\n    AITableSelectOptionStyle,\n    AITableValue,\n    createAITable,\n    createDefaultField,\n    MoveFieldOptions,\n    MoveRecordOptions,\n    SetFieldWidthOptions,\n    UpdateFieldValueOptions\n} from './core';\nimport { AITableGridEventService } from './services/event.service';\nimport { AI_TABLE_GRID_FIELD_SERVICE_MAP, AITableGridFieldService } from './services/field.service';\nimport { AITableGridSelectionService } from './services/selection.service';\nimport { AIFieldConfig, AITableFieldMenuItem, AITableContextMenuItem, AITableReferences, AITableFieldsSizeMap } from './types';\nimport { AITableFieldSetting } from './components';\nimport { KoEventObjectOutput } from './angular-konva';\nimport { AITableGridI18nKey } from './utils/i18n';\n\n@Component({\n    selector: 'ai-table-grid-base',\n    template: '',\n    standalone: true,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableGridBase implements OnInit {\n    aiRecords = model.required<AITableRecords>();\n\n    aiFields = model.required<AITableFields>();\n\n    aiFieldsSizeMap = model.required<AITableFieldsSizeMap>();\n\n    aiContextMenuItems = input<(aiTable: AITable) => AITableContextMenuItem[]>();\n\n    aiFieldConfig = input<AIFieldConfig>();\n\n    aiReadonly = input<boolean>(false);\n\n    aiRowDragDisabled = input<boolean>(false);\n\n    aiPlugins = input<AIPlugin[]>();\n\n    aiReferences = input.required<AITableReferences>();\n\n    aiBuildRenderDataFn = input<(aiTable: AITable) => AITableValue>();\n\n    aiGetI18nTextByKey = input<(key: AITableGridI18nKey | string) => string | undefined>();\n\n    aiKeywords = input<string>();\n\n    refreshRender: WritableSignal<number> = signal(0);\n\n    AITableFieldType = AITableFieldType;\n\n    AITableSelectOptionStyle = AITableSelectOptionStyle;\n\n    aiTable!: AITable;\n\n    isSelectedAll = computed(() => {\n        return this.aiTable.selection().selectedRecords.size === this.aiRecords().length;\n    });\n\n    aiTableInitialized = output<AITable>();\n\n    aiAddRecord = output<AddRecordOptions>();\n\n    aiAddField = output<AddFieldOptions>();\n\n    aiMoveField = output<MoveFieldOptions>();\n\n    aiUpdateFieldValue = output<UpdateFieldValueOptions>();\n\n    aiSetField = output<AITableField>();\n\n    aiSetFieldWidth = output<SetFieldWidthOptions>();\n\n    aiMoveRecords = output<MoveRecordOptions>();\n\n    aiClick = output<KoEventObjectOutput<MouseEvent>>();\n\n    aiDbClick = output<KoEventObjectOutput<MouseEvent>>();\n\n    fieldMenus: Signal<AITableFieldMenuItem[]> = computed(() => {\n        const fieldMenusFn = this.aiFieldConfig()?.fieldMenus;\n        if (fieldMenusFn && this.aiTable) {\n            return fieldMenusFn(this.aiTable);\n        }\n        return [];\n    });\n\n    mouseoverRef!: ThyPopoverRef<any>;\n\n    gridData = computed(() => {\n        this.refreshRender();\n        if (this.aiBuildRenderDataFn && this.aiBuildRenderDataFn() && this.aiTable) {\n            return this.aiBuildRenderDataFn()!(this.aiTable);\n        }\n        return {\n            records: this.aiRecords(),\n            fields: this.aiFields(),\n            fieldsSizeMap: this.aiFieldsSizeMap()\n        };\n    });\n\n    protected ngZone = inject(NgZone);\n    protected elementRef = inject(ElementRef);\n    protected destroyRef = inject(DestroyRef);\n    protected aiTableGridFieldService = inject(AITableGridFieldService);\n    protected aiTableGridEventService = inject(AITableGridEventService);\n    protected aiTableGridSelectionService = inject(AITableGridSelectionService);\n\n    ngOnInit(): void {\n        this.initAITable();\n        this.initService();\n    }\n\n    initAITable() {\n        this.aiTable = createAITable(this.aiRecords, this.aiFields, this.gridData);\n        if (this.aiGetI18nTextByKey()) {\n            this.aiTable.getI18nTextByKey = this.aiGetI18nTextByKey() as (key: AITableGridI18nKey | string) => string;\n        }\n        this.aiPlugins()?.forEach((plugin) => {\n            this.aiTable = plugin(this.aiTable);\n        });\n        this.aiTableInitialized.emit(this.aiTable);\n    }\n\n    initService() {\n        this.aiTableGridEventService.initialize(this.aiTable, this.aiFieldConfig()?.fieldRenderers);\n        this.aiTableGridSelectionService.initialize(this.aiTable);\n        this.aiTableGridEventService.registerEvents(this.elementRef.nativeElement);\n        this.aiTableGridFieldService.initAIFieldConfig(this.aiFieldConfig());\n        AI_TABLE_GRID_FIELD_SERVICE_MAP.set(this.aiTable, this.aiTableGridFieldService);\n    }\n\n    addRecord() {\n        const records = this.aiTable.gridData().records;\n        const recordCount = records.length;\n        this.aiAddRecord.emit({\n            originId: recordCount > 0 ? records[records.length - 1]._id : ''\n        });\n    }\n\n    selectRecord(recordId: string) {\n        this.aiTableGridSelectionService.selectRecord(recordId);\n    }\n\n    toggleSelectAll(checked: boolean) {\n        this.aiTableGridSelectionService.toggleSelectAll(checked);\n    }\n\n    addField(gridColumnBlank?: HTMLElement, position?: { x: number; y: number }) {\n        const field = createDefaultField(this.aiTable, AITableFieldType.text);\n        const popoverRef = this.aiTableGridFieldService.editFieldProperty(this.aiTable, {\n            field,\n            isUpdate: false,\n            origin: gridColumnBlank!,\n            position\n        });\n        if (popoverRef && !this.aiFieldConfig()?.fieldSettingComponent) {\n            (popoverRef.componentInstance as AITableFieldSetting).addField.subscribe((defaultValue) => {\n                const fields = this.gridData().fields;\n                const fieldCount = fields.length;\n                this.aiAddField.emit({\n                    originId: fieldCount > 0 ? fields[fields.length - 1]._id : '',\n                    defaultValue\n                });\n            });\n        }\n    }\n\n    public subscribeEvents() {\n        this.ngZone.runOutsideAngular(() => {\n            this.aiTableGridEventService.dblClickEvent$.pipe(takeUntilDestroyed(this.destroyRef)).subscribe((event) => {\n                this.dblClick(event);\n            });\n            this.aiTableGridEventService.mousedownEvent$\n                .pipe(mergeWith(this.aiTableGridEventService.globalMousedownEvent$), takeUntilDestroyed(this.destroyRef))\n                .subscribe((event) => {\n                    this.aiTableGridSelectionService.updateSelect(event);\n                });\n        });\n    }\n\n    private dblClick(event: MouseEvent) {\n        const cellDom = (event.target as HTMLElement).closest('.grid-cell') as HTMLElement;\n        const type = cellDom && (cellDom.getAttribute('type')! as AITableFieldType);\n        if (type && DBL_CLICK_EDIT_TYPE.includes(type)) {\n            this.aiTableGridEventService.openEdit(cellDom);\n        }\n    }\n}\n"]}