@ai-table/grid 0.0.43 → 0.0.44
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/angular-konva/interfaces/event-object.d.ts +4 -0
- package/angular-konva/interfaces/event-object.d.ts.map +1 -1
- package/components/field-menu/field-menu.component.d.ts +3 -2
- package/components/field-menu/field-menu.component.d.ts.map +1 -1
- package/constants/grid.d.ts.map +1 -1
- package/constants/table.d.ts +5 -1
- package/constants/table.d.ts.map +1 -1
- package/esm2022/angular-konva/interfaces/event-object.mjs +1 -1
- package/esm2022/components/field-menu/field-menu.component.mjs +9 -3
- package/esm2022/constants/grid.mjs +1 -2
- package/esm2022/constants/table.mjs +6 -2
- package/esm2022/grid-base.component.mjs +4 -2
- package/esm2022/grid.component.mjs +38 -22
- package/esm2022/renderer/components/action-icon.component.mjs +117 -0
- package/esm2022/renderer/components/cells/attachment.component.mjs +117 -0
- package/esm2022/renderer/components/cells/index.mjs +3 -1
- package/esm2022/renderer/components/hover-cell.component.mjs +7 -7
- package/esm2022/renderer/drawers/cell-drawer.mjs +4 -7
- package/esm2022/types/cell.mjs +1 -1
- package/esm2022/types/component-config.mjs +1 -1
- package/esm2022/types/field.mjs +1 -1
- package/esm2022/utils/clipboard/paste.mjs +3 -2
- package/esm2022/utils/common.mjs +6 -5
- package/esm2022/utils/field/model/date.mjs +6 -12
- package/esm2022/utils/field/model/progress.mjs +11 -4
- package/esm2022/utils/file.mjs +1 -93
- package/esm2022/utils/hover-cell.mjs +1 -8
- package/fesm2022/ai-table-grid.mjs +1322 -1252
- package/fesm2022/ai-table-grid.mjs.map +1 -1
- package/grid-base.component.d.ts +4 -1
- package/grid-base.component.d.ts.map +1 -1
- package/grid.component.d.ts.map +1 -1
- package/package.json +1 -1
- package/renderer/components/action-icon.component.d.ts +47 -0
- package/renderer/components/action-icon.component.d.ts.map +1 -0
- package/renderer/components/cells/attachment.component.d.ts +16 -0
- package/renderer/components/cells/attachment.component.d.ts.map +1 -0
- package/renderer/components/cells/index.d.ts +1 -0
- package/renderer/components/cells/index.d.ts.map +1 -1
- package/renderer/drawers/cell-drawer.d.ts.map +1 -1
- package/types/cell.d.ts +1 -0
- package/types/cell.d.ts.map +1 -1
- package/types/component-config.d.ts +13 -1
- package/types/component-config.d.ts.map +1 -1
- package/types/field.d.ts +1 -1
- package/types/field.d.ts.map +1 -1
- package/utils/clipboard/paste.d.ts.map +1 -1
- package/utils/common.d.ts +1 -1
- package/utils/common.d.ts.map +1 -1
- package/utils/field/model/date.d.ts.map +1 -1
- package/utils/field/model/progress.d.ts.map +1 -1
- package/utils/file.d.ts +0 -9
- package/utils/file.d.ts.map +1 -1
- package/utils/hover-cell.d.ts.map +1 -1
- package/esm2022/utils/icon.mjs +0 -48
- package/utils/icon.d.ts +0 -19
- package/utils/icon.d.ts.map +0 -1
@@ -0,0 +1,117 @@
|
|
1
|
+
import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';
|
2
|
+
import { KoShape } from '../../../angular-konva/components/shape.component';
|
3
|
+
import { AddOutlinedPath, AI_TABLE_ACTION_COMMON_RADIUS, AI_TABLE_ACTION_COMMON_RIGHT_PADDING, AI_TABLE_ACTION_COMMON_SIZE, AI_TABLE_CELL, AI_TABLE_CELL_ATTACHMENT_ADD, AI_TABLE_CELL_PADDING, AI_TABLE_FIELD_ITEM_MARGIN_RIGHT, AI_TABLE_FILE_ICON_SIZE, AI_TABLE_OFFSET, AI_TABLE_ROW_BLANK_HEIGHT, Colors } from '../../../constants';
|
4
|
+
import { KoContainer } from '../../../angular-konva/components/container.component';
|
5
|
+
import { generateTargetName } from '../../../utils';
|
6
|
+
import { AITableFieldType } from '../../../core';
|
7
|
+
import { getFileThumbnailSvgString } from '../../../utils/file';
|
8
|
+
import { AITableActionIcon } from '../action-icon.component';
|
9
|
+
import * as i0 from "@angular/core";
|
10
|
+
export class AITableCellAttachment {
|
11
|
+
constructor() {
|
12
|
+
this.config = input();
|
13
|
+
this.attachments = computed(() => {
|
14
|
+
const { render, aiTable, coordinate, field, recordId, readonly } = this.config();
|
15
|
+
if (render) {
|
16
|
+
const {} = aiTable;
|
17
|
+
const { transformValue, references, columnWidth, rowHeight, style, zIndex } = render;
|
18
|
+
if (!transformValue?.length) {
|
19
|
+
return [];
|
20
|
+
}
|
21
|
+
const result = transformValue?.map((attachmentId, index) => {
|
22
|
+
const itemWidth = AI_TABLE_FILE_ICON_SIZE + AI_TABLE_FIELD_ITEM_MARGIN_RIGHT;
|
23
|
+
const currentX = AI_TABLE_CELL_PADDING + index * itemWidth + AI_TABLE_OFFSET;
|
24
|
+
let currentY = (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_FILE_ICON_SIZE) / 2 + AI_TABLE_OFFSET;
|
25
|
+
if (columnWidth != null) {
|
26
|
+
// 当超出列宽时,不会渲染后续内容
|
27
|
+
if (currentX >= columnWidth - AI_TABLE_ACTION_COMMON_SIZE - 2 * AI_TABLE_CELL_PADDING) {
|
28
|
+
return null;
|
29
|
+
}
|
30
|
+
}
|
31
|
+
const attachmentInfo = references.attachments[attachmentId];
|
32
|
+
if (attachmentInfo) {
|
33
|
+
const svgString = getFileThumbnailSvgString(attachmentInfo.addition.ext);
|
34
|
+
const image = new Image();
|
35
|
+
image.src = `data:image/svg+xml;charset=utf-8,${encodeURIComponent(svgString)}`;
|
36
|
+
return {
|
37
|
+
// coordinate,
|
38
|
+
// readonly,
|
39
|
+
attachmentInfo,
|
40
|
+
name: generateTargetName({
|
41
|
+
targetName: AI_TABLE_CELL,
|
42
|
+
fieldId: field._id,
|
43
|
+
recordId,
|
44
|
+
mouseStyle: readonly ? 'default' : 'pointer',
|
45
|
+
source: attachmentInfo._id
|
46
|
+
}),
|
47
|
+
x: currentX,
|
48
|
+
y: currentY,
|
49
|
+
width: AI_TABLE_FILE_ICON_SIZE,
|
50
|
+
height: AI_TABLE_FILE_ICON_SIZE,
|
51
|
+
image,
|
52
|
+
listening: true
|
53
|
+
};
|
54
|
+
}
|
55
|
+
return null;
|
56
|
+
}) || [];
|
57
|
+
return result.filter((item) => !!item);
|
58
|
+
}
|
59
|
+
return [];
|
60
|
+
});
|
61
|
+
this.iconConfig = computed(() => {
|
62
|
+
const { coordinate, render, field, recordId, readonly } = this.config();
|
63
|
+
const offsetX = render.columnWidth - AI_TABLE_ACTION_COMMON_SIZE - AI_TABLE_ACTION_COMMON_RIGHT_PADDING;
|
64
|
+
const offsetY = (coordinate.rowInitSize - AI_TABLE_ACTION_COMMON_SIZE) / 2;
|
65
|
+
return {
|
66
|
+
coordinate,
|
67
|
+
readonly,
|
68
|
+
name: generateTargetName({
|
69
|
+
targetName: AI_TABLE_CELL,
|
70
|
+
fieldId: field._id,
|
71
|
+
recordId,
|
72
|
+
source: AI_TABLE_CELL_ATTACHMENT_ADD,
|
73
|
+
mouseStyle: readonly ? 'default' : 'pointer'
|
74
|
+
}),
|
75
|
+
x: offsetX,
|
76
|
+
y: offsetY,
|
77
|
+
data: AddOutlinedPath,
|
78
|
+
fill: Colors.gray600,
|
79
|
+
hoverFill: Colors.primary,
|
80
|
+
backgroundWidth: AI_TABLE_ACTION_COMMON_SIZE,
|
81
|
+
backgroundHeight: AI_TABLE_ACTION_COMMON_SIZE,
|
82
|
+
cornerRadius: AI_TABLE_ACTION_COMMON_RADIUS,
|
83
|
+
listening: true
|
84
|
+
};
|
85
|
+
});
|
86
|
+
}
|
87
|
+
static { this.fieldType = AITableFieldType.attachment; }
|
88
|
+
addClick(e) {
|
89
|
+
// e.event.cancelBubble = true;
|
90
|
+
}
|
91
|
+
attachmentClick(e) {
|
92
|
+
// e.event.cancelBubble = true;
|
93
|
+
}
|
94
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableCellAttachment, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
95
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: AITableCellAttachment, isStandalone: true, selector: "ai-table-attachments", inputs: { config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: `
|
96
|
+
@for (attachment of attachments(); track attachment.attachmentInfo._id) {
|
97
|
+
<ko-image [config]="attachment" (koClick)="attachmentClick($event)"></ko-image>
|
98
|
+
}
|
99
|
+
<ai-table-action-icon [config]="iconConfig()" (onClick)="addClick($event)"></ai-table-action-icon>
|
100
|
+
`, 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"] }, { kind: "component", type: AITableActionIcon, selector: "ai-table-action-icon", inputs: ["config"], outputs: ["onClick", "onMousemove", "onMouseenter", "onMouseleave"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
101
|
+
}
|
102
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableCellAttachment, decorators: [{
|
103
|
+
type: Component,
|
104
|
+
args: [{
|
105
|
+
selector: 'ai-table-attachments',
|
106
|
+
template: `
|
107
|
+
@for (attachment of attachments(); track attachment.attachmentInfo._id) {
|
108
|
+
<ko-image [config]="attachment" (koClick)="attachmentClick($event)"></ko-image>
|
109
|
+
}
|
110
|
+
<ai-table-action-icon [config]="iconConfig()" (onClick)="addClick($event)"></ai-table-action-icon>
|
111
|
+
`,
|
112
|
+
standalone: true,
|
113
|
+
imports: [KoContainer, KoShape, AITableActionIcon],
|
114
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
115
|
+
}]
|
116
|
+
}] });
|
117
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"attachment.component.js","sourceRoot":"","sources":["../../../../../../packages/grid/src/renderer/components/cells/attachment.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';\nimport { KoShape } from '../../../angular-konva/components/shape.component';\nimport {\n    AddOutlinedPath,\n    AI_TABLE_ACTION_COMMON_RADIUS,\n    AI_TABLE_ACTION_COMMON_RIGHT_PADDING,\n    AI_TABLE_ACTION_COMMON_SIZE,\n    AI_TABLE_CELL,\n    AI_TABLE_CELL_ATTACHMENT_ADD,\n    AI_TABLE_CELL_ATTACHMENT_FILE,\n    AI_TABLE_CELL_PADDING,\n    AI_TABLE_FIELD_HEAD_MORE,\n    AI_TABLE_FIELD_ITEM_MARGIN_RIGHT,\n    AI_TABLE_FILE_ICON_SIZE,\n    AI_TABLE_OFFSET,\n    AI_TABLE_ROW_BLANK_HEIGHT,\n    Colors\n} from '../../../constants';\nimport { KoContainer } from '../../../angular-konva/components/container.component';\nimport { generateTargetName } from '../../../utils';\nimport { AITableActionIconConfig, AITableAttachmentConfig, AITableHoverCellConfig } from '../../../types';\nimport { KoEventObject } from '../../../angular-konva';\nimport { AITableFieldType } from '../../../core';\nimport { HoverCellComponent } from '../../interfaces';\nimport { getFileThumbnailSvgString } from '../../../utils/file';\nimport { isNil } from 'lodash';\nimport { AITableActionIcon } from '../action-icon.component';\n\n@Component({\n    selector: 'ai-table-attachments',\n    template: `\n        @for (attachment of attachments(); track attachment.attachmentInfo._id) {\n            <ko-image [config]=\"attachment\" (koClick)=\"attachmentClick($event)\"></ko-image>\n        }\n        <ai-table-action-icon [config]=\"iconConfig()\" (onClick)=\"addClick($event)\"></ai-table-action-icon>\n    `,\n    standalone: true,\n    imports: [KoContainer, KoShape, AITableActionIcon],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableCellAttachment implements HoverCellComponent {\n    static fieldType = AITableFieldType.attachment;\n\n    config = input<AITableHoverCellConfig>();\n\n    attachments = computed<AITableAttachmentConfig[]>(() => {\n        const { render, aiTable, coordinate, field, recordId, readonly } = this.config()!;\n\n        if (render) {\n            const {} = aiTable;\n            const { transformValue, references, columnWidth, rowHeight, style, zIndex } = render;\n            if (!transformValue?.length) {\n                return [];\n            }\n            const result =\n                transformValue?.map((attachmentId: string, index: number) => {\n                    const itemWidth = AI_TABLE_FILE_ICON_SIZE + AI_TABLE_FIELD_ITEM_MARGIN_RIGHT;\n                    const currentX = AI_TABLE_CELL_PADDING + index * itemWidth + AI_TABLE_OFFSET;\n                    let currentY = (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_FILE_ICON_SIZE) / 2 + AI_TABLE_OFFSET;\n                    if (columnWidth != null) {\n                        // 当超出列宽时，不会渲染后续内容\n                        if (currentX >= columnWidth - AI_TABLE_ACTION_COMMON_SIZE - 2 * AI_TABLE_CELL_PADDING) {\n                            return null;\n                        }\n                    }\n\n                    const attachmentInfo = references!.attachments[attachmentId];\n                    if (attachmentInfo) {\n                        const svgString = getFileThumbnailSvgString(attachmentInfo.addition.ext);\n                        const image = new Image();\n                        image.src = `data:image/svg+xml;charset=utf-8,${encodeURIComponent(svgString)}`;\n                        return {\n                            // coordinate,\n                            // readonly,\n                            attachmentInfo,\n                            name: generateTargetName({\n                                targetName: AI_TABLE_CELL,\n                                fieldId: field._id,\n                                recordId,\n                                mouseStyle: readonly ? 'default' : 'pointer',\n                                source: attachmentInfo._id\n                            }),\n                            x: currentX,\n                            y: currentY,\n                            width: AI_TABLE_FILE_ICON_SIZE,\n                            height: AI_TABLE_FILE_ICON_SIZE,\n                            image,\n                            listening: true\n                        };\n                    }\n                    return null;\n                }) || [];\n            return result.filter((item: AITableAttachmentConfig) => !!item);\n        }\n\n        return [];\n    });\n\n    iconConfig = computed<AITableActionIconConfig>(() => {\n        const { coordinate, render, field, recordId, readonly } = this.config()!;\n        const offsetX = render.columnWidth - AI_TABLE_ACTION_COMMON_SIZE - AI_TABLE_ACTION_COMMON_RIGHT_PADDING;\n        const offsetY = (coordinate.rowInitSize - AI_TABLE_ACTION_COMMON_SIZE) / 2;\n\n        return {\n            coordinate,\n            readonly,\n            name: generateTargetName({\n                targetName: AI_TABLE_CELL,\n                fieldId: field._id,\n                recordId,\n                source: AI_TABLE_CELL_ATTACHMENT_ADD,\n                mouseStyle: readonly ? 'default' : 'pointer'\n            }),\n            x: offsetX,\n            y: offsetY,\n            data: AddOutlinedPath,\n            fill: Colors.gray600,\n            hoverFill: Colors.primary,\n            backgroundWidth: AI_TABLE_ACTION_COMMON_SIZE,\n            backgroundHeight: AI_TABLE_ACTION_COMMON_SIZE,\n            cornerRadius: AI_TABLE_ACTION_COMMON_RADIUS,\n            listening: true\n        };\n    });\n\n    addClick(e: KoEventObject<MouseEvent>) {\n        // e.event.cancelBubble = true;\n    }\n\n    attachmentClick(e: KoEventObject<MouseEvent>) {\n        // e.event.cancelBubble = true;\n    }\n}\n"]}
|
@@ -1,2 +1,4 @@
|
|
1
|
+
// TODO: components下的cells组件考虑移出 components ,这些组件都属于
|
1
2
|
export * from './link.component';
|
2
|
-
|
3
|
+
export * from './attachment.component';
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9ncmlkL3NyYy9yZW5kZXJlci9jb21wb25lbnRzL2NlbGxzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLG9EQUFvRDtBQUNwRCxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsd0JBQXdCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBUT0RPOiBjb21wb25lbnRz5LiL55qEY2VsbHPnu4Tku7bogIPomZHnp7vlh7ogY29tcG9uZW50cyDvvIzov5nkupvnu4Tku7bpg73lsZ7kuo5cbmV4cG9ydCAqIGZyb20gJy4vbGluay5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9hdHRhY2htZW50LmNvbXBvbmVudCc7XG4iXX0=
|
@@ -18,7 +18,7 @@ export class AITableHoverCells {
|
|
18
18
|
};
|
19
19
|
});
|
20
20
|
this.hoverCellConfig = computed(() => {
|
21
|
-
const { aiTable, coordinate } = this.config();
|
21
|
+
const { aiTable, coordinate, references, readonly } = this.config();
|
22
22
|
const pointPosition = aiTable.context.pointPosition();
|
23
23
|
const hoverCell = this.hoverCell();
|
24
24
|
if (!hoverCell) {
|
@@ -26,10 +26,7 @@ export class AITableHoverCells {
|
|
26
26
|
}
|
27
27
|
const { field, recordId, fieldId, renderComponentDefinition } = hoverCell;
|
28
28
|
const cellValue = AITableQueries.getFieldValue(aiTable, [recordId, field._id]);
|
29
|
-
const transformValue = transformCellValue(aiTable, field, cellValue)
|
30
|
-
if (Object.keys(transformValue).length === 0) {
|
31
|
-
return;
|
32
|
-
}
|
29
|
+
const transformValue = transformCellValue(aiTable, field, cellValue);
|
33
30
|
const { rowHeight, columnCount, rowCount } = coordinate;
|
34
31
|
const columnIndex = pointPosition.columnIndex;
|
35
32
|
const rowIndex = pointPosition.rowIndex;
|
@@ -51,10 +48,12 @@ export class AITableHoverCells {
|
|
51
48
|
const renderY = 0 - AI_TABLE_OFFSET * 2;
|
52
49
|
const result = {
|
53
50
|
field,
|
51
|
+
recordId,
|
54
52
|
aiTable,
|
55
53
|
coordinate,
|
56
54
|
x,
|
57
55
|
y,
|
56
|
+
readonly,
|
58
57
|
render: {
|
59
58
|
aiTable,
|
60
59
|
recordId,
|
@@ -66,7 +65,8 @@ export class AITableHoverCells {
|
|
66
65
|
rowHeight,
|
67
66
|
cellValue,
|
68
67
|
transformValue,
|
69
|
-
style
|
68
|
+
style,
|
69
|
+
references
|
70
70
|
}
|
71
71
|
};
|
72
72
|
return result;
|
@@ -100,4 +100,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
100
100
|
changeDetection: ChangeDetectionStrategy.OnPush
|
101
101
|
}]
|
102
102
|
}] });
|
103
|
-
//# sourceMappingURL=data:application/json;base64,
|
103
|
+
//# 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":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, effect, input, SimpleChanges } from '@angular/core';\nimport { KoContainer, KoShape } from '../../angular-konva';\nimport { AITableCellsConfig, AITableHoverCellConfig } from '../../types';\nimport { AITableField, AITableFieldType, AITableQueries } from '../../core';\nimport { AITableCellLink } from './cells/link.component';\nimport { CommonModule } from '@angular/common';\nimport {\n    AI_TABLE_CELL_BORDER,\n    AI_TABLE_CELL_PADDING,\n    AI_TABLE_OFFSET,\n    Colors,\n    DEFAULT_TEXT_ALIGN_LEFT,\n    DEFAULT_TEXT_ALIGN_RIGHT\n} from '../../constants';\nimport { getCellHorizontalPosition, getHoverCell, transformCellValue } from '../../utils';\nimport { isSelectedField } from '../creations/create-cells';\nimport _ from 'lodash';\n\nimport * as cellComponents from './cells';\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: [KoShape, 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(() => {\n        const { aiTable, coordinate, references, readonly } = this.config();\n        const pointPosition = aiTable.context!.pointPosition();\n        const hoverCell = this.hoverCell();\n        if (!hoverCell) {\n            return;\n        }\n        const { field, recordId, fieldId, renderComponentDefinition } = 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            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"]}
|