@ai-table/grid 0.0.73 → 0.1.0

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 (232) hide show
  1. package/angular-konva/components/container.component.d.ts.map +1 -1
  2. package/angular-konva/components/shape.component.d.ts.map +1 -1
  3. package/angular-konva/components/stage.component.d.ts.map +1 -1
  4. package/components/cell-editors/abstract-cell-editor.component.d.ts.map +1 -1
  5. package/components/cell-editors/date/date-editor.component.d.ts.map +1 -1
  6. package/components/cell-editors/link/edit-link/edit-link.component.d.ts.map +1 -1
  7. package/components/cell-editors/link/link-editor.component.d.ts.map +1 -1
  8. package/components/cell-editors/number/number-editor.component.d.ts.map +1 -1
  9. package/components/cell-editors/select/select-editor.component.d.ts.map +1 -1
  10. package/components/cell-editors/text/text-editor.component.d.ts.map +1 -1
  11. package/components/cell-views/select/option.component.d.ts.map +1 -1
  12. package/components/context-menu/context-menu.component.d.ts.map +1 -1
  13. package/components/drag/drag.component.d.ts.map +1 -1
  14. package/components/field-menu/field-menu.component.d.ts.map +1 -1
  15. package/components/field-setting/field-setting.component.d.ts.map +1 -1
  16. package/core/context.d.ts +2 -0
  17. package/core/context.d.ts.map +1 -1
  18. package/core/types/ai-table.d.ts.map +1 -1
  19. package/core/utils/field.d.ts.map +1 -1
  20. package/core/utils/queries.d.ts.map +1 -1
  21. package/core/utils/short-id.d.ts.map +1 -1
  22. package/dom-grid.component.d.ts.map +1 -1
  23. package/fesm2022/ai-table-grid.mjs +322 -310
  24. package/fesm2022/ai-table-grid.mjs.map +1 -1
  25. package/grid-base.component.d.ts +3 -1
  26. package/grid-base.component.d.ts.map +1 -1
  27. package/grid.component.d.ts +1 -1
  28. package/grid.component.d.ts.map +1 -1
  29. package/package.json +3 -5
  30. package/pipes/grid.pipe.d.ts.map +1 -1
  31. package/renderer/components/action-icon.component.d.ts.map +1 -1
  32. package/renderer/components/add-field-column.component.d.ts.map +1 -1
  33. package/renderer/components/cells/attachment.component.d.ts.map +1 -1
  34. package/renderer/components/cells/link.component.d.ts.map +1 -1
  35. package/renderer/components/cells/progress.component.d.ts.map +1 -1
  36. package/renderer/components/cells/rate.component.d.ts.map +1 -1
  37. package/renderer/components/cells/rich-text.component.d.ts.map +1 -1
  38. package/renderer/components/cells.component.d.ts.map +1 -1
  39. package/renderer/components/field-head.component.d.ts +2 -2
  40. package/renderer/components/field-head.component.d.ts.map +1 -1
  41. package/renderer/components/field-icon.component.d.ts.map +1 -1
  42. package/renderer/components/frozen-cells.component.d.ts.map +1 -1
  43. package/renderer/components/frozen-heads.component.d.ts +1 -1
  44. package/renderer/components/frozen-heads.component.d.ts.map +1 -1
  45. package/renderer/components/frozen-placeholder-cells.component.d.ts.map +1 -1
  46. package/renderer/components/heads.component.d.ts +1 -1
  47. package/renderer/components/heads.component.d.ts.map +1 -1
  48. package/renderer/components/hover-cell.component.d.ts.map +1 -1
  49. package/renderer/components/hover-row-heads.component.d.ts.map +1 -1
  50. package/renderer/components/icon.component.d.ts.map +1 -1
  51. package/renderer/components/other-rows.component.d.ts.map +1 -1
  52. package/renderer/components/placeholder-cells.component.d.ts.map +1 -1
  53. package/renderer/components/text.component.d.ts.map +1 -1
  54. package/renderer/creations/create-active-cell-border.d.ts.map +1 -1
  55. package/renderer/creations/create-cells.d.ts.map +1 -1
  56. package/renderer/creations/create-heads.d.ts.map +1 -1
  57. package/renderer/drawers/add-row-layout-drawer.d.ts +1 -1
  58. package/renderer/drawers/add-row-layout-drawer.d.ts.map +1 -1
  59. package/renderer/drawers/cell-drawer.d.ts.map +1 -1
  60. package/renderer/drawers/drawer.d.ts +1 -1
  61. package/renderer/renderer.component.d.ts +5 -4
  62. package/renderer/renderer.component.d.ts.map +1 -1
  63. package/types/cell.d.ts +2 -0
  64. package/types/cell.d.ts.map +1 -1
  65. package/types/component-config.d.ts +2 -0
  66. package/types/component-config.d.ts.map +1 -1
  67. package/types/grid.d.ts +4 -0
  68. package/types/grid.d.ts.map +1 -1
  69. package/types/row.d.ts +1 -0
  70. package/types/row.d.ts.map +1 -1
  71. package/utils/build.d.ts.map +1 -1
  72. package/utils/clipboard/clipboard.d.ts.map +1 -1
  73. package/utils/clipboard/copy.d.ts.map +1 -1
  74. package/utils/clipboard/paste.d.ts +5 -1
  75. package/utils/clipboard/paste.d.ts.map +1 -1
  76. package/utils/common.d.ts.map +1 -1
  77. package/utils/field/model/date.d.ts.map +1 -1
  78. package/utils/field/model/link.d.ts.map +1 -1
  79. package/utils/field/model/progress.d.ts.map +1 -1
  80. package/utils/field/model/text.d.ts.map +1 -1
  81. package/utils/get-text-width.d.ts.map +1 -1
  82. package/utils/i18n.d.ts +2 -0
  83. package/utils/i18n.d.ts.map +1 -1
  84. package/utils/match-keywords.d.ts.map +1 -1
  85. package/utils/position.d.ts.map +1 -1
  86. package/utils/style.d.ts.map +1 -1
  87. package/utils/text-measure.d.ts.map +1 -1
  88. package/utils/visible-range.d.ts.map +1 -1
  89. package/esm2022/ai-table-grid.mjs +0 -5
  90. package/esm2022/angular-konva/components/container.component.mjs +0 -29
  91. package/esm2022/angular-konva/components/container.token.mjs +0 -3
  92. package/esm2022/angular-konva/components/index.mjs +0 -4
  93. package/esm2022/angular-konva/components/shape.component.mjs +0 -142
  94. package/esm2022/angular-konva/components/stage.component.mjs +0 -123
  95. package/esm2022/angular-konva/index.mjs +0 -5
  96. package/esm2022/angular-konva/interfaces/component.mjs +0 -4
  97. package/esm2022/angular-konva/interfaces/config.mjs +0 -2
  98. package/esm2022/angular-konva/interfaces/event-object.mjs +0 -2
  99. package/esm2022/angular-konva/interfaces/index.mjs +0 -5
  100. package/esm2022/angular-konva/interfaces/shape.mjs +0 -42
  101. package/esm2022/angular-konva/utils/apply-node-props.mjs +0 -67
  102. package/esm2022/angular-konva/utils/common.mjs +0 -48
  103. package/esm2022/angular-konva/utils/index.mjs +0 -5
  104. package/esm2022/angular-konva/utils/types.mjs +0 -2
  105. package/esm2022/angular-konva/utils/update-picture.mjs +0 -7
  106. package/esm2022/components/cell-editors/abstract-cell-editor.component.mjs +0 -56
  107. package/esm2022/components/cell-editors/date/date-editor.component.mjs +0 -87
  108. package/esm2022/components/cell-editors/link/edit-link/edit-link.component.mjs +0 -81
  109. package/esm2022/components/cell-editors/link/link-editor.component.mjs +0 -122
  110. package/esm2022/components/cell-editors/number/number-editor.component.mjs +0 -41
  111. package/esm2022/components/cell-editors/select/select-editor.component.mjs +0 -74
  112. package/esm2022/components/cell-editors/text/text-editor.component.mjs +0 -76
  113. package/esm2022/components/cell-views/select/option.component.mjs +0 -28
  114. package/esm2022/components/context-menu/context-menu.component.mjs +0 -42
  115. package/esm2022/components/drag/drag.component.mjs +0 -300
  116. package/esm2022/components/field-menu/field-menu.component.mjs +0 -47
  117. package/esm2022/components/field-setting/field-setting.component.mjs +0 -142
  118. package/esm2022/components/index.mjs +0 -10
  119. package/esm2022/constants/colors.mjs +0 -19
  120. package/esm2022/constants/editor.mjs +0 -11
  121. package/esm2022/constants/file-icon.mjs +0 -342
  122. package/esm2022/constants/grid.mjs +0 -35
  123. package/esm2022/constants/icon.mjs +0 -30
  124. package/esm2022/constants/index.mjs +0 -7
  125. package/esm2022/constants/table.mjs +0 -78
  126. package/esm2022/constants/text.mjs +0 -23
  127. package/esm2022/core/constants/field.mjs +0 -107
  128. package/esm2022/core/context.mjs +0 -29
  129. package/esm2022/core/coordinate.mjs +0 -222
  130. package/esm2022/core/index.mjs +0 -6
  131. package/esm2022/core/types/ai-table.mjs +0 -57
  132. package/esm2022/core/types/core.mjs +0 -2
  133. package/esm2022/core/types/index.mjs +0 -3
  134. package/esm2022/core/utils/common.mjs +0 -45
  135. package/esm2022/core/utils/field.mjs +0 -64
  136. package/esm2022/core/utils/id-creator.mjs +0 -21
  137. package/esm2022/core/utils/index.mjs +0 -5
  138. package/esm2022/core/utils/queries.mjs +0 -80
  139. package/esm2022/core/utils/short-id.mjs +0 -53
  140. package/esm2022/dom-grid.component.mjs +0 -80
  141. package/esm2022/grid-base.component.mjs +0 -145
  142. package/esm2022/grid.component.mjs +0 -649
  143. package/esm2022/index.mjs +0 -2
  144. package/esm2022/pipes/grid.pipe.mjs +0 -110
  145. package/esm2022/pipes/index.mjs +0 -2
  146. package/esm2022/public-api.mjs +0 -12
  147. package/esm2022/renderer/components/action-icon.component.mjs +0 -117
  148. package/esm2022/renderer/components/add-field-column.component.mjs +0 -88
  149. package/esm2022/renderer/components/cells/attachment.component.mjs +0 -107
  150. package/esm2022/renderer/components/cells/cells.mjs +0 -6
  151. package/esm2022/renderer/components/cells/index.mjs +0 -7
  152. package/esm2022/renderer/components/cells/link.component.mjs +0 -89
  153. package/esm2022/renderer/components/cells/progress.component.mjs +0 -268
  154. package/esm2022/renderer/components/cells/rate.component.mjs +0 -153
  155. package/esm2022/renderer/components/cells/rich-text.component.mjs +0 -95
  156. package/esm2022/renderer/components/cells.component.mjs +0 -35
  157. package/esm2022/renderer/components/field-head.component.mjs +0 -146
  158. package/esm2022/renderer/components/field-icon.component.mjs +0 -72
  159. package/esm2022/renderer/components/frozen-cells.component.mjs +0 -36
  160. package/esm2022/renderer/components/frozen-heads.component.mjs +0 -214
  161. package/esm2022/renderer/components/frozen-placeholder-cells.component.mjs +0 -38
  162. package/esm2022/renderer/components/heads.component.mjs +0 -38
  163. package/esm2022/renderer/components/hover-cell.component.mjs +0 -104
  164. package/esm2022/renderer/components/hover-row-heads.component.mjs +0 -132
  165. package/esm2022/renderer/components/icon.component.mjs +0 -84
  166. package/esm2022/renderer/components/index.mjs +0 -15
  167. package/esm2022/renderer/components/other-rows.component.mjs +0 -68
  168. package/esm2022/renderer/components/placeholder-cells.component.mjs +0 -33
  169. package/esm2022/renderer/components/text.component.mjs +0 -67
  170. package/esm2022/renderer/creations/create-active-cell-border.mjs +0 -70
  171. package/esm2022/renderer/creations/create-cells.mjs +0 -190
  172. package/esm2022/renderer/creations/create-heads.mjs +0 -51
  173. package/esm2022/renderer/drawers/add-row-layout-drawer.mjs +0 -98
  174. package/esm2022/renderer/drawers/cell-drawer.mjs +0 -673
  175. package/esm2022/renderer/drawers/drawer.mjs +0 -947
  176. package/esm2022/renderer/drawers/layout-drawer.mjs +0 -64
  177. package/esm2022/renderer/drawers/record-row-layout-drawer.mjs +0 -131
  178. package/esm2022/renderer/index.mjs +0 -4
  179. package/esm2022/renderer/interfaces/hover-cell.mjs +0 -4
  180. package/esm2022/renderer/interfaces/index.mjs +0 -2
  181. package/esm2022/renderer/renderer.component.mjs +0 -197
  182. package/esm2022/services/event.service.mjs +0 -241
  183. package/esm2022/services/field.service.mjs +0 -56
  184. package/esm2022/services/index.mjs +0 -4
  185. package/esm2022/services/selection.service.mjs +0 -151
  186. package/esm2022/types/avatar.mjs +0 -27
  187. package/esm2022/types/canvas.mjs +0 -2
  188. package/esm2022/types/cell.mjs +0 -2
  189. package/esm2022/types/clipboard.mjs +0 -2
  190. package/esm2022/types/component-config.mjs +0 -7
  191. package/esm2022/types/field.mjs +0 -2
  192. package/esm2022/types/grid.mjs +0 -17
  193. package/esm2022/types/index.mjs +0 -10
  194. package/esm2022/types/layout.mjs +0 -2
  195. package/esm2022/types/row.mjs +0 -6
  196. package/esm2022/utils/build.mjs +0 -39
  197. package/esm2022/utils/cell.mjs +0 -80
  198. package/esm2022/utils/clear-cells.mjs +0 -23
  199. package/esm2022/utils/clipboard/clipboard.mjs +0 -88
  200. package/esm2022/utils/clipboard/copy.mjs +0 -99
  201. package/esm2022/utils/clipboard/extract.mjs +0 -38
  202. package/esm2022/utils/clipboard/index.mjs +0 -5
  203. package/esm2022/utils/clipboard/paste.mjs +0 -188
  204. package/esm2022/utils/common.mjs +0 -50
  205. package/esm2022/utils/field/field-operable.mjs +0 -2
  206. package/esm2022/utils/field/field.mjs +0 -20
  207. package/esm2022/utils/field/index.mjs +0 -4
  208. package/esm2022/utils/field/model/attachment.mjs +0 -56
  209. package/esm2022/utils/field/model/date.mjs +0 -141
  210. package/esm2022/utils/field/model/index.mjs +0 -12
  211. package/esm2022/utils/field/model/link.mjs +0 -56
  212. package/esm2022/utils/field/model/member.mjs +0 -81
  213. package/esm2022/utils/field/model/number.mjs +0 -59
  214. package/esm2022/utils/field/model/progress.mjs +0 -69
  215. package/esm2022/utils/field/model/rate.mjs +0 -58
  216. package/esm2022/utils/field/model/rich-text.mjs +0 -39
  217. package/esm2022/utils/field/model/select.mjs +0 -131
  218. package/esm2022/utils/field/model/text.mjs +0 -32
  219. package/esm2022/utils/field/operate.mjs +0 -73
  220. package/esm2022/utils/file.mjs +0 -116
  221. package/esm2022/utils/get-placeholder-cells.mjs +0 -66
  222. package/esm2022/utils/get-text-width.mjs +0 -30
  223. package/esm2022/utils/hover-cell.mjs +0 -25
  224. package/esm2022/utils/i18n.mjs +0 -87
  225. package/esm2022/utils/image-cache.mjs +0 -57
  226. package/esm2022/utils/index.mjs +0 -19
  227. package/esm2022/utils/match-keywords.mjs +0 -15
  228. package/esm2022/utils/os.mjs +0 -16
  229. package/esm2022/utils/position.mjs +0 -48
  230. package/esm2022/utils/style.mjs +0 -37
  231. package/esm2022/utils/text-measure.mjs +0 -122
  232. package/esm2022/utils/visible-range.mjs +0 -42
@@ -1,89 +0,0 @@
1
- import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';
2
- import { AI_TABLE_CELL_PADDING, AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE, AI_TABLE_FIELD_HEAD_MORE, Colors } from '../../../constants';
3
- import { AITable, getMousePosition, handleMouseStyle } from '../../../utils';
4
- import { AITableText } from '../text.component';
5
- import { AITableFieldType } from '@ai-table/utils';
6
- import { drawer } from '../../drawers/drawer';
7
- import * as i0 from "@angular/core";
8
- export class AITableCellLink {
9
- constructor() {
10
- this.config = input();
11
- this.textOffset = AI_TABLE_CELL_PADDING + AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE;
12
- this.render = computed(() => this.config()?.render);
13
- this.transformValue = computed(() => this.render()?.transformValue);
14
- this.showLink = computed(() => !!this.transformValue()?.text);
15
- this.textConfig = computed(() => {
16
- const render = this.config()?.render;
17
- if (render) {
18
- const { x, y, transformValue, columnWidth, rowHeight, style, zIndex } = render;
19
- let textRender = transformValue.text;
20
- if (textRender == null) {
21
- return;
22
- }
23
- textRender = textRender.replace(/\r|\n/g, ' ');
24
- const fontWeight = style?.fontWeight;
25
- const textMaxWidth = columnWidth - 2 * AI_TABLE_CELL_PADDING;
26
- const { text, textWidth } = drawer.textEllipsis({
27
- text: textRender,
28
- maxWidth: textMaxWidth,
29
- fontWeight
30
- });
31
- return {
32
- x,
33
- y,
34
- text,
35
- wrap: 'none',
36
- width: textWidth,
37
- fillStyle: Colors.primary,
38
- fill: Colors.primary,
39
- height: rowHeight + 2,
40
- lineHeight: 1.84,
41
- listening: true,
42
- ellipsis: true,
43
- textDecoration: 'underline',
44
- zIndex
45
- };
46
- }
47
- return;
48
- });
49
- }
50
- static { this.fieldType = AITableFieldType.link; }
51
- linkClick(e) {
52
- e.event.cancelBubble = true;
53
- window.open(this.transformValue().url, '_blank', 'noopener,noreferrer');
54
- }
55
- linkMouseMove(e) {
56
- e.event.cancelBubble = true;
57
- const { aiTable, coordinate } = this.config();
58
- const targetName = e.event.target.name();
59
- const gridStage = e.event.currentTarget.getStage();
60
- const pos = gridStage?.getPointerPosition();
61
- if (pos == null)
62
- return;
63
- const { context } = aiTable;
64
- const { x, y } = pos;
65
- const curMousePosition = getMousePosition(aiTable, x, y, coordinate, AITable.getVisibleFields(aiTable), context, targetName);
66
- handleMouseStyle(AI_TABLE_FIELD_HEAD_MORE, curMousePosition.areaType, coordinate.container);
67
- }
68
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableCellLink, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
69
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: AITableCellLink, isStandalone: true, selector: "ai-table-link", inputs: { config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: `
70
- @if (showLink()) {
71
- <ai-table-text [config]="textConfig()!" (koClick)="linkClick($event)" (koMouseMove)="linkMouseMove($event)"></ai-table-text>
72
- }
73
- `, isInline: true, dependencies: [{ kind: "component", type: AITableText, selector: "ai-table-text", inputs: ["config"], outputs: ["koClick", "koMouseMove"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
74
- }
75
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableCellLink, decorators: [{
76
- type: Component,
77
- args: [{
78
- selector: 'ai-table-link',
79
- template: `
80
- @if (showLink()) {
81
- <ai-table-text [config]="textConfig()!" (koClick)="linkClick($event)" (koMouseMove)="linkMouseMove($event)"></ai-table-text>
82
- }
83
- `,
84
- standalone: true,
85
- imports: [AITableText],
86
- changeDetection: ChangeDetectionStrategy.OnPush
87
- }]
88
- }] });
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 { AITable, getMousePosition, handleMouseStyle } from '../../../utils';\nimport { AITableText } from '../text.component';\nimport { AITableHoverCellConfig, AITableRender } from '../../../types';\nimport { KoEventObject } from '../../../angular-konva';\nimport { AITableFieldType } from '@ai-table/utils';\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"]}
@@ -1,268 +0,0 @@
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 '@ai-table/utils';
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 '@ai-table/utils';\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"]}
@@ -1,153 +0,0 @@
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 '@ai-table/utils';
5
- import { generateTargetName } from '../../../utils';
6
- import { isActiveCell } from '../../../renderer';
7
- import { StarFill, Colors, AI_TABLE_CELL_EMOJI_PADDING, AI_TABLE_CELL_PADDING, AI_TABLE_ROW_BLANK_HEIGHT, AI_TABLE_CELL_EMOJI_SIZE, AI_TABLE_OFFSET, AI_TABLE_CELL, AI_TABLE_RATE_MAX, AI_TABLE_CELL_BORDER } from '../../../constants';
8
- import * as i0 from "@angular/core";
9
- export class AITableCellRate {
10
- constructor() {
11
- this.pointerX = signal(0);
12
- this.pointerY = signal(0);
13
- this.resetStatus = signal(false);
14
- this.config = input();
15
- this.readonly = computed(() => {
16
- return this.config()?.readonly;
17
- });
18
- this.whiteBgConfig = computed(() => {
19
- const { aiTable, render, field, recordId, coordinate } = this.config();
20
- const pointPosition = aiTable.context.pointPosition();
21
- const { x, y } = render;
22
- const { columnIndex } = pointPosition;
23
- const isActive = isActiveCell([recordId, field._id], aiTable);
24
- return {
25
- x: x - AI_TABLE_CELL_PADDING + AI_TABLE_CELL_BORDER,
26
- y: y + AI_TABLE_CELL_BORDER + AI_TABLE_OFFSET,
27
- width: coordinate.getColumnWidth(columnIndex) - (AI_TABLE_CELL_BORDER + AI_TABLE_OFFSET) * 2,
28
- height: AI_TABLE_ROW_BLANK_HEIGHT - (AI_TABLE_CELL_BORDER + AI_TABLE_OFFSET),
29
- fill: Colors.white,
30
- stroke: isActive ? null : Colors.white,
31
- zIndex: 0,
32
- name: generateTargetName({
33
- targetName: AI_TABLE_CELL,
34
- fieldId: field._id,
35
- recordId
36
- })
37
- };
38
- });
39
- this.starConfigs = computed(() => {
40
- const { render, field, recordId, readonly, aiTable, coordinate } = this.config();
41
- const { x, transformValue } = render;
42
- const max = AI_TABLE_RATE_MAX;
43
- const starY = (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_CELL_EMOJI_SIZE) / 2 + AI_TABLE_OFFSET;
44
- const pointPosition = aiTable.context.pointPosition();
45
- const { rowIndex, columnIndex } = pointPosition;
46
- const { scrollLeft, scrollTop } = aiTable.context.scrollState();
47
- const columnLeftX = coordinate.getColumnOffset(columnIndex) - scrollLeft + AI_TABLE_OFFSET;
48
- const columnTopY = coordinate.getRowOffset(rowIndex) - scrollTop + AI_TABLE_OFFSET;
49
- const firstStarLeftX = columnLeftX + AI_TABLE_CELL_PADDING;
50
- const lastStarRightX = columnLeftX + AI_TABLE_CELL_PADDING + max * AI_TABLE_CELL_EMOJI_SIZE + (max - 1) * AI_TABLE_CELL_EMOJI_PADDING;
51
- const startTopY = columnTopY + starY;
52
- const startBottomY = columnTopY + starY + AI_TABLE_CELL_EMOJI_SIZE;
53
- const isHoverStar = this.pointerX() >= firstStarLeftX &&
54
- this.pointerX() <= lastStarRightX &&
55
- this.pointerY() >= startTopY &&
56
- this.pointerY() <= startBottomY;
57
- const renderWidth = coordinate.getColumnWidth(columnIndex) - AI_TABLE_CELL_PADDING;
58
- const starWidth = AI_TABLE_CELL_EMOJI_SIZE + AI_TABLE_CELL_EMOJI_PADDING;
59
- const maxStar = Math.min(max, Math.floor(renderWidth / starWidth));
60
- return [...Array(maxStar).keys()].map((item, index) => {
61
- const value = index + 1;
62
- const checked = value <= transformValue;
63
- const starX = x + index * (AI_TABLE_CELL_EMOJI_SIZE + AI_TABLE_CELL_EMOJI_PADDING);
64
- let fill = null;
65
- if (this.resetStatus()) {
66
- fill = Colors.gray100;
67
- }
68
- else {
69
- if (isHoverStar) {
70
- fill = columnLeftX + starX <= this.pointerX() ? Colors.waring : Colors.gray100;
71
- }
72
- else {
73
- fill = checked ? Colors.waring : Colors.gray100;
74
- }
75
- }
76
- return {
77
- x: starX,
78
- y: starY,
79
- size: 22,
80
- data: StarFill,
81
- fill,
82
- scaleX: 1.14,
83
- scaleY: 1.14,
84
- name: generateTargetName({
85
- targetName: AI_TABLE_CELL,
86
- fieldId: field._id,
87
- recordId,
88
- mouseStyle: readonly ? 'default' : 'pointer'
89
- })
90
- };
91
- });
92
- });
93
- }
94
- static { this.fieldType = AITableFieldType.rate; }
95
- koMousemove(e) {
96
- if (this.readonly()) {
97
- return;
98
- }
99
- this.resetStatus.set(false);
100
- const pos = e.event.target.getStage()?.getPointerPosition();
101
- if (!pos)
102
- return;
103
- const { x, y } = pos;
104
- this.pointerX.set(x);
105
- this.pointerY.set(y);
106
- }
107
- koClick(e, index) {
108
- if (this.readonly()) {
109
- return;
110
- }
111
- this.resetStatus.set(false);
112
- const { render, readonly, field, recordId, actions } = this.config();
113
- const { transformValue } = render;
114
- let value = index + 1;
115
- if (transformValue === value) {
116
- value = 0;
117
- this.resetStatus.set(true);
118
- }
119
- if (!readonly && actions && actions.updateFieldValue) {
120
- actions.updateFieldValue({
121
- value,
122
- path: [recordId, field._id]
123
- });
124
- }
125
- }
126
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableCellRate, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
127
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: AITableCellRate, isStandalone: true, selector: "ai-table-rate", inputs: { config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: `
128
- @if (!readonly()) {
129
- <ko-rect [config]="whiteBgConfig()" (koMousemove)="koMousemove($event)"></ko-rect>
130
- }
131
- @for (config of starConfigs(); let index = $index; track $index) {
132
- <ko-path [config]="config" (koClick)="koClick($event, index)"></ko-path>
133
- }
134
- `, 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 }); }
135
- }
136
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableCellRate, decorators: [{
137
- type: Component,
138
- args: [{
139
- selector: 'ai-table-rate',
140
- template: `
141
- @if (!readonly()) {
142
- <ko-rect [config]="whiteBgConfig()" (koMousemove)="koMousemove($event)"></ko-rect>
143
- }
144
- @for (config of starConfigs(); let index = $index; track $index) {
145
- <ko-path [config]="config" (koClick)="koClick($event, index)"></ko-path>
146
- }
147
- `,
148
- standalone: true,
149
- imports: [KoShape],
150
- changeDetection: ChangeDetectionStrategy.OnPush
151
- }]
152
- }] });
153
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rate.component.js","sourceRoot":"","sources":["../../../../../../packages/grid/src/renderer/components/cells/rate.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACnE,OAAO,EAAE,uBAAuB,EAAE,MAAM,eAAe,CAAC;AACxD,OAAO,EAAE,OAAO,EAAiB,MAAM,wBAAwB,CAAC;AAGhE,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AACpD,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EACH,QAAQ,EACR,MAAM,EACN,2BAA2B,EAC3B,qBAAqB,EACrB,yBAAyB,EACzB,wBAAwB,EACxB,eAAe,EACf,aAAa,EACb,iBAAiB,EACjB,oBAAoB,EACvB,MAAM,oBAAoB,CAAC;;AAgB5B,MAAM,OAAO,eAAe;IAd5B;QAiBY,aAAQ,GAAG,MAAM,CAAS,CAAC,CAAC,CAAC;QAE7B,aAAQ,GAAG,MAAM,CAAS,CAAC,CAAC,CAAC;QAE7B,gBAAW,GAAG,MAAM,CAAU,KAAK,CAAC,CAAC;QAE7C,WAAM,GAAG,KAAK,EAA0B,CAAC;QAEzC,aAAQ,GAAG,QAAQ,CAAC,GAAG,EAAE;YACrB,OAAO,IAAI,CAAC,MAAM,EAAE,EAAE,QAAQ,CAAC;QACnC,CAAC,CAAC,CAAC;QAEH,kBAAa,GAAG,QAAQ,CAAC,GAAG,EAAE;YAC1B,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,UAAU,EAAE,GAAG,IAAI,CAAC,MAAM,EAAG,CAAC;YACxE,MAAM,aAAa,GAAG,OAAO,CAAC,OAAQ,CAAC,aAAa,EAAE,CAAC;YACvD,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,MAAM,CAAC;YACxB,MAAM,EAAE,WAAW,EAAE,GAAG,aAAa,CAAC;YACtC,MAAM,QAAQ,GAAG,YAAY,CAAC,CAAC,QAAS,EAAE,KAAK,CAAC,GAAG,CAAC,EAAE,OAAO,CAAC,CAAC;YAE/D,OAAO;gBACH,CAAC,EAAE,CAAC,GAAG,qBAAqB,GAAG,oBAAoB;gBACnD,CAAC,EAAE,CAAC,GAAG,oBAAoB,GAAG,eAAe;gBAC7C,KAAK,EAAE,UAAU,CAAC,cAAc,CAAC,WAAW,CAAC,GAAG,CAAC,oBAAoB,GAAG,eAAe,CAAC,GAAG,CAAC;gBAC5F,MAAM,EAAE,yBAAyB,GAAG,CAAC,oBAAoB,GAAG,eAAe,CAAC;gBAC5E,IAAI,EAAE,MAAM,CAAC,KAAK;gBAClB,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK;gBACtC,MAAM,EAAE,CAAC;gBACT,IAAI,EAAE,kBAAkB,CAAC;oBACrB,UAAU,EAAE,aAAa;oBACzB,OAAO,EAAE,KAAK,CAAC,GAAG;oBAClB,QAAQ;iBACX,CAAC;aACL,CAAC;QACN,CAAC,CAAC,CAAC;QAEH,gBAAW,GAAG,QAAQ,CAAC,GAAG,EAAE;YACxB,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,OAAO,EAAE,UAAU,EAAE,GAAG,IAAI,CAAC,MAAM,EAAG,CAAC;YAClF,MAAM,EAAE,CAAC,EAAE,cAAc,EAAE,GAAG,MAAM,CAAC;YACrC,MAAM,GAAG,GAAG,iBAAiB,CAAC;YAC9B,MAAM,KAAK,GAAG,CAAC,yBAAyB,GAAG,wBAAwB,CAAC,GAAG,CAAC,GAAG,eAAe,CAAC;YAE3F,MAAM,aAAa,GAAG,OAAO,CAAC,OAAQ,CAAC,aAAa,EAAE,CAAC;YACvD,MAAM,EAAE,QAAQ,EAAE,WAAW,EAAE,GAAG,aAAa,CAAC;YAChD,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,GAAG,OAAO,CAAC,OAAQ,CAAC,WAAW,EAAE,CAAC;YACjE,MAAM,WAAW,GAAG,UAAU,CAAC,eAAe,CAAC,WAAW,CAAC,GAAG,UAAU,GAAG,eAAe,CAAC;YAC3F,MAAM,UAAU,GAAG,UAAU,CAAC,YAAY,CAAC,QAAQ,CAAC,GAAG,SAAS,GAAG,eAAe,CAAC;YACnF,MAAM,cAAc,GAAG,WAAW,GAAG,qBAAqB,CAAC;YAC3D,MAAM,cAAc,GAChB,WAAW,GAAG,qBAAqB,GAAG,GAAG,GAAG,wBAAwB,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,2BAA2B,CAAC;YACnH,MAAM,SAAS,GAAG,UAAU,GAAG,KAAK,CAAC;YACrC,MAAM,YAAY,GAAG,UAAU,GAAG,KAAK,GAAG,wBAAwB,CAAC;YAEnE,MAAM,WAAW,GACb,IAAI,CAAC,QAAQ,EAAE,IAAI,cAAc;gBACjC,IAAI,CAAC,QAAQ,EAAE,IAAI,cAAc;gBACjC,IAAI,CAAC,QAAQ,EAAE,IAAI,SAAS;gBAC5B,IAAI,CAAC,QAAQ,EAAE,IAAI,YAAY,CAAC;YAEpC,MAAM,WAAW,GAAG,UAAU,CAAC,cAAc,CAAC,WAAW,CAAC,GAAG,qBAAqB,CAAC;YACnF,MAAM,SAAS,GAAG,wBAAwB,GAAG,2BAA2B,CAAC;YACzE,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,KAAK,CAAC,WAAW,GAAG,SAAS,CAAC,CAAC,CAAC;YAEnE,OAAO,CAAC,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;gBAClD,MAAM,KAAK,GAAG,KAAK,GAAG,CAAC,CAAC;gBACxB,MAAM,OAAO,GAAG,KAAK,IAAI,cAAc,CAAC;gBACxC,MAAM,KAAK,GAAG,CAAC,GAAG,KAAK,GAAG,CAAC,wBAAwB,GAAG,2BAA2B,CAAC,CAAC;gBAEnF,IAAI,IAAI,GAAG,IAAI,CAAC;gBAChB,IAAI,IAAI,CAAC,WAAW,EAAE,EAAE,CAAC;oBACrB,IAAI,GAAG,MAAM,CAAC,OAAO,CAAC;gBAC1B,CAAC;qBAAM,CAAC;oBACJ,IAAI,WAAW,EAAE,CAAC;wBACd,IAAI,GAAG,WAAW,GAAG,KAAK,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC;oBACnF,CAAC;yBAAM,CAAC;wBACJ,IAAI,GAAG,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC;oBACpD,CAAC;gBACL,CAAC;gBAED,OAAO;oBACH,CAAC,EAAE,KAAK;oBACR,CAAC,EAAE,KAAK;oBACR,IAAI,EAAE,EAAE;oBACR,IAAI,EAAE,QAAQ;oBACd,IAAI;oBACJ,MAAM,EAAE,IAAI;oBACZ,MAAM,EAAE,IAAI;oBACZ,IAAI,EAAE,kBAAkB,CAAC;wBACrB,UAAU,EAAE,aAAa;wBACzB,OAAO,EAAE,KAAK,CAAC,GAAG;wBAClB,QAAQ;wBACR,UAAU,EAAE,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS;qBAC/C,CAAC;iBACL,CAAC;YACN,CAAC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;KAqCN;aArIU,cAAS,GAAG,gBAAgB,CAAC,IAAI,AAAxB,CAAyB;IAkGzC,WAAW,CAAC,CAA4B;QACpC,IAAI,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC;YAClB,OAAO;QACX,CAAC;QAED,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAC5B,MAAM,GAAG,GAAG,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,QAAQ,EAAE,EAAE,kBAAkB,EAAE,CAAC;QAC5D,IAAI,CAAC,GAAG;YAAE,OAAO;QACjB,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,GAAG,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IACzB,CAAC;IAED,OAAO,CAAC,CAA4B,EAAE,KAAa;QAC/C,IAAI,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC;YAClB,OAAO;QACX,CAAC;QAED,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAC5B,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC,MAAM,EAAG,CAAC;QACtE,MAAM,EAAE,cAAc,EAAE,GAAG,MAAM,CAAC;QAElC,IAAI,KAAK,GAAG,KAAK,GAAG,CAAC,CAAC;QACtB,IAAI,cAAc,KAAK,KAAK,EAAE,CAAC;YAC3B,KAAK,GAAG,CAAC,CAAC;YACV,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAC/B,CAAC;QAED,IAAI,CAAC,QAAQ,IAAI,OAAO,IAAI,OAAO,CAAC,gBAAgB,EAAE,CAAC;YACnD,OAAO,CAAC,gBAAgB,CAAC;gBACrB,KAAK;gBACL,IAAI,EAAE,CAAC,QAAS,EAAE,KAAK,CAAC,GAAG,CAAC;aAC/B,CAAC,CAAC;QACP,CAAC;IACL,CAAC;+GArIQ,eAAe;mGAAf,eAAe,gNAZd;;;;;;;KAOT,4DAES,OAAO;;4FAGR,eAAe;kBAd3B,SAAS;mBAAC;oBACP,QAAQ,EAAE,eAAe;oBACzB,QAAQ,EAAE;;;;;;;KAOT;oBACD,UAAU,EAAE,IAAI;oBAChB,OAAO,EAAE,CAAC,OAAO,CAAC;oBAClB,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAClD","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 '@ai-table/utils';\nimport { generateTargetName } from '../../../utils';\nimport { isActiveCell } from '../../../renderer';\nimport {\n    StarFill,\n    Colors,\n    AI_TABLE_CELL_EMOJI_PADDING,\n    AI_TABLE_CELL_PADDING,\n    AI_TABLE_ROW_BLANK_HEIGHT,\n    AI_TABLE_CELL_EMOJI_SIZE,\n    AI_TABLE_OFFSET,\n    AI_TABLE_CELL,\n    AI_TABLE_RATE_MAX,\n    AI_TABLE_CELL_BORDER\n} from '../../../constants';\n\n@Component({\n    selector: 'ai-table-rate',\n    template: `\n        @if (!readonly()) {\n            <ko-rect [config]=\"whiteBgConfig()\" (koMousemove)=\"koMousemove($event)\"></ko-rect>\n        }\n        @for (config of starConfigs(); let index = $index; track $index) {\n            <ko-path [config]=\"config\" (koClick)=\"koClick($event, index)\"></ko-path>\n        }\n    `,\n    standalone: true,\n    imports: [KoShape],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableCellRate implements HoverCellComponent {\n    static fieldType = AITableFieldType.rate;\n\n    private pointerX = signal<number>(0);\n\n    private pointerY = signal<number>(0);\n\n    private resetStatus = signal<boolean>(false);\n\n    config = input<AITableHoverCellConfig>();\n\n    readonly = computed(() => {\n        return this.config()?.readonly;\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,\n            y: y + AI_TABLE_CELL_BORDER + AI_TABLE_OFFSET,\n            width: coordinate.getColumnWidth(columnIndex) - (AI_TABLE_CELL_BORDER + AI_TABLE_OFFSET) * 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            zIndex: 0,\n            name: generateTargetName({\n                targetName: AI_TABLE_CELL,\n                fieldId: field._id,\n                recordId\n            })\n        };\n    });\n\n    starConfigs = computed(() => {\n        const { render, field, recordId, readonly, aiTable, coordinate } = this.config()!;\n        const { x, transformValue } = render;\n        const max = AI_TABLE_RATE_MAX;\n        const starY = (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_CELL_EMOJI_SIZE) / 2 + AI_TABLE_OFFSET;\n\n        const pointPosition = aiTable.context!.pointPosition();\n        const { rowIndex, columnIndex } = pointPosition;\n        const { scrollLeft, scrollTop } = aiTable.context!.scrollState();\n        const columnLeftX = coordinate.getColumnOffset(columnIndex) - scrollLeft + AI_TABLE_OFFSET;\n        const columnTopY = coordinate.getRowOffset(rowIndex) - scrollTop + AI_TABLE_OFFSET;\n        const firstStarLeftX = columnLeftX + AI_TABLE_CELL_PADDING;\n        const lastStarRightX =\n            columnLeftX + AI_TABLE_CELL_PADDING + max * AI_TABLE_CELL_EMOJI_SIZE + (max - 1) * AI_TABLE_CELL_EMOJI_PADDING;\n        const startTopY = columnTopY + starY;\n        const startBottomY = columnTopY + starY + AI_TABLE_CELL_EMOJI_SIZE;\n\n        const isHoverStar =\n            this.pointerX() >= firstStarLeftX &&\n            this.pointerX() <= lastStarRightX &&\n            this.pointerY() >= startTopY &&\n            this.pointerY() <= startBottomY;\n\n        const renderWidth = coordinate.getColumnWidth(columnIndex) - AI_TABLE_CELL_PADDING;\n        const starWidth = AI_TABLE_CELL_EMOJI_SIZE + AI_TABLE_CELL_EMOJI_PADDING;\n        const maxStar = Math.min(max, Math.floor(renderWidth / starWidth));\n\n        return [...Array(maxStar).keys()].map((item, index) => {\n            const value = index + 1;\n            const checked = value <= transformValue;\n            const starX = x + index * (AI_TABLE_CELL_EMOJI_SIZE + AI_TABLE_CELL_EMOJI_PADDING);\n\n            let fill = null;\n            if (this.resetStatus()) {\n                fill = Colors.gray100;\n            } else {\n                if (isHoverStar) {\n                    fill = columnLeftX + starX <= this.pointerX() ? Colors.waring : Colors.gray100;\n                } else {\n                    fill = checked ? Colors.waring : Colors.gray100;\n                }\n            }\n\n            return {\n                x: starX,\n                y: starY,\n                size: 22,\n                data: StarFill,\n                fill,\n                scaleX: 1.14,\n                scaleY: 1.14,\n                name: generateTargetName({\n                    targetName: AI_TABLE_CELL,\n                    fieldId: field._id,\n                    recordId,\n                    mouseStyle: readonly ? 'default' : 'pointer'\n                })\n            };\n        });\n    });\n\n    koMousemove(e: KoEventObject<MouseEvent>) {\n        if (this.readonly()) {\n            return;\n        }\n\n        this.resetStatus.set(false);\n        const pos = e.event.target.getStage()?.getPointerPosition();\n        if (!pos) return;\n        const { x, y } = pos;\n        this.pointerX.set(x);\n        this.pointerY.set(y);\n    }\n\n    koClick(e: KoEventObject<MouseEvent>, index: number) {\n        if (this.readonly()) {\n            return;\n        }\n\n        this.resetStatus.set(false);\n        const { render, readonly, field, recordId, actions } = this.config()!;\n        const { transformValue } = render;\n\n        let value = index + 1;\n        if (transformValue === value) {\n            value = 0;\n            this.resetStatus.set(true);\n        }\n\n        if (!readonly && actions && actions.updateFieldValue) {\n            actions.updateFieldValue({\n                value,\n                path: [recordId!, field._id]\n            });\n        }\n    }\n}\n"]}