@ai-table/grid 0.0.54 → 0.0.56
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/components/cell-editors/cell-editor.scss +1 -2
- package/components/drag/drag.component.d.ts +1 -0
- package/components/drag/drag.component.d.ts.map +1 -1
- package/components/index.d.ts +0 -1
- package/components/index.d.ts.map +1 -1
- package/constants/editor.d.ts.map +1 -1
- package/constants/grid.d.ts.map +1 -1
- package/constants/icon.d.ts +1 -0
- package/constants/icon.d.ts.map +1 -1
- package/constants/table.d.ts +4 -1
- package/constants/table.d.ts.map +1 -1
- package/core/types/core.d.ts +4 -0
- package/core/types/core.d.ts.map +1 -1
- package/esm2022/components/drag/drag.component.mjs +42 -2
- package/esm2022/components/index.mjs +1 -2
- package/esm2022/constants/editor.mjs +2 -3
- package/esm2022/constants/grid.mjs +2 -2
- package/esm2022/constants/icon.mjs +2 -1
- package/esm2022/constants/table.mjs +5 -2
- package/esm2022/core/types/core.mjs +1 -1
- package/esm2022/grid-base.component.mjs +6 -4
- package/esm2022/grid.component.mjs +40 -4
- package/esm2022/renderer/components/cells/index.mjs +2 -1
- package/esm2022/renderer/components/cells/rate.component.mjs +150 -0
- package/esm2022/renderer/components/frozen-heads.component.mjs +17 -5
- package/esm2022/renderer/components/hover-cell.component.mjs +6 -5
- package/esm2022/renderer/components/hover-row-heads.component.mjs +20 -3
- package/esm2022/renderer/components/icon.component.mjs +6 -2
- package/esm2022/renderer/creations/create-active-cell-border.mjs +3 -3
- package/esm2022/renderer/creations/create-cells.mjs +2 -2
- package/esm2022/renderer/drawers/add-row-layout-drawer.mjs +5 -5
- package/esm2022/renderer/drawers/cell-drawer.mjs +30 -32
- package/esm2022/renderer/drawers/record-row-layout-drawer.mjs +5 -5
- package/esm2022/renderer/interfaces/hover-cell.mjs +1 -1
- package/esm2022/renderer/renderer.component.mjs +6 -6
- package/esm2022/types/cell.mjs +1 -1
- package/esm2022/types/component-config.mjs +1 -1
- package/esm2022/types/grid.mjs +1 -1
- package/esm2022/utils/cell.mjs +5 -3
- package/esm2022/utils/style.mjs +9 -3
- package/fesm2022/ai-table-grid.mjs +2917 -2674
- package/fesm2022/ai-table-grid.mjs.map +1 -1
- package/grid-base.component.d.ts +5 -3
- package/grid-base.component.d.ts.map +1 -1
- package/grid.component.d.ts +1 -0
- package/grid.component.d.ts.map +1 -1
- package/package.json +1 -1
- package/renderer/components/cells/index.d.ts +1 -0
- package/renderer/components/cells/index.d.ts.map +1 -1
- package/renderer/components/cells/rate.component.d.ts +38 -0
- package/renderer/components/cells/rate.component.d.ts.map +1 -0
- package/renderer/components/frozen-heads.component.d.ts +1 -0
- package/renderer/components/frozen-heads.component.d.ts.map +1 -1
- package/renderer/components/hover-cell.component.d.ts +2 -2
- package/renderer/components/hover-cell.component.d.ts.map +1 -1
- package/renderer/components/hover-row-heads.component.d.ts.map +1 -1
- package/renderer/components/icon.component.d.ts.map +1 -1
- package/renderer/creations/create-cells.d.ts +2 -1
- package/renderer/creations/create-cells.d.ts.map +1 -1
- package/renderer/drawers/add-row-layout-drawer.d.ts.map +1 -1
- package/renderer/drawers/cell-drawer.d.ts.map +1 -1
- package/renderer/drawers/record-row-layout-drawer.d.ts.map +1 -1
- package/renderer/interfaces/hover-cell.d.ts.map +1 -1
- package/renderer/renderer.component.d.ts +4 -12
- package/renderer/renderer.component.d.ts.map +1 -1
- package/types/cell.d.ts +5 -2
- package/types/cell.d.ts.map +1 -1
- package/types/component-config.d.ts +5 -2
- package/types/component-config.d.ts.map +1 -1
- package/types/grid.d.ts +4 -1
- package/types/grid.d.ts.map +1 -1
- package/utils/cell.d.ts +1 -1
- package/utils/cell.d.ts.map +1 -1
- package/utils/style.d.ts +1 -1
- package/utils/style.d.ts.map +1 -1
- package/components/cell-editors/rating/rating-editor.component.d.ts +0 -7
- package/components/cell-editors/rating/rating-editor.component.d.ts.map +0 -1
- package/components/cell-editors/rating/rating-editor.component.scss +0 -10
- package/esm2022/components/cell-editors/rating/rating-editor.component.mjs +0 -24
@@ -0,0 +1,150 @@
|
|
1
|
+
import { Component, computed, input, signal } from '@angular/core';
|
2
|
+
import { ChangeDetectionStrategy } from '@angular/core';
|
3
|
+
import { KoShape } from '../../../angular-konva';
|
4
|
+
import { AITableFieldType } from '../../../core';
|
5
|
+
import { generateTargetName } from '../../../utils';
|
6
|
+
import { isActiveCell } from '../../../renderer';
|
7
|
+
import { StarFill, Colors, AI_TABLE_CELL_EMOJI_PADDING, AI_TABLE_CELL_PADDING, AI_TABLE_ROW_BLANK_HEIGHT, AI_TABLE_CELL_EMOJI_SIZE, AI_TABLE_OFFSET, AI_TABLE_CELL, AI_TABLE_RATE_MAX, AI_TABLE_CELL_BORDER } from '../../../constants';
|
8
|
+
import * as i0 from "@angular/core";
|
9
|
+
export class AITableCellRate {
|
10
|
+
constructor() {
|
11
|
+
this.pointerX = signal(0);
|
12
|
+
this.pointerY = signal(0);
|
13
|
+
this.resetStatus = signal(false);
|
14
|
+
this.config = input();
|
15
|
+
this.readonly = computed(() => {
|
16
|
+
return this.config()?.readonly;
|
17
|
+
});
|
18
|
+
this.whiteBgConfig = computed(() => {
|
19
|
+
const { aiTable, render, field, recordId, coordinate } = this.config();
|
20
|
+
const pointPosition = aiTable.context.pointPosition();
|
21
|
+
const { x, y } = render;
|
22
|
+
const { columnIndex } = pointPosition;
|
23
|
+
const isActive = isActiveCell([recordId, field._id], aiTable);
|
24
|
+
return {
|
25
|
+
x: x - AI_TABLE_CELL_PADDING + AI_TABLE_CELL_BORDER,
|
26
|
+
y: y + AI_TABLE_CELL_BORDER + AI_TABLE_OFFSET,
|
27
|
+
width: coordinate.getColumnWidth(columnIndex) - (AI_TABLE_CELL_BORDER + AI_TABLE_OFFSET) * 2,
|
28
|
+
height: AI_TABLE_ROW_BLANK_HEIGHT - (AI_TABLE_CELL_BORDER + AI_TABLE_OFFSET),
|
29
|
+
fill: Colors.white,
|
30
|
+
stroke: isActive ? null : Colors.white,
|
31
|
+
zIndex: 0,
|
32
|
+
name: generateTargetName({
|
33
|
+
targetName: AI_TABLE_CELL,
|
34
|
+
fieldId: field._id,
|
35
|
+
recordId
|
36
|
+
})
|
37
|
+
};
|
38
|
+
});
|
39
|
+
this.starConfigs = computed(() => {
|
40
|
+
const { render, field, recordId, readonly, aiTable, coordinate } = this.config();
|
41
|
+
const { x, transformValue } = render;
|
42
|
+
const max = AI_TABLE_RATE_MAX;
|
43
|
+
const starY = (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_CELL_EMOJI_SIZE) / 2 + AI_TABLE_OFFSET;
|
44
|
+
const pointPosition = aiTable.context.pointPosition();
|
45
|
+
const { rowIndex, columnIndex } = pointPosition;
|
46
|
+
const { scrollLeft, scrollTop } = aiTable.context.scrollState();
|
47
|
+
const columnLeftX = coordinate.getColumnOffset(columnIndex) - scrollLeft + AI_TABLE_OFFSET;
|
48
|
+
const columnTopY = coordinate.getRowOffset(rowIndex) - scrollTop + AI_TABLE_OFFSET;
|
49
|
+
const firstStarLeftX = columnLeftX + AI_TABLE_CELL_PADDING;
|
50
|
+
const lastStarRightX = columnLeftX + AI_TABLE_CELL_PADDING + max * AI_TABLE_CELL_EMOJI_SIZE + (max - 1) * AI_TABLE_CELL_EMOJI_PADDING;
|
51
|
+
const startTopY = columnTopY + starY;
|
52
|
+
const startBottomY = columnTopY + starY + AI_TABLE_CELL_EMOJI_SIZE;
|
53
|
+
const isHoverStar = this.pointerX() >= firstStarLeftX &&
|
54
|
+
this.pointerX() <= lastStarRightX &&
|
55
|
+
this.pointerY() >= startTopY &&
|
56
|
+
this.pointerY() <= startBottomY;
|
57
|
+
return [...Array(max).keys()].map((item, index) => {
|
58
|
+
const value = index + 1;
|
59
|
+
const checked = value <= transformValue;
|
60
|
+
const starX = x + index * (AI_TABLE_CELL_EMOJI_SIZE + AI_TABLE_CELL_EMOJI_PADDING);
|
61
|
+
let fill = null;
|
62
|
+
if (this.resetStatus()) {
|
63
|
+
fill = Colors.gray100;
|
64
|
+
}
|
65
|
+
else {
|
66
|
+
if (isHoverStar) {
|
67
|
+
fill = columnLeftX + starX <= this.pointerX() ? Colors.waring : Colors.gray100;
|
68
|
+
}
|
69
|
+
else {
|
70
|
+
fill = checked ? Colors.waring : Colors.gray100;
|
71
|
+
}
|
72
|
+
}
|
73
|
+
return {
|
74
|
+
x: starX,
|
75
|
+
y: starY,
|
76
|
+
size: 22,
|
77
|
+
data: StarFill,
|
78
|
+
fill,
|
79
|
+
scaleX: 1.14,
|
80
|
+
scaleY: 1.14,
|
81
|
+
name: generateTargetName({
|
82
|
+
targetName: AI_TABLE_CELL,
|
83
|
+
fieldId: field._id,
|
84
|
+
recordId,
|
85
|
+
mouseStyle: readonly ? 'default' : 'pointer'
|
86
|
+
})
|
87
|
+
};
|
88
|
+
});
|
89
|
+
});
|
90
|
+
}
|
91
|
+
static { this.fieldType = AITableFieldType.rate; }
|
92
|
+
koMousemove(e) {
|
93
|
+
if (this.readonly()) {
|
94
|
+
return;
|
95
|
+
}
|
96
|
+
this.resetStatus.set(false);
|
97
|
+
const pos = e.event.target.getStage()?.getPointerPosition();
|
98
|
+
if (!pos)
|
99
|
+
return;
|
100
|
+
const { x, y } = pos;
|
101
|
+
this.pointerX.set(x);
|
102
|
+
this.pointerY.set(y);
|
103
|
+
}
|
104
|
+
koClick(e, index) {
|
105
|
+
if (this.readonly()) {
|
106
|
+
return;
|
107
|
+
}
|
108
|
+
this.resetStatus.set(false);
|
109
|
+
const { render, readonly, field, recordId, actions } = this.config();
|
110
|
+
const { transformValue } = render;
|
111
|
+
let value = index + 1;
|
112
|
+
if (transformValue === value) {
|
113
|
+
value = 0;
|
114
|
+
this.resetStatus.set(true);
|
115
|
+
}
|
116
|
+
if (!readonly && actions && actions.updateFieldValue) {
|
117
|
+
actions.updateFieldValue({
|
118
|
+
value,
|
119
|
+
path: [recordId, field._id]
|
120
|
+
});
|
121
|
+
}
|
122
|
+
}
|
123
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableCellRate, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
124
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: AITableCellRate, isStandalone: true, selector: "ai-table-rate", inputs: { config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: `
|
125
|
+
@if (!readonly()) {
|
126
|
+
<ko-rect [config]="whiteBgConfig()" (koMousemove)="koMousemove($event)"></ko-rect>
|
127
|
+
}
|
128
|
+
@for (config of starConfigs(); let index = $index; track $index) {
|
129
|
+
<ko-path [config]="config" (koClick)="koClick($event, index)"></ko-path>
|
130
|
+
}
|
131
|
+
`, isInline: true, dependencies: [{ kind: "component", type: KoShape, selector: "ko-shape, ko-circle, ko-label, ko-rect, ko-ellipse, ko-wedge, ko-line, ko-sprite, ko-image, ko-text, ko-text-path, ko-star, ko-ring, ko-arc, ko-tag, ko-path, ko-regular-polygon, ko-arrow, ko-transformer", inputs: ["config"], outputs: ["koMouseover", "koMousemove", "koMouseout", "koMouseenter", "koMouseleave", "koMousedown", "koMouseup", "koWheel", "koContextmenu", "koClick", "koDblclick", "koTouchstart", "koTouchmove", "koTouchend", "koTap", "koDbltap", "koDragstart", "koDragmove", "koDragend"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
132
|
+
}
|
133
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableCellRate, decorators: [{
|
134
|
+
type: Component,
|
135
|
+
args: [{
|
136
|
+
selector: 'ai-table-rate',
|
137
|
+
template: `
|
138
|
+
@if (!readonly()) {
|
139
|
+
<ko-rect [config]="whiteBgConfig()" (koMousemove)="koMousemove($event)"></ko-rect>
|
140
|
+
}
|
141
|
+
@for (config of starConfigs(); let index = $index; track $index) {
|
142
|
+
<ko-path [config]="config" (koClick)="koClick($event, index)"></ko-path>
|
143
|
+
}
|
144
|
+
`,
|
145
|
+
standalone: true,
|
146
|
+
imports: [KoShape],
|
147
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
148
|
+
}]
|
149
|
+
}] });
|
150
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rate.component.js","sourceRoot":"","sources":["../../../../../../packages/grid/src/renderer/components/cells/rate.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, input, signal } from '@angular/core';\nimport { ChangeDetectionStrategy } from '@angular/core';\nimport { KoShape, KoEventObject } from '../../../angular-konva';\nimport { HoverCellComponent } from '../../interfaces';\nimport { AITableHoverCellConfig } from '../../../types';\nimport { AITableFieldType } from '../../../core';\nimport { generateTargetName } from '../../../utils';\nimport { isActiveCell } from '../../../renderer';\nimport {\n    StarFill,\n    Colors,\n    AI_TABLE_CELL_EMOJI_PADDING,\n    AI_TABLE_CELL_PADDING,\n    AI_TABLE_ROW_BLANK_HEIGHT,\n    AI_TABLE_CELL_EMOJI_SIZE,\n    AI_TABLE_OFFSET,\n    AI_TABLE_CELL,\n    AI_TABLE_RATE_MAX,\n    AI_TABLE_CELL_BORDER\n} from '../../../constants';\n\n@Component({\n    selector: 'ai-table-rate',\n    template: `\n        @if (!readonly()) {\n            <ko-rect [config]=\"whiteBgConfig()\" (koMousemove)=\"koMousemove($event)\"></ko-rect>\n        }\n        @for (config of starConfigs(); let index = $index; track $index) {\n            <ko-path [config]=\"config\" (koClick)=\"koClick($event, index)\"></ko-path>\n        }\n    `,\n    standalone: true,\n    imports: [KoShape],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableCellRate implements HoverCellComponent {\n    static fieldType = AITableFieldType.rate;\n\n    private pointerX = signal<number>(0);\n\n    private pointerY = signal<number>(0);\n\n    private resetStatus = signal<boolean>(false);\n\n    config = input<AITableHoverCellConfig>();\n\n    readonly = computed(() => {\n        return this.config()?.readonly;\n    });\n\n    whiteBgConfig = computed(() => {\n        const { aiTable, render, field, recordId, coordinate } = this.config()!;\n        const pointPosition = aiTable.context!.pointPosition();\n        const { x, y } = render;\n        const { columnIndex } = pointPosition;\n        const isActive = isActiveCell([recordId!, field._id], aiTable);\n\n        return {\n            x: x - AI_TABLE_CELL_PADDING + AI_TABLE_CELL_BORDER,\n            y: y + AI_TABLE_CELL_BORDER + AI_TABLE_OFFSET,\n            width: coordinate.getColumnWidth(columnIndex) - (AI_TABLE_CELL_BORDER + AI_TABLE_OFFSET) * 2,\n            height: AI_TABLE_ROW_BLANK_HEIGHT - (AI_TABLE_CELL_BORDER + AI_TABLE_OFFSET),\n            fill: Colors.white,\n            stroke: isActive ? null : Colors.white,\n            zIndex: 0,\n            name: generateTargetName({\n                targetName: AI_TABLE_CELL,\n                fieldId: field._id,\n                recordId\n            })\n        };\n    });\n\n    starConfigs = computed(() => {\n        const { render, field, recordId, readonly, aiTable, coordinate } = this.config()!;\n        const { x, transformValue } = render;\n        const max = AI_TABLE_RATE_MAX;\n        const starY = (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_CELL_EMOJI_SIZE) / 2 + AI_TABLE_OFFSET;\n\n        const pointPosition = aiTable.context!.pointPosition();\n        const { rowIndex, columnIndex } = pointPosition;\n        const { scrollLeft, scrollTop } = aiTable.context!.scrollState();\n        const columnLeftX = coordinate.getColumnOffset(columnIndex) - scrollLeft + AI_TABLE_OFFSET;\n        const columnTopY = coordinate.getRowOffset(rowIndex) - scrollTop + AI_TABLE_OFFSET;\n        const firstStarLeftX = columnLeftX + AI_TABLE_CELL_PADDING;\n        const lastStarRightX =\n            columnLeftX + AI_TABLE_CELL_PADDING + max * AI_TABLE_CELL_EMOJI_SIZE + (max - 1) * AI_TABLE_CELL_EMOJI_PADDING;\n        const startTopY = columnTopY + starY;\n        const startBottomY = columnTopY + starY + AI_TABLE_CELL_EMOJI_SIZE;\n\n        const isHoverStar =\n            this.pointerX() >= firstStarLeftX &&\n            this.pointerX() <= lastStarRightX &&\n            this.pointerY() >= startTopY &&\n            this.pointerY() <= startBottomY;\n\n        return [...Array(max).keys()].map((item, index) => {\n            const value = index + 1;\n            const checked = value <= transformValue;\n            const starX = x + index * (AI_TABLE_CELL_EMOJI_SIZE + AI_TABLE_CELL_EMOJI_PADDING);\n\n            let fill = null;\n            if (this.resetStatus()) {\n                fill = Colors.gray100;\n            } else {\n                if (isHoverStar) {\n                    fill = columnLeftX + starX <= this.pointerX() ? Colors.waring : Colors.gray100;\n                } else {\n                    fill = checked ? Colors.waring : Colors.gray100;\n                }\n            }\n\n            return {\n                x: starX,\n                y: starY,\n                size: 22,\n                data: StarFill,\n                fill,\n                scaleX: 1.14,\n                scaleY: 1.14,\n                name: generateTargetName({\n                    targetName: AI_TABLE_CELL,\n                    fieldId: field._id,\n                    recordId,\n                    mouseStyle: readonly ? 'default' : 'pointer'\n                })\n            };\n        });\n    });\n\n    koMousemove(e: KoEventObject<MouseEvent>) {\n        if (this.readonly()) {\n            return;\n        }\n\n        this.resetStatus.set(false);\n        const pos = e.event.target.getStage()?.getPointerPosition();\n        if (!pos) return;\n        const { x, y } = pos;\n        this.pointerX.set(x);\n        this.pointerY.set(y);\n    }\n\n    koClick(e: KoEventObject<MouseEvent>, index: number) {\n        if (this.readonly()) {\n            return;\n        }\n\n        this.resetStatus.set(false);\n        const { render, readonly, field, recordId, actions } = this.config()!;\n        const { transformValue } = render;\n\n        let value = index + 1;\n        if (transformValue === value) {\n            value = 0;\n            this.resetStatus.set(true);\n        }\n\n        if (!readonly && actions && actions.updateFieldValue) {\n            actions.updateFieldValue({\n                value,\n                path: [recordId!, field._id]\n            });\n        }\n    }\n}\n"]}
|
@@ -1,6 +1,6 @@
|
|
1
1
|
import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';
|
2
2
|
import { KoShape, KoContainer } from '../../angular-konva';
|
3
|
-
import { AI_TABLE_CELL_PADDING, AI_TABLE_FIELD_HEAD_SELECT_CHECKBOX, AI_TABLE_ICON_COMMON_SIZE, AI_TABLE_OFFSET, AI_TABLE_ROW_HEAD_WIDTH, Colors } from '../../constants';
|
3
|
+
import { AI_TABLE_CELL_PADDING, AI_TABLE_FIELD_HEAD_SELECT_CHECKBOX, AI_TABLE_ICON_COMMON_SIZE, AI_TABLE_OFFSET, AI_TABLE_ROW_DRAG_ICON_WIDTH, AI_TABLE_ROW_HEAD_WIDTH, Colors } from '../../constants';
|
4
4
|
import { AITableCheckType, AITableSelectAllState } from '../../types';
|
5
5
|
import { createColumnHeads } from '../creations/create-heads';
|
6
6
|
import { AITableFieldHead } from './field-head.component';
|
@@ -26,6 +26,16 @@ export class AITableFrozenColumnHeads {
|
|
26
26
|
columnStopIndex: this.coordinate().frozenColumnCount - 1
|
27
27
|
});
|
28
28
|
});
|
29
|
+
this.dragHeadBgConfig = computed(() => {
|
30
|
+
return {
|
31
|
+
x: AI_TABLE_OFFSET,
|
32
|
+
y: AI_TABLE_OFFSET,
|
33
|
+
width: AI_TABLE_ROW_DRAG_ICON_WIDTH,
|
34
|
+
height: this.fieldHeadHeight(),
|
35
|
+
fill: Colors.white,
|
36
|
+
listening: false
|
37
|
+
};
|
38
|
+
});
|
29
39
|
this.numberHeadBgConfig = computed(() => {
|
30
40
|
return {
|
31
41
|
x: AI_TABLE_OFFSET,
|
@@ -37,7 +47,7 @@ export class AITableFrozenColumnHeads {
|
|
37
47
|
};
|
38
48
|
});
|
39
49
|
this.topLineConfig = {
|
40
|
-
x: AI_TABLE_OFFSET,
|
50
|
+
x: AI_TABLE_OFFSET + AI_TABLE_ROW_DRAG_ICON_WIDTH,
|
41
51
|
y: AI_TABLE_OFFSET,
|
42
52
|
points: [0, 0, AI_TABLE_ROW_HEAD_WIDTH, 0],
|
43
53
|
stroke: Colors.gray200,
|
@@ -46,7 +56,7 @@ export class AITableFrozenColumnHeads {
|
|
46
56
|
};
|
47
57
|
this.bottomLineConfig = computed(() => {
|
48
58
|
return {
|
49
|
-
x: AI_TABLE_OFFSET,
|
59
|
+
x: AI_TABLE_OFFSET + AI_TABLE_ROW_DRAG_ICON_WIDTH,
|
50
60
|
y: AI_TABLE_OFFSET,
|
51
61
|
points: [AI_TABLE_ROW_HEAD_WIDTH, this.fieldHeadHeight(), 0, this.fieldHeadHeight()],
|
52
62
|
stroke: Colors.gray200,
|
@@ -57,7 +67,7 @@ export class AITableFrozenColumnHeads {
|
|
57
67
|
this.iconConfig = computed(() => {
|
58
68
|
return {
|
59
69
|
name: AI_TABLE_FIELD_HEAD_SELECT_CHECKBOX,
|
60
|
-
x: AI_TABLE_CELL_PADDING,
|
70
|
+
x: AI_TABLE_CELL_PADDING + AI_TABLE_ROW_DRAG_ICON_WIDTH,
|
61
71
|
y: (this.fieldHeadHeight() - AI_TABLE_ICON_COMMON_SIZE) / 2,
|
62
72
|
type: this.isChecked() ? AITableCheckType.checked : AITableCheckType.unchecked,
|
63
73
|
fill: this.isChecked() || (this.config().pointPosition.targetName === AI_TABLE_FIELD_HEAD_SELECT_CHECKBOX && !this.isChecked())
|
@@ -81,6 +91,7 @@ export class AITableFrozenColumnHeads {
|
|
81
91
|
}
|
82
92
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableFrozenColumnHeads, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
83
93
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: AITableFrozenColumnHeads, isStandalone: true, selector: "ai-table-frozen-column-heads", inputs: { config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: `
|
94
|
+
<ko-rect [config]="dragHeadBgConfig()"></ko-rect>
|
84
95
|
<ko-rect [config]="numberHeadBgConfig()"></ko-rect>
|
85
96
|
<ko-line [config]="topLineConfig"></ko-line>
|
86
97
|
<ko-line [config]="bottomLineConfig()"></ko-line>
|
@@ -98,6 +109,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
98
109
|
args: [{
|
99
110
|
selector: 'ai-table-frozen-column-heads',
|
100
111
|
template: `
|
112
|
+
<ko-rect [config]="dragHeadBgConfig()"></ko-rect>
|
101
113
|
<ko-rect [config]="numberHeadBgConfig()"></ko-rect>
|
102
114
|
<ko-line [config]="topLineConfig"></ko-line>
|
103
115
|
<ko-line [config]="bottomLineConfig()"></ko-line>
|
@@ -114,4 +126,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
114
126
|
changeDetection: ChangeDetectionStrategy.OnPush
|
115
127
|
}]
|
116
128
|
}] });
|
117
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"frozen-heads.component.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/components/frozen-heads.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';\nimport { StageConfig } from 'konva/lib/Stage';\nimport { KoShape, KoContainer } from '../../angular-konva';\nimport {\n    AI_TABLE_CELL_PADDING,\n    AI_TABLE_FIELD_HEAD_SELECT_CHECKBOX,\n    AI_TABLE_ICON_COMMON_SIZE,\n    AI_TABLE_OFFSET,\n    AI_TABLE_ROW_HEAD_WIDTH,\n    Colors\n} from '../../constants';\nimport { AITableCheckType, AITableColumnHeadsConfig, AITableSelectAllState } from '../../types';\nimport { createColumnHeads } from '../creations/create-heads';\nimport { AITableFieldHead } from './field-head.component';\nimport { AITableIcon } from './icon.component';\n\n@Component({\n    selector: 'ai-table-frozen-column-heads',\n    template: `\n        <ko-rect [config]=\"numberHeadBgConfig()\"></ko-rect>\n        <ko-line [config]=\"topLineConfig\"></ko-line>\n        <ko-line [config]=\"bottomLineConfig()\"></ko-line>\n        <ko-group>\n            <ai-table-icon [config]=\"iconConfig()\"></ai-table-icon>\n        </ko-group>\n        @for (config of headConfigs(); track $index) {\n            <ai-table-field-head [config]=\"config\"></ai-table-field-head>\n        }\n        <ko-rect [config]=\"headBgConfig()\"></ko-rect>\n    `,\n    standalone: true,\n    imports: [KoShape, AITableFieldHead, AITableIcon, KoContainer],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableFrozenColumnHeads {\n    config = input.required<AITableColumnHeadsConfig>();\n\n    coordinate = computed(() => {\n        return this.config().coordinate;\n    });\n\n    isChecked = computed(() => {\n        // 目前只需要展示全部选中和空的状态\n        return this.config().aiTable.selection().selectAllState === AITableSelectAllState.all;\n    });\n\n    fieldHeadHeight = computed(() => {\n        return this.coordinate().rowInitSize;\n    });\n\n    headConfigs = computed(() => {\n        return createColumnHeads({\n            ...this.config(),\n            columnStartIndex: 0,\n            columnStopIndex: this.coordinate().frozenColumnCount - 1\n        });\n    });\n\n    numberHeadBgConfig = computed<Partial<StageConfig>>(() => {\n        return {\n            x: AI_TABLE_OFFSET,\n            y: AI_TABLE_OFFSET,\n            width: AI_TABLE_ROW_HEAD_WIDTH,\n            height: this.fieldHeadHeight(),\n            fill: Colors.white,\n            listening: false\n        };\n    });\n\n    topLineConfig = {\n        x: AI_TABLE_OFFSET,\n        y: AI_TABLE_OFFSET,\n        points: [0, 0, AI_TABLE_ROW_HEAD_WIDTH, 0],\n        stroke: Colors.gray200,\n        strokeWidth: 1,\n        listening: false\n    };\n\n    bottomLineConfig = computed(() => {\n        return {\n            x: AI_TABLE_OFFSET,\n            y: AI_TABLE_OFFSET,\n            points: [AI_TABLE_ROW_HEAD_WIDTH, this.fieldHeadHeight(), 0, this.fieldHeadHeight()],\n            stroke: Colors.gray200,\n            strokeWidth: 1,\n            listening: false\n        };\n    });\n\n    iconConfig = computed(() => {\n        return {\n            name: AI_TABLE_FIELD_HEAD_SELECT_CHECKBOX,\n            x: AI_TABLE_CELL_PADDING,\n            y: (this.fieldHeadHeight() - AI_TABLE_ICON_COMMON_SIZE) / 2,\n            type: this.isChecked() ? AITableCheckType.checked : AITableCheckType.unchecked,\n            fill:\n                this.isChecked() || (this.config().pointPosition.targetName === AI_TABLE_FIELD_HEAD_SELECT_CHECKBOX && !this.isChecked())\n                    ? Colors.primary\n                    : Colors.gray300\n        };\n    });\n\n    headBgConfig = computed(() => {\n        const { frozenColumnWidth } = this.coordinate();\n        return {\n            x: AI_TABLE_ROW_HEAD_WIDTH,\n            y: AI_TABLE_OFFSET,\n            width: frozenColumnWidth + AI_TABLE_OFFSET,\n            height: this.fieldHeadHeight(),\n            stroke: Colors.gray200,\n            strokeWidth: 1,\n            fill: Colors.transparent,\n            listening: false\n        };\n    });\n}\n"]}
|
129
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"frozen-heads.component.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/components/frozen-heads.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';\nimport { StageConfig } from 'konva/lib/Stage';\nimport { KoShape, KoContainer } from '../../angular-konva';\nimport {\n    AI_TABLE_CELL_PADDING,\n    AI_TABLE_FIELD_HEAD_SELECT_CHECKBOX,\n    AI_TABLE_ICON_COMMON_SIZE,\n    AI_TABLE_OFFSET,\n    AI_TABLE_ROW_DRAG_ICON_WIDTH,\n    AI_TABLE_ROW_HEAD_WIDTH,\n    Colors\n} from '../../constants';\nimport { AITableCheckType, AITableColumnHeadsConfig, AITableSelectAllState } from '../../types';\nimport { createColumnHeads } from '../creations/create-heads';\nimport { AITableFieldHead } from './field-head.component';\nimport { AITableIcon } from './icon.component';\n\n@Component({\n    selector: 'ai-table-frozen-column-heads',\n    template: `\n        <ko-rect [config]=\"dragHeadBgConfig()\"></ko-rect>\n        <ko-rect [config]=\"numberHeadBgConfig()\"></ko-rect>\n        <ko-line [config]=\"topLineConfig\"></ko-line>\n        <ko-line [config]=\"bottomLineConfig()\"></ko-line>\n        <ko-group>\n            <ai-table-icon [config]=\"iconConfig()\"></ai-table-icon>\n        </ko-group>\n        @for (config of headConfigs(); track $index) {\n            <ai-table-field-head [config]=\"config\"></ai-table-field-head>\n        }\n        <ko-rect [config]=\"headBgConfig()\"></ko-rect>\n    `,\n    standalone: true,\n    imports: [KoShape, AITableFieldHead, AITableIcon, KoContainer],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableFrozenColumnHeads {\n    config = input.required<AITableColumnHeadsConfig>();\n\n    coordinate = computed(() => {\n        return this.config().coordinate;\n    });\n\n    isChecked = computed(() => {\n        // 目前只需要展示全部选中和空的状态\n        return this.config().aiTable.selection().selectAllState === AITableSelectAllState.all;\n    });\n\n    fieldHeadHeight = computed(() => {\n        return this.coordinate().rowInitSize;\n    });\n\n    headConfigs = computed(() => {\n        return createColumnHeads({\n            ...this.config(),\n            columnStartIndex: 0,\n            columnStopIndex: this.coordinate().frozenColumnCount - 1\n        });\n    });\n\n    dragHeadBgConfig = computed<Partial<StageConfig>>(() => {\n        return {\n            x: AI_TABLE_OFFSET,\n            y: AI_TABLE_OFFSET,\n            width: AI_TABLE_ROW_DRAG_ICON_WIDTH,\n            height: this.fieldHeadHeight(),\n            fill: Colors.white,\n            listening: false\n        };\n    });\n\n    numberHeadBgConfig = computed<Partial<StageConfig>>(() => {\n        return {\n            x: AI_TABLE_OFFSET,\n            y: AI_TABLE_OFFSET,\n            width: AI_TABLE_ROW_HEAD_WIDTH,\n            height: this.fieldHeadHeight(),\n            fill: Colors.white,\n            listening: false\n        };\n    });\n\n    topLineConfig = {\n        x: AI_TABLE_OFFSET + AI_TABLE_ROW_DRAG_ICON_WIDTH,\n        y: AI_TABLE_OFFSET,\n        points: [0, 0, AI_TABLE_ROW_HEAD_WIDTH, 0],\n        stroke: Colors.gray200,\n        strokeWidth: 1,\n        listening: false\n    };\n\n    bottomLineConfig = computed(() => {\n        return {\n            x: AI_TABLE_OFFSET + AI_TABLE_ROW_DRAG_ICON_WIDTH,\n            y: AI_TABLE_OFFSET,\n            points: [AI_TABLE_ROW_HEAD_WIDTH, this.fieldHeadHeight(), 0, this.fieldHeadHeight()],\n            stroke: Colors.gray200,\n            strokeWidth: 1,\n            listening: false\n        };\n    });\n\n    iconConfig = computed(() => {\n        return {\n            name: AI_TABLE_FIELD_HEAD_SELECT_CHECKBOX,\n            x: AI_TABLE_CELL_PADDING + AI_TABLE_ROW_DRAG_ICON_WIDTH,\n            y: (this.fieldHeadHeight() - AI_TABLE_ICON_COMMON_SIZE) / 2,\n            type: this.isChecked() ? AITableCheckType.checked : AITableCheckType.unchecked,\n            fill:\n                this.isChecked() || (this.config().pointPosition.targetName === AI_TABLE_FIELD_HEAD_SELECT_CHECKBOX && !this.isChecked())\n                    ? Colors.primary\n                    : Colors.gray300\n        };\n    });\n\n    headBgConfig = computed(() => {\n        const { frozenColumnWidth } = this.coordinate();\n        return {\n            x: AI_TABLE_ROW_HEAD_WIDTH,\n            y: AI_TABLE_OFFSET,\n            width: frozenColumnWidth + AI_TABLE_OFFSET,\n            height: this.fieldHeadHeight(),\n            stroke: Colors.gray200,\n            strokeWidth: 1,\n            fill: Colors.transparent,\n            listening: false\n        };\n    });\n}\n"]}
|
@@ -1,5 +1,5 @@
|
|
1
1
|
import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';
|
2
|
-
import { KoContainer
|
2
|
+
import { KoContainer } from '../../angular-konva';
|
3
3
|
import { AITableQueries } from '../../core';
|
4
4
|
import { CommonModule } from '@angular/common';
|
5
5
|
import { AI_TABLE_CELL_PADDING, AI_TABLE_OFFSET, DEFAULT_TEXT_ALIGN_LEFT, DEFAULT_TEXT_ALIGN_RIGHT } from '../../constants';
|
@@ -18,13 +18,13 @@ export class AITableHoverCells {
|
|
18
18
|
};
|
19
19
|
});
|
20
20
|
this.hoverCellConfig = computed(() => {
|
21
|
-
const { aiTable, coordinate, references, readonly } = this.config();
|
21
|
+
const { aiTable, coordinate, references, readonly, actions } = this.config();
|
22
22
|
const pointPosition = aiTable.context.pointPosition();
|
23
23
|
const hoverCell = this.hoverCell();
|
24
24
|
if (!hoverCell) {
|
25
25
|
return;
|
26
26
|
}
|
27
|
-
const { field, recordId
|
27
|
+
const { field, recordId } = hoverCell;
|
28
28
|
const cellValue = AITableQueries.getFieldValue(aiTable, [recordId, field._id]);
|
29
29
|
const transformValue = transformCellValue(aiTable, field, cellValue);
|
30
30
|
const { rowHeight, columnCount, rowCount } = coordinate;
|
@@ -54,6 +54,7 @@ export class AITableHoverCells {
|
|
54
54
|
x,
|
55
55
|
y,
|
56
56
|
readonly,
|
57
|
+
actions,
|
57
58
|
render: {
|
58
59
|
aiTable,
|
59
60
|
recordId,
|
@@ -96,8 +97,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
96
97
|
}
|
97
98
|
`,
|
98
99
|
standalone: true,
|
99
|
-
imports: [
|
100
|
+
imports: [KoContainer, CommonModule],
|
100
101
|
changeDetection: ChangeDetectionStrategy.OnPush
|
101
102
|
}]
|
102
103
|
}] });
|
103
|
-
//# sourceMappingURL=data:application/json;base64,
|
104
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hover-cell.component.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/components/hover-cell.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACpF,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAElD,OAAO,EAAoB,cAAc,EAAE,MAAM,YAAY,CAAC;AAC9D,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,qBAAqB,EAAE,eAAe,EAAE,uBAAuB,EAAE,wBAAwB,EAAE,MAAM,iBAAiB,CAAC;AAC5H,OAAO,EAAE,yBAAyB,EAAE,YAAY,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAC1F,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;;;AAmB5D,MAAM,OAAO,iBAAiB;IAd9B;QAeI,WAAM,GAAG,KAAK,CAAC,QAAQ,EAAsB,CAAC;QAE9C,iBAAY,GAAuE,EAAE,CAAC;QAEtF,gBAAW,GAAG,QAAQ,CAAC,GAAG,EAAE;YACxB,OAAO;gBACH,CAAC,EAAE,IAAI,CAAC,eAAe,EAAE,EAAE,CAAC;gBAC5B,CAAC,EAAE,IAAI,CAAC,eAAe,EAAE,EAAE,CAAC;aAC/B,CAAC;QACN,CAAC,CAAC,CAAC;QAEH,oBAAe,GAAG,QAAQ,CAAqC,GAAG,EAAE;YAChE,MAAM,EAAE,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,QAAQ,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;YAC7E,MAAM,aAAa,GAAG,OAAO,CAAC,OAAQ,CAAC,aAAa,EAAE,CAAC;YACvD,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;YACnC,IAAI,CAAC,SAAS,EAAE,CAAC;gBACb,OAAO;YACX,CAAC;YACD,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,GAAG,SAAS,CAAC;YACtC,MAAM,SAAS,GAAG,cAAc,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC,QAAQ,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC;YAC/E,MAAM,cAAc,GAAG,kBAAkB,CAAC,OAAO,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC;YAErE,MAAM,EAAE,SAAS,EAAE,WAAW,EAAE,QAAQ,EAAE,GAAG,UAAU,CAAC;YACxD,MAAM,WAAW,GAAG,aAAa,CAAC,WAAW,CAAC;YAC9C,MAAM,QAAQ,GAAG,aAAa,CAAC,QAAQ,CAAC;YAExC,MAAM,CAAC,GAAG,UAAU,CAAC,eAAe,CAAC,WAAW,CAAC,GAAG,eAAe,CAAC;YACpE,MAAM,WAAW,GAAG,UAAU,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC;YAC3D,MAAM,CAAC,GAAG,UAAU,CAAC,YAAY,CAAC,QAAQ,CAAC,GAAG,eAAe,CAAC;YAC9D,MAAM,EAAE,KAAK,EAAE,GAAG,yBAAyB,CAAC;gBACxC,WAAW;gBACX,WAAW;gBACX,WAAW;aACd,CAAC,CAAC;YAEH,MAAM,KAAK,GAAG;gBACV,SAAS,EAAE,uBAAuB;aAC9B,CAAC;YACT,MAAM,SAAS,GAAG,KAAK,CAAC,SAAS,CAAC;YAClC,MAAM,OAAO,GACT,SAAS,KAAK,wBAAwB;gBAClC,CAAC,CAAC,WAAW,GAAG,qBAAqB,GAAG,eAAe;gBACvD,CAAC,CAAC,qBAAqB,GAAG,eAAe,CAAC;YAClD,MAAM,OAAO,GAAG,CAAC,GAAG,eAAe,GAAG,CAAC,CAAC;YAExC,MAAM,MAAM,GAA2B;gBACnC,KAAK;gBACL,QAAQ;gBACR,OAAO;gBACP,UAAU;gBACV,CAAC;gBACD,CAAC;gBACD,QAAQ;gBACR,OAAO;gBACP,MAAM,EAAE;oBACJ,OAAO;oBACP,QAAQ;oBACR,KAAK;oBACL,QAAQ,EAAE,eAAe,CAAC,KAAK,CAAC,GAAG,EAAE,OAAO,CAAC;oBAC7C,CAAC,EAAE,OAAO;oBACV,CAAC,EAAE,OAAO;oBACV,WAAW,EAAE,KAAK;oBAClB,SAAS;oBACT,SAAS;oBACT,cAAc;oBACd,KAAK;oBACL,UAAU;iBACb;aACJ,CAAC;YAEF,OAAO,MAAM,CAAC;QAClB,CAAC,CAAC,CAAC;QAEH,cAAS,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC;KACnE;+GA3EY,iBAAiB;mGAAjB,iBAAiB,qNAZhB;;;;;;;KAOT,4DAES,WAAW,4EAAE,YAAY;;4FAG1B,iBAAiB;kBAd7B,SAAS;mBAAC;oBACP,QAAQ,EAAE,qBAAqB;oBAC/B,QAAQ,EAAE;;;;;;;KAOT;oBACD,UAAU,EAAE,IAAI;oBAChB,OAAO,EAAE,CAAC,WAAW,EAAE,YAAY,CAAC;oBACpC,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAClD","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';\nimport { KoContainer } from '../../angular-konva';\nimport { AITableCellsConfig, AITableHoverCellConfig } from '../../types';\nimport { AITableFieldType, AITableQueries } from '../../core';\nimport { CommonModule } from '@angular/common';\nimport { AI_TABLE_CELL_PADDING, AI_TABLE_OFFSET, DEFAULT_TEXT_ALIGN_LEFT, DEFAULT_TEXT_ALIGN_RIGHT } from '../../constants';\nimport { getCellHorizontalPosition, getHoverCell, transformCellValue } from '../../utils';\nimport { isSelectedField } from '../creations/create-cells';\nimport _ from 'lodash';\nimport { HoverCellComponent } from '../interfaces';\nimport { Constructor } from 'ngx-tethys/core';\n\n@Component({\n    selector: 'ai-table-hover-cell',\n    template: `\n        @if (hoverCell()) {\n            <ko-group [config]=\"groupConfig()\">\n                <ng-container *ngComponentOutlet=\"hoverCell()!.renderComponentDefinition; inputs: { config: hoverCellConfig() }\">\n                </ng-container>\n            </ko-group>\n        }\n    `,\n    standalone: true,\n    imports: [KoContainer, CommonModule],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableHoverCells {\n    config = input.required<AITableCellsConfig>();\n\n    componentMap: Partial<Record<AITableFieldType, Constructor<HoverCellComponent>>> = {};\n\n    groupConfig = computed(() => {\n        return {\n            x: this.hoverCellConfig()?.x,\n            y: this.hoverCellConfig()?.y\n        };\n    });\n\n    hoverCellConfig = computed<AITableHoverCellConfig | undefined>(() => {\n        const { aiTable, coordinate, references, readonly, actions } = this.config();\n        const pointPosition = aiTable.context!.pointPosition();\n        const hoverCell = this.hoverCell();\n        if (!hoverCell) {\n            return;\n        }\n        const { field, recordId } = hoverCell;\n        const cellValue = AITableQueries.getFieldValue(aiTable, [recordId, field._id]);\n        const transformValue = transformCellValue(aiTable, field, cellValue);\n\n        const { rowHeight, columnCount, rowCount } = coordinate;\n        const columnIndex = pointPosition.columnIndex;\n        const rowIndex = pointPosition.rowIndex;\n\n        const x = coordinate.getColumnOffset(columnIndex) + AI_TABLE_OFFSET;\n        const columnWidth = coordinate.getColumnWidth(columnIndex);\n        const y = coordinate.getRowOffset(rowIndex) + AI_TABLE_OFFSET;\n        const { width } = getCellHorizontalPosition({\n            columnWidth,\n            columnIndex,\n            columnCount\n        });\n\n        const style = {\n            textAlign: DEFAULT_TEXT_ALIGN_LEFT\n        } as any;\n        const textAlign = style.textAlign;\n        const renderX =\n            textAlign === DEFAULT_TEXT_ALIGN_RIGHT\n                ? columnWidth - AI_TABLE_CELL_PADDING + AI_TABLE_OFFSET\n                : AI_TABLE_CELL_PADDING + AI_TABLE_OFFSET;\n        const renderY = 0 - AI_TABLE_OFFSET * 2;\n\n        const result: AITableHoverCellConfig = {\n            field,\n            recordId,\n            aiTable,\n            coordinate,\n            x,\n            y,\n            readonly,\n            actions,\n            render: {\n                aiTable,\n                recordId,\n                field,\n                isActive: isSelectedField(field._id, aiTable),\n                x: renderX,\n                y: renderY,\n                columnWidth: width,\n                rowHeight,\n                cellValue,\n                transformValue,\n                style,\n                references\n            }\n        };\n\n        return result;\n    });\n\n    hoverCell = computed(() => getHoverCell(this.config().aiTable));\n}\n"]}
|
@@ -1,6 +1,7 @@
|
|
1
1
|
import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';
|
2
2
|
import { KoContainer, KoShape } from '../../angular-konva';
|
3
|
-
import { AI_TABLE_CELL_PADDING, AI_TABLE_FIELD_HEAD, AI_TABLE_FIELD_HEAD_HEIGHT, AI_TABLE_ROW_HEAD, AI_TABLE_ROW_HEAD_WIDTH, AI_TABLE_ROW_SELECT_CHECKBOX, Colors } from '../../constants';
|
3
|
+
import { AI_TABLE_CELL_PADDING, AI_TABLE_FIELD_HEAD, AI_TABLE_FIELD_HEAD_HEIGHT, AI_TABLE_ROW_DRAG, AI_TABLE_ROW_DRAG_ICON_WIDTH, AI_TABLE_ROW_HEAD, AI_TABLE_ROW_HEAD_WIDTH, AI_TABLE_ROW_SELECT_CHECKBOX, Colors } from '../../constants';
|
4
|
+
import { DragType } from '../../core';
|
4
5
|
import { AITableAreaType, AITableCheckType, AITableRowType } from '../../types';
|
5
6
|
import { generateTargetName } from '../../utils';
|
6
7
|
import { AITableIcon } from './icon.component';
|
@@ -58,11 +59,21 @@ export class AITableHoverRowHeads {
|
|
58
59
|
targetName: AI_TABLE_ROW_SELECT_CHECKBOX,
|
59
60
|
recordId
|
60
61
|
}),
|
61
|
-
x: AI_TABLE_CELL_PADDING,
|
62
|
+
x: AI_TABLE_CELL_PADDING + AI_TABLE_ROW_DRAG_ICON_WIDTH,
|
62
63
|
y: iconOffsetY,
|
63
64
|
type: isCheckedRow ? AITableCheckType.checked : AITableCheckType.unchecked,
|
64
65
|
fill: isCheckedRow || (targetName === AI_TABLE_ROW_SELECT_CHECKBOX && !isCheckedRow) ? Colors.primary : Colors.gray300
|
65
66
|
};
|
67
|
+
operationGroup.dragConfig = {
|
68
|
+
name: generateTargetName({
|
69
|
+
targetName: AI_TABLE_ROW_DRAG,
|
70
|
+
recordId
|
71
|
+
}),
|
72
|
+
x: 0,
|
73
|
+
y: iconOffsetY,
|
74
|
+
type: DragType.record,
|
75
|
+
fill: Colors.gray600
|
76
|
+
};
|
66
77
|
headConfigs.push(operationGroup);
|
67
78
|
}
|
68
79
|
}
|
@@ -79,6 +90,9 @@ export class AITableHoverRowHeads {
|
|
79
90
|
@if (config.iconConfig) {
|
80
91
|
<ai-table-icon [config]="config.iconConfig"></ai-table-icon>
|
81
92
|
}
|
93
|
+
@if (config.dragConfig) {
|
94
|
+
<ai-table-icon [config]="config.dragConfig"></ai-table-icon>
|
95
|
+
}
|
82
96
|
</ko-group>
|
83
97
|
}
|
84
98
|
`, isInline: true, dependencies: [{ kind: "component", type: KoContainer, selector: "ko-layer, ko-fastlayer, ko-group" }, { 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: AITableIcon, selector: "ai-table-icon", inputs: ["config"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
@@ -96,6 +110,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
96
110
|
@if (config.iconConfig) {
|
97
111
|
<ai-table-icon [config]="config.iconConfig"></ai-table-icon>
|
98
112
|
}
|
113
|
+
@if (config.dragConfig) {
|
114
|
+
<ai-table-icon [config]="config.dragConfig"></ai-table-icon>
|
115
|
+
}
|
99
116
|
</ko-group>
|
100
117
|
}
|
101
118
|
`,
|
@@ -104,4 +121,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
104
121
|
changeDetection: ChangeDetectionStrategy.OnPush
|
105
122
|
}]
|
106
123
|
}] });
|
107
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hover-row-heads.component.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/components/hover-row-heads.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';\nimport { KoContainer, KoShape } from '../../angular-konva';\nimport {\n    AI_TABLE_CELL_PADDING,\n    AI_TABLE_FIELD_HEAD,\n    AI_TABLE_FIELD_HEAD_HEIGHT,\n    AI_TABLE_ROW_HEAD,\n    AI_TABLE_ROW_HEAD_WIDTH,\n    AI_TABLE_ROW_SELECT_CHECKBOX,\n    Colors\n} from '../../constants';\nimport { RendererContext } from '../../core';\nimport { AITableAreaType, AITableCheckType, AITablePointPosition, AITableRowHeadsConfig, AITableRowType } from '../../types';\nimport { generateTargetName } from '../../utils';\nimport { AITableIcon } from './icon.component';\n\n@Component({\n    selector: 'ai-table-hover-row-heads',\n    template: `\n        @for (config of headConfigs(); track config.recordId) {\n            <ko-group [config]=\"{ x: 0, y: config.y, name: 'hover-heads' }\">\n                @if (config.bgConfig) {\n                    <ko-rect [config]=\"config.bgConfig\"></ko-rect>\n                }\n                @if (config.iconConfig) {\n                    <ai-table-icon [config]=\"config.iconConfig\"></ai-table-icon>\n                }\n            </ko-group>\n        }\n    `,\n    standalone: true,\n    imports: [KoContainer, KoShape, AITableIcon],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableHoverRowHeads {\n    config = input.required<AITableRowHeadsConfig>();\n\n    pointPosition = computed(() => {\n        return this.config().aiTable.context!.pointPosition();\n    });\n\n    headConfigs = computed(() => {\n        return this.createHoverRowHeads(this.pointPosition());\n    });\n\n    createHoverRowHeads = (pointPosition: AITablePointPosition) => {\n        const { coordinate, rowStartIndex, rowStopIndex, aiTable } = this.config();\n        const context = aiTable.context as RendererContext;\n        const headConfigs: any[] = [];\n\n        for (let rowIndex = rowStartIndex; rowIndex <= rowStopIndex; rowIndex++) {\n            if (rowIndex > coordinate.rowCount - 1) {\n                break;\n            }\n\n            const row = context.linearRows()[rowIndex];\n            if (row == null) {\n                continue;\n            }\n\n            const { type, _id: recordId } = row;\n            if (type !== AITableRowType.record || recordId == null) {\n                continue;\n            }\n\n            const isCheckedRow = aiTable.selection().selectedRecords.has(recordId);\n            const { areaType, rowIndex: pointRowIndex, targetName } = pointPosition;\n\n            if (!isCheckedRow && areaType === AITableAreaType.none) {\n                continue;\n            }\n\n            let isHoverRow;\n            if (pointRowIndex > -1 && !!context.linearRows().length && pointRowIndex < context.linearRows().length) {\n                const { type: pointRowType, _id: pointRecordId } = context.linearRows()[pointRowIndex];\n                isHoverRow = recordId === pointRecordId && pointRowType === AITableRowType.record && targetName !== AI_TABLE_FIELD_HEAD;\n            }\n\n            let operationGroup: { recordId: string; y: number; bgConfig: any; iconConfig?: any };\n\n            operationGroup = {\n                recordId,\n                y: coordinate.getRowOffset(rowIndex),\n                bgConfig: {\n                    name: generateTargetName({ targetName: AI_TABLE_ROW_HEAD, recordId }),\n                    width: AI_TABLE_ROW_HEAD_WIDTH + 1,\n                    height: coordinate.rowHeight,\n                    fill: Colors.transparent\n                }\n            };\n\n            if (isCheckedRow || isHoverRow) {\n                const iconOffsetY = (AI_TABLE_FIELD_HEAD_HEIGHT - 16) / 2;\n                operationGroup.iconConfig = {\n                    name: generateTargetName({\n                        targetName: AI_TABLE_ROW_SELECT_CHECKBOX,\n                        recordId\n                    }),\n                    x: AI_TABLE_CELL_PADDING,\n                    y: iconOffsetY,\n                    type: isCheckedRow ? AITableCheckType.checked : AITableCheckType.unchecked,\n                    fill: isCheckedRow || (targetName === AI_TABLE_ROW_SELECT_CHECKBOX && !isCheckedRow) ? Colors.primary : Colors.gray300\n                };\n                headConfigs.push(operationGroup);\n            }\n        }\n\n        return headConfigs;\n    };\n}\n"]}
|
124
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hover-row-heads.component.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/components/hover-row-heads.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';\nimport { KoContainer, KoShape } from '../../angular-konva';\nimport {\n    AI_TABLE_CELL_PADDING,\n    AI_TABLE_FIELD_HEAD,\n    AI_TABLE_FIELD_HEAD_HEIGHT,\n    AI_TABLE_ROW_DRAG,\n    AI_TABLE_ROW_DRAG_ICON_WIDTH,\n    AI_TABLE_ROW_HEAD,\n    AI_TABLE_ROW_HEAD_WIDTH,\n    AI_TABLE_ROW_SELECT_CHECKBOX,\n    Colors\n} from '../../constants';\nimport { DragType, RendererContext } from '../../core';\nimport { AITableAreaType, AITableCheckType, AITablePointPosition, AITableRowHeadsConfig, AITableRowType } from '../../types';\nimport { generateTargetName } from '../../utils';\nimport { AITableIcon } from './icon.component';\n\n@Component({\n    selector: 'ai-table-hover-row-heads',\n    template: `\n        @for (config of headConfigs(); track config.recordId) {\n            <ko-group [config]=\"{ x: 0, y: config.y, name: 'hover-heads' }\">\n                @if (config.bgConfig) {\n                    <ko-rect [config]=\"config.bgConfig\"></ko-rect>\n                }\n                @if (config.iconConfig) {\n                    <ai-table-icon [config]=\"config.iconConfig\"></ai-table-icon>\n                }\n                @if (config.dragConfig) {\n                    <ai-table-icon [config]=\"config.dragConfig\"></ai-table-icon>\n                }\n            </ko-group>\n        }\n    `,\n    standalone: true,\n    imports: [KoContainer, KoShape, AITableIcon],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableHoverRowHeads {\n    config = input.required<AITableRowHeadsConfig>();\n\n    pointPosition = computed(() => {\n        return this.config().aiTable.context!.pointPosition();\n    });\n\n    headConfigs = computed(() => {\n        return this.createHoverRowHeads(this.pointPosition());\n    });\n\n    createHoverRowHeads = (pointPosition: AITablePointPosition) => {\n        const { coordinate, rowStartIndex, rowStopIndex, aiTable } = this.config();\n        const context = aiTable.context as RendererContext;\n        const headConfigs: any[] = [];\n\n        for (let rowIndex = rowStartIndex; rowIndex <= rowStopIndex; rowIndex++) {\n            if (rowIndex > coordinate.rowCount - 1) {\n                break;\n            }\n\n            const row = context.linearRows()[rowIndex];\n            if (row == null) {\n                continue;\n            }\n\n            const { type, _id: recordId } = row;\n            if (type !== AITableRowType.record || recordId == null) {\n                continue;\n            }\n\n            const isCheckedRow = aiTable.selection().selectedRecords.has(recordId);\n            const { areaType, rowIndex: pointRowIndex, targetName } = pointPosition;\n\n            if (!isCheckedRow && areaType === AITableAreaType.none) {\n                continue;\n            }\n\n            let isHoverRow;\n            if (pointRowIndex > -1 && !!context.linearRows().length && pointRowIndex < context.linearRows().length) {\n                const { type: pointRowType, _id: pointRecordId } = context.linearRows()[pointRowIndex];\n                isHoverRow = recordId === pointRecordId && pointRowType === AITableRowType.record && targetName !== AI_TABLE_FIELD_HEAD;\n            }\n\n            let operationGroup: { recordId: string; y: number; bgConfig: any; iconConfig?: any; dragConfig?: any };\n\n            operationGroup = {\n                recordId,\n                y: coordinate.getRowOffset(rowIndex),\n                bgConfig: {\n                    name: generateTargetName({ targetName: AI_TABLE_ROW_HEAD, recordId }),\n                    width: AI_TABLE_ROW_HEAD_WIDTH + 1,\n                    height: coordinate.rowHeight,\n                    fill: Colors.transparent\n                }\n            };\n\n            if (isCheckedRow || isHoverRow) {\n                const iconOffsetY = (AI_TABLE_FIELD_HEAD_HEIGHT - 16) / 2;\n                operationGroup.iconConfig = {\n                    name: generateTargetName({\n                        targetName: AI_TABLE_ROW_SELECT_CHECKBOX,\n                        recordId\n                    }),\n                    x: AI_TABLE_CELL_PADDING + AI_TABLE_ROW_DRAG_ICON_WIDTH,\n                    y: iconOffsetY,\n                    type: isCheckedRow ? AITableCheckType.checked : AITableCheckType.unchecked,\n                    fill: isCheckedRow || (targetName === AI_TABLE_ROW_SELECT_CHECKBOX && !isCheckedRow) ? Colors.primary : Colors.gray300\n                };\n                operationGroup.dragConfig = {\n                    name: generateTargetName({\n                        targetName: AI_TABLE_ROW_DRAG,\n                        recordId\n                    }),\n                    x: 0,\n                    y: iconOffsetY,\n                    type: DragType.record,\n                    fill: Colors.gray600\n                };\n                headConfigs.push(operationGroup);\n            }\n        }\n\n        return headConfigs;\n    };\n}\n"]}
|
@@ -1,8 +1,9 @@
|
|
1
1
|
import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';
|
2
2
|
import { KoContainer } from '../../angular-konva';
|
3
3
|
import { KoShape } from '../../angular-konva/components/shape.component';
|
4
|
-
import { Check, Colors, DEFAULT_ICON_SIZE, Unchecked } from '../../constants';
|
4
|
+
import { Check, Colors, DEFAULT_ICON_SIZE, RowDragPath, Unchecked } from '../../constants';
|
5
5
|
import { AITableCheckType } from '../../types';
|
6
|
+
import { DragType } from '../../core';
|
6
7
|
import * as i0 from "@angular/core";
|
7
8
|
export class AITableIcon {
|
8
9
|
constructor() {
|
@@ -33,6 +34,9 @@ export class AITableIcon {
|
|
33
34
|
case AITableCheckType.unchecked:
|
34
35
|
pathData = Unchecked;
|
35
36
|
break;
|
37
|
+
case DragType.record:
|
38
|
+
pathData = RowDragPath;
|
39
|
+
break;
|
36
40
|
}
|
37
41
|
return {
|
38
42
|
x: backgroundWidth && (backgroundWidth - size * (scaleX || 1)) / 2,
|
@@ -77,4 +81,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
77
81
|
changeDetection: ChangeDetectionStrategy.OnPush
|
78
82
|
}]
|
79
83
|
}] });
|
80
|
-
//# sourceMappingURL=data:application/json;base64,
|
84
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWNvbi5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9ncmlkL3NyYy9yZW5kZXJlci9jb21wb25lbnRzL2ljb24uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsUUFBUSxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVwRixPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDbEQsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLGdEQUFnRCxDQUFDO0FBQ3pFLE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLGlCQUFpQixFQUFFLFdBQVcsRUFBRSxTQUFTLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMzRixPQUFPLEVBQUUsZ0JBQWdCLEVBQXFCLE1BQU0sYUFBYSxDQUFDO0FBQ2xFLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxZQUFZLENBQUM7O0FBY3RDLE1BQU0sT0FBTyxXQUFXO0lBWnhCO1FBYUksV0FBTSxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQXFCLENBQUM7UUFFN0MsZ0JBQVcsR0FBRyxRQUFRLENBQXVCLEdBQUcsRUFBRTtZQUM5QyxNQUFNLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxTQUFTLEVBQUUsR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDMUMsT0FBTyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsU0FBUyxFQUFFLENBQUM7UUFDL0IsQ0FBQyxDQUFDLENBQUM7UUFFSCxzQkFBaUIsR0FBRyxRQUFRLENBQUMsR0FBRyxFQUFFO1lBQzlCLE1BQU0sRUFDRixJQUFJLEVBQ0osZUFBZSxFQUNmLGdCQUFnQixFQUNoQixJQUFJLEdBQUcsaUJBQWlCLEVBQ3hCLFdBQVcsR0FBRyxDQUFDLEVBQ2YsVUFBVSxFQUNWLFlBQVksRUFDWixPQUFPLEVBQ1YsR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDbEIsT0FBTztnQkFDSCxJQUFJO2dCQUNKLEtBQUssRUFBRSxlQUFlLElBQUksSUFBSTtnQkFDOUIsTUFBTSxFQUFFLGdCQUFnQixJQUFJLElBQUk7Z0JBQ2hDLFdBQVcsRUFBRSxXQUFXO2dCQUN4QixJQUFJLEVBQUUsVUFBVSxJQUFJLE1BQU0sQ0FBQyxXQUFXO2dCQUN0QyxZQUFZO2dCQUNaLE9BQU87YUFDVixDQUFDO1FBQ04sQ0FBQyxDQUFDLENBQUM7UUFFSCxlQUFVLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRTtZQUN2QixNQUFNLEVBQ0YsSUFBSSxFQUNKLElBQUksRUFDSixlQUFlLEVBQ2YsZ0JBQWdCLEVBQ2hCLElBQUksR0FBRyxpQkFBaUIsRUFDeEIsTUFBTSxFQUNOLFdBQVcsR0FBRyxDQUFDLEVBQ2YsTUFBTSxFQUNOLE1BQU0sRUFDTixPQUFPLEVBQ1AsT0FBTyxFQUNQLFFBQVEsRUFDUixJQUFJLEdBQUcsTUFBTSxDQUFDLE9BQU8sRUFDckIsaUJBQWlCLEdBQUcsVUFBVSxFQUNqQyxHQUFHLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUVsQixJQUFJLFFBQVEsR0FBRyxJQUFJLENBQUM7WUFFcEIsUUFBUSxJQUFJLEVBQUUsQ0FBQztnQkFDWCxLQUFLLGdCQUFnQixDQUFDLE9BQU87b0JBQ3pCLFFBQVEsR0FBRyxLQUFLLENBQUM7b0JBQ2pCLE1BQU07Z0JBQ1YsS0FBSyxnQkFBZ0IsQ0FBQyxTQUFTO29CQUMzQixRQUFRLEdBQUcsU0FBUyxDQUFDO29CQUNyQixNQUFNO2dCQUNWLEtBQUssUUFBUSxDQUFDLE1BQU07b0JBQ2hCLFFBQVEsR0FBRyxXQUFXLENBQUM7b0JBQ3ZCLE1BQU07WUFDZCxDQUFDO1lBRUQsT0FBTztnQkFDSCxDQUFDLEVBQUUsZUFBZSxJQUFJLENBQUMsZUFBZSxHQUFHLElBQUksR0FBRyxDQUFDLE1BQU0sSUFBSSxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUM7Z0JBQ2xFLENBQUMsRUFBRSxnQkFBZ0IsSUFBSSxDQUFDLGdCQUFnQixHQUFHLElBQUksR0FBRyxDQUFDLE1BQU0sSUFBSSxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUM7Z0JBQ3BFLElBQUksRUFBRSxRQUFRO2dCQUNkLEtBQUssRUFBRSxJQUFJO2dCQUNYLE1BQU0sRUFBRSxJQUFJO2dCQUNaLElBQUk7Z0JBQ0osT0FBTztnQkFDUCxPQUFPO2dCQUNQLE1BQU07Z0JBQ04sTUFBTTtnQkFDTixRQUFRO2dCQUNSLE1BQU07Z0JBQ04sV0FBVztnQkFDWCxpQkFBaUI7Z0JBQ2pCLGtCQUFrQixFQUFFLEtBQUs7Z0JBQ3pCLFNBQVMsRUFBRSxLQUFLO2FBQ25CLENBQUM7UUFDTixDQUFDLENBQUMsQ0FBQztLQUNOOytHQWpGWSxXQUFXO21HQUFYLFdBQVcsK01BVlY7Ozs7O0tBS1QsNERBRVMsV0FBVyw2RUFBRSxPQUFPOzs0RkFHckIsV0FBVztrQkFadkIsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsZUFBZTtvQkFDekIsUUFBUSxFQUFFOzs7OztLQUtUO29CQUNELFVBQVUsRUFBRSxJQUFJO29CQUNoQixPQUFPLEVBQUUsQ0FBQyxXQUFXLEVBQUUsT0FBTyxDQUFDO29CQUMvQixlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDbEQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBjb21wdXRlZCwgaW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFN0YWdlQ29uZmlnIH0gZnJvbSAna29udmEvbGliL1N0YWdlJztcbmltcG9ydCB7IEtvQ29udGFpbmVyIH0gZnJvbSAnLi4vLi4vYW5ndWxhci1rb252YSc7XG5pbXBvcnQgeyBLb1NoYXBlIH0gZnJvbSAnLi4vLi4vYW5ndWxhci1rb252YS9jb21wb25lbnRzL3NoYXBlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDaGVjaywgQ29sb3JzLCBERUZBVUxUX0lDT05fU0laRSwgUm93RHJhZ1BhdGgsIFVuY2hlY2tlZCB9IGZyb20gJy4uLy4uL2NvbnN0YW50cyc7XG5pbXBvcnQgeyBBSVRhYmxlQ2hlY2tUeXBlLCBBSVRhYmxlSWNvbkNvbmZpZyB9IGZyb20gJy4uLy4uL3R5cGVzJztcbmltcG9ydCB7IERyYWdUeXBlIH0gZnJvbSAnLi4vLi4vY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnYWktdGFibGUtaWNvbicsXG4gICAgdGVtcGxhdGU6IGBcbiAgICAgICAgPGtvLWdyb3VwIFtjb25maWddPVwiZ3JvdXBDb25maWcoKVwiPlxuICAgICAgICAgICAgPGtvLXJlY3QgW2NvbmZpZ109XCJzcXVhcmVTaGFwZUNvbmZpZygpXCI+PC9rby1yZWN0PlxuICAgICAgICAgICAgPGtvLXBhdGggW2NvbmZpZ109XCJpY29uQ29uZmlnKClcIj48L2tvLXBhdGg+XG4gICAgICAgIDwva28tZ3JvdXA+XG4gICAgYCxcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIGltcG9ydHM6IFtLb0NvbnRhaW5lciwgS29TaGFwZV0sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgQUlUYWJsZUljb24ge1xuICAgIGNvbmZpZyA9IGlucHV0LnJlcXVpcmVkPEFJVGFibGVJY29uQ29uZmlnPigpO1xuXG4gICAgZ3JvdXBDb25maWcgPSBjb21wdXRlZDxQYXJ0aWFsPFN0YWdlQ29uZmlnPj4oKCkgPT4ge1xuICAgICAgICBjb25zdCB7IHgsIHksIGxpc3RlbmluZyB9ID0gdGhpcy5jb25maWcoKTtcbiAgICAgICAgcmV0dXJuIHsgeCwgeSwgbGlzdGVuaW5nIH07XG4gICAgfSk7XG5cbiAgICBzcXVhcmVTaGFwZUNvbmZpZyA9IGNvbXB1dGVkKCgpID0+IHtcbiAgICAgICAgY29uc3Qge1xuICAgICAgICAgICAgbmFtZSxcbiAgICAgICAgICAgIGJhY2tncm91bmRXaWR0aCxcbiAgICAgICAgICAgIGJhY2tncm91bmRIZWlnaHQsXG4gICAgICAgICAgICBzaXplID0gREVGQVVMVF9JQ09OX1NJWkUsXG4gICAgICAgICAgICBzdHJva2VXaWR0aCA9IDEsXG4gICAgICAgICAgICBiYWNrZ3JvdW5kLFxuICAgICAgICAgICAgY29ybmVyUmFkaXVzLFxuICAgICAgICAgICAgb3BhY2l0eVxuICAgICAgICB9ID0gdGhpcy5jb25maWcoKTtcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgIG5hbWUsXG4gICAgICAgICAgICB3aWR0aDogYmFja2dyb3VuZFdpZHRoIHx8IHNpemUsXG4gICAgICAgICAgICBoZWlnaHQ6IGJhY2tncm91bmRIZWlnaHQgfHwgc2l6ZSxcbiAgICAgICAgICAgIHN0cm9rZVdpZHRoOiBzdHJva2VXaWR0aCxcbiAgICAgICAgICAgIGZpbGw6IGJhY2tncm91bmQgfHwgQ29sb3JzLnRyYW5zcGFyZW50LFxuICAgICAgICAgICAgY29ybmVyUmFkaXVzLFxuICAgICAgICAgICAgb3BhY2l0eVxuICAgICAgICB9O1xuICAgIH0pO1xuXG4gICAgaWNvbkNvbmZpZyA9IGNvbXB1dGVkKCgpID0+IHtcbiAgICAgICAgY29uc3Qge1xuICAgICAgICAgICAgdHlwZSxcbiAgICAgICAgICAgIGRhdGEsXG4gICAgICAgICAgICBiYWNrZ3JvdW5kV2lkdGgsXG4gICAgICAgICAgICBiYWNrZ3JvdW5kSGVpZ2h0LFxuICAgICAgICAgICAgc2l6ZSA9IERFRkFVTFRfSUNPTl9TSVpFLFxuICAgICAgICAgICAgc3Ryb2tlLFxuICAgICAgICAgICAgc3Ryb2tlV2lkdGggPSAxLFxuICAgICAgICAgICAgc2NhbGVYLFxuICAgICAgICAgICAgc2NhbGVZLFxuICAgICAgICAgICAgb2Zmc2V0WCxcbiAgICAgICAgICAgIG9mZnNldFksXG4gICAgICAgICAgICByb3RhdGlvbixcbiAgICAgICAgICAgIGZpbGwgPSBDb2xvcnMuZ3JheTYwMCxcbiAgICAgICAgICAgIHRyYW5zZm9ybXNFbmFibGVkID0gJ3Bvc2l0aW9uJ1xuICAgICAgICB9ID0gdGhpcy5jb25maWcoKTtcblxuICAgICAgICBsZXQgcGF0aERhdGEgPSBkYXRhO1xuXG4gICAgICAgIHN3aXRjaCAodHlwZSkge1xuICAgICAgICAgICAgY2FzZSBBSVRhYmxlQ2hlY2tUeXBlLmNoZWNrZWQ6XG4gICAgICAgICAgICAgICAgcGF0aERhdGEgPSBDaGVjaztcbiAgICAgICAgICAgICAgICBicmVhaztcbiAgICAgICAgICAgIGNhc2UgQUlUYWJsZUNoZWNrVHlwZS51bmNoZWNrZWQ6XG4gICAgICAgICAgICAgICAgcGF0aERhdGEgPSBVbmNoZWNrZWQ7XG4gICAgICAgICAgICAgICAgYnJlYWs7XG4gICAgICAgICAgICBjYXNlIERyYWdUeXBlLnJlY29yZDpcbiAgICAgICAgICAgICAgICBwYXRoRGF0YSA9IFJvd0RyYWdQYXRoO1xuICAgICAgICAgICAgICAgIGJyZWFrO1xuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgIHg6IGJhY2tncm91bmRXaWR0aCAmJiAoYmFja2dyb3VuZFdpZHRoIC0gc2l6ZSAqIChzY2FsZVggfHwgMSkpIC8gMixcbiAgICAgICAgICAgIHk6IGJhY2tncm91bmRIZWlnaHQgJiYgKGJhY2tncm91bmRIZWlnaHQgLSBzaXplICogKHNjYWxlWSB8fCAxKSkgLyAyLFxuICAgICAgICAgICAgZGF0YTogcGF0aERhdGEsXG4gICAgICAgICAgICB3aWR0aDogc2l6ZSxcbiAgICAgICAgICAgIGhlaWdodDogc2l6ZSxcbiAgICAgICAgICAgIGZpbGwsXG4gICAgICAgICAgICBvZmZzZXRYLFxuICAgICAgICAgICAgb2Zmc2V0WSxcbiAgICAgICAgICAgIHNjYWxlWCxcbiAgICAgICAgICAgIHNjYWxlWSxcbiAgICAgICAgICAgIHJvdGF0aW9uLFxuICAgICAgICAgICAgc3Ryb2tlLFxuICAgICAgICAgICAgc3Ryb2tlV2lkdGgsXG4gICAgICAgICAgICB0cmFuc2Zvcm1zRW5hYmxlZCxcbiAgICAgICAgICAgIHBlcmZlY3REcmF3RW5hYmxlZDogZmFsc2UsXG4gICAgICAgICAgICBsaXN0ZW5pbmc6IGZhbHNlXG4gICAgICAgIH07XG4gICAgfSk7XG59XG4iXX0=
|
@@ -46,8 +46,8 @@ export const createActiveCellBorder = (config) => {
|
|
46
46
|
const currentConfig = {
|
47
47
|
x: x + offset + AI_TABLE_OFFSET,
|
48
48
|
y: y + AI_TABLE_OFFSET,
|
49
|
-
width: width -
|
50
|
-
height: rowHeight -
|
49
|
+
width: width - AI_TABLE_OFFSET,
|
50
|
+
height: rowHeight - AI_TABLE_OFFSET,
|
51
51
|
strokeWidth: AI_TABLE_CELL_BORDER,
|
52
52
|
stroke: colors.primary,
|
53
53
|
fillEnabled: false,
|
@@ -67,4 +67,4 @@ export const createActiveCellBorder = (config) => {
|
|
67
67
|
frozenActiveCellBorder
|
68
68
|
};
|
69
69
|
};
|
70
|
-
//# sourceMappingURL=data:application/json;base64,
|
70
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-active-cell-border.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/creations/create-active-cell-border.ts"],"names":[],"mappings":"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","sourcesContent":["import { RectConfig } from 'konva/lib/shapes/Rect';\nimport { AI_TABLE_CELL_BORDER, AI_TABLE_OFFSET } from '../../constants';\nimport { AITable } from '../../core';\nimport { AITableCellsConfig, AITableRowType } from '../../types';\nimport { getCellHorizontalPosition } from '../../utils';\n\nexport const createActiveCellBorder = (config: AITableCellsConfig) => {\n    const { aiTable, coordinate, columnStartIndex, columnStopIndex, rowStartIndex, rowStopIndex } = config;\n    const { linearRows } = aiTable.context!;\n    const { rowHeight, frozenColumnCount } = coordinate;\n    const colors = AITable.getColors();\n    const visibleColumns = AITable.getVisibleFields(aiTable);\n    const activeCell = AITable.getActiveCell(aiTable);\n    const totalColumnCount = visibleColumns.length;\n\n    let activeCellBorder: RectConfig | null = null;\n    let frozenActiveCellBorder: RectConfig | null = null;\n\n    if (\n        Array.isArray(activeCell) &&\n        !!activeCell.length &&\n        aiTable.context!.visibleRowsIndexMap().has(activeCell[0]) &&\n        aiTable.context!.visibleColumnsIndexMap().has(activeCell[1])\n    ) {\n        const fieldId = activeCell[1];\n        const { rowIndex, columnIndex } = AITable.getCellIndex(aiTable, activeCell)!;\n\n        const checkIsVisible = (rowIndex: number, columnIndex: number) => {\n            if (columnIndex < frozenColumnCount) {\n                return true;\n            }\n            return (\n                rowIndex >= rowStartIndex && rowIndex <= rowStopIndex && columnIndex >= columnStartIndex && columnIndex <= columnStopIndex\n            );\n        };\n\n        if (rowIndex != null && columnIndex != null && checkIsVisible(rowIndex, columnIndex)) {\n            const { type } = linearRows()[rowIndex];\n\n            if (type === AITableRowType.record) {\n                const activeField = visibleColumns.find((field) => field._id === fieldId);\n                if (activeField == null) {\n                    return {\n                        activeCellBorder,\n                        frozenActiveCellBorder\n                    };\n                }\n\n                const x = coordinate.getColumnOffset(columnIndex);\n                const y = coordinate.getRowOffset(rowIndex);\n                const columnWidth = coordinate.getColumnWidth(columnIndex);\n                const isFrozenColumn = columnIndex < frozenColumnCount;\n                const { offset, width } = getCellHorizontalPosition({\n                    columnWidth,\n                    columnIndex,\n                    columnCount: totalColumnCount\n                });\n                const currentConfig = {\n                    x: x + offset + AI_TABLE_OFFSET,\n                    y: y + AI_TABLE_OFFSET,\n                    width: width - AI_TABLE_OFFSET,\n                    height: rowHeight - AI_TABLE_OFFSET,\n                    strokeWidth: AI_TABLE_CELL_BORDER,\n                    stroke: colors.primary,\n                    fillEnabled: false,\n                    listening: false\n                };\n\n                if (isFrozenColumn) {\n                    frozenActiveCellBorder = currentConfig;\n                } else {\n                    activeCellBorder = currentConfig;\n                }\n            }\n        }\n    }\n\n    return {\n        activeCellBorder,\n        frozenActiveCellBorder\n    };\n};\n"]}
|