@ai-table/grid 0.0.56 → 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 (97) 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/index.d.ts +0 -1
  4. package/components/index.d.ts.map +1 -1
  5. package/constants/editor.d.ts.map +1 -1
  6. package/constants/grid.d.ts +0 -1
  7. package/constants/grid.d.ts.map +1 -1
  8. package/constants/table.d.ts +3 -1
  9. package/constants/table.d.ts.map +1 -1
  10. package/core/types/core.d.ts +13 -13
  11. package/core/types/core.d.ts.map +1 -1
  12. package/dom-grid.component.d.ts.map +1 -1
  13. package/esm2022/components/cell-editors/abstract-cell-editor.component.mjs +2 -4
  14. package/esm2022/components/cell-editors/date/date-editor.component.mjs +5 -5
  15. package/esm2022/components/index.mjs +1 -2
  16. package/esm2022/constants/editor.mjs +3 -4
  17. package/esm2022/constants/grid.mjs +1 -2
  18. package/esm2022/constants/table.mjs +4 -2
  19. package/esm2022/core/constants/field.mjs +2 -2
  20. package/esm2022/core/types/core.mjs +1 -1
  21. package/esm2022/dom-grid.component.mjs +2 -4
  22. package/esm2022/grid-base.component.mjs +5 -28
  23. package/esm2022/grid.component.mjs +17 -52
  24. package/esm2022/renderer/components/cells/attachment.component.mjs +9 -19
  25. package/esm2022/renderer/components/cells/index.mjs +3 -2
  26. package/esm2022/renderer/components/cells/link.component.mjs +3 -5
  27. package/esm2022/renderer/components/cells/progress.component.mjs +268 -0
  28. package/esm2022/renderer/components/cells/rich-text.component.mjs +90 -0
  29. package/esm2022/renderer/drawers/cell-drawer.mjs +3 -3
  30. package/esm2022/utils/cell.mjs +3 -3
  31. package/esm2022/utils/clipboard/copy.mjs +11 -5
  32. package/esm2022/utils/clipboard/paste.mjs +1 -4
  33. package/esm2022/utils/field/model/attachment.mjs +8 -1
  34. package/esm2022/utils/field/model/date.mjs +13 -3
  35. package/esm2022/utils/field/model/field.mjs +1 -2
  36. package/esm2022/utils/field/model/link.mjs +16 -4
  37. package/esm2022/utils/field/model/member.mjs +1 -1
  38. package/esm2022/utils/field/model/number.mjs +11 -8
  39. package/esm2022/utils/field/model/progress.mjs +7 -7
  40. package/esm2022/utils/field/model/rate.mjs +3 -2
  41. package/esm2022/utils/field/model/rich-text.mjs +1 -1
  42. package/esm2022/utils/field/model/select.mjs +1 -1
  43. package/esm2022/utils/field/model/text.mjs +3 -2
  44. package/esm2022/utils/field/operate.mjs +4 -2
  45. package/esm2022/utils/i18n.mjs +3 -3
  46. package/esm2022/utils/index.mjs +2 -1
  47. package/esm2022/utils/match-keywords.mjs +9 -4
  48. package/fesm2022/ai-table-grid.mjs +836 -675
  49. package/fesm2022/ai-table-grid.mjs.map +1 -1
  50. package/grid-base.component.d.ts +2 -3
  51. package/grid-base.component.d.ts.map +1 -1
  52. package/grid.component.d.ts +1 -1
  53. package/grid.component.d.ts.map +1 -1
  54. package/package.json +1 -1
  55. package/renderer/components/cells/attachment.component.d.ts +0 -3
  56. package/renderer/components/cells/attachment.component.d.ts.map +1 -1
  57. package/renderer/components/cells/index.d.ts +2 -1
  58. package/renderer/components/cells/index.d.ts.map +1 -1
  59. package/renderer/components/cells/link.component.d.ts.map +1 -1
  60. package/renderer/components/cells/progress.component.d.ts +82 -0
  61. package/renderer/components/cells/progress.component.d.ts.map +1 -0
  62. package/renderer/components/cells/{richtext.component.d.ts → rich-text.component.d.ts} +4 -4
  63. package/renderer/components/cells/rich-text.component.d.ts.map +1 -0
  64. package/renderer/drawers/cell-drawer.d.ts.map +1 -1
  65. package/utils/clipboard/paste.d.ts.map +1 -1
  66. package/utils/field/model/attachment.d.ts.map +1 -1
  67. package/utils/field/model/date.d.ts +1 -0
  68. package/utils/field/model/date.d.ts.map +1 -1
  69. package/utils/field/model/field.d.ts.map +1 -1
  70. package/utils/field/model/link.d.ts +3 -2
  71. package/utils/field/model/link.d.ts.map +1 -1
  72. package/utils/field/model/member.d.ts +1 -1
  73. package/utils/field/model/member.d.ts.map +1 -1
  74. package/utils/field/model/number.d.ts +5 -4
  75. package/utils/field/model/number.d.ts.map +1 -1
  76. package/utils/field/model/progress.d.ts +4 -4
  77. package/utils/field/model/progress.d.ts.map +1 -1
  78. package/utils/field/model/rate.d.ts +2 -2
  79. package/utils/field/model/rate.d.ts.map +1 -1
  80. package/utils/field/model/rich-text.d.ts +3 -3
  81. package/utils/field/model/rich-text.d.ts.map +1 -1
  82. package/utils/field/model/select.d.ts +1 -1
  83. package/utils/field/model/select.d.ts.map +1 -1
  84. package/utils/field/model/text.d.ts +3 -3
  85. package/utils/field/model/text.d.ts.map +1 -1
  86. package/utils/field/operate.d.ts +1 -1
  87. package/utils/field/operate.d.ts.map +1 -1
  88. package/utils/i18n.d.ts +1 -1
  89. package/utils/index.d.ts +1 -0
  90. package/utils/index.d.ts.map +1 -1
  91. package/utils/match-keywords.d.ts.map +1 -1
  92. package/components/cell-editors/progress/progress-editor.component.d.ts +0 -19
  93. package/components/cell-editors/progress/progress-editor.component.d.ts.map +0 -1
  94. package/components/cell-editors/progress/progress-editor.component.scss +0 -29
  95. package/esm2022/components/cell-editors/progress/progress-editor.component.mjs +0 -72
  96. package/esm2022/renderer/components/cells/richtext.component.mjs +0 -90
  97. package/renderer/components/cells/richtext.component.d.ts.map +0 -1
@@ -1,7 +1,5 @@
1
1
  import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';
2
- import { KoShape } from '../../../angular-konva/components/shape.component';
3
2
  import { AI_TABLE_CELL_PADDING, AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE, AI_TABLE_FIELD_HEAD_MORE, Colors } from '../../../constants';
4
- import { KoContainer } from '../../../angular-konva/components/container.component';
5
3
  import { getMousePosition, handleMouseStyle } from '../../../utils';
6
4
  import { AITableText } from '../text.component';
7
5
  import { AITable, AITableFieldType } from '../../../core';
@@ -17,7 +15,7 @@ export class AITableCellLink {
17
15
  this.textConfig = computed(() => {
18
16
  const render = this.config()?.render;
19
17
  if (render) {
20
- const { x, y, transformValue, field, columnWidth, rowHeight, style, zIndex } = render;
18
+ const { x, y, transformValue, columnWidth, rowHeight, style, zIndex } = render;
21
19
  let textRender = transformValue.text;
22
20
  if (textRender == null) {
23
21
  return;
@@ -84,8 +82,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
84
82
  }
85
83
  `,
86
84
  standalone: true,
87
- imports: [KoContainer, KoShape, AITableText],
85
+ imports: [AITableText],
88
86
  changeDetection: ChangeDetectionStrategy.OnPush
89
87
  }]
90
88
  }] });
91
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"link.component.js","sourceRoot":"","sources":["../../../../../../packages/grid/src/renderer/components/cells/link.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';\nimport { KoShape } from '../../../angular-konva/components/shape.component';\nimport { AI_TABLE_CELL_PADDING, AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE, AI_TABLE_FIELD_HEAD_MORE, Colors } from '../../../constants';\nimport { KoContainer } from '../../../angular-konva/components/container.component';\nimport { getMousePosition, getTextWidth, handleMouseStyle, TextMeasure } from '../../../utils';\nimport { AITableText } from '../text.component';\nimport { AITableHoverCellConfig, AITableRender } from '../../../types';\nimport { KoEventObject } from '../../../angular-konva';\nimport { AITable, AITableFieldType } from '../../../core';\nimport { TextConfig } from 'konva/lib/shapes/Text';\nimport { drawer } from '../../drawers/drawer';\nimport { HoverCellComponent } from '../../interfaces';\n\n@Component({\n    selector: 'ai-table-link',\n    template: `\n        @if (showLink()) {\n            <ai-table-text [config]=\"textConfig()!\" (koClick)=\"linkClick($event)\" (koMouseMove)=\"linkMouseMove($event)\"></ai-table-text>\n        }\n    `,\n    standalone: true,\n    imports: [KoContainer, KoShape, AITableText],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableCellLink implements HoverCellComponent {\n    static fieldType = AITableFieldType.link;\n\n    config = input<AITableHoverCellConfig | undefined>();\n\n    textOffset = AI_TABLE_CELL_PADDING + AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE;\n\n    render = computed<AITableRender | undefined>(() => this.config()?.render);\n\n    transformValue = computed<{ text: string; url: string }>(() => this.render()?.transformValue);\n\n    showLink = computed<boolean>(() => !!this.transformValue()?.text);\n\n    textConfig = computed<TextConfig | undefined>(() => {\n        const render = this.config()?.render;\n        if (render) {\n            const { x, y, transformValue, field, columnWidth, rowHeight, style, zIndex } = render;\n            let textRender: string | null = transformValue.text;\n            if (textRender == null) {\n                return;\n            }\n\n            textRender = textRender.replace(/\\r|\\n/g, ' ');\n            const fontWeight = style?.fontWeight;\n            const textMaxWidth = columnWidth - 2 * AI_TABLE_CELL_PADDING;\n            const { text, textWidth } = drawer.textEllipsis({\n                text: textRender,\n                maxWidth: textMaxWidth,\n                fontWeight\n            });\n\n            return {\n                x,\n                y,\n                text,\n                wrap: 'none',\n                width: textWidth,\n                fillStyle: Colors.primary,\n                fill: Colors.primary,\n                height: rowHeight + 2,\n                lineHeight: 1.84,\n                listening: true,\n                ellipsis: true,\n                textDecoration: 'underline',\n                zIndex\n            };\n        }\n        return;\n    });\n\n    linkClick(e: KoEventObject<MouseEvent>) {\n        e.event.cancelBubble = true;\n        window.open(this.transformValue().url, '_blank', 'noopener,noreferrer');\n    }\n\n    linkMouseMove(e: KoEventObject<MouseEvent>) {\n        e.event.cancelBubble = true;\n        const { aiTable, coordinate } = this.config()!;\n        const targetName = e.event.target.name();\n        const gridStage = e.event.currentTarget.getStage();\n        const pos = gridStage?.getPointerPosition();\n        if (pos == null) return;\n        const { context } = aiTable;\n        const { x, y } = pos;\n        const curMousePosition = getMousePosition(aiTable, x, y, coordinate, AITable.getVisibleFields(aiTable), context!, targetName);\n        handleMouseStyle(AI_TABLE_FIELD_HEAD_MORE, curMousePosition.areaType, coordinate.container);\n    }\n}\n"]}
89
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"link.component.js","sourceRoot":"","sources":["../../../../../../packages/grid/src/renderer/components/cells/link.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';\nimport { AI_TABLE_CELL_PADDING, AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE, AI_TABLE_FIELD_HEAD_MORE, Colors } from '../../../constants';\nimport { getMousePosition, handleMouseStyle } from '../../../utils';\nimport { AITableText } from '../text.component';\nimport { AITableHoverCellConfig, AITableRender } from '../../../types';\nimport { KoEventObject } from '../../../angular-konva';\nimport { AITable, AITableFieldType } from '../../../core';\nimport { TextConfig } from 'konva/lib/shapes/Text';\nimport { drawer } from '../../drawers/drawer';\nimport { HoverCellComponent } from '../../interfaces';\n\n@Component({\n    selector: 'ai-table-link',\n    template: `\n        @if (showLink()) {\n            <ai-table-text [config]=\"textConfig()!\" (koClick)=\"linkClick($event)\" (koMouseMove)=\"linkMouseMove($event)\"></ai-table-text>\n        }\n    `,\n    standalone: true,\n    imports: [AITableText],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableCellLink implements HoverCellComponent {\n    static fieldType = AITableFieldType.link;\n\n    config = input<AITableHoverCellConfig | undefined>();\n\n    textOffset = AI_TABLE_CELL_PADDING + AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE;\n\n    render = computed<AITableRender | undefined>(() => this.config()?.render);\n\n    transformValue = computed<{ text: string; url: string }>(() => this.render()?.transformValue);\n\n    showLink = computed<boolean>(() => !!this.transformValue()?.text);\n\n    textConfig = computed<TextConfig | undefined>(() => {\n        const render = this.config()?.render;\n        if (render) {\n            const { x, y, transformValue, columnWidth, rowHeight, style, zIndex } = render;\n            let textRender: string | null = transformValue.text;\n            if (textRender == null) {\n                return;\n            }\n\n            textRender = textRender.replace(/\\r|\\n/g, ' ');\n            const fontWeight = style?.fontWeight;\n            const textMaxWidth = columnWidth - 2 * AI_TABLE_CELL_PADDING;\n            const { text, textWidth } = drawer.textEllipsis({\n                text: textRender,\n                maxWidth: textMaxWidth,\n                fontWeight\n            });\n\n            return {\n                x,\n                y,\n                text,\n                wrap: 'none',\n                width: textWidth,\n                fillStyle: Colors.primary,\n                fill: Colors.primary,\n                height: rowHeight + 2,\n                lineHeight: 1.84,\n                listening: true,\n                ellipsis: true,\n                textDecoration: 'underline',\n                zIndex\n            };\n        }\n        return;\n    });\n\n    linkClick(e: KoEventObject<MouseEvent>) {\n        e.event.cancelBubble = true;\n        window.open(this.transformValue().url, '_blank', 'noopener,noreferrer');\n    }\n\n    linkMouseMove(e: KoEventObject<MouseEvent>) {\n        e.event.cancelBubble = true;\n        const { aiTable, coordinate } = this.config()!;\n        const targetName = e.event.target.name();\n        const gridStage = e.event.currentTarget.getStage();\n        const pos = gridStage?.getPointerPosition();\n        if (pos == null) return;\n        const { context } = aiTable;\n        const { x, y } = pos;\n        const curMousePosition = getMousePosition(aiTable, x, y, coordinate, AITable.getVisibleFields(aiTable), context!, targetName);\n        handleMouseStyle(AI_TABLE_FIELD_HEAD_MORE, curMousePosition.areaType, coordinate.container);\n    }\n}\n"]}
@@ -0,0 +1,268 @@
1
+ import { Component, computed, input, signal } from '@angular/core';
2
+ import { ChangeDetectionStrategy } from '@angular/core';
3
+ import { KoShape } from '../../../angular-konva';
4
+ import { AITableFieldType } from '../../../core';
5
+ import { generateTargetName } from '../../../utils';
6
+ import { isActiveCell } from '../../../renderer';
7
+ import { Colors, AI_TABLE_CELL_PADDING, AI_TABLE_ROW_BLANK_HEIGHT, AI_TABLE_OFFSET, AI_TABLE_CELL, AI_TABLE_CELL_BORDER, AI_TABLE_PROGRESS_BAR_HEIGHT, AI_TABLE_PROGRESS_TEXT_WIDTH, AI_TABLE_PROGRESS_BAR_RADIUS, AI_TABLE_PROGRESS_BAR_POINTER_WIDTH, AI_TABLE_PROGRESS_BAR_POINTER_HEIGHT, AI_TABLE_TEXT_GAP, DEFAULT_FONT_FAMILY, DEFAULT_FONT_SIZE, DEFAULT_TEXT_FILL } from '../../../constants';
8
+ import { isNil } from 'lodash';
9
+ import * as i0 from "@angular/core";
10
+ export class AITableCellProgress {
11
+ constructor() {
12
+ this.config = input();
13
+ this.readonly = computed(() => {
14
+ return this.config()?.readonly;
15
+ });
16
+ this.dragPointerX = signal(null);
17
+ this.railWidth = computed(() => {
18
+ const { columnWidth } = this.config().render;
19
+ return columnWidth - 2 * AI_TABLE_CELL_PADDING - AI_TABLE_PROGRESS_TEXT_WIDTH;
20
+ });
21
+ this.trackWidth = computed(() => {
22
+ return (this.progressValue() / 100) * this.railWidth();
23
+ });
24
+ this.pointerWidth = AI_TABLE_PROGRESS_BAR_POINTER_WIDTH;
25
+ this.progressOffsetY = (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_PROGRESS_BAR_HEIGHT) / 2 + AI_TABLE_OFFSET;
26
+ this.dragProgressValue = signal(null);
27
+ this.progressValue = computed(() => {
28
+ const dragValue = this.dragProgressValue();
29
+ if (dragValue !== null) {
30
+ return dragValue;
31
+ }
32
+ const { render } = this.config();
33
+ const { transformValue } = render;
34
+ if (isNil(transformValue)) {
35
+ return 0;
36
+ }
37
+ return transformValue;
38
+ });
39
+ this.whiteBgConfig = computed(() => {
40
+ const { aiTable, render, field, recordId, coordinate } = this.config();
41
+ const pointPosition = aiTable.context.pointPosition();
42
+ const { x, y } = render;
43
+ const { columnIndex } = pointPosition;
44
+ const isActive = isActiveCell([recordId, field._id], aiTable);
45
+ return {
46
+ x: x - AI_TABLE_CELL_PADDING + AI_TABLE_CELL_BORDER / 2,
47
+ y: y + AI_TABLE_CELL_BORDER + AI_TABLE_OFFSET,
48
+ width: coordinate.getColumnWidth(columnIndex) - (AI_TABLE_CELL_BORDER + AI_TABLE_OFFSET) * 2 + AI_TABLE_CELL_BORDER / 2,
49
+ height: AI_TABLE_ROW_BLANK_HEIGHT - (AI_TABLE_CELL_BORDER + AI_TABLE_OFFSET),
50
+ fill: Colors.white,
51
+ stroke: isActive ? null : Colors.white,
52
+ name: generateTargetName({
53
+ targetName: AI_TABLE_CELL,
54
+ fieldId: field._id,
55
+ recordId
56
+ })
57
+ };
58
+ });
59
+ this.railConfig = computed(() => {
60
+ const { render, field, recordId } = this.config();
61
+ const { x } = render;
62
+ return {
63
+ x,
64
+ y: this.progressOffsetY,
65
+ width: this.railWidth(),
66
+ height: AI_TABLE_PROGRESS_BAR_HEIGHT,
67
+ cornerRadius: AI_TABLE_PROGRESS_BAR_RADIUS,
68
+ fill: Colors.gray200,
69
+ name: generateTargetName({
70
+ targetName: AI_TABLE_CELL,
71
+ fieldId: field._id,
72
+ recordId,
73
+ mouseStyle: this.readonly() ? 'default' : 'pointer'
74
+ })
75
+ };
76
+ });
77
+ this.trackConfig = computed(() => {
78
+ const { render, field, recordId } = this.config();
79
+ const { x } = render;
80
+ return {
81
+ x,
82
+ y: this.progressOffsetY,
83
+ width: this.trackWidth(),
84
+ height: AI_TABLE_PROGRESS_BAR_HEIGHT,
85
+ cornerRadius: AI_TABLE_PROGRESS_BAR_RADIUS,
86
+ fill: Colors.success,
87
+ name: generateTargetName({
88
+ targetName: AI_TABLE_CELL,
89
+ fieldId: field._id,
90
+ recordId,
91
+ mouseStyle: this.readonly() ? 'default' : 'pointer'
92
+ })
93
+ };
94
+ });
95
+ this.pointerConfig = computed(() => {
96
+ const { render, field, recordId } = this.config();
97
+ const { x } = render;
98
+ const halfPointerWidth = this.pointerWidth / 2;
99
+ const pointerY = this.progressOffsetY - (AI_TABLE_PROGRESS_BAR_POINTER_HEIGHT - AI_TABLE_PROGRESS_BAR_HEIGHT) / 2;
100
+ let pointerX;
101
+ if (this.dragPointerX() !== null) {
102
+ pointerX = this.dragPointerX() - halfPointerWidth;
103
+ }
104
+ else {
105
+ pointerX = x + this.trackWidth() - halfPointerWidth;
106
+ }
107
+ return {
108
+ x: pointerX,
109
+ y: pointerY,
110
+ width: this.pointerWidth,
111
+ height: AI_TABLE_PROGRESS_BAR_POINTER_HEIGHT,
112
+ fill: Colors.white,
113
+ stroke: Colors.success,
114
+ strokeWidth: 1,
115
+ cornerRadius: AI_TABLE_PROGRESS_BAR_RADIUS,
116
+ opacity: this.readonly() ? 0 : 1,
117
+ draggable: !this.readonly(),
118
+ dragBoundFunc: (pos) => {
119
+ const minX = x;
120
+ const maxX = x + this.railWidth() - this.pointerWidth;
121
+ return {
122
+ x: Math.min(minX, Math.min(maxX, pos.x)),
123
+ y: pointerY
124
+ };
125
+ },
126
+ name: generateTargetName({
127
+ targetName: AI_TABLE_CELL,
128
+ fieldId: field._id,
129
+ recordId,
130
+ mouseStyle: this.readonly() ? 'default' : 'pointer'
131
+ })
132
+ };
133
+ });
134
+ this.textConfig = computed(() => {
135
+ const { render, field, recordId } = this.config();
136
+ const { x } = render;
137
+ const textX = x + this.railWidth() + AI_TABLE_TEXT_GAP;
138
+ const textY = (AI_TABLE_ROW_BLANK_HEIGHT - DEFAULT_FONT_SIZE) / 2 + AI_TABLE_OFFSET;
139
+ return {
140
+ x: textX,
141
+ y: textY,
142
+ text: `${this.progressValue()}%`,
143
+ fill: DEFAULT_TEXT_FILL,
144
+ fontFamily: DEFAULT_FONT_FAMILY,
145
+ fontSize: DEFAULT_FONT_SIZE,
146
+ name: generateTargetName({
147
+ targetName: AI_TABLE_CELL,
148
+ fieldId: field._id,
149
+ recordId
150
+ })
151
+ };
152
+ });
153
+ }
154
+ static { this.fieldType = AITableFieldType.progress; }
155
+ calculatePercentage(clickX) {
156
+ return Math.max(0, Math.min(100, Math.round((clickX / this.railWidth()) * 100)));
157
+ }
158
+ koClick(e) {
159
+ if (this.readonly()) {
160
+ return;
161
+ }
162
+ this.updateProgressValue(e);
163
+ }
164
+ pointerDragstart(e) {
165
+ if (this.readonly()) {
166
+ return;
167
+ }
168
+ }
169
+ pointerDragmove(e) {
170
+ if (this.readonly()) {
171
+ return;
172
+ }
173
+ const { render, aiTable, coordinate } = this.config();
174
+ const { x } = render;
175
+ const { scrollLeft } = aiTable.context.scrollState();
176
+ const pointPosition = aiTable.context.pointPosition();
177
+ const { columnIndex } = pointPosition;
178
+ const columnLeftX = coordinate.getColumnOffset(columnIndex) - scrollLeft + AI_TABLE_OFFSET;
179
+ const stage = e.event.target.getStage();
180
+ if (!stage)
181
+ return;
182
+ const point = stage.getPointerPosition();
183
+ if (!point)
184
+ return;
185
+ const dragX = point.x - columnLeftX - x;
186
+ const minX = x;
187
+ const maxX = x + this.railWidth();
188
+ let dragPointerX = point.x - columnLeftX;
189
+ if (dragPointerX < minX) {
190
+ dragPointerX = minX;
191
+ }
192
+ else if (dragPointerX > maxX) {
193
+ dragPointerX = maxX;
194
+ }
195
+ this.dragPointerX.set(dragPointerX);
196
+ const percentage = this.calculatePercentage(dragX);
197
+ this.dragProgressValue.set(percentage);
198
+ }
199
+ pointerDragend(e) {
200
+ if (this.readonly()) {
201
+ return;
202
+ }
203
+ this.updateProgressValue(e);
204
+ this.dragPointerX.set(null);
205
+ this.dragProgressValue.set(null);
206
+ }
207
+ updateProgressValue(e) {
208
+ const { render, aiTable, coordinate, actions, field, recordId } = this.config();
209
+ const { x } = render;
210
+ const { scrollLeft } = aiTable.context.scrollState();
211
+ const pointPosition = aiTable.context.pointPosition();
212
+ const { columnIndex } = pointPosition;
213
+ const columnLeftX = coordinate.getColumnOffset(columnIndex) - scrollLeft + AI_TABLE_OFFSET;
214
+ const stage = e.event.target.getStage();
215
+ if (!stage)
216
+ return;
217
+ const point = stage.getPointerPosition();
218
+ if (!point)
219
+ return;
220
+ const dragX = point.x - columnLeftX - x;
221
+ const percentage = this.calculatePercentage(dragX);
222
+ if (!this.readonly() && actions && actions.updateFieldValue) {
223
+ actions.updateFieldValue({
224
+ value: percentage,
225
+ path: [recordId, field._id]
226
+ });
227
+ }
228
+ }
229
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableCellProgress, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
230
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: AITableCellProgress, isStandalone: true, selector: "ai-table-progress", inputs: { config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: `
231
+ @if (!readonly()) {
232
+ <ko-rect [config]="whiteBgConfig()"></ko-rect>
233
+ }
234
+ <ko-rect [config]="railConfig()" (koClick)="koClick($event)"></ko-rect>
235
+ <ko-rect [config]="trackConfig()" (koClick)="koClick($event)"></ko-rect>
236
+ <ko-rect
237
+ [config]="pointerConfig()"
238
+ (koDragstart)="pointerDragstart($event)"
239
+ (koDragmove)="pointerDragmove($event)"
240
+ (koDragend)="pointerDragend($event)"
241
+ ></ko-rect>
242
+ <ko-text [config]="textConfig()"></ko-text>
243
+ `, 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"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
244
+ }
245
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableCellProgress, decorators: [{
246
+ type: Component,
247
+ args: [{
248
+ selector: 'ai-table-progress',
249
+ template: `
250
+ @if (!readonly()) {
251
+ <ko-rect [config]="whiteBgConfig()"></ko-rect>
252
+ }
253
+ <ko-rect [config]="railConfig()" (koClick)="koClick($event)"></ko-rect>
254
+ <ko-rect [config]="trackConfig()" (koClick)="koClick($event)"></ko-rect>
255
+ <ko-rect
256
+ [config]="pointerConfig()"
257
+ (koDragstart)="pointerDragstart($event)"
258
+ (koDragmove)="pointerDragmove($event)"
259
+ (koDragend)="pointerDragend($event)"
260
+ ></ko-rect>
261
+ <ko-text [config]="textConfig()"></ko-text>
262
+ `,
263
+ standalone: true,
264
+ imports: [KoShape],
265
+ changeDetection: ChangeDetectionStrategy.OnPush
266
+ }]
267
+ }] });
268
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"progress.component.js","sourceRoot":"","sources":["../../../../../../packages/grid/src/renderer/components/cells/progress.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, input, signal } from '@angular/core';\nimport { ChangeDetectionStrategy } from '@angular/core';\nimport { KoShape, KoEventObject } from '../../../angular-konva';\nimport { HoverCellComponent } from '../../interfaces';\nimport { AITableHoverCellConfig } from '../../../types';\nimport { AITableFieldType } from '../../../core';\nimport { generateTargetName } from '../../../utils';\nimport { isActiveCell } from '../../../renderer';\nimport {\n    Colors,\n    AI_TABLE_CELL_PADDING,\n    AI_TABLE_ROW_BLANK_HEIGHT,\n    AI_TABLE_OFFSET,\n    AI_TABLE_CELL,\n    AI_TABLE_CELL_BORDER,\n    AI_TABLE_PROGRESS_BAR_HEIGHT,\n    AI_TABLE_PROGRESS_TEXT_WIDTH,\n    AI_TABLE_PROGRESS_BAR_RADIUS,\n    AI_TABLE_PROGRESS_BAR_POINTER_WIDTH,\n    AI_TABLE_PROGRESS_BAR_POINTER_HEIGHT,\n    AI_TABLE_TEXT_GAP,\n    DEFAULT_FONT_FAMILY,\n    DEFAULT_FONT_SIZE,\n    DEFAULT_TEXT_FILL\n} from '../../../constants';\nimport { isNil } from 'lodash';\n\n@Component({\n    selector: 'ai-table-progress',\n    template: `\n        @if (!readonly()) {\n            <ko-rect [config]=\"whiteBgConfig()\"></ko-rect>\n        }\n        <ko-rect [config]=\"railConfig()\" (koClick)=\"koClick($event)\"></ko-rect>\n        <ko-rect [config]=\"trackConfig()\" (koClick)=\"koClick($event)\"></ko-rect>\n        <ko-rect\n            [config]=\"pointerConfig()\"\n            (koDragstart)=\"pointerDragstart($event)\"\n            (koDragmove)=\"pointerDragmove($event)\"\n            (koDragend)=\"pointerDragend($event)\"\n        ></ko-rect>\n        <ko-text [config]=\"textConfig()\"></ko-text>\n    `,\n    standalone: true,\n    imports: [KoShape],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableCellProgress implements HoverCellComponent {\n    static fieldType = AITableFieldType.progress;\n\n    config = input<AITableHoverCellConfig>();\n\n    readonly = computed(() => {\n        return this.config()?.readonly;\n    });\n\n    private dragPointerX = signal<number | null>(null);\n\n    private railWidth = computed(() => {\n        const { columnWidth } = this.config()!.render;\n        return columnWidth - 2 * AI_TABLE_CELL_PADDING - AI_TABLE_PROGRESS_TEXT_WIDTH;\n    });\n\n    private trackWidth = computed(() => {\n        return (this.progressValue() / 100) * this.railWidth();\n    });\n\n    private pointerWidth = AI_TABLE_PROGRESS_BAR_POINTER_WIDTH;\n\n    private progressOffsetY = (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_PROGRESS_BAR_HEIGHT) / 2 + AI_TABLE_OFFSET;\n\n    private dragProgressValue = signal<number | null>(null);\n\n    private progressValue = computed(() => {\n        const dragValue = this.dragProgressValue();\n        if (dragValue !== null) {\n            return dragValue;\n        }\n\n        const { render } = this.config()!;\n        const { transformValue } = render;\n        if (isNil(transformValue)) {\n            return 0;\n        }\n        return transformValue;\n    });\n\n    whiteBgConfig = computed(() => {\n        const { aiTable, render, field, recordId, coordinate } = this.config()!;\n        const pointPosition = aiTable.context!.pointPosition();\n        const { x, y } = render;\n        const { columnIndex } = pointPosition;\n        const isActive = isActiveCell([recordId!, field._id], aiTable);\n\n        return {\n            x: x - AI_TABLE_CELL_PADDING + AI_TABLE_CELL_BORDER / 2,\n            y: y + AI_TABLE_CELL_BORDER + AI_TABLE_OFFSET,\n            width: coordinate.getColumnWidth(columnIndex) - (AI_TABLE_CELL_BORDER + AI_TABLE_OFFSET) * 2 + AI_TABLE_CELL_BORDER / 2,\n            height: AI_TABLE_ROW_BLANK_HEIGHT - (AI_TABLE_CELL_BORDER + AI_TABLE_OFFSET),\n            fill: Colors.white,\n            stroke: isActive ? null : Colors.white,\n            name: generateTargetName({\n                targetName: AI_TABLE_CELL,\n                fieldId: field._id,\n                recordId\n            })\n        };\n    });\n\n    railConfig = computed(() => {\n        const { render, field, recordId } = this.config()!;\n        const { x } = render;\n\n        return {\n            x,\n            y: this.progressOffsetY,\n            width: this.railWidth(),\n            height: AI_TABLE_PROGRESS_BAR_HEIGHT,\n            cornerRadius: AI_TABLE_PROGRESS_BAR_RADIUS,\n            fill: Colors.gray200,\n            name: generateTargetName({\n                targetName: AI_TABLE_CELL,\n                fieldId: field._id,\n                recordId,\n                mouseStyle: this.readonly() ? 'default' : 'pointer'\n            })\n        };\n    });\n\n    trackConfig = computed(() => {\n        const { render, field, recordId } = this.config()!;\n        const { x } = render;\n\n        return {\n            x,\n            y: this.progressOffsetY,\n            width: this.trackWidth(),\n            height: AI_TABLE_PROGRESS_BAR_HEIGHT,\n            cornerRadius: AI_TABLE_PROGRESS_BAR_RADIUS,\n            fill: Colors.success,\n            name: generateTargetName({\n                targetName: AI_TABLE_CELL,\n                fieldId: field._id,\n                recordId,\n                mouseStyle: this.readonly() ? 'default' : 'pointer'\n            })\n        };\n    });\n\n    pointerConfig = computed(() => {\n        const { render, field, recordId } = this.config()!;\n        const { x } = render;\n        const halfPointerWidth = this.pointerWidth / 2;\n        const pointerY = this.progressOffsetY - (AI_TABLE_PROGRESS_BAR_POINTER_HEIGHT - AI_TABLE_PROGRESS_BAR_HEIGHT) / 2;\n\n        let pointerX: number;\n        if (this.dragPointerX() !== null) {\n            pointerX = this.dragPointerX()! - halfPointerWidth;\n        } else {\n            pointerX = x + this.trackWidth() - halfPointerWidth;\n        }\n\n        return {\n            x: pointerX,\n            y: pointerY,\n            width: this.pointerWidth,\n            height: AI_TABLE_PROGRESS_BAR_POINTER_HEIGHT,\n            fill: Colors.white,\n            stroke: Colors.success,\n            strokeWidth: 1,\n            cornerRadius: AI_TABLE_PROGRESS_BAR_RADIUS,\n            opacity: this.readonly() ? 0 : 1,\n            draggable: !this.readonly(),\n            dragBoundFunc: (pos: { x: number; y: number }) => {\n                const minX = x;\n                const maxX = x + this.railWidth() - this.pointerWidth;\n\n                return {\n                    x: Math.min(minX, Math.min(maxX, pos.x)),\n                    y: pointerY\n                };\n            },\n            name: generateTargetName({\n                targetName: AI_TABLE_CELL,\n                fieldId: field._id,\n                recordId,\n                mouseStyle: this.readonly() ? 'default' : 'pointer'\n            })\n        };\n    });\n\n    textConfig = computed(() => {\n        const { render, field, recordId } = this.config()!;\n        const { x } = render;\n        const textX = x + this.railWidth() + AI_TABLE_TEXT_GAP;\n        const textY = (AI_TABLE_ROW_BLANK_HEIGHT - DEFAULT_FONT_SIZE) / 2 + AI_TABLE_OFFSET;\n\n        return {\n            x: textX,\n            y: textY,\n            text: `${this.progressValue()}%`,\n            fill: DEFAULT_TEXT_FILL,\n            fontFamily: DEFAULT_FONT_FAMILY,\n            fontSize: DEFAULT_FONT_SIZE,\n            name: generateTargetName({\n                targetName: AI_TABLE_CELL,\n                fieldId: field._id,\n                recordId\n            })\n        };\n    });\n\n    private calculatePercentage(clickX: number): number {\n        return Math.max(0, Math.min(100, Math.round((clickX / this.railWidth()) * 100)));\n    }\n\n    koClick(e: KoEventObject<MouseEvent>) {\n        if (this.readonly()) {\n            return;\n        }\n        this.updateProgressValue(e);\n    }\n\n    pointerDragstart(e: KoEventObject<MouseEvent>) {\n        if (this.readonly()) {\n            return;\n        }\n    }\n\n    pointerDragmove(e: KoEventObject<MouseEvent>) {\n        if (this.readonly()) {\n            return;\n        }\n\n        const { render, aiTable, coordinate } = this.config()!;\n        const { x } = render;\n        const { scrollLeft } = aiTable.context!.scrollState();\n        const pointPosition = aiTable.context!.pointPosition();\n        const { columnIndex } = pointPosition;\n        const columnLeftX = coordinate.getColumnOffset(columnIndex) - scrollLeft + AI_TABLE_OFFSET;\n\n        const stage = e.event.target.getStage();\n        if (!stage) return;\n\n        const point = stage.getPointerPosition();\n        if (!point) return;\n\n        const dragX = point.x - columnLeftX - x;\n        const minX = x;\n        const maxX = x + this.railWidth();\n\n        let dragPointerX = point.x - columnLeftX;\n        if (dragPointerX < minX) {\n            dragPointerX = minX;\n        } else if (dragPointerX > maxX) {\n            dragPointerX = maxX;\n        }\n\n        this.dragPointerX.set(dragPointerX);\n        const percentage = this.calculatePercentage(dragX);\n        this.dragProgressValue.set(percentage);\n    }\n\n    pointerDragend(e: KoEventObject<MouseEvent>) {\n        if (this.readonly()) {\n            return;\n        }\n\n        this.updateProgressValue(e);\n        this.dragPointerX.set(null);\n        this.dragProgressValue.set(null);\n    }\n\n    private updateProgressValue(e: KoEventObject<MouseEvent>): void {\n        const { render, aiTable, coordinate, actions, field, recordId } = this.config()!;\n        const { x } = render;\n        const { scrollLeft } = aiTable.context!.scrollState();\n        const pointPosition = aiTable.context!.pointPosition();\n        const { columnIndex } = pointPosition;\n        const columnLeftX = coordinate.getColumnOffset(columnIndex) - scrollLeft + AI_TABLE_OFFSET;\n\n        const stage = e.event.target.getStage();\n        if (!stage) return;\n\n        const point = stage.getPointerPosition();\n        if (!point) return;\n\n        const dragX = point.x - columnLeftX - x;\n        const percentage = this.calculatePercentage(dragX);\n\n        if (!this.readonly() && actions && actions.updateFieldValue) {\n            actions.updateFieldValue({\n                value: percentage,\n                path: [recordId!, field._id]\n            });\n        }\n    }\n}\n"]}
@@ -0,0 +1,90 @@
1
+ import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';
2
+ import { AI_TABLE_ACTION_COMMON_RADIUS, AI_TABLE_ACTION_COMMON_RIGHT_PADDING, AI_TABLE_ACTION_COMMON_SIZE, AI_TABLE_CELL, AI_TABLE_CELL_EDIT, AI_TABLE_CELL_PADDING, Colors, EditPath } from '../../../constants';
3
+ import { generateTargetName } from '../../../utils';
4
+ import { AITableFieldType } from '../../../core';
5
+ import { AITableActionIcon } from '../action-icon.component';
6
+ import { drawer } from '../../drawers/drawer';
7
+ import { AITableText } from '../text.component';
8
+ import * as i0 from "@angular/core";
9
+ export class AITableCellRichText {
10
+ constructor() {
11
+ this.config = input();
12
+ this.textConfig = computed(() => {
13
+ const render = this.config()?.render;
14
+ if (render) {
15
+ const { x, y, transformValue, field, columnWidth, rowHeight, style, zIndex } = render;
16
+ let textRender = transformValue;
17
+ if (textRender == null) {
18
+ return;
19
+ }
20
+ textRender = textRender.replace(/\r|\n/g, ' ');
21
+ const fontWeight = style?.fontWeight;
22
+ const textMaxWidth = columnWidth - AI_TABLE_CELL_PADDING - AI_TABLE_ACTION_COMMON_RIGHT_PADDING - AI_TABLE_ACTION_COMMON_SIZE;
23
+ const { text, textWidth } = drawer.textEllipsis({
24
+ text: textRender,
25
+ maxWidth: textMaxWidth,
26
+ fontWeight
27
+ });
28
+ return {
29
+ x,
30
+ y,
31
+ text,
32
+ wrap: 'none',
33
+ width: textWidth,
34
+ fillStyle: Colors.primary,
35
+ height: rowHeight + 2,
36
+ lineHeight: 1.84,
37
+ listening: false,
38
+ ellipsis: true,
39
+ zIndex
40
+ };
41
+ }
42
+ return;
43
+ });
44
+ this.iconConfig = computed(() => {
45
+ const { coordinate, render, field, recordId, readonly } = this.config();
46
+ const offsetX = render.columnWidth - AI_TABLE_ACTION_COMMON_SIZE - AI_TABLE_ACTION_COMMON_RIGHT_PADDING;
47
+ const offsetY = (coordinate.rowInitSize - AI_TABLE_ACTION_COMMON_SIZE) / 2;
48
+ return {
49
+ coordinate,
50
+ readonly,
51
+ name: generateTargetName({
52
+ targetName: AI_TABLE_CELL,
53
+ fieldId: field._id,
54
+ recordId,
55
+ source: AI_TABLE_CELL_EDIT,
56
+ mouseStyle: readonly ? 'default' : 'pointer'
57
+ }),
58
+ x: offsetX,
59
+ y: offsetY,
60
+ data: EditPath,
61
+ fill: Colors.gray600,
62
+ hoverFill: Colors.primary,
63
+ backgroundWidth: AI_TABLE_ACTION_COMMON_SIZE,
64
+ backgroundHeight: AI_TABLE_ACTION_COMMON_SIZE,
65
+ cornerRadius: AI_TABLE_ACTION_COMMON_RADIUS,
66
+ listening: true
67
+ };
68
+ });
69
+ }
70
+ static { this.fieldType = AITableFieldType.richText; }
71
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableCellRichText, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
72
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: AITableCellRichText, isStandalone: true, selector: "ai-table-rich-text", inputs: { config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: `
73
+ <ai-table-text [config]="textConfig()!"></ai-table-text>
74
+ <ai-table-action-icon [config]="iconConfig()"></ai-table-action-icon>
75
+ `, isInline: true, dependencies: [{ kind: "component", type: AITableText, selector: "ai-table-text", inputs: ["config"], outputs: ["koClick", "koMouseMove"] }, { kind: "component", type: AITableActionIcon, selector: "ai-table-action-icon", inputs: ["config"], outputs: ["onClick", "onMousemove", "onMouseenter", "onMouseleave"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
76
+ }
77
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableCellRichText, decorators: [{
78
+ type: Component,
79
+ args: [{
80
+ selector: 'ai-table-rich-text',
81
+ template: `
82
+ <ai-table-text [config]="textConfig()!"></ai-table-text>
83
+ <ai-table-action-icon [config]="iconConfig()"></ai-table-action-icon>
84
+ `,
85
+ standalone: true,
86
+ imports: [AITableText, AITableActionIcon],
87
+ changeDetection: ChangeDetectionStrategy.OnPush
88
+ }]
89
+ }] });
90
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rich-text.component.js","sourceRoot":"","sources":["../../../../../../packages/grid/src/renderer/components/cells/rich-text.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';\nimport {\n    AI_TABLE_ACTION_COMMON_RADIUS,\n    AI_TABLE_ACTION_COMMON_RIGHT_PADDING,\n    AI_TABLE_ACTION_COMMON_SIZE,\n    AI_TABLE_CELL,\n    AI_TABLE_CELL_EDIT,\n    AI_TABLE_CELL_PADDING,\n    Colors,\n    EditPath\n} from '../../../constants';\nimport { generateTargetName } from '../../../utils';\nimport { AITableActionIconConfig, AITableHoverCellConfig } from '../../../types';\nimport { AITableFieldType } from '../../../core';\nimport { HoverCellComponent } from '../../interfaces';\nimport { AITableActionIcon } from '../action-icon.component';\nimport { TextConfig } from 'konva/lib/shapes/Text';\nimport { drawer } from '../../drawers/drawer';\nimport { AITableText } from '../text.component';\n\n@Component({\n    selector: 'ai-table-rich-text',\n    template: `\n        <ai-table-text [config]=\"textConfig()!\"></ai-table-text>\n        <ai-table-action-icon [config]=\"iconConfig()\"></ai-table-action-icon>\n    `,\n    standalone: true,\n    imports: [AITableText, AITableActionIcon],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableCellRichText implements HoverCellComponent {\n    static fieldType = AITableFieldType.richText;\n\n    config = input<AITableHoverCellConfig>();\n\n    textConfig = computed<TextConfig | undefined>(() => {\n        const render = this.config()?.render;\n        if (render) {\n            const { x, y, transformValue, field, columnWidth, rowHeight, style, zIndex } = render;\n            let textRender: string | null = transformValue;\n            if (textRender == null) {\n                return;\n            }\n            textRender = textRender.replace(/\\r|\\n/g, ' ');\n            const fontWeight = style?.fontWeight;\n            const textMaxWidth = columnWidth - AI_TABLE_CELL_PADDING - AI_TABLE_ACTION_COMMON_RIGHT_PADDING - AI_TABLE_ACTION_COMMON_SIZE;\n            const { text, textWidth } = drawer.textEllipsis({\n                text: textRender,\n                maxWidth: textMaxWidth,\n                fontWeight\n            });\n\n            return {\n                x,\n                y,\n                text,\n                wrap: 'none',\n                width: textWidth,\n                fillStyle: Colors.primary,\n                height: rowHeight + 2,\n                lineHeight: 1.84,\n                listening: false,\n                ellipsis: true,\n                zIndex\n            };\n        }\n        return;\n    });\n\n    iconConfig = computed<AITableActionIconConfig>(() => {\n        const { coordinate, render, field, recordId, readonly } = this.config()!;\n        const offsetX = render.columnWidth - AI_TABLE_ACTION_COMMON_SIZE - AI_TABLE_ACTION_COMMON_RIGHT_PADDING;\n        const offsetY = (coordinate.rowInitSize - AI_TABLE_ACTION_COMMON_SIZE) / 2;\n\n        return {\n            coordinate,\n            readonly,\n            name: generateTargetName({\n                targetName: AI_TABLE_CELL,\n                fieldId: field._id,\n                recordId,\n                source: AI_TABLE_CELL_EDIT,\n                mouseStyle: readonly ? 'default' : 'pointer'\n            }),\n            x: offsetX,\n            y: offsetY,\n            data: EditPath,\n            fill: Colors.gray600,\n            hoverFill: Colors.primary,\n            backgroundWidth: AI_TABLE_ACTION_COMMON_SIZE,\n            backgroundHeight: AI_TABLE_ACTION_COMMON_SIZE,\n            cornerRadius: AI_TABLE_ACTION_COMMON_RADIUS,\n            listening: true\n        };\n    });\n}\n"]}