@ai-table/grid 0.0.67 → 0.0.69

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 (48) hide show
  1. package/core/context.d.ts +1 -0
  2. package/core/context.d.ts.map +1 -1
  3. package/esm2022/components/drag/drag.component.mjs +3 -3
  4. package/esm2022/core/context.mjs +3 -2
  5. package/esm2022/grid.component.mjs +3 -2
  6. package/esm2022/renderer/components/frozen-heads.component.mjs +123 -38
  7. package/esm2022/renderer/components/hover-cell.component.mjs +4 -3
  8. package/esm2022/renderer/components/hover-row-heads.component.mjs +3 -3
  9. package/esm2022/renderer/creations/create-cells.mjs +10 -5
  10. package/esm2022/renderer/drawers/add-row-layout-drawer.mjs +7 -7
  11. package/esm2022/renderer/drawers/layout-drawer.mjs +7 -3
  12. package/esm2022/renderer/drawers/record-row-layout-drawer.mjs +46 -30
  13. package/esm2022/renderer/renderer.component.mjs +7 -5
  14. package/esm2022/types/grid.mjs +1 -1
  15. package/esm2022/types/layout.mjs +1 -1
  16. package/esm2022/utils/cell.mjs +4 -1
  17. package/esm2022/utils/clipboard/copy.mjs +4 -4
  18. package/esm2022/utils/field/model/date.mjs +5 -1
  19. package/esm2022/utils/field/model/rich-text.mjs +6 -3
  20. package/esm2022/utils/match-keywords.mjs +2 -3
  21. package/esm2022/utils/position.mjs +6 -6
  22. package/esm2022/utils/visible-range.mjs +3 -3
  23. package/fesm2022/ai-table-grid.mjs +217 -91
  24. package/fesm2022/ai-table-grid.mjs.map +1 -1
  25. package/grid.component.d.ts.map +1 -1
  26. package/package.json +1 -1
  27. package/renderer/components/frozen-heads.component.d.ts +39 -3
  28. package/renderer/components/frozen-heads.component.d.ts.map +1 -1
  29. package/renderer/components/hover-cell.component.d.ts.map +1 -1
  30. package/renderer/components/hover-row-heads.component.d.ts.map +1 -1
  31. package/renderer/creations/create-cells.d.ts.map +1 -1
  32. package/renderer/drawers/add-row-layout-drawer.d.ts.map +1 -1
  33. package/renderer/drawers/layout-drawer.d.ts +3 -1
  34. package/renderer/drawers/layout-drawer.d.ts.map +1 -1
  35. package/renderer/drawers/record-row-layout-drawer.d.ts.map +1 -1
  36. package/renderer/renderer.component.d.ts +1 -0
  37. package/renderer/renderer.component.d.ts.map +1 -1
  38. package/types/grid.d.ts +2 -0
  39. package/types/grid.d.ts.map +1 -1
  40. package/types/layout.d.ts +2 -0
  41. package/types/layout.d.ts.map +1 -1
  42. package/utils/cell.d.ts.map +1 -1
  43. package/utils/field/model/date.d.ts +2 -1
  44. package/utils/field/model/date.d.ts.map +1 -1
  45. package/utils/field/model/rich-text.d.ts +2 -1
  46. package/utils/field/model/rich-text.d.ts.map +1 -1
  47. package/utils/position.d.ts +1 -1
  48. package/utils/position.d.ts.map +1 -1
@@ -1,6 +1,6 @@
1
1
  import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';
2
2
  import { KoShape, KoContainer } from '../../angular-konva';
3
- import { AI_TABLE_CELL_PADDING, AI_TABLE_FIELD_HEAD_SELECT_CHECKBOX, AI_TABLE_ICON_COMMON_SIZE, AI_TABLE_OFFSET, AI_TABLE_ROW_DRAG_ICON_WIDTH, AI_TABLE_ROW_HEAD_WIDTH, Colors } from '../../constants';
3
+ import { AI_TABLE_CELL_PADDING, AI_TABLE_FIELD_HEAD_SELECT_CHECKBOX, AI_TABLE_ICON_COMMON_SIZE, AI_TABLE_OFFSET, AI_TABLE_ROW_DRAG_ICON_WIDTH, Colors } from '../../constants';
4
4
  import { AITableCheckType, AITableSelectAllState } from '../../types';
5
5
  import { createColumnHeads } from '../creations/create-heads';
6
6
  import { AITableFieldHead } from './field-head.component';
@@ -10,20 +10,43 @@ export class AITableFrozenColumnHeads {
10
10
  constructor() {
11
11
  this.config = input.required();
12
12
  this.coordinate = computed(() => {
13
- return this.config().coordinate;
13
+ const config = this.config();
14
+ if (!config)
15
+ return null;
16
+ return config.coordinate;
17
+ });
18
+ this.hiddenIndexColumn = computed(() => {
19
+ const context = this.context();
20
+ if (!context)
21
+ return false;
22
+ return context?.aiFieldConfig()?.hiddenIndexColumn;
23
+ });
24
+ this.context = computed(() => {
25
+ const config = this.config();
26
+ if (!config)
27
+ return null;
28
+ return config?.aiTable.context;
14
29
  });
15
30
  this.isChecked = computed(() => {
16
- // 目前只需要展示全部选中和空的状态
17
- return this.config().aiTable.selection().selectAllState === AITableSelectAllState.all;
31
+ const config = this.config();
32
+ if (!config)
33
+ return false;
34
+ return config.aiTable.selection().selectAllState === AITableSelectAllState.all;
18
35
  });
19
36
  this.fieldHeadHeight = computed(() => {
20
- return this.coordinate().rowInitSize;
37
+ const coord = this.coordinate();
38
+ if (!coord)
39
+ return 0;
40
+ return coord.rowInitSize;
21
41
  });
22
42
  this.headConfigs = computed(() => {
43
+ const coord = this.coordinate();
44
+ if (!coord)
45
+ return [];
23
46
  return createColumnHeads({
24
47
  ...this.config(),
25
48
  columnStartIndex: 0,
26
- columnStopIndex: this.coordinate().frozenColumnCount - 1
49
+ columnStopIndex: coord.frozenColumnCount - 1
27
50
  });
28
51
  });
29
52
  this.dragHeadBgConfig = computed(() => {
@@ -37,28 +60,39 @@ export class AITableFrozenColumnHeads {
37
60
  };
38
61
  });
39
62
  this.numberHeadBgConfig = computed(() => {
63
+ const ctx = this.context();
64
+ if (!ctx)
65
+ return { width: 0, height: 0 };
40
66
  return {
41
67
  x: AI_TABLE_OFFSET,
42
68
  y: AI_TABLE_OFFSET,
43
- width: AI_TABLE_ROW_HEAD_WIDTH,
69
+ width: ctx.rowHeadWidth() || 0,
44
70
  height: this.fieldHeadHeight(),
45
71
  fill: Colors.white,
46
72
  listening: false
47
73
  };
48
74
  });
49
- this.topLineConfig = {
50
- x: AI_TABLE_OFFSET + AI_TABLE_ROW_DRAG_ICON_WIDTH,
51
- y: AI_TABLE_OFFSET,
52
- points: [0, 0, AI_TABLE_ROW_HEAD_WIDTH, 0],
53
- stroke: Colors.gray200,
54
- strokeWidth: 1,
55
- listening: false
56
- };
75
+ this.topLineConfig = computed(() => {
76
+ const ctx = this.context();
77
+ if (!ctx)
78
+ return { points: [0, 0, 0, 0] };
79
+ return {
80
+ x: AI_TABLE_OFFSET + AI_TABLE_ROW_DRAG_ICON_WIDTH,
81
+ y: AI_TABLE_OFFSET,
82
+ points: [0, 0, ctx.rowHeadWidth(), 0],
83
+ stroke: Colors.gray200,
84
+ strokeWidth: 1,
85
+ listening: false
86
+ };
87
+ });
57
88
  this.bottomLineConfig = computed(() => {
89
+ const ctx = this.context();
90
+ if (!ctx)
91
+ return { points: [0, 0, 0, 0] };
58
92
  return {
59
93
  x: AI_TABLE_OFFSET + AI_TABLE_ROW_DRAG_ICON_WIDTH,
60
94
  y: AI_TABLE_OFFSET,
61
- points: [AI_TABLE_ROW_HEAD_WIDTH, this.fieldHeadHeight(), 0, this.fieldHeadHeight()],
95
+ points: [ctx.rowHeadWidth(), this.fieldHeadHeight(), 0, this.fieldHeadHeight()],
62
96
  stroke: Colors.gray200,
63
97
  strokeWidth: 1,
64
98
  listening: false
@@ -76,32 +110,77 @@ export class AITableFrozenColumnHeads {
76
110
  };
77
111
  });
78
112
  this.headBgConfig = computed(() => {
79
- const { frozenColumnWidth } = this.coordinate();
113
+ const coord = this.coordinate();
114
+ const ctx = this.context();
115
+ if (!coord || !ctx)
116
+ return { width: 0, height: 0 };
80
117
  return {
81
- x: AI_TABLE_ROW_HEAD_WIDTH,
118
+ x: ctx.rowHeadWidth(),
82
119
  y: AI_TABLE_OFFSET,
83
- width: frozenColumnWidth + AI_TABLE_OFFSET,
120
+ width: coord.frozenColumnWidth + AI_TABLE_OFFSET,
84
121
  height: this.fieldHeadHeight(),
85
122
  stroke: Colors.gray200,
86
- strokeWidth: 1,
123
+ strokeWidth: this.hiddenIndexColumn() ? 0 : 1,
87
124
  fill: Colors.transparent,
88
- listening: false
125
+ listening: false,
126
+ zIndex: 10
89
127
  };
90
128
  });
129
+ this.cellLinesConfig = computed(() => {
130
+ const coord = this.coordinate();
131
+ const ctx = this.context();
132
+ if (!coord || !ctx)
133
+ return [];
134
+ return [
135
+ {
136
+ x: ctx.rowHeadWidth(),
137
+ y: AI_TABLE_OFFSET,
138
+ points: [0, 0, coord.frozenColumnWidth + AI_TABLE_OFFSET, 0],
139
+ stroke: Colors.gray200,
140
+ strokeWidth: 1,
141
+ listening: false,
142
+ zIndex: 10
143
+ },
144
+ {
145
+ x: ctx.rowHeadWidth(),
146
+ y: AI_TABLE_OFFSET,
147
+ points: [coord.frozenColumnWidth + AI_TABLE_OFFSET, 0, coord.frozenColumnWidth + AI_TABLE_OFFSET, this.fieldHeadHeight()],
148
+ stroke: Colors.gray200,
149
+ strokeWidth: 1,
150
+ listening: false,
151
+ zIndex: 10
152
+ },
153
+ {
154
+ x: ctx.rowHeadWidth(),
155
+ y: AI_TABLE_OFFSET,
156
+ points: [0, this.fieldHeadHeight(), coord.frozenColumnWidth + AI_TABLE_OFFSET, this.fieldHeadHeight()],
157
+ stroke: Colors.gray200,
158
+ strokeWidth: 1,
159
+ listening: false,
160
+ zIndex: 10
161
+ }
162
+ ];
163
+ });
91
164
  }
92
165
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableFrozenColumnHeads, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
93
166
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: AITableFrozenColumnHeads, isStandalone: true, selector: "ai-table-frozen-column-heads", inputs: { config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: `
94
- <ko-rect [config]="dragHeadBgConfig()"></ko-rect>
95
- <ko-rect [config]="numberHeadBgConfig()"></ko-rect>
96
- <ko-line [config]="topLineConfig"></ko-line>
97
- <ko-line [config]="bottomLineConfig()"></ko-line>
98
- <ko-group>
99
- <ai-table-icon [config]="iconConfig()"></ai-table-icon>
100
- </ko-group>
167
+ <ko-rect [config]="headBgConfig()"></ko-rect>
168
+ @if (!hiddenIndexColumn()) {
169
+ <ko-rect [config]="dragHeadBgConfig()"></ko-rect>
170
+ <ko-rect [config]="numberHeadBgConfig()"></ko-rect>
171
+ <ko-line [config]="topLineConfig()"></ko-line>
172
+ <ko-line [config]="bottomLineConfig()"></ko-line>
173
+ <ko-group>
174
+ <ai-table-icon [config]="iconConfig()"></ai-table-icon>
175
+ </ko-group>
176
+ } @else {
177
+ @for (lineConfig of cellLinesConfig(); track $index) {
178
+ <ko-line [config]="lineConfig"></ko-line>
179
+ }
180
+ }
101
181
  @for (config of headConfigs(); track $index) {
102
182
  <ai-table-field-head [config]="config"></ai-table-field-head>
103
183
  }
104
- <ko-rect [config]="headBgConfig()"></ko-rect>
105
184
  `, isInline: true, dependencies: [{ kind: "component", type: KoShape, selector: "ko-shape, ko-circle, ko-label, ko-rect, ko-ellipse, ko-wedge, ko-line, ko-sprite, ko-image, ko-text, ko-text-path, ko-star, ko-ring, ko-arc, ko-tag, ko-path, ko-regular-polygon, ko-arrow, ko-transformer", inputs: ["config"], outputs: ["koMouseover", "koMousemove", "koMouseout", "koMouseenter", "koMouseleave", "koMousedown", "koMouseup", "koWheel", "koContextmenu", "koClick", "koDblclick", "koTouchstart", "koTouchmove", "koTouchend", "koTap", "koDbltap", "koDragstart", "koDragmove", "koDragend"] }, { kind: "component", type: AITableFieldHead, selector: "ai-table-field-head", inputs: ["config"] }, { kind: "component", type: AITableIcon, selector: "ai-table-icon", inputs: ["config"] }, { kind: "component", type: KoContainer, selector: "ko-layer, ko-fastlayer, ko-group" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
106
185
  }
107
186
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableFrozenColumnHeads, decorators: [{
@@ -109,21 +188,27 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
109
188
  args: [{
110
189
  selector: 'ai-table-frozen-column-heads',
111
190
  template: `
112
- <ko-rect [config]="dragHeadBgConfig()"></ko-rect>
113
- <ko-rect [config]="numberHeadBgConfig()"></ko-rect>
114
- <ko-line [config]="topLineConfig"></ko-line>
115
- <ko-line [config]="bottomLineConfig()"></ko-line>
116
- <ko-group>
117
- <ai-table-icon [config]="iconConfig()"></ai-table-icon>
118
- </ko-group>
191
+ <ko-rect [config]="headBgConfig()"></ko-rect>
192
+ @if (!hiddenIndexColumn()) {
193
+ <ko-rect [config]="dragHeadBgConfig()"></ko-rect>
194
+ <ko-rect [config]="numberHeadBgConfig()"></ko-rect>
195
+ <ko-line [config]="topLineConfig()"></ko-line>
196
+ <ko-line [config]="bottomLineConfig()"></ko-line>
197
+ <ko-group>
198
+ <ai-table-icon [config]="iconConfig()"></ai-table-icon>
199
+ </ko-group>
200
+ } @else {
201
+ @for (lineConfig of cellLinesConfig(); track $index) {
202
+ <ko-line [config]="lineConfig"></ko-line>
203
+ }
204
+ }
119
205
  @for (config of headConfigs(); track $index) {
120
206
  <ai-table-field-head [config]="config"></ai-table-field-head>
121
207
  }
122
- <ko-rect [config]="headBgConfig()"></ko-rect>
123
208
  `,
124
209
  standalone: true,
125
210
  imports: [KoShape, AITableFieldHead, AITableIcon, KoContainer],
126
211
  changeDetection: ChangeDetectionStrategy.OnPush
127
212
  }]
128
213
  }] });
129
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"frozen-heads.component.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/components/frozen-heads.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAEpF,OAAO,EAAE,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAC3D,OAAO,EACH,qBAAqB,EACrB,mCAAmC,EACnC,yBAAyB,EACzB,eAAe,EACf,4BAA4B,EAC5B,uBAAuB,EACvB,MAAM,EACT,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,gBAAgB,EAA4B,qBAAqB,EAAE,MAAM,aAAa,CAAC;AAChG,OAAO,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAC9D,OAAO,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAC1D,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;;AAqB/C,MAAM,OAAO,wBAAwB;IAnBrC;QAoBI,WAAM,GAAG,KAAK,CAAC,QAAQ,EAA4B,CAAC;QAEpD,eAAU,GAAG,QAAQ,CAAC,GAAG,EAAE;YACvB,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC,UAAU,CAAC;QACpC,CAAC,CAAC,CAAC;QAEH,cAAS,GAAG,QAAQ,CAAC,GAAG,EAAE;YACtB,mBAAmB;YACnB,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,SAAS,EAAE,CAAC,cAAc,KAAK,qBAAqB,CAAC,GAAG,CAAC;QAC1F,CAAC,CAAC,CAAC;QAEH,oBAAe,GAAG,QAAQ,CAAC,GAAG,EAAE;YAC5B,OAAO,IAAI,CAAC,UAAU,EAAE,CAAC,WAAW,CAAC;QACzC,CAAC,CAAC,CAAC;QAEH,gBAAW,GAAG,QAAQ,CAAC,GAAG,EAAE;YACxB,OAAO,iBAAiB,CAAC;gBACrB,GAAG,IAAI,CAAC,MAAM,EAAE;gBAChB,gBAAgB,EAAE,CAAC;gBACnB,eAAe,EAAE,IAAI,CAAC,UAAU,EAAE,CAAC,iBAAiB,GAAG,CAAC;aAC3D,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;QAEH,qBAAgB,GAAG,QAAQ,CAAuB,GAAG,EAAE;YACnD,OAAO;gBACH,CAAC,EAAE,eAAe;gBAClB,CAAC,EAAE,eAAe;gBAClB,KAAK,EAAE,4BAA4B;gBACnC,MAAM,EAAE,IAAI,CAAC,eAAe,EAAE;gBAC9B,IAAI,EAAE,MAAM,CAAC,KAAK;gBAClB,SAAS,EAAE,KAAK;aACnB,CAAC;QACN,CAAC,CAAC,CAAC;QAEH,uBAAkB,GAAG,QAAQ,CAAuB,GAAG,EAAE;YACrD,OAAO;gBACH,CAAC,EAAE,eAAe;gBAClB,CAAC,EAAE,eAAe;gBAClB,KAAK,EAAE,uBAAuB;gBAC9B,MAAM,EAAE,IAAI,CAAC,eAAe,EAAE;gBAC9B,IAAI,EAAE,MAAM,CAAC,KAAK;gBAClB,SAAS,EAAE,KAAK;aACnB,CAAC;QACN,CAAC,CAAC,CAAC;QAEH,kBAAa,GAAG;YACZ,CAAC,EAAE,eAAe,GAAG,4BAA4B;YACjD,CAAC,EAAE,eAAe;YAClB,MAAM,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,uBAAuB,EAAE,CAAC,CAAC;YAC1C,MAAM,EAAE,MAAM,CAAC,OAAO;YACtB,WAAW,EAAE,CAAC;YACd,SAAS,EAAE,KAAK;SACnB,CAAC;QAEF,qBAAgB,GAAG,QAAQ,CAAC,GAAG,EAAE;YAC7B,OAAO;gBACH,CAAC,EAAE,eAAe,GAAG,4BAA4B;gBACjD,CAAC,EAAE,eAAe;gBAClB,MAAM,EAAE,CAAC,uBAAuB,EAAE,IAAI,CAAC,eAAe,EAAE,EAAE,CAAC,EAAE,IAAI,CAAC,eAAe,EAAE,CAAC;gBACpF,MAAM,EAAE,MAAM,CAAC,OAAO;gBACtB,WAAW,EAAE,CAAC;gBACd,SAAS,EAAE,KAAK;aACnB,CAAC;QACN,CAAC,CAAC,CAAC;QAEH,eAAU,GAAG,QAAQ,CAAC,GAAG,EAAE;YACvB,OAAO;gBACH,IAAI,EAAE,mCAAmC;gBACzC,CAAC,EAAE,qBAAqB,GAAG,4BAA4B;gBACvD,CAAC,EAAE,CAAC,IAAI,CAAC,eAAe,EAAE,GAAG,yBAAyB,CAAC,GAAG,CAAC;gBAC3D,IAAI,EAAE,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,CAAC,gBAAgB,CAAC,SAAS;gBAC9E,IAAI,EACA,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,aAAa,CAAC,UAAU,KAAK,mCAAmC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC;oBACrH,CAAC,CAAC,MAAM,CAAC,OAAO;oBAChB,CAAC,CAAC,MAAM,CAAC,OAAO;aAC3B,CAAC;QACN,CAAC,CAAC,CAAC;QAEH,iBAAY,GAAG,QAAQ,CAAC,GAAG,EAAE;YACzB,MAAM,EAAE,iBAAiB,EAAE,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;YAChD,OAAO;gBACH,CAAC,EAAE,uBAAuB;gBAC1B,CAAC,EAAE,eAAe;gBAClB,KAAK,EAAE,iBAAiB,GAAG,eAAe;gBAC1C,MAAM,EAAE,IAAI,CAAC,eAAe,EAAE;gBAC9B,MAAM,EAAE,MAAM,CAAC,OAAO;gBACtB,WAAW,EAAE,CAAC;gBACd,IAAI,EAAE,MAAM,CAAC,WAAW;gBACxB,SAAS,EAAE,KAAK;aACnB,CAAC;QACN,CAAC,CAAC,CAAC;KACN;+GA5FY,wBAAwB;mGAAxB,wBAAwB,8NAjBvB;;;;;;;;;;;;KAYT,4DAES,OAAO,+hBAAE,gBAAgB,oFAAE,WAAW,8EAAE,WAAW;;4FAGpD,wBAAwB;kBAnBpC,SAAS;mBAAC;oBACP,QAAQ,EAAE,8BAA8B;oBACxC,QAAQ,EAAE;;;;;;;;;;;;KAYT;oBACD,UAAU,EAAE,IAAI;oBAChB,OAAO,EAAE,CAAC,OAAO,EAAE,gBAAgB,EAAE,WAAW,EAAE,WAAW,CAAC;oBAC9D,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAClD","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';\nimport { StageConfig } from 'konva/lib/Stage';\nimport { KoShape, KoContainer } from '../../angular-konva';\nimport {\n    AI_TABLE_CELL_PADDING,\n    AI_TABLE_FIELD_HEAD_SELECT_CHECKBOX,\n    AI_TABLE_ICON_COMMON_SIZE,\n    AI_TABLE_OFFSET,\n    AI_TABLE_ROW_DRAG_ICON_WIDTH,\n    AI_TABLE_ROW_HEAD_WIDTH,\n    Colors\n} from '../../constants';\nimport { AITableCheckType, AITableColumnHeadsConfig, AITableSelectAllState } from '../../types';\nimport { createColumnHeads } from '../creations/create-heads';\nimport { AITableFieldHead } from './field-head.component';\nimport { AITableIcon } from './icon.component';\n\n@Component({\n    selector: 'ai-table-frozen-column-heads',\n    template: `\n        <ko-rect [config]=\"dragHeadBgConfig()\"></ko-rect>\n        <ko-rect [config]=\"numberHeadBgConfig()\"></ko-rect>\n        <ko-line [config]=\"topLineConfig\"></ko-line>\n        <ko-line [config]=\"bottomLineConfig()\"></ko-line>\n        <ko-group>\n            <ai-table-icon [config]=\"iconConfig()\"></ai-table-icon>\n        </ko-group>\n        @for (config of headConfigs(); track $index) {\n            <ai-table-field-head [config]=\"config\"></ai-table-field-head>\n        }\n        <ko-rect [config]=\"headBgConfig()\"></ko-rect>\n    `,\n    standalone: true,\n    imports: [KoShape, AITableFieldHead, AITableIcon, KoContainer],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableFrozenColumnHeads {\n    config = input.required<AITableColumnHeadsConfig>();\n\n    coordinate = computed(() => {\n        return this.config().coordinate;\n    });\n\n    isChecked = computed(() => {\n        // 目前只需要展示全部选中和空的状态\n        return this.config().aiTable.selection().selectAllState === AITableSelectAllState.all;\n    });\n\n    fieldHeadHeight = computed(() => {\n        return this.coordinate().rowInitSize;\n    });\n\n    headConfigs = computed(() => {\n        return createColumnHeads({\n            ...this.config(),\n            columnStartIndex: 0,\n            columnStopIndex: this.coordinate().frozenColumnCount - 1\n        });\n    });\n\n    dragHeadBgConfig = computed<Partial<StageConfig>>(() => {\n        return {\n            x: AI_TABLE_OFFSET,\n            y: AI_TABLE_OFFSET,\n            width: AI_TABLE_ROW_DRAG_ICON_WIDTH,\n            height: this.fieldHeadHeight(),\n            fill: Colors.white,\n            listening: false\n        };\n    });\n\n    numberHeadBgConfig = computed<Partial<StageConfig>>(() => {\n        return {\n            x: AI_TABLE_OFFSET,\n            y: AI_TABLE_OFFSET,\n            width: AI_TABLE_ROW_HEAD_WIDTH,\n            height: this.fieldHeadHeight(),\n            fill: Colors.white,\n            listening: false\n        };\n    });\n\n    topLineConfig = {\n        x: AI_TABLE_OFFSET + AI_TABLE_ROW_DRAG_ICON_WIDTH,\n        y: AI_TABLE_OFFSET,\n        points: [0, 0, AI_TABLE_ROW_HEAD_WIDTH, 0],\n        stroke: Colors.gray200,\n        strokeWidth: 1,\n        listening: false\n    };\n\n    bottomLineConfig = computed(() => {\n        return {\n            x: AI_TABLE_OFFSET + AI_TABLE_ROW_DRAG_ICON_WIDTH,\n            y: AI_TABLE_OFFSET,\n            points: [AI_TABLE_ROW_HEAD_WIDTH, this.fieldHeadHeight(), 0, this.fieldHeadHeight()],\n            stroke: Colors.gray200,\n            strokeWidth: 1,\n            listening: false\n        };\n    });\n\n    iconConfig = computed(() => {\n        return {\n            name: AI_TABLE_FIELD_HEAD_SELECT_CHECKBOX,\n            x: AI_TABLE_CELL_PADDING + AI_TABLE_ROW_DRAG_ICON_WIDTH,\n            y: (this.fieldHeadHeight() - AI_TABLE_ICON_COMMON_SIZE) / 2,\n            type: this.isChecked() ? AITableCheckType.checked : AITableCheckType.unchecked,\n            fill:\n                this.isChecked() || (this.config().pointPosition.targetName === AI_TABLE_FIELD_HEAD_SELECT_CHECKBOX && !this.isChecked())\n                    ? Colors.primary\n                    : Colors.gray300\n        };\n    });\n\n    headBgConfig = computed(() => {\n        const { frozenColumnWidth } = this.coordinate();\n        return {\n            x: AI_TABLE_ROW_HEAD_WIDTH,\n            y: AI_TABLE_OFFSET,\n            width: frozenColumnWidth + AI_TABLE_OFFSET,\n            height: this.fieldHeadHeight(),\n            stroke: Colors.gray200,\n            strokeWidth: 1,\n            fill: Colors.transparent,\n            listening: false\n        };\n    });\n}\n"]}
214
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"frozen-heads.component.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/components/frozen-heads.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';\nimport { StageConfig } from 'konva/lib/Stage';\nimport { KoShape, KoContainer } from '../../angular-konva';\nimport {\n    AI_TABLE_CELL_PADDING,\n    AI_TABLE_FIELD_HEAD_SELECT_CHECKBOX,\n    AI_TABLE_ICON_COMMON_SIZE,\n    AI_TABLE_OFFSET,\n    AI_TABLE_ROW_DRAG_ICON_WIDTH,\n    Colors\n} from '../../constants';\nimport { AITableCheckType, AITableColumnHeadsConfig, AITableSelectAllState } from '../../types';\nimport { createColumnHeads } from '../creations/create-heads';\nimport { AITableFieldHead } from './field-head.component';\nimport { AITableIcon } from './icon.component';\n\n@Component({\n    selector: 'ai-table-frozen-column-heads',\n    template: `\n        <ko-rect [config]=\"headBgConfig()\"></ko-rect>\n        @if (!hiddenIndexColumn()) {\n            <ko-rect [config]=\"dragHeadBgConfig()\"></ko-rect>\n            <ko-rect [config]=\"numberHeadBgConfig()\"></ko-rect>\n            <ko-line [config]=\"topLineConfig()\"></ko-line>\n            <ko-line [config]=\"bottomLineConfig()\"></ko-line>\n            <ko-group>\n                <ai-table-icon [config]=\"iconConfig()\"></ai-table-icon>\n            </ko-group>\n        } @else {\n            @for (lineConfig of cellLinesConfig(); track $index) {\n                <ko-line [config]=\"lineConfig\"></ko-line>\n            }\n        }\n        @for (config of headConfigs(); track $index) {\n            <ai-table-field-head [config]=\"config\"></ai-table-field-head>\n        }\n    `,\n    standalone: true,\n    imports: [KoShape, AITableFieldHead, AITableIcon, KoContainer],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableFrozenColumnHeads {\n    config = input.required<AITableColumnHeadsConfig>();\n\n    coordinate = computed(() => {\n        const config = this.config();\n        if (!config) return null;\n        return config.coordinate;\n    });\n\n    hiddenIndexColumn = computed(() => {\n        const context = this.context();\n        if (!context) return false;\n        return context?.aiFieldConfig()?.hiddenIndexColumn;\n    });\n\n    context = computed(() => {\n        const config = this.config();\n        if (!config) return null;\n        return config?.aiTable.context;\n    });\n\n    isChecked = computed(() => {\n        const config = this.config();\n        if (!config) return false;\n        return config.aiTable.selection().selectAllState === AITableSelectAllState.all;\n    });\n\n    fieldHeadHeight = computed(() => {\n        const coord = this.coordinate();\n        if (!coord) return 0;\n        return coord.rowInitSize;\n    });\n\n    headConfigs = computed(() => {\n        const coord = this.coordinate();\n        if (!coord) return [];\n        return createColumnHeads({\n            ...this.config(),\n            columnStartIndex: 0,\n            columnStopIndex: coord.frozenColumnCount - 1\n        });\n    });\n\n    dragHeadBgConfig = computed<Partial<StageConfig>>(() => {\n        return {\n            x: AI_TABLE_OFFSET,\n            y: AI_TABLE_OFFSET,\n            width: AI_TABLE_ROW_DRAG_ICON_WIDTH,\n            height: this.fieldHeadHeight(),\n            fill: Colors.white,\n            listening: false\n        };\n    });\n\n    numberHeadBgConfig = computed<Partial<StageConfig>>(() => {\n        const ctx = this.context();\n        if (!ctx) return { width: 0, height: 0 };\n        return {\n            x: AI_TABLE_OFFSET,\n            y: AI_TABLE_OFFSET,\n            width: ctx.rowHeadWidth() || 0,\n            height: this.fieldHeadHeight(),\n            fill: Colors.white,\n            listening: false\n        };\n    });\n\n    topLineConfig = computed(() => {\n        const ctx = this.context();\n        if (!ctx) return { points: [0, 0, 0, 0] };\n        return {\n            x: AI_TABLE_OFFSET + AI_TABLE_ROW_DRAG_ICON_WIDTH,\n            y: AI_TABLE_OFFSET,\n            points: [0, 0, ctx.rowHeadWidth(), 0],\n            stroke: Colors.gray200,\n            strokeWidth: 1,\n            listening: false\n        };\n    });\n\n    bottomLineConfig = computed(() => {\n        const ctx = this.context();\n        if (!ctx) return { points: [0, 0, 0, 0] };\n        return {\n            x: AI_TABLE_OFFSET + AI_TABLE_ROW_DRAG_ICON_WIDTH,\n            y: AI_TABLE_OFFSET,\n            points: [ctx.rowHeadWidth(), this.fieldHeadHeight(), 0, this.fieldHeadHeight()],\n            stroke: Colors.gray200,\n            strokeWidth: 1,\n            listening: false\n        };\n    });\n\n    iconConfig = computed(() => {\n        return {\n            name: AI_TABLE_FIELD_HEAD_SELECT_CHECKBOX,\n            x: AI_TABLE_CELL_PADDING + AI_TABLE_ROW_DRAG_ICON_WIDTH,\n            y: (this.fieldHeadHeight() - AI_TABLE_ICON_COMMON_SIZE) / 2,\n            type: this.isChecked() ? AITableCheckType.checked : AITableCheckType.unchecked,\n            fill:\n                this.isChecked() || (this.config().pointPosition.targetName === AI_TABLE_FIELD_HEAD_SELECT_CHECKBOX && !this.isChecked())\n                    ? Colors.primary\n                    : Colors.gray300\n        };\n    });\n\n    headBgConfig = computed(() => {\n        const coord = this.coordinate();\n        const ctx = this.context();\n        if (!coord || !ctx) return { width: 0, height: 0 };\n        return {\n            x: ctx.rowHeadWidth(),\n            y: AI_TABLE_OFFSET,\n            width: coord.frozenColumnWidth + AI_TABLE_OFFSET,\n            height: this.fieldHeadHeight(),\n            stroke: Colors.gray200,\n            strokeWidth: this.hiddenIndexColumn() ? 0 : 1,\n            fill: Colors.transparent,\n            listening: false,\n            zIndex: 10\n        };\n    });\n\n    cellLinesConfig = computed(() => {\n        const coord = this.coordinate();\n        const ctx = this.context();\n        if (!coord || !ctx) return [];\n        return [\n            {\n                x: ctx.rowHeadWidth(),\n                y: AI_TABLE_OFFSET,\n                points: [0, 0, coord.frozenColumnWidth + AI_TABLE_OFFSET, 0],\n                stroke: Colors.gray200,\n                strokeWidth: 1,\n                listening: false,\n                zIndex: 10\n            },\n            {\n                x: ctx.rowHeadWidth(),\n                y: AI_TABLE_OFFSET,\n                points: [coord.frozenColumnWidth + AI_TABLE_OFFSET, 0, coord.frozenColumnWidth + AI_TABLE_OFFSET, this.fieldHeadHeight()],\n                stroke: Colors.gray200,\n                strokeWidth: 1,\n                listening: false,\n                zIndex: 10\n            },\n            {\n                x: ctx.rowHeadWidth(),\n                y: AI_TABLE_OFFSET,\n                points: [0, this.fieldHeadHeight(), coord.frozenColumnWidth + AI_TABLE_OFFSET, this.fieldHeadHeight()],\n                stroke: Colors.gray200,\n                strokeWidth: 1,\n                listening: false,\n                zIndex: 10\n            }\n        ];\n    });\n}\n"]}
@@ -2,7 +2,7 @@ import { ChangeDetectionStrategy, Component, computed, input } from '@angular/co
2
2
  import { KoContainer } from '../../angular-konva';
3
3
  import { CommonModule } from '@angular/common';
4
4
  import { AI_TABLE_CELL_PADDING, AI_TABLE_OFFSET, DEFAULT_TEXT_ALIGN_LEFT, DEFAULT_TEXT_ALIGN_RIGHT } from '../../constants';
5
- import { AITableQueries, getCellHorizontalPosition, getHoverCell, transformCellValue } from '../../utils';
5
+ import { AITableQueries, FieldModelMap, getCellHorizontalPosition, getHoverCell } from '../../utils';
6
6
  import { isSelectedField } from '../creations/create-cells';
7
7
  import * as i0 from "@angular/core";
8
8
  import * as i1 from "@angular/common";
@@ -25,7 +25,8 @@ export class AITableHoverCells {
25
25
  }
26
26
  const { field, recordId } = hoverCell;
27
27
  const cellValue = AITableQueries.getFieldValue(aiTable, [recordId, field._id]);
28
- const transformValue = transformCellValue(aiTable, field, cellValue);
28
+ const fieldModel = FieldModelMap[field.type];
29
+ const transformValue = fieldModel.transformCellValue(cellValue, { aiTable, field });
29
30
  const { rowHeight, columnCount, rowCount } = coordinate;
30
31
  const columnIndex = pointPosition.columnIndex;
31
32
  const rowIndex = pointPosition.rowIndex;
@@ -100,4 +101,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
100
101
  changeDetection: ChangeDetectionStrategy.OnPush
101
102
  }]
102
103
  }] });
103
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hover-cell.component.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/components/hover-cell.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';\nimport { KoContainer } from '../../angular-konva';\nimport { AITableCellsConfig, AITableHoverCellConfig } from '../../types';\nimport { AITableFieldType } from '@ai-table/utils';\nimport { CommonModule } from '@angular/common';\nimport { AI_TABLE_CELL_PADDING, AI_TABLE_OFFSET, DEFAULT_TEXT_ALIGN_LEFT, DEFAULT_TEXT_ALIGN_RIGHT } from '../../constants';\nimport { AITableQueries, getCellHorizontalPosition, getHoverCell, transformCellValue } from '../../utils';\nimport { isSelectedField } from '../creations/create-cells';\nimport _ from 'lodash';\nimport { HoverCellComponent } from '../interfaces';\nimport { Constructor } from 'ngx-tethys/core';\n\n@Component({\n    selector: 'ai-table-hover-cell',\n    template: `\n        @if (hoverCell()) {\n            <ko-group [config]=\"groupConfig()\">\n                <ng-container *ngComponentOutlet=\"hoverCell()!.renderComponentDefinition; inputs: { config: hoverCellConfig() }\">\n                </ng-container>\n            </ko-group>\n        }\n    `,\n    standalone: true,\n    imports: [KoContainer, CommonModule],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableHoverCells {\n    config = input.required<AITableCellsConfig>();\n\n    componentMap: Partial<Record<AITableFieldType, Constructor<HoverCellComponent>>> = {};\n\n    groupConfig = computed(() => {\n        return {\n            x: this.hoverCellConfig()?.x,\n            y: this.hoverCellConfig()?.y\n        };\n    });\n\n    hoverCellConfig = computed<AITableHoverCellConfig | undefined>(() => {\n        const { aiTable, coordinate, references, readonly, actions } = this.config();\n        const pointPosition = aiTable.context!.pointPosition();\n        const hoverCell = this.hoverCell();\n        if (!hoverCell) {\n            return;\n        }\n        const { field, recordId } = hoverCell;\n        const cellValue = AITableQueries.getFieldValue(aiTable, [recordId, field._id]);\n        const transformValue = transformCellValue(aiTable, field, cellValue);\n\n        const { rowHeight, columnCount, rowCount } = coordinate;\n        const columnIndex = pointPosition.columnIndex;\n        const rowIndex = pointPosition.rowIndex;\n\n        const x = coordinate.getColumnOffset(columnIndex) + AI_TABLE_OFFSET;\n        const columnWidth = coordinate.getColumnWidth(columnIndex);\n        const y = coordinate.getRowOffset(rowIndex) + AI_TABLE_OFFSET;\n        const { width } = getCellHorizontalPosition({\n            columnWidth,\n            columnIndex,\n            columnCount\n        });\n\n        const style = {\n            textAlign: DEFAULT_TEXT_ALIGN_LEFT\n        } as any;\n        const textAlign = style.textAlign;\n        const renderX =\n            textAlign === DEFAULT_TEXT_ALIGN_RIGHT\n                ? columnWidth - AI_TABLE_CELL_PADDING + AI_TABLE_OFFSET\n                : AI_TABLE_CELL_PADDING + AI_TABLE_OFFSET;\n        const renderY = 0 - AI_TABLE_OFFSET * 2;\n\n        const result: AITableHoverCellConfig = {\n            field,\n            recordId,\n            aiTable,\n            coordinate,\n            x,\n            y,\n            readonly,\n            actions,\n            render: {\n                aiTable,\n                recordId,\n                field,\n                isActive: isSelectedField(field._id, aiTable),\n                x: renderX,\n                y: renderY,\n                columnWidth: width,\n                rowHeight,\n                cellValue,\n                transformValue,\n                style,\n                references\n            }\n        };\n\n        return result;\n    });\n\n    hoverCell = computed(() => getHoverCell(this.config().aiTable));\n}\n"]}
104
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hover-cell.component.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/components/hover-cell.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';\nimport { KoContainer } from '../../angular-konva';\nimport { AITableCellsConfig, AITableHoverCellConfig } from '../../types';\nimport { AITableFieldType } from '@ai-table/utils';\nimport { CommonModule } from '@angular/common';\nimport { AI_TABLE_CELL_PADDING, AI_TABLE_OFFSET, DEFAULT_TEXT_ALIGN_LEFT, DEFAULT_TEXT_ALIGN_RIGHT } from '../../constants';\nimport { AITableQueries, FieldModelMap, getCellHorizontalPosition, getHoverCell, transformCellValue } from '../../utils';\nimport { isSelectedField } from '../creations/create-cells';\nimport _ from 'lodash';\nimport { HoverCellComponent } from '../interfaces';\nimport { Constructor } from 'ngx-tethys/core';\n\n@Component({\n    selector: 'ai-table-hover-cell',\n    template: `\n        @if (hoverCell()) {\n            <ko-group [config]=\"groupConfig()\">\n                <ng-container *ngComponentOutlet=\"hoverCell()!.renderComponentDefinition; inputs: { config: hoverCellConfig() }\">\n                </ng-container>\n            </ko-group>\n        }\n    `,\n    standalone: true,\n    imports: [KoContainer, CommonModule],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableHoverCells {\n    config = input.required<AITableCellsConfig>();\n\n    componentMap: Partial<Record<AITableFieldType, Constructor<HoverCellComponent>>> = {};\n\n    groupConfig = computed(() => {\n        return {\n            x: this.hoverCellConfig()?.x,\n            y: this.hoverCellConfig()?.y\n        };\n    });\n\n    hoverCellConfig = computed<AITableHoverCellConfig | undefined>(() => {\n        const { aiTable, coordinate, references, readonly, actions } = this.config();\n        const pointPosition = aiTable.context!.pointPosition();\n        const hoverCell = this.hoverCell();\n        if (!hoverCell) {\n            return;\n        }\n        const { field, recordId } = hoverCell;\n        const cellValue = AITableQueries.getFieldValue(aiTable, [recordId, field._id]);\n        const fieldModel = FieldModelMap[field.type];\n        const transformValue = fieldModel.transformCellValue(cellValue, { aiTable, field });\n\n        const { rowHeight, columnCount, rowCount } = coordinate;\n        const columnIndex = pointPosition.columnIndex;\n        const rowIndex = pointPosition.rowIndex;\n\n        const x = coordinate.getColumnOffset(columnIndex) + AI_TABLE_OFFSET;\n        const columnWidth = coordinate.getColumnWidth(columnIndex);\n        const y = coordinate.getRowOffset(rowIndex) + AI_TABLE_OFFSET;\n        const { width } = getCellHorizontalPosition({\n            columnWidth,\n            columnIndex,\n            columnCount\n        });\n\n        const style = {\n            textAlign: DEFAULT_TEXT_ALIGN_LEFT\n        } as any;\n        const textAlign = style.textAlign;\n        const renderX =\n            textAlign === DEFAULT_TEXT_ALIGN_RIGHT\n                ? columnWidth - AI_TABLE_CELL_PADDING + AI_TABLE_OFFSET\n                : AI_TABLE_CELL_PADDING + AI_TABLE_OFFSET;\n        const renderY = 0 - AI_TABLE_OFFSET * 2;\n\n        const result: AITableHoverCellConfig = {\n            field,\n            recordId,\n            aiTable,\n            coordinate,\n            x,\n            y,\n            readonly,\n            actions,\n            render: {\n                aiTable,\n                recordId,\n                field,\n                isActive: isSelectedField(field._id, aiTable),\n                x: renderX,\n                y: renderY,\n                columnWidth: width,\n                rowHeight,\n                cellValue,\n                transformValue,\n                style,\n                references\n            }\n        };\n\n        return result;\n    });\n\n    hoverCell = computed(() => getHoverCell(this.config().aiTable));\n}\n"]}
@@ -1,6 +1,6 @@
1
1
  import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';
2
2
  import { KoContainer, KoShape } from '../../angular-konva';
3
- import { AI_TABLE_CELL_PADDING, AI_TABLE_FIELD_HEAD, AI_TABLE_FIELD_HEAD_HEIGHT, AI_TABLE_ROW_DRAG, AI_TABLE_ROW_DRAG_ICON_WIDTH, AI_TABLE_ROW_HEAD, AI_TABLE_ROW_HEAD_WIDTH, AI_TABLE_ROW_SELECT_CHECKBOX, Colors } from '../../constants';
3
+ import { AI_TABLE_CELL_PADDING, AI_TABLE_FIELD_HEAD, AI_TABLE_FIELD_HEAD_HEIGHT, AI_TABLE_ROW_DRAG, AI_TABLE_ROW_DRAG_ICON_WIDTH, AI_TABLE_ROW_HEAD, AI_TABLE_ROW_SELECT_CHECKBOX, Colors } from '../../constants';
4
4
  import { AITableAreaType, AITableCheckType, AITableRowType } from '../../types';
5
5
  import { generateTargetName } from '../../utils';
6
6
  import { AITableIcon } from './icon.component';
@@ -53,7 +53,7 @@ export class AITableHoverRowHeads {
53
53
  y: coordinate.getRowOffset(rowIndex),
54
54
  bgConfig: {
55
55
  name: generateTargetName({ targetName: AI_TABLE_ROW_HEAD, recordId }),
56
- width: AI_TABLE_ROW_HEAD_WIDTH + 1,
56
+ width: context.rowHeadWidth() + 1,
57
57
  height: coordinate.rowHeight,
58
58
  fill: Colors.transparent
59
59
  }
@@ -129,4 +129,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
129
129
  changeDetection: ChangeDetectionStrategy.OnPush
130
130
  }]
131
131
  }] });
132
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hover-row-heads.component.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/components/hover-row-heads.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';\nimport { KoContainer, KoShape } from '../../angular-konva';\nimport {\n    AI_TABLE_CELL_PADDING,\n    AI_TABLE_FIELD_HEAD,\n    AI_TABLE_FIELD_HEAD_HEIGHT,\n    AI_TABLE_ROW_DRAG,\n    AI_TABLE_ROW_DRAG_ICON_WIDTH,\n    AI_TABLE_ROW_HEAD,\n    AI_TABLE_ROW_HEAD_WIDTH,\n    AI_TABLE_ROW_SELECT_CHECKBOX,\n    Colors\n} from '../../constants';\nimport { RendererContext } from '../../core';\nimport { AITableAreaType, AITableCheckType, AITablePointPosition, AITableRowHeadsConfig, AITableRowType } from '../../types';\nimport { generateTargetName } from '../../utils';\nimport { AITableIcon } from './icon.component';\nimport { DragType } from '@ai-table/utils';\n\n@Component({\n    selector: 'ai-table-hover-row-heads',\n    template: `\n        @for (config of headConfigs(); track config.recordId) {\n            <ko-group [config]=\"{ x: 0, y: config.y, name: 'hover-heads' }\">\n                @if (config.bgConfig) {\n                    <ko-rect [config]=\"config.bgConfig\"></ko-rect>\n                }\n                @if (config.iconConfig) {\n                    <ai-table-icon [config]=\"config.iconConfig\"></ai-table-icon>\n                }\n                @if (config.dragConfig) {\n                    <ai-table-icon [config]=\"config.dragConfig\"></ai-table-icon>\n                }\n            </ko-group>\n        }\n    `,\n    standalone: true,\n    imports: [KoContainer, KoShape, AITableIcon],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableHoverRowHeads {\n    config = input.required<AITableRowHeadsConfig>();\n\n    pointPosition = computed(() => {\n        return this.config().aiTable.context!.pointPosition();\n    });\n\n    headConfigs = computed(() => {\n        return this.createHoverRowHeads(this.pointPosition());\n    });\n\n    readonly = computed(() => {\n        return this.config().readonly;\n    });\n\n    rowDragDisabled = computed(() => {\n        return this.config().rowDragDisabled;\n    });\n\n    createHoverRowHeads = (pointPosition: AITablePointPosition) => {\n        const { coordinate, rowStartIndex, rowStopIndex, aiTable } = this.config();\n        const context = aiTable.context as RendererContext;\n        const headConfigs: any[] = [];\n\n        for (let rowIndex = rowStartIndex; rowIndex <= rowStopIndex; rowIndex++) {\n            if (rowIndex > coordinate.rowCount - 1) {\n                break;\n            }\n\n            const row = context.linearRows()[rowIndex];\n            if (row == null) {\n                continue;\n            }\n\n            const { type, _id: recordId } = row;\n            if (type !== AITableRowType.record || recordId == null) {\n                continue;\n            }\n\n            const isCheckedRow = aiTable.selection().selectedRecords.has(recordId);\n            const { areaType, rowIndex: pointRowIndex, targetName } = pointPosition;\n\n            if (!isCheckedRow && areaType === AITableAreaType.none) {\n                continue;\n            }\n\n            let isHoverRow;\n            if (pointRowIndex > -1 && !!context.linearRows().length && pointRowIndex < context.linearRows().length) {\n                const { type: pointRowType, _id: pointRecordId } = context.linearRows()[pointRowIndex];\n                isHoverRow = recordId === pointRecordId && pointRowType === AITableRowType.record && targetName !== AI_TABLE_FIELD_HEAD;\n            }\n\n            let operationGroup: { recordId: string; y: number; bgConfig: any; iconConfig?: any; dragConfig?: any };\n\n            operationGroup = {\n                recordId,\n                y: coordinate.getRowOffset(rowIndex),\n                bgConfig: {\n                    name: generateTargetName({ targetName: AI_TABLE_ROW_HEAD, recordId }),\n                    width: AI_TABLE_ROW_HEAD_WIDTH + 1,\n                    height: coordinate.rowHeight,\n                    fill: Colors.transparent\n                }\n            };\n\n            if (isCheckedRow || isHoverRow) {\n                const iconOffsetY = (AI_TABLE_FIELD_HEAD_HEIGHT - 16) / 2;\n                operationGroup.iconConfig = {\n                    name: generateTargetName({\n                        targetName: AI_TABLE_ROW_SELECT_CHECKBOX,\n                        recordId\n                    }),\n                    x: AI_TABLE_CELL_PADDING + AI_TABLE_ROW_DRAG_ICON_WIDTH,\n                    y: iconOffsetY,\n                    type: isCheckedRow ? AITableCheckType.checked : AITableCheckType.unchecked,\n                    fill: isCheckedRow || (targetName === AI_TABLE_ROW_SELECT_CHECKBOX && !isCheckedRow) ? Colors.primary : Colors.gray300\n                };\n                if (!this.readonly() && !this.rowDragDisabled()) {\n                    operationGroup.dragConfig = {\n                        name: generateTargetName({\n                            targetName: AI_TABLE_ROW_DRAG,\n                            recordId\n                        }),\n                        x: 0,\n                        y: iconOffsetY,\n                        type: DragType.record,\n                        fill: Colors.gray600\n                    };\n                }\n                headConfigs.push(operationGroup);\n            }\n        }\n\n        return headConfigs;\n    };\n}\n"]}
132
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hover-row-heads.component.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/components/hover-row-heads.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';\nimport { KoContainer, KoShape } from '../../angular-konva';\nimport {\n    AI_TABLE_CELL_PADDING,\n    AI_TABLE_FIELD_HEAD,\n    AI_TABLE_FIELD_HEAD_HEIGHT,\n    AI_TABLE_ROW_DRAG,\n    AI_TABLE_ROW_DRAG_ICON_WIDTH,\n    AI_TABLE_ROW_HEAD,\n    AI_TABLE_ROW_SELECT_CHECKBOX,\n    Colors\n} from '../../constants';\nimport { RendererContext } from '../../core';\nimport { AITableAreaType, AITableCheckType, AITablePointPosition, AITableRowHeadsConfig, AITableRowType } from '../../types';\nimport { generateTargetName } from '../../utils';\nimport { AITableIcon } from './icon.component';\nimport { DragType } from '@ai-table/utils';\n\n@Component({\n    selector: 'ai-table-hover-row-heads',\n    template: `\n        @for (config of headConfigs(); track config.recordId) {\n            <ko-group [config]=\"{ x: 0, y: config.y, name: 'hover-heads' }\">\n                @if (config.bgConfig) {\n                    <ko-rect [config]=\"config.bgConfig\"></ko-rect>\n                }\n                @if (config.iconConfig) {\n                    <ai-table-icon [config]=\"config.iconConfig\"></ai-table-icon>\n                }\n                @if (config.dragConfig) {\n                    <ai-table-icon [config]=\"config.dragConfig\"></ai-table-icon>\n                }\n            </ko-group>\n        }\n    `,\n    standalone: true,\n    imports: [KoContainer, KoShape, AITableIcon],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableHoverRowHeads {\n    config = input.required<AITableRowHeadsConfig>();\n\n    pointPosition = computed(() => {\n        return this.config().aiTable.context!.pointPosition();\n    });\n\n    headConfigs = computed(() => {\n        return this.createHoverRowHeads(this.pointPosition());\n    });\n\n    readonly = computed(() => {\n        return this.config().readonly;\n    });\n\n    rowDragDisabled = computed(() => {\n        return this.config().rowDragDisabled;\n    });\n\n    createHoverRowHeads = (pointPosition: AITablePointPosition) => {\n        const { coordinate, rowStartIndex, rowStopIndex, aiTable } = this.config();\n        const context = aiTable.context as RendererContext;\n        const headConfigs: any[] = [];\n\n        for (let rowIndex = rowStartIndex; rowIndex <= rowStopIndex; rowIndex++) {\n            if (rowIndex > coordinate.rowCount - 1) {\n                break;\n            }\n\n            const row = context.linearRows()[rowIndex];\n            if (row == null) {\n                continue;\n            }\n\n            const { type, _id: recordId } = row;\n            if (type !== AITableRowType.record || recordId == null) {\n                continue;\n            }\n\n            const isCheckedRow = aiTable.selection().selectedRecords.has(recordId);\n            const { areaType, rowIndex: pointRowIndex, targetName } = pointPosition;\n\n            if (!isCheckedRow && areaType === AITableAreaType.none) {\n                continue;\n            }\n\n            let isHoverRow;\n            if (pointRowIndex > -1 && !!context.linearRows().length && pointRowIndex < context.linearRows().length) {\n                const { type: pointRowType, _id: pointRecordId } = context.linearRows()[pointRowIndex];\n                isHoverRow = recordId === pointRecordId && pointRowType === AITableRowType.record && targetName !== AI_TABLE_FIELD_HEAD;\n            }\n\n            let operationGroup: { recordId: string; y: number; bgConfig: any; iconConfig?: any; dragConfig?: any };\n\n            operationGroup = {\n                recordId,\n                y: coordinate.getRowOffset(rowIndex),\n                bgConfig: {\n                    name: generateTargetName({ targetName: AI_TABLE_ROW_HEAD, recordId }),\n                    width: context.rowHeadWidth() + 1,\n                    height: coordinate.rowHeight,\n                    fill: Colors.transparent\n                }\n            };\n\n            if (isCheckedRow || isHoverRow) {\n                const iconOffsetY = (AI_TABLE_FIELD_HEAD_HEIGHT - 16) / 2;\n                operationGroup.iconConfig = {\n                    name: generateTargetName({\n                        targetName: AI_TABLE_ROW_SELECT_CHECKBOX,\n                        recordId\n                    }),\n                    x: AI_TABLE_CELL_PADDING + AI_TABLE_ROW_DRAG_ICON_WIDTH,\n                    y: iconOffsetY,\n                    type: isCheckedRow ? AITableCheckType.checked : AITableCheckType.unchecked,\n                    fill: isCheckedRow || (targetName === AI_TABLE_ROW_SELECT_CHECKBOX && !isCheckedRow) ? Colors.primary : Colors.gray300\n                };\n                if (!this.readonly() && !this.rowDragDisabled()) {\n                    operationGroup.dragConfig = {\n                        name: generateTargetName({\n                            targetName: AI_TABLE_ROW_DRAG,\n                            recordId\n                        }),\n                        x: 0,\n                        y: iconOffsetY,\n                        type: DragType.record,\n                        fill: Colors.gray600\n                    };\n                }\n                headConfigs.push(operationGroup);\n            }\n        }\n\n        return headConfigs;\n    };\n}\n"]}
@@ -1,7 +1,7 @@
1
1
  import { AI_TABLE_FIELD_HEAD, AI_TABLE_FIELD_HEAD_HEIGHT, AI_TABLE_OFFSET, AI_TABLE_ROW_ADD_BUTTON, DEFAULT_FONT_STYLE } from '../../constants';
2
2
  import { AITable, AITableQueries } from '../../core';
3
3
  import { AITableRowType } from '../../types';
4
- import { getCellHorizontalPosition, getHoverCell, transformCellValue } from '../../utils';
4
+ import { FieldModelMap, getCellHorizontalPosition, getHoverCell } from '../../utils';
5
5
  import { addRowLayout } from '../drawers/add-row-layout-drawer';
6
6
  import { cellDrawer } from '../drawers/cell-drawer';
7
7
  import { recordRowLayout } from '../drawers/record-row-layout-drawer';
@@ -57,7 +57,9 @@ export const createCells = (config) => {
57
57
  columnWidth,
58
58
  rowHeight: AI_TABLE_FIELD_HEAD_HEIGHT,
59
59
  columnCount,
60
- containerWidth: coordinate.containerWidth
60
+ containerWidth: coordinate.containerWidth,
61
+ rowHeadWidth: context.rowHeadWidth(),
62
+ hiddenIndexColumn: !!context.aiFieldConfig()?.hiddenIndexColumn
61
63
  });
62
64
  addRowLayout.render({
63
65
  isHoverRow,
@@ -77,7 +79,9 @@ export const createCells = (config) => {
77
79
  columnWidth,
78
80
  rowHeight,
79
81
  columnCount,
80
- containerWidth: coordinate.containerWidth
82
+ containerWidth: coordinate.containerWidth,
83
+ rowHeadWidth: context.rowHeadWidth(),
84
+ hiddenIndexColumn: !!context.aiFieldConfig()?.hiddenIndexColumn
81
85
  });
82
86
  recordRowLayout.render({
83
87
  row,
@@ -94,7 +98,8 @@ export const createCells = (config) => {
94
98
  const realY = y + AI_TABLE_OFFSET;
95
99
  const style = { fontWeight: DEFAULT_FONT_STYLE };
96
100
  const cellValue = AITableQueries.getFieldValue(aiTable, [recordId, fieldId]);
97
- const transformValue = transformCellValue(aiTable, field, cellValue);
101
+ const fieldModel = FieldModelMap[field.type];
102
+ const transformValue = fieldModel.transformCellValue(cellValue, { aiTable, field });
98
103
  const render = {
99
104
  aiTable,
100
105
  x: realX,
@@ -182,4 +187,4 @@ const isSelectedRecord = (recordId, aiTable) => {
182
187
  const isHoverRecord = (isHover, targetName) => {
183
188
  return isHover && targetName !== AI_TABLE_FIELD_HEAD;
184
189
  };
185
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-cells.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/creations/create-cells.ts"],"names":[],"mappings":"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","sourcesContent":["import { AIRecordFieldIdPath } from '@ai-table/utils';\nimport {\n    AI_TABLE_FIELD_HEAD,\n    AI_TABLE_FIELD_HEAD_HEIGHT,\n    AI_TABLE_OFFSET,\n    AI_TABLE_ROW_ADD_BUTTON,\n    DEFAULT_FONT_STYLE\n} from '../../constants';\nimport { AITable, AITableQueries, RendererContext } from '../../core';\nimport { AITableCellsDrawerConfig, AITableRender, AITableRowType } from '../../types';\nimport { getCellHorizontalPosition, getHoverCell, transformCellValue } from '../../utils';\nimport { addRowLayout } from '../drawers/add-row-layout-drawer';\nimport { cellDrawer } from '../drawers/cell-drawer';\nimport { recordRowLayout } from '../drawers/record-row-layout-drawer';\n\n/**\n * 绘制单元格内容的函数\n * 利用 Canvas API 绘制每个单元格的背景颜色、文本以及其他可能的样式。这个函数通常用于自定义表格渲染，尤其是在处理大量数据时，通过直接操作 Canvas 来提高渲染性能\n * @param config\n */\nexport const createCells = (config: AITableCellsDrawerConfig) => {\n    const { aiTable, coordinate, references, ctx, rowStartIndex, rowStopIndex, columnStartIndex, columnStopIndex } = config;\n    const context = aiTable.context as RendererContext;\n    const { rowHeight, columnCount, rowCount } = coordinate;\n    const colors = AITable.getColors();\n    const visibleColumns = AITable.getVisibleFields(aiTable);\n\n    // 初始化绘图上下文, 为后续的绘制操作做准备\n    cellDrawer.initCtx(ctx as CanvasRenderingContext2D);\n    addRowLayout.initCtx(ctx as CanvasRenderingContext2D);\n    recordRowLayout.initCtx(ctx as CanvasRenderingContext2D);\n\n    const hoverCell = getHoverCell(aiTable);\n\n    // 遍历列, 确定在哪些列上绘制单元格\n    for (let columnIndex = columnStartIndex; columnIndex <= columnStopIndex; columnIndex++) {\n        if (columnIndex > columnCount - 1) break;\n\n        // 获取该列对应的 field，如果 field 不再展示范围，则跳过该列\n        const field = visibleColumns[columnIndex];\n        if (field == null) continue;\n\n        // 获取该列对应的宽度\n        const columnWidth = coordinate.getColumnWidth(columnIndex);\n        const x = coordinate.getColumnOffset(columnIndex) + AI_TABLE_OFFSET;\n        const isLastColumn = columnIndex === aiTable.gridData().fields?.length - 1;\n\n        if (columnIndex === 1) {\n            cellDrawer.initStyle(field, { fontWeight: DEFAULT_FONT_STYLE });\n        }\n\n        // 遍历行, 从 rowStartIndex 到 rowStopIndex 的所有行，决定将在哪些行上绘制单元格\n        for (let rowIndex = rowStartIndex; rowIndex <= rowStopIndex; rowIndex++) {\n            if (rowIndex > rowCount - 1) break;\n            const row = context.linearRows()[rowIndex];\n            const { _id: recordId, type } = row;\n            const y = coordinate.getRowOffset(rowIndex) + AI_TABLE_OFFSET;\n            const { rowIndex: pointRowIndex, targetName } = context.pointPosition();\n            const isHover = pointRowIndex === rowIndex;\n\n            switch (type) {\n                case AITableRowType.add: {\n                    const isHoverRow = isHover && targetName === AI_TABLE_ROW_ADD_BUTTON;\n                    const isCheckedRow = aiTable.selection().selectedRecords.has(row._id);\n                    addRowLayout.init({\n                        x,\n                        y,\n                        rowIndex,\n                        columnIndex,\n                        columnWidth,\n                        rowHeight: AI_TABLE_FIELD_HEAD_HEIGHT,\n                        columnCount,\n                        containerWidth: coordinate.containerWidth\n                    });\n                    addRowLayout.render({\n                        isHoverRow,\n                        isCheckedRow\n                    });\n                    break;\n                }\n                case AITableRowType.record: {\n                    const fieldId = field._id;\n                    const cell: AIRecordFieldIdPath = [recordId, fieldId];\n                    let background = getCellBackground(cell, isHover, targetName, aiTable);\n\n                    recordRowLayout.init({\n                        x,\n                        y,\n                        rowIndex,\n                        columnIndex,\n                        columnWidth,\n                        rowHeight,\n                        columnCount,\n                        containerWidth: coordinate.containerWidth\n                    });\n                    recordRowLayout.render({\n                        row,\n                        style: { fill: background },\n                        isHoverRow: isHoverRecord(isHover, targetName),\n                        isCheckedRow: isSelectedRecord(recordId, aiTable)\n                    });\n                    const { width, offset } = getCellHorizontalPosition({\n                        columnIndex,\n                        columnWidth,\n                        columnCount\n                    });\n                    const realX = x + offset + AI_TABLE_OFFSET;\n                    const realY = y + AI_TABLE_OFFSET;\n                    const style = { fontWeight: DEFAULT_FONT_STYLE };\n                    const cellValue = AITableQueries.getFieldValue(aiTable, [recordId, fieldId]);\n                    const transformValue = transformCellValue(aiTable, field, cellValue);\n                    const render = {\n                        aiTable,\n                        x: realX,\n                        y: realY,\n                        columnWidth: width,\n                        rowHeight,\n                        recordId: recordId,\n                        field,\n                        cellValue,\n                        transformValue,\n                        references,\n                        isActive: isSelectedField(fieldId, aiTable),\n                        style,\n                        colors\n                    };\n                    // hover 组件渲染时，底层的 cell 渲染为空\n                    if (hoverCell && hoverCell.recordId === recordId && hoverCell.fieldId === fieldId) {\n                        render.cellValue = '';\n                        render.transformValue = '';\n                    }\n\n                    cellDrawer.initStyle(field, style);\n                    // 最后一列，且单元格内容存在，需要裁剪内容，以防止文本溢出单元格边界\n                    // 然后，根据计算好的样式和布局绘制单元格内容\n                    if (isLastColumn && cellValue != null) {\n                        ctx.save();\n                        ctx.rect(realX, realY, width, rowHeight);\n                        ctx.clip();\n                        cellDrawer.renderCell(render as AITableRender, ctx as CanvasRenderingContext2D, columnWidth);\n                        ctx.restore();\n                    } else {\n                        cellDrawer.renderCell(render as AITableRender, ctx as CanvasRenderingContext2D, columnWidth);\n                    }\n                }\n            }\n        }\n    }\n};\n\nconst getCellBackground = (cell: AIRecordFieldIdPath, isHover: boolean, targetName: string, aiTable: AITable): string => {\n    const colors = AITable.getColors();\n    const [recordId, fieldId] = cell;\n    let background = colors.white;\n\n    const _isHoverRecord = isHoverRecord(isHover, targetName);\n    const _isSelectedRecord = isSelectedRecord(recordId, aiTable);\n    const _isSelectedField = isSelectedField(fieldId, aiTable);\n    const _isSiblingCell = isSiblingCell(cell, aiTable);\n    const _isActiveCell = isActiveCell(cell, aiTable);\n    const _isSelectedCell = isSelectedCell(cell, aiTable);\n    const _isKeywordsMatchedCell = isKeywordsMatchedCell(cell, aiTable);\n\n    if (_isKeywordsMatchedCell) {\n        background = colors.itemMatchBgColor;\n    } else if (_isSelectedRecord || _isSelectedField || _isSiblingCell || (_isSelectedCell && !_isActiveCell)) {\n        background = colors.itemActiveBgColor;\n    } else if (_isHoverRecord && !_isActiveCell) {\n        background = colors.gray80;\n    }\n\n    return background;\n};\n\nexport const isActiveCell = (cell: AIRecordFieldIdPath, aiTable: AITable): boolean => {\n    const [recordId, fieldId] = cell;\n    const [activeRecordId, activeFieldId] = AITable.getActiveCell(aiTable) || [];\n    return recordId === activeRecordId && fieldId === activeFieldId;\n};\n\nconst isSiblingCell = (cell: AIRecordFieldIdPath, aiTable: AITable): boolean => {\n    const [recordId, fieldId] = cell;\n    const [activeRecordId, activeFieldId] = AITable.getActiveCell(aiTable) || [];\n    return AITable.getActiveRecordIds(aiTable).length === 1 && recordId === activeRecordId && fieldId !== activeFieldId;\n};\n\nconst isKeywordsMatchedCell = (cell: AIRecordFieldIdPath, aiTable: AITable): boolean => {\n    const [recordId, fieldId] = cell;\n    return aiTable.keywordsMatchedCells().has(`${recordId}:${fieldId}`);\n};\n\nconst isSelectedCell = (cell: AIRecordFieldIdPath, aiTable: AITable): boolean => {\n    const [recordId, fieldId] = cell;\n    return aiTable.selection().selectedCells.has(`${recordId}:${fieldId}`);\n};\n\nexport const isSelectedField = (fieldId: string, aiTable: AITable): boolean => {\n    return aiTable.selection().selectedFields.has(fieldId);\n};\n\nconst isSelectedRecord = (recordId: string, aiTable: AITable): boolean => {\n    return aiTable.selection().selectedRecords.has(recordId);\n};\n\nconst isHoverRecord = (isHover: boolean, targetName: string): boolean => {\n    return isHover && targetName !== AI_TABLE_FIELD_HEAD;\n};\n"]}
190
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-cells.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/creations/create-cells.ts"],"names":[],"mappings":"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","sourcesContent":["import { AIRecordFieldIdPath } from '@ai-table/utils';\nimport {\n    AI_TABLE_FIELD_HEAD,\n    AI_TABLE_FIELD_HEAD_HEIGHT,\n    AI_TABLE_OFFSET,\n    AI_TABLE_ROW_ADD_BUTTON,\n    DEFAULT_FONT_STYLE\n} from '../../constants';\nimport { AITable, AITableQueries, RendererContext } from '../../core';\nimport { AITableCellsDrawerConfig, AITableRender, AITableRowType } from '../../types';\nimport { FieldModelMap, getCellHorizontalPosition, getHoverCell, transformCellValue } from '../../utils';\nimport { addRowLayout } from '../drawers/add-row-layout-drawer';\nimport { cellDrawer } from '../drawers/cell-drawer';\nimport { recordRowLayout } from '../drawers/record-row-layout-drawer';\n\n/**\n * 绘制单元格内容的函数\n * 利用 Canvas API 绘制每个单元格的背景颜色、文本以及其他可能的样式。这个函数通常用于自定义表格渲染，尤其是在处理大量数据时，通过直接操作 Canvas 来提高渲染性能\n * @param config\n */\nexport const createCells = (config: AITableCellsDrawerConfig) => {\n    const { aiTable, coordinate, references, ctx, rowStartIndex, rowStopIndex, columnStartIndex, columnStopIndex } = config;\n    const context = aiTable.context as RendererContext;\n    const { rowHeight, columnCount, rowCount } = coordinate;\n    const colors = AITable.getColors();\n    const visibleColumns = AITable.getVisibleFields(aiTable);\n\n    // 初始化绘图上下文, 为后续的绘制操作做准备\n    cellDrawer.initCtx(ctx as CanvasRenderingContext2D);\n    addRowLayout.initCtx(ctx as CanvasRenderingContext2D);\n    recordRowLayout.initCtx(ctx as CanvasRenderingContext2D);\n\n    const hoverCell = getHoverCell(aiTable);\n\n    // 遍历列, 确定在哪些列上绘制单元格\n    for (let columnIndex = columnStartIndex; columnIndex <= columnStopIndex; columnIndex++) {\n        if (columnIndex > columnCount - 1) break;\n\n        // 获取该列对应的 field，如果 field 不再展示范围，则跳过该列\n        const field = visibleColumns[columnIndex];\n        if (field == null) continue;\n\n        // 获取该列对应的宽度\n        const columnWidth = coordinate.getColumnWidth(columnIndex);\n        const x = coordinate.getColumnOffset(columnIndex) + AI_TABLE_OFFSET;\n        const isLastColumn = columnIndex === aiTable.gridData().fields?.length - 1;\n\n        if (columnIndex === 1) {\n            cellDrawer.initStyle(field, { fontWeight: DEFAULT_FONT_STYLE });\n        }\n\n        // 遍历行, 从 rowStartIndex 到 rowStopIndex 的所有行，决定将在哪些行上绘制单元格\n        for (let rowIndex = rowStartIndex; rowIndex <= rowStopIndex; rowIndex++) {\n            if (rowIndex > rowCount - 1) break;\n            const row = context.linearRows()[rowIndex];\n            const { _id: recordId, type } = row;\n            const y = coordinate.getRowOffset(rowIndex) + AI_TABLE_OFFSET;\n            const { rowIndex: pointRowIndex, targetName } = context.pointPosition();\n            const isHover = pointRowIndex === rowIndex;\n\n            switch (type) {\n                case AITableRowType.add: {\n                    const isHoverRow = isHover && targetName === AI_TABLE_ROW_ADD_BUTTON;\n                    const isCheckedRow = aiTable.selection().selectedRecords.has(row._id);\n                    addRowLayout.init({\n                        x,\n                        y,\n                        rowIndex,\n                        columnIndex,\n                        columnWidth,\n                        rowHeight: AI_TABLE_FIELD_HEAD_HEIGHT,\n                        columnCount,\n                        containerWidth: coordinate.containerWidth,\n                        rowHeadWidth: context.rowHeadWidth(),\n                        hiddenIndexColumn: !!context.aiFieldConfig()?.hiddenIndexColumn\n                    });\n                    addRowLayout.render({\n                        isHoverRow,\n                        isCheckedRow\n                    });\n                    break;\n                }\n                case AITableRowType.record: {\n                    const fieldId = field._id;\n                    const cell: AIRecordFieldIdPath = [recordId, fieldId];\n                    let background = getCellBackground(cell, isHover, targetName, aiTable);\n\n                    recordRowLayout.init({\n                        x,\n                        y,\n                        rowIndex,\n                        columnIndex,\n                        columnWidth,\n                        rowHeight,\n                        columnCount,\n                        containerWidth: coordinate.containerWidth,\n                        rowHeadWidth: context.rowHeadWidth(),\n                        hiddenIndexColumn: !!context.aiFieldConfig()?.hiddenIndexColumn\n                    });\n                    recordRowLayout.render({\n                        row,\n                        style: { fill: background },\n                        isHoverRow: isHoverRecord(isHover, targetName),\n                        isCheckedRow: isSelectedRecord(recordId, aiTable)\n                    });\n                    const { width, offset } = getCellHorizontalPosition({\n                        columnIndex,\n                        columnWidth,\n                        columnCount\n                    });\n                    const realX = x + offset + AI_TABLE_OFFSET;\n                    const realY = y + AI_TABLE_OFFSET;\n                    const style = { fontWeight: DEFAULT_FONT_STYLE };\n                    const cellValue = AITableQueries.getFieldValue(aiTable, [recordId, fieldId]);\n                    const fieldModel = FieldModelMap[field.type];\n                    const transformValue = fieldModel.transformCellValue(cellValue, { aiTable, field });\n                    const render = {\n                        aiTable,\n                        x: realX,\n                        y: realY,\n                        columnWidth: width,\n                        rowHeight,\n                        recordId: recordId,\n                        field,\n                        cellValue,\n                        transformValue,\n                        references,\n                        isActive: isSelectedField(fieldId, aiTable),\n                        style,\n                        colors\n                    };\n                    // hover 组件渲染时，底层的 cell 渲染为空\n                    if (hoverCell && hoverCell.recordId === recordId && hoverCell.fieldId === fieldId) {\n                        render.cellValue = '';\n                        render.transformValue = '';\n                    }\n\n                    cellDrawer.initStyle(field, style);\n                    // 最后一列，且单元格内容存在，需要裁剪内容，以防止文本溢出单元格边界\n                    // 然后，根据计算好的样式和布局绘制单元格内容\n                    if (isLastColumn && cellValue != null) {\n                        ctx.save();\n                        ctx.rect(realX, realY, width, rowHeight);\n                        ctx.clip();\n                        cellDrawer.renderCell(render as AITableRender, ctx as CanvasRenderingContext2D, columnWidth);\n                        ctx.restore();\n                    } else {\n                        cellDrawer.renderCell(render as AITableRender, ctx as CanvasRenderingContext2D, columnWidth);\n                    }\n                }\n            }\n        }\n    }\n};\n\nconst getCellBackground = (cell: AIRecordFieldIdPath, isHover: boolean, targetName: string, aiTable: AITable): string => {\n    const colors = AITable.getColors();\n    const [recordId, fieldId] = cell;\n    let background = colors.white;\n\n    const _isHoverRecord = isHoverRecord(isHover, targetName);\n    const _isSelectedRecord = isSelectedRecord(recordId, aiTable);\n    const _isSelectedField = isSelectedField(fieldId, aiTable);\n    const _isSiblingCell = isSiblingCell(cell, aiTable);\n    const _isActiveCell = isActiveCell(cell, aiTable);\n    const _isSelectedCell = isSelectedCell(cell, aiTable);\n    const _isKeywordsMatchedCell = isKeywordsMatchedCell(cell, aiTable);\n\n    if (_isKeywordsMatchedCell) {\n        background = colors.itemMatchBgColor;\n    } else if (_isSelectedRecord || _isSelectedField || _isSiblingCell || (_isSelectedCell && !_isActiveCell)) {\n        background = colors.itemActiveBgColor;\n    } else if (_isHoverRecord && !_isActiveCell) {\n        background = colors.gray80;\n    }\n\n    return background;\n};\n\nexport const isActiveCell = (cell: AIRecordFieldIdPath, aiTable: AITable): boolean => {\n    const [recordId, fieldId] = cell;\n    const [activeRecordId, activeFieldId] = AITable.getActiveCell(aiTable) || [];\n    return recordId === activeRecordId && fieldId === activeFieldId;\n};\n\nconst isSiblingCell = (cell: AIRecordFieldIdPath, aiTable: AITable): boolean => {\n    const [recordId, fieldId] = cell;\n    const [activeRecordId, activeFieldId] = AITable.getActiveCell(aiTable) || [];\n    return AITable.getActiveRecordIds(aiTable).length === 1 && recordId === activeRecordId && fieldId !== activeFieldId;\n};\n\nconst isKeywordsMatchedCell = (cell: AIRecordFieldIdPath, aiTable: AITable): boolean => {\n    const [recordId, fieldId] = cell;\n    return aiTable.keywordsMatchedCells().has(`${recordId}:${fieldId}`);\n};\n\nconst isSelectedCell = (cell: AIRecordFieldIdPath, aiTable: AITable): boolean => {\n    const [recordId, fieldId] = cell;\n    return aiTable.selection().selectedCells.has(`${recordId}:${fieldId}`);\n};\n\nexport const isSelectedField = (fieldId: string, aiTable: AITable): boolean => {\n    return aiTable.selection().selectedFields.has(fieldId);\n};\n\nconst isSelectedRecord = (recordId: string, aiTable: AITable): boolean => {\n    return aiTable.selection().selectedRecords.has(recordId);\n};\n\nconst isHoverRecord = (isHover: boolean, targetName: string): boolean => {\n    return isHover && targetName !== AI_TABLE_FIELD_HEAD;\n};\n"]}