@ai-table/grid 0.0.67 → 0.0.69

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (48) hide show
  1. package/core/context.d.ts +1 -0
  2. package/core/context.d.ts.map +1 -1
  3. package/esm2022/components/drag/drag.component.mjs +3 -3
  4. package/esm2022/core/context.mjs +3 -2
  5. package/esm2022/grid.component.mjs +3 -2
  6. package/esm2022/renderer/components/frozen-heads.component.mjs +123 -38
  7. package/esm2022/renderer/components/hover-cell.component.mjs +4 -3
  8. package/esm2022/renderer/components/hover-row-heads.component.mjs +3 -3
  9. package/esm2022/renderer/creations/create-cells.mjs +10 -5
  10. package/esm2022/renderer/drawers/add-row-layout-drawer.mjs +7 -7
  11. package/esm2022/renderer/drawers/layout-drawer.mjs +7 -3
  12. package/esm2022/renderer/drawers/record-row-layout-drawer.mjs +46 -30
  13. package/esm2022/renderer/renderer.component.mjs +7 -5
  14. package/esm2022/types/grid.mjs +1 -1
  15. package/esm2022/types/layout.mjs +1 -1
  16. package/esm2022/utils/cell.mjs +4 -1
  17. package/esm2022/utils/clipboard/copy.mjs +4 -4
  18. package/esm2022/utils/field/model/date.mjs +5 -1
  19. package/esm2022/utils/field/model/rich-text.mjs +6 -3
  20. package/esm2022/utils/match-keywords.mjs +2 -3
  21. package/esm2022/utils/position.mjs +6 -6
  22. package/esm2022/utils/visible-range.mjs +3 -3
  23. package/fesm2022/ai-table-grid.mjs +217 -91
  24. package/fesm2022/ai-table-grid.mjs.map +1 -1
  25. package/grid.component.d.ts.map +1 -1
  26. package/package.json +1 -1
  27. package/renderer/components/frozen-heads.component.d.ts +39 -3
  28. package/renderer/components/frozen-heads.component.d.ts.map +1 -1
  29. package/renderer/components/hover-cell.component.d.ts.map +1 -1
  30. package/renderer/components/hover-row-heads.component.d.ts.map +1 -1
  31. package/renderer/creations/create-cells.d.ts.map +1 -1
  32. package/renderer/drawers/add-row-layout-drawer.d.ts.map +1 -1
  33. package/renderer/drawers/layout-drawer.d.ts +3 -1
  34. package/renderer/drawers/layout-drawer.d.ts.map +1 -1
  35. package/renderer/drawers/record-row-layout-drawer.d.ts.map +1 -1
  36. package/renderer/renderer.component.d.ts +1 -0
  37. package/renderer/renderer.component.d.ts.map +1 -1
  38. package/types/grid.d.ts +2 -0
  39. package/types/grid.d.ts.map +1 -1
  40. package/types/layout.d.ts +2 -0
  41. package/types/layout.d.ts.map +1 -1
  42. package/utils/cell.d.ts.map +1 -1
  43. package/utils/field/model/date.d.ts +2 -1
  44. package/utils/field/model/date.d.ts.map +1 -1
  45. package/utils/field/model/rich-text.d.ts +2 -1
  46. package/utils/field/model/rich-text.d.ts.map +1 -1
  47. package/utils/position.d.ts +1 -1
  48. package/utils/position.d.ts.map +1 -1
@@ -1,4 +1,4 @@
1
- import { AddOutlinedPath, AI_TABLE_CELL_PADDING, AI_TABLE_FIELD_ADD_BUTTON_WIDTH, AI_TABLE_ICON_COMMON_SIZE, AI_TABLE_OFFSET, AI_TABLE_ROW_DRAG_ICON_WIDTH, AI_TABLE_ROW_HEAD_SIZE, AI_TABLE_ROW_HEAD_WIDTH } from '../../constants';
1
+ import { AddOutlinedPath, AI_TABLE_CELL_PADDING, AI_TABLE_FIELD_ADD_BUTTON_WIDTH, AI_TABLE_ICON_COMMON_SIZE, AI_TABLE_OFFSET, AI_TABLE_ROW_DRAG_ICON_WIDTH, AI_TABLE_ROW_HEAD_SIZE } from '../../constants';
2
2
  import { Layout } from './layout-drawer';
3
3
  export class AddRowLayout extends Layout {
4
4
  renderAddFieldBlank({ isHoverRow, isCheckedRow }) {
@@ -41,20 +41,20 @@ export class AddRowLayout extends Layout {
41
41
  const frozenOffset = AI_TABLE_OFFSET;
42
42
  const fill = isHoverRow ? this.colors.gray80 : this.colors.transparent;
43
43
  this.rect({
44
- x: frozenOffset + AI_TABLE_ROW_DRAG_ICON_WIDTH,
44
+ x: this.hiddenIndexColumn ? frozenOffset : frozenOffset + AI_TABLE_ROW_DRAG_ICON_WIDTH,
45
45
  y: y + AI_TABLE_OFFSET,
46
- width: columnWidth + AI_TABLE_ROW_HEAD_WIDTH - frozenOffset + 1,
46
+ width: columnWidth + this.rowHeadWidth - frozenOffset + 1,
47
47
  height: rowHeight,
48
48
  fill
49
49
  });
50
50
  this.line({
51
- x: frozenOffset + AI_TABLE_ROW_DRAG_ICON_WIDTH,
51
+ x: this.hiddenIndexColumn ? frozenOffset : frozenOffset + AI_TABLE_ROW_DRAG_ICON_WIDTH,
52
52
  y,
53
- points: [0, rowHeight, columnWidth + AI_TABLE_ROW_HEAD_WIDTH - frozenOffset + 1, rowHeight],
53
+ points: [0, rowHeight, columnWidth + this.rowHeadWidth - frozenOffset + 1, rowHeight],
54
54
  stroke: this.colors.gray200
55
55
  });
56
56
  this.path({
57
- x: AI_TABLE_CELL_PADDING + AI_TABLE_ROW_DRAG_ICON_WIDTH,
57
+ x: this.hiddenIndexColumn ? AI_TABLE_CELL_PADDING : AI_TABLE_CELL_PADDING + AI_TABLE_ROW_DRAG_ICON_WIDTH,
58
58
  y: y + (rowHeight - AI_TABLE_ICON_COMMON_SIZE) / 2 - AI_TABLE_OFFSET,
59
59
  data: AddOutlinedPath,
60
60
  size: AI_TABLE_ROW_HEAD_SIZE,
@@ -95,4 +95,4 @@ export class AddRowLayout extends Layout {
95
95
  }
96
96
  }
97
97
  export const addRowLayout = new AddRowLayout();
98
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-row-layout-drawer.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/drawers/add-row-layout-drawer.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AddOutlinedPath,\n    AI_TABLE_CELL_PADDING,\n    AI_TABLE_FIELD_ADD_BUTTON_WIDTH,\n    AI_TABLE_ICON_COMMON_SIZE,\n    AI_TABLE_OFFSET,\n    AI_TABLE_ROW_DRAG_ICON_WIDTH,\n    AI_TABLE_ROW_HEAD_SIZE,\n    AI_TABLE_ROW_HEAD_WIDTH\n} from '../../constants';\nimport { AITableCell } from '../../types';\nimport { Layout } from './layout-drawer';\n\nexport class AddRowLayout extends Layout {\n    override renderAddFieldBlank({ isHoverRow, isCheckedRow }: Pick<AITableCell, 'isHoverRow' | 'isCheckedRow'>) {\n        super.renderAddFieldBlank({ isHoverRow, isCheckedRow });\n        const rowHeight = this.rowHeight;\n        const defaultWidth = AI_TABLE_FIELD_ADD_BUTTON_WIDTH;\n        const width = this.containerWidth - this.x < defaultWidth ? defaultWidth : this.containerWidth - this.x;\n        this.line({\n            x: this.x + this.columnWidth,\n            y: this.y,\n            points: [0, rowHeight, width, rowHeight],\n            stroke: this.colors.gray200\n        });\n    }\n\n    private renderCell({ width, isHoverRow }: Pick<AITableCell, 'width' | 'isHoverRow'>) {\n        const x = this.x;\n        const y = this.y;\n        const rowHeight = this.rowHeight;\n        const fill = isHoverRow ? this.colors.gray80 : this.colors.transparent;\n\n        this.rect({\n            x,\n            y: y + AI_TABLE_OFFSET,\n            width: width as number,\n            height: rowHeight,\n            fill\n        });\n        this.line({\n            x,\n            y: y + rowHeight,\n            points: [0, 0, width as number, 0],\n            stroke: this.colors.gray200\n        });\n    }\n\n    private renderFirstCell({ isHoverRow }: Pick<AITableCell, 'isHoverRow'>) {\n        if (!this.isFirst) return;\n        const y = this.y;\n        const rowHeight = this.rowHeight;\n        const columnWidth = this.columnWidth;\n        const frozenOffset = AI_TABLE_OFFSET;\n        const fill = isHoverRow ? this.colors.gray80 : this.colors.transparent;\n\n        this.rect({\n            x: frozenOffset + AI_TABLE_ROW_DRAG_ICON_WIDTH,\n            y: y + AI_TABLE_OFFSET,\n            width: columnWidth + AI_TABLE_ROW_HEAD_WIDTH - frozenOffset + 1,\n            height: rowHeight,\n            fill\n        });\n        this.line({\n            x: frozenOffset + AI_TABLE_ROW_DRAG_ICON_WIDTH,\n            y,\n            points: [0, rowHeight, columnWidth + AI_TABLE_ROW_HEAD_WIDTH - frozenOffset + 1, rowHeight],\n            stroke: this.colors.gray200\n        });\n\n        this.path({\n            x: AI_TABLE_CELL_PADDING + AI_TABLE_ROW_DRAG_ICON_WIDTH,\n            y: y + (rowHeight - AI_TABLE_ICON_COMMON_SIZE) / 2 - AI_TABLE_OFFSET,\n            data: AddOutlinedPath,\n            size: AI_TABLE_ROW_HEAD_SIZE,\n            fill: this.colors.gray600\n        });\n    }\n\n    private renderLastCell({ isHoverRow, isCheckedRow }: Pick<AITableCell, 'isHoverRow' | 'isCheckedRow'>) {\n        if (!this.isLast) return;\n        const width = this.columnWidth;\n        if (!this.isFirst) {\n            this.renderCell({\n                width,\n                isHoverRow\n            });\n        }\n        this.renderAddFieldBlank({ isHoverRow, isCheckedRow });\n    }\n\n    private renderCommonCell({ isHoverRow }: Pick<AITableCell, 'isHoverRow'>) {\n        if (this.isFirst || this.isLast) return;\n        this.renderCell({\n            width: this.columnWidth,\n            isHoverRow\n        });\n    }\n\n    render({ isHoverRow, isCheckedRow }: Pick<AITableCell, 'isHoverRow' | 'isCheckedRow'>) {\n        this.renderFirstCell({\n            isHoverRow\n        });\n        this.renderCommonCell({\n            isHoverRow\n        });\n        this.renderLastCell({\n            isHoverRow,\n            isCheckedRow\n        });\n    }\n}\n\nexport const addRowLayout = new AddRowLayout();\n"]}
98
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-row-layout-drawer.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/drawers/add-row-layout-drawer.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AddOutlinedPath,\n    AI_TABLE_CELL_PADDING,\n    AI_TABLE_FIELD_ADD_BUTTON_WIDTH,\n    AI_TABLE_ICON_COMMON_SIZE,\n    AI_TABLE_OFFSET,\n    AI_TABLE_ROW_DRAG_ICON_WIDTH,\n    AI_TABLE_ROW_HEAD_SIZE\n} from '../../constants';\nimport { AITableCell } from '../../types';\nimport { Layout } from './layout-drawer';\n\nexport class AddRowLayout extends Layout {\n    override renderAddFieldBlank({ isHoverRow, isCheckedRow }: Pick<AITableCell, 'isHoverRow' | 'isCheckedRow'>) {\n        super.renderAddFieldBlank({ isHoverRow, isCheckedRow });\n        const rowHeight = this.rowHeight;\n        const defaultWidth = AI_TABLE_FIELD_ADD_BUTTON_WIDTH;\n        const width = this.containerWidth - this.x < defaultWidth ? defaultWidth : this.containerWidth - this.x;\n        this.line({\n            x: this.x + this.columnWidth,\n            y: this.y,\n            points: [0, rowHeight, width, rowHeight],\n            stroke: this.colors.gray200\n        });\n    }\n\n    private renderCell({ width, isHoverRow }: Pick<AITableCell, 'width' | 'isHoverRow'>) {\n        const x = this.x;\n        const y = this.y;\n        const rowHeight = this.rowHeight;\n        const fill = isHoverRow ? this.colors.gray80 : this.colors.transparent;\n\n        this.rect({\n            x,\n            y: y + AI_TABLE_OFFSET,\n            width: width as number,\n            height: rowHeight,\n            fill\n        });\n        this.line({\n            x,\n            y: y + rowHeight,\n            points: [0, 0, width as number, 0],\n            stroke: this.colors.gray200\n        });\n    }\n\n    private renderFirstCell({ isHoverRow }: Pick<AITableCell, 'isHoverRow'>) {\n        if (!this.isFirst) return;\n        const y = this.y;\n        const rowHeight = this.rowHeight;\n        const columnWidth = this.columnWidth;\n        const frozenOffset = AI_TABLE_OFFSET;\n        const fill = isHoverRow ? this.colors.gray80 : this.colors.transparent;\n\n        this.rect({\n            x: this.hiddenIndexColumn ? frozenOffset : frozenOffset + AI_TABLE_ROW_DRAG_ICON_WIDTH,\n            y: y + AI_TABLE_OFFSET,\n            width: columnWidth + this.rowHeadWidth - frozenOffset + 1,\n            height: rowHeight,\n            fill\n        });\n        this.line({\n            x: this.hiddenIndexColumn ? frozenOffset : frozenOffset + AI_TABLE_ROW_DRAG_ICON_WIDTH,\n            y,\n            points: [0, rowHeight, columnWidth + this.rowHeadWidth - frozenOffset + 1, rowHeight],\n            stroke: this.colors.gray200\n        });\n\n        this.path({\n            x: this.hiddenIndexColumn ? AI_TABLE_CELL_PADDING : AI_TABLE_CELL_PADDING + AI_TABLE_ROW_DRAG_ICON_WIDTH,\n            y: y + (rowHeight - AI_TABLE_ICON_COMMON_SIZE) / 2 - AI_TABLE_OFFSET,\n            data: AddOutlinedPath,\n            size: AI_TABLE_ROW_HEAD_SIZE,\n            fill: this.colors.gray600\n        });\n    }\n\n    private renderLastCell({ isHoverRow, isCheckedRow }: Pick<AITableCell, 'isHoverRow' | 'isCheckedRow'>) {\n        if (!this.isLast) return;\n        const width = this.columnWidth;\n        if (!this.isFirst) {\n            this.renderCell({\n                width,\n                isHoverRow\n            });\n        }\n        this.renderAddFieldBlank({ isHoverRow, isCheckedRow });\n    }\n\n    private renderCommonCell({ isHoverRow }: Pick<AITableCell, 'isHoverRow'>) {\n        if (this.isFirst || this.isLast) return;\n        this.renderCell({\n            width: this.columnWidth,\n            isHoverRow\n        });\n    }\n\n    render({ isHoverRow, isCheckedRow }: Pick<AITableCell, 'isHoverRow' | 'isCheckedRow'>) {\n        this.renderFirstCell({\n            isHoverRow\n        });\n        this.renderCommonCell({\n            isHoverRow\n        });\n        this.renderLastCell({\n            isHoverRow,\n            isCheckedRow\n        });\n    }\n}\n\nexport const addRowLayout = new AddRowLayout();\n"]}
@@ -1,4 +1,4 @@
1
- import { AI_TABLE_FIELD_ADD_BUTTON_WIDTH, AI_TABLE_OFFSET } from '../../constants/table';
1
+ import { AI_TABLE_FIELD_ADD_BUTTON_WIDTH, AI_TABLE_OFFSET, AI_TABLE_ROW_HEAD_WIDTH } from '../../constants/table';
2
2
  import { Drawer } from './drawer';
3
3
  /**
4
4
  * 用于处理表格行或单元格的布局和绘制。
@@ -22,9 +22,11 @@ export class Layout extends Drawer {
22
22
  // 列数
23
23
  this.columnCount = 0;
24
24
  this.containerWidth = 0;
25
+ this.rowHeadWidth = AI_TABLE_ROW_HEAD_WIDTH;
26
+ this.hiddenIndexColumn = false;
25
27
  }
26
28
  // 用于初始化或重置布局的基本属性。这个方法通常在每次渲染新的一行或单元格时调用,确保布局信息是最新的
27
- init({ x, y, rowIndex, columnIndex, rowHeight, columnWidth, columnCount, containerWidth }) {
29
+ init({ x, y, rowIndex, columnIndex, rowHeight, columnWidth, columnCount, containerWidth, rowHeadWidth, hiddenIndexColumn }) {
28
30
  this.x = x;
29
31
  this.y = y;
30
32
  this.rowIndex = rowIndex;
@@ -33,6 +35,8 @@ export class Layout extends Drawer {
33
35
  this.columnWidth = columnWidth;
34
36
  this.columnCount = columnCount;
35
37
  this.containerWidth = containerWidth;
38
+ this.rowHeadWidth = rowHeadWidth;
39
+ this.hiddenIndexColumn = hiddenIndexColumn;
36
40
  }
37
41
  // 当前单元格是否是行的第一列
38
42
  get isFirst() {
@@ -57,4 +61,4 @@ export class Layout extends Drawer {
57
61
  });
58
62
  }
59
63
  }
60
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF5b3V0LWRyYXdlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2dyaWQvc3JjL3JlbmRlcmVyL2RyYXdlcnMvbGF5b3V0LWRyYXdlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsK0JBQStCLEVBQUUsZUFBZSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFFekYsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUVsQzs7OztHQUlHO0FBQ0gsTUFBTSxPQUFPLE1BQU8sU0FBUSxNQUFNO0lBQWxDOztRQUNJLGVBQWU7UUFDTCxNQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ04sTUFBQyxHQUFHLENBQUMsQ0FBQztRQUNoQixLQUFLO1FBQ0ssY0FBUyxHQUFHLENBQUMsQ0FBQztRQUN4QixLQUFLO1FBQ0ssZ0JBQVcsR0FBRyxDQUFDLENBQUM7UUFDMUIsTUFBTTtRQUNJLGFBQVEsR0FBRyxDQUFDLENBQUM7UUFDdkIsTUFBTTtRQUNJLGdCQUFXLEdBQUcsQ0FBQyxDQUFDO1FBQzFCLEtBQUs7UUFDSyxnQkFBVyxHQUFHLENBQUMsQ0FBQztRQUVoQixtQkFBYyxHQUFHLENBQUMsQ0FBQztJQXVDakMsQ0FBQztJQXJDRyxvREFBb0Q7SUFDcEQsSUFBSSxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxRQUFRLEVBQUUsV0FBVyxFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsV0FBVyxFQUFFLGNBQWMsRUFBaUI7UUFDcEcsSUFBSSxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDWCxJQUFJLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUNYLElBQUksQ0FBQyxRQUFRLEdBQUcsUUFBUSxDQUFDO1FBQ3pCLElBQUksQ0FBQyxXQUFXLEdBQUcsV0FBVyxDQUFDO1FBQy9CLElBQUksQ0FBQyxTQUFTLEdBQUcsU0FBUyxDQUFDO1FBQzNCLElBQUksQ0FBQyxXQUFXLEdBQUcsV0FBVyxDQUFDO1FBQy9CLElBQUksQ0FBQyxXQUFXLEdBQUcsV0FBVyxDQUFDO1FBQy9CLElBQUksQ0FBQyxjQUFjLEdBQUcsY0FBYyxDQUFDO0lBQ3pDLENBQUM7SUFFRCxnQkFBZ0I7SUFDaEIsSUFBYyxPQUFPO1FBQ2pCLE9BQU8sSUFBSSxDQUFDLFdBQVcsS0FBSyxDQUFDLENBQUM7SUFDbEMsQ0FBQztJQUVELGlCQUFpQjtJQUNqQixJQUFjLE1BQU07UUFDaEIsT0FBTyxJQUFJLENBQUMsV0FBVyxLQUFLLElBQUksQ0FBQyxXQUFXLEdBQUcsQ0FBQyxDQUFDO0lBQ3JELENBQUM7SUFFUyxtQkFBbUIsQ0FBQyxFQUFFLFVBQVUsRUFBRSxZQUFZLEVBQW9EO1FBQ3hHLE1BQU0sU0FBUyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUM7UUFDakMsTUFBTSxJQUFJLEdBQUcsWUFBWSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLGlCQUFpQixDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLFdBQVcsQ0FBQztRQUN0SCxNQUFNLGNBQWMsR0FBRyxJQUFJLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxXQUFXLEdBQUcsZUFBZSxDQUFDO1FBQ25FLElBQUksQ0FBQyxJQUFJLENBQUM7WUFDTixDQUFDLEVBQUUsY0FBYztZQUNqQixDQUFDLEVBQUUsSUFBSSxDQUFDLENBQUMsR0FBRyxlQUFlO1lBQzNCLEtBQUssRUFDRCxJQUFJLENBQUMsY0FBYyxHQUFHLGNBQWMsR0FBRywrQkFBK0I7Z0JBQ2xFLENBQUMsQ0FBQywrQkFBK0I7Z0JBQ2pDLENBQUMsQ0FBQyxJQUFJLENBQUMsY0FBYyxHQUFHLGNBQWM7WUFDOUMsTUFBTSxFQUFFLFNBQVM7WUFDakIsSUFBSTtTQUNQLENBQUMsQ0FBQztJQUNQLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFJX1RBQkxFX0ZJRUxEX0FERF9CVVRUT05fV0lEVEgsIEFJX1RBQkxFX09GRlNFVCB9IGZyb20gJy4uLy4uL2NvbnN0YW50cy90YWJsZSc7XG5pbXBvcnQgeyBBSVRhYmxlQ2VsbCwgQUlUYWJsZUxheW91dCB9IGZyb20gJy4uLy4uL3R5cGVzJztcbmltcG9ydCB7IERyYXdlciB9IGZyb20gJy4vZHJhd2VyJztcblxuLyoqXG4gKiDnlKjkuo7lpITnkIbooajmoLzooYzmiJbljZXlhYPmoLznmoTluIPlsYDlkoznu5jliLbjgIJcbiAqIOWug+aPkOS+m+S6huWfuuacrOeahOW4g+WxgOS/oeaBr++8iOWmguS9jee9ruOAgeWkp+Wwj+etie+8ie+8jOW5tuWumuS5ieS6huW4uOeUqOeahOe7mOWbvuaWueazle+8iOWmgua4suafk+e8qei/m+WMuuWfn+OAgea3u+WKoOaWsOWtl+auteeahOepuueZveWMuuWfn+etie+8ieOAglxuICog6K+l57G757un5om/6IeqIERyYXdlcu+8jOW5tuiiq+WFtuS7luabtOWFt+S9k+eahOW4g+WxgOexu++8iOWmgiBSZWNvcmRSb3dMYXlvdXTvvInmianlsZXlkozkvb/nlKhcbiAqL1xuZXhwb3J0IGNsYXNzIExheW91dCBleHRlbmRzIERyYXdlciB7XG4gICAgLy8g5a6a5LmJ5b2T5YmN5Y2V5YWD5qC85oiW6KGM55qE5L2N572uXG4gICAgcHJvdGVjdGVkIHggPSAwO1xuICAgIHByb3RlY3RlZCB5ID0gMDtcbiAgICAvLyDooYzpq5hcbiAgICBwcm90ZWN0ZWQgcm93SGVpZ2h0ID0gMDtcbiAgICAvLyDliJflrr1cbiAgICBwcm90ZWN0ZWQgY29sdW1uV2lkdGggPSAwO1xuICAgIC8vIOihjOe0ouW8lVxuICAgIHByb3RlY3RlZCByb3dJbmRleCA9IDA7XG4gICAgLy8g5YiX57Si5byVXG4gICAgcHJvdGVjdGVkIGNvbHVtbkluZGV4ID0gMDtcbiAgICAvLyDliJfmlbBcbiAgICBwcm90ZWN0ZWQgY29sdW1uQ291bnQgPSAwO1xuXG4gICAgcHJvdGVjdGVkIGNvbnRhaW5lcldpZHRoID0gMDtcblxuICAgIC8vIOeUqOS6juWIneWni+WMluaIlumHjee9ruW4g+WxgOeahOWfuuacrOWxnuaAp+OAgui/meS4quaWueazlemAmuW4uOWcqOavj+asoea4suafk+aWsOeahOS4gOihjOaIluWNleWFg+agvOaXtuiwg+eUqO+8jOehruS/neW4g+WxgOS/oeaBr+aYr+acgOaWsOeahFxuICAgIGluaXQoeyB4LCB5LCByb3dJbmRleCwgY29sdW1uSW5kZXgsIHJvd0hlaWdodCwgY29sdW1uV2lkdGgsIGNvbHVtbkNvdW50LCBjb250YWluZXJXaWR0aCB9OiBBSVRhYmxlTGF5b3V0KSB7XG4gICAgICAgIHRoaXMueCA9IHg7XG4gICAgICAgIHRoaXMueSA9IHk7XG4gICAgICAgIHRoaXMucm93SW5kZXggPSByb3dJbmRleDtcbiAgICAgICAgdGhpcy5jb2x1bW5JbmRleCA9IGNvbHVtbkluZGV4O1xuICAgICAgICB0aGlzLnJvd0hlaWdodCA9IHJvd0hlaWdodDtcbiAgICAgICAgdGhpcy5jb2x1bW5XaWR0aCA9IGNvbHVtbldpZHRoO1xuICAgICAgICB0aGlzLmNvbHVtbkNvdW50ID0gY29sdW1uQ291bnQ7XG4gICAgICAgIHRoaXMuY29udGFpbmVyV2lkdGggPSBjb250YWluZXJXaWR0aDtcbiAgICB9XG5cbiAgICAvLyDlvZPliY3ljZXlhYPmoLzmmK/lkKbmmK/ooYznmoTnrKzkuIDliJdcbiAgICBwcm90ZWN0ZWQgZ2V0IGlzRmlyc3QoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLmNvbHVtbkluZGV4ID09PSAwO1xuICAgIH1cblxuICAgIC8vIOW9k+WJjeWNleWFg+agvOaYr+WQpuaYr+ihjOeahOacgOWQjuS4gOWIl1xuICAgIHByb3RlY3RlZCBnZXQgaXNMYXN0KCkge1xuICAgICAgICByZXR1cm4gdGhpcy5jb2x1bW5JbmRleCA9PT0gdGhpcy5jb2x1bW5Db3VudCAtIDE7XG4gICAgfVxuXG4gICAgcHJvdGVjdGVkIHJlbmRlckFkZEZpZWxkQmxhbmsoeyBpc0hvdmVyUm93LCBpc0NoZWNrZWRSb3cgfTogUGljazxBSVRhYmxlQ2VsbCwgJ2lzSG92ZXJSb3cnIHwgJ2lzQ2hlY2tlZFJvdyc+KSB7XG4gICAgICAgIGNvbnN0IHJvd0hlaWdodCA9IHRoaXMucm93SGVpZ2h0O1xuICAgICAgICBjb25zdCBmaWxsID0gaXNDaGVja2VkUm93ID8gdGhpcy5jb2xvcnMuaXRlbUFjdGl2ZUJnQ29sb3IgOiBpc0hvdmVyUm93ID8gdGhpcy5jb2xvcnMuZ3JheTgwIDogdGhpcy5jb2xvcnMudHJhbnNwYXJlbnQ7XG4gICAgICAgIGNvbnN0IGFkZEZpZWxkQmxhbmtYID0gdGhpcy54ICsgdGhpcy5jb2x1bW5XaWR0aCArIEFJX1RBQkxFX09GRlNFVDtcbiAgICAgICAgdGhpcy5yZWN0KHtcbiAgICAgICAgICAgIHg6IGFkZEZpZWxkQmxhbmtYLFxuICAgICAgICAgICAgeTogdGhpcy55ICsgQUlfVEFCTEVfT0ZGU0VULFxuICAgICAgICAgICAgd2lkdGg6XG4gICAgICAgICAgICAgICAgdGhpcy5jb250YWluZXJXaWR0aCAtIGFkZEZpZWxkQmxhbmtYIDwgQUlfVEFCTEVfRklFTERfQUREX0JVVFRPTl9XSURUSFxuICAgICAgICAgICAgICAgICAgICA/IEFJX1RBQkxFX0ZJRUxEX0FERF9CVVRUT05fV0lEVEhcbiAgICAgICAgICAgICAgICAgICAgOiB0aGlzLmNvbnRhaW5lcldpZHRoIC0gYWRkRmllbGRCbGFua1gsXG4gICAgICAgICAgICBoZWlnaHQ6IHJvd0hlaWdodCxcbiAgICAgICAgICAgIGZpbGxcbiAgICAgICAgfSk7XG4gICAgfVxufVxuIl19
64
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF5b3V0LWRyYXdlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2dyaWQvc3JjL3JlbmRlcmVyL2RyYXdlcnMvbGF5b3V0LWRyYXdlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsK0JBQStCLEVBQUUsZUFBZSxFQUFFLHVCQUF1QixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFFbEgsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUVsQzs7OztHQUlHO0FBQ0gsTUFBTSxPQUFPLE1BQU8sU0FBUSxNQUFNO0lBQWxDOztRQUNJLGVBQWU7UUFDTCxNQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ04sTUFBQyxHQUFHLENBQUMsQ0FBQztRQUNoQixLQUFLO1FBQ0ssY0FBUyxHQUFHLENBQUMsQ0FBQztRQUN4QixLQUFLO1FBQ0ssZ0JBQVcsR0FBRyxDQUFDLENBQUM7UUFDMUIsTUFBTTtRQUNJLGFBQVEsR0FBRyxDQUFDLENBQUM7UUFDdkIsTUFBTTtRQUNJLGdCQUFXLEdBQUcsQ0FBQyxDQUFDO1FBQzFCLEtBQUs7UUFDSyxnQkFBVyxHQUFHLENBQUMsQ0FBQztRQUVoQixtQkFBYyxHQUFHLENBQUMsQ0FBQztRQUVuQixpQkFBWSxHQUFHLHVCQUF1QixDQUFDO1FBRXZDLHNCQUFpQixHQUFHLEtBQUssQ0FBQztJQW9EeEMsQ0FBQztJQWxERyxvREFBb0Q7SUFDcEQsSUFBSSxDQUFDLEVBQ0QsQ0FBQyxFQUNELENBQUMsRUFDRCxRQUFRLEVBQ1IsV0FBVyxFQUNYLFNBQVMsRUFDVCxXQUFXLEVBQ1gsV0FBVyxFQUNYLGNBQWMsRUFDZCxZQUFZLEVBQ1osaUJBQWlCLEVBQ0w7UUFDWixJQUFJLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUNYLElBQUksQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ1gsSUFBSSxDQUFDLFFBQVEsR0FBRyxRQUFRLENBQUM7UUFDekIsSUFBSSxDQUFDLFdBQVcsR0FBRyxXQUFXLENBQUM7UUFDL0IsSUFBSSxDQUFDLFNBQVMsR0FBRyxTQUFTLENBQUM7UUFDM0IsSUFBSSxDQUFDLFdBQVcsR0FBRyxXQUFXLENBQUM7UUFDL0IsSUFBSSxDQUFDLFdBQVcsR0FBRyxXQUFXLENBQUM7UUFDL0IsSUFBSSxDQUFDLGNBQWMsR0FBRyxjQUFjLENBQUM7UUFDckMsSUFBSSxDQUFDLFlBQVksR0FBRyxZQUFZLENBQUM7UUFDakMsSUFBSSxDQUFDLGlCQUFpQixHQUFHLGlCQUFpQixDQUFDO0lBQy9DLENBQUM7SUFFRCxnQkFBZ0I7SUFDaEIsSUFBYyxPQUFPO1FBQ2pCLE9BQU8sSUFBSSxDQUFDLFdBQVcsS0FBSyxDQUFDLENBQUM7SUFDbEMsQ0FBQztJQUVELGlCQUFpQjtJQUNqQixJQUFjLE1BQU07UUFDaEIsT0FBTyxJQUFJLENBQUMsV0FBVyxLQUFLLElBQUksQ0FBQyxXQUFXLEdBQUcsQ0FBQyxDQUFDO0lBQ3JELENBQUM7SUFFUyxtQkFBbUIsQ0FBQyxFQUFFLFVBQVUsRUFBRSxZQUFZLEVBQW9EO1FBQ3hHLE1BQU0sU0FBUyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUM7UUFDakMsTUFBTSxJQUFJLEdBQUcsWUFBWSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLGlCQUFpQixDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLFdBQVcsQ0FBQztRQUN0SCxNQUFNLGNBQWMsR0FBRyxJQUFJLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxXQUFXLEdBQUcsZUFBZSxDQUFDO1FBQ25FLElBQUksQ0FBQyxJQUFJLENBQUM7WUFDTixDQUFDLEVBQUUsY0FBYztZQUNqQixDQUFDLEVBQUUsSUFBSSxDQUFDLENBQUMsR0FBRyxlQUFlO1lBQzNCLEtBQUssRUFDRCxJQUFJLENBQUMsY0FBYyxHQUFHLGNBQWMsR0FBRywrQkFBK0I7Z0JBQ2xFLENBQUMsQ0FBQywrQkFBK0I7Z0JBQ2pDLENBQUMsQ0FBQyxJQUFJLENBQUMsY0FBYyxHQUFHLGNBQWM7WUFDOUMsTUFBTSxFQUFFLFNBQVM7WUFDakIsSUFBSTtTQUNQLENBQUMsQ0FBQztJQUNQLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFJX1RBQkxFX0ZJRUxEX0FERF9CVVRUT05fV0lEVEgsIEFJX1RBQkxFX09GRlNFVCwgQUlfVEFCTEVfUk9XX0hFQURfV0lEVEggfSBmcm9tICcuLi8uLi9jb25zdGFudHMvdGFibGUnO1xuaW1wb3J0IHsgQUlUYWJsZUNlbGwsIEFJVGFibGVMYXlvdXQgfSBmcm9tICcuLi8uLi90eXBlcyc7XG5pbXBvcnQgeyBEcmF3ZXIgfSBmcm9tICcuL2RyYXdlcic7XG5cbi8qKlxuICog55So5LqO5aSE55CG6KGo5qC86KGM5oiW5Y2V5YWD5qC855qE5biD5bGA5ZKM57uY5Yi244CCXG4gKiDlroPmj5Dkvpvkuobln7rmnKznmoTluIPlsYDkv6Hmga/vvIjlpoLkvY3nva7jgIHlpKflsI/nrYnvvInvvIzlubblrprkuYnkuobluLjnlKjnmoTnu5jlm77mlrnms5XvvIjlpoLmuLLmn5PnvKnov5vljLrln5/jgIHmt7vliqDmlrDlrZfmrrXnmoTnqbrnmb3ljLrln5/nrYnvvInjgIJcbiAqIOivpeexu+e7p+aJv+iHqiBEcmF3ZXLvvIzlubbooqvlhbbku5bmm7TlhbfkvZPnmoTluIPlsYDnsbvvvIjlpoIgUmVjb3JkUm93TGF5b3V077yJ5omp5bGV5ZKM5L2/55SoXG4gKi9cbmV4cG9ydCBjbGFzcyBMYXlvdXQgZXh0ZW5kcyBEcmF3ZXIge1xuICAgIC8vIOWumuS5ieW9k+WJjeWNleWFg+agvOaIluihjOeahOS9jee9rlxuICAgIHByb3RlY3RlZCB4ID0gMDtcbiAgICBwcm90ZWN0ZWQgeSA9IDA7XG4gICAgLy8g6KGM6auYXG4gICAgcHJvdGVjdGVkIHJvd0hlaWdodCA9IDA7XG4gICAgLy8g5YiX5a69XG4gICAgcHJvdGVjdGVkIGNvbHVtbldpZHRoID0gMDtcbiAgICAvLyDooYzntKLlvJVcbiAgICBwcm90ZWN0ZWQgcm93SW5kZXggPSAwO1xuICAgIC8vIOWIl+e0ouW8lVxuICAgIHByb3RlY3RlZCBjb2x1bW5JbmRleCA9IDA7XG4gICAgLy8g5YiX5pWwXG4gICAgcHJvdGVjdGVkIGNvbHVtbkNvdW50ID0gMDtcblxuICAgIHByb3RlY3RlZCBjb250YWluZXJXaWR0aCA9IDA7XG5cbiAgICBwcm90ZWN0ZWQgcm93SGVhZFdpZHRoID0gQUlfVEFCTEVfUk9XX0hFQURfV0lEVEg7XG5cbiAgICBwcm90ZWN0ZWQgaGlkZGVuSW5kZXhDb2x1bW4gPSBmYWxzZTtcblxuICAgIC8vIOeUqOS6juWIneWni+WMluaIlumHjee9ruW4g+WxgOeahOWfuuacrOWxnuaAp+OAgui/meS4quaWueazlemAmuW4uOWcqOavj+asoea4suafk+aWsOeahOS4gOihjOaIluWNleWFg+agvOaXtuiwg+eUqO+8jOehruS/neW4g+WxgOS/oeaBr+aYr+acgOaWsOeahFxuICAgIGluaXQoe1xuICAgICAgICB4LFxuICAgICAgICB5LFxuICAgICAgICByb3dJbmRleCxcbiAgICAgICAgY29sdW1uSW5kZXgsXG4gICAgICAgIHJvd0hlaWdodCxcbiAgICAgICAgY29sdW1uV2lkdGgsXG4gICAgICAgIGNvbHVtbkNvdW50LFxuICAgICAgICBjb250YWluZXJXaWR0aCxcbiAgICAgICAgcm93SGVhZFdpZHRoLFxuICAgICAgICBoaWRkZW5JbmRleENvbHVtblxuICAgIH06IEFJVGFibGVMYXlvdXQpIHtcbiAgICAgICAgdGhpcy54ID0geDtcbiAgICAgICAgdGhpcy55ID0geTtcbiAgICAgICAgdGhpcy5yb3dJbmRleCA9IHJvd0luZGV4O1xuICAgICAgICB0aGlzLmNvbHVtbkluZGV4ID0gY29sdW1uSW5kZXg7XG4gICAgICAgIHRoaXMucm93SGVpZ2h0ID0gcm93SGVpZ2h0O1xuICAgICAgICB0aGlzLmNvbHVtbldpZHRoID0gY29sdW1uV2lkdGg7XG4gICAgICAgIHRoaXMuY29sdW1uQ291bnQgPSBjb2x1bW5Db3VudDtcbiAgICAgICAgdGhpcy5jb250YWluZXJXaWR0aCA9IGNvbnRhaW5lcldpZHRoO1xuICAgICAgICB0aGlzLnJvd0hlYWRXaWR0aCA9IHJvd0hlYWRXaWR0aDtcbiAgICAgICAgdGhpcy5oaWRkZW5JbmRleENvbHVtbiA9IGhpZGRlbkluZGV4Q29sdW1uO1xuICAgIH1cblxuICAgIC8vIOW9k+WJjeWNleWFg+agvOaYr+WQpuaYr+ihjOeahOesrOS4gOWIl1xuICAgIHByb3RlY3RlZCBnZXQgaXNGaXJzdCgpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuY29sdW1uSW5kZXggPT09IDA7XG4gICAgfVxuXG4gICAgLy8g5b2T5YmN5Y2V5YWD5qC85piv5ZCm5piv6KGM55qE5pyA5ZCO5LiA5YiXXG4gICAgcHJvdGVjdGVkIGdldCBpc0xhc3QoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLmNvbHVtbkluZGV4ID09PSB0aGlzLmNvbHVtbkNvdW50IC0gMTtcbiAgICB9XG5cbiAgICBwcm90ZWN0ZWQgcmVuZGVyQWRkRmllbGRCbGFuayh7IGlzSG92ZXJSb3csIGlzQ2hlY2tlZFJvdyB9OiBQaWNrPEFJVGFibGVDZWxsLCAnaXNIb3ZlclJvdycgfCAnaXNDaGVja2VkUm93Jz4pIHtcbiAgICAgICAgY29uc3Qgcm93SGVpZ2h0ID0gdGhpcy5yb3dIZWlnaHQ7XG4gICAgICAgIGNvbnN0IGZpbGwgPSBpc0NoZWNrZWRSb3cgPyB0aGlzLmNvbG9ycy5pdGVtQWN0aXZlQmdDb2xvciA6IGlzSG92ZXJSb3cgPyB0aGlzLmNvbG9ycy5ncmF5ODAgOiB0aGlzLmNvbG9ycy50cmFuc3BhcmVudDtcbiAgICAgICAgY29uc3QgYWRkRmllbGRCbGFua1ggPSB0aGlzLnggKyB0aGlzLmNvbHVtbldpZHRoICsgQUlfVEFCTEVfT0ZGU0VUO1xuICAgICAgICB0aGlzLnJlY3Qoe1xuICAgICAgICAgICAgeDogYWRkRmllbGRCbGFua1gsXG4gICAgICAgICAgICB5OiB0aGlzLnkgKyBBSV9UQUJMRV9PRkZTRVQsXG4gICAgICAgICAgICB3aWR0aDpcbiAgICAgICAgICAgICAgICB0aGlzLmNvbnRhaW5lcldpZHRoIC0gYWRkRmllbGRCbGFua1ggPCBBSV9UQUJMRV9GSUVMRF9BRERfQlVUVE9OX1dJRFRIXG4gICAgICAgICAgICAgICAgICAgID8gQUlfVEFCTEVfRklFTERfQUREX0JVVFRPTl9XSURUSFxuICAgICAgICAgICAgICAgICAgICA6IHRoaXMuY29udGFpbmVyV2lkdGggLSBhZGRGaWVsZEJsYW5rWCxcbiAgICAgICAgICAgIGhlaWdodDogcm93SGVpZ2h0LFxuICAgICAgICAgICAgZmlsbFxuICAgICAgICB9KTtcbiAgICB9XG59XG4iXX0=
@@ -1,4 +1,4 @@
1
- import { AI_TABLE_FIELD_ADD_BUTTON_WIDTH, AI_TABLE_FIELD_HEAD_HEIGHT, AI_TABLE_OFFSET, AI_TABLE_ROW_DRAG_ICON_WIDTH, AI_TABLE_ROW_HEAD_WIDTH, DEFAULT_FONT_SIZE } from '../../constants';
1
+ import { AI_TABLE_FIELD_ADD_BUTTON_WIDTH, AI_TABLE_FIELD_HEAD_HEIGHT, AI_TABLE_OFFSET, AI_TABLE_ROW_DRAG_ICON_WIDTH, DEFAULT_FONT_SIZE } from '../../constants';
2
2
  import { DEFAULT_TEXT_ALIGN_CENTER, DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE } from '../../constants/text';
3
3
  import { AITable } from '../../core';
4
4
  import { Layout } from './layout-drawer';
@@ -36,35 +36,51 @@ export class RecordRowLayout extends Layout {
36
36
  else if (isHoverRow) {
37
37
  fillBg = colors.gray80;
38
38
  }
39
- this.customRect({
40
- x: AI_TABLE_OFFSET + AI_TABLE_ROW_DRAG_ICON_WIDTH,
41
- y,
42
- width: AI_TABLE_ROW_HEAD_WIDTH - AI_TABLE_OFFSET - AI_TABLE_ROW_DRAG_ICON_WIDTH,
43
- height: rowHeight,
44
- fill: fillBg,
45
- strokes: {
46
- right: colors.gray200,
47
- bottom: colors.gray200
39
+ if (!this.hiddenIndexColumn) {
40
+ this.customRect({
41
+ x: AI_TABLE_OFFSET + AI_TABLE_ROW_DRAG_ICON_WIDTH,
42
+ y,
43
+ width: this.rowHeadWidth - AI_TABLE_OFFSET - AI_TABLE_ROW_DRAG_ICON_WIDTH,
44
+ height: rowHeight,
45
+ fill: fillBg,
46
+ strokes: {
47
+ right: colors.gray200,
48
+ bottom: colors.gray200
49
+ }
50
+ });
51
+ if (!isCheckedRow && !isHoverRow) {
52
+ // 设置字体样式,居中绘制行号
53
+ this.setStyle({ fontSize: DEFAULT_FONT_SIZE });
54
+ this.text({
55
+ x: (this.rowHeadWidth + AI_TABLE_ROW_DRAG_ICON_WIDTH) / 2,
56
+ y: y + AI_TABLE_FIELD_HEAD_HEIGHT / 2,
57
+ text: String(row.displayIndex),
58
+ textAlign: DEFAULT_TEXT_ALIGN_CENTER,
59
+ verticalAlign: DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE
60
+ });
48
61
  }
49
- });
50
- // 第一列单元格
51
- this.rect({
52
- x: AI_TABLE_ROW_HEAD_WIDTH,
53
- y,
54
- width: columnWidth + AI_TABLE_OFFSET,
55
- height: rowHeight,
56
- fill: fill,
57
- stroke: colors.gray200
58
- });
59
- if (!isCheckedRow && !isHoverRow) {
60
- // 设置字体样式,居中绘制行号
61
- this.setStyle({ fontSize: DEFAULT_FONT_SIZE });
62
- this.text({
63
- x: (AI_TABLE_ROW_HEAD_WIDTH + AI_TABLE_ROW_DRAG_ICON_WIDTH) / 2,
64
- y: y + AI_TABLE_FIELD_HEAD_HEIGHT / 2,
65
- text: String(row.displayIndex),
66
- textAlign: DEFAULT_TEXT_ALIGN_CENTER,
67
- verticalAlign: DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE
62
+ // 第一列单元格
63
+ this.rect({
64
+ x: this.rowHeadWidth,
65
+ y,
66
+ width: columnWidth + AI_TABLE_OFFSET,
67
+ height: rowHeight,
68
+ fill: fill,
69
+ stroke: colors.gray200
70
+ });
71
+ }
72
+ else {
73
+ // 第一列单元格
74
+ this.customRect({
75
+ x: this.rowHeadWidth,
76
+ y,
77
+ width: columnWidth + AI_TABLE_OFFSET,
78
+ height: rowHeight,
79
+ fill: fill,
80
+ strokes: {
81
+ right: colors.gray200,
82
+ bottom: colors.gray200
83
+ }
68
84
  });
69
85
  }
70
86
  if (this.isLast) {
@@ -112,4 +128,4 @@ export class RecordRowLayout extends Layout {
112
128
  }
113
129
  }
114
130
  export const recordRowLayout = new RecordRowLayout();
115
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"record-row-layout-drawer.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/drawers/record-row-layout-drawer.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AI_TABLE_FIELD_ADD_BUTTON_WIDTH,\n    AI_TABLE_FIELD_HEAD_HEIGHT,\n    AI_TABLE_OFFSET,\n    AI_TABLE_ROW_DRAG_ICON_WIDTH,\n    AI_TABLE_ROW_HEAD_WIDTH,\n    DEFAULT_FONT_SIZE\n} from '../../constants';\nimport { DEFAULT_TEXT_ALIGN_CENTER, DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE } from '../../constants/text';\nimport { AITable } from '../../core';\nimport { AITableCell } from '../../types';\nimport { Layout } from './layout-drawer';\n\n/**\n * 绘制行的布局，通过直接操作 Canvas 提供高效的渲染方法。\n * 它继承自 Layout 类，包含了用于绘制行中单元格（尤其是首列和尾列）的几个方法\n */\nexport class RecordRowLayout extends Layout {\n    protected override renderAddFieldBlank({ isHoverRow, isCheckedRow }: Pick<AITableCell, 'isHoverRow' | 'isCheckedRow'>): void {\n        super.renderAddFieldBlank({ isHoverRow, isCheckedRow });\n        const rowHeight = this.rowHeight;\n        const startX = this.x + this.columnWidth;\n        const lineWidth =\n            this.containerWidth - startX < AI_TABLE_FIELD_ADD_BUTTON_WIDTH ? AI_TABLE_FIELD_ADD_BUTTON_WIDTH : this.containerWidth - startX;\n        this.line({\n            x: startX,\n            y: this.y,\n            points: [0, rowHeight, lineWidth, rowHeight],\n            stroke: this.colors.gray200\n        });\n    }\n\n    // 首列\n    private renderFirstCell({ row, style, isHoverRow, isCheckedRow }: AITableCell) {\n        if (!this.isFirst) return;\n        const { fill } = style;\n        const y = this.y;\n        const rowHeight = this.rowHeight;\n        const columnWidth = this.columnWidth;\n        const colors = AITable.getColors();\n        // 编号的上下边框\n        let fillBg = colors.transparent;\n        if (isCheckedRow) {\n            fillBg = colors.itemActiveBgColor;\n        } else if (isHoverRow) {\n            fillBg = colors.gray80;\n        }\n        this.customRect({\n            x: AI_TABLE_OFFSET + AI_TABLE_ROW_DRAG_ICON_WIDTH,\n            y,\n            width: AI_TABLE_ROW_HEAD_WIDTH - AI_TABLE_OFFSET - AI_TABLE_ROW_DRAG_ICON_WIDTH,\n            height: rowHeight,\n            fill: fillBg,\n            strokes: {\n                right: colors.gray200,\n                bottom: colors.gray200\n            }\n        });\n        // 第一列单元格\n        this.rect({\n            x: AI_TABLE_ROW_HEAD_WIDTH,\n            y,\n            width: columnWidth + AI_TABLE_OFFSET,\n            height: rowHeight,\n            fill: fill,\n            stroke: colors.gray200\n        });\n\n        if (!isCheckedRow && !isHoverRow) {\n            // 设置字体样式，居中绘制行号\n            this.setStyle({ fontSize: DEFAULT_FONT_SIZE });\n            this.text({\n                x: (AI_TABLE_ROW_HEAD_WIDTH + AI_TABLE_ROW_DRAG_ICON_WIDTH) / 2,\n                y: y + AI_TABLE_FIELD_HEAD_HEIGHT / 2,\n                text: String(row.displayIndex),\n                textAlign: DEFAULT_TEXT_ALIGN_CENTER,\n                verticalAlign: DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE\n            });\n        }\n\n        if (this.isLast) {\n            this.renderAddFieldBlank({ isHoverRow, isCheckedRow });\n        }\n    }\n\n    // 尾列\n    private renderLastCell({ style, isHoverRow, isCheckedRow }: Pick<AITableCell, 'style' | 'isHoverRow' | 'isCheckedRow'>) {\n        if (!this.isLast || this.isFirst) return;\n        const { fill, stroke } = style;\n        const colors = AITable.getColors();\n\n        // 背景、边框\n        this.rect({\n            x: this.x,\n            y: this.y,\n            width: this.columnWidth,\n            height: this.rowHeight,\n            fill: fill || colors.white,\n            stroke: stroke || colors.gray200\n        });\n\n        this.renderAddFieldBlank({ isHoverRow, isCheckedRow });\n    }\n\n    // 绘制中间的普通单元格\n    private renderCommonCell({ style }: Pick<AITableCell, 'style'>) {\n        if (this.isFirst || this.isLast) return;\n\n        const { fill, stroke } = style;\n        const colors = AITable.getColors();\n\n        // 背景、边框\n        this.rect({\n            x: this.x,\n            y: this.y,\n            width: this.columnWidth,\n            height: this.rowHeight,\n            fill: fill || colors.white,\n            stroke: stroke || colors.gray200\n        });\n    }\n\n    render(config: AITableCell) {\n        const { row, style, isCheckedRow, isHoverRow } = config;\n        this.renderFirstCell({ row, style, isCheckedRow, isHoverRow });\n        this.renderCommonCell({ style });\n        this.renderLastCell({ style, isCheckedRow, isHoverRow });\n    }\n}\n\nexport const recordRowLayout = new RecordRowLayout();\n"]}
131
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"record-row-layout-drawer.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/drawers/record-row-layout-drawer.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AI_TABLE_FIELD_ADD_BUTTON_WIDTH,\n    AI_TABLE_FIELD_HEAD_HEIGHT,\n    AI_TABLE_OFFSET,\n    AI_TABLE_ROW_DRAG_ICON_WIDTH,\n    DEFAULT_FONT_SIZE\n} from '../../constants';\nimport { DEFAULT_TEXT_ALIGN_CENTER, DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE } from '../../constants/text';\nimport { AITable } from '../../core';\nimport { AITableCell } from '../../types';\nimport { Layout } from './layout-drawer';\n\n/**\n * 绘制行的布局，通过直接操作 Canvas 提供高效的渲染方法。\n * 它继承自 Layout 类，包含了用于绘制行中单元格（尤其是首列和尾列）的几个方法\n */\nexport class RecordRowLayout extends Layout {\n    protected override renderAddFieldBlank({ isHoverRow, isCheckedRow }: Pick<AITableCell, 'isHoverRow' | 'isCheckedRow'>): void {\n        super.renderAddFieldBlank({ isHoverRow, isCheckedRow });\n        const rowHeight = this.rowHeight;\n        const startX = this.x + this.columnWidth;\n        const lineWidth =\n            this.containerWidth - startX < AI_TABLE_FIELD_ADD_BUTTON_WIDTH ? AI_TABLE_FIELD_ADD_BUTTON_WIDTH : this.containerWidth - startX;\n        this.line({\n            x: startX,\n            y: this.y,\n            points: [0, rowHeight, lineWidth, rowHeight],\n            stroke: this.colors.gray200\n        });\n    }\n\n    // 首列\n    private renderFirstCell({ row, style, isHoverRow, isCheckedRow }: AITableCell) {\n        if (!this.isFirst) return;\n        const { fill } = style;\n        const y = this.y;\n        const rowHeight = this.rowHeight;\n        const columnWidth = this.columnWidth;\n        const colors = AITable.getColors();\n        // 编号的上下边框\n        let fillBg = colors.transparent;\n        if (isCheckedRow) {\n            fillBg = colors.itemActiveBgColor;\n        } else if (isHoverRow) {\n            fillBg = colors.gray80;\n        }\n\n        if (!this.hiddenIndexColumn) {\n            this.customRect({\n                x: AI_TABLE_OFFSET + AI_TABLE_ROW_DRAG_ICON_WIDTH,\n                y,\n                width: this.rowHeadWidth - AI_TABLE_OFFSET - AI_TABLE_ROW_DRAG_ICON_WIDTH,\n                height: rowHeight,\n                fill: fillBg,\n                strokes: {\n                    right: colors.gray200,\n                    bottom: colors.gray200\n                }\n            });\n            if (!isCheckedRow && !isHoverRow) {\n                // 设置字体样式，居中绘制行号\n                this.setStyle({ fontSize: DEFAULT_FONT_SIZE });\n                this.text({\n                    x: (this.rowHeadWidth + AI_TABLE_ROW_DRAG_ICON_WIDTH) / 2,\n                    y: y + AI_TABLE_FIELD_HEAD_HEIGHT / 2,\n                    text: String(row.displayIndex),\n                    textAlign: DEFAULT_TEXT_ALIGN_CENTER,\n                    verticalAlign: DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE\n                });\n            }\n            // 第一列单元格\n            this.rect({\n                x: this.rowHeadWidth,\n                y,\n                width: columnWidth + AI_TABLE_OFFSET,\n                height: rowHeight,\n                fill: fill,\n                stroke: colors.gray200\n            });\n        } else {\n            // 第一列单元格\n            this.customRect({\n                x: this.rowHeadWidth,\n                y,\n                width: columnWidth + AI_TABLE_OFFSET,\n                height: rowHeight,\n                fill: fill,\n                strokes: {\n                    right: colors.gray200,\n                    bottom: colors.gray200\n                }\n            });\n        }\n\n        if (this.isLast) {\n            this.renderAddFieldBlank({ isHoverRow, isCheckedRow });\n        }\n    }\n\n    // 尾列\n    private renderLastCell({ style, isHoverRow, isCheckedRow }: Pick<AITableCell, 'style' | 'isHoverRow' | 'isCheckedRow'>) {\n        if (!this.isLast || this.isFirst) return;\n        const { fill, stroke } = style;\n        const colors = AITable.getColors();\n\n        // 背景、边框\n        this.rect({\n            x: this.x,\n            y: this.y,\n            width: this.columnWidth,\n            height: this.rowHeight,\n            fill: fill || colors.white,\n            stroke: stroke || colors.gray200\n        });\n\n        this.renderAddFieldBlank({ isHoverRow, isCheckedRow });\n    }\n\n    // 绘制中间的普通单元格\n    private renderCommonCell({ style }: Pick<AITableCell, 'style'>) {\n        if (this.isFirst || this.isLast) return;\n\n        const { fill, stroke } = style;\n        const colors = AITable.getColors();\n\n        // 背景、边框\n        this.rect({\n            x: this.x,\n            y: this.y,\n            width: this.columnWidth,\n            height: this.rowHeight,\n            fill: fill || colors.white,\n            stroke: stroke || colors.gray200\n        });\n    }\n\n    render(config: AITableCell) {\n        const { row, style, isCheckedRow, isHoverRow } = config;\n        this.renderFirstCell({ row, style, isCheckedRow, isHoverRow });\n        this.renderCommonCell({ style });\n        this.renderLastCell({ style, isCheckedRow, isHoverRow });\n    }\n}\n\nexport const recordRowLayout = new RecordRowLayout();\n"]}
@@ -1,7 +1,6 @@
1
1
  import { ChangeDetectionStrategy, Component, computed, input, output } from '@angular/core';
2
2
  import Konva from 'konva';
3
3
  import { KoContainer, KoShape, KoStage } from '../angular-konva';
4
- import { AI_TABLE_ROW_HEAD_WIDTH } from '../constants';
5
4
  import { AITable } from '../core';
6
5
  import { getVisibleRangeInfo } from '../utils';
7
6
  import { AITableAddField, AITableCells, AITableColumnHeads, AITableFrozenCells, AITableFrozenColumnHeads, AITableFrozenPlaceholderCells, AITableHoverRowHeads, AITableOtherRows, AITablePlaceholderCells } from './components';
@@ -26,6 +25,9 @@ export class AITableRenderer {
26
25
  this.readonly = computed(() => {
27
26
  return this.config()?.readonly;
28
27
  });
28
+ this.hiddenIndexColumn = computed(() => {
29
+ return this.config()?.aiTable.context?.aiFieldConfig()?.hiddenIndexColumn;
30
+ });
29
31
  this.rowDragDisabled = computed(() => {
30
32
  return this.config()?.rowDragDisabled;
31
33
  });
@@ -45,7 +47,7 @@ export class AITableRenderer {
45
47
  return getVisibleRangeInfo(this.coordinate(), this.scrollState());
46
48
  });
47
49
  this.frozenAreaWidth = computed(() => {
48
- return AI_TABLE_ROW_HEAD_WIDTH + this.coordinate().frozenColumnWidth;
50
+ return this.config().aiTable.context.rowHeadWidth() + this.coordinate().frozenColumnWidth;
49
51
  });
50
52
  this.lastColumnWidth = computed(() => {
51
53
  return this.coordinate().getColumnWidth(this.visibleRangeInfo().columnStopIndex);
@@ -172,7 +174,7 @@ export class AITableRenderer {
172
174
  this.koMouseleave.emit(e);
173
175
  }
174
176
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableRenderer, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
175
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: AITableRenderer, isStandalone: true, selector: "ai-table-renderer", inputs: { config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { koMousemove: "koMousemove", koMousedown: "koMousedown", koMouseup: "koMouseup", koContextmenu: "koContextmenu", koWheel: "koWheel", koClick: "koClick", koDblclick: "koDblclick", koMouseleave: "koMouseleave" }, ngImport: i0, template: "<ko-stage\n [config]=\"stageConfig()\"\n (koMousemove)=\"stageMousemove($event)\"\n (koMousedown)=\"stageMousedown($event)\"\n (koMouseup)=\"stageMouseup($event)\"\n (koContextmenu)=\"stageContextmenu($event)\"\n (koClick)=\"stageClick($event)\"\n (koDblclick)=\"stageDblclick($event)\"\n (koMouseleave)=\"stageMouseleave($event)\"\n>\n <ko-layer>\n <ko-group [config]=\"gridGroupConfig()\">\n <ko-group [config]=\"offsetYConfig()\">\n <ai-table-frozen-cells [config]=\"cellsConfig()\"></ai-table-frozen-cells>\n <ai-table-other-rows [config]=\"cellsConfig()\"></ai-table-other-rows>\n <ai-table-hover-row-heads [config]=\"cellsConfig()\"></ai-table-hover-row-heads>\n <ai-table-frozen-placeholder-cells [config]=\"cellsConfig()\"></ai-table-frozen-placeholder-cells>\n </ko-group>\n\n <ko-group>\n <ai-table-frozen-column-heads [config]=\"columnHeadOrAddFieldConfig()\"></ai-table-frozen-column-heads>\n </ko-group>\n\n <ko-group [config]=\"commonGroupConfig()\">\n <ko-group [config]=\"offsetConfig()\">\n <ai-table-cells [config]=\"cellsConfig()\"></ai-table-cells>\n </ko-group>\n\n <ko-group [config]=\"offsetXConfig()\">\n <ai-table-column-heads [config]=\"columnHeadOrAddFieldConfig()\"></ai-table-column-heads>\n <ai-table-add-field [config]=\"columnHeadOrAddFieldConfig()\"></ai-table-add-field>\n </ko-group>\n </ko-group>\n\n <ko-group [config]=\"attachGroupConfig()\">\n <ko-group [config]=\"offsetConfig()\">\n <ai-table-placeholder-cells [config]=\"cellsConfig()\"></ai-table-placeholder-cells>\n @if (activeCellBorderConfig().activeCellBorder) {\n <ko-rect [config]=\"activeCellBorderConfig().activeCellBorder!\"></ko-rect>\n }\n <ai-table-hover-cell [config]=\"cellsConfig()\"></ai-table-hover-cell>\n </ko-group>\n </ko-group>\n\n <ko-group [config]=\"frozenAttachGroupConfig()\">\n <ko-group [config]=\"offsetYConfig()\">\n @if (activeCellBorderConfig().frozenActiveCellBorder) {\n <ko-rect [config]=\"activeCellBorderConfig().frozenActiveCellBorder!\"></ko-rect>\n }\n <ai-table-hover-cell [config]=\"cellsConfig()\"></ai-table-hover-cell>\n </ko-group>\n </ko-group>\n </ko-group>\n </ko-layer>\n</ko-stage>\n\n<ng-content></ng-content>\n", dependencies: [{ kind: "component", type: KoContainer, selector: "ko-layer, ko-fastlayer, ko-group" }, { kind: "component", type: KoStage, selector: "ko-stage", inputs: ["config"], outputs: ["koMouseover", "koMousemove", "koMouseout", "koMouseenter", "koMouseleave", "koMousedown", "koMouseup", "koWheel", "koContextmenu", "koClick", "koDblclick", "koTouchstart", "koTouchmove", "koTouchend", "koTap", "koDbltap", "koDragstart", "koDragmove", "koDragend"] }, { kind: "component", type: KoShape, selector: "ko-shape, ko-circle, ko-label, ko-rect, ko-ellipse, ko-wedge, ko-line, ko-sprite, ko-image, ko-text, ko-text-path, ko-star, ko-ring, ko-arc, ko-tag, ko-path, ko-regular-polygon, ko-arrow, ko-transformer", inputs: ["config"], outputs: ["koMouseover", "koMousemove", "koMouseout", "koMouseenter", "koMouseleave", "koMousedown", "koMouseup", "koWheel", "koContextmenu", "koClick", "koDblclick", "koTouchstart", "koTouchmove", "koTouchend", "koTap", "koDbltap", "koDragstart", "koDragmove", "koDragend"] }, { kind: "component", type: AITableColumnHeads, selector: "ai-table-column-heads", inputs: ["config"] }, { kind: "component", type: AITableFrozenColumnHeads, selector: "ai-table-frozen-column-heads", inputs: ["config"] }, { kind: "component", type: AITableCells, selector: "ai-table-cells", inputs: ["config"] }, { kind: "component", type: AITableFrozenCells, selector: "ai-table-frozen-cells", inputs: ["config"] }, { kind: "component", type: AITableFrozenPlaceholderCells, selector: "ai-table-frozen-placeholder-cells", inputs: ["config"] }, { kind: "component", type: AITableHoverCells, selector: "ai-table-hover-cell", inputs: ["config"] }, { kind: "component", type: AITablePlaceholderCells, selector: "ai-table-placeholder-cells", inputs: ["config"] }, { kind: "component", type: AITableAddField, selector: "ai-table-add-field", inputs: ["config"] }, { kind: "component", type: AITableHoverRowHeads, selector: "ai-table-hover-row-heads", inputs: ["config"] }, { kind: "component", type: AITableOtherRows, selector: "ai-table-other-rows", inputs: ["config"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
177
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: AITableRenderer, isStandalone: true, selector: "ai-table-renderer", inputs: { config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { koMousemove: "koMousemove", koMousedown: "koMousedown", koMouseup: "koMouseup", koContextmenu: "koContextmenu", koWheel: "koWheel", koClick: "koClick", koDblclick: "koDblclick", koMouseleave: "koMouseleave" }, ngImport: i0, template: "<ko-stage\n [config]=\"stageConfig()\"\n (koMousemove)=\"stageMousemove($event)\"\n (koMousedown)=\"stageMousedown($event)\"\n (koMouseup)=\"stageMouseup($event)\"\n (koContextmenu)=\"stageContextmenu($event)\"\n (koClick)=\"stageClick($event)\"\n (koDblclick)=\"stageDblclick($event)\"\n (koMouseleave)=\"stageMouseleave($event)\"\n>\n <ko-layer>\n <ko-group [config]=\"gridGroupConfig()\">\n <ko-group [config]=\"offsetYConfig()\">\n <ai-table-frozen-cells [config]=\"cellsConfig()\"></ai-table-frozen-cells>\n <ai-table-other-rows [config]=\"cellsConfig()\"></ai-table-other-rows>\n @if (!hiddenIndexColumn()) {\n <ai-table-hover-row-heads [config]=\"cellsConfig()\"></ai-table-hover-row-heads>\n }\n <ai-table-frozen-placeholder-cells [config]=\"cellsConfig()\"></ai-table-frozen-placeholder-cells>\n </ko-group>\n\n <ko-group>\n <ai-table-frozen-column-heads [config]=\"columnHeadOrAddFieldConfig()\"></ai-table-frozen-column-heads>\n </ko-group>\n\n <ko-group [config]=\"commonGroupConfig()\">\n <ko-group [config]=\"offsetConfig()\">\n <ai-table-cells [config]=\"cellsConfig()\"></ai-table-cells>\n </ko-group>\n\n <ko-group [config]=\"offsetXConfig()\">\n <ai-table-column-heads [config]=\"columnHeadOrAddFieldConfig()\"></ai-table-column-heads>\n <ai-table-add-field [config]=\"columnHeadOrAddFieldConfig()\"></ai-table-add-field>\n </ko-group>\n </ko-group>\n\n <ko-group [config]=\"attachGroupConfig()\">\n <ko-group [config]=\"offsetConfig()\">\n <ai-table-placeholder-cells [config]=\"cellsConfig()\"></ai-table-placeholder-cells>\n @if (activeCellBorderConfig().activeCellBorder) {\n <ko-rect [config]=\"activeCellBorderConfig().activeCellBorder!\"></ko-rect>\n }\n <ai-table-hover-cell [config]=\"cellsConfig()\"></ai-table-hover-cell>\n </ko-group>\n </ko-group>\n\n <ko-group [config]=\"frozenAttachGroupConfig()\">\n <ko-group [config]=\"offsetYConfig()\">\n @if (activeCellBorderConfig().frozenActiveCellBorder) {\n <ko-rect [config]=\"activeCellBorderConfig().frozenActiveCellBorder!\"></ko-rect>\n }\n <ai-table-hover-cell [config]=\"cellsConfig()\"></ai-table-hover-cell>\n </ko-group>\n </ko-group>\n </ko-group>\n </ko-layer>\n</ko-stage>\n\n<ng-content></ng-content>\n", dependencies: [{ kind: "component", type: KoContainer, selector: "ko-layer, ko-fastlayer, ko-group" }, { kind: "component", type: KoStage, selector: "ko-stage", inputs: ["config"], outputs: ["koMouseover", "koMousemove", "koMouseout", "koMouseenter", "koMouseleave", "koMousedown", "koMouseup", "koWheel", "koContextmenu", "koClick", "koDblclick", "koTouchstart", "koTouchmove", "koTouchend", "koTap", "koDbltap", "koDragstart", "koDragmove", "koDragend"] }, { kind: "component", type: KoShape, selector: "ko-shape, ko-circle, ko-label, ko-rect, ko-ellipse, ko-wedge, ko-line, ko-sprite, ko-image, ko-text, ko-text-path, ko-star, ko-ring, ko-arc, ko-tag, ko-path, ko-regular-polygon, ko-arrow, ko-transformer", inputs: ["config"], outputs: ["koMouseover", "koMousemove", "koMouseout", "koMouseenter", "koMouseleave", "koMousedown", "koMouseup", "koWheel", "koContextmenu", "koClick", "koDblclick", "koTouchstart", "koTouchmove", "koTouchend", "koTap", "koDbltap", "koDragstart", "koDragmove", "koDragend"] }, { kind: "component", type: AITableColumnHeads, selector: "ai-table-column-heads", inputs: ["config"] }, { kind: "component", type: AITableFrozenColumnHeads, selector: "ai-table-frozen-column-heads", inputs: ["config"] }, { kind: "component", type: AITableCells, selector: "ai-table-cells", inputs: ["config"] }, { kind: "component", type: AITableFrozenCells, selector: "ai-table-frozen-cells", inputs: ["config"] }, { kind: "component", type: AITableFrozenPlaceholderCells, selector: "ai-table-frozen-placeholder-cells", inputs: ["config"] }, { kind: "component", type: AITableHoverCells, selector: "ai-table-hover-cell", inputs: ["config"] }, { kind: "component", type: AITablePlaceholderCells, selector: "ai-table-placeholder-cells", inputs: ["config"] }, { kind: "component", type: AITableAddField, selector: "ai-table-add-field", inputs: ["config"] }, { kind: "component", type: AITableHoverRowHeads, selector: "ai-table-hover-row-heads", inputs: ["config"] }, { kind: "component", type: AITableOtherRows, selector: "ai-table-other-rows", inputs: ["config"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
176
178
  }
177
179
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableRenderer, decorators: [{
178
180
  type: Component,
@@ -190,6 +192,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
190
192
  AITableAddField,
191
193
  AITableHoverRowHeads,
192
194
  AITableOtherRows
193
- ], changeDetection: ChangeDetectionStrategy.OnPush, template: "<ko-stage\n [config]=\"stageConfig()\"\n (koMousemove)=\"stageMousemove($event)\"\n (koMousedown)=\"stageMousedown($event)\"\n (koMouseup)=\"stageMouseup($event)\"\n (koContextmenu)=\"stageContextmenu($event)\"\n (koClick)=\"stageClick($event)\"\n (koDblclick)=\"stageDblclick($event)\"\n (koMouseleave)=\"stageMouseleave($event)\"\n>\n <ko-layer>\n <ko-group [config]=\"gridGroupConfig()\">\n <ko-group [config]=\"offsetYConfig()\">\n <ai-table-frozen-cells [config]=\"cellsConfig()\"></ai-table-frozen-cells>\n <ai-table-other-rows [config]=\"cellsConfig()\"></ai-table-other-rows>\n <ai-table-hover-row-heads [config]=\"cellsConfig()\"></ai-table-hover-row-heads>\n <ai-table-frozen-placeholder-cells [config]=\"cellsConfig()\"></ai-table-frozen-placeholder-cells>\n </ko-group>\n\n <ko-group>\n <ai-table-frozen-column-heads [config]=\"columnHeadOrAddFieldConfig()\"></ai-table-frozen-column-heads>\n </ko-group>\n\n <ko-group [config]=\"commonGroupConfig()\">\n <ko-group [config]=\"offsetConfig()\">\n <ai-table-cells [config]=\"cellsConfig()\"></ai-table-cells>\n </ko-group>\n\n <ko-group [config]=\"offsetXConfig()\">\n <ai-table-column-heads [config]=\"columnHeadOrAddFieldConfig()\"></ai-table-column-heads>\n <ai-table-add-field [config]=\"columnHeadOrAddFieldConfig()\"></ai-table-add-field>\n </ko-group>\n </ko-group>\n\n <ko-group [config]=\"attachGroupConfig()\">\n <ko-group [config]=\"offsetConfig()\">\n <ai-table-placeholder-cells [config]=\"cellsConfig()\"></ai-table-placeholder-cells>\n @if (activeCellBorderConfig().activeCellBorder) {\n <ko-rect [config]=\"activeCellBorderConfig().activeCellBorder!\"></ko-rect>\n }\n <ai-table-hover-cell [config]=\"cellsConfig()\"></ai-table-hover-cell>\n </ko-group>\n </ko-group>\n\n <ko-group [config]=\"frozenAttachGroupConfig()\">\n <ko-group [config]=\"offsetYConfig()\">\n @if (activeCellBorderConfig().frozenActiveCellBorder) {\n <ko-rect [config]=\"activeCellBorderConfig().frozenActiveCellBorder!\"></ko-rect>\n }\n <ai-table-hover-cell [config]=\"cellsConfig()\"></ai-table-hover-cell>\n </ko-group>\n </ko-group>\n </ko-group>\n </ko-layer>\n</ko-stage>\n\n<ng-content></ng-content>\n" }]
195
+ ], changeDetection: ChangeDetectionStrategy.OnPush, template: "<ko-stage\n [config]=\"stageConfig()\"\n (koMousemove)=\"stageMousemove($event)\"\n (koMousedown)=\"stageMousedown($event)\"\n (koMouseup)=\"stageMouseup($event)\"\n (koContextmenu)=\"stageContextmenu($event)\"\n (koClick)=\"stageClick($event)\"\n (koDblclick)=\"stageDblclick($event)\"\n (koMouseleave)=\"stageMouseleave($event)\"\n>\n <ko-layer>\n <ko-group [config]=\"gridGroupConfig()\">\n <ko-group [config]=\"offsetYConfig()\">\n <ai-table-frozen-cells [config]=\"cellsConfig()\"></ai-table-frozen-cells>\n <ai-table-other-rows [config]=\"cellsConfig()\"></ai-table-other-rows>\n @if (!hiddenIndexColumn()) {\n <ai-table-hover-row-heads [config]=\"cellsConfig()\"></ai-table-hover-row-heads>\n }\n <ai-table-frozen-placeholder-cells [config]=\"cellsConfig()\"></ai-table-frozen-placeholder-cells>\n </ko-group>\n\n <ko-group>\n <ai-table-frozen-column-heads [config]=\"columnHeadOrAddFieldConfig()\"></ai-table-frozen-column-heads>\n </ko-group>\n\n <ko-group [config]=\"commonGroupConfig()\">\n <ko-group [config]=\"offsetConfig()\">\n <ai-table-cells [config]=\"cellsConfig()\"></ai-table-cells>\n </ko-group>\n\n <ko-group [config]=\"offsetXConfig()\">\n <ai-table-column-heads [config]=\"columnHeadOrAddFieldConfig()\"></ai-table-column-heads>\n <ai-table-add-field [config]=\"columnHeadOrAddFieldConfig()\"></ai-table-add-field>\n </ko-group>\n </ko-group>\n\n <ko-group [config]=\"attachGroupConfig()\">\n <ko-group [config]=\"offsetConfig()\">\n <ai-table-placeholder-cells [config]=\"cellsConfig()\"></ai-table-placeholder-cells>\n @if (activeCellBorderConfig().activeCellBorder) {\n <ko-rect [config]=\"activeCellBorderConfig().activeCellBorder!\"></ko-rect>\n }\n <ai-table-hover-cell [config]=\"cellsConfig()\"></ai-table-hover-cell>\n </ko-group>\n </ko-group>\n\n <ko-group [config]=\"frozenAttachGroupConfig()\">\n <ko-group [config]=\"offsetYConfig()\">\n @if (activeCellBorderConfig().frozenActiveCellBorder) {\n <ko-rect [config]=\"activeCellBorderConfig().frozenActiveCellBorder!\"></ko-rect>\n }\n <ai-table-hover-cell [config]=\"cellsConfig()\"></ai-table-hover-cell>\n </ko-group>\n </ko-group>\n </ko-group>\n </ko-layer>\n</ko-stage>\n\n<ng-content></ng-content>\n" }]
194
196
  }] });
195
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"renderer.component.js","sourceRoot":"","sources":["../../../../packages/grid/src/renderer/renderer.component.ts","../../../../packages/grid/src/renderer/renderer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input, output } from '@angular/core';\nimport Konva from 'konva';\nimport { StageConfig } from 'konva/lib/Stage';\nimport { KoContainer, KoEventObject, KoShape, KoStage } from '../angular-konva';\nimport { AI_TABLE_ROW_HEAD_WIDTH } from '../constants';\nimport { AITable } from '../core';\nimport { AITableCellsConfig, AITableRendererConfig } from '../types';\nimport { getVisibleRangeInfo } from '../utils';\nimport {\n    AITableAddField,\n    AITableCells,\n    AITableColumnHeads,\n    AITableFrozenCells,\n    AITableFrozenColumnHeads,\n    AITableFrozenPlaceholderCells,\n    AITableHoverRowHeads,\n    AITableOtherRows,\n    AITablePlaceholderCells\n} from './components';\nimport { createActiveCellBorder } from './creations/create-active-cell-border';\nimport { AITableHoverCells } from './components/hover-cell.component';\n\nKonva.pixelRatio = 2;\n\n@Component({\n    selector: 'ai-table-renderer',\n    templateUrl: './renderer.component.html',\n    standalone: true,\n    imports: [\n        KoContainer,\n        KoStage,\n        KoShape,\n        AITableColumnHeads,\n        AITableFrozenColumnHeads,\n        AITableCells,\n        AITableFrozenCells,\n        AITableFrozenPlaceholderCells,\n        AITableHoverCells,\n        AITablePlaceholderCells,\n        AITableAddField,\n        AITableHoverRowHeads,\n        AITableOtherRows\n    ],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableRenderer {\n    config = input.required<AITableRendererConfig>();\n\n    koMousemove = output<KoEventObject<MouseEvent>>();\n\n    koMousedown = output<KoEventObject<MouseEvent>>();\n\n    koMouseup = output<KoEventObject<MouseEvent>>();\n\n    koContextmenu = output<KoEventObject<MouseEvent>>();\n\n    koWheel = output<KoEventObject<WheelEvent>>();\n\n    koClick = output<KoEventObject<MouseEvent>>();\n\n    koDblclick = output<KoEventObject<MouseEvent>>();\n\n    koMouseleave = output<KoEventObject<MouseEvent>>();\n\n    fields = computed(() => {\n        return AITable.getVisibleFields(this.config().aiTable);\n    });\n\n    readonly = computed(() => {\n        return this.config()?.readonly;\n    });\n\n    rowDragDisabled = computed(() => {\n        return this.config()?.rowDragDisabled;\n    });\n\n    coordinate = computed(() => {\n        return this.config()?.coordinate;\n    });\n\n    containerWidth = computed<number>(() => {\n        return this.config().containerWidth;\n    });\n\n    containerHeight = computed<number>(() => {\n        return this.config().containerHeight;\n    });\n\n    scrollState = computed(() => {\n        return this.config()?.aiTable!.context!.scrollState();\n    });\n\n    visibleRangeInfo = computed(() => {\n        return getVisibleRangeInfo(this.coordinate()!, this.scrollState()!);\n    });\n\n    frozenAreaWidth = computed(() => {\n        return AI_TABLE_ROW_HEAD_WIDTH + this.coordinate()!.frozenColumnWidth!;\n    });\n\n    lastColumnWidth = computed(() => {\n        return this.coordinate()!.getColumnWidth(this.visibleRangeInfo().columnStopIndex);\n    });\n\n    lastColumnOffset = computed(() => {\n        return this.coordinate()!.getColumnOffset(this.visibleRangeInfo().columnStopIndex);\n    });\n\n    cellGroupClipWidth = computed(() => {\n        return this.containerWidth() - this.frozenAreaWidth();\n    });\n\n    stageConfig = computed<Partial<StageConfig>>(() => {\n        const { isScrolling } = this.scrollState()!;\n        return {\n            width: this.containerWidth(),\n            height: this.containerHeight(),\n            listening: isScrolling ? false : true\n        };\n    });\n\n    gridGroupConfig = computed<Partial<StageConfig>>(() => {\n        return {\n            clipX: 0,\n            clipY: 0,\n            clipWidth: this.containerWidth(),\n            clipHeight: this.containerHeight()\n        };\n    });\n\n    commonGroupConfig = computed<Partial<StageConfig>>(() => {\n        return {\n            clipX: this.frozenAreaWidth() + 1,\n            clipY: 0,\n            clipWidth: this.cellGroupClipWidth(),\n            clipHeight: this.containerHeight()\n        };\n    });\n\n    attachGroupConfig = computed<Partial<StageConfig>>(() => {\n        return {\n            clipX: this.frozenAreaWidth() - 1,\n            clipY: this.coordinate()!.rowInitSize - 1,\n            clipWidth: this.containerWidth() - this.frozenAreaWidth(),\n            clipHeight: this.containerHeight() - this.coordinate()!.rowInitSize\n        };\n    });\n\n    frozenAttachGroupConfig = computed<Partial<StageConfig>>(() => {\n        return {\n            clipX: 0,\n            clipY: this.coordinate()!.rowInitSize - 1,\n            clipWidth: this.frozenAreaWidth() + 4,\n            clipHeight: this.containerHeight() - this.coordinate()!.rowInitSize\n        };\n    });\n\n    offsetYConfig = computed<Partial<StageConfig>>(() => {\n        const { scrollTop } = this.scrollState()!;\n        return {\n            offsetY: scrollTop\n        };\n    });\n\n    offsetXConfig = computed<Partial<StageConfig>>(() => {\n        const { scrollLeft } = this.scrollState()!;\n        return {\n            offsetX: scrollLeft\n        };\n    });\n\n    offsetConfig = computed<Partial<StageConfig>>(() => {\n        const { scrollLeft, scrollTop } = this.scrollState()!;\n        return {\n            offsetX: scrollLeft,\n            offsetY: scrollTop\n        };\n    });\n\n    columnHeadOrAddFieldConfig = computed(() => {\n        const { columnStartIndex, columnStopIndex } = this.visibleRangeInfo();\n        const { aiTable, coordinate, readonly } = this.config();\n        const { pointPosition } = aiTable.context!;\n        const fields = this.fields();\n        return {\n            aiTable,\n            coordinate,\n            fields,\n            columnStartIndex,\n            columnStopIndex,\n            pointPosition: pointPosition(),\n            readonly\n        };\n    });\n\n    cellsConfig = computed<AITableCellsConfig>(() => {\n        const { aiTable, readonly, coordinate, references, actions, rowDragDisabled } = this.config();\n        const { rowStartIndex, rowStopIndex, columnStartIndex, columnStopIndex } = this.visibleRangeInfo();\n        return {\n            aiTable,\n            readonly,\n            coordinate,\n            references,\n            rowStartIndex,\n            rowStopIndex,\n            columnStartIndex,\n            columnStopIndex,\n            actions,\n            rowDragDisabled\n        };\n    });\n\n    activeCellBorderConfig = computed(() => {\n        return createActiveCellBorder(this.cellsConfig());\n    });\n\n    stageMousemove(e: KoEventObject<MouseEvent>) {\n        this.koMousemove.emit(e as KoEventObject<MouseEvent>);\n    }\n\n    stageMousedown(e: KoEventObject<MouseEvent>) {\n        this.koMousedown.emit(e as KoEventObject<MouseEvent>);\n    }\n\n    stageMouseup(e: KoEventObject<MouseEvent>) {\n        this.koMouseup.emit(e as KoEventObject<MouseEvent>);\n    }\n\n    stageContextmenu(e: KoEventObject<MouseEvent>) {\n        this.koContextmenu.emit(e as KoEventObject<MouseEvent>);\n    }\n\n    stageClick(e: KoEventObject<MouseEvent>) {\n        this.koClick.emit(e as KoEventObject<MouseEvent>);\n    }\n\n    stageDblclick(e: KoEventObject<MouseEvent>) {\n        this.koDblclick.emit(e as KoEventObject<MouseEvent>);\n    }\n\n    stageMouseleave(e: KoEventObject<MouseEvent>) {\n        this.koMouseleave.emit(e as KoEventObject<MouseEvent>);\n    }\n}\n","<ko-stage\n    [config]=\"stageConfig()\"\n    (koMousemove)=\"stageMousemove($event)\"\n    (koMousedown)=\"stageMousedown($event)\"\n    (koMouseup)=\"stageMouseup($event)\"\n    (koContextmenu)=\"stageContextmenu($event)\"\n    (koClick)=\"stageClick($event)\"\n    (koDblclick)=\"stageDblclick($event)\"\n    (koMouseleave)=\"stageMouseleave($event)\"\n>\n    <ko-layer>\n        <ko-group [config]=\"gridGroupConfig()\">\n            <ko-group [config]=\"offsetYConfig()\">\n                <ai-table-frozen-cells [config]=\"cellsConfig()\"></ai-table-frozen-cells>\n                <ai-table-other-rows [config]=\"cellsConfig()\"></ai-table-other-rows>\n                <ai-table-hover-row-heads [config]=\"cellsConfig()\"></ai-table-hover-row-heads>\n                <ai-table-frozen-placeholder-cells [config]=\"cellsConfig()\"></ai-table-frozen-placeholder-cells>\n            </ko-group>\n\n            <ko-group>\n                <ai-table-frozen-column-heads [config]=\"columnHeadOrAddFieldConfig()\"></ai-table-frozen-column-heads>\n            </ko-group>\n\n            <ko-group [config]=\"commonGroupConfig()\">\n                <ko-group [config]=\"offsetConfig()\">\n                    <ai-table-cells [config]=\"cellsConfig()\"></ai-table-cells>\n                </ko-group>\n\n                <ko-group [config]=\"offsetXConfig()\">\n                    <ai-table-column-heads [config]=\"columnHeadOrAddFieldConfig()\"></ai-table-column-heads>\n                    <ai-table-add-field [config]=\"columnHeadOrAddFieldConfig()\"></ai-table-add-field>\n                </ko-group>\n            </ko-group>\n\n            <ko-group [config]=\"attachGroupConfig()\">\n                <ko-group [config]=\"offsetConfig()\">\n                    <ai-table-placeholder-cells [config]=\"cellsConfig()\"></ai-table-placeholder-cells>\n                    @if (activeCellBorderConfig().activeCellBorder) {\n                        <ko-rect [config]=\"activeCellBorderConfig().activeCellBorder!\"></ko-rect>\n                    }\n                    <ai-table-hover-cell [config]=\"cellsConfig()\"></ai-table-hover-cell>\n                </ko-group>\n            </ko-group>\n\n            <ko-group [config]=\"frozenAttachGroupConfig()\">\n                <ko-group [config]=\"offsetYConfig()\">\n                    @if (activeCellBorderConfig().frozenActiveCellBorder) {\n                        <ko-rect [config]=\"activeCellBorderConfig().frozenActiveCellBorder!\"></ko-rect>\n                    }\n                    <ai-table-hover-cell [config]=\"cellsConfig()\"></ai-table-hover-cell>\n                </ko-group>\n            </ko-group>\n        </ko-group>\n    </ko-layer>\n</ko-stage>\n\n<ng-content></ng-content>\n"]}
197
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"renderer.component.js","sourceRoot":"","sources":["../../../../packages/grid/src/renderer/renderer.component.ts","../../../../packages/grid/src/renderer/renderer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input, output } from '@angular/core';\nimport Konva from 'konva';\nimport { StageConfig } from 'konva/lib/Stage';\nimport { KoContainer, KoEventObject, KoShape, KoStage } from '../angular-konva';\nimport { AITable } from '../core';\nimport { AITableCellsConfig, AITableRendererConfig } from '../types';\nimport { getVisibleRangeInfo } from '../utils';\nimport {\n    AITableAddField,\n    AITableCells,\n    AITableColumnHeads,\n    AITableFrozenCells,\n    AITableFrozenColumnHeads,\n    AITableFrozenPlaceholderCells,\n    AITableHoverRowHeads,\n    AITableOtherRows,\n    AITablePlaceholderCells\n} from './components';\nimport { createActiveCellBorder } from './creations/create-active-cell-border';\nimport { AITableHoverCells } from './components/hover-cell.component';\n\nKonva.pixelRatio = 2;\n\n@Component({\n    selector: 'ai-table-renderer',\n    templateUrl: './renderer.component.html',\n    standalone: true,\n    imports: [\n        KoContainer,\n        KoStage,\n        KoShape,\n        AITableColumnHeads,\n        AITableFrozenColumnHeads,\n        AITableCells,\n        AITableFrozenCells,\n        AITableFrozenPlaceholderCells,\n        AITableHoverCells,\n        AITablePlaceholderCells,\n        AITableAddField,\n        AITableHoverRowHeads,\n        AITableOtherRows\n    ],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableRenderer {\n    config = input.required<AITableRendererConfig>();\n\n    koMousemove = output<KoEventObject<MouseEvent>>();\n\n    koMousedown = output<KoEventObject<MouseEvent>>();\n\n    koMouseup = output<KoEventObject<MouseEvent>>();\n\n    koContextmenu = output<KoEventObject<MouseEvent>>();\n\n    koWheel = output<KoEventObject<WheelEvent>>();\n\n    koClick = output<KoEventObject<MouseEvent>>();\n\n    koDblclick = output<KoEventObject<MouseEvent>>();\n\n    koMouseleave = output<KoEventObject<MouseEvent>>();\n\n    fields = computed(() => {\n        return AITable.getVisibleFields(this.config().aiTable);\n    });\n\n    readonly = computed(() => {\n        return this.config()?.readonly;\n    });\n\n    hiddenIndexColumn = computed(() => {\n        return this.config()?.aiTable.context?.aiFieldConfig()?.hiddenIndexColumn;\n    });\n\n    rowDragDisabled = computed(() => {\n        return this.config()?.rowDragDisabled;\n    });\n\n    coordinate = computed(() => {\n        return this.config()?.coordinate;\n    });\n\n    containerWidth = computed<number>(() => {\n        return this.config().containerWidth;\n    });\n\n    containerHeight = computed<number>(() => {\n        return this.config().containerHeight;\n    });\n\n    scrollState = computed(() => {\n        return this.config()?.aiTable!.context!.scrollState();\n    });\n\n    visibleRangeInfo = computed(() => {\n        return getVisibleRangeInfo(this.coordinate()!, this.scrollState()!);\n    });\n\n    frozenAreaWidth = computed(() => {\n        return this.config().aiTable!.context!.rowHeadWidth() + this.coordinate()!.frozenColumnWidth!;\n    });\n\n    lastColumnWidth = computed(() => {\n        return this.coordinate()!.getColumnWidth(this.visibleRangeInfo().columnStopIndex);\n    });\n\n    lastColumnOffset = computed(() => {\n        return this.coordinate()!.getColumnOffset(this.visibleRangeInfo().columnStopIndex);\n    });\n\n    cellGroupClipWidth = computed(() => {\n        return this.containerWidth() - this.frozenAreaWidth();\n    });\n\n    stageConfig = computed<Partial<StageConfig>>(() => {\n        const { isScrolling } = this.scrollState()!;\n        return {\n            width: this.containerWidth(),\n            height: this.containerHeight(),\n            listening: isScrolling ? false : true\n        };\n    });\n\n    gridGroupConfig = computed<Partial<StageConfig>>(() => {\n        return {\n            clipX: 0,\n            clipY: 0,\n            clipWidth: this.containerWidth(),\n            clipHeight: this.containerHeight()\n        };\n    });\n\n    commonGroupConfig = computed<Partial<StageConfig>>(() => {\n        return {\n            clipX: this.frozenAreaWidth() + 1,\n            clipY: 0,\n            clipWidth: this.cellGroupClipWidth(),\n            clipHeight: this.containerHeight()\n        };\n    });\n\n    attachGroupConfig = computed<Partial<StageConfig>>(() => {\n        return {\n            clipX: this.frozenAreaWidth() - 1,\n            clipY: this.coordinate()!.rowInitSize - 1,\n            clipWidth: this.containerWidth() - this.frozenAreaWidth(),\n            clipHeight: this.containerHeight() - this.coordinate()!.rowInitSize\n        };\n    });\n\n    frozenAttachGroupConfig = computed<Partial<StageConfig>>(() => {\n        return {\n            clipX: 0,\n            clipY: this.coordinate()!.rowInitSize - 1,\n            clipWidth: this.frozenAreaWidth() + 4,\n            clipHeight: this.containerHeight() - this.coordinate()!.rowInitSize\n        };\n    });\n\n    offsetYConfig = computed<Partial<StageConfig>>(() => {\n        const { scrollTop } = this.scrollState()!;\n        return {\n            offsetY: scrollTop\n        };\n    });\n\n    offsetXConfig = computed<Partial<StageConfig>>(() => {\n        const { scrollLeft } = this.scrollState()!;\n        return {\n            offsetX: scrollLeft\n        };\n    });\n\n    offsetConfig = computed<Partial<StageConfig>>(() => {\n        const { scrollLeft, scrollTop } = this.scrollState()!;\n        return {\n            offsetX: scrollLeft,\n            offsetY: scrollTop\n        };\n    });\n\n    columnHeadOrAddFieldConfig = computed(() => {\n        const { columnStartIndex, columnStopIndex } = this.visibleRangeInfo();\n        const { aiTable, coordinate, readonly } = this.config();\n        const { pointPosition } = aiTable.context!;\n        const fields = this.fields();\n        return {\n            aiTable,\n            coordinate,\n            fields,\n            columnStartIndex,\n            columnStopIndex,\n            pointPosition: pointPosition(),\n            readonly\n        };\n    });\n\n    cellsConfig = computed<AITableCellsConfig>(() => {\n        const { aiTable, readonly, coordinate, references, actions, rowDragDisabled } = this.config();\n        const { rowStartIndex, rowStopIndex, columnStartIndex, columnStopIndex } = this.visibleRangeInfo();\n        return {\n            aiTable,\n            readonly,\n            coordinate,\n            references,\n            rowStartIndex,\n            rowStopIndex,\n            columnStartIndex,\n            columnStopIndex,\n            actions,\n            rowDragDisabled\n        };\n    });\n\n    activeCellBorderConfig = computed(() => {\n        return createActiveCellBorder(this.cellsConfig());\n    });\n\n    stageMousemove(e: KoEventObject<MouseEvent>) {\n        this.koMousemove.emit(e as KoEventObject<MouseEvent>);\n    }\n\n    stageMousedown(e: KoEventObject<MouseEvent>) {\n        this.koMousedown.emit(e as KoEventObject<MouseEvent>);\n    }\n\n    stageMouseup(e: KoEventObject<MouseEvent>) {\n        this.koMouseup.emit(e as KoEventObject<MouseEvent>);\n    }\n\n    stageContextmenu(e: KoEventObject<MouseEvent>) {\n        this.koContextmenu.emit(e as KoEventObject<MouseEvent>);\n    }\n\n    stageClick(e: KoEventObject<MouseEvent>) {\n        this.koClick.emit(e as KoEventObject<MouseEvent>);\n    }\n\n    stageDblclick(e: KoEventObject<MouseEvent>) {\n        this.koDblclick.emit(e as KoEventObject<MouseEvent>);\n    }\n\n    stageMouseleave(e: KoEventObject<MouseEvent>) {\n        this.koMouseleave.emit(e as KoEventObject<MouseEvent>);\n    }\n}\n","<ko-stage\n    [config]=\"stageConfig()\"\n    (koMousemove)=\"stageMousemove($event)\"\n    (koMousedown)=\"stageMousedown($event)\"\n    (koMouseup)=\"stageMouseup($event)\"\n    (koContextmenu)=\"stageContextmenu($event)\"\n    (koClick)=\"stageClick($event)\"\n    (koDblclick)=\"stageDblclick($event)\"\n    (koMouseleave)=\"stageMouseleave($event)\"\n>\n    <ko-layer>\n        <ko-group [config]=\"gridGroupConfig()\">\n            <ko-group [config]=\"offsetYConfig()\">\n                <ai-table-frozen-cells [config]=\"cellsConfig()\"></ai-table-frozen-cells>\n                <ai-table-other-rows [config]=\"cellsConfig()\"></ai-table-other-rows>\n                @if (!hiddenIndexColumn()) {\n                    <ai-table-hover-row-heads [config]=\"cellsConfig()\"></ai-table-hover-row-heads>\n                }\n                <ai-table-frozen-placeholder-cells [config]=\"cellsConfig()\"></ai-table-frozen-placeholder-cells>\n            </ko-group>\n\n            <ko-group>\n                <ai-table-frozen-column-heads [config]=\"columnHeadOrAddFieldConfig()\"></ai-table-frozen-column-heads>\n            </ko-group>\n\n            <ko-group [config]=\"commonGroupConfig()\">\n                <ko-group [config]=\"offsetConfig()\">\n                    <ai-table-cells [config]=\"cellsConfig()\"></ai-table-cells>\n                </ko-group>\n\n                <ko-group [config]=\"offsetXConfig()\">\n                    <ai-table-column-heads [config]=\"columnHeadOrAddFieldConfig()\"></ai-table-column-heads>\n                    <ai-table-add-field [config]=\"columnHeadOrAddFieldConfig()\"></ai-table-add-field>\n                </ko-group>\n            </ko-group>\n\n            <ko-group [config]=\"attachGroupConfig()\">\n                <ko-group [config]=\"offsetConfig()\">\n                    <ai-table-placeholder-cells [config]=\"cellsConfig()\"></ai-table-placeholder-cells>\n                    @if (activeCellBorderConfig().activeCellBorder) {\n                        <ko-rect [config]=\"activeCellBorderConfig().activeCellBorder!\"></ko-rect>\n                    }\n                    <ai-table-hover-cell [config]=\"cellsConfig()\"></ai-table-hover-cell>\n                </ko-group>\n            </ko-group>\n\n            <ko-group [config]=\"frozenAttachGroupConfig()\">\n                <ko-group [config]=\"offsetYConfig()\">\n                    @if (activeCellBorderConfig().frozenActiveCellBorder) {\n                        <ko-rect [config]=\"activeCellBorderConfig().frozenActiveCellBorder!\"></ko-rect>\n                    }\n                    <ai-table-hover-cell [config]=\"cellsConfig()\"></ai-table-hover-cell>\n                </ko-group>\n            </ko-group>\n        </ko-group>\n    </ko-layer>\n</ko-stage>\n\n<ng-content></ng-content>\n"]}
@@ -14,4 +14,4 @@ export var AITableSelectAllState;
14
14
  AITableSelectAllState["partial"] = "partial";
15
15
  AITableSelectAllState["none"] = "none";
16
16
  })(AITableSelectAllState || (AITableSelectAllState = {}));
17
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JpZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL2dyaWQvc3JjL3R5cGVzL2dyaWQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMERBLE1BQU0sQ0FBTixJQUFZLGdCQUdYO0FBSEQsV0FBWSxnQkFBZ0I7SUFDeEIsdUNBQW1CLENBQUE7SUFDbkIsMkNBQXVCLENBQUE7QUFDM0IsQ0FBQyxFQUhXLGdCQUFnQixLQUFoQixnQkFBZ0IsUUFHM0I7QUFlRCxNQUFNLENBQU4sSUFBWSxlQUdYO0FBSEQsV0FBWSxlQUFlO0lBQ3ZCLGdDQUFhLENBQUE7SUFDYixnQ0FBYSxDQUFBO0FBQ2pCLENBQUMsRUFIVyxlQUFlLEtBQWYsZUFBZSxRQUcxQjtBQTRDRCxNQUFNLENBQU4sSUFBWSxxQkFJWDtBQUpELFdBQVkscUJBQXFCO0lBQzdCLG9DQUFXLENBQUE7SUFDWCw0Q0FBbUIsQ0FBQTtJQUNuQixzQ0FBYSxDQUFBO0FBQ2pCLENBQUMsRUFKVyxxQkFBcUIsS0FBckIscUJBQXFCLFFBSWhDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2lnbmFsLCBWaWV3Q29udGFpbmVyUmVmLCBXcml0YWJsZVNpZ25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBBSVRhYmxlRmllbGRNZW51SXRlbSB9IGZyb20gJy4vZmllbGQnO1xuaW1wb3J0IHsgQUlUYWJsZUxpbmVhclJvdyB9IGZyb20gJy4vcm93JztcbmltcG9ydCB7XG4gICAgQUlUYWJsZUZpZWxkLFxuICAgIEFJVGFibGVSZWNvcmQsXG4gICAgRmllbGRWYWx1ZSxcbiAgICBBSVRhYmxlRmllbGRzLFxuICAgIEFJUmVjb3JkRmllbGRJZFBhdGgsXG4gICAgQUlUYWJsZUZpZWxkVHlwZSxcbiAgICBVcGRhdGVGaWVsZFZhbHVlT3B0aW9ucyxcbiAgICBBSVRhYmxlUmVmZXJlbmNlc1xufSBmcm9tICdAYWktdGFibGUvdXRpbHMnO1xuaW1wb3J0IHsgQUlUYWJsZSwgQ29vcmRpbmF0ZSB9IGZyb20gJy4uL2NvcmUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIEFJVGFibGVHcmlkQ2VsbFJlbmRlclNjaGVtYSB7XG4gICAgZWRpdG9yPzogYW55O1xuICAgIHRyYW5zZm9ybT86IChmaWVsZDogQUlUYWJsZUZpZWxkLCB2YWx1ZTogRmllbGRWYWx1ZSkgPT4gYW55O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFJVGFibGVDb250ZW50IHtcbiAgICByZWNvcmRzOiBQYXJ0aWFsPEFJVGFibGVSZWNvcmQ+W107XG4gICAgZmllbGRzOiBBSVRhYmxlRmllbGRzO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFJVGFibGVHcmlkRGF0YSBleHRlbmRzIEFJVGFibGVDb250ZW50IHtcbiAgICB0eXBlOiAnZ3JpZCc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQUlUYWJsZVNlbGVjdGlvbiB7XG4gICAgc2VsZWN0ZWRSZWNvcmRzOiBTZXQ8c3RyaW5nPjsgLy8gYCR7cmVjb3JkSWR9YFxuICAgIHNlbGVjdGVkRmllbGRzOiBTZXQ8c3RyaW5nPjsgLy8gYCR7ZmllbGRJZH1gXG4gICAgc2VsZWN0ZWRDZWxsczogU2V0PHN0cmluZz47IC8vIGAke3JlY29yZElkfToke2ZpZWxkSWR9YFxuICAgIGFjdGl2ZUNlbGw6IEFJUmVjb3JkRmllbGRJZFBhdGggfCBudWxsO1xuICAgIHNlbGVjdEFsbFN0YXRlOiBBSVRhYmxlU2VsZWN0QWxsU3RhdGU7IC8vICdhbGwnLCdwYXJ0aWFsJywnbm9uZSdcbn1cblxuZXhwb3J0IGludGVyZmFjZSBBSUZpZWxkQ29uZmlnIHtcbiAgICBmaWVsZFJlbmRlcmVycz86IFBhcnRpYWw8UmVjb3JkPEFJVGFibGVGaWVsZFR5cGUsIEFJVGFibGVHcmlkQ2VsbFJlbmRlclNjaGVtYT4+O1xuICAgIGZpZWxkU2V0dGluZ0NvbXBvbmVudD86IGFueTtcbiAgICBmaWVsZE1lbnVzPzogKGFpVGFibGU6IEFJVGFibGUpID0+IEFJVGFibGVGaWVsZE1lbnVJdGVtW107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQUlUYWJsZVJlbmRlcmVyQ29uZmlnIHtcbiAgICBhaVRhYmxlOiBBSVRhYmxlO1xuICAgIGNvbnRhaW5lcjogSFRNTERpdkVsZW1lbnQ7XG4gICAgY29vcmRpbmF0ZTogQ29vcmRpbmF0ZTtcbiAgICBjb250YWluZXJXaWR0aDogbnVtYmVyO1xuICAgIGNvbnRhaW5lckhlaWdodDogbnVtYmVyO1xuICAgIHJlZmVyZW5jZXM6IEFJVGFibGVSZWZlcmVuY2VzO1xuICAgIHJlYWRvbmx5OiBib29sZWFuO1xuICAgIHJvd0RyYWdEaXNhYmxlZDogYm9vbGVhbjtcbiAgICBhY3Rpb25zOiB7XG4gICAgICAgIHVwZGF0ZUZpZWxkVmFsdWU6IChvcHRpb25zOiBVcGRhdGVGaWVsZFZhbHVlT3B0aW9ucykgPT4gdm9pZDtcbiAgICB9O1xufVxuXG5leHBvcnQgZW51bSBBSVRhYmxlQ2hlY2tUeXBlIHtcbiAgICBjaGVja2VkID0gJ2NoZWNrZWQnLFxuICAgIHVuY2hlY2tlZCA9ICd1bmNoZWNrZWQnXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQUlUYWJsZVNjcm9sbFN0YXRlIHtcbiAgICBzY3JvbGxUb3A6IG51bWJlcjtcbiAgICBzY3JvbGxMZWZ0OiBudW1iZXI7XG4gICAgaXNTY3JvbGxpbmc6IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2Nyb2xsQWN0aW9uT3B0aW9ucyB7XG4gICAgZGVsdGFYOiBudW1iZXI7XG4gICAgZGVsdGFZOiBudW1iZXI7XG4gICAgc2hpZnRLZXk6IGJvb2xlYW47XG4gICAgY2FsbGJhY2s/OiAoKSA9PiB2b2lkO1xufVxuXG5leHBvcnQgZW51bSBBSVRhYmxlQXJlYVR5cGUge1xuICAgIGdyaWQgPSAnZ3JpZCcsXG4gICAgbm9uZSA9ICdub25lJ1xufVxuXG5leHBvcnQgdHlwZSBBSVRhYmxlUG9pbnRQb3NpdGlvbiA9IHtcbiAgICB4OiBudW1iZXI7XG4gICAgeTogbnVtYmVyO1xuICAgIGFyZWFUeXBlOiBBSVRhYmxlQXJlYVR5cGU7XG4gICAgdGFyZ2V0TmFtZTogc3RyaW5nO1xuICAgIHJlYWxUYXJnZXROYW1lOiBzdHJpbmc7XG4gICAgcm93SW5kZXg6IG51bWJlcjtcbiAgICBjb2x1bW5JbmRleDogbnVtYmVyO1xuICAgIG9mZnNldFRvcDogbnVtYmVyO1xuICAgIG9mZnNldExlZnQ6IG51bWJlcjtcbn07XG5cbmV4cG9ydCBpbnRlcmZhY2UgQUlUYWJsZUVkaXRQb3NpdGlvbiB7XG4gICAgeDogbnVtYmVyO1xuICAgIHk6IG51bWJlcjtcbiAgICB3aWR0aDogbnVtYmVyO1xuICAgIGhlaWdodDogbnVtYmVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFJVGFibGVPcGVuRWRpdE9wdGlvbnMge1xuICAgIHJlY29yZElkOiBzdHJpbmc7XG4gICAgZmllbGRJZDogc3RyaW5nO1xuICAgIGNvb3JkaW5hdGU6IENvb3JkaW5hdGU7XG4gICAgcmVmZXJlbmNlczogQUlUYWJsZVJlZmVyZW5jZXM7XG4gICAgY29udGFpbmVyPzogSFRNTERpdkVsZW1lbnQ7XG4gICAgaXNIb3ZlckVkaXQ/OiBib29sZWFuO1xuICAgIHZpZXdDb250YWluZXJSZWY/OiBWaWV3Q29udGFpbmVyUmVmO1xuICAgIHVwZGF0ZUZpZWxkVmFsdWU6IChvcHRpb25zOiBVcGRhdGVGaWVsZFZhbHVlT3B0aW9uczxhbnk+KSA9PiB2b2lkO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFJVGFibGVDb250ZXh0IHtcbiAgICBsaW5lYXJSb3dzOiBTaWduYWw8QUlUYWJsZUxpbmVhclJvd1tdPjtcbiAgICBwb2ludFBvc2l0aW9uOiBXcml0YWJsZVNpZ25hbDxBSVRhYmxlUG9pbnRQb3NpdGlvbj47XG4gICAgc2Nyb2xsU3RhdGU6IFdyaXRhYmxlU2lnbmFsPEFJVGFibGVTY3JvbGxTdGF0ZT47XG4gICAgc2Nyb2xsQWN0aW9uOiAob3B0aW9uczogU2Nyb2xsQWN0aW9uT3B0aW9ucykgPT4gdm9pZDtcbiAgICB2aXNpYmxlQ29sdW1uc0luZGV4TWFwOiBTaWduYWw8TWFwPHN0cmluZywgbnVtYmVyPj47XG4gICAgdmlzaWJsZVJvd3NJbmRleE1hcDogU2lnbmFsPE1hcDxzdHJpbmcsIG51bWJlcj4+O1xuICAgIGZyb3plbkNvbHVtbkNvdW50OiBTaWduYWw8bnVtYmVyPjtcbiAgICByZWZlcmVuY2VzOiBTaWduYWw8QUlUYWJsZVJlZmVyZW5jZXM+O1xuICAgIGFpRmllbGRDb25maWc6IFNpZ25hbDxBSUZpZWxkQ29uZmlnIHwgdW5kZWZpbmVkPjtcbn1cblxuZXhwb3J0IGVudW0gQUlUYWJsZVNlbGVjdEFsbFN0YXRlIHtcbiAgICBhbGwgPSAnYWxsJyxcbiAgICBwYXJ0aWFsID0gJ3BhcnRpYWwnLFxuICAgIG5vbmUgPSAnbm9uZSdcbn1cbiJdfQ==
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JpZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL2dyaWQvc3JjL3R5cGVzL2dyaWQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkRBLE1BQU0sQ0FBTixJQUFZLGdCQUdYO0FBSEQsV0FBWSxnQkFBZ0I7SUFDeEIsdUNBQW1CLENBQUE7SUFDbkIsMkNBQXVCLENBQUE7QUFDM0IsQ0FBQyxFQUhXLGdCQUFnQixLQUFoQixnQkFBZ0IsUUFHM0I7QUFlRCxNQUFNLENBQU4sSUFBWSxlQUdYO0FBSEQsV0FBWSxlQUFlO0lBQ3ZCLGdDQUFhLENBQUE7SUFDYixnQ0FBYSxDQUFBO0FBQ2pCLENBQUMsRUFIVyxlQUFlLEtBQWYsZUFBZSxRQUcxQjtBQTZDRCxNQUFNLENBQU4sSUFBWSxxQkFJWDtBQUpELFdBQVkscUJBQXFCO0lBQzdCLG9DQUFXLENBQUE7SUFDWCw0Q0FBbUIsQ0FBQTtJQUNuQixzQ0FBYSxDQUFBO0FBQ2pCLENBQUMsRUFKVyxxQkFBcUIsS0FBckIscUJBQXFCLFFBSWhDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2lnbmFsLCBWaWV3Q29udGFpbmVyUmVmLCBXcml0YWJsZVNpZ25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBBSVRhYmxlRmllbGRNZW51SXRlbSB9IGZyb20gJy4vZmllbGQnO1xuaW1wb3J0IHsgQUlUYWJsZUxpbmVhclJvdyB9IGZyb20gJy4vcm93JztcbmltcG9ydCB7XG4gICAgQUlUYWJsZUZpZWxkLFxuICAgIEFJVGFibGVSZWNvcmQsXG4gICAgRmllbGRWYWx1ZSxcbiAgICBBSVRhYmxlRmllbGRzLFxuICAgIEFJUmVjb3JkRmllbGRJZFBhdGgsXG4gICAgQUlUYWJsZUZpZWxkVHlwZSxcbiAgICBVcGRhdGVGaWVsZFZhbHVlT3B0aW9ucyxcbiAgICBBSVRhYmxlUmVmZXJlbmNlc1xufSBmcm9tICdAYWktdGFibGUvdXRpbHMnO1xuaW1wb3J0IHsgQUlUYWJsZSwgQ29vcmRpbmF0ZSB9IGZyb20gJy4uL2NvcmUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIEFJVGFibGVHcmlkQ2VsbFJlbmRlclNjaGVtYSB7XG4gICAgZWRpdG9yPzogYW55O1xuICAgIHRyYW5zZm9ybT86IChmaWVsZDogQUlUYWJsZUZpZWxkLCB2YWx1ZTogRmllbGRWYWx1ZSkgPT4gYW55O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFJVGFibGVDb250ZW50IHtcbiAgICByZWNvcmRzOiBQYXJ0aWFsPEFJVGFibGVSZWNvcmQ+W107XG4gICAgZmllbGRzOiBBSVRhYmxlRmllbGRzO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFJVGFibGVHcmlkRGF0YSBleHRlbmRzIEFJVGFibGVDb250ZW50IHtcbiAgICB0eXBlOiAnZ3JpZCc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQUlUYWJsZVNlbGVjdGlvbiB7XG4gICAgc2VsZWN0ZWRSZWNvcmRzOiBTZXQ8c3RyaW5nPjsgLy8gYCR7cmVjb3JkSWR9YFxuICAgIHNlbGVjdGVkRmllbGRzOiBTZXQ8c3RyaW5nPjsgLy8gYCR7ZmllbGRJZH1gXG4gICAgc2VsZWN0ZWRDZWxsczogU2V0PHN0cmluZz47IC8vIGAke3JlY29yZElkfToke2ZpZWxkSWR9YFxuICAgIGFjdGl2ZUNlbGw6IEFJUmVjb3JkRmllbGRJZFBhdGggfCBudWxsO1xuICAgIHNlbGVjdEFsbFN0YXRlOiBBSVRhYmxlU2VsZWN0QWxsU3RhdGU7IC8vICdhbGwnLCdwYXJ0aWFsJywnbm9uZSdcbn1cblxuZXhwb3J0IGludGVyZmFjZSBBSUZpZWxkQ29uZmlnIHtcbiAgICBoaWRkZW5JbmRleENvbHVtbj86IGJvb2xlYW47XG4gICAgZmllbGRSZW5kZXJlcnM/OiBQYXJ0aWFsPFJlY29yZDxBSVRhYmxlRmllbGRUeXBlLCBBSVRhYmxlR3JpZENlbGxSZW5kZXJTY2hlbWE+PjtcbiAgICBmaWVsZFNldHRpbmdDb21wb25lbnQ/OiBhbnk7XG4gICAgZmllbGRNZW51cz86IChhaVRhYmxlOiBBSVRhYmxlKSA9PiBBSVRhYmxlRmllbGRNZW51SXRlbVtdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFJVGFibGVSZW5kZXJlckNvbmZpZyB7XG4gICAgYWlUYWJsZTogQUlUYWJsZTtcbiAgICBjb250YWluZXI6IEhUTUxEaXZFbGVtZW50O1xuICAgIGNvb3JkaW5hdGU6IENvb3JkaW5hdGU7XG4gICAgY29udGFpbmVyV2lkdGg6IG51bWJlcjtcbiAgICBjb250YWluZXJIZWlnaHQ6IG51bWJlcjtcbiAgICByZWZlcmVuY2VzOiBBSVRhYmxlUmVmZXJlbmNlcztcbiAgICByZWFkb25seTogYm9vbGVhbjtcbiAgICByb3dEcmFnRGlzYWJsZWQ6IGJvb2xlYW47XG4gICAgYWN0aW9uczoge1xuICAgICAgICB1cGRhdGVGaWVsZFZhbHVlOiAob3B0aW9uczogVXBkYXRlRmllbGRWYWx1ZU9wdGlvbnMpID0+IHZvaWQ7XG4gICAgfTtcbn1cblxuZXhwb3J0IGVudW0gQUlUYWJsZUNoZWNrVHlwZSB7XG4gICAgY2hlY2tlZCA9ICdjaGVja2VkJyxcbiAgICB1bmNoZWNrZWQgPSAndW5jaGVja2VkJ1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFJVGFibGVTY3JvbGxTdGF0ZSB7XG4gICAgc2Nyb2xsVG9wOiBudW1iZXI7XG4gICAgc2Nyb2xsTGVmdDogbnVtYmVyO1xuICAgIGlzU2Nyb2xsaW5nOiBib29sZWFuO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNjcm9sbEFjdGlvbk9wdGlvbnMge1xuICAgIGRlbHRhWDogbnVtYmVyO1xuICAgIGRlbHRhWTogbnVtYmVyO1xuICAgIHNoaWZ0S2V5OiBib29sZWFuO1xuICAgIGNhbGxiYWNrPzogKCkgPT4gdm9pZDtcbn1cblxuZXhwb3J0IGVudW0gQUlUYWJsZUFyZWFUeXBlIHtcbiAgICBncmlkID0gJ2dyaWQnLFxuICAgIG5vbmUgPSAnbm9uZSdcbn1cblxuZXhwb3J0IHR5cGUgQUlUYWJsZVBvaW50UG9zaXRpb24gPSB7XG4gICAgeDogbnVtYmVyO1xuICAgIHk6IG51bWJlcjtcbiAgICBhcmVhVHlwZTogQUlUYWJsZUFyZWFUeXBlO1xuICAgIHRhcmdldE5hbWU6IHN0cmluZztcbiAgICByZWFsVGFyZ2V0TmFtZTogc3RyaW5nO1xuICAgIHJvd0luZGV4OiBudW1iZXI7XG4gICAgY29sdW1uSW5kZXg6IG51bWJlcjtcbiAgICBvZmZzZXRUb3A6IG51bWJlcjtcbiAgICBvZmZzZXRMZWZ0OiBudW1iZXI7XG59O1xuXG5leHBvcnQgaW50ZXJmYWNlIEFJVGFibGVFZGl0UG9zaXRpb24ge1xuICAgIHg6IG51bWJlcjtcbiAgICB5OiBudW1iZXI7XG4gICAgd2lkdGg6IG51bWJlcjtcbiAgICBoZWlnaHQ6IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBBSVRhYmxlT3BlbkVkaXRPcHRpb25zIHtcbiAgICByZWNvcmRJZDogc3RyaW5nO1xuICAgIGZpZWxkSWQ6IHN0cmluZztcbiAgICBjb29yZGluYXRlOiBDb29yZGluYXRlO1xuICAgIHJlZmVyZW5jZXM6IEFJVGFibGVSZWZlcmVuY2VzO1xuICAgIGNvbnRhaW5lcj86IEhUTUxEaXZFbGVtZW50O1xuICAgIGlzSG92ZXJFZGl0PzogYm9vbGVhbjtcbiAgICB2aWV3Q29udGFpbmVyUmVmPzogVmlld0NvbnRhaW5lclJlZjtcbiAgICB1cGRhdGVGaWVsZFZhbHVlOiAob3B0aW9uczogVXBkYXRlRmllbGRWYWx1ZU9wdGlvbnM8YW55PikgPT4gdm9pZDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBBSVRhYmxlQ29udGV4dCB7XG4gICAgcm93SGVhZFdpZHRoOiBTaWduYWw8bnVtYmVyPjtcbiAgICBsaW5lYXJSb3dzOiBTaWduYWw8QUlUYWJsZUxpbmVhclJvd1tdPjtcbiAgICBwb2ludFBvc2l0aW9uOiBXcml0YWJsZVNpZ25hbDxBSVRhYmxlUG9pbnRQb3NpdGlvbj47XG4gICAgc2Nyb2xsU3RhdGU6IFdyaXRhYmxlU2lnbmFsPEFJVGFibGVTY3JvbGxTdGF0ZT47XG4gICAgc2Nyb2xsQWN0aW9uOiAob3B0aW9uczogU2Nyb2xsQWN0aW9uT3B0aW9ucykgPT4gdm9pZDtcbiAgICB2aXNpYmxlQ29sdW1uc0luZGV4TWFwOiBTaWduYWw8TWFwPHN0cmluZywgbnVtYmVyPj47XG4gICAgdmlzaWJsZVJvd3NJbmRleE1hcDogU2lnbmFsPE1hcDxzdHJpbmcsIG51bWJlcj4+O1xuICAgIGZyb3plbkNvbHVtbkNvdW50OiBTaWduYWw8bnVtYmVyPjtcbiAgICByZWZlcmVuY2VzOiBTaWduYWw8QUlUYWJsZVJlZmVyZW5jZXM+O1xuICAgIGFpRmllbGRDb25maWc6IFNpZ25hbDxBSUZpZWxkQ29uZmlnIHwgdW5kZWZpbmVkPjtcbn1cblxuZXhwb3J0IGVudW0gQUlUYWJsZVNlbGVjdEFsbFN0YXRlIHtcbiAgICBhbGwgPSAnYWxsJyxcbiAgICBwYXJ0aWFsID0gJ3BhcnRpYWwnLFxuICAgIG5vbmUgPSAnbm9uZSdcbn1cbiJdfQ==
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF5b3V0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvZ3JpZC9zcmMvdHlwZXMvbGF5b3V0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIEFJVGFibGVMYXlvdXQge1xuICAgIHg6IG51bWJlcjtcbiAgICB5OiBudW1iZXI7XG4gICAgcm93SW5kZXg6IG51bWJlcjtcbiAgICBjb2x1bW5JbmRleDogbnVtYmVyO1xuICAgIHJvd0hlaWdodDogbnVtYmVyO1xuICAgIGNvbHVtbldpZHRoOiBudW1iZXI7XG4gICAgY29sdW1uQ291bnQ6IG51bWJlcjtcbiAgICBjb250YWluZXJXaWR0aDogbnVtYmVyO1xufVxuIl19
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF5b3V0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvZ3JpZC9zcmMvdHlwZXMvbGF5b3V0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIEFJVGFibGVMYXlvdXQge1xuICAgIHg6IG51bWJlcjtcbiAgICB5OiBudW1iZXI7XG4gICAgcm93SW5kZXg6IG51bWJlcjtcbiAgICBjb2x1bW5JbmRleDogbnVtYmVyO1xuICAgIHJvd0hlaWdodDogbnVtYmVyO1xuICAgIGNvbHVtbldpZHRoOiBudW1iZXI7XG4gICAgY29sdW1uQ291bnQ6IG51bWJlcjtcbiAgICBjb250YWluZXJXaWR0aDogbnVtYmVyO1xuICAgIHJvd0hlYWRXaWR0aDogbnVtYmVyO1xuICAgIGhpZGRlbkluZGV4Q29sdW1uOiBib29sZWFuO1xufVxuIl19
@@ -17,6 +17,9 @@ export function getCellHorizontalPosition(options) {
17
17
  const { columnWidth } = options;
18
18
  return { width: columnWidth, offset: 0 };
19
19
  }
20
+ // @deprecated 请使用 FieldModelMap 的 transformCellValue 方法
21
+ // const fieldModel = FieldModelMap[field.type];
22
+ // const transformValue = fieldModel.transformCellValue(cellValue, { aiTable, field });
20
23
  export function transformCellValue(aiTable, field, cellValue) {
21
24
  const fieldModel = FieldModelMap[field.type];
22
25
  if (!fieldModel.isValid(cellValue)) {
@@ -74,4 +77,4 @@ export function getAvatarBgColor(name) {
74
77
  : 0;
75
78
  return colors[code % 9];
76
79
  }
77
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cell.js","sourceRoot":"","sources":["../../../../packages/grid/src/utils/cell.ts"],"names":[],"mappings":"AACA,OAAO,EAAW,qBAAqB,EAAE,MAAM,SAAS,CAAC;AACzD,OAAO,EAAE,+BAA+B,EAAE,MAAM,aAAa,CAAC;AAC9D,OAAO,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AAExC,MAAM,UAAU,uBAAuB,CAAC,OAAgB,EAAE,MAAsB;IAC5E,MAAM,YAAY,GAAG,OAAO,CAAC,QAAQ,EAAE,CAAC,aAAa,CAAC;IACtD,MAAM,oBAAoB,GAAmB,EAAE,CAAC;IAChD,MAAM,EAAE,OAAO,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE;QAC7B,oBAAoB,CAAC,KAAK,CAAC,GAAG,YAAY,CAAC,KAAK,CAAC,GAAG,CAAC,IAAK,qBAAqB,CAAC,OAAO,EAAE,KAAK,CAAwB,CAAC,KAAK,CAAC;IACjI,CAAC,CAAC,CAAC;IACH,OAAO,oBAAoB,CAAC;AAChC,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,yBAAyB,CAAC,OAA0E;IAChH,MAAM,EAAE,WAAW,EAAE,GAAG,OAAO,CAAC;IAChC,OAAO,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC;AAC7C,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAU,OAAgB,EAAE,KAAmB,EAAE,SAAqB;IACpG,MAAM,UAAU,GAAG,aAAa,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IAC7C,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,CAAC;QACjC,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,MAAM,YAAY,GAAG,+BAA+B,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;IAElE,IAAI,CAAC,YAAY,EAAE,CAAC;QAChB,OAAO,SAAS,CAAC;IACrB,CAAC;IAED,MAAM,cAAc,GAAG,YAAY,CAAC,aAAa,EAAE,cAAc,CAAC;IAClE,IAAI,CAAC,cAAc,EAAE,CAAC;QAClB,OAAO,SAAS,CAAC;IACrB,CAAC;IAED,MAAM,aAAa,GAAG,cAAc,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,SAAS,CAAC;IAC5D,IAAI,CAAC,aAAa,EAAE,CAAC;QACjB,OAAO,SAAS,CAAC;IACrB,CAAC;IAED,MAAM,QAAQ,GAAG,aAAa,CAAC,KAAK,EAAE,SAAS,CAAC,CAAC;IAEjD,IAAI,QAAQ,IAAI,IAAI,EAAE,CAAC;QACnB,OAAO,SAAS,CAAC;IACrB,CAAC;IAED,OAAO,QAAQ,CAAC;AACpB,CAAC;AAED;;;GAGG;AACH,MAAM,wBAAwB,GAAG,oBAAoB,CAAC;AAEtD,MAAM,oBAAoB,GAAG,gBAAgB,CAAC;AAE9C,MAAM,UAAU,kBAAkB,CAAC,IAA+B;IAC9D,IAAI,CAAC,IAAI,EAAE,CAAC;QACR,OAAO,EAAE,CAAC;IACd,CAAC;IAED,IAAI,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC;IAEnB,IAAI,wBAAwB,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACzD,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;IACvC,CAAC;IAED,IAAI,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC;QAC3D,MAAM,KAAK,GAAa,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QACxC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;IACvE,CAAC;IAED,OAAO,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;AACjF,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,IAAY;IACzC,IAAI,CAAC,IAAI,EAAE,CAAC;QACR,OAAO;IACX,CAAC;IACD,MAAM,MAAM,GAAG,CAAC,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,CAAC,CAAC;IACnH,MAAM,SAAS,GAAa,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;IAC3C,MAAM,IAAI,GACN,IAAI,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC;QACnB,CAAC,CAAC,SAAS,CAAC,MAAM,CACZ,UAAU,MAAM,EAAE,IAAI;YAClB,MAAM,CAAC,KAAK,IAAI,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;YACnC,OAAO,MAAM,CAAC;QAClB,CAAC,EACD,EAAE,KAAK,EAAE,CAAC,EAAE,CACf,CAAC,KAAK;QACT,CAAC,CAAC,CAAC,CAAC;IACZ,OAAO,MAAM,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC;AAC5B,CAAC","sourcesContent":["import { AITableField, AITableFieldOption, AITableSizeMap, FieldValue } from '@ai-table/utils';\nimport { AITable, getFieldOptionByField } from '../core';\nimport { AI_TABLE_GRID_FIELD_SERVICE_MAP } from '../services';\nimport { FieldModelMap } from './field';\n\nexport function getColumnIndicesSizeMap(aiTable: AITable, fields: AITableField[]) {\n    const fieldSizeMap = aiTable.gridData().fieldsSizeMap;\n    const columnIndicesSizeMap: AITableSizeMap = {};\n    fields?.forEach((field, index) => {\n        columnIndicesSizeMap[index] = fieldSizeMap[field._id] ?? (getFieldOptionByField(aiTable, field) as AITableFieldOption).width;\n    });\n    return columnIndicesSizeMap;\n}\n\n/**\n * 获取单元格位置\n * 根据单元格是否是第一列/最后一列确定单元格所在的位置\n */\nexport function getCellHorizontalPosition(options: { columnWidth: number; columnIndex: number; columnCount: number }) {\n    const { columnWidth } = options;\n    return { width: columnWidth, offset: 0 };\n}\n\nexport function transformCellValue<T = any>(aiTable: AITable, field: AITableField, cellValue: FieldValue): T | null {\n    const fieldModel = FieldModelMap[field.type];\n    if (!fieldModel.isValid(cellValue)) {\n        return null;\n    }\n\n    const fieldService = AI_TABLE_GRID_FIELD_SERVICE_MAP.get(aiTable);\n\n    if (!fieldService) {\n        return cellValue;\n    }\n\n    const fieldRenderers = fieldService.aiFieldConfig?.fieldRenderers;\n    if (!fieldRenderers) {\n        return cellValue;\n    }\n\n    const cellTransform = fieldRenderers[field.type]?.transform;\n    if (!cellTransform) {\n        return cellValue;\n    }\n\n    const cellText = cellTransform(field, cellValue);\n\n    if (cellText == null) {\n        return cellValue;\n    }\n\n    return cellText;\n}\n\n/**\n * `\\u4e00`: https://www.compart.com/en/unicode/U+4E00\n * `\\u9fa5`: https://www.compart.com/en/unicode/U+9FA5\n */\nconst UNIFIED_IDEOGRAPHS_REGEX = /^[\\u4e00-\\u9fa5]+$/;\n\nconst SET_OF_LETTERS_REGEX = /^[a-zA-Z\\/ ]+$/;\n\nexport function getAvatarShortName(name: string | null | undefined): string {\n    if (!name) {\n        return '';\n    }\n\n    name = name.trim();\n\n    if (UNIFIED_IDEOGRAPHS_REGEX.test(name) && name.length > 2) {\n        return name.slice(name.length - 2);\n    }\n\n    if (SET_OF_LETTERS_REGEX.test(name) && name.indexOf(' ') > 0) {\n        const words: string[] = name.split(' ');\n        return (words[0].slice(0, 1) + words[1].slice(0, 1)).toUpperCase();\n    }\n\n    return name.length > 2 ? name.slice(0, 2).toUpperCase() : name.toUpperCase();\n}\n\nexport function getAvatarBgColor(name: string) {\n    if (!name) {\n        return;\n    }\n    const colors = ['#56abfb', '#5dcfff', '#84e17e', '#73d897', '#ff9f73', '#fa8888', '#fb7fb7', '#9a7ef4', '#868af6'];\n    const nameArray: string[] = name.split('');\n    const code: number =\n        name && name.length > 0\n            ? nameArray.reduce(\n                  function (result, item) {\n                      result.value += item.charCodeAt(0);\n                      return result;\n                  },\n                  { value: 0 }\n              ).value\n            : 0;\n    return colors[code % 9];\n}\n"]}
80
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cell.js","sourceRoot":"","sources":["../../../../packages/grid/src/utils/cell.ts"],"names":[],"mappings":"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","sourcesContent":["import { AITableField, AITableFieldOption, AITableSizeMap, FieldValue } from '@ai-table/utils';\nimport { AITable, getFieldOptionByField } from '../core';\nimport { AI_TABLE_GRID_FIELD_SERVICE_MAP } from '../services';\nimport { FieldModelMap } from './field';\n\nexport function getColumnIndicesSizeMap(aiTable: AITable, fields: AITableField[]) {\n    const fieldSizeMap = aiTable.gridData().fieldsSizeMap;\n    const columnIndicesSizeMap: AITableSizeMap = {};\n    fields?.forEach((field, index) => {\n        columnIndicesSizeMap[index] = fieldSizeMap[field._id] ?? (getFieldOptionByField(aiTable, field) as AITableFieldOption).width;\n    });\n    return columnIndicesSizeMap;\n}\n\n/**\n * 获取单元格位置\n * 根据单元格是否是第一列/最后一列确定单元格所在的位置\n */\nexport function getCellHorizontalPosition(options: { columnWidth: number; columnIndex: number; columnCount: number }) {\n    const { columnWidth } = options;\n    return { width: columnWidth, offset: 0 };\n}\n\n// @deprecated 请使用 FieldModelMap 的 transformCellValue 方法\n// const fieldModel = FieldModelMap[field.type];\n// const transformValue = fieldModel.transformCellValue(cellValue, { aiTable, field });\nexport function transformCellValue<T = any>(aiTable: AITable, field: AITableField, cellValue: FieldValue): T | null {\n    const fieldModel = FieldModelMap[field.type];\n    if (!fieldModel.isValid(cellValue)) {\n        return null;\n    }\n\n    const fieldService = AI_TABLE_GRID_FIELD_SERVICE_MAP.get(aiTable);\n\n    if (!fieldService) {\n        return cellValue;\n    }\n\n    const fieldRenderers = fieldService.aiFieldConfig?.fieldRenderers;\n    if (!fieldRenderers) {\n        return cellValue;\n    }\n\n    const cellTransform = fieldRenderers[field.type]?.transform;\n    if (!cellTransform) {\n        return cellValue;\n    }\n\n    const cellText = cellTransform(field, cellValue);\n\n    if (cellText == null) {\n        return cellValue;\n    }\n\n    return cellText;\n}\n\n/**\n * `\\u4e00`: https://www.compart.com/en/unicode/U+4E00\n * `\\u9fa5`: https://www.compart.com/en/unicode/U+9FA5\n */\nconst UNIFIED_IDEOGRAPHS_REGEX = /^[\\u4e00-\\u9fa5]+$/;\n\nconst SET_OF_LETTERS_REGEX = /^[a-zA-Z\\/ ]+$/;\n\nexport function getAvatarShortName(name: string | null | undefined): string {\n    if (!name) {\n        return '';\n    }\n\n    name = name.trim();\n\n    if (UNIFIED_IDEOGRAPHS_REGEX.test(name) && name.length > 2) {\n        return name.slice(name.length - 2);\n    }\n\n    if (SET_OF_LETTERS_REGEX.test(name) && name.indexOf(' ') > 0) {\n        const words: string[] = name.split(' ');\n        return (words[0].slice(0, 1) + words[1].slice(0, 1)).toUpperCase();\n    }\n\n    return name.length > 2 ? name.slice(0, 2).toUpperCase() : name.toUpperCase();\n}\n\nexport function getAvatarBgColor(name: string) {\n    if (!name) {\n        return;\n    }\n    const colors = ['#56abfb', '#5dcfff', '#84e17e', '#73d897', '#ff9f73', '#fa8888', '#fb7fb7', '#9a7ef4', '#868af6'];\n    const nameArray: string[] = name.split('');\n    const code: number =\n        name && name.length > 0\n            ? nameArray.reduce(\n                  function (result, item) {\n                      result.value += item.charCodeAt(0);\n                      return result;\n                  },\n                  { value: 0 }\n              ).value\n            : 0;\n    return colors[code % 9];\n}\n"]}