@ai-table/grid 0.0.73 → 0.1.0
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/components/container.component.d.ts.map +1 -1
- package/angular-konva/components/shape.component.d.ts.map +1 -1
- package/angular-konva/components/stage.component.d.ts.map +1 -1
- package/components/cell-editors/abstract-cell-editor.component.d.ts.map +1 -1
- package/components/cell-editors/date/date-editor.component.d.ts.map +1 -1
- package/components/cell-editors/link/edit-link/edit-link.component.d.ts.map +1 -1
- package/components/cell-editors/link/link-editor.component.d.ts.map +1 -1
- package/components/cell-editors/number/number-editor.component.d.ts.map +1 -1
- package/components/cell-editors/select/select-editor.component.d.ts.map +1 -1
- package/components/cell-editors/text/text-editor.component.d.ts.map +1 -1
- package/components/cell-views/select/option.component.d.ts.map +1 -1
- package/components/context-menu/context-menu.component.d.ts.map +1 -1
- package/components/drag/drag.component.d.ts.map +1 -1
- package/components/field-menu/field-menu.component.d.ts.map +1 -1
- package/components/field-setting/field-setting.component.d.ts.map +1 -1
- package/core/context.d.ts +2 -0
- package/core/context.d.ts.map +1 -1
- package/core/types/ai-table.d.ts.map +1 -1
- package/core/utils/field.d.ts.map +1 -1
- package/core/utils/queries.d.ts.map +1 -1
- package/core/utils/short-id.d.ts.map +1 -1
- package/dom-grid.component.d.ts.map +1 -1
- package/fesm2022/ai-table-grid.mjs +322 -310
- package/fesm2022/ai-table-grid.mjs.map +1 -1
- package/grid-base.component.d.ts +3 -1
- package/grid-base.component.d.ts.map +1 -1
- package/grid.component.d.ts +1 -1
- package/grid.component.d.ts.map +1 -1
- package/package.json +3 -5
- package/pipes/grid.pipe.d.ts.map +1 -1
- package/renderer/components/action-icon.component.d.ts.map +1 -1
- package/renderer/components/add-field-column.component.d.ts.map +1 -1
- package/renderer/components/cells/attachment.component.d.ts.map +1 -1
- package/renderer/components/cells/link.component.d.ts.map +1 -1
- package/renderer/components/cells/progress.component.d.ts.map +1 -1
- package/renderer/components/cells/rate.component.d.ts.map +1 -1
- package/renderer/components/cells/rich-text.component.d.ts.map +1 -1
- package/renderer/components/cells.component.d.ts.map +1 -1
- package/renderer/components/field-head.component.d.ts +2 -2
- package/renderer/components/field-head.component.d.ts.map +1 -1
- package/renderer/components/field-icon.component.d.ts.map +1 -1
- package/renderer/components/frozen-cells.component.d.ts.map +1 -1
- package/renderer/components/frozen-heads.component.d.ts +1 -1
- package/renderer/components/frozen-heads.component.d.ts.map +1 -1
- package/renderer/components/frozen-placeholder-cells.component.d.ts.map +1 -1
- package/renderer/components/heads.component.d.ts +1 -1
- package/renderer/components/heads.component.d.ts.map +1 -1
- package/renderer/components/hover-cell.component.d.ts.map +1 -1
- package/renderer/components/hover-row-heads.component.d.ts.map +1 -1
- package/renderer/components/icon.component.d.ts.map +1 -1
- package/renderer/components/other-rows.component.d.ts.map +1 -1
- package/renderer/components/placeholder-cells.component.d.ts.map +1 -1
- package/renderer/components/text.component.d.ts.map +1 -1
- package/renderer/creations/create-active-cell-border.d.ts.map +1 -1
- package/renderer/creations/create-cells.d.ts.map +1 -1
- package/renderer/creations/create-heads.d.ts.map +1 -1
- package/renderer/drawers/add-row-layout-drawer.d.ts +1 -1
- package/renderer/drawers/add-row-layout-drawer.d.ts.map +1 -1
- package/renderer/drawers/cell-drawer.d.ts.map +1 -1
- package/renderer/drawers/drawer.d.ts +1 -1
- package/renderer/renderer.component.d.ts +5 -4
- package/renderer/renderer.component.d.ts.map +1 -1
- package/types/cell.d.ts +2 -0
- package/types/cell.d.ts.map +1 -1
- package/types/component-config.d.ts +2 -0
- package/types/component-config.d.ts.map +1 -1
- package/types/grid.d.ts +4 -0
- package/types/grid.d.ts.map +1 -1
- package/types/row.d.ts +1 -0
- package/types/row.d.ts.map +1 -1
- package/utils/build.d.ts.map +1 -1
- package/utils/clipboard/clipboard.d.ts.map +1 -1
- package/utils/clipboard/copy.d.ts.map +1 -1
- package/utils/clipboard/paste.d.ts +5 -1
- package/utils/clipboard/paste.d.ts.map +1 -1
- package/utils/common.d.ts.map +1 -1
- package/utils/field/model/date.d.ts.map +1 -1
- package/utils/field/model/link.d.ts.map +1 -1
- package/utils/field/model/progress.d.ts.map +1 -1
- package/utils/field/model/text.d.ts.map +1 -1
- package/utils/get-text-width.d.ts.map +1 -1
- package/utils/i18n.d.ts +2 -0
- package/utils/i18n.d.ts.map +1 -1
- package/utils/match-keywords.d.ts.map +1 -1
- package/utils/position.d.ts.map +1 -1
- package/utils/style.d.ts.map +1 -1
- package/utils/text-measure.d.ts.map +1 -1
- package/utils/visible-range.d.ts.map +1 -1
- package/esm2022/ai-table-grid.mjs +0 -5
- package/esm2022/angular-konva/components/container.component.mjs +0 -29
- package/esm2022/angular-konva/components/container.token.mjs +0 -3
- package/esm2022/angular-konva/components/index.mjs +0 -4
- package/esm2022/angular-konva/components/shape.component.mjs +0 -142
- package/esm2022/angular-konva/components/stage.component.mjs +0 -123
- package/esm2022/angular-konva/index.mjs +0 -5
- package/esm2022/angular-konva/interfaces/component.mjs +0 -4
- package/esm2022/angular-konva/interfaces/config.mjs +0 -2
- package/esm2022/angular-konva/interfaces/event-object.mjs +0 -2
- package/esm2022/angular-konva/interfaces/index.mjs +0 -5
- package/esm2022/angular-konva/interfaces/shape.mjs +0 -42
- package/esm2022/angular-konva/utils/apply-node-props.mjs +0 -67
- package/esm2022/angular-konva/utils/common.mjs +0 -48
- package/esm2022/angular-konva/utils/index.mjs +0 -5
- package/esm2022/angular-konva/utils/types.mjs +0 -2
- package/esm2022/angular-konva/utils/update-picture.mjs +0 -7
- package/esm2022/components/cell-editors/abstract-cell-editor.component.mjs +0 -56
- package/esm2022/components/cell-editors/date/date-editor.component.mjs +0 -87
- package/esm2022/components/cell-editors/link/edit-link/edit-link.component.mjs +0 -81
- package/esm2022/components/cell-editors/link/link-editor.component.mjs +0 -122
- package/esm2022/components/cell-editors/number/number-editor.component.mjs +0 -41
- package/esm2022/components/cell-editors/select/select-editor.component.mjs +0 -74
- package/esm2022/components/cell-editors/text/text-editor.component.mjs +0 -76
- package/esm2022/components/cell-views/select/option.component.mjs +0 -28
- package/esm2022/components/context-menu/context-menu.component.mjs +0 -42
- package/esm2022/components/drag/drag.component.mjs +0 -300
- package/esm2022/components/field-menu/field-menu.component.mjs +0 -47
- package/esm2022/components/field-setting/field-setting.component.mjs +0 -142
- package/esm2022/components/index.mjs +0 -10
- package/esm2022/constants/colors.mjs +0 -19
- package/esm2022/constants/editor.mjs +0 -11
- package/esm2022/constants/file-icon.mjs +0 -342
- package/esm2022/constants/grid.mjs +0 -35
- package/esm2022/constants/icon.mjs +0 -30
- package/esm2022/constants/index.mjs +0 -7
- package/esm2022/constants/table.mjs +0 -78
- package/esm2022/constants/text.mjs +0 -23
- package/esm2022/core/constants/field.mjs +0 -107
- package/esm2022/core/context.mjs +0 -29
- package/esm2022/core/coordinate.mjs +0 -222
- package/esm2022/core/index.mjs +0 -6
- package/esm2022/core/types/ai-table.mjs +0 -57
- package/esm2022/core/types/core.mjs +0 -2
- package/esm2022/core/types/index.mjs +0 -3
- package/esm2022/core/utils/common.mjs +0 -45
- package/esm2022/core/utils/field.mjs +0 -64
- package/esm2022/core/utils/id-creator.mjs +0 -21
- package/esm2022/core/utils/index.mjs +0 -5
- package/esm2022/core/utils/queries.mjs +0 -80
- package/esm2022/core/utils/short-id.mjs +0 -53
- package/esm2022/dom-grid.component.mjs +0 -80
- package/esm2022/grid-base.component.mjs +0 -145
- package/esm2022/grid.component.mjs +0 -649
- package/esm2022/index.mjs +0 -2
- package/esm2022/pipes/grid.pipe.mjs +0 -110
- package/esm2022/pipes/index.mjs +0 -2
- package/esm2022/public-api.mjs +0 -12
- package/esm2022/renderer/components/action-icon.component.mjs +0 -117
- package/esm2022/renderer/components/add-field-column.component.mjs +0 -88
- package/esm2022/renderer/components/cells/attachment.component.mjs +0 -107
- package/esm2022/renderer/components/cells/cells.mjs +0 -6
- package/esm2022/renderer/components/cells/index.mjs +0 -7
- package/esm2022/renderer/components/cells/link.component.mjs +0 -89
- package/esm2022/renderer/components/cells/progress.component.mjs +0 -268
- package/esm2022/renderer/components/cells/rate.component.mjs +0 -153
- package/esm2022/renderer/components/cells/rich-text.component.mjs +0 -95
- package/esm2022/renderer/components/cells.component.mjs +0 -35
- package/esm2022/renderer/components/field-head.component.mjs +0 -146
- package/esm2022/renderer/components/field-icon.component.mjs +0 -72
- package/esm2022/renderer/components/frozen-cells.component.mjs +0 -36
- package/esm2022/renderer/components/frozen-heads.component.mjs +0 -214
- package/esm2022/renderer/components/frozen-placeholder-cells.component.mjs +0 -38
- package/esm2022/renderer/components/heads.component.mjs +0 -38
- package/esm2022/renderer/components/hover-cell.component.mjs +0 -104
- package/esm2022/renderer/components/hover-row-heads.component.mjs +0 -132
- package/esm2022/renderer/components/icon.component.mjs +0 -84
- package/esm2022/renderer/components/index.mjs +0 -15
- package/esm2022/renderer/components/other-rows.component.mjs +0 -68
- package/esm2022/renderer/components/placeholder-cells.component.mjs +0 -33
- package/esm2022/renderer/components/text.component.mjs +0 -67
- package/esm2022/renderer/creations/create-active-cell-border.mjs +0 -70
- package/esm2022/renderer/creations/create-cells.mjs +0 -190
- package/esm2022/renderer/creations/create-heads.mjs +0 -51
- package/esm2022/renderer/drawers/add-row-layout-drawer.mjs +0 -98
- package/esm2022/renderer/drawers/cell-drawer.mjs +0 -673
- package/esm2022/renderer/drawers/drawer.mjs +0 -947
- package/esm2022/renderer/drawers/layout-drawer.mjs +0 -64
- package/esm2022/renderer/drawers/record-row-layout-drawer.mjs +0 -131
- package/esm2022/renderer/index.mjs +0 -4
- package/esm2022/renderer/interfaces/hover-cell.mjs +0 -4
- package/esm2022/renderer/interfaces/index.mjs +0 -2
- package/esm2022/renderer/renderer.component.mjs +0 -197
- package/esm2022/services/event.service.mjs +0 -241
- package/esm2022/services/field.service.mjs +0 -56
- package/esm2022/services/index.mjs +0 -4
- package/esm2022/services/selection.service.mjs +0 -151
- package/esm2022/types/avatar.mjs +0 -27
- package/esm2022/types/canvas.mjs +0 -2
- package/esm2022/types/cell.mjs +0 -2
- package/esm2022/types/clipboard.mjs +0 -2
- package/esm2022/types/component-config.mjs +0 -7
- package/esm2022/types/field.mjs +0 -2
- package/esm2022/types/grid.mjs +0 -17
- package/esm2022/types/index.mjs +0 -10
- package/esm2022/types/layout.mjs +0 -2
- package/esm2022/types/row.mjs +0 -6
- package/esm2022/utils/build.mjs +0 -39
- package/esm2022/utils/cell.mjs +0 -80
- package/esm2022/utils/clear-cells.mjs +0 -23
- package/esm2022/utils/clipboard/clipboard.mjs +0 -88
- package/esm2022/utils/clipboard/copy.mjs +0 -99
- package/esm2022/utils/clipboard/extract.mjs +0 -38
- package/esm2022/utils/clipboard/index.mjs +0 -5
- package/esm2022/utils/clipboard/paste.mjs +0 -188
- package/esm2022/utils/common.mjs +0 -50
- package/esm2022/utils/field/field-operable.mjs +0 -2
- package/esm2022/utils/field/field.mjs +0 -20
- package/esm2022/utils/field/index.mjs +0 -4
- package/esm2022/utils/field/model/attachment.mjs +0 -56
- package/esm2022/utils/field/model/date.mjs +0 -141
- package/esm2022/utils/field/model/index.mjs +0 -12
- package/esm2022/utils/field/model/link.mjs +0 -56
- package/esm2022/utils/field/model/member.mjs +0 -81
- package/esm2022/utils/field/model/number.mjs +0 -59
- package/esm2022/utils/field/model/progress.mjs +0 -69
- package/esm2022/utils/field/model/rate.mjs +0 -58
- package/esm2022/utils/field/model/rich-text.mjs +0 -39
- package/esm2022/utils/field/model/select.mjs +0 -131
- package/esm2022/utils/field/model/text.mjs +0 -32
- package/esm2022/utils/field/operate.mjs +0 -73
- package/esm2022/utils/file.mjs +0 -116
- package/esm2022/utils/get-placeholder-cells.mjs +0 -66
- package/esm2022/utils/get-text-width.mjs +0 -30
- package/esm2022/utils/hover-cell.mjs +0 -25
- package/esm2022/utils/i18n.mjs +0 -87
- package/esm2022/utils/image-cache.mjs +0 -57
- package/esm2022/utils/index.mjs +0 -19
- package/esm2022/utils/match-keywords.mjs +0 -15
- package/esm2022/utils/os.mjs +0 -16
- package/esm2022/utils/position.mjs +0 -48
- package/esm2022/utils/style.mjs +0 -37
- package/esm2022/utils/text-measure.mjs +0 -122
- package/esm2022/utils/visible-range.mjs +0 -42
@@ -1,649 +0,0 @@
|
|
1
|
-
import { afterNextRender, ChangeDetectionStrategy, Component, computed, effect, inject, signal, untracked, viewChild, ViewContainerRef } from '@angular/core';
|
2
|
-
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
3
|
-
import { filter, fromEvent } from 'rxjs';
|
4
|
-
import { AI_TABLE_CELL, AI_TABLE_CELL_PADDING, AI_TABLE_FIELD_ADD_BUTTON, AI_TABLE_FIELD_ADD_BUTTON_WIDTH, AI_TABLE_FIELD_HEAD, AI_TABLE_FIELD_HEAD_HEIGHT, AI_TABLE_FIELD_HEAD_MORE, AI_TABLE_FIELD_HEAD_OPACITY_LINE, AI_TABLE_FIELD_HEAD_SELECT_CHECKBOX, AI_TABLE_PREVENT_CLEAR_SELECTION_CLASS, AI_TABLE_ROW_ADD_BUTTON, AI_TABLE_ROW_DRAG, AI_TABLE_ROW_HEAD, AI_TABLE_ROW_HEAD_WIDTH, AI_TABLE_ROW_SELECT_CHECKBOX, DBL_CLICK_EDIT_TYPE, DEFAULT_POINT_POSITION, DEFAULT_SCROLL_STATE } from './constants';
|
5
|
-
import { Coordinate, RendererContext, AITable } from './core';
|
6
|
-
import { AITableGridBase } from './grid-base.component';
|
7
|
-
import { AITableRenderer } from './renderer/renderer.component';
|
8
|
-
import { AITableGridEventService } from './services/event.service';
|
9
|
-
import { AITableGridFieldService } from './services/field.service';
|
10
|
-
import { AITableGridSelectionService } from './services/selection.service';
|
11
|
-
import { AITableAreaType, AITableMouseDownType, AITableSelectAllState } from './types';
|
12
|
-
import { AITableGridI18nKey, buildGridLinearRows, getColumnIndicesSizeMap, getDetailByTargetName, getI18nTextByKey, handleMouseStyle, isCellMatchKeywords, isWindows, clearCells } from './utils';
|
13
|
-
import { getMousePosition } from './utils/position';
|
14
|
-
import { AITableDragComponent } from './components/drag/drag.component';
|
15
|
-
import { buildClipboardData, writeToClipboard, writeToAITable } from './utils/clipboard';
|
16
|
-
import { ThyNotifyService } from 'ngx-tethys/notify';
|
17
|
-
import { isNumber } from 'lodash';
|
18
|
-
import { DragType } from '@ai-table/utils';
|
19
|
-
import * as i0 from "@angular/core";
|
20
|
-
export class AITableGrid extends AITableGridBase {
|
21
|
-
constructor() {
|
22
|
-
super();
|
23
|
-
this.viewContainerRef = inject(ViewContainerRef);
|
24
|
-
this.isDragSelecting = false;
|
25
|
-
this.dragSelectionStart = null;
|
26
|
-
this.notifyService = inject(ThyNotifyService);
|
27
|
-
this.isPopoverOpen = false;
|
28
|
-
this.fieldHeadHeight = AI_TABLE_FIELD_HEAD_HEIGHT;
|
29
|
-
this.containerRect = signal({ width: 0, height: 0 });
|
30
|
-
this.frozenColumnCount = signal(1);
|
31
|
-
this.hasContainerRect = computed(() => {
|
32
|
-
return this.containerRect().width > 0 && this.containerRect().height > 0;
|
33
|
-
});
|
34
|
-
this.container = viewChild('container');
|
35
|
-
this.verticalBarRef = viewChild('verticalBar');
|
36
|
-
this.horizontalBarRef = viewChild('horizontalBar');
|
37
|
-
this.linearRows = computed(() => {
|
38
|
-
return buildGridLinearRows(this.gridData().records, !this.aiReadonly());
|
39
|
-
});
|
40
|
-
this.visibleColumnsIndexMap = computed(() => {
|
41
|
-
const columns = AITable.getVisibleFields(this.aiTable);
|
42
|
-
return new Map(columns?.map((item, index) => [item._id, index]));
|
43
|
-
});
|
44
|
-
this.visibleRowsIndexMap = computed(() => {
|
45
|
-
return new Map(this.linearRows().map((row, index) => [row._id, index]));
|
46
|
-
});
|
47
|
-
this.containerElement = computed(() => {
|
48
|
-
return this.container().nativeElement;
|
49
|
-
});
|
50
|
-
this.rendererConfig = computed(() => {
|
51
|
-
const fields = AITable.getVisibleFields(this.aiTable);
|
52
|
-
const coordinate = new Coordinate({
|
53
|
-
container: this.containerElement(),
|
54
|
-
rowHeight: AI_TABLE_FIELD_HEAD_HEIGHT,
|
55
|
-
rowCount: this.linearRows().length,
|
56
|
-
columnCount: fields.length,
|
57
|
-
rowInitSize: AI_TABLE_FIELD_HEAD_HEIGHT,
|
58
|
-
columnInitSize: this.aiTable.context.rowHeadWidth(),
|
59
|
-
rowIndicesSizeMap: {},
|
60
|
-
columnIndicesSizeMap: getColumnIndicesSizeMap(this.aiTable, fields),
|
61
|
-
frozenColumnCount: this.frozenColumnCount()
|
62
|
-
});
|
63
|
-
return {
|
64
|
-
aiTable: this.aiTable,
|
65
|
-
gridData: this.gridData(),
|
66
|
-
container: this.containerElement(),
|
67
|
-
coordinate: coordinate,
|
68
|
-
containerWidth: this.containerRect().width,
|
69
|
-
containerHeight: this.containerRect().height,
|
70
|
-
references: this.aiReferences(),
|
71
|
-
readonly: this.aiReadonly(),
|
72
|
-
rowDragDisabled: this.aiRowDragDisabled(),
|
73
|
-
actions: this.actions
|
74
|
-
};
|
75
|
-
});
|
76
|
-
this.coordinate = computed(() => {
|
77
|
-
return this.rendererConfig().coordinate;
|
78
|
-
});
|
79
|
-
this.scrollTotalHeight = computed(() => {
|
80
|
-
return Math.max(this.coordinate().totalHeight, this.containerRect().height - this.fieldHeadHeight);
|
81
|
-
});
|
82
|
-
this.scrollbarWidth = computed(() => {
|
83
|
-
return this.coordinate().totalWidth + AI_TABLE_FIELD_ADD_BUTTON_WIDTH;
|
84
|
-
});
|
85
|
-
this.actions = {
|
86
|
-
updateFieldValue: (data) => {
|
87
|
-
this.aiUpdateFieldValue.emit(data);
|
88
|
-
},
|
89
|
-
setField: (field) => {
|
90
|
-
this.aiSetField.emit(field);
|
91
|
-
},
|
92
|
-
addField: (data) => {
|
93
|
-
this.aiAddField.emit(data);
|
94
|
-
},
|
95
|
-
addRecord: (data) => {
|
96
|
-
this.addRecord(data);
|
97
|
-
}
|
98
|
-
};
|
99
|
-
this.scrollAction = (options) => {
|
100
|
-
if (this.timer) {
|
101
|
-
cancelAnimationFrame(this.timer);
|
102
|
-
}
|
103
|
-
this.timer = requestAnimationFrame(() => {
|
104
|
-
const { deltaX, deltaY, shiftKey } = options;
|
105
|
-
const fixedDeltaY = shiftKey && isWindows ? 0 : deltaY;
|
106
|
-
const fixedDeltaX = shiftKey && isWindows ? deltaY : deltaX;
|
107
|
-
const horizontalBar = this.horizontalBarRef()?.nativeElement;
|
108
|
-
const verticalBar = this.verticalBarRef()?.nativeElement;
|
109
|
-
if (horizontalBar) {
|
110
|
-
horizontalBar.scrollLeft = horizontalBar.scrollLeft + fixedDeltaX;
|
111
|
-
}
|
112
|
-
if (verticalBar) {
|
113
|
-
verticalBar.scrollTop = verticalBar.scrollTop + fixedDeltaY;
|
114
|
-
}
|
115
|
-
options.callback && options.callback();
|
116
|
-
this.timer = null;
|
117
|
-
});
|
118
|
-
};
|
119
|
-
this.resetScrolling = () => {
|
120
|
-
this.aiTable.context.setScrollState({
|
121
|
-
isScrolling: false
|
122
|
-
});
|
123
|
-
};
|
124
|
-
this.horizontalScroll = (e) => {
|
125
|
-
const { scrollLeft } = e.target;
|
126
|
-
this.aiTable.context.setScrollState({
|
127
|
-
scrollLeft,
|
128
|
-
isScrolling: true
|
129
|
-
});
|
130
|
-
this.resetScrolling();
|
131
|
-
};
|
132
|
-
afterNextRender(() => {
|
133
|
-
this.setContainerRect();
|
134
|
-
this.bindGlobalMousedown();
|
135
|
-
this.containerResizeListener();
|
136
|
-
this.bindWheel();
|
137
|
-
this.bindClipboardShortcuts();
|
138
|
-
});
|
139
|
-
effect(() => {
|
140
|
-
if (this.hasContainerRect() && this.horizontalBarRef() && this.verticalBarRef()) {
|
141
|
-
this.bindScrollBarScroll();
|
142
|
-
}
|
143
|
-
});
|
144
|
-
effect(() => {
|
145
|
-
this.setKeywordsMatchedCells();
|
146
|
-
}, { allowSignalWrites: true });
|
147
|
-
effect(() => {
|
148
|
-
// 当新增行选中的cell,编辑后,activeCell 不在新增的行中时,根据筛选 过滤行数据,触发重新渲染
|
149
|
-
const activeCellPath = this.aiTable.selection().activeCell;
|
150
|
-
untracked(() => {
|
151
|
-
if (!activeCellPath || !this.aiTable.recordsWillHidden().includes(activeCellPath[0])) {
|
152
|
-
if (this.aiTable.recordsWillHidden().length > 0) {
|
153
|
-
this.aiTable.recordsWillHidden.set([]);
|
154
|
-
}
|
155
|
-
}
|
156
|
-
});
|
157
|
-
}, { allowSignalWrites: true });
|
158
|
-
effect(() => {
|
159
|
-
const recordIdSet = new Set(this.aiTable.records().map((item) => item._id));
|
160
|
-
untracked(() => {
|
161
|
-
const selectedRecords = this.aiTable.selection().selectedRecords;
|
162
|
-
for (const selectedRecordId of selectedRecords.values()) {
|
163
|
-
if (!recordIdSet.has(selectedRecordId)) {
|
164
|
-
selectedRecords.delete(selectedRecordId);
|
165
|
-
}
|
166
|
-
}
|
167
|
-
this.aiTable.selection.update((item) => {
|
168
|
-
return {
|
169
|
-
...item,
|
170
|
-
selectedRecords,
|
171
|
-
selectAllState: this.aiTableGridSelectionService.selectAllState()
|
172
|
-
};
|
173
|
-
});
|
174
|
-
});
|
175
|
-
}, { allowSignalWrites: true });
|
176
|
-
}
|
177
|
-
ngOnInit() {
|
178
|
-
super.ngOnInit();
|
179
|
-
this.initContext();
|
180
|
-
}
|
181
|
-
ngOnDestroy() {
|
182
|
-
this.resizeObserver?.disconnect();
|
183
|
-
}
|
184
|
-
initContext() {
|
185
|
-
this.aiTable.context = new RendererContext({
|
186
|
-
rowHeadWidth: computed(() => (this.aiFieldConfig()?.hiddenIndexColumn ? 0 : AI_TABLE_ROW_HEAD_WIDTH)),
|
187
|
-
linearRows: this.linearRows,
|
188
|
-
visibleColumnsIndexMap: this.visibleColumnsIndexMap,
|
189
|
-
visibleRowsIndexMap: this.visibleRowsIndexMap,
|
190
|
-
pointPosition: signal(DEFAULT_POINT_POSITION),
|
191
|
-
scrollState: signal(DEFAULT_SCROLL_STATE),
|
192
|
-
frozenColumnCount: this.frozenColumnCount,
|
193
|
-
references: this.aiReferences,
|
194
|
-
aiFieldConfig: this.aiFieldConfig,
|
195
|
-
scrollAction: this.scrollAction
|
196
|
-
});
|
197
|
-
}
|
198
|
-
setKeywordsMatchedCells() {
|
199
|
-
const keywords = this.aiKeywords();
|
200
|
-
let matchedCells = new Set();
|
201
|
-
if (keywords) {
|
202
|
-
const references = this.aiReferences();
|
203
|
-
this.aiTable.records().forEach((record) => {
|
204
|
-
this.aiTable.fields().forEach((field) => {
|
205
|
-
if (isCellMatchKeywords(this.aiTable, field, record._id, keywords, references)) {
|
206
|
-
matchedCells.add(`${record._id}:${field._id}`);
|
207
|
-
}
|
208
|
-
});
|
209
|
-
});
|
210
|
-
}
|
211
|
-
this.aiTable.keywordsMatchedCells.set(matchedCells);
|
212
|
-
}
|
213
|
-
stageMousemove(e) {
|
214
|
-
if (this.timer) {
|
215
|
-
cancelAnimationFrame(this.timer);
|
216
|
-
}
|
217
|
-
this.timer = requestAnimationFrame(() => {
|
218
|
-
const targetName = e.event.target.name();
|
219
|
-
const gridStage = e.event.currentTarget.getStage();
|
220
|
-
const pos = gridStage?.getPointerPosition();
|
221
|
-
if (pos == null)
|
222
|
-
return;
|
223
|
-
const { context } = this.aiTable;
|
224
|
-
const { x, y } = pos;
|
225
|
-
const curMousePosition = getMousePosition(this.aiTable, x, y, this.coordinate(), AITable.getVisibleFields(this.aiTable), context, targetName);
|
226
|
-
handleMouseStyle(curMousePosition.realTargetName, curMousePosition.areaType, this.containerElement(), this.aiReadonly(), this.aiRowDragDisabled());
|
227
|
-
if (curMousePosition.areaType !== AITableAreaType.none) {
|
228
|
-
context.setPointPosition(curMousePosition);
|
229
|
-
}
|
230
|
-
else {
|
231
|
-
this.setDefaultPointPosition();
|
232
|
-
}
|
233
|
-
this.timer = null;
|
234
|
-
if (this.isDragSelecting) {
|
235
|
-
const { fieldId, recordId } = getDetailByTargetName(curMousePosition.realTargetName);
|
236
|
-
if (fieldId && recordId) {
|
237
|
-
const startCell = this.dragSelectionStart;
|
238
|
-
const endCell = [recordId, fieldId];
|
239
|
-
if (startCell && !!startCell.length) {
|
240
|
-
this.aiTableGridSelectionService.selectCells(startCell, endCell);
|
241
|
-
}
|
242
|
-
}
|
243
|
-
}
|
244
|
-
});
|
245
|
-
}
|
246
|
-
stageMousedown(e) {
|
247
|
-
const mouseEvent = e.event.evt;
|
248
|
-
const _targetName = e.event.target.name();
|
249
|
-
const { targetName, fieldId, recordId } = getDetailByTargetName(_targetName);
|
250
|
-
if (mouseEvent.button === AITableMouseDownType.Right &&
|
251
|
-
recordId &&
|
252
|
-
fieldId &&
|
253
|
-
(this.aiTable.selection().selectedRecords.has(recordId) || this.aiTable.selection().selectedCells.has(`${recordId}:${fieldId}`))) {
|
254
|
-
return;
|
255
|
-
}
|
256
|
-
switch (targetName) {
|
257
|
-
case AI_TABLE_FIELD_HEAD:
|
258
|
-
mouseEvent.preventDefault();
|
259
|
-
if (!fieldId)
|
260
|
-
return;
|
261
|
-
this.aiTableGridSelectionService.selectField(fieldId);
|
262
|
-
this.handleFieldDragStart();
|
263
|
-
return;
|
264
|
-
case AI_TABLE_FIELD_HEAD_OPACITY_LINE:
|
265
|
-
mouseEvent.preventDefault();
|
266
|
-
if (!fieldId)
|
267
|
-
return;
|
268
|
-
this.handleFieldWidthDragStart(fieldId);
|
269
|
-
return;
|
270
|
-
case AI_TABLE_CELL:
|
271
|
-
if (!recordId || !fieldId)
|
272
|
-
return;
|
273
|
-
const dragSelectionStart = [recordId, fieldId];
|
274
|
-
this.updateDragSelectionState(true, dragSelectionStart);
|
275
|
-
this.aiTableGridSelectionService.selectCells(dragSelectionStart);
|
276
|
-
return;
|
277
|
-
case AI_TABLE_ROW_DRAG:
|
278
|
-
if (!recordId)
|
279
|
-
return;
|
280
|
-
mouseEvent.preventDefault();
|
281
|
-
const selectedRecords = this.aiTable.selection().selectedRecords;
|
282
|
-
let dragRecords = [];
|
283
|
-
if (selectedRecords.has(recordId)) {
|
284
|
-
dragRecords = [recordId, ...selectedRecords.values()];
|
285
|
-
}
|
286
|
-
else {
|
287
|
-
// 当前拖拽行不在选中行中,只拖拽当前行
|
288
|
-
dragRecords = [recordId];
|
289
|
-
}
|
290
|
-
this.handleRowDragStart(dragRecords);
|
291
|
-
return;
|
292
|
-
case AI_TABLE_ROW_ADD_BUTTON:
|
293
|
-
case AI_TABLE_FIELD_ADD_BUTTON:
|
294
|
-
case AI_TABLE_ROW_HEAD:
|
295
|
-
case AI_TABLE_ROW_SELECT_CHECKBOX:
|
296
|
-
case AI_TABLE_FIELD_HEAD_SELECT_CHECKBOX:
|
297
|
-
return;
|
298
|
-
default:
|
299
|
-
this.aiTableGridSelectionService.clearSelection();
|
300
|
-
}
|
301
|
-
}
|
302
|
-
stageMouseup(e) {
|
303
|
-
this.updateDragSelectionState(false, null);
|
304
|
-
}
|
305
|
-
stageMouseleave(e) {
|
306
|
-
if (this.timer) {
|
307
|
-
cancelAnimationFrame(this.timer);
|
308
|
-
}
|
309
|
-
this.timer = requestAnimationFrame(() => {
|
310
|
-
if (this.isPopoverOpen) {
|
311
|
-
return;
|
312
|
-
}
|
313
|
-
this.setDefaultPointPosition();
|
314
|
-
});
|
315
|
-
}
|
316
|
-
stageContextmenu(e) {
|
317
|
-
const mouseEvent = e.event.evt;
|
318
|
-
mouseEvent.preventDefault();
|
319
|
-
if (this.aiReadonly()) {
|
320
|
-
return;
|
321
|
-
}
|
322
|
-
const targetName = e.event.target.name();
|
323
|
-
const { fieldId, recordId } = getDetailByTargetName(targetName);
|
324
|
-
if (!recordId || !fieldId) {
|
325
|
-
return;
|
326
|
-
}
|
327
|
-
const position = {
|
328
|
-
x: mouseEvent.x,
|
329
|
-
y: mouseEvent.y
|
330
|
-
};
|
331
|
-
const menuItems = [];
|
332
|
-
if (this.aiContextMenuItems()) {
|
333
|
-
menuItems.push(...this.aiContextMenuItems()(this.aiTable));
|
334
|
-
}
|
335
|
-
if (!menuItems.length || menuItems.every((item) => !!(item.hidden && item.hidden(this.aiTable, targetName, position)))) {
|
336
|
-
return;
|
337
|
-
}
|
338
|
-
this.aiTableGridEventService.openContextMenu(this.aiTable, {
|
339
|
-
origin: this.containerElement(),
|
340
|
-
menuItems,
|
341
|
-
position,
|
342
|
-
targetName,
|
343
|
-
viewContainerRef: this.viewContainerRef
|
344
|
-
});
|
345
|
-
}
|
346
|
-
stageClick(e) {
|
347
|
-
const targetNameDetail = getDetailByTargetName(e.event.target.name());
|
348
|
-
this.aiClick.emit({
|
349
|
-
...e,
|
350
|
-
targetNameDetail
|
351
|
-
});
|
352
|
-
const mouseEvent = e.event.evt;
|
353
|
-
mouseEvent.preventDefault();
|
354
|
-
this.aiTableGridEventService.closeCellEditor();
|
355
|
-
const { context } = this.aiTable;
|
356
|
-
const { targetName, rowIndex: pointRowIndex } = context.pointPosition();
|
357
|
-
if (mouseEvent.button !== AITableMouseDownType.Left || (targetName !== AI_TABLE_FIELD_HEAD_MORE && this.aiReadonly()))
|
358
|
-
return;
|
359
|
-
switch (targetName) {
|
360
|
-
case AI_TABLE_ROW_ADD_BUTTON: {
|
361
|
-
this.aiTableGridSelectionService.clearSelection();
|
362
|
-
this.addRecord();
|
363
|
-
const { records, fields } = this.gridData();
|
364
|
-
this.aiTableGridSelectionService.setActiveCell([records[records.length - 1]._id, fields[0]._id]);
|
365
|
-
break;
|
366
|
-
}
|
367
|
-
case AI_TABLE_ROW_SELECT_CHECKBOX: {
|
368
|
-
const pointRecordId = context.linearRows()[pointRowIndex]?._id;
|
369
|
-
this.selectRecord(pointRecordId);
|
370
|
-
break;
|
371
|
-
}
|
372
|
-
case AI_TABLE_FIELD_HEAD_SELECT_CHECKBOX: {
|
373
|
-
const isChecked = this.aiTable.selection().selectAllState === AITableSelectAllState.all;
|
374
|
-
this.toggleSelectAll(!isChecked);
|
375
|
-
break;
|
376
|
-
}
|
377
|
-
case AI_TABLE_FIELD_ADD_BUTTON: {
|
378
|
-
this.aiTableGridSelectionService.clearSelection();
|
379
|
-
const fieldGroupRect = e.event.target.getParent()?.getClientRect();
|
380
|
-
const containerRect = this.containerElement().getBoundingClientRect();
|
381
|
-
this.addField(this.containerElement(), {
|
382
|
-
x: fieldGroupRect.x + containerRect.x,
|
383
|
-
y: containerRect.y + fieldGroupRect.y + fieldGroupRect.height
|
384
|
-
});
|
385
|
-
break;
|
386
|
-
}
|
387
|
-
case AI_TABLE_FIELD_HEAD_MORE:
|
388
|
-
mouseEvent.preventDefault();
|
389
|
-
const _targetName = e.event.target.name();
|
390
|
-
const { fieldId } = getDetailByTargetName(_targetName);
|
391
|
-
if (fieldId) {
|
392
|
-
const moreRect = e.event.target.getClientRect();
|
393
|
-
const fieldGroupRect = e.event.target.getParent()?.getParent()?.getClientRect();
|
394
|
-
const containerRect = this.containerElement().getBoundingClientRect();
|
395
|
-
const position = {
|
396
|
-
x: containerRect.x + moreRect.x,
|
397
|
-
y: containerRect.y + moreRect.y + moreRect.height
|
398
|
-
};
|
399
|
-
const editFieldPosition = {
|
400
|
-
x: containerRect.x + fieldGroupRect.x - AI_TABLE_CELL_PADDING,
|
401
|
-
y: containerRect.y + fieldGroupRect.y + fieldGroupRect.height
|
402
|
-
};
|
403
|
-
const editOrigin = this.containerElement().querySelector('.konvajs-content');
|
404
|
-
const menuRef = this.aiTableGridFieldService.openFieldMenu(this.aiTable, {
|
405
|
-
fieldId: fieldId,
|
406
|
-
fieldMenus: this.fieldMenus(),
|
407
|
-
origin: this.containerElement(),
|
408
|
-
position,
|
409
|
-
editOrigin: editOrigin,
|
410
|
-
editFieldPosition
|
411
|
-
});
|
412
|
-
if (menuRef) {
|
413
|
-
menuRef.afterClosed().subscribe(() => {
|
414
|
-
this.isPopoverOpen = false;
|
415
|
-
this.setDefaultPointPosition();
|
416
|
-
});
|
417
|
-
this.isPopoverOpen = true;
|
418
|
-
}
|
419
|
-
}
|
420
|
-
break;
|
421
|
-
}
|
422
|
-
return;
|
423
|
-
}
|
424
|
-
stageDblclick(e) {
|
425
|
-
const _targetName = e.event.target.name();
|
426
|
-
const targetNameDetail = getDetailByTargetName(_targetName);
|
427
|
-
this.aiDbClick.emit({
|
428
|
-
...e,
|
429
|
-
targetNameDetail
|
430
|
-
});
|
431
|
-
if (this.aiReadonly()) {
|
432
|
-
return;
|
433
|
-
}
|
434
|
-
const { fieldId, recordId } = targetNameDetail;
|
435
|
-
if (!recordId || !fieldId) {
|
436
|
-
return;
|
437
|
-
}
|
438
|
-
const field = this.aiTable.fieldsMap()[fieldId];
|
439
|
-
const fieldType = field.type;
|
440
|
-
if (DBL_CLICK_EDIT_TYPE.includes(fieldType)) {
|
441
|
-
setTimeout(() => {
|
442
|
-
this.aiTableGridEventService.openCellEditor(this.aiTable, {
|
443
|
-
viewContainerRef: this.viewContainerRef,
|
444
|
-
container: this.containerElement(),
|
445
|
-
coordinate: this.coordinate(),
|
446
|
-
fieldId: fieldId,
|
447
|
-
recordId: recordId,
|
448
|
-
references: this.aiReferences(),
|
449
|
-
updateFieldValue: (value) => {
|
450
|
-
this.aiUpdateFieldValue.emit(value);
|
451
|
-
}
|
452
|
-
});
|
453
|
-
}, 0);
|
454
|
-
}
|
455
|
-
}
|
456
|
-
bindWheel() {
|
457
|
-
fromEvent(this.containerElement(), 'wheel', { passive: false })
|
458
|
-
.pipe(takeUntilDestroyed(this.destroyRef))
|
459
|
-
.subscribe((e) => {
|
460
|
-
e.preventDefault();
|
461
|
-
this.aiTableGridEventService.closeCellEditor();
|
462
|
-
this.scrollAction({ deltaX: e.deltaX, deltaY: e.deltaY, shiftKey: e.shiftKey });
|
463
|
-
});
|
464
|
-
}
|
465
|
-
setDefaultPointPosition() {
|
466
|
-
const { context } = this.aiTable;
|
467
|
-
context.setPointPosition(DEFAULT_POINT_POSITION);
|
468
|
-
}
|
469
|
-
bindScrollBarScroll() {
|
470
|
-
fromEvent(this.horizontalBarRef().nativeElement, 'scroll', { passive: true })
|
471
|
-
.pipe(takeUntilDestroyed(this.destroyRef))
|
472
|
-
.subscribe((e) => {
|
473
|
-
this.horizontalScroll(e);
|
474
|
-
});
|
475
|
-
fromEvent(this.verticalBarRef().nativeElement, 'scroll', { passive: true })
|
476
|
-
.pipe(takeUntilDestroyed(this.destroyRef))
|
477
|
-
.subscribe((e) => {
|
478
|
-
this.verticalScroll(e);
|
479
|
-
});
|
480
|
-
}
|
481
|
-
bindGlobalMousedown() {
|
482
|
-
fromEvent(document, 'mousedown', { passive: true })
|
483
|
-
.pipe(filter((e) => e.target instanceof Element &&
|
484
|
-
!this.containerElement().contains(e.target) &&
|
485
|
-
!e.target.closest(AI_TABLE_PREVENT_CLEAR_SELECTION_CLASS)), takeUntilDestroyed(this.destroyRef))
|
486
|
-
.subscribe(() => {
|
487
|
-
this.updateDragSelectionState(false, null);
|
488
|
-
this.aiTableGridSelectionService.clearSelection();
|
489
|
-
});
|
490
|
-
}
|
491
|
-
updateDragSelectionState(isDragSelecting, dragSelectionStart) {
|
492
|
-
this.isDragSelecting = isDragSelecting;
|
493
|
-
this.dragSelectionStart = dragSelectionStart;
|
494
|
-
}
|
495
|
-
verticalScroll(e) {
|
496
|
-
const { scrollTop } = e.target;
|
497
|
-
this.aiTable.context.setScrollState({
|
498
|
-
scrollTop,
|
499
|
-
isScrolling: true
|
500
|
-
});
|
501
|
-
this.resetScrolling();
|
502
|
-
}
|
503
|
-
setContainerRect() {
|
504
|
-
this.containerRect.set({
|
505
|
-
width: this.containerElement().offsetWidth,
|
506
|
-
height: this.containerElement().offsetHeight
|
507
|
-
});
|
508
|
-
}
|
509
|
-
containerResizeListener() {
|
510
|
-
this.resizeObserver = new ResizeObserver(() => {
|
511
|
-
const containerWidth = this.containerElement().offsetWidth;
|
512
|
-
const totalWidth = this.coordinate().totalWidth + AI_TABLE_FIELD_ADD_BUTTON_WIDTH;
|
513
|
-
this.setContainerRect();
|
514
|
-
if (containerWidth >= totalWidth) {
|
515
|
-
this.aiTable.context.setScrollState({ scrollLeft: 0 });
|
516
|
-
return;
|
517
|
-
}
|
518
|
-
});
|
519
|
-
this.resizeObserver.observe(this.containerElement());
|
520
|
-
}
|
521
|
-
bindClipboardShortcuts() {
|
522
|
-
fromEvent(document, 'keydown')
|
523
|
-
.pipe(filter((event) => ((event.ctrlKey || event.metaKey) && (event.key === 'c' || event.key === 'v')) ||
|
524
|
-
event.key === 'Backspace' ||
|
525
|
-
event.key === 'Delete'), takeUntilDestroyed(this.destroyRef))
|
526
|
-
.subscribe(async (event) => {
|
527
|
-
if (this.aiReadonly()) {
|
528
|
-
return;
|
529
|
-
}
|
530
|
-
const hasSelectedCells = this.aiTable.selection().selectedCells.size > 0;
|
531
|
-
if (!hasSelectedCells) {
|
532
|
-
return;
|
533
|
-
}
|
534
|
-
const hasEditingCell = !!this.aiTableGridEventService.getCurrentEditCell();
|
535
|
-
if (hasEditingCell) {
|
536
|
-
return;
|
537
|
-
}
|
538
|
-
event.preventDefault();
|
539
|
-
if (event.key === 'c') {
|
540
|
-
this.copyCells();
|
541
|
-
}
|
542
|
-
else if (event.key === 'v') {
|
543
|
-
this.pasteCells();
|
544
|
-
}
|
545
|
-
else if (event.key === 'Backspace' || event.key === 'Delete') {
|
546
|
-
clearCells(this.aiTable, this.actions);
|
547
|
-
}
|
548
|
-
});
|
549
|
-
}
|
550
|
-
copyCells() {
|
551
|
-
const clipboardData = buildClipboardData(this.aiTable);
|
552
|
-
if (clipboardData) {
|
553
|
-
writeToClipboard(clipboardData).then(() => {
|
554
|
-
const copiedCellsCount = this.aiTable.selection().selectedCells.size;
|
555
|
-
const message = getI18nTextByKey(this.aiTable, AITableGridI18nKey.copiedCells).replace('{count}', copiedCellsCount.toString());
|
556
|
-
this.notifyService.success(message, undefined, {
|
557
|
-
placement: 'bottomLeft'
|
558
|
-
});
|
559
|
-
});
|
560
|
-
}
|
561
|
-
}
|
562
|
-
pasteCells() {
|
563
|
-
writeToAITable(this.aiTable, this.actions).then((isPasteSuccess) => {
|
564
|
-
if (!isPasteSuccess) {
|
565
|
-
this.notifyService.error(getI18nTextByKey(this.aiTable, AITableGridI18nKey.invalidPasteContent), undefined, {
|
566
|
-
placement: 'bottomLeft'
|
567
|
-
});
|
568
|
-
}
|
569
|
-
});
|
570
|
-
}
|
571
|
-
handleFieldDragStart() {
|
572
|
-
if (!this.aiReadonly() && this.aiTableGridSelectionService.selectedFields.size > 0) {
|
573
|
-
this.aiTableGridSelectionService.drag({
|
574
|
-
type: DragType.field,
|
575
|
-
sourceIds: this.aiTableGridSelectionService.selectedFields,
|
576
|
-
scroll: this.getScrollPosition(),
|
577
|
-
coordinate: this.coordinate()
|
578
|
-
});
|
579
|
-
}
|
580
|
-
}
|
581
|
-
handleFieldWidthDragStart(fieldId) {
|
582
|
-
if (!this.aiReadonly() && fieldId) {
|
583
|
-
this.aiTableGridSelectionService.drag({
|
584
|
-
type: DragType.columnWidth,
|
585
|
-
sourceIds: new Set([fieldId]),
|
586
|
-
scroll: this.getScrollPosition(),
|
587
|
-
coordinate: this.coordinate()
|
588
|
-
});
|
589
|
-
}
|
590
|
-
}
|
591
|
-
handleRowDragStart(recordIds) {
|
592
|
-
if (!this.aiReadonly() && !this.aiRowDragDisabled() && recordIds.length > 0) {
|
593
|
-
this.aiTableGridSelectionService.drag({
|
594
|
-
type: DragType.record,
|
595
|
-
sourceIds: new Set(recordIds),
|
596
|
-
scroll: this.getScrollPosition(),
|
597
|
-
coordinate: this.coordinate()
|
598
|
-
});
|
599
|
-
}
|
600
|
-
}
|
601
|
-
getScrollPosition() {
|
602
|
-
const horizontalBar = this.horizontalBarRef()?.nativeElement;
|
603
|
-
const verticalBar = this.verticalBarRef()?.nativeElement;
|
604
|
-
let scrollLeft = horizontalBar?.scrollLeft || 0;
|
605
|
-
let scrollTop = verticalBar?.scrollTop || 0;
|
606
|
-
return { x: scrollLeft, y: scrollTop };
|
607
|
-
}
|
608
|
-
dragEnd(data) {
|
609
|
-
switch (data.type) {
|
610
|
-
case DragType.field:
|
611
|
-
if (data.fieldsIndex && isNumber(data.targetIndex)) {
|
612
|
-
for (let i = 0; i < data.fieldsIndex.length; i++) {
|
613
|
-
this.aiMoveField.emit({
|
614
|
-
path: [data.fieldsIndex[i]],
|
615
|
-
newPath: [data.targetIndex + i]
|
616
|
-
});
|
617
|
-
}
|
618
|
-
}
|
619
|
-
break;
|
620
|
-
case DragType.columnWidth:
|
621
|
-
if (data.fieldIds && isNumber(data.width)) {
|
622
|
-
const fieldId = data.fieldIds.values().next().value;
|
623
|
-
this.aiSetFieldWidth.emit({
|
624
|
-
path: [fieldId],
|
625
|
-
width: data.width
|
626
|
-
});
|
627
|
-
}
|
628
|
-
break;
|
629
|
-
case DragType.record:
|
630
|
-
if (data.recordIds && isNumber(data.targetIndex)) {
|
631
|
-
this.aiMoveRecords.emit({
|
632
|
-
recordIds: Array.from(data.recordIds).map((id) => [id]),
|
633
|
-
newPath: [data.targetIndex]
|
634
|
-
});
|
635
|
-
}
|
636
|
-
return;
|
637
|
-
}
|
638
|
-
this.aiTableGridSelectionService.clearDrag();
|
639
|
-
}
|
640
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableGrid, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
641
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: AITableGrid, isStandalone: true, selector: "ai-table-grid", host: { classAttribute: "ai-table-grid" }, providers: [AITableGridEventService, AITableGridFieldService, AITableGridSelectionService], viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true, isSignal: true }, { propertyName: "verticalBarRef", first: true, predicate: ["verticalBar"], descendants: true, isSignal: true }, { propertyName: "horizontalBarRef", first: true, predicate: ["horizontalBar"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<div #container class=\"ai-table-grid-view\">\n @if (hasContainerRect()) {\n <ai-table-renderer\n [config]=\"rendererConfig()\"\n (koMousemove)=\"stageMousemove($event)\"\n (koMousedown)=\"stageMousedown($event)\"\n (koMouseup)=\"stageMouseup($event)\"\n (koContextmenu)=\"stageContextmenu($event)\"\n (koClick)=\"stageClick($event)\"\n (koDblclick)=\"stageDblclick($event)\"\n (koMouseleave)=\"stageMouseleave($event)\"\n >\n <div #horizontalBar class=\"ai-table-horizontal-scroll-bar-wrapper\" [style.width.px]=\"containerRect().width\">\n <div class=\"ai-table-scroll-bar-inner\" [style.width.px]=\"scrollbarWidth()\"></div>\n </div>\n <div\n #verticalBar\n class=\"ai-table-vertical-scroll-bar-wrapper\"\n [style.height.px]=\"containerRect().height - fieldHeadHeight\"\n [style.top.px]=\"fieldHeadHeight\"\n >\n <div class=\"ai-table-scroll-bar-inner\" [style.height.px]=\"scrollTotalHeight()\"></div>\n </div>\n </ai-table-renderer>\n }\n <ai-table-drag (dragEnd)=\"dragEnd($event)\"></ai-table-drag>\n</div>\n", dependencies: [{ kind: "component", type: AITableRenderer, selector: "ai-table-renderer", inputs: ["config"], outputs: ["koMousemove", "koMousedown", "koMouseup", "koContextmenu", "koWheel", "koClick", "koDblclick", "koMouseleave"] }, { kind: "component", type: AITableDragComponent, selector: "ai-table-drag", outputs: ["dragEnd"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
642
|
-
}
|
643
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableGrid, decorators: [{
|
644
|
-
type: Component,
|
645
|
-
args: [{ selector: 'ai-table-grid', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, host: {
|
646
|
-
class: 'ai-table-grid'
|
647
|
-
}, imports: [AITableRenderer, AITableDragComponent], providers: [AITableGridEventService, AITableGridFieldService, AITableGridSelectionService], template: "<div #container class=\"ai-table-grid-view\">\n @if (hasContainerRect()) {\n <ai-table-renderer\n [config]=\"rendererConfig()\"\n (koMousemove)=\"stageMousemove($event)\"\n (koMousedown)=\"stageMousedown($event)\"\n (koMouseup)=\"stageMouseup($event)\"\n (koContextmenu)=\"stageContextmenu($event)\"\n (koClick)=\"stageClick($event)\"\n (koDblclick)=\"stageDblclick($event)\"\n (koMouseleave)=\"stageMouseleave($event)\"\n >\n <div #horizontalBar class=\"ai-table-horizontal-scroll-bar-wrapper\" [style.width.px]=\"containerRect().width\">\n <div class=\"ai-table-scroll-bar-inner\" [style.width.px]=\"scrollbarWidth()\"></div>\n </div>\n <div\n #verticalBar\n class=\"ai-table-vertical-scroll-bar-wrapper\"\n [style.height.px]=\"containerRect().height - fieldHeadHeight\"\n [style.top.px]=\"fieldHeadHeight\"\n >\n <div class=\"ai-table-scroll-bar-inner\" [style.height.px]=\"scrollTotalHeight()\"></div>\n </div>\n </ai-table-renderer>\n }\n <ai-table-drag (dragEnd)=\"dragEnd($event)\"></ai-table-drag>\n</div>\n" }]
|
648
|
-
}], ctorParameters: () => [] });
|
649
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid.component.js","sourceRoot":"","sources":["../../../packages/grid/src/grid.component.ts","../../../packages/grid/src/grid.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    afterNextRender,\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    effect,\n    ElementRef,\n    inject,\n    OnDestroy,\n    OnInit,\n    Signal,\n    signal,\n    untracked,\n    viewChild,\n    ViewContainerRef\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { filter, fromEvent } from 'rxjs';\nimport { KoEventObject } from './angular-konva';\nimport {\n    AI_TABLE_CELL,\n    AI_TABLE_CELL_PADDING,\n    AI_TABLE_FIELD_ADD_BUTTON,\n    AI_TABLE_FIELD_ADD_BUTTON_WIDTH,\n    AI_TABLE_FIELD_HEAD,\n    AI_TABLE_FIELD_HEAD_HEIGHT,\n    AI_TABLE_FIELD_HEAD_MORE,\n    AI_TABLE_FIELD_HEAD_OPACITY_LINE,\n    AI_TABLE_FIELD_HEAD_SELECT_CHECKBOX,\n    AI_TABLE_PREVENT_CLEAR_SELECTION_CLASS,\n    AI_TABLE_ROW_ADD_BUTTON,\n    AI_TABLE_ROW_DRAG,\n    AI_TABLE_ROW_HEAD,\n    AI_TABLE_ROW_HEAD_WIDTH,\n    AI_TABLE_ROW_SELECT_CHECKBOX,\n    DBL_CLICK_EDIT_TYPE,\n    DEFAULT_POINT_POSITION,\n    DEFAULT_SCROLL_STATE\n} from './constants';\nimport { Coordinate, RendererContext, AITable } from './core';\nimport { AITableGridBase } from './grid-base.component';\nimport { AITableRenderer } from './renderer/renderer.component';\nimport { AITableGridEventService } from './services/event.service';\nimport { AITableGridFieldService } from './services/field.service';\nimport { AITableGridSelectionService } from './services/selection.service';\nimport {\n    AITableAreaType,\n    AITableContextMenuItem,\n    AITableMouseDownType,\n    AITableRendererConfig,\n    AITableSelectAllState,\n    ScrollActionOptions\n} from './types';\nimport {\n    AITableGridI18nKey,\n    buildGridLinearRows,\n    getColumnIndicesSizeMap,\n    getDetailByTargetName,\n    getI18nTextByKey,\n    handleMouseStyle,\n    isCellMatchKeywords,\n    isWindows,\n    clearCells\n} from './utils';\nimport { getMousePosition } from './utils/position';\nimport { AITableDragComponent } from './components/drag/drag.component';\nimport { buildClipboardData, writeToClipboard, writeToAITable, AITableActions } from './utils/clipboard';\nimport { ThyNotifyService } from 'ngx-tethys/notify';\nimport { isNumber } from 'lodash';\nimport {\n    AddFieldOptions,\n    AddRecordOptions,\n    AIRecordFieldIdPath,\n    AITableField,\n    DragEndData,\n    DragType,\n    IdPath,\n    UpdateFieldValueOptions\n} from '@ai-table/utils';\n\n@Component({\n    selector: 'ai-table-grid',\n    templateUrl: './grid.component.html',\n    standalone: true,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        class: 'ai-table-grid'\n    },\n    imports: [AITableRenderer, AITableDragComponent],\n    providers: [AITableGridEventService, AITableGridFieldService, AITableGridSelectionService]\n})\nexport class AITableGrid extends AITableGridBase implements OnInit, OnDestroy {\n    private viewContainerRef = inject(ViewContainerRef);\n\n    private isDragSelecting = false;\n\n    private dragSelectionStart: AIRecordFieldIdPath | null = null;\n\n    private notifyService = inject(ThyNotifyService);\n\n    private isPopoverOpen = false;\n\n    timer!: number | null;\n\n    resizeObserver!: ResizeObserver;\n\n    fieldHeadHeight = AI_TABLE_FIELD_HEAD_HEIGHT;\n\n    containerRect = signal({ width: 0, height: 0 });\n\n    frozenColumnCount = signal(1);\n\n    hasContainerRect = computed(() => {\n        return this.containerRect().width > 0 && this.containerRect().height > 0;\n    });\n\n    container = viewChild<ElementRef>('container');\n\n    verticalBarRef = viewChild<ElementRef>('verticalBar');\n\n    horizontalBarRef = viewChild<ElementRef>('horizontalBar');\n\n    linearRows = computed(() => {\n        return buildGridLinearRows(this.gridData().records, !this.aiReadonly());\n    });\n\n    visibleColumnsIndexMap = computed(() => {\n        const columns = AITable.getVisibleFields(this.aiTable);\n        return new Map(columns?.map((item, index) => [item._id, index]));\n    });\n\n    visibleRowsIndexMap = computed(() => {\n        return new Map(this.linearRows().map((row, index) => [row._id, index]));\n    });\n\n    containerElement = computed(() => {\n        return this.container()!.nativeElement;\n    });\n\n    rendererConfig: Signal<AITableRendererConfig> = computed(() => {\n        const fields = AITable.getVisibleFields(this.aiTable);\n        const coordinate = new Coordinate({\n            container: this.containerElement(),\n            rowHeight: AI_TABLE_FIELD_HEAD_HEIGHT,\n            rowCount: this.linearRows().length,\n            columnCount: fields.length,\n            rowInitSize: AI_TABLE_FIELD_HEAD_HEIGHT,\n            columnInitSize: this.aiTable.context!.rowHeadWidth(),\n            rowIndicesSizeMap: {},\n            columnIndicesSizeMap: getColumnIndicesSizeMap(this.aiTable, fields),\n            frozenColumnCount: this.frozenColumnCount()\n        });\n        return {\n            aiTable: this.aiTable,\n            gridData: this.gridData(),\n            container: this.containerElement(),\n            coordinate: coordinate,\n            containerWidth: this.containerRect().width,\n            containerHeight: this.containerRect().height,\n            references: this.aiReferences(),\n            readonly: this.aiReadonly(),\n            rowDragDisabled: this.aiRowDragDisabled(),\n            actions: this.actions\n        };\n    });\n\n    coordinate = computed(() => {\n        return this.rendererConfig().coordinate;\n    });\n\n    scrollTotalHeight = computed(() => {\n        return Math.max(this.coordinate().totalHeight, this.containerRect().height - this.fieldHeadHeight);\n    });\n\n    scrollbarWidth = computed(() => {\n        return this.coordinate().totalWidth + AI_TABLE_FIELD_ADD_BUTTON_WIDTH;\n    });\n\n    private actions: AITableActions = {\n        updateFieldValue: (data: UpdateFieldValueOptions) => {\n            this.aiUpdateFieldValue.emit(data);\n        },\n        setField: (field: AITableField) => {\n            this.aiSetField.emit(field);\n        },\n        addField: (data: AddFieldOptions) => {\n            this.aiAddField.emit(data);\n        },\n        addRecord: (data: AddRecordOptions) => {\n            this.addRecord(data);\n        }\n    };\n\n    constructor() {\n        super();\n        afterNextRender(() => {\n            this.setContainerRect();\n            this.bindGlobalMousedown();\n            this.containerResizeListener();\n            this.bindWheel();\n            this.bindClipboardShortcuts();\n        });\n        effect(() => {\n            if (this.hasContainerRect() && this.horizontalBarRef() && this.verticalBarRef()) {\n                this.bindScrollBarScroll();\n            }\n        });\n        effect(\n            () => {\n                this.setKeywordsMatchedCells();\n            },\n            { allowSignalWrites: true }\n        );\n        effect(\n            () => {\n                // 当新增行选中的cell,编辑后，activeCell 不在新增的行中时，根据筛选 过滤行数据,触发重新渲染\n                const activeCellPath = this.aiTable.selection().activeCell;\n                untracked(() => {\n                    if (!activeCellPath || !this.aiTable.recordsWillHidden().includes(activeCellPath[0])) {\n                        if (this.aiTable.recordsWillHidden().length > 0) {\n                            this.aiTable.recordsWillHidden.set([]);\n                        }\n                    }\n                });\n            },\n            { allowSignalWrites: true }\n        );\n\n        effect(\n            () => {\n                const recordIdSet = new Set<string>(this.aiTable.records().map((item) => item._id));\n                untracked(() => {\n                    const selectedRecords = this.aiTable.selection().selectedRecords;\n                    for (const selectedRecordId of selectedRecords.values()) {\n                        if (!recordIdSet.has(selectedRecordId)) {\n                            selectedRecords.delete(selectedRecordId);\n                        }\n                    }\n                    this.aiTable.selection.update((item) => {\n                        return {\n                            ...item,\n                            selectedRecords,\n                            selectAllState: this.aiTableGridSelectionService.selectAllState()\n                        };\n                    });\n                });\n            },\n            { allowSignalWrites: true }\n        );\n    }\n\n    override ngOnInit(): void {\n        super.ngOnInit();\n        this.initContext();\n    }\n\n    ngOnDestroy(): void {\n        this.resizeObserver?.disconnect();\n    }\n\n    private initContext() {\n        this.aiTable.context = new RendererContext({\n            rowHeadWidth: computed(() => (this.aiFieldConfig()?.hiddenIndexColumn ? 0 : AI_TABLE_ROW_HEAD_WIDTH)),\n            linearRows: this.linearRows,\n            visibleColumnsIndexMap: this.visibleColumnsIndexMap,\n            visibleRowsIndexMap: this.visibleRowsIndexMap,\n            pointPosition: signal(DEFAULT_POINT_POSITION),\n            scrollState: signal(DEFAULT_SCROLL_STATE),\n            frozenColumnCount: this.frozenColumnCount,\n            references: this.aiReferences,\n            aiFieldConfig: this.aiFieldConfig,\n            scrollAction: this.scrollAction\n        });\n    }\n\n    private setKeywordsMatchedCells() {\n        const keywords = this.aiKeywords();\n        let matchedCells = new Set<string>();\n\n        if (keywords) {\n            const references = this.aiReferences();\n            this.aiTable.records().forEach((record) => {\n                this.aiTable.fields().forEach((field) => {\n                    if (isCellMatchKeywords(this.aiTable, field, record._id, keywords, references)) {\n                        matchedCells.add(`${record._id}:${field._id}`);\n                    }\n                });\n            });\n        }\n\n        this.aiTable.keywordsMatchedCells.set(matchedCells);\n    }\n\n    stageMousemove(e: KoEventObject<MouseEvent>) {\n        if (this.timer) {\n            cancelAnimationFrame(this.timer);\n        }\n        this.timer = requestAnimationFrame(() => {\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 } = this.aiTable;\n            const { x, y } = pos;\n            const curMousePosition = getMousePosition(\n                this.aiTable,\n                x,\n                y,\n                this.coordinate(),\n                AITable.getVisibleFields(this.aiTable),\n                context!,\n                targetName\n            );\n            handleMouseStyle(\n                curMousePosition.realTargetName,\n                curMousePosition.areaType,\n                this.containerElement(),\n                this.aiReadonly(),\n                this.aiRowDragDisabled()\n            );\n            if (curMousePosition.areaType !== AITableAreaType.none) {\n                context!.setPointPosition(curMousePosition);\n            } else {\n                this.setDefaultPointPosition();\n            }\n            this.timer = null;\n            if (this.isDragSelecting) {\n                const { fieldId, recordId } = getDetailByTargetName(curMousePosition.realTargetName);\n                if (fieldId && recordId) {\n                    const startCell = this.dragSelectionStart;\n                    const endCell: AIRecordFieldIdPath = [recordId, fieldId];\n                    if (startCell && !!startCell.length) {\n                        this.aiTableGridSelectionService.selectCells(startCell, endCell);\n                    }\n                }\n            }\n        });\n    }\n\n    stageMousedown(e: KoEventObject<MouseEvent>) {\n        const mouseEvent = e.event.evt;\n        const _targetName = e.event.target.name();\n\n        const { targetName, fieldId, recordId } = getDetailByTargetName(_targetName);\n        if (\n            mouseEvent.button === AITableMouseDownType.Right &&\n            recordId &&\n            fieldId &&\n            (this.aiTable.selection().selectedRecords.has(recordId) || this.aiTable.selection().selectedCells.has(`${recordId}:${fieldId}`))\n        ) {\n            return;\n        }\n\n        switch (targetName) {\n            case AI_TABLE_FIELD_HEAD:\n                mouseEvent.preventDefault();\n                if (!fieldId) return;\n                this.aiTableGridSelectionService.selectField(fieldId);\n                this.handleFieldDragStart();\n                return;\n            case AI_TABLE_FIELD_HEAD_OPACITY_LINE:\n                mouseEvent.preventDefault();\n                if (!fieldId) return;\n                this.handleFieldWidthDragStart(fieldId);\n                return;\n            case AI_TABLE_CELL:\n                if (!recordId || !fieldId) return;\n                const dragSelectionStart: AIRecordFieldIdPath = [recordId, fieldId];\n                this.updateDragSelectionState(true, dragSelectionStart);\n                this.aiTableGridSelectionService.selectCells(dragSelectionStart);\n                return;\n            case AI_TABLE_ROW_DRAG:\n                if (!recordId) return;\n                mouseEvent.preventDefault();\n                const selectedRecords = this.aiTable.selection().selectedRecords;\n                let dragRecords: string[] = [];\n                if (selectedRecords.has(recordId)) {\n                    dragRecords = [recordId, ...selectedRecords.values()];\n                } else {\n                    // 当前拖拽行不在选中行中，只拖拽当前行\n                    dragRecords = [recordId];\n                }\n                this.handleRowDragStart(dragRecords);\n                return;\n            case AI_TABLE_ROW_ADD_BUTTON:\n            case AI_TABLE_FIELD_ADD_BUTTON:\n            case AI_TABLE_ROW_HEAD:\n            case AI_TABLE_ROW_SELECT_CHECKBOX:\n            case AI_TABLE_FIELD_HEAD_SELECT_CHECKBOX:\n                return;\n            default:\n                this.aiTableGridSelectionService.clearSelection();\n        }\n    }\n\n    stageMouseup(e: KoEventObject<MouseEvent>) {\n        this.updateDragSelectionState(false, null);\n    }\n\n    stageMouseleave(e: KoEventObject<MouseEvent>) {\n        if (this.timer) {\n            cancelAnimationFrame(this.timer);\n        }\n        this.timer = requestAnimationFrame(() => {\n            if (this.isPopoverOpen) {\n                return;\n            }\n            this.setDefaultPointPosition();\n        });\n    }\n\n    stageContextmenu(e: KoEventObject<MouseEvent>) {\n        const mouseEvent = e.event.evt;\n        mouseEvent.preventDefault();\n\n        if (this.aiReadonly()) {\n            return;\n        }\n\n        const targetName = e.event.target.name();\n        const { fieldId, recordId } = getDetailByTargetName(targetName);\n        if (!recordId || !fieldId) {\n            return;\n        }\n\n        const position = {\n            x: mouseEvent.x,\n            y: mouseEvent.y\n        };\n\n        const menuItems: AITableContextMenuItem[] = [];\n        if (this.aiContextMenuItems()) {\n            menuItems.push(...this.aiContextMenuItems()!(this.aiTable));\n        }\n        if (!menuItems.length || menuItems.every((item) => !!(item.hidden && item.hidden(this.aiTable, targetName, position)))) {\n            return;\n        }\n\n        this.aiTableGridEventService.openContextMenu(this.aiTable, {\n            origin: this.containerElement(),\n            menuItems,\n            position,\n            targetName,\n            viewContainerRef: this.viewContainerRef\n        });\n    }\n\n    stageClick(e: KoEventObject<MouseEvent>) {\n        const targetNameDetail = getDetailByTargetName(e.event.target.name());\n        this.aiClick.emit({\n            ...e,\n            targetNameDetail\n        });\n        const mouseEvent = e.event.evt;\n        mouseEvent.preventDefault();\n        this.aiTableGridEventService.closeCellEditor();\n\n        const { context } = this.aiTable;\n        const { targetName, rowIndex: pointRowIndex } = context!.pointPosition();\n        if (mouseEvent.button !== AITableMouseDownType.Left || (targetName !== AI_TABLE_FIELD_HEAD_MORE && this.aiReadonly())) return;\n        switch (targetName) {\n            case AI_TABLE_ROW_ADD_BUTTON: {\n                this.aiTableGridSelectionService.clearSelection();\n                this.addRecord();\n                const { records, fields } = this.gridData();\n                this.aiTableGridSelectionService.setActiveCell([records[records.length - 1]._id, fields[0]._id]);\n                break;\n            }\n            case AI_TABLE_ROW_SELECT_CHECKBOX: {\n                const pointRecordId = context!.linearRows()[pointRowIndex]?._id;\n                this.selectRecord(pointRecordId);\n                break;\n            }\n            case AI_TABLE_FIELD_HEAD_SELECT_CHECKBOX: {\n                const isChecked = this.aiTable.selection().selectAllState === AITableSelectAllState.all;\n                this.toggleSelectAll(!isChecked);\n                break;\n            }\n            case AI_TABLE_FIELD_ADD_BUTTON: {\n                this.aiTableGridSelectionService.clearSelection();\n                const fieldGroupRect = e.event.target.getParent()?.getClientRect()!;\n                const containerRect = this.containerElement().getBoundingClientRect();\n                this.addField(this.containerElement(), {\n                    x: fieldGroupRect.x + containerRect.x,\n                    y: containerRect.y + fieldGroupRect.y + fieldGroupRect.height\n                });\n                break;\n            }\n            case AI_TABLE_FIELD_HEAD_MORE:\n                mouseEvent.preventDefault();\n                const _targetName = e.event.target.name();\n                const { fieldId } = getDetailByTargetName(_targetName);\n                if (fieldId) {\n                    const moreRect = e.event.target.getClientRect();\n                    const fieldGroupRect = e.event.target.getParent()?.getParent()?.getClientRect()!;\n                    const containerRect = this.containerElement().getBoundingClientRect();\n\n                    const position = {\n                        x: containerRect.x + moreRect.x,\n                        y: containerRect.y + moreRect.y + moreRect.height\n                    };\n                    const editFieldPosition = {\n                        x: containerRect.x + fieldGroupRect.x - AI_TABLE_CELL_PADDING,\n                        y: containerRect.y + fieldGroupRect.y + fieldGroupRect.height\n                    };\n\n                    const editOrigin = this.containerElement().querySelector('.konvajs-content') as HTMLElement;\n                    const menuRef = this.aiTableGridFieldService.openFieldMenu(this.aiTable, {\n                        fieldId: fieldId,\n                        fieldMenus: this.fieldMenus(),\n                        origin: this.containerElement(),\n                        position,\n                        editOrigin: editOrigin,\n                        editFieldPosition\n                    });\n                    if (menuRef) {\n                        menuRef.afterClosed().subscribe(() => {\n                            this.isPopoverOpen = false;\n                            this.setDefaultPointPosition();\n                        });\n                        this.isPopoverOpen = true;\n                    }\n                }\n                break;\n        }\n        return;\n    }\n\n    stageDblclick(e: KoEventObject<MouseEvent>) {\n        const _targetName = e.event.target.name();\n        const targetNameDetail = getDetailByTargetName(_targetName);\n        this.aiDbClick.emit({\n            ...e,\n            targetNameDetail\n        });\n\n        if (this.aiReadonly()) {\n            return;\n        }\n\n        const { fieldId, recordId } = targetNameDetail;\n        if (!recordId || !fieldId) {\n            return;\n        }\n        const field = this.aiTable.fieldsMap()[fieldId];\n        const fieldType = field.type;\n        if (DBL_CLICK_EDIT_TYPE.includes(fieldType)) {\n            setTimeout(() => {\n                this.aiTableGridEventService.openCellEditor(this.aiTable, {\n                    viewContainerRef: this.viewContainerRef,\n                    container: this.containerElement(),\n                    coordinate: this.coordinate(),\n                    fieldId: fieldId!,\n                    recordId: recordId!,\n                    references: this.aiReferences(),\n                    updateFieldValue: (value: UpdateFieldValueOptions<any>) => {\n                        this.aiUpdateFieldValue.emit(value);\n                    }\n                });\n            }, 0);\n        }\n    }\n\n    private bindWheel() {\n        fromEvent<WheelEvent>(this.containerElement(), 'wheel', { passive: false })\n            .pipe(takeUntilDestroyed(this.destroyRef))\n            .subscribe((e: WheelEvent) => {\n                e.preventDefault();\n                this.aiTableGridEventService.closeCellEditor();\n                this.scrollAction({ deltaX: e.deltaX, deltaY: e.deltaY, shiftKey: e.shiftKey });\n            });\n    }\n\n    scrollAction = (options: ScrollActionOptions) => {\n        if (this.timer) {\n            cancelAnimationFrame(this.timer);\n        }\n        this.timer = requestAnimationFrame(() => {\n            const { deltaX, deltaY, shiftKey } = options;\n            const fixedDeltaY = shiftKey && isWindows ? 0 : deltaY;\n            const fixedDeltaX = shiftKey && isWindows ? deltaY : deltaX;\n            const horizontalBar = this.horizontalBarRef()?.nativeElement;\n            const verticalBar = this.verticalBarRef()?.nativeElement;\n            if (horizontalBar) {\n                horizontalBar.scrollLeft = horizontalBar.scrollLeft + fixedDeltaX;\n            }\n            if (verticalBar) {\n                verticalBar.scrollTop = verticalBar.scrollTop + fixedDeltaY;\n            }\n            options.callback && options.callback();\n            this.timer = null;\n        });\n    };\n\n    private setDefaultPointPosition() {\n        const { context } = this.aiTable;\n        context!.setPointPosition(DEFAULT_POINT_POSITION);\n    }\n\n    private bindScrollBarScroll() {\n        fromEvent<WheelEvent>(this.horizontalBarRef()!.nativeElement, 'scroll', { passive: true })\n            .pipe(takeUntilDestroyed(this.destroyRef))\n            .subscribe((e) => {\n                this.horizontalScroll(e);\n            });\n\n        fromEvent<WheelEvent>(this.verticalBarRef()!.nativeElement, 'scroll', { passive: true })\n            .pipe(takeUntilDestroyed(this.destroyRef))\n            .subscribe((e) => {\n                this.verticalScroll(e);\n            });\n    }\n\n    private bindGlobalMousedown() {\n        fromEvent<MouseEvent>(document, 'mousedown', { passive: true })\n            .pipe(\n                filter(\n                    (e) =>\n                        e.target instanceof Element &&\n                        !this.containerElement().contains(e.target) &&\n                        !e.target.closest(AI_TABLE_PREVENT_CLEAR_SELECTION_CLASS)\n                ),\n                takeUntilDestroyed(this.destroyRef)\n            )\n            .subscribe(() => {\n                this.updateDragSelectionState(false, null);\n                this.aiTableGridSelectionService.clearSelection();\n            });\n    }\n\n    private updateDragSelectionState(isDragSelecting: boolean, dragSelectionStart: AIRecordFieldIdPath | null) {\n        this.isDragSelecting = isDragSelecting;\n        this.dragSelectionStart = dragSelectionStart;\n    }\n\n    private resetScrolling = () => {\n        this.aiTable.context!.setScrollState({\n            isScrolling: false\n        });\n    };\n\n    private horizontalScroll = (e: any) => {\n        const { scrollLeft } = e.target;\n        this.aiTable.context!.setScrollState({\n            scrollLeft,\n            isScrolling: true\n        });\n        this.resetScrolling();\n    };\n\n    private verticalScroll(e: any) {\n        const { scrollTop } = e.target;\n        this.aiTable.context!.setScrollState({\n            scrollTop,\n            isScrolling: true\n        });\n        this.resetScrolling();\n    }\n\n    private setContainerRect() {\n        this.containerRect.set({\n            width: this.containerElement().offsetWidth,\n            height: this.containerElement().offsetHeight\n        });\n    }\n\n    private containerResizeListener() {\n        this.resizeObserver = new ResizeObserver(() => {\n            const containerWidth = this.containerElement().offsetWidth;\n            const totalWidth = this.coordinate().totalWidth + AI_TABLE_FIELD_ADD_BUTTON_WIDTH;\n            this.setContainerRect();\n            if (containerWidth >= totalWidth) {\n                this.aiTable.context!.setScrollState({ scrollLeft: 0 });\n                return;\n            }\n        });\n        this.resizeObserver.observe(this.containerElement());\n    }\n\n    private bindClipboardShortcuts() {\n        fromEvent<KeyboardEvent>(document, 'keydown')\n            .pipe(\n                filter(\n                    (event) =>\n                        ((event.ctrlKey || event.metaKey) && (event.key === 'c' || event.key === 'v')) ||\n                        event.key === 'Backspace' ||\n                        event.key === 'Delete'\n                ),\n                takeUntilDestroyed(this.destroyRef)\n            )\n            .subscribe(async (event: KeyboardEvent) => {\n                if (this.aiReadonly()) {\n                    return;\n                }\n\n                const hasSelectedCells = this.aiTable.selection().selectedCells.size > 0;\n                if (!hasSelectedCells) {\n                    return;\n                }\n\n                const hasEditingCell = !!this.aiTableGridEventService.getCurrentEditCell();\n                if (hasEditingCell) {\n                    return;\n                }\n\n                event.preventDefault();\n                if (event.key === 'c') {\n                    this.copyCells();\n                } else if (event.key === 'v') {\n                    this.pasteCells();\n                } else if (event.key === 'Backspace' || event.key === 'Delete') {\n                    clearCells(this.aiTable, this.actions);\n                }\n            });\n    }\n\n    private copyCells() {\n        const clipboardData = buildClipboardData(this.aiTable);\n        if (clipboardData) {\n            writeToClipboard(clipboardData).then(() => {\n                const copiedCellsCount = this.aiTable.selection().selectedCells.size;\n                const message = getI18nTextByKey(this.aiTable, AITableGridI18nKey.copiedCells).replace(\n                    '{count}',\n                    copiedCellsCount.toString()\n                );\n                this.notifyService.success(message, undefined, {\n                    placement: 'bottomLeft'\n                });\n            });\n        }\n    }\n\n    private pasteCells() {\n        writeToAITable(this.aiTable, this.actions).then((isPasteSuccess) => {\n            if (!isPasteSuccess) {\n                this.notifyService.error(getI18nTextByKey(this.aiTable, AITableGridI18nKey.invalidPasteContent), undefined, {\n                    placement: 'bottomLeft'\n                });\n            }\n        });\n    }\n\n    private handleFieldDragStart() {\n        if (!this.aiReadonly() && this.aiTableGridSelectionService.selectedFields.size > 0) {\n            this.aiTableGridSelectionService.drag({\n                type: DragType.field,\n                sourceIds: this.aiTableGridSelectionService.selectedFields,\n                scroll: this.getScrollPosition(),\n                coordinate: this.coordinate()\n            });\n        }\n    }\n\n    private handleFieldWidthDragStart(fieldId: string) {\n        if (!this.aiReadonly() && fieldId) {\n            this.aiTableGridSelectionService.drag({\n                type: DragType.columnWidth,\n                sourceIds: new Set([fieldId]),\n                scroll: this.getScrollPosition(),\n                coordinate: this.coordinate()\n            });\n        }\n    }\n\n    private handleRowDragStart(recordIds: string[]) {\n        if (!this.aiReadonly() && !this.aiRowDragDisabled() && recordIds.length > 0) {\n            this.aiTableGridSelectionService.drag({\n                type: DragType.record,\n                sourceIds: new Set(recordIds),\n                scroll: this.getScrollPosition(),\n                coordinate: this.coordinate()\n            });\n        }\n    }\n\n    private getScrollPosition() {\n        const horizontalBar = this.horizontalBarRef()?.nativeElement;\n        const verticalBar = this.verticalBarRef()?.nativeElement;\n        let scrollLeft = horizontalBar?.scrollLeft || 0;\n        let scrollTop = verticalBar?.scrollTop || 0;\n        return { x: scrollLeft, y: scrollTop };\n    }\n\n    dragEnd(data: DragEndData) {\n        switch (data.type) {\n            case DragType.field:\n                if (data.fieldsIndex && isNumber(data.targetIndex)) {\n                    for (let i = 0; i < data.fieldsIndex.length; i++) {\n                        this.aiMoveField.emit({\n                            path: [data.fieldsIndex[i]],\n                            newPath: [data.targetIndex + i]\n                        });\n                    }\n                }\n                break;\n            case DragType.columnWidth:\n                if (data.fieldIds && isNumber(data.width)) {\n                    const fieldId = data.fieldIds.values().next().value!;\n                    this.aiSetFieldWidth.emit({\n                        path: [fieldId],\n                        width: data.width\n                    });\n                }\n                break;\n            case DragType.record:\n                if (data.recordIds && isNumber(data.targetIndex)) {\n                    this.aiMoveRecords.emit({\n                        recordIds: Array.from(data.recordIds).map((id) => [id] as IdPath),\n                        newPath: [data.targetIndex]\n                    });\n                }\n                return;\n        }\n        this.aiTableGridSelectionService.clearDrag();\n    }\n}\n","<div #container class=\"ai-table-grid-view\">\n    @if (hasContainerRect()) {\n        <ai-table-renderer\n            [config]=\"rendererConfig()\"\n            (koMousemove)=\"stageMousemove($event)\"\n            (koMousedown)=\"stageMousedown($event)\"\n            (koMouseup)=\"stageMouseup($event)\"\n            (koContextmenu)=\"stageContextmenu($event)\"\n            (koClick)=\"stageClick($event)\"\n            (koDblclick)=\"stageDblclick($event)\"\n            (koMouseleave)=\"stageMouseleave($event)\"\n        >\n            <div #horizontalBar class=\"ai-table-horizontal-scroll-bar-wrapper\" [style.width.px]=\"containerRect().width\">\n                <div class=\"ai-table-scroll-bar-inner\" [style.width.px]=\"scrollbarWidth()\"></div>\n            </div>\n            <div\n                #verticalBar\n                class=\"ai-table-vertical-scroll-bar-wrapper\"\n                [style.height.px]=\"containerRect().height - fieldHeadHeight\"\n                [style.top.px]=\"fieldHeadHeight\"\n            >\n                <div class=\"ai-table-scroll-bar-inner\" [style.height.px]=\"scrollTotalHeight()\"></div>\n            </div>\n        </ai-table-renderer>\n    }\n    <ai-table-drag (dragEnd)=\"dragEnd($event)\"></ai-table-drag>\n</div>\n"]}
|