@ai-table/grid 0.0.11 → 0.0.13
Sign up to get free protection for your applications and to get access to all the features.
- package/angular-konva/components/container.component.d.ts +7 -0
- package/angular-konva/components/container.component.d.ts.map +1 -0
- package/angular-konva/components/container.token.d.ts +3 -0
- package/angular-konva/components/container.token.d.ts.map +1 -0
- package/angular-konva/components/index.d.ts +4 -0
- package/angular-konva/components/index.d.ts.map +1 -0
- package/angular-konva/components/shape.component.d.ts +61 -0
- package/angular-konva/components/shape.component.d.ts.map +1 -0
- package/angular-konva/components/stage.component.d.ts +40 -0
- package/angular-konva/components/stage.component.d.ts.map +1 -0
- package/angular-konva/index.d.ts +5 -0
- package/angular-konva/index.d.ts.map +1 -0
- package/angular-konva/interfaces/component.d.ts +49 -0
- package/angular-konva/interfaces/component.d.ts.map +1 -0
- package/angular-konva/interfaces/config.d.ts +26 -0
- package/angular-konva/interfaces/config.d.ts.map +1 -0
- package/angular-konva/interfaces/event-object.d.ts +7 -0
- package/angular-konva/interfaces/event-object.d.ts.map +1 -0
- package/angular-konva/interfaces/index.d.ts +5 -0
- package/angular-konva/interfaces/index.d.ts.map +1 -0
- package/angular-konva/interfaces/shape.d.ts +42 -0
- package/angular-konva/interfaces/shape.d.ts.map +1 -0
- package/angular-konva/utils/apply-node-props.d.ts +4 -0
- package/angular-konva/utils/apply-node-props.d.ts.map +1 -0
- package/angular-konva/utils/common.d.ts +8 -0
- package/angular-konva/utils/common.d.ts.map +1 -0
- package/angular-konva/utils/index.d.ts +5 -0
- package/angular-konva/utils/index.d.ts.map +1 -0
- package/angular-konva/utils/types.d.ts +4 -0
- package/angular-konva/utils/types.d.ts.map +1 -0
- package/angular-konva/utils/update-picture.d.ts +4 -0
- package/angular-konva/utils/update-picture.d.ts.map +1 -0
- package/components/cell-editors/abstract-cell-editor.component.d.ts +7 -5
- package/components/cell-editors/abstract-cell-editor.component.d.ts.map +1 -1
- package/components/cell-editors/cell-editor.scss +38 -25
- package/components/cell-editors/cell-editor.variables.scss +5 -0
- package/components/cell-editors/date/date-editor.component.d.ts.map +1 -1
- package/components/cell-editors/link/edit-link/edit-link.component.d.ts +33 -0
- package/components/cell-editors/link/edit-link/edit-link.component.d.ts.map +1 -0
- package/components/cell-editors/link/link-editor.component.d.ts +36 -0
- package/components/cell-editors/link/link-editor.component.d.ts.map +1 -0
- package/components/cell-editors/link/link-editor.component.scss +21 -0
- package/components/cell-editors/progress/progress-editor.component.d.ts +0 -1
- package/components/cell-editors/progress/progress-editor.component.d.ts.map +1 -1
- package/components/cell-editors/progress/progress-editor.component.scss +12 -4
- package/components/cell-editors/rating/rating-editor.component.d.ts +0 -1
- package/components/cell-editors/rating/rating-editor.component.d.ts.map +1 -1
- package/components/cell-editors/rating/rating-editor.component.scss +10 -0
- package/components/cell-editors/select/select-editor.component.d.ts +1 -3
- package/components/cell-editors/select/select-editor.component.d.ts.map +1 -1
- package/components/cell-editors/text/text-editor.component.d.ts +0 -1
- package/components/cell-editors/text/text-editor.component.d.ts.map +1 -1
- package/components/cell-views/select/option.component.d.ts.map +1 -1
- package/components/cell-views/select/option.scss +10 -0
- package/components/field-menu/field-menu.component.d.ts +8 -3
- package/components/field-menu/field-menu.component.d.ts.map +1 -1
- package/components/field-property-editor/field-property-editor.component.d.ts +4 -2
- package/components/field-property-editor/field-property-editor.component.d.ts.map +1 -1
- package/components/index.d.ts +3 -1
- package/components/index.d.ts.map +1 -1
- package/constants/colors.d.ts +18 -0
- package/constants/colors.d.ts.map +1 -0
- package/constants/grid.d.ts +17 -1
- package/constants/grid.d.ts.map +1 -1
- package/constants/icon.d.ts +19 -0
- package/constants/icon.d.ts.map +1 -0
- package/constants/index.d.ts +5 -1
- package/constants/index.d.ts.map +1 -1
- package/constants/table.d.ts +60 -0
- package/constants/table.d.ts.map +1 -0
- package/constants/text.d.ts +22 -0
- package/constants/text.d.ts.map +1 -0
- package/core/context.d.ts +14 -0
- package/core/context.d.ts.map +1 -0
- package/core/coordinate.d.ts +96 -0
- package/core/coordinate.d.ts.map +1 -0
- package/core/index.d.ts +3 -2
- package/core/index.d.ts.map +1 -1
- package/core/types/ai-table.d.ts +56 -0
- package/core/types/ai-table.d.ts.map +1 -0
- package/core/types/core.d.ts +29 -23
- package/core/types/core.d.ts.map +1 -1
- package/core/types/index.d.ts +1 -1
- package/core/types/index.d.ts.map +1 -1
- package/core/utils/common.d.ts +1 -2
- package/core/utils/common.d.ts.map +1 -1
- package/core/utils/field.d.ts +1 -1
- package/core/utils/field.d.ts.map +1 -1
- package/core/utils/index.d.ts +0 -1
- package/core/utils/index.d.ts.map +1 -1
- package/core/utils/queries.d.ts +5 -5
- package/core/utils/queries.d.ts.map +1 -1
- package/dom-grid.component.d.ts +11 -0
- package/dom-grid.component.d.ts.map +1 -0
- package/esm2022/angular-konva/components/container.component.mjs +29 -0
- package/esm2022/angular-konva/components/container.token.mjs +3 -0
- package/esm2022/angular-konva/components/index.mjs +4 -0
- package/esm2022/angular-konva/components/shape.component.mjs +142 -0
- package/esm2022/angular-konva/components/stage.component.mjs +123 -0
- package/esm2022/angular-konva/index.mjs +5 -0
- package/esm2022/angular-konva/interfaces/component.mjs +4 -0
- package/esm2022/angular-konva/interfaces/config.mjs +2 -0
- package/esm2022/angular-konva/interfaces/event-object.mjs +2 -0
- package/esm2022/angular-konva/interfaces/index.mjs +5 -0
- package/esm2022/angular-konva/interfaces/shape.mjs +42 -0
- package/esm2022/angular-konva/utils/apply-node-props.mjs +67 -0
- package/esm2022/angular-konva/utils/common.mjs +48 -0
- package/esm2022/angular-konva/utils/index.mjs +5 -0
- package/esm2022/angular-konva/utils/types.mjs +2 -0
- package/esm2022/angular-konva/utils/update-picture.mjs +7 -0
- package/esm2022/components/cell-editors/abstract-cell-editor.component.mjs +12 -7
- package/esm2022/components/cell-editors/date/date-editor.component.mjs +6 -3
- package/esm2022/components/cell-editors/link/edit-link/edit-link.component.mjs +66 -0
- package/esm2022/components/cell-editors/link/link-editor.component.mjs +117 -0
- package/esm2022/components/cell-editors/number/number-editor.component.mjs +2 -2
- package/esm2022/components/cell-editors/progress/progress-editor.component.mjs +3 -6
- package/esm2022/components/cell-editors/rating/rating-editor.component.mjs +4 -7
- package/esm2022/components/cell-editors/select/select-editor.component.mjs +11 -16
- package/esm2022/components/cell-editors/text/text-editor.component.mjs +10 -11
- package/esm2022/components/cell-views/select/option.component.mjs +6 -5
- package/esm2022/components/field-menu/field-menu.component.mjs +11 -8
- package/esm2022/components/field-property-editor/field-property-editor.component.mjs +17 -12
- package/esm2022/components/index.mjs +4 -2
- package/esm2022/constants/colors.mjs +18 -0
- package/esm2022/constants/editor.mjs +2 -3
- package/esm2022/constants/grid.mjs +22 -4
- package/esm2022/constants/icon.mjs +26 -0
- package/esm2022/constants/index.mjs +6 -2
- package/esm2022/constants/table.mjs +62 -0
- package/esm2022/constants/text.mjs +23 -0
- package/esm2022/core/context.mjs +25 -0
- package/esm2022/core/coordinate.mjs +222 -0
- package/esm2022/core/index.mjs +4 -3
- package/esm2022/core/types/ai-table.mjs +44 -0
- package/esm2022/core/types/core.mjs +6 -1
- package/esm2022/core/types/index.mjs +2 -2
- package/esm2022/core/utils/common.mjs +3 -20
- package/esm2022/core/utils/field.mjs +9 -5
- package/esm2022/core/utils/index.mjs +1 -2
- package/esm2022/core/utils/queries.mjs +4 -4
- package/esm2022/dom-grid.component.mjs +82 -0
- package/esm2022/grid-base.component.mjs +154 -0
- package/esm2022/grid.component.mjs +336 -160
- package/esm2022/public-api.mjs +9 -5
- package/esm2022/renderer/components/add-field-column.component.mjs +68 -0
- package/esm2022/renderer/components/cells.component.mjs +35 -0
- package/esm2022/renderer/components/field-head.component.mjs +130 -0
- package/esm2022/renderer/components/field-icon.component.mjs +66 -0
- package/esm2022/renderer/components/frozen-cells.component.mjs +36 -0
- package/esm2022/renderer/components/frozen-heads.component.mjs +117 -0
- package/esm2022/renderer/components/frozen-placeholder-cells.component.mjs +38 -0
- package/esm2022/renderer/components/heads.component.mjs +38 -0
- package/esm2022/renderer/components/hover-row-heads.component.mjs +107 -0
- package/esm2022/renderer/components/icon.component.mjs +80 -0
- package/esm2022/renderer/components/index.mjs +14 -0
- package/esm2022/renderer/components/other-rows.component.mjs +68 -0
- package/esm2022/renderer/components/placeholder-cells.component.mjs +33 -0
- package/esm2022/renderer/components/text.component.mjs +45 -0
- package/esm2022/renderer/creations/create-active-cell-border.mjs +68 -0
- package/esm2022/renderer/creations/create-cells.mjs +135 -0
- package/esm2022/renderer/creations/create-heads.mjs +45 -0
- package/esm2022/renderer/drawers/add-row-layout-drawer.mjs +97 -0
- package/esm2022/renderer/drawers/cell-drawer.mjs +586 -0
- package/esm2022/renderer/drawers/drawer.mjs +936 -0
- package/esm2022/renderer/drawers/layout-drawer.mjs +58 -0
- package/esm2022/renderer/drawers/record-row-layout-drawer.mjs +101 -0
- package/esm2022/renderer/index.mjs +4 -0
- package/esm2022/renderer/renderer.component.mjs +174 -0
- package/esm2022/services/event.service.mjs +115 -11
- package/esm2022/services/field.service.mjs +28 -5
- package/esm2022/services/index.mjs +4 -0
- package/esm2022/services/selection.service.mjs +8 -1
- package/esm2022/types/avatar.mjs +27 -0
- package/esm2022/types/canvas.mjs +2 -0
- package/esm2022/types/cell.mjs +2 -0
- package/esm2022/types/component-config.mjs +7 -0
- package/esm2022/types/field.mjs +1 -1
- package/esm2022/types/grid.mjs +16 -2
- package/esm2022/types/index.mjs +8 -2
- package/esm2022/types/layout.mjs +2 -0
- package/esm2022/types/row.mjs +6 -0
- package/esm2022/utils/build.mjs +39 -0
- package/esm2022/utils/cell.mjs +71 -0
- package/esm2022/utils/common.mjs +49 -0
- package/esm2022/utils/get-placeholder-cells.mjs +66 -0
- package/esm2022/utils/get-text-width.mjs +30 -0
- package/esm2022/utils/image-cache.mjs +57 -0
- package/esm2022/utils/index.mjs +12 -0
- package/esm2022/utils/os.mjs +16 -0
- package/esm2022/utils/position.mjs +48 -0
- package/esm2022/utils/style.mjs +25 -0
- package/esm2022/utils/text-measure.mjs +122 -0
- package/esm2022/utils/visible-range.mjs +38 -0
- package/fesm2022/ai-table-grid.mjs +5526 -693
- package/fesm2022/ai-table-grid.mjs.map +1 -1
- package/grid-base.component.d.ts +52 -0
- package/grid-base.component.d.ts.map +1 -0
- package/grid.component.d.ts +43 -40
- package/grid.component.d.ts.map +1 -1
- package/package.json +5 -2
- package/public-api.d.ts +8 -4
- package/public-api.d.ts.map +1 -1
- package/renderer/components/add-field-column.component.d.ts +16 -0
- package/renderer/components/add-field-column.component.d.ts.map +1 -0
- package/renderer/components/cells.component.d.ts +14 -0
- package/renderer/components/cells.component.d.ts.map +1 -0
- package/renderer/components/field-head.component.d.ts +73 -0
- package/renderer/components/field-head.component.d.ts.map +1 -0
- package/renderer/components/field-icon.component.d.ts +17 -0
- package/renderer/components/field-icon.component.d.ts.map +1 -0
- package/renderer/components/frozen-cells.component.d.ts +14 -0
- package/renderer/components/frozen-cells.component.d.ts.map +1 -0
- package/renderer/components/frozen-heads.component.d.ts +47 -0
- package/renderer/components/frozen-heads.component.d.ts.map +1 -0
- package/renderer/components/frozen-placeholder-cells.component.d.ts +22 -0
- package/renderer/components/frozen-placeholder-cells.component.d.ts.map +1 -0
- package/renderer/components/heads.component.d.ts +9 -0
- package/renderer/components/heads.component.d.ts.map +1 -0
- package/renderer/components/hover-row-heads.component.d.ts +11 -0
- package/renderer/components/hover-row-heads.component.d.ts.map +1 -0
- package/renderer/components/icon.component.d.ts +37 -0
- package/renderer/components/icon.component.d.ts.map +1 -0
- package/renderer/components/index.d.ts +14 -0
- package/renderer/components/index.d.ts.map +1 -0
- package/renderer/components/other-rows.component.d.ts +31 -0
- package/renderer/components/other-rows.component.d.ts.map +1 -0
- package/renderer/components/placeholder-cells.component.d.ts +22 -0
- package/renderer/components/placeholder-cells.component.d.ts.map +1 -0
- package/renderer/components/text.component.d.ts +99 -0
- package/renderer/components/text.component.d.ts.map +1 -0
- package/renderer/creations/create-active-cell-border.d.ts +7 -0
- package/renderer/creations/create-active-cell-border.d.ts.map +1 -0
- package/renderer/creations/create-cells.d.ts +8 -0
- package/renderer/creations/create-cells.d.ts.map +1 -0
- package/renderer/creations/create-heads.d.ts +3 -0
- package/renderer/creations/create-heads.d.ts.map +1 -0
- package/renderer/drawers/add-row-layout-drawer.d.ts +12 -0
- package/renderer/drawers/add-row-layout-drawer.d.ts.map +1 -0
- package/renderer/drawers/cell-drawer.d.ts +22 -0
- package/renderer/drawers/cell-drawer.d.ts.map +1 -0
- package/renderer/drawers/drawer.d.ts +136 -0
- package/renderer/drawers/drawer.d.ts.map +1 -0
- package/renderer/drawers/layout-drawer.d.ts +22 -0
- package/renderer/drawers/layout-drawer.d.ts.map +1 -0
- package/renderer/drawers/record-row-layout-drawer.d.ts +14 -0
- package/renderer/drawers/record-row-layout-drawer.d.ts.map +1 -0
- package/renderer/index.d.ts +4 -0
- package/renderer/index.d.ts.map +1 -0
- package/renderer/renderer.component.d.ts +64 -0
- package/renderer/renderer.component.d.ts.map +1 -0
- package/services/event.service.d.ts +17 -3
- package/services/event.service.d.ts.map +1 -1
- package/services/field.service.d.ts +5 -4
- package/services/field.service.d.ts.map +1 -1
- package/services/index.d.ts +4 -0
- package/services/index.d.ts.map +1 -0
- package/services/selection.service.d.ts.map +1 -1
- package/styles/styles.scss +71 -11
- package/types/avatar.d.ts +24 -0
- package/types/avatar.d.ts.map +1 -0
- package/types/canvas.d.ts +83 -0
- package/types/canvas.d.ts.map +1 -0
- package/types/cell.d.ts +43 -0
- package/types/cell.d.ts.map +1 -0
- package/types/component-config.d.ts +50 -0
- package/types/component-config.d.ts.map +1 -0
- package/types/field.d.ts +27 -1
- package/types/field.d.ts.map +1 -1
- package/types/grid.d.ts +80 -2
- package/types/grid.d.ts.map +1 -1
- package/types/index.d.ts +7 -1
- package/types/index.d.ts.map +1 -1
- package/types/layout.d.ts +11 -0
- package/types/layout.d.ts.map +1 -0
- package/types/row.d.ts +27 -0
- package/types/row.d.ts.map +1 -0
- package/utils/build.d.ts +5 -0
- package/utils/build.d.ts.map +1 -0
- package/utils/cell.d.ts +19 -0
- package/utils/cell.d.ts.map +1 -0
- package/utils/common.d.ts +20 -0
- package/utils/common.d.ts.map +1 -0
- package/utils/get-placeholder-cells.d.ts +16 -0
- package/utils/get-placeholder-cells.d.ts.map +1 -0
- package/utils/get-text-width.d.ts +9 -0
- package/utils/get-text-width.d.ts.map +1 -0
- package/utils/image-cache.d.ts +16 -0
- package/utils/image-cache.d.ts.map +1 -0
- package/utils/index.d.ts +12 -0
- package/utils/index.d.ts.map +1 -0
- package/utils/os.d.ts +4 -0
- package/utils/os.d.ts.map +1 -0
- package/utils/position.d.ts +20 -0
- package/utils/position.d.ts.map +1 -0
- package/utils/style.d.ts +4 -0
- package/utils/style.d.ts.map +1 -0
- package/utils/text-measure.d.ts +32 -0
- package/utils/text-measure.d.ts.map +1 -0
- package/utils/visible-range.d.ts +13 -0
- package/utils/visible-range.d.ts.map +1 -0
- package/components/cell-editors/link/number-editor.component.d.ts +0 -8
- package/components/cell-editors/link/number-editor.component.d.ts.map +0 -1
- package/constants/field.d.ts +0 -20
- package/constants/field.d.ts.map +0 -1
- package/core/action/field.d.ts +0 -12
- package/core/action/field.d.ts.map +0 -1
- package/core/action/general.d.ts +0 -5
- package/core/action/general.d.ts.map +0 -1
- package/core/action/index.d.ts +0 -12
- package/core/action/index.d.ts.map +0 -1
- package/core/action/record.d.ts +0 -12
- package/core/action/record.d.ts.map +0 -1
- package/core/types/action.d.ts +0 -64
- package/core/types/action.d.ts.map +0 -1
- package/core/utils/weak-map.d.ts +0 -3
- package/core/utils/weak-map.d.ts.map +0 -1
- package/esm2022/components/cell-editors/link/number-editor.component.mjs +0 -25
- package/esm2022/constants/field.mjs +0 -25
- package/esm2022/core/action/field.mjs +0 -57
- package/esm2022/core/action/general.mjs +0 -116
- package/esm2022/core/action/index.mjs +0 -9
- package/esm2022/core/action/record.mjs +0 -44
- package/esm2022/core/types/action.mjs +0 -18
- package/esm2022/core/utils/weak-map.mjs +0 -2
@@ -0,0 +1,58 @@
|
|
1
|
+
import { AI_TABLE_FIELD_ADD_BUTTON_WIDTH } from '../../constants/table';
|
2
|
+
import { Drawer } from './drawer';
|
3
|
+
/**
|
4
|
+
* 用于处理表格行或单元格的布局和绘制。
|
5
|
+
* 它提供了基本的布局信息(如位置、大小等),并定义了常用的绘图方法(如渲染缩进区域、添加新字段的空白区域等)。
|
6
|
+
* 该类继承自 Drawer,并被其他更具体的布局类(如 RecordRowLayout)扩展和使用
|
7
|
+
*/
|
8
|
+
export class Layout extends Drawer {
|
9
|
+
constructor() {
|
10
|
+
super(...arguments);
|
11
|
+
// 定义当前单元格或行的位置
|
12
|
+
this.x = 0;
|
13
|
+
this.y = 0;
|
14
|
+
// 行高
|
15
|
+
this.rowHeight = 0;
|
16
|
+
// 列宽
|
17
|
+
this.columnWidth = 0;
|
18
|
+
// 行索引
|
19
|
+
this.rowIndex = 0;
|
20
|
+
// 列索引
|
21
|
+
this.columnIndex = 0;
|
22
|
+
// 列数
|
23
|
+
this.columnCount = 0;
|
24
|
+
this.containerWidth = 0;
|
25
|
+
}
|
26
|
+
// 用于初始化或重置布局的基本属性。这个方法通常在每次渲染新的一行或单元格时调用,确保布局信息是最新的
|
27
|
+
init({ x, y, rowIndex, columnIndex, rowHeight, columnWidth, columnCount, containerWidth }) {
|
28
|
+
this.x = x;
|
29
|
+
this.y = y;
|
30
|
+
this.rowIndex = rowIndex;
|
31
|
+
this.columnIndex = columnIndex;
|
32
|
+
this.rowHeight = rowHeight;
|
33
|
+
this.columnWidth = columnWidth;
|
34
|
+
this.columnCount = columnCount;
|
35
|
+
this.containerWidth = containerWidth;
|
36
|
+
}
|
37
|
+
// 当前单元格是否是行的第一列
|
38
|
+
get isFirst() {
|
39
|
+
return this.columnIndex === 0;
|
40
|
+
}
|
41
|
+
// 当前单元格是否是行的最后一列
|
42
|
+
get isLast() {
|
43
|
+
return this.columnIndex === this.columnCount - 1;
|
44
|
+
}
|
45
|
+
renderAddFieldBlank() {
|
46
|
+
const width = AI_TABLE_FIELD_ADD_BUTTON_WIDTH;
|
47
|
+
const y = this.y;
|
48
|
+
const rowHeight = this.rowHeight;
|
49
|
+
this.rect({
|
50
|
+
x: this.x + 0.5,
|
51
|
+
y: y - 0.5,
|
52
|
+
width: this.containerWidth - this.x < width ? width : this.containerWidth - this.x,
|
53
|
+
height: rowHeight + 1,
|
54
|
+
fill: this.colors.transparent
|
55
|
+
});
|
56
|
+
}
|
57
|
+
}
|
58
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF5b3V0LWRyYXdlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2dyaWQvc3JjL3JlbmRlcmVyL2RyYXdlcnMvbGF5b3V0LWRyYXdlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsK0JBQStCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUV4RSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBRWxDOzs7O0dBSUc7QUFDSCxNQUFNLE9BQU8sTUFBTyxTQUFRLE1BQU07SUFBbEM7O1FBQ0ksZUFBZTtRQUNMLE1BQUMsR0FBRyxDQUFDLENBQUM7UUFDTixNQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ2hCLEtBQUs7UUFDSyxjQUFTLEdBQUcsQ0FBQyxDQUFDO1FBQ3hCLEtBQUs7UUFDSyxnQkFBVyxHQUFHLENBQUMsQ0FBQztRQUMxQixNQUFNO1FBQ0ksYUFBUSxHQUFHLENBQUMsQ0FBQztRQUN2QixNQUFNO1FBQ0ksZ0JBQVcsR0FBRyxDQUFDLENBQUM7UUFDMUIsS0FBSztRQUNLLGdCQUFXLEdBQUcsQ0FBQyxDQUFDO1FBRWhCLG1CQUFjLEdBQUcsQ0FBQyxDQUFDO0lBb0NqQyxDQUFDO0lBbENHLG9EQUFvRDtJQUNwRCxJQUFJLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLFFBQVEsRUFBRSxXQUFXLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxXQUFXLEVBQUUsY0FBYyxFQUFpQjtRQUNwRyxJQUFJLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUNYLElBQUksQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ1gsSUFBSSxDQUFDLFFBQVEsR0FBRyxRQUFRLENBQUM7UUFDekIsSUFBSSxDQUFDLFdBQVcsR0FBRyxXQUFXLENBQUM7UUFDL0IsSUFBSSxDQUFDLFNBQVMsR0FBRyxTQUFTLENBQUM7UUFDM0IsSUFBSSxDQUFDLFdBQVcsR0FBRyxXQUFXLENBQUM7UUFDL0IsSUFBSSxDQUFDLFdBQVcsR0FBRyxXQUFXLENBQUM7UUFDL0IsSUFBSSxDQUFDLGNBQWMsR0FBRyxjQUFjLENBQUM7SUFDekMsQ0FBQztJQUVELGdCQUFnQjtJQUNoQixJQUFjLE9BQU87UUFDakIsT0FBTyxJQUFJLENBQUMsV0FBVyxLQUFLLENBQUMsQ0FBQztJQUNsQyxDQUFDO0lBRUQsaUJBQWlCO0lBQ2pCLElBQWMsTUFBTTtRQUNoQixPQUFPLElBQUksQ0FBQyxXQUFXLEtBQUssSUFBSSxDQUFDLFdBQVcsR0FBRyxDQUFDLENBQUM7SUFDckQsQ0FBQztJQUVTLG1CQUFtQjtRQUN6QixNQUFNLEtBQUssR0FBRywrQkFBK0IsQ0FBQztRQUM5QyxNQUFNLENBQUMsR0FBRyxJQUFJLENBQUMsQ0FBQyxDQUFDO1FBQ2pCLE1BQU0sU0FBUyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUM7UUFDakMsSUFBSSxDQUFDLElBQUksQ0FBQztZQUNOLENBQUMsRUFBRSxJQUFJLENBQUMsQ0FBQyxHQUFHLEdBQUc7WUFDZixDQUFDLEVBQUUsQ0FBQyxHQUFHLEdBQUc7WUFDVixLQUFLLEVBQUUsSUFBSSxDQUFDLGNBQWMsR0FBRyxJQUFJLENBQUMsQ0FBQyxHQUFHLEtBQUssQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksQ0FBQyxDQUFDO1lBQ2xGLE1BQU0sRUFBRSxTQUFTLEdBQUcsQ0FBQztZQUNyQixJQUFJLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxXQUFXO1NBQ2hDLENBQUMsQ0FBQztJQUNQLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFJX1RBQkxFX0ZJRUxEX0FERF9CVVRUT05fV0lEVEggfSBmcm9tICcuLi8uLi9jb25zdGFudHMvdGFibGUnO1xuaW1wb3J0IHsgQUlUYWJsZUxheW91dCB9IGZyb20gJy4uLy4uL3R5cGVzJztcbmltcG9ydCB7IERyYXdlciB9IGZyb20gJy4vZHJhd2VyJztcblxuLyoqXG4gKiDnlKjkuo7lpITnkIbooajmoLzooYzmiJbljZXlhYPmoLznmoTluIPlsYDlkoznu5jliLbjgIJcbiAqIOWug+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+ihjOeahOacgOWQjuS4gOWIl1xuICAgIHByb3RlY3RlZCBnZXQgaXNMYXN0KCkge1xuICAgICAgICByZXR1cm4gdGhpcy5jb2x1bW5JbmRleCA9PT0gdGhpcy5jb2x1bW5Db3VudCAtIDE7XG4gICAgfVxuXG4gICAgcHJvdGVjdGVkIHJlbmRlckFkZEZpZWxkQmxhbmsoKSB7XG4gICAgICAgIGNvbnN0IHdpZHRoID0gQUlfVEFCTEVfRklFTERfQUREX0JVVFRPTl9XSURUSDtcbiAgICAgICAgY29uc3QgeSA9IHRoaXMueTtcbiAgICAgICAgY29uc3Qgcm93SGVpZ2h0ID0gdGhpcy5yb3dIZWlnaHQ7XG4gICAgICAgIHRoaXMucmVjdCh7XG4gICAgICAgICAgICB4OiB0aGlzLnggKyAwLjUsXG4gICAgICAgICAgICB5OiB5IC0gMC41LFxuICAgICAgICAgICAgd2lkdGg6IHRoaXMuY29udGFpbmVyV2lkdGggLSB0aGlzLnggPCB3aWR0aCA/IHdpZHRoIDogdGhpcy5jb250YWluZXJXaWR0aCAtIHRoaXMueCxcbiAgICAgICAgICAgIGhlaWdodDogcm93SGVpZ2h0ICsgMSxcbiAgICAgICAgICAgIGZpbGw6IHRoaXMuY29sb3JzLnRyYW5zcGFyZW50XG4gICAgICAgIH0pO1xuICAgIH1cbn1cbiJdfQ==
|
@@ -0,0 +1,101 @@
|
|
1
|
+
import { AI_TABLE_FIELD_HEAD_HEIGHT, AI_TABLE_OFFSET, AI_TABLE_ROW_HEAD_WIDTH, DEFAULT_FONT_SIZE } from '../../constants';
|
2
|
+
import { DEFAULT_TEXT_ALIGN_CENTER, DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE } from '../../constants/text';
|
3
|
+
import { AITable } from '../../core';
|
4
|
+
import { Layout } from './layout-drawer';
|
5
|
+
/**
|
6
|
+
* 绘制行的布局,通过直接操作 Canvas 提供高效的渲染方法。
|
7
|
+
* 它继承自 Layout 类,包含了用于绘制行中单元格(尤其是首列和尾列)的几个方法
|
8
|
+
*/
|
9
|
+
export class RecordRowLayout extends Layout {
|
10
|
+
// 首列
|
11
|
+
renderFirstCell({ row, style, isHoverRow, isCheckedRow }) {
|
12
|
+
if (!this.isFirst)
|
13
|
+
return;
|
14
|
+
const { fill } = style;
|
15
|
+
const y = this.y;
|
16
|
+
const rowHeight = this.rowHeight;
|
17
|
+
const columnWidth = this.columnWidth;
|
18
|
+
const colors = AITable.getColors();
|
19
|
+
// 编号的上下边框
|
20
|
+
let fillBg = colors.transparent;
|
21
|
+
if (isCheckedRow) {
|
22
|
+
fillBg = colors.itemActiveBgColor;
|
23
|
+
}
|
24
|
+
else if (isHoverRow) {
|
25
|
+
fillBg = colors.gray80;
|
26
|
+
}
|
27
|
+
this.customRect({
|
28
|
+
x: AI_TABLE_OFFSET,
|
29
|
+
y,
|
30
|
+
width: AI_TABLE_ROW_HEAD_WIDTH - AI_TABLE_OFFSET,
|
31
|
+
height: rowHeight,
|
32
|
+
fill: fillBg,
|
33
|
+
strokes: {
|
34
|
+
right: colors.gray200,
|
35
|
+
bottom: colors.gray200
|
36
|
+
}
|
37
|
+
});
|
38
|
+
// 第一列单元格
|
39
|
+
this.rect({
|
40
|
+
x: AI_TABLE_ROW_HEAD_WIDTH,
|
41
|
+
y,
|
42
|
+
width: columnWidth + AI_TABLE_OFFSET,
|
43
|
+
height: rowHeight,
|
44
|
+
fill: fill,
|
45
|
+
stroke: colors.gray200
|
46
|
+
});
|
47
|
+
if (!isCheckedRow && !isHoverRow) {
|
48
|
+
// 设置字体样式,居中绘制行号
|
49
|
+
this.setStyle({ fontSize: DEFAULT_FONT_SIZE });
|
50
|
+
this.text({
|
51
|
+
x: AI_TABLE_ROW_HEAD_WIDTH / 2,
|
52
|
+
y: y + AI_TABLE_FIELD_HEAD_HEIGHT / 2,
|
53
|
+
text: String(row.displayIndex),
|
54
|
+
textAlign: DEFAULT_TEXT_ALIGN_CENTER,
|
55
|
+
verticalAlign: DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE
|
56
|
+
});
|
57
|
+
}
|
58
|
+
}
|
59
|
+
// 尾列
|
60
|
+
renderLastCell({ style }) {
|
61
|
+
if (!this.isLast || this.isFirst)
|
62
|
+
return;
|
63
|
+
const { fill, stroke } = style;
|
64
|
+
const columnWidth = this.columnWidth;
|
65
|
+
const width = columnWidth;
|
66
|
+
const colors = AITable.getColors();
|
67
|
+
// 背景、边框
|
68
|
+
this.rect({
|
69
|
+
x: this.x,
|
70
|
+
y: this.y,
|
71
|
+
width,
|
72
|
+
height: this.rowHeight,
|
73
|
+
fill: fill || colors.white,
|
74
|
+
stroke: stroke || colors.gray200
|
75
|
+
});
|
76
|
+
}
|
77
|
+
// 绘制中间的普通单元格
|
78
|
+
renderCommonCell({ style }) {
|
79
|
+
if (this.isFirst || this.isLast)
|
80
|
+
return;
|
81
|
+
const { fill, stroke } = style;
|
82
|
+
const colors = AITable.getColors();
|
83
|
+
// 背景、边框
|
84
|
+
this.rect({
|
85
|
+
x: this.x,
|
86
|
+
y: this.y,
|
87
|
+
width: this.columnWidth,
|
88
|
+
height: this.rowHeight,
|
89
|
+
fill: fill || colors.white,
|
90
|
+
stroke: stroke || colors.gray200
|
91
|
+
});
|
92
|
+
}
|
93
|
+
render(config) {
|
94
|
+
const { row, style, isCheckedRow, isHoverRow } = config;
|
95
|
+
this.renderFirstCell({ row, style, isCheckedRow, isHoverRow });
|
96
|
+
this.renderCommonCell({ style });
|
97
|
+
this.renderLastCell({ style });
|
98
|
+
}
|
99
|
+
}
|
100
|
+
export const recordRowLayout = new RecordRowLayout();
|
101
|
+
//# 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 { AI_TABLE_FIELD_HEAD_HEIGHT, AI_TABLE_OFFSET, AI_TABLE_ROW_HEAD_WIDTH, DEFAULT_FONT_SIZE } 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    // 首列\n    private renderFirstCell({ row, style, isHoverRow, isCheckedRow }: AITableCell) {\n        if (!this.isFirst) return;\n\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,\n            y,\n            width: AI_TABLE_ROW_HEAD_WIDTH - AI_TABLE_OFFSET,\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 / 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\n    // 尾列\n    private renderLastCell({ style }: Pick<AITableCell, 'style'>) {\n        if (!this.isLast || this.isFirst) return;\n\n        const { fill, stroke } = style;\n        const columnWidth = this.columnWidth;\n        const width = columnWidth;\n        const colors = AITable.getColors();\n\n        // 背景、边框\n        this.rect({\n            x: this.x,\n            y: this.y,\n            width,\n            height: this.rowHeight,\n            fill: fill || colors.white,\n            stroke: stroke || colors.gray200\n        });\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 });\n    }\n}\n\nexport const recordRowLayout = new RecordRowLayout();\n"]}
|
@@ -0,0 +1,4 @@
|
|
1
|
+
export * from './creations/create-active-cell-border';
|
2
|
+
export * from './creations/create-cells';
|
3
|
+
export * from './renderer.component';
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9ncmlkL3NyYy9yZW5kZXJlci9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHVDQUF1QyxDQUFDO0FBQ3RELGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyxzQkFBc0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY3JlYXRpb25zL2NyZWF0ZS1hY3RpdmUtY2VsbC1ib3JkZXInO1xuZXhwb3J0ICogZnJvbSAnLi9jcmVhdGlvbnMvY3JlYXRlLWNlbGxzJztcbmV4cG9ydCAqIGZyb20gJy4vcmVuZGVyZXIuY29tcG9uZW50JztcbiJdfQ==
|
@@ -0,0 +1,174 @@
|
|
1
|
+
import { ChangeDetectionStrategy, Component, computed, input, output } from '@angular/core';
|
2
|
+
import Konva from 'konva';
|
3
|
+
import { KoContainer, KoShape, KoStage } from '../angular-konva';
|
4
|
+
import { AI_TABLE_FIELD_ADD_BUTTON_WIDTH, AI_TABLE_ROW_HEAD_WIDTH } from '../constants';
|
5
|
+
import { AITable } from '../core';
|
6
|
+
import { getVisibleRangeInfo } from '../utils';
|
7
|
+
import { AITableAddField, AITableCells, AITableColumnHeads, AITableFieldHead, AITableFrozenCells, AITableFrozenColumnHeads, AITableFrozenPlaceholderCells, AITableHoverRowHeads, AITableIcon, AITableOtherRows, AITablePlaceholderCells } from './components';
|
8
|
+
import { createActiveCellBorder } from './creations/create-active-cell-border';
|
9
|
+
import * as i0 from "@angular/core";
|
10
|
+
Konva.pixelRatio = 2;
|
11
|
+
export class AITableRenderer {
|
12
|
+
constructor() {
|
13
|
+
this.config = input.required();
|
14
|
+
this.koMousemove = output();
|
15
|
+
this.koMousedown = output();
|
16
|
+
this.koWheel = output();
|
17
|
+
this.koClick = output();
|
18
|
+
this.koDblclick = output();
|
19
|
+
this.fields = computed(() => {
|
20
|
+
return AITable.getVisibleFields(this.config().aiTable);
|
21
|
+
});
|
22
|
+
this.coordinate = computed(() => {
|
23
|
+
return this.config()?.coordinate;
|
24
|
+
});
|
25
|
+
this.containerWidth = computed(() => {
|
26
|
+
return this.config().containerWidth;
|
27
|
+
});
|
28
|
+
this.containerHeight = computed(() => {
|
29
|
+
return this.config().containerHeight;
|
30
|
+
});
|
31
|
+
this.scrollState = computed(() => {
|
32
|
+
return this.config()?.aiTable.context.scrollState();
|
33
|
+
});
|
34
|
+
this.visibleRangeInfo = computed(() => {
|
35
|
+
return getVisibleRangeInfo(this.coordinate(), this.scrollState());
|
36
|
+
});
|
37
|
+
this.frozenAreaWidth = computed(() => {
|
38
|
+
return AI_TABLE_ROW_HEAD_WIDTH + this.coordinate().frozenColumnWidth;
|
39
|
+
});
|
40
|
+
this.lastColumnWidth = computed(() => {
|
41
|
+
return this.coordinate().getColumnWidth(this.visibleRangeInfo().columnStopIndex);
|
42
|
+
});
|
43
|
+
this.lastColumnOffset = computed(() => {
|
44
|
+
return this.coordinate().getColumnOffset(this.visibleRangeInfo().columnStopIndex);
|
45
|
+
});
|
46
|
+
this.cellGroupClipWidth = computed(() => {
|
47
|
+
const { scrollLeft } = this.scrollState();
|
48
|
+
return Math.min(this.containerWidth() - this.frozenAreaWidth(), AI_TABLE_FIELD_ADD_BUTTON_WIDTH + this.lastColumnOffset() + this.lastColumnWidth() - scrollLeft - this.frozenAreaWidth());
|
49
|
+
});
|
50
|
+
this.stageConfig = computed(() => {
|
51
|
+
const { isScrolling } = this.scrollState();
|
52
|
+
return {
|
53
|
+
width: this.containerWidth(),
|
54
|
+
height: this.containerHeight(),
|
55
|
+
listening: isScrolling ? false : true
|
56
|
+
};
|
57
|
+
});
|
58
|
+
this.gridGroupConfig = computed(() => {
|
59
|
+
return {
|
60
|
+
clipX: 0,
|
61
|
+
clipY: 0,
|
62
|
+
clipWidth: this.containerWidth(),
|
63
|
+
clipHeight: this.containerHeight()
|
64
|
+
};
|
65
|
+
});
|
66
|
+
this.commonGroupConfig = computed(() => {
|
67
|
+
return {
|
68
|
+
clipX: this.frozenAreaWidth() + 1,
|
69
|
+
clipY: 0,
|
70
|
+
clipWidth: this.cellGroupClipWidth(),
|
71
|
+
clipHeight: this.containerHeight()
|
72
|
+
};
|
73
|
+
});
|
74
|
+
this.attachGroupConfig = computed(() => {
|
75
|
+
return {
|
76
|
+
clipX: this.frozenAreaWidth() - 1,
|
77
|
+
clipY: this.coordinate().rowInitSize - 1,
|
78
|
+
clipWidth: this.containerWidth() - this.frozenAreaWidth(),
|
79
|
+
clipHeight: this.containerHeight() - this.coordinate().rowInitSize
|
80
|
+
};
|
81
|
+
});
|
82
|
+
this.frozenAttachGroupConfig = computed(() => {
|
83
|
+
return {
|
84
|
+
clipX: 0,
|
85
|
+
clipY: this.coordinate().rowInitSize - 1,
|
86
|
+
clipWidth: this.frozenAreaWidth() + 4,
|
87
|
+
clipHeight: this.containerHeight() - this.coordinate().rowInitSize
|
88
|
+
};
|
89
|
+
});
|
90
|
+
this.offsetYConfig = computed(() => {
|
91
|
+
const { scrollTop } = this.scrollState();
|
92
|
+
return {
|
93
|
+
offsetY: scrollTop
|
94
|
+
};
|
95
|
+
});
|
96
|
+
this.offsetXConfig = computed(() => {
|
97
|
+
const { scrollLeft } = this.scrollState();
|
98
|
+
return {
|
99
|
+
offsetX: scrollLeft
|
100
|
+
};
|
101
|
+
});
|
102
|
+
this.offsetConfig = computed(() => {
|
103
|
+
const { scrollLeft, scrollTop } = this.scrollState();
|
104
|
+
return {
|
105
|
+
offsetX: scrollLeft,
|
106
|
+
offsetY: scrollTop
|
107
|
+
};
|
108
|
+
});
|
109
|
+
this.columnHeadConfig = computed(() => {
|
110
|
+
const { columnStartIndex, columnStopIndex } = this.visibleRangeInfo();
|
111
|
+
const { aiTable, coordinate } = this.config();
|
112
|
+
const { pointPosition } = aiTable.context;
|
113
|
+
const fields = this.fields();
|
114
|
+
return {
|
115
|
+
aiTable,
|
116
|
+
coordinate,
|
117
|
+
fields,
|
118
|
+
columnStartIndex,
|
119
|
+
columnStopIndex,
|
120
|
+
pointPosition: pointPosition()
|
121
|
+
};
|
122
|
+
});
|
123
|
+
this.cellsConfig = computed(() => {
|
124
|
+
const { aiTable, coordinate, references } = this.config();
|
125
|
+
const { rowStartIndex, rowStopIndex, columnStartIndex, columnStopIndex } = this.visibleRangeInfo();
|
126
|
+
return {
|
127
|
+
aiTable,
|
128
|
+
coordinate,
|
129
|
+
references,
|
130
|
+
rowStartIndex,
|
131
|
+
rowStopIndex,
|
132
|
+
columnStartIndex,
|
133
|
+
columnStopIndex
|
134
|
+
};
|
135
|
+
});
|
136
|
+
this.activeCellBorderConfig = computed(() => {
|
137
|
+
return createActiveCellBorder(this.cellsConfig());
|
138
|
+
});
|
139
|
+
}
|
140
|
+
stageMousemove(e) {
|
141
|
+
this.koMousemove.emit(e);
|
142
|
+
}
|
143
|
+
stageMousedown(e) {
|
144
|
+
this.koMousedown.emit(e);
|
145
|
+
}
|
146
|
+
stageClick(e) {
|
147
|
+
this.koClick.emit(e);
|
148
|
+
}
|
149
|
+
stageDblclick(e) {
|
150
|
+
this.koDblclick.emit(e);
|
151
|
+
}
|
152
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AITableRenderer, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
153
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", 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", koWheel: "koWheel", koClick: "koClick", koDblclick: "koDblclick" }, ngImport: i0, template: "<ko-stage\n [config]=\"stageConfig()\"\n (koMousemove)=\"stageMousemove($event)\"\n (koMousedown)=\"stageMousedown($event)\"\n (koClick)=\"stageClick($event)\"\n (koDblclick)=\"stageDblclick($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]=\"columnHeadConfig()\"></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]=\"columnHeadConfig()\"></ai-table-column-heads>\n <ai-table-add-field\n [coordinate]=\"coordinate()\"\n [fields]=\"fields()\"\n [columnStopIndex]=\"visibleRangeInfo().columnStopIndex\"\n ></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 </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 </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: AITablePlaceholderCells, selector: "ai-table-placeholder-cells", inputs: ["config"] }, { kind: "component", type: AITableAddField, selector: "ai-table-add-field", inputs: ["coordinate", "fields", "columnStopIndex"] }, { 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 }); }
|
154
|
+
}
|
155
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AITableRenderer, decorators: [{
|
156
|
+
type: Component,
|
157
|
+
args: [{ selector: 'ai-table-renderer', standalone: true, imports: [
|
158
|
+
KoContainer,
|
159
|
+
KoStage,
|
160
|
+
KoShape,
|
161
|
+
AITableIcon,
|
162
|
+
AITableFieldHead,
|
163
|
+
AITableColumnHeads,
|
164
|
+
AITableFrozenColumnHeads,
|
165
|
+
AITableCells,
|
166
|
+
AITableFrozenCells,
|
167
|
+
AITableFrozenPlaceholderCells,
|
168
|
+
AITablePlaceholderCells,
|
169
|
+
AITableAddField,
|
170
|
+
AITableHoverRowHeads,
|
171
|
+
AITableOtherRows
|
172
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<ko-stage\n [config]=\"stageConfig()\"\n (koMousemove)=\"stageMousemove($event)\"\n (koMousedown)=\"stageMousedown($event)\"\n (koClick)=\"stageClick($event)\"\n (koDblclick)=\"stageDblclick($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]=\"columnHeadConfig()\"></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]=\"columnHeadConfig()\"></ai-table-column-heads>\n <ai-table-add-field\n [coordinate]=\"coordinate()\"\n [fields]=\"fields()\"\n [columnStopIndex]=\"visibleRangeInfo().columnStopIndex\"\n ></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 </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 </ko-group>\n </ko-group>\n </ko-group>\n </ko-layer>\n</ko-stage>\n\n<ng-content></ng-content>\n" }]
|
173
|
+
}] });
|
174
|
+
//# 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_FIELD_ADD_BUTTON_WIDTH, AI_TABLE_ROW_HEAD_WIDTH } from '../constants';\nimport { AITable } from '../core';\nimport { AITableRendererConfig } from '../types';\nimport { getVisibleRangeInfo } from '../utils';\nimport {\n    AITableAddField,\n    AITableCells,\n    AITableColumnHeads,\n    AITableFieldHead,\n    AITableFrozenCells,\n    AITableFrozenColumnHeads,\n    AITableFrozenPlaceholderCells,\n    AITableHoverRowHeads,\n    AITableIcon,\n    AITableOtherRows,\n    AITablePlaceholderCells\n} from './components';\nimport { createActiveCellBorder } from './creations/create-active-cell-border';\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        AITableIcon,\n        AITableFieldHead,\n        AITableColumnHeads,\n        AITableFrozenColumnHeads,\n        AITableCells,\n        AITableFrozenCells,\n        AITableFrozenPlaceholderCells,\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    koWheel = output<KoEventObject<WheelEvent>>();\n\n    koClick = output<KoEventObject<MouseEvent>>();\n\n    koDblclick = output<KoEventObject<MouseEvent>>();\n\n    fields = computed(() => {\n        return AITable.getVisibleFields(this.config().aiTable);\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        const { scrollLeft } = this.scrollState()!;\n        return Math.min(\n            this.containerWidth() - this.frozenAreaWidth(),\n            AI_TABLE_FIELD_ADD_BUTTON_WIDTH + this.lastColumnOffset() + this.lastColumnWidth() - scrollLeft - this.frozenAreaWidth()\n        );\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    columnHeadConfig = computed(() => {\n        const { columnStartIndex, columnStopIndex } = this.visibleRangeInfo();\n        const { aiTable, coordinate } = 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        };\n    });\n\n    cellsConfig = computed(() => {\n        const { aiTable, coordinate, references } = this.config();\n        const { rowStartIndex, rowStopIndex, columnStartIndex, columnStopIndex } = this.visibleRangeInfo();\n        return {\n            aiTable,\n            coordinate,\n            references,\n            rowStartIndex,\n            rowStopIndex,\n            columnStartIndex,\n            columnStopIndex\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    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","<ko-stage\n    [config]=\"stageConfig()\"\n    (koMousemove)=\"stageMousemove($event)\"\n    (koMousedown)=\"stageMousedown($event)\"\n    (koClick)=\"stageClick($event)\"\n    (koDblclick)=\"stageDblclick($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]=\"columnHeadConfig()\"></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]=\"columnHeadConfig()\"></ai-table-column-heads>\n                    <ai-table-add-field\n                        [coordinate]=\"coordinate()\"\n                        [fields]=\"fields()\"\n                        [columnStopIndex]=\"visibleRangeInfo().columnStopIndex\"\n                    ></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                </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                </ko-group>\n            </ko-group>\n        </ko-group>\n    </ko-layer>\n</ko-stage>\n\n<ng-content></ng-content>\n"]}
|