@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.
- package/components/cell-editors/abstract-cell-editor.component.d.ts.map +1 -1
- package/components/cell-editors/cell-editor.scss +0 -1
- package/components/index.d.ts +0 -1
- package/components/index.d.ts.map +1 -1
- package/constants/editor.d.ts.map +1 -1
- package/constants/grid.d.ts +0 -1
- package/constants/grid.d.ts.map +1 -1
- package/constants/table.d.ts +3 -1
- package/constants/table.d.ts.map +1 -1
- package/core/types/core.d.ts +13 -13
- package/core/types/core.d.ts.map +1 -1
- package/dom-grid.component.d.ts.map +1 -1
- package/esm2022/components/cell-editors/abstract-cell-editor.component.mjs +2 -4
- package/esm2022/components/cell-editors/date/date-editor.component.mjs +5 -5
- package/esm2022/components/index.mjs +1 -2
- package/esm2022/constants/editor.mjs +3 -4
- package/esm2022/constants/grid.mjs +1 -2
- package/esm2022/constants/table.mjs +4 -2
- package/esm2022/core/constants/field.mjs +2 -2
- package/esm2022/core/types/core.mjs +1 -1
- package/esm2022/dom-grid.component.mjs +2 -4
- package/esm2022/grid-base.component.mjs +5 -28
- package/esm2022/grid.component.mjs +17 -52
- package/esm2022/renderer/components/cells/attachment.component.mjs +9 -19
- package/esm2022/renderer/components/cells/index.mjs +3 -2
- package/esm2022/renderer/components/cells/link.component.mjs +3 -5
- package/esm2022/renderer/components/cells/progress.component.mjs +268 -0
- package/esm2022/renderer/components/cells/rich-text.component.mjs +90 -0
- package/esm2022/renderer/drawers/cell-drawer.mjs +3 -3
- package/esm2022/utils/cell.mjs +3 -3
- package/esm2022/utils/clipboard/copy.mjs +11 -5
- package/esm2022/utils/clipboard/paste.mjs +1 -4
- package/esm2022/utils/field/model/attachment.mjs +8 -1
- package/esm2022/utils/field/model/date.mjs +13 -3
- package/esm2022/utils/field/model/field.mjs +1 -2
- package/esm2022/utils/field/model/link.mjs +16 -4
- package/esm2022/utils/field/model/member.mjs +1 -1
- package/esm2022/utils/field/model/number.mjs +11 -8
- package/esm2022/utils/field/model/progress.mjs +7 -7
- package/esm2022/utils/field/model/rate.mjs +3 -2
- package/esm2022/utils/field/model/rich-text.mjs +1 -1
- package/esm2022/utils/field/model/select.mjs +1 -1
- package/esm2022/utils/field/model/text.mjs +3 -2
- package/esm2022/utils/field/operate.mjs +4 -2
- package/esm2022/utils/i18n.mjs +3 -3
- package/esm2022/utils/index.mjs +2 -1
- package/esm2022/utils/match-keywords.mjs +9 -4
- package/fesm2022/ai-table-grid.mjs +836 -675
- package/fesm2022/ai-table-grid.mjs.map +1 -1
- package/grid-base.component.d.ts +2 -3
- package/grid-base.component.d.ts.map +1 -1
- package/grid.component.d.ts +1 -1
- package/grid.component.d.ts.map +1 -1
- package/package.json +1 -1
- package/renderer/components/cells/attachment.component.d.ts +0 -3
- package/renderer/components/cells/attachment.component.d.ts.map +1 -1
- package/renderer/components/cells/index.d.ts +2 -1
- package/renderer/components/cells/index.d.ts.map +1 -1
- package/renderer/components/cells/link.component.d.ts.map +1 -1
- package/renderer/components/cells/progress.component.d.ts +82 -0
- package/renderer/components/cells/progress.component.d.ts.map +1 -0
- package/renderer/components/cells/{richtext.component.d.ts → rich-text.component.d.ts} +4 -4
- package/renderer/components/cells/rich-text.component.d.ts.map +1 -0
- package/renderer/drawers/cell-drawer.d.ts.map +1 -1
- package/utils/clipboard/paste.d.ts.map +1 -1
- package/utils/field/model/attachment.d.ts.map +1 -1
- package/utils/field/model/date.d.ts +1 -0
- package/utils/field/model/date.d.ts.map +1 -1
- package/utils/field/model/field.d.ts.map +1 -1
- package/utils/field/model/link.d.ts +3 -2
- package/utils/field/model/link.d.ts.map +1 -1
- package/utils/field/model/member.d.ts +1 -1
- package/utils/field/model/member.d.ts.map +1 -1
- package/utils/field/model/number.d.ts +5 -4
- package/utils/field/model/number.d.ts.map +1 -1
- package/utils/field/model/progress.d.ts +4 -4
- package/utils/field/model/progress.d.ts.map +1 -1
- package/utils/field/model/rate.d.ts +2 -2
- package/utils/field/model/rate.d.ts.map +1 -1
- package/utils/field/model/rich-text.d.ts +3 -3
- package/utils/field/model/rich-text.d.ts.map +1 -1
- package/utils/field/model/select.d.ts +1 -1
- package/utils/field/model/select.d.ts.map +1 -1
- package/utils/field/model/text.d.ts +3 -3
- package/utils/field/model/text.d.ts.map +1 -1
- package/utils/field/operate.d.ts +1 -1
- package/utils/field/operate.d.ts.map +1 -1
- package/utils/i18n.d.ts +1 -1
- package/utils/index.d.ts +1 -0
- package/utils/index.d.ts.map +1 -1
- package/utils/match-keywords.d.ts.map +1 -1
- package/components/cell-editors/progress/progress-editor.component.d.ts +0 -19
- package/components/cell-editors/progress/progress-editor.component.d.ts.map +0 -1
- package/components/cell-editors/progress/progress-editor.component.scss +0 -29
- package/esm2022/components/cell-editors/progress/progress-editor.component.mjs +0 -72
- package/esm2022/renderer/components/cells/richtext.component.mjs +0 -90
- 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,
|
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: [
|
85
|
+
imports: [AITableText],
|
88
86
|
changeDetection: ChangeDetectionStrategy.OnPush
|
89
87
|
}]
|
90
88
|
}] });
|
91
|
-
//# sourceMappingURL=data:application/json;base64,
|
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"]}
|