@ai-table/grid 0.0.31 → 0.0.33
Sign up to get free protection for your applications and to get access to all the features.
- package/components/{field-property-editor/field-property-editor.component.d.ts → field-setting/field-setting.component.d.ts} +4 -4
- package/components/field-setting/field-setting.component.d.ts.map +1 -0
- package/components/{field-property-editor/field-property-editor.component.scss → field-setting/field-setting.component.scss} +1 -1
- package/components/index.d.ts +1 -1
- package/components/index.d.ts.map +1 -1
- package/core/context.d.ts +4 -2
- package/core/context.d.ts.map +1 -1
- package/core/coordinate.d.ts +3 -3
- package/core/coordinate.d.ts.map +1 -1
- package/core/types/ai-table.d.ts +2 -2
- package/core/types/ai-table.d.ts.map +1 -1
- package/core/utils/common.d.ts.map +1 -1
- package/esm2022/components/field-setting/field-setting.component.mjs +102 -0
- package/esm2022/components/index.mjs +2 -2
- package/esm2022/core/context.mjs +5 -3
- package/esm2022/core/coordinate.mjs +9 -9
- package/esm2022/core/types/ai-table.mjs +10 -3
- package/esm2022/core/utils/common.mjs +2 -3
- package/esm2022/dom-grid.component.mjs +3 -3
- package/esm2022/grid-base.component.mjs +2 -3
- package/esm2022/grid.component.mjs +10 -8
- package/esm2022/renderer/creations/create-active-cell-border.mjs +2 -2
- package/esm2022/renderer/drawers/cell-drawer.mjs +7 -8
- package/esm2022/renderer/drawers/drawer.mjs +5 -3
- package/esm2022/services/event.service.mjs +6 -3
- package/esm2022/services/field.service.mjs +4 -4
- package/esm2022/types/grid.mjs +1 -1
- package/esm2022/utils/cell.mjs +5 -5
- package/fesm2022/ai-table-grid.mjs +64 -55
- package/fesm2022/ai-table-grid.mjs.map +1 -1
- package/grid-base.component.d.ts.map +1 -1
- package/grid.component.d.ts +2 -1
- package/grid.component.d.ts.map +1 -1
- package/package.json +1 -1
- package/renderer/drawers/cell-drawer.d.ts.map +1 -1
- package/renderer/drawers/drawer.d.ts.map +1 -1
- package/services/event.service.d.ts.map +1 -1
- package/styles/styles.scss +1 -0
- package/types/grid.d.ts +6 -4
- package/types/grid.d.ts.map +1 -1
- package/utils/cell.d.ts +1 -1
- package/utils/cell.d.ts.map +1 -1
- package/components/field-property-editor/field-property-editor.component.d.ts.map +0 -1
- package/esm2022/components/field-property-editor/field-property-editor.component.mjs +0 -106
@@ -3,7 +3,7 @@ import { ThyFormValidatorConfig } from 'ngx-tethys/form';
|
|
3
3
|
import { ThyPopoverRef } from 'ngx-tethys/popover';
|
4
4
|
import { AITable, AITableField, AITableFieldOption, SetFieldOptions } from '../../core';
|
5
5
|
import * as i0 from "@angular/core";
|
6
|
-
export declare class
|
6
|
+
export declare class AITableFieldSetting {
|
7
7
|
aiEditField: import("@angular/core").ModelSignal<AITableField>;
|
8
8
|
aiTable: AITable;
|
9
9
|
aiExternalTemplate: TemplateRef<any> | null;
|
@@ -19,8 +19,8 @@ export declare class AITableFieldPropertyEditor {
|
|
19
19
|
selectFieldType(field: AITableFieldOption): void;
|
20
20
|
editFieldProperty(): void;
|
21
21
|
cancel(): void;
|
22
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<
|
23
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<
|
22
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<AITableFieldSetting, never>;
|
23
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<AITableFieldSetting, "ai-table-field-setting", never, { "aiEditField": { "alias": "aiEditField"; "required": true; "isSignal": true; }; "aiTable": { "alias": "aiTable"; "required": true; }; "aiExternalTemplate": { "alias": "aiExternalTemplate"; "required": false; }; "isUpdate": { "alias": "isUpdate"; "required": false; }; }, { "aiEditField": "aiEditFieldChange"; "addField": "addField"; "setField": "setField"; }, never, never, true, never>;
|
24
24
|
static ngAcceptInputType_isUpdate: unknown;
|
25
25
|
}
|
26
|
-
//# sourceMappingURL=field-
|
26
|
+
//# sourceMappingURL=field-setting.component.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"field-setting.component.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/components/field-setting/field-setting.component.ts"],"names":[],"mappings":"AACA,OAAO,EAA6C,WAAW,EAAqD,MAAM,eAAe,CAAC;AAS1I,OAAO,EAAiB,sBAAsB,EAA2B,MAAM,iBAAiB,CAAC;AAIjG,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAGnD,OAAO,EACH,OAAO,EACP,YAAY,EACZ,kBAAkB,EAIlB,eAAe,EAClB,MAAM,YAAY,CAAC;;AAGpB,qBAoCa,mBAAmB;IAC5B,WAAW,oDAAkC;IAElB,OAAO,EAAG,OAAO,CAAC;IAEpC,kBAAkB,EAAE,WAAW,CAAC,GAAG,CAAC,GAAG,IAAI,CAAQ;IAEpB,QAAQ,EAAG,OAAO,CAAC;IAE3D,QAAQ,yDAA0B;IAElC,QAAQ,qEAA6B;IAErC,mBAAmB,qDAEhB;IAEH,cAAc,SAAM;IAEpB,eAAe,EAAE,sBAAsB,CAOrC;IAEF,YAAY,uBAAgB;IAE5B,SAAS,CAAC,aAAa,+BAA8C;IAErE,eAAe,cAAe,MAAM,wCAGlC;IAEF,eAAe,CAAC,KAAK,EAAE,kBAAkB;IASzC,iBAAiB;IAYjB,MAAM;yCA1DG,mBAAmB;2CAAnB,mBAAmB;uCA8D0ulC,OAAQ;CADjxlC"}
|
package/components/index.d.ts
CHANGED
@@ -7,6 +7,6 @@ export * from './cell-editors/rating/rating-editor.component';
|
|
7
7
|
export * from './cell-editors/select/select-editor.component';
|
8
8
|
export * from './cell-editors/text/text-editor.component';
|
9
9
|
export * from './cell-views/select/option.component';
|
10
|
-
export * from './field-
|
10
|
+
export * from './field-setting/field-setting.component';
|
11
11
|
export * from './context-menu/context-menu.component';
|
12
12
|
//# sourceMappingURL=index.d.ts.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../packages/grid/src/components/index.ts"],"names":[],"mappings":"AAAA,cAAc,+CAA+C,CAAC;AAC9D,cAAc,2CAA2C,CAAC;AAC1D,cAAc,2CAA2C,CAAC;AAC1D,cAAc,+CAA+C,CAAC;AAC9D,cAAc,mDAAmD,CAAC;AAClE,cAAc,+CAA+C,CAAC;AAC9D,cAAc,+CAA+C,CAAC;AAC9D,cAAc,2CAA2C,CAAC;AAC1D,cAAc,sCAAsC,CAAC;AACrD,cAAc,
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../packages/grid/src/components/index.ts"],"names":[],"mappings":"AAAA,cAAc,+CAA+C,CAAC;AAC9D,cAAc,2CAA2C,CAAC;AAC1D,cAAc,2CAA2C,CAAC;AAC1D,cAAc,+CAA+C,CAAC;AAC9D,cAAc,mDAAmD,CAAC;AAClE,cAAc,+CAA+C,CAAC;AAC9D,cAAc,+CAA+C,CAAC;AAC9D,cAAc,2CAA2C,CAAC;AAC1D,cAAc,sCAAsC,CAAC;AACrD,cAAc,yCAAyC,CAAC;AACxD,cAAc,uCAAuC,CAAC"}
|
package/core/context.d.ts
CHANGED
@@ -1,11 +1,13 @@
|
|
1
1
|
import { Signal, WritableSignal } from '@angular/core';
|
2
|
-
import { AITableContext, AITableLinearRow, AITablePointPosition, AITableScrollState, ScrollActionOptions } from '../types';
|
2
|
+
import { AITableContext, AITableLinearRow, AITablePointPosition, AITableReferences, AITableScrollState, ScrollActionOptions } from '../types';
|
3
3
|
export declare class RendererContext {
|
4
4
|
linearRows: Signal<AITableLinearRow[]>;
|
5
5
|
pointPosition: WritableSignal<AITablePointPosition>;
|
6
6
|
scrollState: WritableSignal<AITableScrollState>;
|
7
|
-
|
7
|
+
visibleColumnsIndexMap: Signal<Map<string, number>>;
|
8
8
|
visibleRowsIndexMap: Signal<Map<string, number>>;
|
9
|
+
frozenColumnCount: Signal<number>;
|
10
|
+
references: Signal<AITableReferences>;
|
9
11
|
scrollAction: (options: ScrollActionOptions) => void;
|
10
12
|
constructor(options: AITableContext);
|
11
13
|
setPointPosition(position: Partial<AITablePointPosition>): void;
|
package/core/context.d.ts.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"context.d.ts","sourceRoot":"","sources":["../../../packages/grid/src/core/context.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AACvD,OAAO,EAAE,cAAc,EAAE,gBAAgB,EAAE,oBAAoB,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,MAAM,UAAU,CAAC;
|
1
|
+
{"version":3,"file":"context.d.ts","sourceRoot":"","sources":["../../../packages/grid/src/core/context.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AACvD,OAAO,EAAE,cAAc,EAAE,gBAAgB,EAAE,oBAAoB,EAAE,iBAAiB,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,MAAM,UAAU,CAAC;AAE9I,qBAAa,eAAe;IACxB,UAAU,EAAE,MAAM,CAAC,gBAAgB,EAAE,CAAC,CAAC;IACvC,aAAa,EAAE,cAAc,CAAC,oBAAoB,CAAC,CAAC;IACpD,WAAW,EAAE,cAAc,CAAC,kBAAkB,CAAC,CAAC;IAChD,sBAAsB,EAAE,MAAM,CAAC,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC;IACpD,mBAAmB,EAAE,MAAM,CAAC,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC;IACjD,iBAAiB,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;IAClC,UAAU,EAAE,MAAM,CAAC,iBAAiB,CAAC,CAAC;IACtC,YAAY,EAAE,CAAC,OAAO,EAAE,mBAAmB,KAAK,IAAI,CAAC;gBAEzC,OAAO,EAAE,cAAc;IAYnC,gBAAgB,CAAC,QAAQ,EAAE,OAAO,CAAC,oBAAoB,CAAC;IAaxD,cAAc,CAAC,WAAW,EAAE,OAAO,CAAC,kBAAkB,CAAC;CAG1D"}
|
package/core/coordinate.d.ts
CHANGED
@@ -9,8 +9,8 @@ export declare class Coordinate {
|
|
9
9
|
container: HTMLDivElement;
|
10
10
|
containerWidth: number;
|
11
11
|
containerHeight: number;
|
12
|
-
|
13
|
-
|
12
|
+
rowIndicesSizeMap: AITableSizeMap;
|
13
|
+
columnIndicesSizeMap: AITableSizeMap;
|
14
14
|
rowInitSize: number;
|
15
15
|
columnInitSize: number;
|
16
16
|
lastRowIndex: number;
|
@@ -18,7 +18,7 @@ export declare class Coordinate {
|
|
18
18
|
rowMetaDataMap: Record<number, AITableCellMetaData>;
|
19
19
|
columnMetaDataMap: Record<number, AITableCellMetaData>;
|
20
20
|
frozenColumnCount: number;
|
21
|
-
constructor({ rowHeight, rowCount, columnCount, container,
|
21
|
+
constructor({ rowHeight, rowCount, columnCount, container, rowIndicesSizeMap, columnIndicesSizeMap, rowInitSize, columnInitSize, frozenColumnCount }: AITableCoordinate);
|
22
22
|
get rowHeight(): number;
|
23
23
|
set rowHeight(height: number);
|
24
24
|
/**
|
package/core/coordinate.d.ts.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"coordinate.d.ts","sourceRoot":"","sources":["../../../packages/grid/src/core/coordinate.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,iBAAiB,EAAE,oBAAoB,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AAExG;;GAEG;AACH,qBAAa,UAAU;IACnB,SAAS,CAAC,UAAU,EAAE,MAAM,CAAC;IACtB,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,cAAc,CAAC;IAC1B,cAAc,EAAE,MAAM,CAAC;IACvB,eAAe,EAAE,MAAM,CAAC;IAExB,
|
1
|
+
{"version":3,"file":"coordinate.d.ts","sourceRoot":"","sources":["../../../packages/grid/src/core/coordinate.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,iBAAiB,EAAE,oBAAoB,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AAExG;;GAEG;AACH,qBAAa,UAAU;IACnB,SAAS,CAAC,UAAU,EAAE,MAAM,CAAC;IACtB,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,EAAE,MAAM,CAAC;IACpB,SAAS,EAAE,cAAc,CAAC;IAC1B,cAAc,EAAE,MAAM,CAAC;IACvB,eAAe,EAAE,MAAM,CAAC;IAExB,iBAAiB,EAAE,cAAc,CAAM;IAEvC,oBAAoB,EAAE,cAAc,CAAM;IAE1C,WAAW,EAAE,MAAM,CAAC;IAEpB,cAAc,EAAE,MAAM,CAAC;IAEvB,YAAY,SAAM;IAElB,eAAe,SAAM;IACrB,cAAc,EAAE,MAAM,CAAC,MAAM,EAAE,mBAAmB,CAAC,CAAM;IACzD,iBAAiB,EAAE,MAAM,CAAC,MAAM,EAAE,mBAAmB,CAAC,CAAM;IAC5D,iBAAiB,EAAE,MAAM,CAAC;gBAErB,EACR,SAAS,EACT,QAAQ,EACR,WAAW,EACX,SAAS,EACT,iBAAsB,EACtB,oBAAyB,EACzB,WAAe,EACf,cAAkB,EAClB,iBAAqB,EACxB,EAAE,iBAAiB;IAcpB,IAAW,SAAS,IAIS,MAAM,CAFlC;IAED,IAAW,SAAS,CAAC,MAAM,EAAE,MAAM,EAElC;IAED;;OAEG;IACH,IAAW,UAAU,WAGpB;IAED;;OAEG;IACH,IAAW,WAAW,WAGrB;IAED;;OAEG;IACI,YAAY,CAAC,KAAK,EAAE,MAAM;IAIjC;;OAEG;IACI,cAAc,CAAC,KAAK,EAAE,MAAM;IAInC;;OAEG;IACH,SAAS,CAAC,eAAe,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,oBAAoB,GAAG,mBAAmB;IAoC7F;;;OAGG;IACH,OAAO,CAAC,qBAAqB;IAY7B;;;OAGG;IACH,OAAO,CAAC,6BAA6B;IAgBrC;;OAEG;IACI,oBAAoB,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,oBAAoB;IAgB1E;;OAEG;IACI,gBAAgB,CAAC,MAAM,EAAE,MAAM;IAItC;;OAEG;IACI,eAAe,CAAC,UAAU,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM;IAa5D;;OAEG;IACI,mBAAmB,CAAC,MAAM,EAAE,MAAM;IAIzC;;OAEG;IACI,kBAAkB,CAAC,UAAU,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM;IAahE;;OAEG;IACI,YAAY,CAAC,QAAQ,EAAE,MAAM;IAIpC;;OAEG;IACI,eAAe,CAAC,WAAW,EAAE,MAAM;IAI1C;;OAEG;IACH,IAAI,iBAAiB,WAEpB;IAED;;OAEG;IACI,WAAW,CAAC,QAAQ,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM;;;;;;CAU3D"}
|
package/core/types/ai-table.d.ts
CHANGED
@@ -1,5 +1,5 @@
|
|
1
1
|
import { Signal, WritableSignal } from '@angular/core';
|
2
|
-
import {
|
2
|
+
import { AITableSelection } from '../../types';
|
3
3
|
import { RendererContext } from '../context';
|
4
4
|
import { AIRecordFieldIdPath, AITableField, AITableFields, AITableRecord, AITableRecords } from './core';
|
5
5
|
export interface AITable {
|
@@ -16,7 +16,6 @@ export interface AITable {
|
|
16
16
|
}>;
|
17
17
|
recordsWillHidden: WritableSignal<string[]>;
|
18
18
|
recordsWillMove: WritableSignal<string[]>;
|
19
|
-
references: WritableSignal<AITableReferences>;
|
20
19
|
}
|
21
20
|
export type AIPlugin = (aiTable: AITable) => AITable;
|
22
21
|
export declare const AITable: {
|
@@ -47,5 +46,6 @@ export declare const AITable: {
|
|
47
46
|
rowIndex: number;
|
48
47
|
columnIndex: number;
|
49
48
|
} | null;
|
49
|
+
isFrozenColumn(aiTable: AITable, columnIndex: number): boolean;
|
50
50
|
};
|
51
51
|
//# sourceMappingURL=ai-table.d.ts.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"ai-table.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/core/types/ai-table.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAEvD,OAAO,EAAE,
|
1
|
+
{"version":3,"file":"ai-table.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/core/types/ai-table.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAEvD,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAC/C,OAAO,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AAC7C,OAAO,EAAE,mBAAmB,EAAE,YAAY,EAAE,aAAa,EAAE,aAAa,EAAE,cAAc,EAAE,MAAM,QAAQ,CAAC;AAEzG,MAAM,WAAW,OAAO;IACpB,OAAO,EAAE,cAAc,CAAC,cAAc,CAAC,CAAC;IACxC,MAAM,EAAE,cAAc,CAAC,aAAa,CAAC,CAAC;IACtC,OAAO,CAAC,EAAE,eAAe,CAAC;IAC1B,SAAS,EAAE,cAAc,CAAC,gBAAgB,CAAC,CAAC;IAC5C,oBAAoB,EAAE,cAAc,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC;IAClD,UAAU,EAAE,MAAM,CAAC;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,aAAa,CAAA;KAAE,CAAC,CAAC;IACrD,SAAS,EAAE,MAAM,CAAC;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,YAAY,CAAA;KAAE,CAAC,CAAC;IACnD,iBAAiB,EAAE,cAAc,CAAC,MAAM,EAAE,CAAC,CAAC;IAC5C,eAAe,EAAE,cAAc,CAAC,MAAM,EAAE,CAAC,CAAC;CAC7C;AAED,MAAM,MAAM,QAAQ,GAAG,CAAC,OAAO,EAAE,OAAO,KAAK,OAAO,CAAC;AAErD,eAAO,MAAM,OAAO;;;;;;;;;;;;;;;;;;;8BAIU,OAAO;4BAGT,OAAO;2BAGR,OAAO,GAAG,mBAAmB,GAAG,IAAI;gCAG/B,OAAO,GAAG,MAAM,EAAE;2BAavB,OAAO,8BAA8B,OAAO;0BAO7C,OAAO,8BAA8B;QAAE,QAAQ,EAAE,MAAM,CAAC;QAAC,WAAW,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI;4BAYnF,OAAO,eAAe,MAAM;CAOvD,CAAC"}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"common.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/core/utils/common.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAoB,MAAM,eAAe,CAAC;AACjE,OAAO,EAAE,OAAO,EAAgB,aAAa,EAAiB,cAAc,EAAE,MAAM,UAAU,CAAC;AAE/F,wBAAgB,aAAa,CAAC,OAAO,EAAE,cAAc,CAAC,cAAc,CAAC,EAAE,MAAM,EAAE,cAAc,CAAC,aAAa,CAAC,GAAG,OAAO,
|
1
|
+
{"version":3,"file":"common.d.ts","sourceRoot":"","sources":["../../../../packages/grid/src/core/utils/common.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAoB,MAAM,eAAe,CAAC;AACjE,OAAO,EAAE,OAAO,EAAgB,aAAa,EAAiB,cAAc,EAAE,MAAM,UAAU,CAAC;AAE/F,wBAAgB,aAAa,CAAC,OAAO,EAAE,cAAc,CAAC,cAAc,CAAC,EAAE,MAAM,EAAE,cAAc,CAAC,aAAa,CAAC,GAAG,OAAO,CAiCrH"}
|
@@ -0,0 +1,102 @@
|
|
1
|
+
import { NgClass, NgIf, NgTemplateOutlet } from '@angular/common';
|
2
|
+
import { ChangeDetectionStrategy, Component, Input, booleanAttribute, computed, inject, model, output } from '@angular/core';
|
3
|
+
import { FormsModule } from '@angular/forms';
|
4
|
+
import { ThyButton } from 'ngx-tethys/button';
|
5
|
+
import { ThyDropdownDirective, ThyDropdownMenuComponent, ThyDropdownMenuItemDirective, ThyDropdownMenuItemNameDirective } from 'ngx-tethys/dropdown';
|
6
|
+
import { ThyFormModule, ThyUniqueCheckValidator } from 'ngx-tethys/form';
|
7
|
+
import { ThyIcon } from 'ngx-tethys/icon';
|
8
|
+
import { ThyInputCount, ThyInputDirective, ThyInputGroup } from 'ngx-tethys/input';
|
9
|
+
import { ThyListItem } from 'ngx-tethys/list';
|
10
|
+
import { ThyPopoverRef } from 'ngx-tethys/popover';
|
11
|
+
import { ThyAutofocusDirective } from 'ngx-tethys/shared';
|
12
|
+
import { of } from 'rxjs';
|
13
|
+
import { FieldOptions, createDefaultFieldName, getFieldOptionByField } from '../../core';
|
14
|
+
import { AITableFieldIsMultiplePipe } from '../../pipes';
|
15
|
+
import * as i0 from "@angular/core";
|
16
|
+
import * as i1 from "@angular/forms";
|
17
|
+
import * as i2 from "ngx-tethys/form";
|
18
|
+
export class AITableFieldSetting {
|
19
|
+
constructor() {
|
20
|
+
this.aiEditField = model.required();
|
21
|
+
this.aiExternalTemplate = null;
|
22
|
+
this.addField = output();
|
23
|
+
this.setField = output();
|
24
|
+
this.selectedFieldOption = computed(() => {
|
25
|
+
return getFieldOptionByField(this.aiEditField());
|
26
|
+
});
|
27
|
+
this.fieldMaxLength = 32;
|
28
|
+
this.validatorConfig = {
|
29
|
+
validationMessages: {
|
30
|
+
fieldName: {
|
31
|
+
required: '列名不能为空',
|
32
|
+
thyUniqueCheck: '列名已存在'
|
33
|
+
}
|
34
|
+
}
|
35
|
+
};
|
36
|
+
this.fieldOptions = FieldOptions;
|
37
|
+
this.thyPopoverRef = inject((ThyPopoverRef));
|
38
|
+
this.checkUniqueName = (fieldName) => {
|
39
|
+
fieldName = fieldName?.trim();
|
40
|
+
return of(!!this.aiTable.fields()?.find((field) => field.name === fieldName && this.aiEditField()?._id !== field._id));
|
41
|
+
};
|
42
|
+
}
|
43
|
+
selectFieldType(field) {
|
44
|
+
this.aiEditField.update((item) => {
|
45
|
+
const width = item.width ?? field.width;
|
46
|
+
const settings = field.settings || {};
|
47
|
+
const name = createDefaultFieldName(this.aiTable, field);
|
48
|
+
return { ...item, ...field, width, name, ...settings };
|
49
|
+
});
|
50
|
+
}
|
51
|
+
editFieldProperty() {
|
52
|
+
if (this.isUpdate) {
|
53
|
+
this.setField.emit({
|
54
|
+
field: this.aiEditField(),
|
55
|
+
path: [this.aiEditField()._id]
|
56
|
+
});
|
57
|
+
}
|
58
|
+
else {
|
59
|
+
this.addField.emit(this.aiEditField());
|
60
|
+
}
|
61
|
+
this.thyPopoverRef.close();
|
62
|
+
}
|
63
|
+
cancel() {
|
64
|
+
this.thyPopoverRef.close();
|
65
|
+
}
|
66
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableFieldSetting, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
67
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: AITableFieldSetting, isStandalone: true, selector: "ai-table-field-setting", inputs: { aiEditField: { classPropertyName: "aiEditField", publicName: "aiEditField", isSignal: true, isRequired: true, transformFunction: null }, aiTable: { classPropertyName: "aiTable", publicName: "aiTable", isSignal: false, isRequired: true, transformFunction: null }, aiExternalTemplate: { classPropertyName: "aiExternalTemplate", publicName: "aiExternalTemplate", isSignal: false, isRequired: false, transformFunction: null }, isUpdate: { classPropertyName: "isUpdate", publicName: "isUpdate", isSignal: false, isRequired: false, transformFunction: booleanAttribute } }, outputs: { aiEditField: "aiEditFieldChange", addField: "addField", setField: "setField" }, host: { classAttribute: "field-setting d-block pl-5 pr-5 pb-5 pt-4" }, ngImport: i0, template: "<form thyForm name=\"createPropertyForm\" [thyFormValidatorConfig]=\"validatorConfig\" thyLayout=\"vertical\">\n <thy-form-group thyLabelRequired thyLabelText=\"\u8868\u683C\u5217\u540D\">\n <thy-input-group>\n <input\n thyInput\n [thyAutofocus]=\"true\"\n name=\"fieldName\"\n [maxlength]=\"fieldMaxLength\"\n [(ngModel)]=\"aiEditField().name\"\n required\n placeholder=\"\u8F93\u5165\u5217\u540D\u79F0\"\n [thyUniqueCheck]=\"checkUniqueName\"\n />\n <ng-template #suffix>\n <thy-input-count></thy-input-count>\n </ng-template>\n </thy-input-group>\n </thy-form-group>\n <thy-form-group thyLabelText=\"\u5217\u7C7B\u578B\">\n <div class=\"ml-n5 mr-n5\">\n <thy-list-item [thyDropdown]=\"menu\" thyTrigger=\"hover\" thyPlacement=\"right\" class=\"justify-content-between\">\n <span>\n <thy-icon [thyIconName]=\"selectedFieldOption().icon\" class=\"text-desc mr-2\"></thy-icon>\n <span>{{ selectedFieldOption().name }}</span>\n </span>\n <thy-icon thyIconName=\"angle-right\" class=\"text-desc\"></thy-icon>\n </thy-list-item>\n </div>\n </thy-form-group>\n <ng-container *ngIf=\"aiExternalTemplate; else defaultTemplate\">\n <ng-container *ngTemplateOutlet=\"aiExternalTemplate\"></ng-container>\n </ng-container>\n <ng-template #defaultTemplate>\n <!-- TODO: \u5185\u90E8\u5C5E\u6027\u6E32\u67D3 -->\n </ng-template>\n <thy-form-group-footer thyAlign=\"right\">\n <button thyButton=\"link-secondary\" (click)=\"cancel()\" thySize=\"sm\">\u53D6\u6D88</button>\n <button thyButton=\"primary\" (thyFormSubmit)=\"editFieldProperty()\" thySize=\"sm\">\u786E\u5B9A</button>\n </thy-form-group-footer>\n</form>\n\n<thy-dropdown-menu #menu>\n @for (item of fieldOptions; track $index) {\n @let isSelectedField = aiEditField().type === item.type;\n @let isSameMultipleMode = (item.settings! | fieldIsMultiple) === (aiEditField().settings! | fieldIsMultiple);\n <a\n thyDropdownMenuItem\n href=\"javascript:;\"\n [ngClass]=\"{\n active: isSelectedField && isSameMultipleMode\n }\"\n (click)=\"selectFieldType(item)\"\n >\n <thy-icon [thyIconName]=\"item.icon!\"></thy-icon>\n <span thyDropdownMenuItemName>{{ item.name }}</span>\n </a>\n }\n</thy-dropdown-menu>\n", styles: [":host{width:350px}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i1.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i1.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: ThyIcon, selector: "thy-icon, [thy-icon]", inputs: ["thyIconType", "thyTwotoneColor", "thyIconName", "thyIconRotate", "thyIconSet", "thyIconLegging", "thyIconLinearGradient"] }, { kind: "component", type: ThyInputGroup, selector: "thy-input-group", inputs: ["thyAppendText", "thyAppendTextTranslateKey", "thyPrependText", "thyPrependTextTranslateKey", "thySize"] }, { kind: "component", type: ThyInputCount, selector: "thy-input-count", inputs: ["thyInput"] }, { kind: "directive", type: ThyInputDirective, selector: "input[thyInput], select[thyInput], textarea[thyInput]", inputs: ["thySize"], exportAs: ["thyInput"] }, { kind: "directive", type: ThyUniqueCheckValidator, selector: "[thyUniqueCheck]", inputs: ["thyUniqueCheck"] }, { kind: "directive", type: ThyDropdownDirective, selector: "[thyDropdown]", inputs: ["thyDropdownMenu", "thyDropdown", "thyTrigger", "thyShowDelay", "thyHideDelay", "thyActiveClass", "thyPopoverOptions", "thyPlacement", "thyMenuInsideClosable", "thyPanelClass"], outputs: ["thyActiveChange"] }, { kind: "component", type: ThyDropdownMenuComponent, selector: "thy-dropdown-menu", inputs: ["thyWidth", "thyImmediateRender"] }, { kind: "directive", type: ThyDropdownMenuItemDirective, selector: "[thyDropdownMenuItem]", inputs: ["thyType", "thyDisabled"] }, { kind: "directive", type: ThyDropdownMenuItemNameDirective, selector: "[thyDropdownMenuItemName]" }, { kind: "component", type: ThyButton, selector: "thy-button,[thy-button],[thyButton]", inputs: ["thyButton", "thyType", "thyLoading", "thyLoadingText", "thySize", "thyIcon", "thyBlock"] }, { kind: "ngmodule", type: ThyFormModule }, { kind: "directive", type: i2.ThyFormDirective, selector: "[thyForm],[thy-form]", inputs: ["thyLayout", "thyEnterKeyMode", "thyFormValidatorConfig"], exportAs: ["thyForm"] }, { kind: "component", type: i2.ThyFormGroup, selector: "thy-form-group", inputs: ["thyLabelText", "thyLabelTextTranslateKey", "thyLabelRequired", "thyLabelPaddingTopClear", "thyFeedbackIcon", "thyTipsMode", "thyTips", "thyTipsTranslateKey", "thyRowFill"] }, { kind: "directive", type: i2.ThyFormSubmitDirective, selector: "[thyFormSubmit],[thy-form-submit]", outputs: ["thyFormSubmit"] }, { kind: "component", type: i2.ThyFormGroupFooter, selector: "thy-form-group-footer", inputs: ["thyAlign"] }, { kind: "component", type: ThyListItem, selector: "thy-list-item,[thy-list-item]" }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: ThyAutofocusDirective, selector: "input[thyAutofocus],textarea[thyAutofocus]", inputs: ["thyAutofocus", "thyAutoSelect"] }, { kind: "pipe", type: AITableFieldIsMultiplePipe, name: "fieldIsMultiple" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
68
|
+
}
|
69
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableFieldSetting, decorators: [{
|
70
|
+
type: Component,
|
71
|
+
args: [{ selector: 'ai-table-field-setting', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [
|
72
|
+
NgIf,
|
73
|
+
NgClass,
|
74
|
+
FormsModule,
|
75
|
+
ThyIcon,
|
76
|
+
ThyInputGroup,
|
77
|
+
ThyInputCount,
|
78
|
+
ThyInputDirective,
|
79
|
+
ThyUniqueCheckValidator,
|
80
|
+
ThyDropdownDirective,
|
81
|
+
ThyDropdownMenuComponent,
|
82
|
+
ThyDropdownMenuItemDirective,
|
83
|
+
ThyDropdownMenuItemNameDirective,
|
84
|
+
ThyButton,
|
85
|
+
ThyFormModule,
|
86
|
+
ThyListItem,
|
87
|
+
NgTemplateOutlet,
|
88
|
+
ThyAutofocusDirective,
|
89
|
+
AITableFieldIsMultiplePipe
|
90
|
+
], host: {
|
91
|
+
class: 'field-setting d-block pl-5 pr-5 pb-5 pt-4'
|
92
|
+
}, template: "<form thyForm name=\"createPropertyForm\" [thyFormValidatorConfig]=\"validatorConfig\" thyLayout=\"vertical\">\n <thy-form-group thyLabelRequired thyLabelText=\"\u8868\u683C\u5217\u540D\">\n <thy-input-group>\n <input\n thyInput\n [thyAutofocus]=\"true\"\n name=\"fieldName\"\n [maxlength]=\"fieldMaxLength\"\n [(ngModel)]=\"aiEditField().name\"\n required\n placeholder=\"\u8F93\u5165\u5217\u540D\u79F0\"\n [thyUniqueCheck]=\"checkUniqueName\"\n />\n <ng-template #suffix>\n <thy-input-count></thy-input-count>\n </ng-template>\n </thy-input-group>\n </thy-form-group>\n <thy-form-group thyLabelText=\"\u5217\u7C7B\u578B\">\n <div class=\"ml-n5 mr-n5\">\n <thy-list-item [thyDropdown]=\"menu\" thyTrigger=\"hover\" thyPlacement=\"right\" class=\"justify-content-between\">\n <span>\n <thy-icon [thyIconName]=\"selectedFieldOption().icon\" class=\"text-desc mr-2\"></thy-icon>\n <span>{{ selectedFieldOption().name }}</span>\n </span>\n <thy-icon thyIconName=\"angle-right\" class=\"text-desc\"></thy-icon>\n </thy-list-item>\n </div>\n </thy-form-group>\n <ng-container *ngIf=\"aiExternalTemplate; else defaultTemplate\">\n <ng-container *ngTemplateOutlet=\"aiExternalTemplate\"></ng-container>\n </ng-container>\n <ng-template #defaultTemplate>\n <!-- TODO: \u5185\u90E8\u5C5E\u6027\u6E32\u67D3 -->\n </ng-template>\n <thy-form-group-footer thyAlign=\"right\">\n <button thyButton=\"link-secondary\" (click)=\"cancel()\" thySize=\"sm\">\u53D6\u6D88</button>\n <button thyButton=\"primary\" (thyFormSubmit)=\"editFieldProperty()\" thySize=\"sm\">\u786E\u5B9A</button>\n </thy-form-group-footer>\n</form>\n\n<thy-dropdown-menu #menu>\n @for (item of fieldOptions; track $index) {\n @let isSelectedField = aiEditField().type === item.type;\n @let isSameMultipleMode = (item.settings! | fieldIsMultiple) === (aiEditField().settings! | fieldIsMultiple);\n <a\n thyDropdownMenuItem\n href=\"javascript:;\"\n [ngClass]=\"{\n active: isSelectedField && isSameMultipleMode\n }\"\n (click)=\"selectFieldType(item)\"\n >\n <thy-icon [thyIconName]=\"item.icon!\"></thy-icon>\n <span thyDropdownMenuItemName>{{ item.name }}</span>\n </a>\n }\n</thy-dropdown-menu>\n", styles: [":host{width:350px}\n"] }]
|
93
|
+
}], propDecorators: { aiTable: [{
|
94
|
+
type: Input,
|
95
|
+
args: [{ required: true }]
|
96
|
+
}], aiExternalTemplate: [{
|
97
|
+
type: Input
|
98
|
+
}], isUpdate: [{
|
99
|
+
type: Input,
|
100
|
+
args: [{ transform: booleanAttribute }]
|
101
|
+
}] } });
|
102
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"field-setting.component.js","sourceRoot":"","sources":["../../../../../packages/grid/src/components/field-setting/field-setting.component.ts","../../../../../packages/grid/src/components/field-setting/field-setting.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgClass, NgIf, NgTemplateOutlet } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, Input, TemplateRef, booleanAttribute, computed, inject, model, output } from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { ThyButton } from 'ngx-tethys/button';\nimport {\n    ThyDropdownDirective,\n    ThyDropdownMenuComponent,\n    ThyDropdownMenuItemDirective,\n    ThyDropdownMenuItemNameDirective\n} from 'ngx-tethys/dropdown';\nimport { ThyFormModule, ThyFormValidatorConfig, ThyUniqueCheckValidator } from 'ngx-tethys/form';\nimport { ThyIcon } from 'ngx-tethys/icon';\nimport { ThyInputCount, ThyInputDirective, ThyInputGroup } from 'ngx-tethys/input';\nimport { ThyListItem } from 'ngx-tethys/list';\nimport { ThyPopoverRef } from 'ngx-tethys/popover';\nimport { ThyAutofocusDirective } from 'ngx-tethys/shared';\nimport { of } from 'rxjs';\nimport {\n    AITable,\n    AITableField,\n    AITableFieldOption,\n    FieldOptions,\n    createDefaultFieldName,\n    getFieldOptionByField,\n    SetFieldOptions\n} from '../../core';\nimport { AITableFieldIsMultiplePipe } from '../../pipes';\n\n@Component({\n    selector: 'ai-table-field-setting',\n    templateUrl: './field-setting.component.html',\n    standalone: true,\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    imports: [\n        NgIf,\n        NgClass,\n        FormsModule,\n        ThyIcon,\n        ThyInputGroup,\n        ThyInputCount,\n        ThyInputDirective,\n        ThyUniqueCheckValidator,\n        ThyDropdownDirective,\n        ThyDropdownMenuComponent,\n        ThyDropdownMenuItemDirective,\n        ThyDropdownMenuItemNameDirective,\n        ThyButton,\n        ThyFormModule,\n        ThyListItem,\n        NgTemplateOutlet,\n        ThyAutofocusDirective,\n        AITableFieldIsMultiplePipe\n    ],\n    host: {\n        class: 'field-setting d-block pl-5 pr-5 pb-5 pt-4'\n    },\n    styles: [\n        `\n            :host {\n                width: 350px;\n            }\n        `\n    ]\n})\nexport class AITableFieldSetting {\n    aiEditField = model.required<AITableField>();\n\n    @Input({ required: true }) aiTable!: AITable;\n\n    @Input() aiExternalTemplate: TemplateRef<any> | null = null;\n\n    @Input({ transform: booleanAttribute }) isUpdate!: boolean;\n\n    addField = output<AITableField>();\n\n    setField = output<SetFieldOptions>();\n\n    selectedFieldOption = computed(() => {\n        return getFieldOptionByField(this.aiEditField())!;\n    });\n\n    fieldMaxLength = 32;\n\n    validatorConfig: ThyFormValidatorConfig = {\n        validationMessages: {\n            fieldName: {\n                required: '列名不能为空',\n                thyUniqueCheck: '列名已存在'\n            }\n        }\n    };\n\n    fieldOptions = FieldOptions;\n\n    protected thyPopoverRef = inject(ThyPopoverRef<AITableFieldSetting>);\n\n    checkUniqueName = (fieldName: string) => {\n        fieldName = fieldName?.trim();\n        return of(!!this.aiTable.fields()?.find((field) => field.name === fieldName && this.aiEditField()?._id !== field._id));\n    };\n\n    selectFieldType(field: AITableFieldOption) {\n        this.aiEditField.update((item) => {\n            const width = item.width ?? field.width;\n            const settings = field.settings || {};\n            const name = createDefaultFieldName(this.aiTable, field);\n            return { ...item, ...field, width, name, ...settings };\n        });\n    }\n\n    editFieldProperty() {\n        if (this.isUpdate) {\n            this.setField.emit({\n                field: this.aiEditField(),\n                path: [this.aiEditField()._id]\n            });\n        } else {\n            this.addField.emit(this.aiEditField());\n        }\n        this.thyPopoverRef.close();\n    }\n\n    cancel() {\n        this.thyPopoverRef.close();\n    }\n}\n","<form thyForm name=\"createPropertyForm\" [thyFormValidatorConfig]=\"validatorConfig\" thyLayout=\"vertical\">\n    <thy-form-group thyLabelRequired thyLabelText=\"表格列名\">\n        <thy-input-group>\n            <input\n                thyInput\n                [thyAutofocus]=\"true\"\n                name=\"fieldName\"\n                [maxlength]=\"fieldMaxLength\"\n                [(ngModel)]=\"aiEditField().name\"\n                required\n                placeholder=\"输入列名称\"\n                [thyUniqueCheck]=\"checkUniqueName\"\n            />\n            <ng-template #suffix>\n                <thy-input-count></thy-input-count>\n            </ng-template>\n        </thy-input-group>\n    </thy-form-group>\n    <thy-form-group thyLabelText=\"列类型\">\n        <div class=\"ml-n5 mr-n5\">\n            <thy-list-item [thyDropdown]=\"menu\" thyTrigger=\"hover\" thyPlacement=\"right\" class=\"justify-content-between\">\n                <span>\n                    <thy-icon [thyIconName]=\"selectedFieldOption().icon\" class=\"text-desc mr-2\"></thy-icon>\n                    <span>{{ selectedFieldOption().name }}</span>\n                </span>\n                <thy-icon thyIconName=\"angle-right\" class=\"text-desc\"></thy-icon>\n            </thy-list-item>\n        </div>\n    </thy-form-group>\n    <ng-container *ngIf=\"aiExternalTemplate; else defaultTemplate\">\n        <ng-container *ngTemplateOutlet=\"aiExternalTemplate\"></ng-container>\n    </ng-container>\n    <ng-template #defaultTemplate>\n        <!-- TODO: 内部属性渲染 -->\n    </ng-template>\n    <thy-form-group-footer thyAlign=\"right\">\n        <button thyButton=\"link-secondary\" (click)=\"cancel()\" thySize=\"sm\">取消</button>\n        <button thyButton=\"primary\" (thyFormSubmit)=\"editFieldProperty()\" thySize=\"sm\">确定</button>\n    </thy-form-group-footer>\n</form>\n\n<thy-dropdown-menu #menu>\n    @for (item of fieldOptions; track $index) {\n        @let isSelectedField = aiEditField().type === item.type;\n        @let isSameMultipleMode = (item.settings! | fieldIsMultiple) === (aiEditField().settings! | fieldIsMultiple);\n        <a\n            thyDropdownMenuItem\n            href=\"javascript:;\"\n            [ngClass]=\"{\n                active: isSelectedField && isSameMultipleMode\n            }\"\n            (click)=\"selectFieldType(item)\"\n        >\n            <thy-icon [thyIconName]=\"item.icon!\"></thy-icon>\n            <span thyDropdownMenuItemName>{{ item.name }}</span>\n        </a>\n    }\n</thy-dropdown-menu>\n"]}
|
@@ -7,6 +7,6 @@ export * from './cell-editors/rating/rating-editor.component';
|
|
7
7
|
export * from './cell-editors/select/select-editor.component';
|
8
8
|
export * from './cell-editors/text/text-editor.component';
|
9
9
|
export * from './cell-views/select/option.component';
|
10
|
-
export * from './field-
|
10
|
+
export * from './field-setting/field-setting.component';
|
11
11
|
export * from './context-menu/context-menu.component';
|
12
|
-
//# sourceMappingURL=data:application/json;base64,
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9ncmlkL3NyYy9jb21wb25lbnRzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsK0NBQStDLENBQUM7QUFDOUQsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMsK0NBQStDLENBQUM7QUFDOUQsY0FBYyxtREFBbUQsQ0FBQztBQUNsRSxjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMsK0NBQStDLENBQUM7QUFDOUQsY0FBYywyQ0FBMkMsQ0FBQztBQUMxRCxjQUFjLHNDQUFzQyxDQUFDO0FBQ3JELGNBQWMseUNBQXlDLENBQUM7QUFDeEQsY0FBYyx1Q0FBdUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY2VsbC1lZGl0b3JzL2Fic3RyYWN0LWNlbGwtZWRpdG9yLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2NlbGwtZWRpdG9ycy9kYXRlL2RhdGUtZWRpdG9yLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2NlbGwtZWRpdG9ycy9saW5rL2xpbmstZWRpdG9yLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2NlbGwtZWRpdG9ycy9udW1iZXIvbnVtYmVyLWVkaXRvci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9jZWxsLWVkaXRvcnMvcHJvZ3Jlc3MvcHJvZ3Jlc3MtZWRpdG9yLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2NlbGwtZWRpdG9ycy9yYXRpbmcvcmF0aW5nLWVkaXRvci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9jZWxsLWVkaXRvcnMvc2VsZWN0L3NlbGVjdC1lZGl0b3IuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY2VsbC1lZGl0b3JzL3RleHQvdGV4dC1lZGl0b3IuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY2VsbC12aWV3cy9zZWxlY3Qvb3B0aW9uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2ZpZWxkLXNldHRpbmcvZmllbGQtc2V0dGluZy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9jb250ZXh0LW1lbnUvY29udGV4dC1tZW51LmNvbXBvbmVudCc7XG4iXX0=
|
package/esm2022/core/context.mjs
CHANGED
@@ -1,12 +1,14 @@
|
|
1
1
|
export class RendererContext {
|
2
2
|
constructor(options) {
|
3
|
-
const { linearRows, pointPosition, scrollState,
|
3
|
+
const { linearRows, pointPosition, scrollState, visibleColumnsIndexMap, visibleRowsIndexMap, frozenColumnCount, references, scrollAction } = options;
|
4
4
|
this.linearRows = linearRows;
|
5
5
|
this.pointPosition = pointPosition;
|
6
6
|
this.scrollState = scrollState;
|
7
7
|
this.scrollAction = scrollAction;
|
8
|
-
this.
|
8
|
+
this.visibleColumnsIndexMap = visibleColumnsIndexMap;
|
9
9
|
this.visibleRowsIndexMap = visibleRowsIndexMap;
|
10
|
+
this.frozenColumnCount = frozenColumnCount;
|
11
|
+
this.references = references;
|
10
12
|
}
|
11
13
|
setPointPosition(position) {
|
12
14
|
const oldPosition = this.pointPosition();
|
@@ -22,4 +24,4 @@ export class RendererContext {
|
|
22
24
|
this.scrollState.set({ ...this.scrollState(), ...scrollState });
|
23
25
|
}
|
24
26
|
}
|
25
|
-
//# sourceMappingURL=data:application/json;base64,
|
27
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGV4dC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL2dyaWQvc3JjL2NvcmUvY29udGV4dC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHQSxNQUFNLE9BQU8sZUFBZTtJQVV4QixZQUFZLE9BQXVCO1FBQy9CLE1BQU0sRUFBRSxVQUFVLEVBQUUsYUFBYSxFQUFFLFdBQVcsRUFBRSxzQkFBc0IsRUFBRSxtQkFBbUIsRUFBRSxpQkFBaUIsRUFBRSxVQUFVLEVBQUUsWUFBWSxFQUFFLEdBQUcsT0FBTyxDQUFDO1FBQ3JKLElBQUksQ0FBQyxVQUFVLEdBQUcsVUFBVSxDQUFDO1FBQzdCLElBQUksQ0FBQyxhQUFhLEdBQUcsYUFBYSxDQUFDO1FBQ25DLElBQUksQ0FBQyxXQUFXLEdBQUcsV0FBVyxDQUFDO1FBQy9CLElBQUksQ0FBQyxZQUFZLEdBQUcsWUFBWSxDQUFDO1FBQ2pDLElBQUksQ0FBQyxzQkFBc0IsR0FBRyxzQkFBc0IsQ0FBQztRQUNyRCxJQUFJLENBQUMsbUJBQW1CLEdBQUcsbUJBQW1CLENBQUM7UUFDL0MsSUFBSSxDQUFDLGlCQUFpQixHQUFHLGlCQUFpQixDQUFDO1FBQzNDLElBQUksQ0FBQyxVQUFVLEdBQUcsVUFBVSxDQUFDO0lBQ2pDLENBQUM7SUFFRCxnQkFBZ0IsQ0FBQyxRQUF1QztRQUNwRCxNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7UUFDekMsSUFDSSxXQUFXLENBQUMsUUFBUSxLQUFLLFFBQVEsQ0FBQyxRQUFRO1lBQzFDLFdBQVcsQ0FBQyxRQUFRLEtBQUssUUFBUSxDQUFDLFFBQVE7WUFDMUMsV0FBVyxDQUFDLFdBQVcsS0FBSyxRQUFRLENBQUMsV0FBVztZQUNoRCxXQUFXLENBQUMsVUFBVSxLQUFLLFFBQVEsQ0FBQyxVQUFVLEVBQ2hELENBQUM7WUFDQyxNQUFNLFdBQVcsR0FBRyxFQUFFLEdBQUcsV0FBVyxFQUFFLEdBQUcsUUFBUSxFQUFFLENBQUM7WUFDcEQsSUFBSSxDQUFDLGFBQWEsQ0FBQyxHQUFHLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDeEMsQ0FBQztJQUNMLENBQUM7SUFFRCxjQUFjLENBQUMsV0FBd0M7UUFDbkQsSUFBSSxDQUFDLFdBQVcsQ0FBQyxHQUFHLENBQUMsRUFBRSxHQUFHLElBQUksQ0FBQyxXQUFXLEVBQUUsRUFBRSxHQUFHLFdBQVcsRUFBRSxDQUFDLENBQUM7SUFDcEUsQ0FBQztDQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2lnbmFsLCBXcml0YWJsZVNpZ25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQUlUYWJsZUNvbnRleHQsIEFJVGFibGVMaW5lYXJSb3csIEFJVGFibGVQb2ludFBvc2l0aW9uLCBBSVRhYmxlUmVmZXJlbmNlcywgQUlUYWJsZVNjcm9sbFN0YXRlLCBTY3JvbGxBY3Rpb25PcHRpb25zIH0gZnJvbSAnLi4vdHlwZXMnO1xuXG5leHBvcnQgY2xhc3MgUmVuZGVyZXJDb250ZXh0IHtcbiAgICBsaW5lYXJSb3dzOiBTaWduYWw8QUlUYWJsZUxpbmVhclJvd1tdPjtcbiAgICBwb2ludFBvc2l0aW9uOiBXcml0YWJsZVNpZ25hbDxBSVRhYmxlUG9pbnRQb3NpdGlvbj47XG4gICAgc2Nyb2xsU3RhdGU6IFdyaXRhYmxlU2lnbmFsPEFJVGFibGVTY3JvbGxTdGF0ZT47XG4gICAgdmlzaWJsZUNvbHVtbnNJbmRleE1hcDogU2lnbmFsPE1hcDxzdHJpbmcsIG51bWJlcj4+O1xuICAgIHZpc2libGVSb3dzSW5kZXhNYXA6IFNpZ25hbDxNYXA8c3RyaW5nLCBudW1iZXI+PjtcbiAgICBmcm96ZW5Db2x1bW5Db3VudDogU2lnbmFsPG51bWJlcj47XG4gICAgcmVmZXJlbmNlczogU2lnbmFsPEFJVGFibGVSZWZlcmVuY2VzPjtcbiAgICBzY3JvbGxBY3Rpb246IChvcHRpb25zOiBTY3JvbGxBY3Rpb25PcHRpb25zKSA9PiB2b2lkO1xuXG4gICAgY29uc3RydWN0b3Iob3B0aW9uczogQUlUYWJsZUNvbnRleHQpIHtcbiAgICAgICAgY29uc3QgeyBsaW5lYXJSb3dzLCBwb2ludFBvc2l0aW9uLCBzY3JvbGxTdGF0ZSwgdmlzaWJsZUNvbHVtbnNJbmRleE1hcCwgdmlzaWJsZVJvd3NJbmRleE1hcCwgZnJvemVuQ29sdW1uQ291bnQsIHJlZmVyZW5jZXMsIHNjcm9sbEFjdGlvbiB9ID0gb3B0aW9ucztcbiAgICAgICAgdGhpcy5saW5lYXJSb3dzID0gbGluZWFyUm93cztcbiAgICAgICAgdGhpcy5wb2ludFBvc2l0aW9uID0gcG9pbnRQb3NpdGlvbjtcbiAgICAgICAgdGhpcy5zY3JvbGxTdGF0ZSA9IHNjcm9sbFN0YXRlO1xuICAgICAgICB0aGlzLnNjcm9sbEFjdGlvbiA9IHNjcm9sbEFjdGlvbjtcbiAgICAgICAgdGhpcy52aXNpYmxlQ29sdW1uc0luZGV4TWFwID0gdmlzaWJsZUNvbHVtbnNJbmRleE1hcDtcbiAgICAgICAgdGhpcy52aXNpYmxlUm93c0luZGV4TWFwID0gdmlzaWJsZVJvd3NJbmRleE1hcDtcbiAgICAgICAgdGhpcy5mcm96ZW5Db2x1bW5Db3VudCA9IGZyb3plbkNvbHVtbkNvdW50O1xuICAgICAgICB0aGlzLnJlZmVyZW5jZXMgPSByZWZlcmVuY2VzO1xuICAgIH1cblxuICAgIHNldFBvaW50UG9zaXRpb24ocG9zaXRpb246IFBhcnRpYWw8QUlUYWJsZVBvaW50UG9zaXRpb24+KSB7XG4gICAgICAgIGNvbnN0IG9sZFBvc2l0aW9uID0gdGhpcy5wb2ludFBvc2l0aW9uKCk7XG4gICAgICAgIGlmIChcbiAgICAgICAgICAgIG9sZFBvc2l0aW9uLmFyZWFUeXBlICE9PSBwb3NpdGlvbi5hcmVhVHlwZSB8fFxuICAgICAgICAgICAgb2xkUG9zaXRpb24ucm93SW5kZXggIT09IHBvc2l0aW9uLnJvd0luZGV4IHx8XG4gICAgICAgICAgICBvbGRQb3NpdGlvbi5jb2x1bW5JbmRleCAhPT0gcG9zaXRpb24uY29sdW1uSW5kZXggfHxcbiAgICAgICAgICAgIG9sZFBvc2l0aW9uLnRhcmdldE5hbWUgIT09IHBvc2l0aW9uLnRhcmdldE5hbWVcbiAgICAgICAgKSB7XG4gICAgICAgICAgICBjb25zdCBuZXdQb3NpdGlvbiA9IHsgLi4ub2xkUG9zaXRpb24sIC4uLnBvc2l0aW9uIH07XG4gICAgICAgICAgICB0aGlzLnBvaW50UG9zaXRpb24uc2V0KG5ld1Bvc2l0aW9uKTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHNldFNjcm9sbFN0YXRlKHNjcm9sbFN0YXRlOiBQYXJ0aWFsPEFJVGFibGVTY3JvbGxTdGF0ZT4pIHtcbiAgICAgICAgdGhpcy5zY3JvbGxTdGF0ZS5zZXQoeyAuLi50aGlzLnNjcm9sbFN0YXRlKCksIC4uLnNjcm9sbFN0YXRlIH0pO1xuICAgIH1cbn1cbiJdfQ==
|
@@ -3,11 +3,11 @@ import { AITableRowColumnType } from '../types';
|
|
3
3
|
* 用于构建 Canvas 基础坐标系,后续的绘制工作以此为基础
|
4
4
|
*/
|
5
5
|
export class Coordinate {
|
6
|
-
constructor({ rowHeight, rowCount, columnCount, container,
|
6
|
+
constructor({ rowHeight, rowCount, columnCount, container, rowIndicesSizeMap = {}, columnIndicesSizeMap = {}, rowInitSize = 0, columnInitSize = 0, frozenColumnCount = 0 }) {
|
7
7
|
// 用 index 映射 每一行的 高度
|
8
|
-
this.
|
8
|
+
this.rowIndicesSizeMap = {};
|
9
9
|
// 用 index 映射 每一列 的 宽度
|
10
|
-
this.
|
10
|
+
this.columnIndicesSizeMap = {};
|
11
11
|
// 行坐标集中最后一行的索引
|
12
12
|
this.lastRowIndex = -1;
|
13
13
|
// 列坐标集中最后一列的索引
|
@@ -20,8 +20,8 @@ export class Coordinate {
|
|
20
20
|
this.rowInitSize = rowInitSize;
|
21
21
|
this.columnInitSize = columnInitSize;
|
22
22
|
this.containerWidth = container.offsetWidth;
|
23
|
-
this.
|
24
|
-
this.
|
23
|
+
this.rowIndicesSizeMap = rowIndicesSizeMap;
|
24
|
+
this.columnIndicesSizeMap = columnIndicesSizeMap;
|
25
25
|
this.containerHeight = container.offsetHeight;
|
26
26
|
this.frozenColumnCount = frozenColumnCount;
|
27
27
|
this.container = container;
|
@@ -50,13 +50,13 @@ export class Coordinate {
|
|
50
50
|
* 根据 rowIndex 获取对应行高
|
51
51
|
*/
|
52
52
|
getRowHeight(index) {
|
53
|
-
return this.
|
53
|
+
return this.rowIndicesSizeMap[index] ?? this.rowHeight;
|
54
54
|
}
|
55
55
|
/**
|
56
56
|
* 根据 columnIndex 获取对应列宽
|
57
57
|
*/
|
58
58
|
getColumnWidth(index) {
|
59
|
-
return this.
|
59
|
+
return this.columnIndicesSizeMap[index];
|
60
60
|
}
|
61
61
|
/**
|
62
62
|
* 获取每个 cell 垂直/水平方向的坐标信息
|
@@ -80,7 +80,7 @@ export class Coordinate {
|
|
80
80
|
offset = itemMetadata.offset + itemMetadata.size;
|
81
81
|
}
|
82
82
|
for (let i = lastMeasuredIndex + 1; i <= index; i++) {
|
83
|
-
const size = isColumnType ? this.
|
83
|
+
const size = isColumnType ? this.columnIndicesSizeMap[i] : (this.rowIndicesSizeMap[i] ?? this.rowHeight);
|
84
84
|
cellMetadataMap[i] = {
|
85
85
|
offset,
|
86
86
|
size
|
@@ -219,4 +219,4 @@ export class Coordinate {
|
|
219
219
|
};
|
220
220
|
}
|
221
221
|
}
|
222
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"coordinate.js","sourceRoot":"","sources":["../../../../packages/grid/src/core/coordinate.ts"],"names":[],"mappings":"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","sourcesContent":["import { AITableCellMetaData, AITableCoordinate, AITableRowColumnType, AITableSizeMap } from '../types';\n\n/**\n * 用于构建 Canvas 基础坐标系，后续的绘制工作以此为基础\n */\nexport class Coordinate {\n    protected _rowHeight: number;\n    public rowCount: number;\n    public columnCount: number;\n    public container: HTMLDivElement;\n    public containerWidth: number;\n    public containerHeight: number;\n    // 用 index 映射 每一行的 高度\n    public rowIndicesMap: AITableSizeMap = {};\n    // 用 index 映射 每一列 的 宽度\n    public columnIndicesMap: AITableSizeMap = {};\n    // 除去表头和编号列真正单元格绘制的初始值 x\n    public rowInitSize: number;\n    // 除去表头和编号列真正单元格绘制的初始值 y\n    public columnInitSize: number;\n    // 行坐标集中最后一行的索引\n    public lastRowIndex = -1;\n    // 列坐标集中最后一列的索引\n    public lastColumnIndex = -1;\n    public rowMetaDataMap: Record<number, AITableCellMetaData> = {};\n    public columnMetaDataMap: Record<number, AITableCellMetaData> = {};\n    public frozenColumnCount: number;\n\n    constructor({\n        rowHeight,\n        rowCount,\n        columnCount,\n        container,\n        rowIndicesMap = {},\n        columnIndicesMap = {},\n        rowInitSize = 0,\n        columnInitSize = 0,\n        frozenColumnCount = 0\n    }: AITableCoordinate) {\n        this._rowHeight = rowHeight;\n        this.rowCount = rowCount;\n        this.columnCount = columnCount;\n        this.rowInitSize = rowInitSize;\n        this.columnInitSize = columnInitSize;\n        this.containerWidth = container.offsetWidth;\n        this.rowIndicesMap = rowIndicesMap;\n        this.columnIndicesMap = columnIndicesMap;\n        this.containerHeight = container.offsetHeight;\n        this.frozenColumnCount = frozenColumnCount;\n        this.container = container;\n    }\n\n    public get rowHeight() {\n        return this._rowHeight;\n    }\n\n    public set rowHeight(height: number) {\n        this._rowHeight = height;\n    }\n\n    /**\n     * 总宽度\n     */\n    public get totalWidth() {\n        const { offset, size } = this.getCellMetaData(this.columnCount - 1, AITableRowColumnType.column);\n        return offset + size;\n    }\n\n    /**\n     * 总高度\n     */\n    public get totalHeight() {\n        const { offset, size } = this.getCellMetaData(this.rowCount - 1, AITableRowColumnType.row);\n        return offset + size;\n    }\n\n    /**\n     * 根据 rowIndex 获取对应行高\n     */\n    public getRowHeight(index: number) {\n        return this.rowIndicesMap[index] ?? this.rowHeight;\n    }\n\n    /**\n     * 根据 columnIndex 获取对应列宽\n     */\n    public getColumnWidth(index: number) {\n        return this.columnIndicesMap[index];\n    }\n\n    /**\n     * 获取每个 cell 垂直/水平方向的坐标信息\n     */\n    protected getCellMetaData(index: number, itemType: AITableRowColumnType): AITableCellMetaData {\n        let cellMetadataMap, lastMeasuredIndex, offset;\n        const isColumnType = itemType === AITableRowColumnType.column;\n        if (isColumnType) {\n            offset = this.columnInitSize;\n            lastMeasuredIndex = this.lastColumnIndex;\n            cellMetadataMap = this.columnMetaDataMap;\n        } else {\n            offset = this.rowInitSize;\n            lastMeasuredIndex = this.lastRowIndex;\n            cellMetadataMap = this.rowMetaDataMap;\n        }\n        if (index > lastMeasuredIndex) {\n            if (lastMeasuredIndex >= 0) {\n                const itemMetadata = cellMetadataMap[lastMeasuredIndex];\n                offset = itemMetadata.offset + itemMetadata.size;\n            }\n\n            for (let i = lastMeasuredIndex + 1; i <= index; i++) {\n                const size = isColumnType ? this.columnIndicesMap[i] : (this.rowIndicesMap[i] ?? this.rowHeight);\n\n                cellMetadataMap[i] = {\n                    offset,\n                    size\n                };\n                offset += size;\n            }\n            if (isColumnType) {\n                this.lastColumnIndex = index;\n            } else {\n                this.lastRowIndex = index;\n            }\n        }\n        return cellMetadataMap[index] || { size: 0, offset: 0 };\n    }\n\n    /**\n     * 查找最近的单元格索引\n     * 性能较差，但无论如何都可以找到\n     */\n    private _findNearestCellIndex(index: number, offset: number, itemType: AITableRowColumnType) {\n        const itemCount = itemType === AITableRowColumnType.column ? this.columnCount : this.rowCount;\n        let interval = 1;\n\n        while (index < itemCount && this.getCellMetaData(index, itemType).offset < offset) {\n            index += interval;\n            interval *= 2;\n        }\n\n        return this._findNearestCellIndexByBinary(offset, Math.floor(index / 2), Math.min(index, itemCount - 1), itemType);\n    }\n\n    /**\n     * 二分法查找最近的单元格索引\n     * 性能更佳，但需要加载数据\n     */\n    private _findNearestCellIndexByBinary(offset: number, low: number, high: number, itemType: AITableRowColumnType) {\n        while (low <= high) {\n            const middle = low + Math.floor((high - low) / 2);\n            const currentOffset = this.getCellMetaData(middle, itemType).offset;\n\n            if (currentOffset === offset) {\n                return middle;\n            } else if (currentOffset < offset) {\n                low = middle + 1;\n            } else if (currentOffset > offset) {\n                high = middle - 1;\n            }\n        }\n        return low > -1 ? low - 1 : 0;\n    }\n\n    /**\n     * 根据偏移量查找最近的单元格索引\n     */\n    public findNearestCellIndex(offset: number, itemType: AITableRowColumnType) {\n        let lastIndex;\n        if (itemType === AITableRowColumnType.column) {\n            lastIndex = this.lastColumnIndex;\n        } else {\n            lastIndex = this.lastRowIndex;\n        }\n        const cellOffset = this.getCellMetaData(lastIndex, itemType).offset;\n        const lastMeasuredItemOffset = lastIndex > 0 ? cellOffset : 0;\n\n        if (lastMeasuredItemOffset >= offset) {\n            return this._findNearestCellIndexByBinary(offset, 0, lastIndex, itemType);\n        }\n        return this._findNearestCellIndex(Math.max(0, lastIndex), offset, itemType);\n    }\n\n    /**\n     * 根据垂直偏移量找到起始单元格的索引\n     */\n    public getRowStartIndex(offset: number) {\n        return this.findNearestCellIndex(offset, AITableRowColumnType.row);\n    }\n\n    /**\n     * 根据垂直起始单元格的索引查找结束单元格的索引\n     */\n    public getRowStopIndex(startIndex: number, scrollTop: number) {\n        const itemMetadata = this.getCellMetaData(startIndex, AITableRowColumnType.row);\n        const maxOffset = scrollTop + this.containerHeight;\n        let offset = itemMetadata.offset + itemMetadata.size;\n        let stopIndex = startIndex;\n\n        while (stopIndex < this.rowCount - 1 && offset < maxOffset) {\n            stopIndex++;\n            offset += this.getCellMetaData(stopIndex, AITableRowColumnType.row).size;\n        }\n        return stopIndex;\n    }\n\n    /**\n     * 根据水平偏移量找到起始单元格的索引\n     */\n    public getColumnStartIndex(offset: number) {\n        return this.findNearestCellIndex(offset, AITableRowColumnType.column);\n    }\n\n    /**\n     * 根据水平起始单元格的索引查找结束单元格的索引\n     */\n    public getColumnStopIndex(startIndex: number, scrollLeft: number) {\n        const itemMetadata = this.getCellMetaData(startIndex, AITableRowColumnType.column);\n        const maxOffset = scrollLeft + this.containerWidth;\n        let offset = itemMetadata.offset + itemMetadata.size;\n        let stopIndex = startIndex;\n\n        while (stopIndex < this.columnCount - 1 && offset < maxOffset) {\n            stopIndex++;\n            offset += this.getCellMetaData(stopIndex, AITableRowColumnType.column).size;\n        }\n        return stopIndex;\n    }\n\n    /**\n     * 根据 rowIndex 获取垂直偏移量\n     */\n    public getRowOffset(rowIndex: number) {\n        return this.getCellMetaData(rowIndex, AITableRowColumnType.row).offset;\n    }\n\n    /**\n     * 根据 columnIndex 获取水平偏移量\n     */\n    public getColumnOffset(columnIndex: number) {\n        return this.getCellMetaData(columnIndex, AITableRowColumnType.column).offset;\n    }\n\n    /**\n     * 冻结区域宽度\n     */\n    get frozenColumnWidth() {\n        return this.getColumnOffset(this.frozenColumnCount) - this.columnInitSize;\n    }\n\n    /**\n     * 根据 rowIndex, columnIndex 获取单元格坐标信息\n     */\n    public getCellRect(rowIndex: number, columnIndex: number) {\n        const { size: height, offset: y } = this.getCellMetaData(rowIndex, AITableRowColumnType.row);\n        const { size: width, offset: x } = this.getCellMetaData(columnIndex, AITableRowColumnType.column);\n        return {\n            x,\n            y,\n            width,\n            height\n        };\n    }\n}\n"]}
|
222
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"coordinate.js","sourceRoot":"","sources":["../../../../packages/grid/src/core/coordinate.ts"],"names":[],"mappings":"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","sourcesContent":["import { AITableCellMetaData, AITableCoordinate, AITableRowColumnType, AITableSizeMap } from '../types';\n\n/**\n * 用于构建 Canvas 基础坐标系，后续的绘制工作以此为基础\n */\nexport class Coordinate {\n    protected _rowHeight: number;\n    public rowCount: number;\n    public columnCount: number;\n    public container: HTMLDivElement;\n    public containerWidth: number;\n    public containerHeight: number;\n    // 用 index 映射 每一行的 高度\n    public rowIndicesSizeMap: AITableSizeMap = {};\n    // 用 index 映射 每一列 的 宽度\n    public columnIndicesSizeMap: AITableSizeMap = {};\n    // 除去表头和编号列真正单元格绘制的初始值 x\n    public rowInitSize: number;\n    // 除去表头和编号列真正单元格绘制的初始值 y\n    public columnInitSize: number;\n    // 行坐标集中最后一行的索引\n    public lastRowIndex = -1;\n    // 列坐标集中最后一列的索引\n    public lastColumnIndex = -1;\n    public rowMetaDataMap: Record<number, AITableCellMetaData> = {};\n    public columnMetaDataMap: Record<number, AITableCellMetaData> = {};\n    public frozenColumnCount: number;\n\n    constructor({\n        rowHeight,\n        rowCount,\n        columnCount,\n        container,\n        rowIndicesSizeMap = {},\n        columnIndicesSizeMap = {},\n        rowInitSize = 0,\n        columnInitSize = 0,\n        frozenColumnCount = 0\n    }: AITableCoordinate) {\n        this._rowHeight = rowHeight;\n        this.rowCount = rowCount;\n        this.columnCount = columnCount;\n        this.rowInitSize = rowInitSize;\n        this.columnInitSize = columnInitSize;\n        this.containerWidth = container.offsetWidth;\n        this.rowIndicesSizeMap = rowIndicesSizeMap;\n        this.columnIndicesSizeMap = columnIndicesSizeMap;\n        this.containerHeight = container.offsetHeight;\n        this.frozenColumnCount = frozenColumnCount;\n        this.container = container;\n    }\n\n    public get rowHeight() {\n        return this._rowHeight;\n    }\n\n    public set rowHeight(height: number) {\n        this._rowHeight = height;\n    }\n\n    /**\n     * 总宽度\n     */\n    public get totalWidth() {\n        const { offset, size } = this.getCellMetaData(this.columnCount - 1, AITableRowColumnType.column);\n        return offset + size;\n    }\n\n    /**\n     * 总高度\n     */\n    public get totalHeight() {\n        const { offset, size } = this.getCellMetaData(this.rowCount - 1, AITableRowColumnType.row);\n        return offset + size;\n    }\n\n    /**\n     * 根据 rowIndex 获取对应行高\n     */\n    public getRowHeight(index: number) {\n        return this.rowIndicesSizeMap[index] ?? this.rowHeight;\n    }\n\n    /**\n     * 根据 columnIndex 获取对应列宽\n     */\n    public getColumnWidth(index: number) {\n        return this.columnIndicesSizeMap[index];\n    }\n\n    /**\n     * 获取每个 cell 垂直/水平方向的坐标信息\n     */\n    protected getCellMetaData(index: number, itemType: AITableRowColumnType): AITableCellMetaData {\n        let cellMetadataMap, lastMeasuredIndex, offset;\n        const isColumnType = itemType === AITableRowColumnType.column;\n        if (isColumnType) {\n            offset = this.columnInitSize;\n            lastMeasuredIndex = this.lastColumnIndex;\n            cellMetadataMap = this.columnMetaDataMap;\n        } else {\n            offset = this.rowInitSize;\n            lastMeasuredIndex = this.lastRowIndex;\n            cellMetadataMap = this.rowMetaDataMap;\n        }\n        if (index > lastMeasuredIndex) {\n            if (lastMeasuredIndex >= 0) {\n                const itemMetadata = cellMetadataMap[lastMeasuredIndex];\n                offset = itemMetadata.offset + itemMetadata.size;\n            }\n\n            for (let i = lastMeasuredIndex + 1; i <= index; i++) {\n                const size = isColumnType ? this.columnIndicesSizeMap[i] : (this.rowIndicesSizeMap[i] ?? this.rowHeight);\n\n                cellMetadataMap[i] = {\n                    offset,\n                    size\n                };\n                offset += size;\n            }\n            if (isColumnType) {\n                this.lastColumnIndex = index;\n            } else {\n                this.lastRowIndex = index;\n            }\n        }\n        return cellMetadataMap[index] || { size: 0, offset: 0 };\n    }\n\n    /**\n     * 查找最近的单元格索引\n     * 性能较差，但无论如何都可以找到\n     */\n    private _findNearestCellIndex(index: number, offset: number, itemType: AITableRowColumnType) {\n        const itemCount = itemType === AITableRowColumnType.column ? this.columnCount : this.rowCount;\n        let interval = 1;\n\n        while (index < itemCount && this.getCellMetaData(index, itemType).offset < offset) {\n            index += interval;\n            interval *= 2;\n        }\n\n        return this._findNearestCellIndexByBinary(offset, Math.floor(index / 2), Math.min(index, itemCount - 1), itemType);\n    }\n\n    /**\n     * 二分法查找最近的单元格索引\n     * 性能更佳，但需要加载数据\n     */\n    private _findNearestCellIndexByBinary(offset: number, low: number, high: number, itemType: AITableRowColumnType) {\n        while (low <= high) {\n            const middle = low + Math.floor((high - low) / 2);\n            const currentOffset = this.getCellMetaData(middle, itemType).offset;\n\n            if (currentOffset === offset) {\n                return middle;\n            } else if (currentOffset < offset) {\n                low = middle + 1;\n            } else if (currentOffset > offset) {\n                high = middle - 1;\n            }\n        }\n        return low > -1 ? low - 1 : 0;\n    }\n\n    /**\n     * 根据偏移量查找最近的单元格索引\n     */\n    public findNearestCellIndex(offset: number, itemType: AITableRowColumnType) {\n        let lastIndex;\n        if (itemType === AITableRowColumnType.column) {\n            lastIndex = this.lastColumnIndex;\n        } else {\n            lastIndex = this.lastRowIndex;\n        }\n        const cellOffset = this.getCellMetaData(lastIndex, itemType).offset;\n        const lastMeasuredItemOffset = lastIndex > 0 ? cellOffset : 0;\n\n        if (lastMeasuredItemOffset >= offset) {\n            return this._findNearestCellIndexByBinary(offset, 0, lastIndex, itemType);\n        }\n        return this._findNearestCellIndex(Math.max(0, lastIndex), offset, itemType);\n    }\n\n    /**\n     * 根据垂直偏移量找到起始单元格的索引\n     */\n    public getRowStartIndex(offset: number) {\n        return this.findNearestCellIndex(offset, AITableRowColumnType.row);\n    }\n\n    /**\n     * 根据垂直起始单元格的索引查找结束单元格的索引\n     */\n    public getRowStopIndex(startIndex: number, scrollTop: number) {\n        const itemMetadata = this.getCellMetaData(startIndex, AITableRowColumnType.row);\n        const maxOffset = scrollTop + this.containerHeight;\n        let offset = itemMetadata.offset + itemMetadata.size;\n        let stopIndex = startIndex;\n\n        while (stopIndex < this.rowCount - 1 && offset < maxOffset) {\n            stopIndex++;\n            offset += this.getCellMetaData(stopIndex, AITableRowColumnType.row).size;\n        }\n        return stopIndex;\n    }\n\n    /**\n     * 根据水平偏移量找到起始单元格的索引\n     */\n    public getColumnStartIndex(offset: number) {\n        return this.findNearestCellIndex(offset, AITableRowColumnType.column);\n    }\n\n    /**\n     * 根据水平起始单元格的索引查找结束单元格的索引\n     */\n    public getColumnStopIndex(startIndex: number, scrollLeft: number) {\n        const itemMetadata = this.getCellMetaData(startIndex, AITableRowColumnType.column);\n        const maxOffset = scrollLeft + this.containerWidth;\n        let offset = itemMetadata.offset + itemMetadata.size;\n        let stopIndex = startIndex;\n\n        while (stopIndex < this.columnCount - 1 && offset < maxOffset) {\n            stopIndex++;\n            offset += this.getCellMetaData(stopIndex, AITableRowColumnType.column).size;\n        }\n        return stopIndex;\n    }\n\n    /**\n     * 根据 rowIndex 获取垂直偏移量\n     */\n    public getRowOffset(rowIndex: number) {\n        return this.getCellMetaData(rowIndex, AITableRowColumnType.row).offset;\n    }\n\n    /**\n     * 根据 columnIndex 获取水平偏移量\n     */\n    public getColumnOffset(columnIndex: number) {\n        return this.getCellMetaData(columnIndex, AITableRowColumnType.column).offset;\n    }\n\n    /**\n     * 冻结区域宽度\n     */\n    get frozenColumnWidth() {\n        return this.getColumnOffset(this.frozenColumnCount) - this.columnInitSize;\n    }\n\n    /**\n     * 根据 rowIndex, columnIndex 获取单元格坐标信息\n     */\n    public getCellRect(rowIndex: number, columnIndex: number) {\n        const { size: height, offset: y } = this.getCellMetaData(rowIndex, AITableRowColumnType.row);\n        const { size: width, offset: x } = this.getCellMetaData(columnIndex, AITableRowColumnType.column);\n        return {\n            x,\n            y,\n            width,\n            height\n        };\n    }\n}\n"]}
|
@@ -29,14 +29,14 @@ export const AITable = {
|
|
29
29
|
},
|
30
30
|
isCellVisible(aiTable, cell) {
|
31
31
|
const visibleRowIndexMap = aiTable.context.visibleRowsIndexMap();
|
32
|
-
const visibleColumnIndexMap = aiTable.context.
|
32
|
+
const visibleColumnIndexMap = aiTable.context.visibleColumnsIndexMap();
|
33
33
|
const [recordId, fieldId] = cell || [];
|
34
34
|
const isVisible = visibleRowIndexMap.has(recordId) && visibleColumnIndexMap.has(fieldId);
|
35
35
|
return isVisible;
|
36
36
|
},
|
37
37
|
getCellIndex(aiTable, cell) {
|
38
38
|
const visibleRowIndexMap = aiTable.context.visibleRowsIndexMap();
|
39
|
-
const visibleColumnIndexMap = aiTable.context.
|
39
|
+
const visibleColumnIndexMap = aiTable.context.visibleColumnsIndexMap();
|
40
40
|
if (AITable.isCellVisible(aiTable, cell)) {
|
41
41
|
const [recordId, fieldId] = cell;
|
42
42
|
return {
|
@@ -45,6 +45,13 @@ export const AITable = {
|
|
45
45
|
};
|
46
46
|
}
|
47
47
|
return null;
|
48
|
+
},
|
49
|
+
isFrozenColumn(aiTable, columnIndex) {
|
50
|
+
const frozenColumnCount = aiTable.context.frozenColumnCount();
|
51
|
+
if (columnIndex <= frozenColumnCount - 1) {
|
52
|
+
return true;
|
53
|
+
}
|
54
|
+
return false;
|
48
55
|
}
|
49
56
|
};
|
50
|
-
//# sourceMappingURL=data:application/json;base64,
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWktdGFibGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9ncmlkL3NyYy9jb3JlL3R5cGVzL2FpLXRhYmxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQW1CaEQsTUFBTSxDQUFDLE1BQU0sT0FBTyxHQUFHO0lBQ25CLFNBQVM7UUFDTCxPQUFPLE1BQU0sQ0FBQztJQUNsQixDQUFDO0lBQ0QsZ0JBQWdCLENBQUMsT0FBZ0I7UUFDN0IsT0FBTyxPQUFPLENBQUMsTUFBTSxFQUFFLENBQUMsTUFBTSxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUM3RCxDQUFDO0lBQ0QsY0FBYyxDQUFDLE9BQWdCO1FBQzNCLE9BQU8sT0FBTyxDQUFDLE9BQU8sRUFBRSxDQUFDO0lBQzdCLENBQUM7SUFDRCxhQUFhLENBQUMsT0FBZ0I7UUFDMUIsT0FBTyxPQUFPLENBQUMsU0FBUyxFQUFFLENBQUMsVUFBVSxDQUFDO0lBQzFDLENBQUM7SUFDRCxrQkFBa0IsQ0FBQyxPQUFnQjtRQUMvQixNQUFNLGVBQWUsR0FBRyxPQUFPLENBQUMsU0FBUyxFQUFFLENBQUMsZUFBZSxDQUFDO1FBQzVELE1BQU0sYUFBYSxHQUFHLE9BQU8sQ0FBQyxTQUFTLEVBQUUsQ0FBQyxhQUFhLENBQUM7UUFDeEQsSUFBSSxpQkFBaUIsR0FBYSxFQUFFLENBQUM7UUFDckMsSUFBSSxlQUFlLENBQUMsSUFBSSxHQUFHLENBQUMsRUFBRSxDQUFDO1lBQzNCLGlCQUFpQixHQUFHLENBQUMsR0FBRyxlQUFlLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQztRQUNwRCxDQUFDO2FBQU0sSUFBSSxhQUFhLENBQUMsSUFBSSxHQUFHLENBQUMsRUFBRSxDQUFDO1lBQ2hDLGlCQUFpQixHQUFHLENBQUMsR0FBRyxhQUFhLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUM3RSxDQUFDO2FBQU0sQ0FBQztZQUNKLGlCQUFpQixHQUFHLEVBQUUsQ0FBQztRQUMzQixDQUFDO1FBQ0QsT0FBTyxpQkFBaUIsQ0FBQztJQUM3QixDQUFDO0lBQ0QsYUFBYSxDQUFDLE9BQWdCLEVBQUUsSUFBeUI7UUFDckQsTUFBTSxrQkFBa0IsR0FBRyxPQUFPLENBQUMsT0FBUSxDQUFDLG1CQUFtQixFQUFFLENBQUM7UUFDbEUsTUFBTSxxQkFBcUIsR0FBRyxPQUFPLENBQUMsT0FBUSxDQUFDLHNCQUFzQixFQUFFLENBQUM7UUFDeEUsTUFBTSxDQUFDLFFBQVEsRUFBRSxPQUFPLENBQUMsR0FBRyxJQUFJLElBQUksRUFBRSxDQUFDO1FBQ3ZDLE1BQU0sU0FBUyxHQUFHLGtCQUFtQixDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsSUFBSSxxQkFBcUIsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDMUYsT0FBTyxTQUFTLENBQUM7SUFDckIsQ0FBQztJQUNELFlBQVksQ0FBQyxPQUFnQixFQUFFLElBQXlCO1FBQ3BELE1BQU0sa0JBQWtCLEdBQUcsT0FBTyxDQUFDLE9BQVEsQ0FBQyxtQkFBbUIsRUFBRSxDQUFDO1FBQ2xFLE1BQU0scUJBQXFCLEdBQUcsT0FBTyxDQUFDLE9BQVEsQ0FBQyxzQkFBc0IsRUFBRSxDQUFDO1FBQ3hFLElBQUksT0FBTyxDQUFDLGFBQWEsQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLEVBQUUsQ0FBQztZQUN2QyxNQUFNLENBQUMsUUFBUSxFQUFFLE9BQU8sQ0FBQyxHQUFHLElBQUksQ0FBQztZQUNqQyxPQUFPO2dCQUNILFFBQVEsRUFBRSxrQkFBbUIsQ0FBQyxHQUFHLENBQUMsUUFBUSxDQUFFO2dCQUM1QyxXQUFXLEVBQUUscUJBQXFCLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBRTthQUNuRCxDQUFDO1FBQ04sQ0FBQztRQUNELE9BQU8sSUFBSSxDQUFDO0lBQ2hCLENBQUM7SUFDRCxjQUFjLENBQUMsT0FBZ0IsRUFBRSxXQUFtQjtRQUNoRCxNQUFNLGlCQUFpQixHQUFHLE9BQU8sQ0FBQyxPQUFRLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztRQUMvRCxJQUFJLFdBQVcsSUFBSSxpQkFBaUIsR0FBRyxDQUFDLEVBQUUsQ0FBQztZQUN2QyxPQUFPLElBQUksQ0FBQztRQUNoQixDQUFDO1FBQ0QsT0FBTyxLQUFLLENBQUM7SUFDakIsQ0FBQztDQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTaWduYWwsIFdyaXRhYmxlU2lnbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb2xvcnMgfSBmcm9tICcuLi8uLi9jb25zdGFudHMvY29sb3JzJztcbmltcG9ydCB7IEFJVGFibGVTZWxlY3Rpb24gfSBmcm9tICcuLi8uLi90eXBlcyc7XG5pbXBvcnQgeyBSZW5kZXJlckNvbnRleHQgfSBmcm9tICcuLi9jb250ZXh0JztcbmltcG9ydCB7IEFJUmVjb3JkRmllbGRJZFBhdGgsIEFJVGFibGVGaWVsZCwgQUlUYWJsZUZpZWxkcywgQUlUYWJsZVJlY29yZCwgQUlUYWJsZVJlY29yZHMgfSBmcm9tICcuL2NvcmUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIEFJVGFibGUge1xuICAgIHJlY29yZHM6IFdyaXRhYmxlU2lnbmFsPEFJVGFibGVSZWNvcmRzPjtcbiAgICBmaWVsZHM6IFdyaXRhYmxlU2lnbmFsPEFJVGFibGVGaWVsZHM+O1xuICAgIGNvbnRleHQ/OiBSZW5kZXJlckNvbnRleHQ7XG4gICAgc2VsZWN0aW9uOiBXcml0YWJsZVNpZ25hbDxBSVRhYmxlU2VsZWN0aW9uPjtcbiAgICBrZXl3b3Jkc01hdGNoZWRDZWxsczogV3JpdGFibGVTaWduYWw8U2V0PHN0cmluZz4+OyAvLyBbYCR7cmVjb3JkSWR9OiR7ZmllbGRJZH1gXVxuICAgIHJlY29yZHNNYXA6IFNpZ25hbDx7IFtrZXk6IHN0cmluZ106IEFJVGFibGVSZWNvcmQgfT47XG4gICAgZmllbGRzTWFwOiBTaWduYWw8eyBba2V5OiBzdHJpbmddOiBBSVRhYmxlRmllbGQgfT47XG4gICAgcmVjb3Jkc1dpbGxIaWRkZW46IFdyaXRhYmxlU2lnbmFsPHN0cmluZ1tdPjtcbiAgICByZWNvcmRzV2lsbE1vdmU6IFdyaXRhYmxlU2lnbmFsPHN0cmluZ1tdPjtcbn1cblxuZXhwb3J0IHR5cGUgQUlQbHVnaW4gPSAoYWlUYWJsZTogQUlUYWJsZSkgPT4gQUlUYWJsZTtcblxuZXhwb3J0IGNvbnN0IEFJVGFibGUgPSB7XG4gICAgZ2V0Q29sb3JzKCkge1xuICAgICAgICByZXR1cm4gQ29sb3JzO1xuICAgIH0sXG4gICAgZ2V0VmlzaWJsZUZpZWxkcyhhaVRhYmxlOiBBSVRhYmxlKTogQUlUYWJsZUZpZWxkcyB7XG4gICAgICAgIHJldHVybiBhaVRhYmxlLmZpZWxkcygpLmZpbHRlcigoZmllbGQpID0+ICFmaWVsZC5oaWRkZW4pO1xuICAgIH0sXG4gICAgZ2V0VmlzaWJsZVJvd3MoYWlUYWJsZTogQUlUYWJsZSk6IEFJVGFibGVSZWNvcmRzIHtcbiAgICAgICAgcmV0dXJuIGFpVGFibGUucmVjb3JkcygpO1xuICAgIH0sXG4gICAgZ2V0QWN0aXZlQ2VsbChhaVRhYmxlOiBBSVRhYmxlKTogQUlSZWNvcmRGaWVsZElkUGF0aCB8IG51bGwge1xuICAgICAgICByZXR1cm4gYWlUYWJsZS5zZWxlY3Rpb24oKS5hY3RpdmVDZWxsO1xuICAgIH0sXG4gICAgZ2V0QWN0aXZlUmVjb3JkSWRzKGFpVGFibGU6IEFJVGFibGUpOiBzdHJpbmdbXSB7XG4gICAgICAgIGNvbnN0IHNlbGVjdGVkUmVjb3JkcyA9IGFpVGFibGUuc2VsZWN0aW9uKCkuc2VsZWN0ZWRSZWNvcmRzO1xuICAgICAgICBjb25zdCBzZWxlY3RlZENlbGxzID0gYWlUYWJsZS5zZWxlY3Rpb24oKS5zZWxlY3RlZENlbGxzO1xuICAgICAgICBsZXQgc2VsZWN0ZWRSZWNvcmRJZHM6IHN0cmluZ1tdID0gW107XG4gICAgICAgIGlmIChzZWxlY3RlZFJlY29yZHMuc2l6ZSA+IDApIHtcbiAgICAgICAgICAgIHNlbGVjdGVkUmVjb3JkSWRzID0gWy4uLnNlbGVjdGVkUmVjb3Jkcy5rZXlzKCldO1xuICAgICAgICB9IGVsc2UgaWYgKHNlbGVjdGVkQ2VsbHMuc2l6ZSA+IDApIHtcbiAgICAgICAgICAgIHNlbGVjdGVkUmVjb3JkSWRzID0gWy4uLnNlbGVjdGVkQ2VsbHNdLm1hcCgoaXRlbSkgPT4gaXRlbS5zcGxpdCgnOicpWzBdKTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHNlbGVjdGVkUmVjb3JkSWRzID0gW107XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIHNlbGVjdGVkUmVjb3JkSWRzO1xuICAgIH0sXG4gICAgaXNDZWxsVmlzaWJsZShhaVRhYmxlOiBBSVRhYmxlLCBjZWxsOiBBSVJlY29yZEZpZWxkSWRQYXRoKTogYm9vbGVhbiB7XG4gICAgICAgIGNvbnN0IHZpc2libGVSb3dJbmRleE1hcCA9IGFpVGFibGUuY29udGV4dCEudmlzaWJsZVJvd3NJbmRleE1hcCgpO1xuICAgICAgICBjb25zdCB2aXNpYmxlQ29sdW1uSW5kZXhNYXAgPSBhaVRhYmxlLmNvbnRleHQhLnZpc2libGVDb2x1bW5zSW5kZXhNYXAoKTtcbiAgICAgICAgY29uc3QgW3JlY29yZElkLCBmaWVsZElkXSA9IGNlbGwgfHwgW107XG4gICAgICAgIGNvbnN0IGlzVmlzaWJsZSA9IHZpc2libGVSb3dJbmRleE1hcCEuaGFzKHJlY29yZElkKSAmJiB2aXNpYmxlQ29sdW1uSW5kZXhNYXAuaGFzKGZpZWxkSWQpO1xuICAgICAgICByZXR1cm4gaXNWaXNpYmxlO1xuICAgIH0sXG4gICAgZ2V0Q2VsbEluZGV4KGFpVGFibGU6IEFJVGFibGUsIGNlbGw6IEFJUmVjb3JkRmllbGRJZFBhdGgpOiB7IHJvd0luZGV4OiBudW1iZXI7IGNvbHVtbkluZGV4OiBudW1iZXIgfSB8IG51bGwge1xuICAgICAgICBjb25zdCB2aXNpYmxlUm93SW5kZXhNYXAgPSBhaVRhYmxlLmNvbnRleHQhLnZpc2libGVSb3dzSW5kZXhNYXAoKTtcbiAgICAgICAgY29uc3QgdmlzaWJsZUNvbHVtbkluZGV4TWFwID0gYWlUYWJsZS5jb250ZXh0IS52aXNpYmxlQ29sdW1uc0luZGV4TWFwKCk7XG4gICAgICAgIGlmIChBSVRhYmxlLmlzQ2VsbFZpc2libGUoYWlUYWJsZSwgY2VsbCkpIHtcbiAgICAgICAgICAgIGNvbnN0IFtyZWNvcmRJZCwgZmllbGRJZF0gPSBjZWxsO1xuICAgICAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgICAgICByb3dJbmRleDogdmlzaWJsZVJvd0luZGV4TWFwIS5nZXQocmVjb3JkSWQpISxcbiAgICAgICAgICAgICAgICBjb2x1bW5JbmRleDogdmlzaWJsZUNvbHVtbkluZGV4TWFwLmdldChmaWVsZElkKSFcbiAgICAgICAgICAgIH07XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIG51bGw7XG4gICAgfSxcbiAgICBpc0Zyb3plbkNvbHVtbihhaVRhYmxlOiBBSVRhYmxlLCBjb2x1bW5JbmRleDogbnVtYmVyKSB7XG4gICAgICAgIGNvbnN0IGZyb3plbkNvbHVtbkNvdW50ID0gYWlUYWJsZS5jb250ZXh0IS5mcm96ZW5Db2x1bW5Db3VudCgpO1xuICAgICAgICBpZiAoY29sdW1uSW5kZXggPD0gZnJvemVuQ29sdW1uQ291bnQgLSAxKSB7XG4gICAgICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxufTtcbiJdfQ==
|
@@ -23,9 +23,8 @@ export function createAITable(records, fields) {
|
|
23
23
|
}, {});
|
24
24
|
}),
|
25
25
|
recordsWillHidden: signal([]),
|
26
|
-
recordsWillMove: signal([])
|
27
|
-
references: signal({ members: {} })
|
26
|
+
recordsWillMove: signal([])
|
28
27
|
};
|
29
28
|
return aiTable;
|
30
29
|
}
|
31
|
-
//# sourceMappingURL=data:application/json;base64,
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZ3JpZC9zcmMvY29yZS91dGlscy9jb21tb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFrQixRQUFRLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBR2pFLE1BQU0sVUFBVSxhQUFhLENBQUMsT0FBdUMsRUFBRSxNQUFxQztJQUN4RyxNQUFNLE9BQU8sR0FBWTtRQUNyQixPQUFPO1FBQ1AsTUFBTTtRQUNOLFNBQVMsRUFBRSxNQUFNLENBQUM7WUFDZCxlQUFlLEVBQUUsSUFBSSxHQUFHLEVBQUU7WUFDMUIsY0FBYyxFQUFFLElBQUksR0FBRyxFQUFFO1lBQ3pCLGFBQWEsRUFBRSxJQUFJLEdBQUcsRUFBRTtZQUN4QixVQUFVLEVBQUUsSUFBSTtTQUNuQixDQUFDO1FBQ0Ysb0JBQW9CLEVBQUUsTUFBTSxDQUFDLElBQUksR0FBRyxFQUFFLENBQUM7UUFDdkMsVUFBVSxFQUFFLFFBQVEsQ0FBQyxHQUFHLEVBQUU7WUFDdEIsT0FBTyxPQUFPLEVBQUUsQ0FBQyxNQUFNLENBQ25CLENBQUMsTUFBTSxFQUFFLElBQUksRUFBRSxFQUFFO2dCQUNiLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsSUFBSSxDQUFDO2dCQUN4QixPQUFPLE1BQU0sQ0FBQztZQUNsQixDQUFDLEVBQ0QsRUFBc0MsQ0FDekMsQ0FBQztRQUNOLENBQUMsQ0FBQztRQUNGLFNBQVMsRUFBRSxRQUFRLENBQUMsR0FBRyxFQUFFO1lBQ3JCLE9BQU8sTUFBTSxFQUFFLENBQUMsTUFBTSxDQUNsQixDQUFDLE1BQU0sRUFBRSxJQUFJLEVBQUUsRUFBRTtnQkFDYixNQUFNLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBQztnQkFDeEIsT0FBTyxNQUFNLENBQUM7WUFDbEIsQ0FBQyxFQUNELEVBQXFDLENBQ3hDLENBQUM7UUFDTixDQUFDLENBQUM7UUFDRixpQkFBaUIsRUFBRSxNQUFNLENBQUMsRUFBRSxDQUFDO1FBQzdCLGVBQWUsRUFBRSxNQUFNLENBQUMsRUFBRSxDQUFDO0tBQzlCLENBQUM7SUFDRixPQUFPLE9BQU8sQ0FBQztBQUNuQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgV3JpdGFibGVTaWduYWwsIGNvbXB1dGVkLCBzaWduYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFJVGFibGUsIEFJVGFibGVGaWVsZCwgQUlUYWJsZUZpZWxkcywgQUlUYWJsZVJlY29yZCwgQUlUYWJsZVJlY29yZHMgfSBmcm9tICcuLi90eXBlcyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVBSVRhYmxlKHJlY29yZHM6IFdyaXRhYmxlU2lnbmFsPEFJVGFibGVSZWNvcmRzPiwgZmllbGRzOiBXcml0YWJsZVNpZ25hbDxBSVRhYmxlRmllbGRzPik6IEFJVGFibGUge1xuICAgIGNvbnN0IGFpVGFibGU6IEFJVGFibGUgPSB7XG4gICAgICAgIHJlY29yZHMsXG4gICAgICAgIGZpZWxkcyxcbiAgICAgICAgc2VsZWN0aW9uOiBzaWduYWwoe1xuICAgICAgICAgICAgc2VsZWN0ZWRSZWNvcmRzOiBuZXcgU2V0KCksXG4gICAgICAgICAgICBzZWxlY3RlZEZpZWxkczogbmV3IFNldCgpLFxuICAgICAgICAgICAgc2VsZWN0ZWRDZWxsczogbmV3IFNldCgpLFxuICAgICAgICAgICAgYWN0aXZlQ2VsbDogbnVsbFxuICAgICAgICB9KSxcbiAgICAgICAga2V5d29yZHNNYXRjaGVkQ2VsbHM6IHNpZ25hbChuZXcgU2V0KCkpLFxuICAgICAgICByZWNvcmRzTWFwOiBjb21wdXRlZCgoKSA9PiB7XG4gICAgICAgICAgICByZXR1cm4gcmVjb3JkcygpLnJlZHVjZShcbiAgICAgICAgICAgICAgICAob2JqZWN0LCBpdGVtKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIG9iamVjdFtpdGVtLl9pZF0gPSBpdGVtO1xuICAgICAgICAgICAgICAgICAgICByZXR1cm4gb2JqZWN0O1xuICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAge30gYXMgeyBba2V5OiBzdHJpbmddOiBBSVRhYmxlUmVjb3JkIH1cbiAgICAgICAgICAgICk7XG4gICAgICAgIH0pLFxuICAgICAgICBmaWVsZHNNYXA6IGNvbXB1dGVkKCgpID0+IHtcbiAgICAgICAgICAgIHJldHVybiBmaWVsZHMoKS5yZWR1Y2UoXG4gICAgICAgICAgICAgICAgKG9iamVjdCwgaXRlbSkgPT4ge1xuICAgICAgICAgICAgICAgICAgICBvYmplY3RbaXRlbS5faWRdID0gaXRlbTtcbiAgICAgICAgICAgICAgICAgICAgcmV0dXJuIG9iamVjdDtcbiAgICAgICAgICAgICAgICB9LFxuICAgICAgICAgICAgICAgIHt9IGFzIHsgW2tleTogc3RyaW5nXTogQUlUYWJsZUZpZWxkIH1cbiAgICAgICAgICAgICk7XG4gICAgICAgIH0pLFxuICAgICAgICByZWNvcmRzV2lsbEhpZGRlbjogc2lnbmFsKFtdKSxcbiAgICAgICAgcmVjb3Jkc1dpbGxNb3ZlOiBzaWduYWwoW10pXG4gICAgfTtcbiAgICByZXR1cm4gYWlUYWJsZTtcbn1cbiJdfQ==
|