@ai-table/grid 0.0.43 → 0.0.45

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (119) hide show
  1. package/angular-konva/interfaces/event-object.d.ts +4 -0
  2. package/angular-konva/interfaces/event-object.d.ts.map +1 -1
  3. package/components/cell-editors/date/date-editor.component.d.ts +1 -0
  4. package/components/cell-editors/date/date-editor.component.d.ts.map +1 -1
  5. package/components/cell-editors/link/edit-link/edit-link.component.d.ts +13 -3
  6. package/components/cell-editors/link/edit-link/edit-link.component.d.ts.map +1 -1
  7. package/components/cell-editors/link/link-editor.component.d.ts +1 -0
  8. package/components/cell-editors/link/link-editor.component.d.ts.map +1 -1
  9. package/components/drag/drag.component.d.ts +10 -1
  10. package/components/drag/drag.component.d.ts.map +1 -1
  11. package/components/drag/drag.component.scss +1 -1
  12. package/components/field-menu/field-menu.component.d.ts +3 -2
  13. package/components/field-menu/field-menu.component.d.ts.map +1 -1
  14. package/components/field-setting/field-setting.component.d.ts +17 -3
  15. package/components/field-setting/field-setting.component.d.ts.map +1 -1
  16. package/constants/grid.d.ts.map +1 -1
  17. package/constants/table.d.ts +5 -1
  18. package/constants/table.d.ts.map +1 -1
  19. package/core/constants/field.d.ts +2 -2
  20. package/core/constants/field.d.ts.map +1 -1
  21. package/core/types/ai-table.d.ts +2 -0
  22. package/core/types/ai-table.d.ts.map +1 -1
  23. package/core/types/core.d.ts +4 -4
  24. package/core/types/core.d.ts.map +1 -1
  25. package/core/utils/common.d.ts +1 -0
  26. package/core/utils/common.d.ts.map +1 -1
  27. package/core/utils/field.d.ts +1 -1
  28. package/core/utils/field.d.ts.map +1 -1
  29. package/core/utils/{shoft-id.d.ts → short-id.d.ts} +1 -1
  30. package/core/utils/{shoft-id.d.ts.map → short-id.d.ts.map} +1 -1
  31. package/esm2022/angular-konva/interfaces/event-object.mjs +1 -1
  32. package/esm2022/components/cell-editors/date/date-editor.component.mjs +9 -3
  33. package/esm2022/components/cell-editors/link/edit-link/edit-link.component.mjs +27 -12
  34. package/esm2022/components/cell-editors/link/link-editor.component.mjs +12 -8
  35. package/esm2022/components/drag/drag.component.mjs +107 -79
  36. package/esm2022/components/field-menu/field-menu.component.mjs +9 -3
  37. package/esm2022/components/field-setting/field-setting.component.mjs +28 -14
  38. package/esm2022/constants/grid.mjs +1 -2
  39. package/esm2022/constants/table.mjs +6 -2
  40. package/esm2022/core/constants/field.mjs +95 -95
  41. package/esm2022/core/types/ai-table.mjs +1 -1
  42. package/esm2022/core/types/core.mjs +1 -2
  43. package/esm2022/core/utils/common.mjs +13 -1
  44. package/esm2022/core/utils/field.mjs +13 -8
  45. package/esm2022/core/utils/id-creator.mjs +2 -2
  46. package/esm2022/core/utils/{shoft-id.mjs → short-id.mjs} +1 -1
  47. package/esm2022/grid-base.component.mjs +14 -4
  48. package/esm2022/grid.component.mjs +54 -29
  49. package/esm2022/renderer/components/action-icon.component.mjs +117 -0
  50. package/esm2022/renderer/components/cells/attachment.component.mjs +117 -0
  51. package/esm2022/renderer/components/cells/index.mjs +3 -1
  52. package/esm2022/renderer/components/cells/link.component.mjs +2 -2
  53. package/esm2022/renderer/components/hover-cell.component.mjs +7 -7
  54. package/esm2022/renderer/creations/create-active-cell-border.mjs +1 -2
  55. package/esm2022/renderer/creations/create-heads.mjs +3 -2
  56. package/esm2022/renderer/drawers/cell-drawer.mjs +4 -7
  57. package/esm2022/types/cell.mjs +1 -1
  58. package/esm2022/types/component-config.mjs +1 -1
  59. package/esm2022/types/field.mjs +1 -1
  60. package/esm2022/types/grid.mjs +1 -1
  61. package/esm2022/utils/build.mjs +5 -4
  62. package/esm2022/utils/cell.mjs +3 -3
  63. package/esm2022/utils/clipboard/paste.mjs +6 -4
  64. package/esm2022/utils/common.mjs +6 -5
  65. package/esm2022/utils/field/model/date.mjs +6 -12
  66. package/esm2022/utils/field/model/progress.mjs +11 -4
  67. package/esm2022/utils/file.mjs +1 -93
  68. package/esm2022/utils/hover-cell.mjs +1 -8
  69. package/esm2022/utils/i18n.mjs +85 -0
  70. package/esm2022/utils/index.mjs +2 -1
  71. package/esm2022/utils/position.mjs +3 -3
  72. package/esm2022/utils/visible-range.mjs +3 -3
  73. package/fesm2022/ai-table-grid.mjs +1762 -1510
  74. package/fesm2022/ai-table-grid.mjs.map +1 -1
  75. package/grid-base.component.d.ts +7 -2
  76. package/grid-base.component.d.ts.map +1 -1
  77. package/grid.component.d.ts.map +1 -1
  78. package/package.json +1 -1
  79. package/renderer/components/action-icon.component.d.ts +47 -0
  80. package/renderer/components/action-icon.component.d.ts.map +1 -0
  81. package/renderer/components/cells/attachment.component.d.ts +16 -0
  82. package/renderer/components/cells/attachment.component.d.ts.map +1 -0
  83. package/renderer/components/cells/index.d.ts +1 -0
  84. package/renderer/components/cells/index.d.ts.map +1 -1
  85. package/renderer/creations/create-active-cell-border.d.ts.map +1 -1
  86. package/renderer/creations/create-heads.d.ts.map +1 -1
  87. package/renderer/drawers/cell-drawer.d.ts.map +1 -1
  88. package/types/cell.d.ts +1 -0
  89. package/types/cell.d.ts.map +1 -1
  90. package/types/component-config.d.ts +13 -1
  91. package/types/component-config.d.ts.map +1 -1
  92. package/types/field.d.ts +1 -1
  93. package/types/field.d.ts.map +1 -1
  94. package/types/grid.d.ts +1 -1
  95. package/types/grid.d.ts.map +1 -1
  96. package/utils/build.d.ts +2 -2
  97. package/utils/build.d.ts.map +1 -1
  98. package/utils/cell.d.ts +1 -1
  99. package/utils/cell.d.ts.map +1 -1
  100. package/utils/clipboard/paste.d.ts +2 -2
  101. package/utils/clipboard/paste.d.ts.map +1 -1
  102. package/utils/common.d.ts +1 -1
  103. package/utils/common.d.ts.map +1 -1
  104. package/utils/field/model/date.d.ts.map +1 -1
  105. package/utils/field/model/progress.d.ts.map +1 -1
  106. package/utils/file.d.ts +0 -9
  107. package/utils/file.d.ts.map +1 -1
  108. package/utils/hover-cell.d.ts.map +1 -1
  109. package/utils/i18n.d.ts +39 -0
  110. package/utils/i18n.d.ts.map +1 -0
  111. package/utils/index.d.ts +1 -0
  112. package/utils/index.d.ts.map +1 -1
  113. package/utils/position.d.ts +2 -2
  114. package/utils/position.d.ts.map +1 -1
  115. package/utils/visible-range.d.ts +2 -2
  116. package/utils/visible-range.d.ts.map +1 -1
  117. package/esm2022/utils/icon.mjs +0 -48
  118. package/utils/icon.d.ts +0 -19
  119. package/utils/icon.d.ts.map +0 -1
@@ -0,0 +1,117 @@
1
+ import { ChangeDetectionStrategy, Component, computed, input, output, signal } from '@angular/core';
2
+ import { KoContainer } from '../../angular-konva';
3
+ import { KoShape } from '../../angular-konva/components/shape.component';
4
+ import { Check, Colors, DEFAULT_ICON_SIZE, Unchecked } from '../../constants';
5
+ import { AITableCheckType } from '../../types';
6
+ import { setMouseStyle } from '../../utils';
7
+ import * as i0 from "@angular/core";
8
+ export class AITableActionIcon {
9
+ constructor() {
10
+ this.onClick = output();
11
+ this.onMousemove = output();
12
+ this.onMouseenter = output();
13
+ this.onMouseleave = output();
14
+ this.config = input.required();
15
+ this.isHover = signal(false);
16
+ this.groupConfig = computed(() => {
17
+ const { x, y, listening } = this.config();
18
+ return { x, y, listening };
19
+ });
20
+ this.squareShapeConfig = computed(() => {
21
+ const { name, backgroundWidth, backgroundHeight, hoverFill, size = DEFAULT_ICON_SIZE, strokeWidth = 1, cornerRadius } = this.config();
22
+ return {
23
+ name,
24
+ width: backgroundWidth || size,
25
+ height: backgroundHeight || size,
26
+ strokeWidth: strokeWidth,
27
+ fill: hoverFill && this.isHover() ? hoverFill : Colors.transparent,
28
+ opacity: hoverFill && this.isHover() ? 0.1 : 1,
29
+ cornerRadius
30
+ };
31
+ });
32
+ this.iconConfig = computed(() => {
33
+ let { type, data, backgroundWidth, backgroundHeight, size = DEFAULT_ICON_SIZE, stroke, strokeWidth = 1, scaleX, scaleY, offsetX, offsetY, rotation, fill, hoverFill, transformsEnabled = 'position' } = this.config();
34
+ fill = fill || Colors.gray600;
35
+ let pathData = data;
36
+ switch (type) {
37
+ case AITableCheckType.checked:
38
+ pathData = Check;
39
+ break;
40
+ case AITableCheckType.unchecked:
41
+ pathData = Unchecked;
42
+ break;
43
+ }
44
+ return {
45
+ x: backgroundWidth && (backgroundWidth - size * (scaleX || 1)) / 2,
46
+ y: backgroundHeight && (backgroundHeight - size * (scaleY || 1)) / 2,
47
+ data: pathData,
48
+ width: size,
49
+ height: size,
50
+ fill: hoverFill && this.isHover() ? hoverFill : fill,
51
+ offsetX,
52
+ offsetY,
53
+ scaleX,
54
+ scaleY,
55
+ rotation,
56
+ stroke,
57
+ strokeWidth,
58
+ transformsEnabled,
59
+ perfectDrawEnabled: false,
60
+ listening: false
61
+ };
62
+ });
63
+ }
64
+ koClick(e) {
65
+ this.onClick.emit(e);
66
+ }
67
+ koMousemove(e) {
68
+ e.event.cancelBubble = true;
69
+ }
70
+ koMouseenter(e) {
71
+ this.onMouseenter.emit(e);
72
+ this.isHover.set(true);
73
+ const { coordinate } = this.config();
74
+ setMouseStyle('pointer', coordinate.container);
75
+ }
76
+ koMouseleave(e) {
77
+ this.onMouseleave.emit(e);
78
+ this.isHover.set(false);
79
+ const { coordinate } = this.config();
80
+ setMouseStyle('default', coordinate.container);
81
+ }
82
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableActionIcon, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
83
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: AITableActionIcon, isStandalone: true, selector: "ai-table-action-icon", inputs: { config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { onClick: "onClick", onMousemove: "onMousemove", onMouseenter: "onMouseenter", onMouseleave: "onMouseleave" }, ngImport: i0, template: `
84
+ <ko-group
85
+ [config]="groupConfig()"
86
+ (koClick)="koClick($event)"
87
+ (koMousemove)="koMousemove($event)"
88
+ (koMouseenter)="koMouseenter($event)"
89
+ (koMouseleave)="koMouseleave($event)"
90
+ >
91
+ <ko-rect [config]="squareShapeConfig()"></ko-rect>
92
+ <ko-path [config]="iconConfig()"></ko-path>
93
+ </ko-group>
94
+ `, 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"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
95
+ }
96
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableActionIcon, decorators: [{
97
+ type: Component,
98
+ args: [{
99
+ selector: 'ai-table-action-icon',
100
+ template: `
101
+ <ko-group
102
+ [config]="groupConfig()"
103
+ (koClick)="koClick($event)"
104
+ (koMousemove)="koMousemove($event)"
105
+ (koMouseenter)="koMouseenter($event)"
106
+ (koMouseleave)="koMouseleave($event)"
107
+ >
108
+ <ko-rect [config]="squareShapeConfig()"></ko-rect>
109
+ <ko-path [config]="iconConfig()"></ko-path>
110
+ </ko-group>
111
+ `,
112
+ standalone: true,
113
+ imports: [KoContainer, KoShape],
114
+ changeDetection: ChangeDetectionStrategy.OnPush
115
+ }]
116
+ }] });
117
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"action-icon.component.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/components/action-icon.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input, output, signal } from '@angular/core';\nimport { StageConfig } from 'konva/lib/Stage';\nimport { KoContainer, KoEventObject } from '../../angular-konva';\nimport { KoShape } from '../../angular-konva/components/shape.component';\nimport { Check, Colors, DEFAULT_ICON_SIZE, Unchecked } from '../../constants';\nimport { AITableActionIconConfig, AITableCheckType, AITableIconConfig } from '../../types';\nimport { setMouseStyle } from '../../utils';\n\n@Component({\n    selector: 'ai-table-action-icon',\n    template: `\n        <ko-group\n            [config]=\"groupConfig()\"\n            (koClick)=\"koClick($event)\"\n            (koMousemove)=\"koMousemove($event)\"\n            (koMouseenter)=\"koMouseenter($event)\"\n            (koMouseleave)=\"koMouseleave($event)\"\n        >\n            <ko-rect [config]=\"squareShapeConfig()\"></ko-rect>\n            <ko-path [config]=\"iconConfig()\"></ko-path>\n        </ko-group>\n    `,\n    standalone: true,\n    imports: [KoContainer, KoShape],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableActionIcon {\n    onClick = output<KoEventObject<MouseEvent>>();\n\n    onMousemove = output<KoEventObject<MouseEvent>>();\n\n    onMouseenter = output<KoEventObject<MouseEvent>>();\n\n    onMouseleave = output<KoEventObject<MouseEvent>>();\n\n    config = input.required<AITableActionIconConfig>();\n\n    isHover = signal(false);\n\n    groupConfig = computed<Partial<StageConfig>>(() => {\n        const { x, y, listening } = this.config();\n        return { x, y, listening };\n    });\n\n    squareShapeConfig = computed(() => {\n        const {\n            name,\n            backgroundWidth,\n            backgroundHeight,\n            hoverFill,\n            size = DEFAULT_ICON_SIZE,\n            strokeWidth = 1,\n            cornerRadius\n        } = this.config();\n        return {\n            name,\n            width: backgroundWidth || size,\n            height: backgroundHeight || size,\n            strokeWidth: strokeWidth,\n            fill: hoverFill && this.isHover() ? hoverFill : Colors.transparent,\n            opacity: hoverFill && this.isHover() ? 0.1 : 1,\n            cornerRadius\n        };\n    });\n\n    iconConfig = computed(() => {\n        let {\n            type,\n            data,\n            backgroundWidth,\n            backgroundHeight,\n            size = DEFAULT_ICON_SIZE,\n            stroke,\n            strokeWidth = 1,\n            scaleX,\n            scaleY,\n            offsetX,\n            offsetY,\n            rotation,\n            fill,\n            hoverFill,\n            transformsEnabled = 'position'\n        } = this.config();\n        fill = fill || Colors.gray600;\n        let pathData = data;\n\n        switch (type) {\n            case AITableCheckType.checked:\n                pathData = Check;\n                break;\n            case AITableCheckType.unchecked:\n                pathData = Unchecked;\n                break;\n        }\n\n        return {\n            x: backgroundWidth && (backgroundWidth - size * (scaleX || 1)) / 2,\n            y: backgroundHeight && (backgroundHeight - size * (scaleY || 1)) / 2,\n            data: pathData,\n            width: size,\n            height: size,\n            fill: hoverFill && this.isHover() ? hoverFill : fill,\n            offsetX,\n            offsetY,\n            scaleX,\n            scaleY,\n            rotation,\n            stroke,\n            strokeWidth,\n            transformsEnabled,\n            perfectDrawEnabled: false,\n            listening: false\n        };\n    });\n\n    koClick(e: KoEventObject<MouseEvent>) {\n        this.onClick.emit(e);\n    }\n    koMousemove(e: KoEventObject<MouseEvent>) {\n        e.event.cancelBubble = true;\n    }\n\n    koMouseenter(e: KoEventObject<MouseEvent>) {\n        this.onMouseenter.emit(e);\n        this.isHover.set(true);\n        const { coordinate } = this.config()!;\n        setMouseStyle('pointer', coordinate.container);\n    }\n\n    koMouseleave(e: KoEventObject<MouseEvent>) {\n        this.onMouseleave.emit(e);\n        this.isHover.set(false);\n        const { coordinate } = this.config()!;\n        setMouseStyle('default', coordinate.container);\n    }\n}\n"]}
@@ -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
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9ncmlkL3NyYy9yZW5kZXJlci9jb21wb25lbnRzL2NlbGxzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsa0JBQWtCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2xpbmsuY29tcG9uZW50JztcbiJdfQ==
3
+ export * from './attachment.component';
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9ncmlkL3NyYy9yZW5kZXJlci9jb21wb25lbnRzL2NlbGxzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLG9EQUFvRDtBQUNwRCxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsd0JBQXdCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvLyBUT0RPOiBjb21wb25lbnRz5LiL55qEY2VsbHPnu4Tku7bogIPomZHnp7vlh7ogY29tcG9uZW50cyDvvIzov5nkupvnu4Tku7bpg73lsZ7kuo5cbmV4cG9ydCAqIGZyb20gJy4vbGluay5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9hdHRhY2htZW50LmNvbXBvbmVudCc7XG4iXX0=
@@ -64,7 +64,7 @@ export class AITableCellLink {
64
64
  return;
65
65
  const { context } = aiTable;
66
66
  const { x, y } = pos;
67
- const curMousePosition = getMousePosition(x, y, coordinate, AITable.getVisibleFields(aiTable), context, targetName);
67
+ const curMousePosition = getMousePosition(aiTable, x, y, coordinate, AITable.getVisibleFields(aiTable), context, targetName);
68
68
  handleMouseStyle(AI_TABLE_FIELD_HEAD_MORE, curMousePosition.areaType, coordinate.container);
69
69
  }
70
70
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableCellLink, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
@@ -88,4 +88,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
88
88
  changeDetection: ChangeDetectionStrategy.OnPush
89
89
  }]
90
90
  }] });
91
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"link.component.js","sourceRoot":"","sources":["../../../../../../packages/grid/src/renderer/components/cells/link.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';\nimport { KoShape } from '../../../angular-konva/components/shape.component';\nimport { AI_TABLE_CELL_PADDING, AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE, AI_TABLE_FIELD_HEAD_MORE, Colors } from '../../../constants';\nimport { KoContainer } from '../../../angular-konva/components/container.component';\nimport { getMousePosition, getTextWidth, handleMouseStyle, TextMeasure } from '../../../utils';\nimport { AITableText } from '../text.component';\nimport { AITableHoverCellConfig, AITableRender } from '../../../types';\nimport { KoEventObject } from '../../../angular-konva';\nimport { AITable, AITableFieldType } from '../../../core';\nimport { TextConfig } from 'konva/lib/shapes/Text';\nimport { drawer } from '../../drawers/drawer';\nimport { HoverCellComponent } from '../../interfaces';\n\n@Component({\n    selector: 'ai-table-link',\n    template: `\n        @if (showLink()) {\n            <ai-table-text [config]=\"textConfig()!\" (koClick)=\"linkClick($event)\" (koMouseMove)=\"linkMouseMove($event)\"></ai-table-text>\n        }\n    `,\n    standalone: true,\n    imports: [KoContainer, KoShape, AITableText],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableCellLink implements HoverCellComponent {\n    static fieldType = AITableFieldType.link;\n\n    config = input<AITableHoverCellConfig | undefined>();\n\n    textOffset = AI_TABLE_CELL_PADDING + AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE;\n\n    render = computed<AITableRender | undefined>(() => this.config()?.render);\n\n    transformValue = computed<{ text: string; url: string }>(() => this.render()?.transformValue);\n\n    showLink = computed<boolean>(() => !!this.transformValue()?.text);\n\n    textConfig = computed<TextConfig | undefined>(() => {\n        const render = this.config()?.render;\n        if (render) {\n            const { x, y, transformValue, field, columnWidth, rowHeight, style, zIndex } = render;\n            let textRender: string | null = transformValue.text;\n            if (textRender == null) {\n                return;\n            }\n\n            textRender = textRender.replace(/\\r|\\n/g, ' ');\n            const fontWeight = style?.fontWeight;\n            const textMaxWidth = columnWidth - 2 * AI_TABLE_CELL_PADDING;\n            const { text, textWidth } = drawer.textEllipsis({\n                text: textRender,\n                maxWidth: textMaxWidth,\n                fontWeight\n            });\n\n            return {\n                x,\n                y,\n                text,\n                wrap: 'none',\n                width: textWidth,\n                fillStyle: Colors.primary,\n                fill: Colors.primary,\n                height: rowHeight + 2,\n                lineHeight: 1.84,\n                listening: true,\n                ellipsis: true,\n                textDecoration: 'underline',\n                zIndex\n            };\n        }\n        return;\n    });\n\n    linkClick(e: KoEventObject<MouseEvent>) {\n        e.event.cancelBubble = true;\n        window.open(this.transformValue().url, '_blank', 'noopener,noreferrer');\n    }\n\n    linkMouseMove(e: KoEventObject<MouseEvent>) {\n        e.event.cancelBubble = true;\n        const { aiTable, coordinate } = this.config()!;\n        const targetName = e.event.target.name();\n        const gridStage = e.event.currentTarget.getStage();\n        const pos = gridStage?.getPointerPosition();\n        if (pos == null) return;\n        const { context } = aiTable;\n        const { x, y } = pos;\n        const curMousePosition = getMousePosition(x, y, coordinate, AITable.getVisibleFields(aiTable), context!, targetName);\n        handleMouseStyle(AI_TABLE_FIELD_HEAD_MORE, curMousePosition.areaType, coordinate.container);\n    }\n}\n"]}
91
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"link.component.js","sourceRoot":"","sources":["../../../../../../packages/grid/src/renderer/components/cells/link.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';\nimport { KoShape } from '../../../angular-konva/components/shape.component';\nimport { AI_TABLE_CELL_PADDING, AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE, AI_TABLE_FIELD_HEAD_MORE, Colors } from '../../../constants';\nimport { KoContainer } from '../../../angular-konva/components/container.component';\nimport { getMousePosition, getTextWidth, handleMouseStyle, TextMeasure } from '../../../utils';\nimport { AITableText } from '../text.component';\nimport { AITableHoverCellConfig, AITableRender } from '../../../types';\nimport { KoEventObject } from '../../../angular-konva';\nimport { AITable, AITableFieldType } from '../../../core';\nimport { TextConfig } from 'konva/lib/shapes/Text';\nimport { drawer } from '../../drawers/drawer';\nimport { HoverCellComponent } from '../../interfaces';\n\n@Component({\n    selector: 'ai-table-link',\n    template: `\n        @if (showLink()) {\n            <ai-table-text [config]=\"textConfig()!\" (koClick)=\"linkClick($event)\" (koMouseMove)=\"linkMouseMove($event)\"></ai-table-text>\n        }\n    `,\n    standalone: true,\n    imports: [KoContainer, KoShape, AITableText],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableCellLink implements HoverCellComponent {\n    static fieldType = AITableFieldType.link;\n\n    config = input<AITableHoverCellConfig | undefined>();\n\n    textOffset = AI_TABLE_CELL_PADDING + AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE;\n\n    render = computed<AITableRender | undefined>(() => this.config()?.render);\n\n    transformValue = computed<{ text: string; url: string }>(() => this.render()?.transformValue);\n\n    showLink = computed<boolean>(() => !!this.transformValue()?.text);\n\n    textConfig = computed<TextConfig | undefined>(() => {\n        const render = this.config()?.render;\n        if (render) {\n            const { x, y, transformValue, field, columnWidth, rowHeight, style, zIndex } = render;\n            let textRender: string | null = transformValue.text;\n            if (textRender == null) {\n                return;\n            }\n\n            textRender = textRender.replace(/\\r|\\n/g, ' ');\n            const fontWeight = style?.fontWeight;\n            const textMaxWidth = columnWidth - 2 * AI_TABLE_CELL_PADDING;\n            const { text, textWidth } = drawer.textEllipsis({\n                text: textRender,\n                maxWidth: textMaxWidth,\n                fontWeight\n            });\n\n            return {\n                x,\n                y,\n                text,\n                wrap: 'none',\n                width: textWidth,\n                fillStyle: Colors.primary,\n                fill: Colors.primary,\n                height: rowHeight + 2,\n                lineHeight: 1.84,\n                listening: true,\n                ellipsis: true,\n                textDecoration: 'underline',\n                zIndex\n            };\n        }\n        return;\n    });\n\n    linkClick(e: KoEventObject<MouseEvent>) {\n        e.event.cancelBubble = true;\n        window.open(this.transformValue().url, '_blank', 'noopener,noreferrer');\n    }\n\n    linkMouseMove(e: KoEventObject<MouseEvent>) {\n        e.event.cancelBubble = true;\n        const { aiTable, coordinate } = this.config()!;\n        const targetName = e.event.target.name();\n        const gridStage = e.event.currentTarget.getStage();\n        const pos = gridStage?.getPointerPosition();\n        if (pos == null) return;\n        const { context } = aiTable;\n        const { x, y } = pos;\n        const curMousePosition = getMousePosition(aiTable, x, y, coordinate, AITable.getVisibleFields(aiTable), context!, targetName);\n        handleMouseStyle(AI_TABLE_FIELD_HEAD_MORE, curMousePosition.areaType, coordinate.container);\n    }\n}\n"]}
@@ -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,{"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 } = 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        if (Object.keys(transformValue).length === 0) {\n            return;\n        }\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            aiTable,\n            coordinate,\n            x,\n            y,\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            }\n        };\n\n        return result;\n    });\n\n    hoverCell = computed(() => getHoverCell(this.config().aiTable));\n}\n"]}
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"]}
@@ -43,7 +43,6 @@ export const createActiveCellBorder = (config) => {
43
43
  columnIndex,
44
44
  columnCount: totalColumnCount
45
45
  });
46
- // active 外边界和非 active 外边界 box 大小保持一致
47
46
  const currentConfig = {
48
47
  x: x + offset + AI_TABLE_OFFSET,
49
48
  y: y + AI_TABLE_OFFSET,
@@ -68,4 +67,4 @@ export const createActiveCellBorder = (config) => {
68
67
  frozenActiveCellBorder
69
68
  };
70
69
  };
71
- //# 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                // active 外边界和非 active 外边界 box 大小保持一致\n                const currentConfig = {\n                    x: x + offset + AI_TABLE_OFFSET,\n                    y: y + AI_TABLE_OFFSET,\n                    width: width - AI_TABLE_CELL_BORDER / 2,\n                    height: rowHeight - AI_TABLE_CELL_BORDER / 2,\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"]}
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_CELL_BORDER / 2,\n                    height: rowHeight - AI_TABLE_CELL_BORDER / 2,\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"]}
@@ -16,7 +16,8 @@ export const createColumnHeads = (config) => {
16
16
  };
17
17
  };
18
18
  const fieldHeads = [];
19
- const fieldMenus = config.aiTable.context?.aiFieldConfig()?.fieldMenus || [];
19
+ const fieldMenuFn = config.aiTable.context?.aiFieldConfig()?.fieldMenus;
20
+ const fieldMenus = (fieldMenuFn && fieldMenuFn(aiTable)) || [];
20
21
  let noMoreIcon = false;
21
22
  if (fieldMenus.length === 0) {
22
23
  noMoreIcon = true;
@@ -47,4 +48,4 @@ export const createColumnHeads = (config) => {
47
48
  }
48
49
  return fieldHeads;
49
50
  };
50
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlLWhlYWRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZ3JpZC9zcmMvcmVuZGVyZXIvY3JlYXRpb25zL2NyZWF0ZS1oZWFkcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFHeEYsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsQ0FBQyxNQUFnQyxFQUFFLEVBQUU7SUFDbEUsTUFBTSxFQUFFLFVBQVUsRUFBRSxnQkFBZ0IsRUFBRSxlQUFlLEVBQUUsYUFBYSxFQUFFLE9BQU8sRUFBRSxHQUFHLE1BQU0sQ0FBQztJQUN6RixNQUFNLE1BQU0sR0FBRyxNQUFNLENBQUM7SUFDdEIsTUFBTSxFQUFFLFdBQVcsRUFBRSxXQUFXLEVBQUUsZUFBZSxFQUFFLEdBQUcsVUFBVSxDQUFDO0lBQ2pFLE1BQU0sRUFBRSxXQUFXLEVBQUUsZ0JBQWdCLEVBQUUsVUFBVSxFQUFFLGVBQWUsRUFBRSxHQUFHLGFBQWEsQ0FBQztJQUNyRixNQUFNLE1BQU0sR0FBRyxPQUFPLENBQUMsUUFBUSxFQUFFLENBQUMsTUFBTSxDQUFDO0lBRXpDLE1BQU0sa0JBQWtCLEdBQUcsQ0FBQyxPQUFlLEVBQUUsRUFBRTtRQUMzQyxNQUFNLFdBQVcsR0FDYixDQUFDLG1CQUFtQixFQUFFLHdCQUF3QixDQUFDLENBQUMsUUFBUSxDQUFDLGVBQWUsQ0FBQyxJQUFJLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxFQUFFLEdBQUcsS0FBSyxPQUFPLENBQUM7UUFDM0gsTUFBTSxXQUFXLEdBQUcsZUFBZSxLQUFLLHdCQUF3QixJQUFJLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxFQUFFLEdBQUcsS0FBSyxPQUFPLENBQUM7UUFDOUcsTUFBTSxVQUFVLEdBQUcsT0FBTyxDQUFDLFNBQVMsRUFBRSxDQUFDLGNBQWMsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDbkUsT0FBTztZQUNILFdBQVc7WUFDWCxVQUFVO1lBQ1YsV0FBVztTQUNkLENBQUM7SUFDTixDQUFDLENBQUM7SUFFRixNQUFNLFVBQVUsR0FBNkIsRUFBRSxDQUFDO0lBQ2hELE1BQU0sVUFBVSxHQUFHLE1BQU0sQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLGFBQWEsRUFBRSxFQUFFLFVBQVUsSUFBSSxFQUFFLENBQUM7SUFDN0UsSUFBSSxVQUFVLEdBQUcsS0FBSyxDQUFDO0lBQ3ZCLElBQUksVUFBVSxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUUsQ0FBQztRQUMxQixVQUFVLEdBQUcsSUFBSSxDQUFDO0lBQ3RCLENBQUM7SUFDRCxLQUFLLElBQUksV0FBVyxHQUFHLGdCQUFnQixFQUFFLFdBQVcsSUFBSSxlQUFlLEVBQUUsV0FBVyxFQUFFLEVBQUUsQ0FBQztRQUNyRixJQUFJLFdBQVcsR0FBRyxXQUFXLEdBQUcsQ0FBQztZQUFFLE1BQU07UUFDekMsSUFBSSxXQUFXLEdBQUcsQ0FBQztZQUFFLFNBQVM7UUFDOUIsTUFBTSxLQUFLLEdBQUcsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQ2xDLElBQUksS0FBSyxJQUFJLElBQUk7WUFBRSxTQUFTO1FBQzVCLE1BQU0sQ0FBQyxHQUFHLFVBQVUsQ0FBQyxlQUFlLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDbEQsTUFBTSxXQUFXLEdBQUcsVUFBVSxDQUFDLGNBQWMsQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUMzRCxNQUFNLEVBQUUsV0FBVyxFQUFFLFVBQVUsRUFBRSxXQUFXLEVBQUUsR0FBRyxrQkFBa0IsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDL0UsTUFBTSxTQUFTLEdBQUc7WUFDZCxDQUFDO1lBQ0QsQ0FBQyxFQUFFLENBQUM7WUFDSixLQUFLLEVBQUUsV0FBVztZQUNsQixNQUFNLEVBQUUsZUFBZTtZQUN2QixLQUFLO1lBQ0wsTUFBTSxFQUFFLFdBQVcsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLFNBQVM7WUFDMUQsV0FBVyxFQUFFLFVBQVUsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxXQUFXO1lBQzdDLFVBQVU7WUFDVixXQUFXO1NBQ2QsQ0FBQztRQUVGLFVBQVUsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDL0IsQ0FBQztJQUNELE9BQU8sVUFBVSxDQUFDO0FBQ3RCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFJX1RBQkxFX0ZJRUxEX0hFQUQsIEFJX1RBQkxFX0ZJRUxEX0hFQURfTU9SRSwgQ29sb3JzIH0gZnJvbSAnLi4vLi4vY29uc3RhbnRzJztcbmltcG9ydCB7IEFJVGFibGVDb2x1bW5IZWFkc0NvbmZpZywgQUlUYWJsZUZpZWxkSGVhZENvbmZpZyB9IGZyb20gJy4uLy4uL3R5cGVzJztcblxuZXhwb3J0IGNvbnN0IGNyZWF0ZUNvbHVtbkhlYWRzID0gKGNvbmZpZzogQUlUYWJsZUNvbHVtbkhlYWRzQ29uZmlnKSA9PiB7XG4gICAgY29uc3QgeyBjb29yZGluYXRlLCBjb2x1bW5TdGFydEluZGV4LCBjb2x1bW5TdG9wSW5kZXgsIHBvaW50UG9zaXRpb24sIGFpVGFibGUgfSA9IGNvbmZpZztcbiAgICBjb25zdCBjb2xvcnMgPSBDb2xvcnM7XG4gICAgY29uc3QgeyBjb2x1bW5Db3VudCwgcm93SW5pdFNpemU6IGZpZWxkSGVhZEhlaWdodCB9ID0gY29vcmRpbmF0ZTtcbiAgICBjb25zdCB7IGNvbHVtbkluZGV4OiBwb2ludENvbHVtbkluZGV4LCB0YXJnZXROYW1lOiBwb2ludFRhcmdldE5hbWUgfSA9IHBvaW50UG9zaXRpb247XG4gICAgY29uc3QgZmllbGRzID0gYWlUYWJsZS5ncmlkRGF0YSgpLmZpZWxkcztcblxuICAgIGNvbnN0IGdldEZpZWxkSGVhZFN0YXR1cyA9IChmaWVsZElkOiBzdHJpbmcpID0+IHtcbiAgICAgICAgY29uc3QgaWNvblZpc2libGUgPVxuICAgICAgICAgICAgW0FJX1RBQkxFX0ZJRUxEX0hFQUQsIEFJX1RBQkxFX0ZJRUxEX0hFQURfTU9SRV0uaW5jbHVkZXMocG9pbnRUYXJnZXROYW1lKSAmJiBmaWVsZHNbcG9pbnRDb2x1bW5JbmRleF0/Ll9pZCA9PT0gZmllbGRJZDtcbiAgICAgICAgY29uc3QgaXNIb3Zlckljb24gPSBwb2ludFRhcmdldE5hbWUgPT09IEFJX1RBQkxFX0ZJRUxEX0hFQURfTU9SRSAmJiBmaWVsZHNbcG9pbnRDb2x1bW5JbmRleF0/Ll9pZCA9PT0gZmllbGRJZDtcbiAgICAgICAgY29uc3QgaXNTZWxlY3RlZCA9IGFpVGFibGUuc2VsZWN0aW9uKCkuc2VsZWN0ZWRGaWVsZHMuaGFzKGZpZWxkSWQpO1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgaWNvblZpc2libGUsXG4gICAgICAgICAgICBpc1NlbGVjdGVkLFxuICAgICAgICAgICAgaXNIb3Zlckljb25cbiAgICAgICAgfTtcbiAgICB9O1xuXG4gICAgY29uc3QgZmllbGRIZWFkczogQUlUYWJsZUZpZWxkSGVhZENvbmZpZ1tdID0gW107XG4gICAgY29uc3QgZmllbGRNZW51cyA9IGNvbmZpZy5haVRhYmxlLmNvbnRleHQ/LmFpRmllbGRDb25maWcoKT8uZmllbGRNZW51cyB8fCBbXTtcbiAgICBsZXQgbm9Nb3JlSWNvbiA9IGZhbHNlO1xuICAgIGlmIChmaWVsZE1lbnVzLmxlbmd0aCA9PT0gMCkge1xuICAgICAgICBub01vcmVJY29uID0gdHJ1ZTtcbiAgICB9XG4gICAgZm9yIChsZXQgY29sdW1uSW5kZXggPSBjb2x1bW5TdGFydEluZGV4OyBjb2x1bW5JbmRleCA8PSBjb2x1bW5TdG9wSW5kZXg7IGNvbHVtbkluZGV4KyspIHtcbiAgICAgICAgaWYgKGNvbHVtbkluZGV4ID4gY29sdW1uQ291bnQgLSAxKSBicmVhaztcbiAgICAgICAgaWYgKGNvbHVtbkluZGV4IDwgMCkgY29udGludWU7XG4gICAgICAgIGNvbnN0IGZpZWxkID0gZmllbGRzW2NvbHVtbkluZGV4XTtcbiAgICAgICAgaWYgKGZpZWxkID09IG51bGwpIGNvbnRpbnVlO1xuICAgICAgICBjb25zdCB4ID0gY29vcmRpbmF0ZS5nZXRDb2x1bW5PZmZzZXQoY29sdW1uSW5kZXgpO1xuICAgICAgICBjb25zdCBjb2x1bW5XaWR0aCA9IGNvb3JkaW5hdGUuZ2V0Q29sdW1uV2lkdGgoY29sdW1uSW5kZXgpO1xuICAgICAgICBjb25zdCB7IGljb25WaXNpYmxlLCBpc1NlbGVjdGVkLCBpc0hvdmVySWNvbiB9ID0gZ2V0RmllbGRIZWFkU3RhdHVzKGZpZWxkLl9pZCk7XG4gICAgICAgIGNvbnN0IGZpZWxkSGVhZCA9IHtcbiAgICAgICAgICAgIHgsXG4gICAgICAgICAgICB5OiAwLFxuICAgICAgICAgICAgd2lkdGg6IGNvbHVtbldpZHRoLFxuICAgICAgICAgICAgaGVpZ2h0OiBmaWVsZEhlYWRIZWlnaHQsXG4gICAgICAgICAgICBmaWVsZCxcbiAgICAgICAgICAgIHN0cm9rZTogY29sdW1uSW5kZXggPT09IDAgPyBjb2xvcnMudHJhbnNwYXJlbnQgOiB1bmRlZmluZWQsXG4gICAgICAgICAgICBpY29uVmlzaWJsZTogbm9Nb3JlSWNvbiA/IGZhbHNlIDogaWNvblZpc2libGUsXG4gICAgICAgICAgICBpc1NlbGVjdGVkLFxuICAgICAgICAgICAgaXNIb3Zlckljb25cbiAgICAgICAgfTtcblxuICAgICAgICBmaWVsZEhlYWRzLnB1c2goZmllbGRIZWFkKTtcbiAgICB9XG4gICAgcmV0dXJuIGZpZWxkSGVhZHM7XG59O1xuIl19
51
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlLWhlYWRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZ3JpZC9zcmMvcmVuZGVyZXIvY3JlYXRpb25zL2NyZWF0ZS1oZWFkcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFHeEYsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsQ0FBQyxNQUFnQyxFQUFFLEVBQUU7SUFDbEUsTUFBTSxFQUFFLFVBQVUsRUFBRSxnQkFBZ0IsRUFBRSxlQUFlLEVBQUUsYUFBYSxFQUFFLE9BQU8sRUFBRSxHQUFHLE1BQU0sQ0FBQztJQUN6RixNQUFNLE1BQU0sR0FBRyxNQUFNLENBQUM7SUFDdEIsTUFBTSxFQUFFLFdBQVcsRUFBRSxXQUFXLEVBQUUsZUFBZSxFQUFFLEdBQUcsVUFBVSxDQUFDO0lBQ2pFLE1BQU0sRUFBRSxXQUFXLEVBQUUsZ0JBQWdCLEVBQUUsVUFBVSxFQUFFLGVBQWUsRUFBRSxHQUFHLGFBQWEsQ0FBQztJQUNyRixNQUFNLE1BQU0sR0FBRyxPQUFPLENBQUMsUUFBUSxFQUFFLENBQUMsTUFBTSxDQUFDO0lBRXpDLE1BQU0sa0JBQWtCLEdBQUcsQ0FBQyxPQUFlLEVBQUUsRUFBRTtRQUMzQyxNQUFNLFdBQVcsR0FDYixDQUFDLG1CQUFtQixFQUFFLHdCQUF3QixDQUFDLENBQUMsUUFBUSxDQUFDLGVBQWUsQ0FBQyxJQUFJLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxFQUFFLEdBQUcsS0FBSyxPQUFPLENBQUM7UUFDM0gsTUFBTSxXQUFXLEdBQUcsZUFBZSxLQUFLLHdCQUF3QixJQUFJLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxFQUFFLEdBQUcsS0FBSyxPQUFPLENBQUM7UUFDOUcsTUFBTSxVQUFVLEdBQUcsT0FBTyxDQUFDLFNBQVMsRUFBRSxDQUFDLGNBQWMsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDbkUsT0FBTztZQUNILFdBQVc7WUFDWCxVQUFVO1lBQ1YsV0FBVztTQUNkLENBQUM7SUFDTixDQUFDLENBQUM7SUFFRixNQUFNLFVBQVUsR0FBNkIsRUFBRSxDQUFDO0lBQ2hELE1BQU0sV0FBVyxHQUFHLE1BQU0sQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLGFBQWEsRUFBRSxFQUFFLFVBQVUsQ0FBQztJQUN4RSxNQUFNLFVBQVUsR0FBRyxDQUFDLFdBQVcsSUFBSSxXQUFXLENBQUMsT0FBTyxDQUFDLENBQUMsSUFBSSxFQUFFLENBQUM7SUFDL0QsSUFBSSxVQUFVLEdBQUcsS0FBSyxDQUFDO0lBQ3ZCLElBQUksVUFBVSxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUUsQ0FBQztRQUMxQixVQUFVLEdBQUcsSUFBSSxDQUFDO0lBQ3RCLENBQUM7SUFDRCxLQUFLLElBQUksV0FBVyxHQUFHLGdCQUFnQixFQUFFLFdBQVcsSUFBSSxlQUFlLEVBQUUsV0FBVyxFQUFFLEVBQUUsQ0FBQztRQUNyRixJQUFJLFdBQVcsR0FBRyxXQUFXLEdBQUcsQ0FBQztZQUFFLE1BQU07UUFDekMsSUFBSSxXQUFXLEdBQUcsQ0FBQztZQUFFLFNBQVM7UUFDOUIsTUFBTSxLQUFLLEdBQUcsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQ2xDLElBQUksS0FBSyxJQUFJLElBQUk7WUFBRSxTQUFTO1FBQzVCLE1BQU0sQ0FBQyxHQUFHLFVBQVUsQ0FBQyxlQUFlLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDbEQsTUFBTSxXQUFXLEdBQUcsVUFBVSxDQUFDLGNBQWMsQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUMzRCxNQUFNLEVBQUUsV0FBVyxFQUFFLFVBQVUsRUFBRSxXQUFXLEVBQUUsR0FBRyxrQkFBa0IsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDL0UsTUFBTSxTQUFTLEdBQUc7WUFDZCxDQUFDO1lBQ0QsQ0FBQyxFQUFFLENBQUM7WUFDSixLQUFLLEVBQUUsV0FBVztZQUNsQixNQUFNLEVBQUUsZUFBZTtZQUN2QixLQUFLO1lBQ0wsTUFBTSxFQUFFLFdBQVcsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDLFNBQVM7WUFDMUQsV0FBVyxFQUFFLFVBQVUsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxXQUFXO1lBQzdDLFVBQVU7WUFDVixXQUFXO1NBQ2QsQ0FBQztRQUVGLFVBQVUsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7SUFDL0IsQ0FBQztJQUNELE9BQU8sVUFBVSxDQUFDO0FBQ3RCLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFJX1RBQkxFX0ZJRUxEX0hFQUQsIEFJX1RBQkxFX0ZJRUxEX0hFQURfTU9SRSwgQ29sb3JzIH0gZnJvbSAnLi4vLi4vY29uc3RhbnRzJztcbmltcG9ydCB7IEFJVGFibGVDb2x1bW5IZWFkc0NvbmZpZywgQUlUYWJsZUZpZWxkSGVhZENvbmZpZyB9IGZyb20gJy4uLy4uL3R5cGVzJztcblxuZXhwb3J0IGNvbnN0IGNyZWF0ZUNvbHVtbkhlYWRzID0gKGNvbmZpZzogQUlUYWJsZUNvbHVtbkhlYWRzQ29uZmlnKSA9PiB7XG4gICAgY29uc3QgeyBjb29yZGluYXRlLCBjb2x1bW5TdGFydEluZGV4LCBjb2x1bW5TdG9wSW5kZXgsIHBvaW50UG9zaXRpb24sIGFpVGFibGUgfSA9IGNvbmZpZztcbiAgICBjb25zdCBjb2xvcnMgPSBDb2xvcnM7XG4gICAgY29uc3QgeyBjb2x1bW5Db3VudCwgcm93SW5pdFNpemU6IGZpZWxkSGVhZEhlaWdodCB9ID0gY29vcmRpbmF0ZTtcbiAgICBjb25zdCB7IGNvbHVtbkluZGV4OiBwb2ludENvbHVtbkluZGV4LCB0YXJnZXROYW1lOiBwb2ludFRhcmdldE5hbWUgfSA9IHBvaW50UG9zaXRpb247XG4gICAgY29uc3QgZmllbGRzID0gYWlUYWJsZS5ncmlkRGF0YSgpLmZpZWxkcztcblxuICAgIGNvbnN0IGdldEZpZWxkSGVhZFN0YXR1cyA9IChmaWVsZElkOiBzdHJpbmcpID0+IHtcbiAgICAgICAgY29uc3QgaWNvblZpc2libGUgPVxuICAgICAgICAgICAgW0FJX1RBQkxFX0ZJRUxEX0hFQUQsIEFJX1RBQkxFX0ZJRUxEX0hFQURfTU9SRV0uaW5jbHVkZXMocG9pbnRUYXJnZXROYW1lKSAmJiBmaWVsZHNbcG9pbnRDb2x1bW5JbmRleF0/Ll9pZCA9PT0gZmllbGRJZDtcbiAgICAgICAgY29uc3QgaXNIb3Zlckljb24gPSBwb2ludFRhcmdldE5hbWUgPT09IEFJX1RBQkxFX0ZJRUxEX0hFQURfTU9SRSAmJiBmaWVsZHNbcG9pbnRDb2x1bW5JbmRleF0/Ll9pZCA9PT0gZmllbGRJZDtcbiAgICAgICAgY29uc3QgaXNTZWxlY3RlZCA9IGFpVGFibGUuc2VsZWN0aW9uKCkuc2VsZWN0ZWRGaWVsZHMuaGFzKGZpZWxkSWQpO1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgaWNvblZpc2libGUsXG4gICAgICAgICAgICBpc1NlbGVjdGVkLFxuICAgICAgICAgICAgaXNIb3Zlckljb25cbiAgICAgICAgfTtcbiAgICB9O1xuXG4gICAgY29uc3QgZmllbGRIZWFkczogQUlUYWJsZUZpZWxkSGVhZENvbmZpZ1tdID0gW107XG4gICAgY29uc3QgZmllbGRNZW51Rm4gPSBjb25maWcuYWlUYWJsZS5jb250ZXh0Py5haUZpZWxkQ29uZmlnKCk/LmZpZWxkTWVudXM7XG4gICAgY29uc3QgZmllbGRNZW51cyA9IChmaWVsZE1lbnVGbiAmJiBmaWVsZE1lbnVGbihhaVRhYmxlKSkgfHwgW107XG4gICAgbGV0IG5vTW9yZUljb24gPSBmYWxzZTtcbiAgICBpZiAoZmllbGRNZW51cy5sZW5ndGggPT09IDApIHtcbiAgICAgICAgbm9Nb3JlSWNvbiA9IHRydWU7XG4gICAgfVxuICAgIGZvciAobGV0IGNvbHVtbkluZGV4ID0gY29sdW1uU3RhcnRJbmRleDsgY29sdW1uSW5kZXggPD0gY29sdW1uU3RvcEluZGV4OyBjb2x1bW5JbmRleCsrKSB7XG4gICAgICAgIGlmIChjb2x1bW5JbmRleCA+IGNvbHVtbkNvdW50IC0gMSkgYnJlYWs7XG4gICAgICAgIGlmIChjb2x1bW5JbmRleCA8IDApIGNvbnRpbnVlO1xuICAgICAgICBjb25zdCBmaWVsZCA9IGZpZWxkc1tjb2x1bW5JbmRleF07XG4gICAgICAgIGlmIChmaWVsZCA9PSBudWxsKSBjb250aW51ZTtcbiAgICAgICAgY29uc3QgeCA9IGNvb3JkaW5hdGUuZ2V0Q29sdW1uT2Zmc2V0KGNvbHVtbkluZGV4KTtcbiAgICAgICAgY29uc3QgY29sdW1uV2lkdGggPSBjb29yZGluYXRlLmdldENvbHVtbldpZHRoKGNvbHVtbkluZGV4KTtcbiAgICAgICAgY29uc3QgeyBpY29uVmlzaWJsZSwgaXNTZWxlY3RlZCwgaXNIb3Zlckljb24gfSA9IGdldEZpZWxkSGVhZFN0YXR1cyhmaWVsZC5faWQpO1xuICAgICAgICBjb25zdCBmaWVsZEhlYWQgPSB7XG4gICAgICAgICAgICB4LFxuICAgICAgICAgICAgeTogMCxcbiAgICAgICAgICAgIHdpZHRoOiBjb2x1bW5XaWR0aCxcbiAgICAgICAgICAgIGhlaWdodDogZmllbGRIZWFkSGVpZ2h0LFxuICAgICAgICAgICAgZmllbGQsXG4gICAgICAgICAgICBzdHJva2U6IGNvbHVtbkluZGV4ID09PSAwID8gY29sb3JzLnRyYW5zcGFyZW50IDogdW5kZWZpbmVkLFxuICAgICAgICAgICAgaWNvblZpc2libGU6IG5vTW9yZUljb24gPyBmYWxzZSA6IGljb25WaXNpYmxlLFxuICAgICAgICAgICAgaXNTZWxlY3RlZCxcbiAgICAgICAgICAgIGlzSG92ZXJJY29uXG4gICAgICAgIH07XG5cbiAgICAgICAgZmllbGRIZWFkcy5wdXNoKGZpZWxkSGVhZCk7XG4gICAgfVxuICAgIHJldHVybiBmaWVsZEhlYWRzO1xufTtcbiJdfQ==