@ai-table/grid 0.0.33 → 0.0.35

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.
@@ -3,7 +3,7 @@ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
3
3
  import { ThyPopover } from 'ngx-tethys/popover';
4
4
  import { debounceTime, fromEvent, Subject } from 'rxjs';
5
5
  import { GRID_CELL_EDITOR_MAP } from '../constants';
6
- import { AITable } from '../core';
6
+ import { AITable, AITableFieldType } from '../core';
7
7
  import { getCellHorizontalPosition, getEditorBoxOffset, getEditorSpace, getHoverEditorBoxOffset, getHoverEditorSpace } from '../utils';
8
8
  import { AITableContextMenu } from '../components/context-menu/context-menu.component';
9
9
  import * as i0 from "@angular/core";
@@ -157,6 +157,10 @@ export class AITableGridEventService {
157
157
  });
158
158
  if (this.cellEditorPopoverRef) {
159
159
  const wheelEvent = fromEvent(this.cellEditorPopoverRef.componentInstance.elementRef.nativeElement, 'wheel').subscribe((event) => {
160
+ const field = aiTable.fieldsMap()[fieldId];
161
+ if (field.type === AITableFieldType.text || field.type === AITableFieldType.richText) {
162
+ return;
163
+ }
160
164
  event.preventDefault();
161
165
  this.aiTable.context?.scrollAction({
162
166
  deltaX: event.deltaX,
@@ -225,4 +229,4 @@ export class AITableGridEventService {
225
229
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableGridEventService, decorators: [{
226
230
  type: Injectable
227
231
  }] });
228
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"event.service.js","sourceRoot":"","sources":["../../../../packages/grid/src/services/event.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { FlexibleConnectedPositionStrategy } from '@angular/cdk/overlay';\nimport { DestroyRef, inject, Injectable } from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { ThyAbstractInternalOverlayRef } from 'ngx-tethys/core';\nimport { ThyPopover, ThyPopoverRef } from 'ngx-tethys/popover';\nimport { debounceTime, fromEvent, Subject } from 'rxjs';\nimport { AbstractEditCellEditor } from '../components';\nimport { GRID_CELL_EDITOR_MAP } from '../constants';\nimport { AIRecordFieldIdPath, AITable, AITableFieldType } from '../core';\nimport { AITableContextMenuOptions, AITableGridCellRenderSchema, AITableOpenEditOptions } from '../types';\nimport { getCellHorizontalPosition, getEditorBoxOffset, getEditorSpace, getHoverEditorBoxOffset, getHoverEditorSpace } from '../utils';\nimport { AITableContextMenu } from '../components/context-menu/context-menu.component';\n\n@Injectable()\nexport class AITableGridEventService {\n    aiTable!: AITable;\n\n    aiFieldRenderers?: Partial<Record<AITableFieldType, AITableGridCellRenderSchema>>;\n\n    dblClickEvent$ = new Subject<MouseEvent>();\n\n    mousedownEvent$ = new Subject<MouseEvent>();\n\n    mouseoverEvent$ = new Subject<MouseEvent>();\n\n    globalMouseoverEvent$ = new Subject<MouseEvent>();\n\n    globalMousedownEvent$ = new Subject<MouseEvent>();\n\n    private cellEditorPopoverRef!: ThyPopoverRef<AbstractEditCellEditor<any>> | null;\n\n    private destroyRef = inject(DestroyRef);\n\n    private thyPopover = inject(ThyPopover);\n\n    initialize(aiTable: AITable, aiFieldRenderers?: Partial<Record<AITableFieldType, AITableGridCellRenderSchema>>) {\n        this.aiTable = aiTable;\n        this.aiFieldRenderers = aiFieldRenderers;\n    }\n\n    registerEvents(element: HTMLElement) {\n        fromEvent<MouseEvent>(element, 'dblclick', { passive: true })\n            .pipe(takeUntilDestroyed(this.destroyRef))\n            .subscribe((event) => {\n                this.dblClickEvent$.next(event);\n            });\n\n        fromEvent<MouseEvent>(element, 'mouseover', { passive: true })\n            .pipe(debounceTime(80), takeUntilDestroyed(this.destroyRef))\n            .subscribe((event) => {\n                this.mouseoverEvent$.next(event);\n            });\n\n        fromEvent<MouseEvent>(document, 'mouseover', { passive: true })\n            .pipe(takeUntilDestroyed(this.destroyRef))\n            .subscribe((event) => {\n                this.globalMouseoverEvent$.next(event);\n            });\n\n        fromEvent<MouseEvent>(element, 'mousedown', { passive: true })\n            .pipe(takeUntilDestroyed(this.destroyRef))\n            .subscribe((event) => {\n                this.mousedownEvent$.next(event);\n            });\n\n        fromEvent<MouseEvent>(document, 'mousedown', { passive: true })\n            .pipe(takeUntilDestroyed(this.destroyRef))\n            .subscribe((event) => {\n                this.globalMousedownEvent$.next(event as MouseEvent);\n            });\n    }\n\n    private getEditorComponent(type: AITableFieldType) {\n        const filedRenderSchema = this.aiFieldRenderers && this.aiFieldRenderers[type];\n        if (filedRenderSchema && filedRenderSchema.editor) {\n            return filedRenderSchema.editor;\n        }\n        return GRID_CELL_EDITOR_MAP[type];\n    }\n\n    openEdit(cellDom: HTMLElement) {\n        const { x, y, width, height } = cellDom.getBoundingClientRect();\n        const fieldId = cellDom.getAttribute('fieldId')!;\n        const recordId = cellDom.getAttribute('recordId')!;\n        const component = this.getEditorComponent(this.aiTable.fieldsMap()[fieldId].type);\n        const ref = this.thyPopover.open(component, {\n            origin: cellDom,\n            originPosition: {\n                x: x - 1,\n                y: y + 1,\n                width: width + 2,\n                height: height + 2\n            },\n            width: width + 1 + 'px',\n            height: height + 2 + 'px',\n            placement: 'top',\n            offset: -(height + 4),\n            minWidth: width,\n            initialState: {\n                fieldId: fieldId,\n                recordId: recordId,\n                aiTable: this.aiTable\n            },\n            panelClass: 'grid-cell-editor',\n            outsideClosable: false,\n            hasBackdrop: false,\n            manualClosure: true,\n            animationDisabled: true,\n            autoAdaptive: true\n        });\n        return ref;\n    }\n\n    getOriginPosition(aiTable: AITable, options: AITableOpenEditOptions) {\n        const { container, coordinate, recordId, fieldId, isHoverEdit } = options;\n        const { scrollState } = aiTable.context!;\n        const { rowHeight, columnCount } = coordinate;\n        const cell: AIRecordFieldIdPath = [recordId, fieldId];\n        const { rowIndex, columnIndex } = AITable.getCellIndex(aiTable, cell)!;\n        const originX = coordinate.getColumnOffset(columnIndex);\n        const originY = coordinate.getRowOffset(rowIndex);\n        const columnWidth = coordinate.getColumnWidth(columnIndex);\n        const { width: originWidth, offset: originOffset } = getCellHorizontalPosition({\n            columnWidth,\n            columnIndex,\n            columnCount\n        });\n        const originRect = container!.getBoundingClientRect();\n        const isFrozenColumn = AITable.isFrozenColumn(aiTable, columnIndex);\n        const scrollLeft = isFrozenColumn ? 0 : scrollState().scrollLeft;\n        const scrollTop = scrollState().scrollTop;\n        const originPosition = {\n            x: originX + originOffset - scrollLeft + originRect.x,\n            y: originY - scrollTop + originRect.y,\n            width: originWidth,\n            height: rowHeight\n        };\n        let x = originPosition.x + getEditorBoxOffset();\n        let y = originPosition.y + getEditorBoxOffset();\n        let width = getEditorSpace(originPosition.width);\n        let height = getEditorSpace(originPosition.height);\n        // hover 编辑组件无边框\n        if (isHoverEdit) {\n            x = originPosition.x + getHoverEditorBoxOffset();\n            y = originPosition.y + getHoverEditorBoxOffset();\n            width = getHoverEditorSpace(originPosition.width);\n            height = getHoverEditorSpace(originPosition.height);\n        }\n        return {\n            ...originPosition,\n            x: x,\n            y: y,\n            width: width,\n            height: height\n        };\n    }\n\n    openCellEditor(aiTable: AITable, options: AITableOpenEditOptions) {\n        const { container, recordId, fieldId, isHoverEdit, references } = options;\n        const component = this.getEditorComponent(this.aiTable.fieldsMap()[fieldId].type);\n        const offsetOriginPosition = this.getOriginPosition(aiTable, options);\n        this.cellEditorPopoverRef = this.thyPopover.open(component, {\n            origin: container!,\n            originPosition: offsetOriginPosition,\n            width: offsetOriginPosition.width + 'px',\n            height: offsetOriginPosition.height + 'px',\n            minWidth: offsetOriginPosition.width + 'px',\n            placement: 'bottom',\n            offset: -offsetOriginPosition.height,\n            initialState: {\n                fieldId: fieldId,\n                recordId: recordId,\n                references,\n                aiTable: aiTable\n            },\n            panelClass: 'grid-cell-editor',\n            outsideClosable: false,\n            hasBackdrop: false,\n            manualClosure: true,\n            animationDisabled: true,\n            autoAdaptive: true\n        });\n\n        if (this.cellEditorPopoverRef) {\n            const wheelEvent = fromEvent<WheelEvent>(\n                this.cellEditorPopoverRef.componentInstance.elementRef.nativeElement,\n                'wheel'\n            ).subscribe((event: WheelEvent) => {\n                event.preventDefault();\n                this.aiTable.context?.scrollAction({\n                    deltaX: event.deltaX,\n                    deltaY: event.deltaY,\n                    shiftKey: event.shiftKey,\n                    callback: () => {\n                        const originPosition = this.getOriginPosition(aiTable, options);\n                        const positionStrategy = (this.cellEditorPopoverRef as ThyAbstractInternalOverlayRef<any, any, any>)\n                            .getOverlayRef()\n                            .getConfig().positionStrategy as FlexibleConnectedPositionStrategy;\n                        positionStrategy.setOrigin(originPosition);\n                        positionStrategy.apply();\n                    }\n                });\n            });\n            this.cellEditorPopoverRef.afterClosed().subscribe(() => {\n                wheelEvent.unsubscribe();\n                this.cellEditorPopoverRef = null;\n            });\n            (this.cellEditorPopoverRef.componentInstance as AbstractEditCellEditor<any>).updateFieldValue.subscribe((value) => {\n                options.updateFieldValue(value);\n            });\n        }\n        return this.cellEditorPopoverRef;\n    }\n\n    closeCellEditor() {\n        if (this.cellEditorPopoverRef) {\n            this.cellEditorPopoverRef.close();\n            this.cellEditorPopoverRef = null;\n        }\n    }\n\n    getCurrentEditCell() {\n        if (this.cellEditorPopoverRef) {\n            const recordId = this.cellEditorPopoverRef.componentInstance?.recordId;\n            const fieldId = this.cellEditorPopoverRef.componentInstance?.fieldId;\n\n            if (recordId && fieldId) {\n                return {\n                    recordId,\n                    fieldId\n                };\n            }\n            return null;\n        }\n        return null;\n    }\n\n    openContextMenu(aiTable: AITable, options: AITableContextMenuOptions) {\n        const { origin, position, menuItems, targetName, viewContainerRef } = options;\n        const ref = this.thyPopover.open(AITableContextMenu, {\n            origin: origin as HTMLElement,\n            originPosition: position,\n            placement: 'bottomLeft',\n            insideClosable: true,\n            viewContainerRef,\n            initialState: {\n                aiTable,\n                menuItems,\n                targetName,\n                position\n            }\n        });\n        return ref;\n    }\n}\n"]}
232
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"event.service.js","sourceRoot":"","sources":["../../../../packages/grid/src/services/event.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { FlexibleConnectedPositionStrategy } from '@angular/cdk/overlay';\nimport { DestroyRef, inject, Injectable } from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { ThyAbstractInternalOverlayRef } from 'ngx-tethys/core';\nimport { ThyPopover, ThyPopoverRef } from 'ngx-tethys/popover';\nimport { debounceTime, fromEvent, Subject } from 'rxjs';\nimport { AbstractEditCellEditor } from '../components';\nimport { GRID_CELL_EDITOR_MAP } from '../constants';\nimport { AIRecordFieldIdPath, AITable, AITableFieldType } from '../core';\nimport { AITableContextMenuOptions, AITableGridCellRenderSchema, AITableOpenEditOptions } from '../types';\nimport { getCellHorizontalPosition, getEditorBoxOffset, getEditorSpace, getHoverEditorBoxOffset, getHoverEditorSpace } from '../utils';\nimport { AITableContextMenu } from '../components/context-menu/context-menu.component';\n\n@Injectable()\nexport class AITableGridEventService {\n    aiTable!: AITable;\n\n    aiFieldRenderers?: Partial<Record<AITableFieldType, AITableGridCellRenderSchema>>;\n\n    dblClickEvent$ = new Subject<MouseEvent>();\n\n    mousedownEvent$ = new Subject<MouseEvent>();\n\n    mouseoverEvent$ = new Subject<MouseEvent>();\n\n    globalMouseoverEvent$ = new Subject<MouseEvent>();\n\n    globalMousedownEvent$ = new Subject<MouseEvent>();\n\n    private cellEditorPopoverRef!: ThyPopoverRef<AbstractEditCellEditor<any>> | null;\n\n    private destroyRef = inject(DestroyRef);\n\n    private thyPopover = inject(ThyPopover);\n\n    initialize(aiTable: AITable, aiFieldRenderers?: Partial<Record<AITableFieldType, AITableGridCellRenderSchema>>) {\n        this.aiTable = aiTable;\n        this.aiFieldRenderers = aiFieldRenderers;\n    }\n\n    registerEvents(element: HTMLElement) {\n        fromEvent<MouseEvent>(element, 'dblclick', { passive: true })\n            .pipe(takeUntilDestroyed(this.destroyRef))\n            .subscribe((event) => {\n                this.dblClickEvent$.next(event);\n            });\n\n        fromEvent<MouseEvent>(element, 'mouseover', { passive: true })\n            .pipe(debounceTime(80), takeUntilDestroyed(this.destroyRef))\n            .subscribe((event) => {\n                this.mouseoverEvent$.next(event);\n            });\n\n        fromEvent<MouseEvent>(document, 'mouseover', { passive: true })\n            .pipe(takeUntilDestroyed(this.destroyRef))\n            .subscribe((event) => {\n                this.globalMouseoverEvent$.next(event);\n            });\n\n        fromEvent<MouseEvent>(element, 'mousedown', { passive: true })\n            .pipe(takeUntilDestroyed(this.destroyRef))\n            .subscribe((event) => {\n                this.mousedownEvent$.next(event);\n            });\n\n        fromEvent<MouseEvent>(document, 'mousedown', { passive: true })\n            .pipe(takeUntilDestroyed(this.destroyRef))\n            .subscribe((event) => {\n                this.globalMousedownEvent$.next(event as MouseEvent);\n            });\n    }\n\n    private getEditorComponent(type: AITableFieldType) {\n        const filedRenderSchema = this.aiFieldRenderers && this.aiFieldRenderers[type];\n        if (filedRenderSchema && filedRenderSchema.editor) {\n            return filedRenderSchema.editor;\n        }\n        return GRID_CELL_EDITOR_MAP[type];\n    }\n\n    openEdit(cellDom: HTMLElement) {\n        const { x, y, width, height } = cellDom.getBoundingClientRect();\n        const fieldId = cellDom.getAttribute('fieldId')!;\n        const recordId = cellDom.getAttribute('recordId')!;\n        const component = this.getEditorComponent(this.aiTable.fieldsMap()[fieldId].type);\n        const ref = this.thyPopover.open(component, {\n            origin: cellDom,\n            originPosition: {\n                x: x - 1,\n                y: y + 1,\n                width: width + 2,\n                height: height + 2\n            },\n            width: width + 1 + 'px',\n            height: height + 2 + 'px',\n            placement: 'top',\n            offset: -(height + 4),\n            minWidth: width,\n            initialState: {\n                fieldId: fieldId,\n                recordId: recordId,\n                aiTable: this.aiTable\n            },\n            panelClass: 'grid-cell-editor',\n            outsideClosable: false,\n            hasBackdrop: false,\n            manualClosure: true,\n            animationDisabled: true,\n            autoAdaptive: true\n        });\n        return ref;\n    }\n\n    getOriginPosition(aiTable: AITable, options: AITableOpenEditOptions) {\n        const { container, coordinate, recordId, fieldId, isHoverEdit } = options;\n        const { scrollState } = aiTable.context!;\n        const { rowHeight, columnCount } = coordinate;\n        const cell: AIRecordFieldIdPath = [recordId, fieldId];\n        const { rowIndex, columnIndex } = AITable.getCellIndex(aiTable, cell)!;\n        const originX = coordinate.getColumnOffset(columnIndex);\n        const originY = coordinate.getRowOffset(rowIndex);\n        const columnWidth = coordinate.getColumnWidth(columnIndex);\n        const { width: originWidth, offset: originOffset } = getCellHorizontalPosition({\n            columnWidth,\n            columnIndex,\n            columnCount\n        });\n        const originRect = container!.getBoundingClientRect();\n        const isFrozenColumn = AITable.isFrozenColumn(aiTable, columnIndex);\n        const scrollLeft = isFrozenColumn ? 0 : scrollState().scrollLeft;\n        const scrollTop = scrollState().scrollTop;\n        const originPosition = {\n            x: originX + originOffset - scrollLeft + originRect.x,\n            y: originY - scrollTop + originRect.y,\n            width: originWidth,\n            height: rowHeight\n        };\n        let x = originPosition.x + getEditorBoxOffset();\n        let y = originPosition.y + getEditorBoxOffset();\n        let width = getEditorSpace(originPosition.width);\n        let height = getEditorSpace(originPosition.height);\n        // hover 编辑组件无边框\n        if (isHoverEdit) {\n            x = originPosition.x + getHoverEditorBoxOffset();\n            y = originPosition.y + getHoverEditorBoxOffset();\n            width = getHoverEditorSpace(originPosition.width);\n            height = getHoverEditorSpace(originPosition.height);\n        }\n        return {\n            ...originPosition,\n            x: x,\n            y: y,\n            width: width,\n            height: height\n        };\n    }\n\n    openCellEditor(aiTable: AITable, options: AITableOpenEditOptions) {\n        const { container, recordId, fieldId, isHoverEdit, references } = options;\n        const component = this.getEditorComponent(this.aiTable.fieldsMap()[fieldId].type);\n        const offsetOriginPosition = this.getOriginPosition(aiTable, options);\n        this.cellEditorPopoverRef = this.thyPopover.open(component, {\n            origin: container!,\n            originPosition: offsetOriginPosition,\n            width: offsetOriginPosition.width + 'px',\n            height: offsetOriginPosition.height + 'px',\n            minWidth: offsetOriginPosition.width + 'px',\n            placement: 'bottom',\n            offset: -offsetOriginPosition.height,\n            initialState: {\n                fieldId: fieldId,\n                recordId: recordId,\n                references,\n                aiTable: aiTable\n            },\n            panelClass: 'grid-cell-editor',\n            outsideClosable: false,\n            hasBackdrop: false,\n            manualClosure: true,\n            animationDisabled: true,\n            autoAdaptive: true\n        });\n\n        if (this.cellEditorPopoverRef) {\n            const wheelEvent = fromEvent<WheelEvent>(\n                this.cellEditorPopoverRef.componentInstance.elementRef.nativeElement,\n                'wheel'\n            ).subscribe((event: WheelEvent) => {\n                const field = aiTable.fieldsMap()[fieldId];\n                if (field.type === AITableFieldType.text || field.type === AITableFieldType.richText) {\n                    return;\n                }\n                event.preventDefault();\n                this.aiTable.context?.scrollAction({\n                    deltaX: event.deltaX,\n                    deltaY: event.deltaY,\n                    shiftKey: event.shiftKey,\n                    callback: () => {\n                        const originPosition = this.getOriginPosition(aiTable, options);\n                        const positionStrategy = (this.cellEditorPopoverRef as ThyAbstractInternalOverlayRef<any, any, any>)\n                            .getOverlayRef()\n                            .getConfig().positionStrategy as FlexibleConnectedPositionStrategy;\n                        positionStrategy.setOrigin(originPosition);\n                        positionStrategy.apply();\n                    }\n                });\n            });\n            this.cellEditorPopoverRef.afterClosed().subscribe(() => {\n                wheelEvent.unsubscribe();\n                this.cellEditorPopoverRef = null;\n            });\n            (this.cellEditorPopoverRef.componentInstance as AbstractEditCellEditor<any>).updateFieldValue.subscribe((value) => {\n                options.updateFieldValue(value);\n            });\n        }\n        return this.cellEditorPopoverRef;\n    }\n\n    closeCellEditor() {\n        if (this.cellEditorPopoverRef) {\n            this.cellEditorPopoverRef.close();\n            this.cellEditorPopoverRef = null;\n        }\n    }\n\n    getCurrentEditCell() {\n        if (this.cellEditorPopoverRef) {\n            const recordId = this.cellEditorPopoverRef.componentInstance?.recordId;\n            const fieldId = this.cellEditorPopoverRef.componentInstance?.fieldId;\n\n            if (recordId && fieldId) {\n                return {\n                    recordId,\n                    fieldId\n                };\n            }\n            return null;\n        }\n        return null;\n    }\n\n    openContextMenu(aiTable: AITable, options: AITableContextMenuOptions) {\n        const { origin, position, menuItems, targetName, viewContainerRef } = options;\n        const ref = this.thyPopover.open(AITableContextMenu, {\n            origin: origin as HTMLElement,\n            originPosition: position,\n            placement: 'bottomLeft',\n            insideClosable: true,\n            viewContainerRef,\n            initialState: {\n                aiTable,\n                menuItems,\n                targetName,\n                position\n            }\n        });\n        return ref;\n    }\n}\n"]}
@@ -1,7 +1,17 @@
1
- import { Injectable } from '@angular/core';
1
+ import { computed, Injectable } from '@angular/core';
2
+ import { AITableSelectAllState } from '../types';
2
3
  import * as i0 from "@angular/core";
3
4
  export class AITableGridSelectionService {
4
- constructor() { }
5
+ constructor() {
6
+ this.selectAllState = computed(() => {
7
+ const selectedRecords = this.aiTable.selection().selectedRecords;
8
+ return selectedRecords.size === this.aiTable.records().length
9
+ ? AITableSelectAllState.all
10
+ : selectedRecords.size === 0
11
+ ? AITableSelectAllState.none
12
+ : AITableSelectAllState.partial;
13
+ });
14
+ }
5
15
  initialize(aiTable) {
6
16
  this.aiTable = aiTable;
7
17
  }
@@ -10,7 +20,8 @@ export class AITableGridSelectionService {
10
20
  selectedRecords: new Set(),
11
21
  selectedFields: new Set(),
12
22
  selectedCells: new Set(),
13
- activeCell: null
23
+ activeCell: null,
24
+ selectAllState: AITableSelectAllState.none
14
25
  });
15
26
  }
16
27
  setActiveCell(activeCell) {
@@ -30,19 +41,31 @@ export class AITableGridSelectionService {
30
41
  else {
31
42
  this.aiTable.selection().selectedRecords.add(recordId);
32
43
  }
44
+ const selectedRecords = this.aiTable.selection().selectedRecords;
33
45
  this.aiTable.selection.set({
34
- selectedRecords: this.aiTable.selection().selectedRecords,
46
+ selectedRecords: selectedRecords,
35
47
  selectedFields: new Set(),
36
48
  selectedCells: new Set(),
37
- activeCell: null
49
+ activeCell: null,
50
+ selectAllState: this.selectAllState()
38
51
  });
39
52
  }
40
53
  toggleSelectAll(checked) {
41
- this.clearSelection();
42
54
  if (checked) {
43
- this.aiTable.records().forEach((item) => {
44
- this.selectRecord(item._id);
45
- });
55
+ if (this.aiTable.records().length === 0) {
56
+ this.aiTable.selection.set({
57
+ ...this.aiTable.selection(),
58
+ selectAllState: AITableSelectAllState.all
59
+ });
60
+ }
61
+ else {
62
+ this.aiTable.records().forEach((item) => {
63
+ this.selectRecord(item._id);
64
+ });
65
+ }
66
+ }
67
+ else {
68
+ this.clearSelection();
46
69
  }
47
70
  }
48
71
  updateSelect(event) {
@@ -101,4 +124,4 @@ export class AITableGridSelectionService {
101
124
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableGridSelectionService, decorators: [{
102
125
  type: Injectable
103
126
  }], ctorParameters: () => [] });
104
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selection.service.js","sourceRoot":"","sources":["../../../../packages/grid/src/services/selection.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { AIRecordFieldIdPath, AITable } from '../core';\n\n@Injectable()\nexport class AITableGridSelectionService {\n    aiTable!: AITable;\n\n    constructor() {}\n\n    initialize(aiTable: AITable) {\n        this.aiTable = aiTable;\n    }\n\n    clearSelection() {\n        this.aiTable.selection.set({\n            selectedRecords: new Set(),\n            selectedFields: new Set(),\n            selectedCells: new Set(),\n            activeCell: null\n        });\n    }\n\n    setActiveCell(activeCell: AIRecordFieldIdPath) {\n        this.aiTable.selection().activeCell = activeCell;\n    }\n\n    selectField(fieldId: string) {\n        if (this.aiTable.selection().selectedFields.has(fieldId)) {\n            return;\n        }\n        this.clearSelection();\n        this.aiTable.selection().selectedFields.add(fieldId);\n    }\n\n    selectRecord(recordId: string) {\n        if (this.aiTable.selection().selectedRecords.has(recordId)) {\n            this.aiTable.selection().selectedRecords.delete(recordId);\n        } else {\n            this.aiTable.selection().selectedRecords.add(recordId);\n        }\n        this.aiTable.selection.set({\n            selectedRecords: this.aiTable.selection().selectedRecords,\n            selectedFields: new Set(),\n            selectedCells: new Set(),\n            activeCell: null\n        });\n    }\n\n    toggleSelectAll(checked: boolean) {\n        this.clearSelection();\n        if (checked) {\n            this.aiTable.records().forEach((item) => {\n                this.selectRecord(item._id);\n            });\n        }\n    }\n\n    updateSelect(event: MouseEvent) {\n        const target = event?.target as HTMLElement;\n        if (!target) {\n            return;\n        }\n        const cellDom = target.closest('.grid-cell');\n        const colDom = target.closest('.grid-field');\n        const checkbox = target.tagName === 'INPUT' && (target as HTMLInputElement).type === 'checkbox' && target.closest('.grid-checkbox');\n        const fieldAction = target.closest('.grid-field-action');\n        if (cellDom) {\n            const fieldId = cellDom.getAttribute('fieldId');\n            const recordId = cellDom.getAttribute('recordId');\n            fieldId && recordId && this.selectCells([recordId, fieldId]);\n        }\n        if (colDom && !fieldAction) {\n            const fieldId = colDom.getAttribute('fieldId');\n            fieldId && this.selectField(fieldId);\n        }\n        if (!cellDom && !colDom && !checkbox) {\n            this.clearSelection();\n        }\n    }\n\n    selectCells(startCell: AIRecordFieldIdPath, endCell?: AIRecordFieldIdPath) {\n        const [startRecordId, startFieldId] = startCell;\n        const records = this.aiTable.records();\n        const fields = this.aiTable.fields();\n        const selectedCells = new Set<string>();\n\n        if (!endCell) {\n            selectedCells.add(`${startRecordId}:${startFieldId}`);\n        } else {\n            const [endRecordId, endFieldId] = endCell;\n\n            const startRowIndex = records.findIndex((record) => record._id === startRecordId);\n            const endRowIndex = records.findIndex((record) => record._id === endRecordId);\n            const startColIndex = fields.findIndex((field) => field._id === startFieldId);\n            const endColIndex = fields.findIndex((field) => field._id === endFieldId);\n\n            const minRowIndex = Math.min(startRowIndex, endRowIndex);\n            const maxRowIndex = Math.max(startRowIndex, endRowIndex);\n            const minColIndex = Math.min(startColIndex, endColIndex);\n            const maxColIndex = Math.max(startColIndex, endColIndex);\n\n            for (let i = minRowIndex; i <= maxRowIndex; i++) {\n                for (let j = minColIndex; j <= maxColIndex; j++) {\n                    selectedCells.add(`${records[i]._id}:${fields[j]._id}`);\n                }\n            }\n        }\n\n        this.clearSelection();\n        this.setActiveCell(startCell);\n        this.aiTable.selection().selectedCells = selectedCells;\n    }\n}\n"]}
127
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selection.service.js","sourceRoot":"","sources":["../../../../packages/grid/src/services/selection.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { computed, Injectable } from '@angular/core';\nimport { AIRecordFieldIdPath, AITable } from '../core';\nimport { AITableSelectAllState } from '../types';\n\n@Injectable()\nexport class AITableGridSelectionService {\n    aiTable!: AITable;\n\n    selectAllState = computed(() => {\n        const selectedRecords = this.aiTable.selection().selectedRecords;\n        return selectedRecords.size === this.aiTable.records().length\n            ? AITableSelectAllState.all\n            : selectedRecords.size === 0\n              ? AITableSelectAllState.none\n              : AITableSelectAllState.partial;\n    });\n\n    constructor() {}\n\n    initialize(aiTable: AITable) {\n        this.aiTable = aiTable;\n    }\n\n    clearSelection() {\n        this.aiTable.selection.set({\n            selectedRecords: new Set(),\n            selectedFields: new Set(),\n            selectedCells: new Set(),\n            activeCell: null,\n            selectAllState: AITableSelectAllState.none\n        });\n    }\n\n    setActiveCell(activeCell: AIRecordFieldIdPath) {\n        this.aiTable.selection().activeCell = activeCell;\n    }\n\n    selectField(fieldId: string) {\n        if (this.aiTable.selection().selectedFields.has(fieldId)) {\n            return;\n        }\n        this.clearSelection();\n        this.aiTable.selection().selectedFields.add(fieldId);\n    }\n\n    selectRecord(recordId: string) {\n        if (this.aiTable.selection().selectedRecords.has(recordId)) {\n            this.aiTable.selection().selectedRecords.delete(recordId);\n        } else {\n            this.aiTable.selection().selectedRecords.add(recordId);\n        }\n        const selectedRecords = this.aiTable.selection().selectedRecords;\n        this.aiTable.selection.set({\n            selectedRecords: selectedRecords,\n            selectedFields: new Set(),\n            selectedCells: new Set(),\n            activeCell: null,\n            selectAllState: this.selectAllState()\n        });\n    }\n\n    toggleSelectAll(checked: boolean) {\n        if (checked) {\n            if (this.aiTable.records().length === 0) {\n                this.aiTable.selection.set({\n                    ...this.aiTable.selection(),\n                    selectAllState: AITableSelectAllState.all\n                });\n            } else {\n                this.aiTable.records().forEach((item) => {\n                    this.selectRecord(item._id);\n                });\n            }\n        } else {\n            this.clearSelection();\n        }\n    }\n\n    updateSelect(event: MouseEvent) {\n        const target = event?.target as HTMLElement;\n        if (!target) {\n            return;\n        }\n        const cellDom = target.closest('.grid-cell');\n        const colDom = target.closest('.grid-field');\n        const checkbox = target.tagName === 'INPUT' && (target as HTMLInputElement).type === 'checkbox' && target.closest('.grid-checkbox');\n        const fieldAction = target.closest('.grid-field-action');\n        if (cellDom) {\n            const fieldId = cellDom.getAttribute('fieldId');\n            const recordId = cellDom.getAttribute('recordId');\n            fieldId && recordId && this.selectCells([recordId, fieldId]);\n        }\n        if (colDom && !fieldAction) {\n            const fieldId = colDom.getAttribute('fieldId');\n            fieldId && this.selectField(fieldId);\n        }\n        if (!cellDom && !colDom && !checkbox) {\n            this.clearSelection();\n        }\n    }\n\n    selectCells(startCell: AIRecordFieldIdPath, endCell?: AIRecordFieldIdPath) {\n        const [startRecordId, startFieldId] = startCell;\n        const records = this.aiTable.records();\n        const fields = this.aiTable.fields();\n        const selectedCells = new Set<string>();\n\n        if (!endCell) {\n            selectedCells.add(`${startRecordId}:${startFieldId}`);\n        } else {\n            const [endRecordId, endFieldId] = endCell;\n\n            const startRowIndex = records.findIndex((record) => record._id === startRecordId);\n            const endRowIndex = records.findIndex((record) => record._id === endRecordId);\n            const startColIndex = fields.findIndex((field) => field._id === startFieldId);\n            const endColIndex = fields.findIndex((field) => field._id === endFieldId);\n\n            const minRowIndex = Math.min(startRowIndex, endRowIndex);\n            const maxRowIndex = Math.max(startRowIndex, endRowIndex);\n            const minColIndex = Math.min(startColIndex, endColIndex);\n            const maxColIndex = Math.max(startColIndex, endColIndex);\n\n            for (let i = minRowIndex; i <= maxRowIndex; i++) {\n                for (let j = minColIndex; j <= maxColIndex; j++) {\n                    selectedCells.add(`${records[i]._id}:${fields[j]._id}`);\n                }\n            }\n        }\n\n        this.clearSelection();\n        this.setActiveCell(startCell);\n        this.aiTable.selection().selectedCells = selectedCells;\n    }\n}\n"]}
@@ -13,4 +13,10 @@ export var AITableAreaType;
13
13
  AITableAreaType["grid"] = "grid";
14
14
  AITableAreaType["none"] = "none";
15
15
  })(AITableAreaType || (AITableAreaType = {}));
16
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JpZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL2dyaWQvc3JjL3R5cGVzL2dyaWQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNERBLE1BQU0sQ0FBTixJQUFZLG9CQUdYO0FBSEQsV0FBWSxvQkFBb0I7SUFDNUIsbUNBQVcsQ0FBQTtJQUNYLHlDQUFpQixDQUFBO0FBQ3JCLENBQUMsRUFIVyxvQkFBb0IsS0FBcEIsb0JBQW9CLFFBRy9CO0FBZ0JELE1BQU0sQ0FBTixJQUFZLGdCQUdYO0FBSEQsV0FBWSxnQkFBZ0I7SUFDeEIsdUNBQW1CLENBQUE7SUFDbkIsMkNBQXVCLENBQUE7QUFDM0IsQ0FBQyxFQUhXLGdCQUFnQixLQUFoQixnQkFBZ0IsUUFHM0I7QUFlRCxNQUFNLENBQU4sSUFBWSxlQUdYO0FBSEQsV0FBWSxlQUFlO0lBQ3ZCLGdDQUFhLENBQUE7SUFDYixnQ0FBYSxDQUFBO0FBQ2pCLENBQUMsRUFIVyxlQUFlLEtBQWYsZUFBZSxRQUcxQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNpZ25hbCwgV3JpdGFibGVTaWduYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERpY3Rpb25hcnkgfSBmcm9tICduZ3gtdGV0aHlzL3R5cGVzJztcbmltcG9ydCB7XG4gICAgQUlSZWNvcmRGaWVsZElkUGF0aCxcbiAgICBBSVRhYmxlLFxuICAgIEFJVGFibGVGaWVsZCxcbiAgICBBSVRhYmxlRmllbGRUeXBlLFxuICAgIEFJVGFibGVSZWNvcmQsXG4gICAgQ29vcmRpbmF0ZSxcbiAgICBGaWVsZFZhbHVlLFxuICAgIFVwZGF0ZUZpZWxkVmFsdWVPcHRpb25zXG59IGZyb20gJy4uL2NvcmUnO1xuaW1wb3J0IHsgQUlUYWJsZUZpZWxkTWVudUl0ZW0gfSBmcm9tICcuL2ZpZWxkJztcbmltcG9ydCB7IEFJVGFibGVMaW5lYXJSb3cgfSBmcm9tICcuL3Jvdyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQUlUYWJsZUdyaWRDZWxsUmVuZGVyU2NoZW1hIHtcbiAgICBlZGl0b3I/OiBhbnk7XG4gICAgdHJhbnNmb3JtPzogKGZpZWxkOiBBSVRhYmxlRmllbGQsIHZhbHVlOiBGaWVsZFZhbHVlKSA9PiBhbnk7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQUlUYWJsZUdyaWREYXRhIHtcbiAgICB0eXBlOiAnZ3JpZCc7XG4gICAgZmllbGRzOiBBSVRhYmxlRmllbGRbXTtcbiAgICByZWNvcmRzOiBBSVRhYmxlUmVjb3JkW107XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQUlUYWJsZVNlbGVjdGlvbiB7XG4gICAgc2VsZWN0ZWRSZWNvcmRzOiBTZXQ8c3RyaW5nPjsgLy8gYCR7cmVjb3JkSWR9YFxuICAgIHNlbGVjdGVkRmllbGRzOiBTZXQ8c3RyaW5nPjsgLy8gYCR7ZmllbGRJZH1gXG4gICAgc2VsZWN0ZWRDZWxsczogU2V0PHN0cmluZz47IC8vIGAke3JlY29yZElkfToke2ZpZWxkSWR9YFxuICAgIGFjdGl2ZUNlbGw6IEFJUmVjb3JkRmllbGRJZFBhdGggfCBudWxsO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFJRmllbGRDb25maWcge1xuICAgIGZpZWxkUmVuZGVyZXJzPzogUGFydGlhbDxSZWNvcmQ8QUlUYWJsZUZpZWxkVHlwZSwgQUlUYWJsZUdyaWRDZWxsUmVuZGVyU2NoZW1hPj47XG4gICAgZmllbGRTZXR0aW5nQ29tcG9uZW50PzogYW55O1xuICAgIGZpZWxkTWVudXM/OiBBSVRhYmxlRmllbGRNZW51SXRlbVtdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFJVGFibGVVc2VySW5mbyB7XG4gICAgdWlkPzogc3RyaW5nO1xuICAgIGRpc3BsYXlfbmFtZT86IHN0cmluZztcbiAgICBhdmF0YXI/OiBzdHJpbmc7XG4gICAgW2tleTogc3RyaW5nXTogYW55O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFJVGFibGVSZWZlcmVuY2VzIHtcbiAgICBtZW1iZXJzOiBEaWN0aW9uYXJ5PEFJVGFibGVVc2VySW5mbz47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQUlUYWJsZVJlbmRlcmVyQ29uZmlnIHtcbiAgICBhaVRhYmxlOiBBSVRhYmxlO1xuICAgIGNvbnRhaW5lcjogSFRNTERpdkVsZW1lbnQ7XG4gICAgY29vcmRpbmF0ZTogQ29vcmRpbmF0ZTtcbiAgICBjb250YWluZXJXaWR0aDogbnVtYmVyO1xuICAgIGNvbnRhaW5lckhlaWdodDogbnVtYmVyO1xuICAgIHJlZmVyZW5jZXM6IEFJVGFibGVSZWZlcmVuY2VzO1xuICAgIHJlYWRvbmx5PzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGVudW0gQUlUYWJsZVJvd0NvbHVtblR5cGUge1xuICAgIHJvdyA9ICdyb3cnLFxuICAgIGNvbHVtbiA9ICdjb2x1bW4nXG59XG5cbmV4cG9ydCB0eXBlIEFJVGFibGVTaXplTWFwID0gUmVjb3JkPG51bWJlciwgbnVtYmVyPjtcblxuZXhwb3J0IGludGVyZmFjZSBBSVRhYmxlQ29vcmRpbmF0ZSB7XG4gICAgcm93Q291bnQ6IG51bWJlcjtcbiAgICBjb2x1bW5Db3VudDogbnVtYmVyO1xuICAgIGNvbnRhaW5lcjogSFRNTERpdkVsZW1lbnQ7XG4gICAgcm93SGVpZ2h0OiBudW1iZXI7XG4gICAgcm93SW5pdFNpemU/OiBudW1iZXI7XG4gICAgcm93SW5kaWNlc1NpemVNYXA6IEFJVGFibGVTaXplTWFwO1xuICAgIGNvbHVtbkluZGljZXNTaXplTWFwOiBBSVRhYmxlU2l6ZU1hcDtcbiAgICBjb2x1bW5Jbml0U2l6ZT86IG51bWJlcjtcbiAgICBmcm96ZW5Db2x1bW5Db3VudD86IG51bWJlcjtcbn1cblxuZXhwb3J0IGVudW0gQUlUYWJsZUNoZWNrVHlwZSB7XG4gICAgY2hlY2tlZCA9ICdjaGVja2VkJyxcbiAgICB1bmNoZWNrZWQgPSAndW5jaGVja2VkJ1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFJVGFibGVTY3JvbGxTdGF0ZSB7XG4gICAgc2Nyb2xsVG9wOiBudW1iZXI7XG4gICAgc2Nyb2xsTGVmdDogbnVtYmVyO1xuICAgIGlzU2Nyb2xsaW5nOiBib29sZWFuO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNjcm9sbEFjdGlvbk9wdGlvbnMge1xuICAgIGRlbHRhWDogbnVtYmVyO1xuICAgIGRlbHRhWTogbnVtYmVyO1xuICAgIHNoaWZ0S2V5OiBib29sZWFuO1xuICAgIGNhbGxiYWNrPzogKCkgPT4gdm9pZDtcbn1cblxuZXhwb3J0IGVudW0gQUlUYWJsZUFyZWFUeXBlIHtcbiAgICBncmlkID0gJ2dyaWQnLFxuICAgIG5vbmUgPSAnbm9uZSdcbn1cblxuZXhwb3J0IHR5cGUgQUlUYWJsZVBvaW50UG9zaXRpb24gPSB7XG4gICAgeDogbnVtYmVyO1xuICAgIHk6IG51bWJlcjtcbiAgICBhcmVhVHlwZTogQUlUYWJsZUFyZWFUeXBlO1xuICAgIHRhcmdldE5hbWU6IHN0cmluZztcbiAgICByZWFsVGFyZ2V0TmFtZTogc3RyaW5nO1xuICAgIHJvd0luZGV4OiBudW1iZXI7XG4gICAgY29sdW1uSW5kZXg6IG51bWJlcjtcbiAgICBvZmZzZXRUb3A6IG51bWJlcjtcbiAgICBvZmZzZXRMZWZ0OiBudW1iZXI7XG59O1xuXG5leHBvcnQgaW50ZXJmYWNlIEFJVGFibGVFZGl0UG9zaXRpb24ge1xuICAgIHg6IG51bWJlcjtcbiAgICB5OiBudW1iZXI7XG4gICAgd2lkdGg6IG51bWJlcjtcbiAgICBoZWlnaHQ6IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBBSVRhYmxlT3BlbkVkaXRPcHRpb25zIHtcbiAgICByZWNvcmRJZDogc3RyaW5nO1xuICAgIGZpZWxkSWQ6IHN0cmluZztcbiAgICBjb29yZGluYXRlOiBDb29yZGluYXRlO1xuICAgIHJlZmVyZW5jZXM6IEFJVGFibGVSZWZlcmVuY2VzO1xuICAgIGNvbnRhaW5lcj86IEhUTUxEaXZFbGVtZW50O1xuICAgIGlzSG92ZXJFZGl0PzogYm9vbGVhbjtcbiAgICB1cGRhdGVGaWVsZFZhbHVlOiAob3B0aW9uczogVXBkYXRlRmllbGRWYWx1ZU9wdGlvbnM8YW55PikgPT4gdm9pZDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBBSVRhYmxlQ29udGV4dCB7XG4gICAgbGluZWFyUm93czogU2lnbmFsPEFJVGFibGVMaW5lYXJSb3dbXT47XG4gICAgcG9pbnRQb3NpdGlvbjogV3JpdGFibGVTaWduYWw8QUlUYWJsZVBvaW50UG9zaXRpb24+O1xuICAgIHNjcm9sbFN0YXRlOiBXcml0YWJsZVNpZ25hbDxBSVRhYmxlU2Nyb2xsU3RhdGU+O1xuICAgIHNjcm9sbEFjdGlvbjogKG9wdGlvbnM6IFNjcm9sbEFjdGlvbk9wdGlvbnMpID0+IHZvaWQ7XG4gICAgdmlzaWJsZUNvbHVtbnNJbmRleE1hcDogU2lnbmFsPE1hcDxzdHJpbmcsIG51bWJlcj4+O1xuICAgIHZpc2libGVSb3dzSW5kZXhNYXA6IFNpZ25hbDxNYXA8c3RyaW5nLCBudW1iZXI+PjtcbiAgICBmcm96ZW5Db2x1bW5Db3VudDogU2lnbmFsPG51bWJlcj47XG4gICAgcmVmZXJlbmNlczogU2lnbmFsPEFJVGFibGVSZWZlcmVuY2VzPjtcbn1cbiJdfQ==
16
+ export var AITableSelectAllState;
17
+ (function (AITableSelectAllState) {
18
+ AITableSelectAllState["all"] = "all";
19
+ AITableSelectAllState["partial"] = "partial";
20
+ AITableSelectAllState["none"] = "none";
21
+ })(AITableSelectAllState || (AITableSelectAllState = {}));
22
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JpZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3BhY2thZ2VzL2dyaWQvc3JjL3R5cGVzL2dyaWQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNkRBLE1BQU0sQ0FBTixJQUFZLG9CQUdYO0FBSEQsV0FBWSxvQkFBb0I7SUFDNUIsbUNBQVcsQ0FBQTtJQUNYLHlDQUFpQixDQUFBO0FBQ3JCLENBQUMsRUFIVyxvQkFBb0IsS0FBcEIsb0JBQW9CLFFBRy9CO0FBZ0JELE1BQU0sQ0FBTixJQUFZLGdCQUdYO0FBSEQsV0FBWSxnQkFBZ0I7SUFDeEIsdUNBQW1CLENBQUE7SUFDbkIsMkNBQXVCLENBQUE7QUFDM0IsQ0FBQyxFQUhXLGdCQUFnQixLQUFoQixnQkFBZ0IsUUFHM0I7QUFlRCxNQUFNLENBQU4sSUFBWSxlQUdYO0FBSEQsV0FBWSxlQUFlO0lBQ3ZCLGdDQUFhLENBQUE7SUFDYixnQ0FBYSxDQUFBO0FBQ2pCLENBQUMsRUFIVyxlQUFlLEtBQWYsZUFBZSxRQUcxQjtBQTJDRCxNQUFNLENBQU4sSUFBWSxxQkFJWDtBQUpELFdBQVkscUJBQXFCO0lBQzdCLG9DQUFXLENBQUE7SUFDWCw0Q0FBbUIsQ0FBQTtJQUNuQixzQ0FBYSxDQUFBO0FBQ2pCLENBQUMsRUFKVyxxQkFBcUIsS0FBckIscUJBQXFCLFFBSWhDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU2lnbmFsLCBXcml0YWJsZVNpZ25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRGljdGlvbmFyeSB9IGZyb20gJ25neC10ZXRoeXMvdHlwZXMnO1xuaW1wb3J0IHtcbiAgICBBSVJlY29yZEZpZWxkSWRQYXRoLFxuICAgIEFJVGFibGUsXG4gICAgQUlUYWJsZUZpZWxkLFxuICAgIEFJVGFibGVGaWVsZFR5cGUsXG4gICAgQUlUYWJsZVJlY29yZCxcbiAgICBDb29yZGluYXRlLFxuICAgIEZpZWxkVmFsdWUsXG4gICAgVXBkYXRlRmllbGRWYWx1ZU9wdGlvbnNcbn0gZnJvbSAnLi4vY29yZSc7XG5pbXBvcnQgeyBBSVRhYmxlRmllbGRNZW51SXRlbSB9IGZyb20gJy4vZmllbGQnO1xuaW1wb3J0IHsgQUlUYWJsZUxpbmVhclJvdyB9IGZyb20gJy4vcm93JztcblxuZXhwb3J0IGludGVyZmFjZSBBSVRhYmxlR3JpZENlbGxSZW5kZXJTY2hlbWEge1xuICAgIGVkaXRvcj86IGFueTtcbiAgICB0cmFuc2Zvcm0/OiAoZmllbGQ6IEFJVGFibGVGaWVsZCwgdmFsdWU6IEZpZWxkVmFsdWUpID0+IGFueTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBBSVRhYmxlR3JpZERhdGEge1xuICAgIHR5cGU6ICdncmlkJztcbiAgICBmaWVsZHM6IEFJVGFibGVGaWVsZFtdO1xuICAgIHJlY29yZHM6IEFJVGFibGVSZWNvcmRbXTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBBSVRhYmxlU2VsZWN0aW9uIHtcbiAgICBzZWxlY3RlZFJlY29yZHM6IFNldDxzdHJpbmc+OyAvLyBgJHtyZWNvcmRJZH1gXG4gICAgc2VsZWN0ZWRGaWVsZHM6IFNldDxzdHJpbmc+OyAvLyBgJHtmaWVsZElkfWBcbiAgICBzZWxlY3RlZENlbGxzOiBTZXQ8c3RyaW5nPjsgLy8gYCR7cmVjb3JkSWR9OiR7ZmllbGRJZH1gXG4gICAgYWN0aXZlQ2VsbDogQUlSZWNvcmRGaWVsZElkUGF0aCB8IG51bGw7XG4gICAgc2VsZWN0QWxsU3RhdGU6IEFJVGFibGVTZWxlY3RBbGxTdGF0ZTsgLy8gJ2FsbCcsJ3BhcnRpYWwnLCdub25lJ1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFJRmllbGRDb25maWcge1xuICAgIGZpZWxkUmVuZGVyZXJzPzogUGFydGlhbDxSZWNvcmQ8QUlUYWJsZUZpZWxkVHlwZSwgQUlUYWJsZUdyaWRDZWxsUmVuZGVyU2NoZW1hPj47XG4gICAgZmllbGRTZXR0aW5nQ29tcG9uZW50PzogYW55O1xuICAgIGZpZWxkTWVudXM/OiBBSVRhYmxlRmllbGRNZW51SXRlbVtdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFJVGFibGVVc2VySW5mbyB7XG4gICAgdWlkPzogc3RyaW5nO1xuICAgIGRpc3BsYXlfbmFtZT86IHN0cmluZztcbiAgICBhdmF0YXI/OiBzdHJpbmc7XG4gICAgW2tleTogc3RyaW5nXTogYW55O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFJVGFibGVSZWZlcmVuY2VzIHtcbiAgICBtZW1iZXJzOiBEaWN0aW9uYXJ5PEFJVGFibGVVc2VySW5mbz47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQUlUYWJsZVJlbmRlcmVyQ29uZmlnIHtcbiAgICBhaVRhYmxlOiBBSVRhYmxlO1xuICAgIGNvbnRhaW5lcjogSFRNTERpdkVsZW1lbnQ7XG4gICAgY29vcmRpbmF0ZTogQ29vcmRpbmF0ZTtcbiAgICBjb250YWluZXJXaWR0aDogbnVtYmVyO1xuICAgIGNvbnRhaW5lckhlaWdodDogbnVtYmVyO1xuICAgIHJlZmVyZW5jZXM6IEFJVGFibGVSZWZlcmVuY2VzO1xuICAgIHJlYWRvbmx5PzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGVudW0gQUlUYWJsZVJvd0NvbHVtblR5cGUge1xuICAgIHJvdyA9ICdyb3cnLFxuICAgIGNvbHVtbiA9ICdjb2x1bW4nXG59XG5cbmV4cG9ydCB0eXBlIEFJVGFibGVTaXplTWFwID0gUmVjb3JkPG51bWJlciwgbnVtYmVyPjtcblxuZXhwb3J0IGludGVyZmFjZSBBSVRhYmxlQ29vcmRpbmF0ZSB7XG4gICAgcm93Q291bnQ6IG51bWJlcjtcbiAgICBjb2x1bW5Db3VudDogbnVtYmVyO1xuICAgIGNvbnRhaW5lcjogSFRNTERpdkVsZW1lbnQ7XG4gICAgcm93SGVpZ2h0OiBudW1iZXI7XG4gICAgcm93SW5pdFNpemU/OiBudW1iZXI7XG4gICAgcm93SW5kaWNlc1NpemVNYXA6IEFJVGFibGVTaXplTWFwO1xuICAgIGNvbHVtbkluZGljZXNTaXplTWFwOiBBSVRhYmxlU2l6ZU1hcDtcbiAgICBjb2x1bW5Jbml0U2l6ZT86IG51bWJlcjtcbiAgICBmcm96ZW5Db2x1bW5Db3VudD86IG51bWJlcjtcbn1cblxuZXhwb3J0IGVudW0gQUlUYWJsZUNoZWNrVHlwZSB7XG4gICAgY2hlY2tlZCA9ICdjaGVja2VkJyxcbiAgICB1bmNoZWNrZWQgPSAndW5jaGVja2VkJ1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFJVGFibGVTY3JvbGxTdGF0ZSB7XG4gICAgc2Nyb2xsVG9wOiBudW1iZXI7XG4gICAgc2Nyb2xsTGVmdDogbnVtYmVyO1xuICAgIGlzU2Nyb2xsaW5nOiBib29sZWFuO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNjcm9sbEFjdGlvbk9wdGlvbnMge1xuICAgIGRlbHRhWDogbnVtYmVyO1xuICAgIGRlbHRhWTogbnVtYmVyO1xuICAgIHNoaWZ0S2V5OiBib29sZWFuO1xuICAgIGNhbGxiYWNrPzogKCkgPT4gdm9pZDtcbn1cblxuZXhwb3J0IGVudW0gQUlUYWJsZUFyZWFUeXBlIHtcbiAgICBncmlkID0gJ2dyaWQnLFxuICAgIG5vbmUgPSAnbm9uZSdcbn1cblxuZXhwb3J0IHR5cGUgQUlUYWJsZVBvaW50UG9zaXRpb24gPSB7XG4gICAgeDogbnVtYmVyO1xuICAgIHk6IG51bWJlcjtcbiAgICBhcmVhVHlwZTogQUlUYWJsZUFyZWFUeXBlO1xuICAgIHRhcmdldE5hbWU6IHN0cmluZztcbiAgICByZWFsVGFyZ2V0TmFtZTogc3RyaW5nO1xuICAgIHJvd0luZGV4OiBudW1iZXI7XG4gICAgY29sdW1uSW5kZXg6IG51bWJlcjtcbiAgICBvZmZzZXRUb3A6IG51bWJlcjtcbiAgICBvZmZzZXRMZWZ0OiBudW1iZXI7XG59O1xuXG5leHBvcnQgaW50ZXJmYWNlIEFJVGFibGVFZGl0UG9zaXRpb24ge1xuICAgIHg6IG51bWJlcjtcbiAgICB5OiBudW1iZXI7XG4gICAgd2lkdGg6IG51bWJlcjtcbiAgICBoZWlnaHQ6IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBBSVRhYmxlT3BlbkVkaXRPcHRpb25zIHtcbiAgICByZWNvcmRJZDogc3RyaW5nO1xuICAgIGZpZWxkSWQ6IHN0cmluZztcbiAgICBjb29yZGluYXRlOiBDb29yZGluYXRlO1xuICAgIHJlZmVyZW5jZXM6IEFJVGFibGVSZWZlcmVuY2VzO1xuICAgIGNvbnRhaW5lcj86IEhUTUxEaXZFbGVtZW50O1xuICAgIGlzSG92ZXJFZGl0PzogYm9vbGVhbjtcbiAgICB1cGRhdGVGaWVsZFZhbHVlOiAob3B0aW9uczogVXBkYXRlRmllbGRWYWx1ZU9wdGlvbnM8YW55PikgPT4gdm9pZDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBBSVRhYmxlQ29udGV4dCB7XG4gICAgbGluZWFyUm93czogU2lnbmFsPEFJVGFibGVMaW5lYXJSb3dbXT47XG4gICAgcG9pbnRQb3NpdGlvbjogV3JpdGFibGVTaWduYWw8QUlUYWJsZVBvaW50UG9zaXRpb24+O1xuICAgIHNjcm9sbFN0YXRlOiBXcml0YWJsZVNpZ25hbDxBSVRhYmxlU2Nyb2xsU3RhdGU+O1xuICAgIHNjcm9sbEFjdGlvbjogKG9wdGlvbnM6IFNjcm9sbEFjdGlvbk9wdGlvbnMpID0+IHZvaWQ7XG4gICAgdmlzaWJsZUNvbHVtbnNJbmRleE1hcDogU2lnbmFsPE1hcDxzdHJpbmcsIG51bWJlcj4+O1xuICAgIHZpc2libGVSb3dzSW5kZXhNYXA6IFNpZ25hbDxNYXA8c3RyaW5nLCBudW1iZXI+PjtcbiAgICBmcm96ZW5Db2x1bW5Db3VudDogU2lnbmFsPG51bWJlcj47XG4gICAgcmVmZXJlbmNlczogU2lnbmFsPEFJVGFibGVSZWZlcmVuY2VzPjtcbiAgICBhaUZpZWxkQ29uZmlnOiBTaWduYWw8QUlGaWVsZENvbmZpZyB8IHVuZGVmaW5lZD47XG59XG5cbmV4cG9ydCBlbnVtIEFJVGFibGVTZWxlY3RBbGxTdGF0ZSB7XG4gICAgYWxsID0gJ2FsbCcsXG4gICAgcGFydGlhbCA9ICdwYXJ0aWFsJyxcbiAgICBub25lID0gJ25vbmUnXG59XG4iXX0=
@@ -1,5 +1,5 @@
1
1
  import * as i0 from '@angular/core';
2
- import { signal, computed, output, inject, ElementRef, Component, ChangeDetectionStrategy, Input, EventEmitter, Output, ChangeDetectorRef, ViewChild, HostListener, Pipe, input, Renderer2, model, booleanAttribute, Injectable, DestroyRef, NgZone, InjectionToken, effect, ViewContainerRef, viewChild, afterNextRender } from '@angular/core';
2
+ import { signal, computed, output, inject, ElementRef, Component, ChangeDetectionStrategy, Input, EventEmitter, Output, ChangeDetectorRef, ViewChild, HostListener, Pipe, input, Renderer2, model, booleanAttribute, Injectable, DestroyRef, NgZone, InjectionToken, effect, ViewContainerRef, viewChild, afterNextRender, untracked } from '@angular/core';
3
3
  import * as i1$1 from 'ngx-tethys/popover';
4
4
  import { ThyPopoverRef, ThyPopover, ThyPopoverModule } from 'ngx-tethys/popover';
5
5
  import ObjectID from 'bson-objectid';
@@ -340,6 +340,12 @@ var AITableAreaType;
340
340
  AITableAreaType["grid"] = "grid";
341
341
  AITableAreaType["none"] = "none";
342
342
  })(AITableAreaType || (AITableAreaType = {}));
343
+ var AITableSelectAllState;
344
+ (function (AITableSelectAllState) {
345
+ AITableSelectAllState["all"] = "all";
346
+ AITableSelectAllState["partial"] = "partial";
347
+ AITableSelectAllState["none"] = "none";
348
+ })(AITableSelectAllState || (AITableSelectAllState = {}));
343
349
 
344
350
  var AITableRowType;
345
351
  (function (AITableRowType) {
@@ -707,7 +713,8 @@ function createAITable(records, fields) {
707
713
  selectedRecords: new Set(),
708
714
  selectedFields: new Set(),
709
715
  selectedCells: new Set(),
710
- activeCell: null
716
+ activeCell: null,
717
+ selectAllState: AITableSelectAllState.none
711
718
  }),
712
719
  keywordsMatchedCells: signal(new Set()),
713
720
  recordsMap: computed(() => {
@@ -801,7 +808,7 @@ const AITableQueries = {
801
808
 
802
809
  class RendererContext {
803
810
  constructor(options) {
804
- const { linearRows, pointPosition, scrollState, visibleColumnsIndexMap, visibleRowsIndexMap, frozenColumnCount, references, scrollAction } = options;
811
+ const { linearRows, pointPosition, scrollState, visibleColumnsIndexMap, visibleRowsIndexMap, frozenColumnCount, references, aiFieldConfig, scrollAction } = options;
805
812
  this.linearRows = linearRows;
806
813
  this.pointPosition = pointPosition;
807
814
  this.scrollState = scrollState;
@@ -810,6 +817,7 @@ class RendererContext {
810
817
  this.visibleRowsIndexMap = visibleRowsIndexMap;
811
818
  this.frozenColumnCount = frozenColumnCount;
812
819
  this.references = references;
820
+ this.aiFieldConfig = aiFieldConfig;
813
821
  }
814
822
  setPointPosition(position) {
815
823
  const oldPosition = this.pointPosition();
@@ -1565,7 +1573,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
1565
1573
  }] } });
1566
1574
 
1567
1575
  class AITableGridSelectionService {
1568
- constructor() { }
1576
+ constructor() {
1577
+ this.selectAllState = computed(() => {
1578
+ const selectedRecords = this.aiTable.selection().selectedRecords;
1579
+ return selectedRecords.size === this.aiTable.records().length
1580
+ ? AITableSelectAllState.all
1581
+ : selectedRecords.size === 0
1582
+ ? AITableSelectAllState.none
1583
+ : AITableSelectAllState.partial;
1584
+ });
1585
+ }
1569
1586
  initialize(aiTable) {
1570
1587
  this.aiTable = aiTable;
1571
1588
  }
@@ -1574,7 +1591,8 @@ class AITableGridSelectionService {
1574
1591
  selectedRecords: new Set(),
1575
1592
  selectedFields: new Set(),
1576
1593
  selectedCells: new Set(),
1577
- activeCell: null
1594
+ activeCell: null,
1595
+ selectAllState: AITableSelectAllState.none
1578
1596
  });
1579
1597
  }
1580
1598
  setActiveCell(activeCell) {
@@ -1594,19 +1612,31 @@ class AITableGridSelectionService {
1594
1612
  else {
1595
1613
  this.aiTable.selection().selectedRecords.add(recordId);
1596
1614
  }
1615
+ const selectedRecords = this.aiTable.selection().selectedRecords;
1597
1616
  this.aiTable.selection.set({
1598
- selectedRecords: this.aiTable.selection().selectedRecords,
1617
+ selectedRecords: selectedRecords,
1599
1618
  selectedFields: new Set(),
1600
1619
  selectedCells: new Set(),
1601
- activeCell: null
1620
+ activeCell: null,
1621
+ selectAllState: this.selectAllState()
1602
1622
  });
1603
1623
  }
1604
1624
  toggleSelectAll(checked) {
1605
- this.clearSelection();
1606
1625
  if (checked) {
1607
- this.aiTable.records().forEach((item) => {
1608
- this.selectRecord(item._id);
1609
- });
1626
+ if (this.aiTable.records().length === 0) {
1627
+ this.aiTable.selection.set({
1628
+ ...this.aiTable.selection(),
1629
+ selectAllState: AITableSelectAllState.all
1630
+ });
1631
+ }
1632
+ else {
1633
+ this.aiTable.records().forEach((item) => {
1634
+ this.selectRecord(item._id);
1635
+ });
1636
+ }
1637
+ }
1638
+ else {
1639
+ this.clearSelection();
1610
1640
  }
1611
1641
  }
1612
1642
  updateSelect(event) {
@@ -3042,6 +3072,10 @@ class AITableGridEventService {
3042
3072
  });
3043
3073
  if (this.cellEditorPopoverRef) {
3044
3074
  const wheelEvent = fromEvent(this.cellEditorPopoverRef.componentInstance.elementRef.nativeElement, 'wheel').subscribe((event) => {
3075
+ const field = aiTable.fieldsMap()[fieldId];
3076
+ if (field.type === AITableFieldType.text || field.type === AITableFieldType.richText) {
3077
+ return;
3078
+ }
3045
3079
  event.preventDefault();
3046
3080
  this.aiTable.context?.scrollAction({
3047
3081
  deltaX: event.deltaX,
@@ -5404,20 +5438,21 @@ class CellDrawer extends Drawer {
5404
5438
  renderCellRate(render, ctx) {
5405
5439
  const { x, y, transformValue: _cellValue } = render;
5406
5440
  const max = 5;
5407
- const cellValue = _cellValue || 0;
5441
+ const cellValue = _cellValue;
5408
5442
  const size = AI_TABLE_CELL_EMOJI_SIZE;
5443
+ const isEmpty = isNil(cellValue);
5409
5444
  return [...Array(max).keys()].map((item, index) => {
5410
5445
  const value = index + 1;
5411
5446
  const checked = value <= cellValue;
5412
5447
  const iconX = index * size + AI_TABLE_CELL_PADDING + index * AI_TABLE_CELL_EMOJI_PADDING;
5413
5448
  const iconY = (AI_TABLE_ROW_BLANK_HEIGHT - size) / 2;
5414
- if (ctx && checked) {
5449
+ if (ctx && (checked || isEmpty)) {
5415
5450
  this.path({
5416
5451
  x: x + iconX,
5417
5452
  y: y + iconY,
5418
5453
  size: 22,
5419
5454
  data: StarFill,
5420
- fill: this.colors.waring,
5455
+ fill: isEmpty ? this.colors.gray100 : this.colors.waring,
5421
5456
  scaleX: 1.14,
5422
5457
  scaleY: 1.14
5423
5458
  });
@@ -5427,8 +5462,11 @@ class CellDrawer extends Drawer {
5427
5462
  renderCellProgress(render, ctx) {
5428
5463
  const { x, y, transformValue, columnWidth, style } = render;
5429
5464
  const colors = AITable.getColors();
5430
- const cellText = transformValue;
5431
- if (cellText == null || !___default.isNumber(cellText)) {
5465
+ let cellValue = transformValue;
5466
+ if (isNil(cellValue)) {
5467
+ cellValue = 0;
5468
+ }
5469
+ if (!___default.isNumber(cellValue)) {
5432
5470
  return;
5433
5471
  }
5434
5472
  const width = columnWidth - 2 * AI_TABLE_CELL_PADDING - AI_TABLE_PROGRESS_TEXT_Width;
@@ -5447,7 +5485,7 @@ class CellDrawer extends Drawer {
5447
5485
  fill: colors.gray200
5448
5486
  });
5449
5487
  // 计算并绘制进度
5450
- const progressWidth = (transformValue / 100) * width;
5488
+ const progressWidth = (cellValue / 100) * width;
5451
5489
  this.rect({
5452
5490
  x: x + offsetX,
5453
5491
  y: y + offsetY,
@@ -5459,7 +5497,7 @@ class CellDrawer extends Drawer {
5459
5497
  this.text({
5460
5498
  x: x + offsetX + width + AI_TABLE_TEXT_GAP,
5461
5499
  y: y + textOffsetY,
5462
- text: `${transformValue}%`,
5500
+ text: `${cellValue}%`,
5463
5501
  fillStyle: colors.gray800
5464
5502
  });
5465
5503
  }
@@ -5563,6 +5601,18 @@ const cellDrawer = new CellDrawer();
5563
5601
  * 它继承自 Layout 类,包含了用于绘制行中单元格(尤其是首列和尾列)的几个方法
5564
5602
  */
5565
5603
  class RecordRowLayout extends Layout {
5604
+ renderAddFieldBlank({ isHoverRow, isCheckedRow }) {
5605
+ super.renderAddFieldBlank({ isHoverRow, isCheckedRow });
5606
+ const rowHeight = this.rowHeight;
5607
+ const startX = this.x + this.columnWidth;
5608
+ const lineWidth = this.containerWidth - startX < AI_TABLE_FIELD_ADD_BUTTON_WIDTH ? AI_TABLE_FIELD_ADD_BUTTON_WIDTH : this.containerWidth - startX;
5609
+ this.line({
5610
+ x: startX,
5611
+ y: this.y,
5612
+ points: [0, rowHeight, lineWidth, rowHeight],
5613
+ stroke: this.colors.gray200
5614
+ });
5615
+ }
5566
5616
  // 首列
5567
5617
  renderFirstCell({ row, style, isHoverRow, isCheckedRow }) {
5568
5618
  if (!this.isFirst)
@@ -5611,6 +5661,9 @@ class RecordRowLayout extends Layout {
5611
5661
  verticalAlign: DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE
5612
5662
  });
5613
5663
  }
5664
+ if (this.isLast) {
5665
+ this.renderAddFieldBlank({ isHoverRow, isCheckedRow });
5666
+ }
5614
5667
  }
5615
5668
  // 尾列
5616
5669
  renderLastCell({ style, isHoverRow, isCheckedRow }) {
@@ -5627,17 +5680,7 @@ class RecordRowLayout extends Layout {
5627
5680
  fill: fill || colors.white,
5628
5681
  stroke: stroke || colors.gray200
5629
5682
  });
5630
- // 延伸到 FIELD_ADD_BUTTON
5631
- super.renderAddFieldBlank({ isHoverRow, isCheckedRow });
5632
- const rowHeight = this.rowHeight;
5633
- const startX = this.x + this.columnWidth;
5634
- const lineWidth = this.containerWidth - startX < AI_TABLE_FIELD_ADD_BUTTON_WIDTH ? AI_TABLE_FIELD_ADD_BUTTON_WIDTH : this.containerWidth - startX;
5635
- this.line({
5636
- x: startX,
5637
- y: this.y,
5638
- points: [0, rowHeight, lineWidth, rowHeight],
5639
- stroke: this.colors.gray200
5640
- });
5683
+ this.renderAddFieldBlank({ isHoverRow, isCheckedRow });
5641
5684
  }
5642
5685
  // 绘制中间的普通单元格
5643
5686
  renderCommonCell({ style }) {
@@ -6140,6 +6183,11 @@ const createColumnHeads = (config) => {
6140
6183
  };
6141
6184
  };
6142
6185
  const fieldHeads = [];
6186
+ const fieldMenus = config.aiTable.context?.aiFieldConfig()?.fieldMenus || [];
6187
+ let noMoreIcon = false;
6188
+ if (fieldMenus.length === 0) {
6189
+ noMoreIcon = true;
6190
+ }
6143
6191
  for (let columnIndex = columnStartIndex; columnIndex <= columnStopIndex; columnIndex++) {
6144
6192
  if (columnIndex > columnCount - 1)
6145
6193
  break;
@@ -6158,7 +6206,7 @@ const createColumnHeads = (config) => {
6158
6206
  height: fieldHeadHeight,
6159
6207
  field,
6160
6208
  stroke: columnIndex === 0 ? colors.transparent : undefined,
6161
- iconVisible,
6209
+ iconVisible: noMoreIcon ? false : iconVisible,
6162
6210
  isSelected,
6163
6211
  isHoverIcon
6164
6212
  };
@@ -6174,8 +6222,8 @@ class AITableFrozenColumnHeads {
6174
6222
  return this.config().coordinate;
6175
6223
  });
6176
6224
  this.isChecked = computed(() => {
6177
- const { selection, records } = this.config().aiTable;
6178
- return selection().selectedRecords.size === records().length;
6225
+ // 目前只需要展示全部选中和空的状态
6226
+ return this.config().aiTable.selection().selectAllState === AITableSelectAllState.all;
6179
6227
  });
6180
6228
  this.fieldHeadHeight = computed(() => {
6181
6229
  return this.coordinate().rowInitSize;
@@ -6889,6 +6937,24 @@ class AITableGrid extends AITableGridBase {
6889
6937
  effect(() => {
6890
6938
  this.setKeywordsMatchedCells();
6891
6939
  }, { allowSignalWrites: true });
6940
+ effect(() => {
6941
+ const recordIdSet = new Set(this.aiTable.records().map((item) => item._id));
6942
+ untracked(() => {
6943
+ const selectedRecords = this.aiTable.selection().selectedRecords;
6944
+ for (const selectedRecordId of selectedRecords.values()) {
6945
+ if (!recordIdSet.has(selectedRecordId)) {
6946
+ selectedRecords.delete(selectedRecordId);
6947
+ }
6948
+ }
6949
+ this.aiTable.selection.update((item) => {
6950
+ return {
6951
+ ...item,
6952
+ selectedRecords,
6953
+ selectAllState: this.aiTableGridSelectionService.selectAllState()
6954
+ };
6955
+ });
6956
+ });
6957
+ }, { allowSignalWrites: true });
6892
6958
  }
6893
6959
  ngOnInit() {
6894
6960
  super.ngOnInit();
@@ -6906,6 +6972,7 @@ class AITableGrid extends AITableGridBase {
6906
6972
  scrollState: signal(DEFAULT_SCROLL_STATE),
6907
6973
  frozenColumnCount: this.frozenColumnCount,
6908
6974
  references: this.aiReferences,
6975
+ aiFieldConfig: this.aiFieldConfig,
6909
6976
  scrollAction: this.scrollAction
6910
6977
  });
6911
6978
  }
@@ -7034,7 +7101,7 @@ class AITableGrid extends AITableGridBase {
7034
7101
  return;
7035
7102
  }
7036
7103
  case AI_TABLE_FIELD_HEAD_SELECT_CHECKBOX: {
7037
- const isChecked = this.aiTable.selection().selectedRecords.size === this.aiTable.records().length;
7104
+ const isChecked = this.aiTable.selection().selectAllState === AITableSelectAllState.all;
7038
7105
  this.toggleSelectAll(!isChecked);
7039
7106
  return;
7040
7107
  }
@@ -7223,5 +7290,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
7223
7290
  * Generated bundle index. Do not edit.
7224
7291
  */
7225
7292
 
7226
- export { AITable, AITableAreaType, AITableAvatarSize, AITableAvatarType, AITableCheckType, AITableContextMenu, AITableDomGrid, AITableFieldIsMultiplePipe, AITableFieldSetting, AITableFieldType, AITableFilterOperation, AITableGrid, AITableGridEventService, AITableGridFieldService, AITableGridSelectionService, AITableMemberType, AITableMouseDownType, AITableQueries, AITableRenderer, AITableRowColumnType, AITableRowType, AITableSelectOptionStyle, AITableStatType, AI_TABLE_ACTION_COMMON_SIZE, AI_TABLE_BLANK, AI_TABLE_CELL, AI_TABLE_CELL_ACTIVE_BORDER_WIDTH, AI_TABLE_CELL_ADD_ITEM_BUTTON_SIZE, AI_TABLE_CELL_BORDER, AI_TABLE_CELL_DELETE_ITEM_BUTTON_SIZE, AI_TABLE_CELL_DELETE_ITEM_BUTTON_SIZE_OFFSET, AI_TABLE_CELL_EMOJI_PADDING, AI_TABLE_CELL_EMOJI_SIZE, AI_TABLE_CELL_MAX_ROW_COUNT, AI_TABLE_CELL_MEMBER_ITEM_HEIGHT, AI_TABLE_CELL_MEMBER_ITEM_PADDING, AI_TABLE_CELL_MEMBER_MAX_HEIGHT, AI_TABLE_CELL_MULTI_DOT_RADIUS, AI_TABLE_CELL_MULTI_ITEM_MARGIN_LEFT, AI_TABLE_CELL_MULTI_ITEM_MARGIN_TOP, AI_TABLE_CELL_MULTI_ITEM_MIN_WIDTH, AI_TABLE_CELL_MULTI_PADDING_LEFT, AI_TABLE_CELL_MULTI_PADDING_TOP, AI_TABLE_CELL_PADDING, AI_TABLE_COMMON_FONT_SIZE, AI_TABLE_DEFAULT_COLUMN_WIDTH, AI_TABLE_DOT_RADIUS, AI_TABLE_FIELD_ADD_BUTTON, AI_TABLE_FIELD_ADD_BUTTON_WIDTH, AI_TABLE_FIELD_HEAD, AI_TABLE_FIELD_HEAD_HEIGHT, AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE, AI_TABLE_FIELD_HEAD_MORE, AI_TABLE_FIELD_HEAD_SELECT_CHECKBOX, AI_TABLE_FIELD_HEAD_TEXT_MIN_WIDTH, AI_TABLE_GRID_FIELD_SERVICE_MAP, AI_TABLE_ICON_COMMON_SIZE, AI_TABLE_MEMBER_AVATAR_SIZE, AI_TABLE_MEMBER_ITEM_AVATAR_MARGIN_RIGHT, AI_TABLE_MEMBER_ITEM_PADDING_RIGHT, AI_TABLE_MIN_TEXT_WIDTH, AI_TABLE_OFFSET, AI_TABLE_OPTION_ITEM_FONT_SIZE, AI_TABLE_OPTION_ITEM_HEIGHT, AI_TABLE_OPTION_ITEM_PADDING, AI_TABLE_OPTION_ITEM_RADIUS, AI_TABLE_PIECE_RADIUS, AI_TABLE_PIECE_WIDTH, AI_TABLE_POPOVER_LEFT_OFFSET, AI_TABLE_PREVENT_CLEAR_SELECTION_CLASS, AI_TABLE_PROGRESS_BAR_HEIGHT, AI_TABLE_PROGRESS_BAR_RADIUS, AI_TABLE_PROGRESS_TEXT_Width, AI_TABLE_ROW_ADD_BUTTON, AI_TABLE_ROW_BLANK_HEIGHT, AI_TABLE_ROW_HEAD, AI_TABLE_ROW_HEAD_SIZE, AI_TABLE_ROW_HEAD_WIDTH, AI_TABLE_ROW_HEIGHT, AI_TABLE_ROW_SELECT_CHECKBOX, AI_TABLE_SCROLL_BAR_PADDING, AI_TABLE_TAG_FONT_SIZE, AI_TABLE_TAG_PADDING, AI_TABLE_TEXT_GAP, AbstractEditCellEditor, AddOutlinedPath, Check, Colors, ColumnCalendarFilledPath, ColumnLinkOutlinedPath, ColumnMemberFilledPath, ColumnMultipleFillPath, ColumnNumberFilledPath, ColumnProgressFilledPath, ColumnRatingFilledPath, ColumnSelectFilledPath, ColumnTextFilledPath, Coordinate, DBL_CLICK_EDIT_TYPE, DEFAULT_FONT_FAMILY, DEFAULT_FONT_SIZE, DEFAULT_FONT_STYLE, DEFAULT_FONT_WEIGHT, DEFAULT_ICON_SHAPE, DEFAULT_ICON_SIZE, DEFAULT_POINT_POSITION, DEFAULT_SCROLL_STATE, DEFAULT_TEXT_ALIGN_CENTER, DEFAULT_TEXT_ALIGN_LEFT, DEFAULT_TEXT_ALIGN_RIGHT, DEFAULT_TEXT_DECORATION, DEFAULT_TEXT_ELLIPSIS, DEFAULT_TEXT_FILL, DEFAULT_TEXT_LINE_HEIGHT, DEFAULT_TEXT_LISTENING, DEFAULT_TEXT_MAX_CACHE, DEFAULT_TEXT_MAX_HEIGHT, DEFAULT_TEXT_SCALE, DEFAULT_TEXT_TRANSFORMS_ENABLED, DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE, DEFAULT_TEXT_VERTICAL_ALIGN_TOP, DEFAULT_TEXT_WRAP, DEFAULT_WRAP_TEXT_MAX_ROW, DateCellEditorComponent, DepartmentOutlinedPath, Direction, FONT_SIZE_SM, FieldOptions, GRID_CELL_EDITOR_MAP, IsSelectRecordPipe, LinkCellEditorComponent, MIN_COLUMN_WIDTH, MOUSEOVER_EDIT_TYPE, MemberSettingPipe, MoreStandOutlinedPath, NumberCellEditorComponent, ProgressEditorComponent, RatingCellEditorComponent, RendererContext, RowHeight, SelectCellEditorComponent, SelectOptionComponent, SelectOptionPipe, SelectOptionsPipe, SelectSettingPipe, StarFill, TextCellEditorComponent, TextMeasure, Unchecked, UserPipe, ViewOperationMap, WebOutlinedPath, buildGridData, buildGridLinearRows, castToString, compareNumber, compareString, createAITable, createActiveCellBorder, createCells, createDefaultField, createDefaultFieldName, generateTargetName, getAvatarBgColor, getAvatarShortName, getCellEditorBorderSpace, getCellHorizontalPosition, getColumnIndicesSizeMap, getDefaultFieldValue, getDetailByTargetName, getEditorBoxOffset, getEditorSpace, getFieldOptionByField, getHoverEditorBoxOffset, getHoverEditorSpace, getMousePosition, getPlaceHolderCellsConfigs, getTargetName, getTextWidth, getVisibleRangeInfo, handleMouseStyle, hasIntersect, idCreator, idsCreator, imageCache, isArrayField, isCellMatchKeywords, isEmpty, isMac, isNumberFiled, isSameFieldOption, isSystemField, isWindows, isWindowsOS, isWithinFrozenColumnBoundary, scrollMax, setMouseStyle, shortIdCreator, shortIdsCreator, stringInclude, textDataCache, transformCellValue, zhIntlCollator };
7293
+ export { AITable, AITableAreaType, AITableAvatarSize, AITableAvatarType, AITableCheckType, AITableContextMenu, AITableDomGrid, AITableFieldIsMultiplePipe, AITableFieldSetting, AITableFieldType, AITableFilterOperation, AITableGrid, AITableGridEventService, AITableGridFieldService, AITableGridSelectionService, AITableMemberType, AITableMouseDownType, AITableQueries, AITableRenderer, AITableRowColumnType, AITableRowType, AITableSelectAllState, AITableSelectOptionStyle, AITableStatType, AI_TABLE_ACTION_COMMON_SIZE, AI_TABLE_BLANK, AI_TABLE_CELL, AI_TABLE_CELL_ACTIVE_BORDER_WIDTH, AI_TABLE_CELL_ADD_ITEM_BUTTON_SIZE, AI_TABLE_CELL_BORDER, AI_TABLE_CELL_DELETE_ITEM_BUTTON_SIZE, AI_TABLE_CELL_DELETE_ITEM_BUTTON_SIZE_OFFSET, AI_TABLE_CELL_EMOJI_PADDING, AI_TABLE_CELL_EMOJI_SIZE, AI_TABLE_CELL_MAX_ROW_COUNT, AI_TABLE_CELL_MEMBER_ITEM_HEIGHT, AI_TABLE_CELL_MEMBER_ITEM_PADDING, AI_TABLE_CELL_MEMBER_MAX_HEIGHT, AI_TABLE_CELL_MULTI_DOT_RADIUS, AI_TABLE_CELL_MULTI_ITEM_MARGIN_LEFT, AI_TABLE_CELL_MULTI_ITEM_MARGIN_TOP, AI_TABLE_CELL_MULTI_ITEM_MIN_WIDTH, AI_TABLE_CELL_MULTI_PADDING_LEFT, AI_TABLE_CELL_MULTI_PADDING_TOP, AI_TABLE_CELL_PADDING, AI_TABLE_COMMON_FONT_SIZE, AI_TABLE_DEFAULT_COLUMN_WIDTH, AI_TABLE_DOT_RADIUS, AI_TABLE_FIELD_ADD_BUTTON, AI_TABLE_FIELD_ADD_BUTTON_WIDTH, AI_TABLE_FIELD_HEAD, AI_TABLE_FIELD_HEAD_HEIGHT, AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE, AI_TABLE_FIELD_HEAD_MORE, AI_TABLE_FIELD_HEAD_SELECT_CHECKBOX, AI_TABLE_FIELD_HEAD_TEXT_MIN_WIDTH, AI_TABLE_GRID_FIELD_SERVICE_MAP, AI_TABLE_ICON_COMMON_SIZE, AI_TABLE_MEMBER_AVATAR_SIZE, AI_TABLE_MEMBER_ITEM_AVATAR_MARGIN_RIGHT, AI_TABLE_MEMBER_ITEM_PADDING_RIGHT, AI_TABLE_MIN_TEXT_WIDTH, AI_TABLE_OFFSET, AI_TABLE_OPTION_ITEM_FONT_SIZE, AI_TABLE_OPTION_ITEM_HEIGHT, AI_TABLE_OPTION_ITEM_PADDING, AI_TABLE_OPTION_ITEM_RADIUS, AI_TABLE_PIECE_RADIUS, AI_TABLE_PIECE_WIDTH, AI_TABLE_POPOVER_LEFT_OFFSET, AI_TABLE_PREVENT_CLEAR_SELECTION_CLASS, AI_TABLE_PROGRESS_BAR_HEIGHT, AI_TABLE_PROGRESS_BAR_RADIUS, AI_TABLE_PROGRESS_TEXT_Width, AI_TABLE_ROW_ADD_BUTTON, AI_TABLE_ROW_BLANK_HEIGHT, AI_TABLE_ROW_HEAD, AI_TABLE_ROW_HEAD_SIZE, AI_TABLE_ROW_HEAD_WIDTH, AI_TABLE_ROW_HEIGHT, AI_TABLE_ROW_SELECT_CHECKBOX, AI_TABLE_SCROLL_BAR_PADDING, AI_TABLE_TAG_FONT_SIZE, AI_TABLE_TAG_PADDING, AI_TABLE_TEXT_GAP, AbstractEditCellEditor, AddOutlinedPath, Check, Colors, ColumnCalendarFilledPath, ColumnLinkOutlinedPath, ColumnMemberFilledPath, ColumnMultipleFillPath, ColumnNumberFilledPath, ColumnProgressFilledPath, ColumnRatingFilledPath, ColumnSelectFilledPath, ColumnTextFilledPath, Coordinate, DBL_CLICK_EDIT_TYPE, DEFAULT_FONT_FAMILY, DEFAULT_FONT_SIZE, DEFAULT_FONT_STYLE, DEFAULT_FONT_WEIGHT, DEFAULT_ICON_SHAPE, DEFAULT_ICON_SIZE, DEFAULT_POINT_POSITION, DEFAULT_SCROLL_STATE, DEFAULT_TEXT_ALIGN_CENTER, DEFAULT_TEXT_ALIGN_LEFT, DEFAULT_TEXT_ALIGN_RIGHT, DEFAULT_TEXT_DECORATION, DEFAULT_TEXT_ELLIPSIS, DEFAULT_TEXT_FILL, DEFAULT_TEXT_LINE_HEIGHT, DEFAULT_TEXT_LISTENING, DEFAULT_TEXT_MAX_CACHE, DEFAULT_TEXT_MAX_HEIGHT, DEFAULT_TEXT_SCALE, DEFAULT_TEXT_TRANSFORMS_ENABLED, DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE, DEFAULT_TEXT_VERTICAL_ALIGN_TOP, DEFAULT_TEXT_WRAP, DEFAULT_WRAP_TEXT_MAX_ROW, DateCellEditorComponent, DepartmentOutlinedPath, Direction, FONT_SIZE_SM, FieldOptions, GRID_CELL_EDITOR_MAP, IsSelectRecordPipe, LinkCellEditorComponent, MIN_COLUMN_WIDTH, MOUSEOVER_EDIT_TYPE, MemberSettingPipe, MoreStandOutlinedPath, NumberCellEditorComponent, ProgressEditorComponent, RatingCellEditorComponent, RendererContext, RowHeight, SelectCellEditorComponent, SelectOptionComponent, SelectOptionPipe, SelectOptionsPipe, SelectSettingPipe, StarFill, TextCellEditorComponent, TextMeasure, Unchecked, UserPipe, ViewOperationMap, WebOutlinedPath, buildGridData, buildGridLinearRows, castToString, compareNumber, compareString, createAITable, createActiveCellBorder, createCells, createDefaultField, createDefaultFieldName, generateTargetName, getAvatarBgColor, getAvatarShortName, getCellEditorBorderSpace, getCellHorizontalPosition, getColumnIndicesSizeMap, getDefaultFieldValue, getDetailByTargetName, getEditorBoxOffset, getEditorSpace, getFieldOptionByField, getHoverEditorBoxOffset, getHoverEditorSpace, getMousePosition, getPlaceHolderCellsConfigs, getTargetName, getTextWidth, getVisibleRangeInfo, handleMouseStyle, hasIntersect, idCreator, idsCreator, imageCache, isArrayField, isCellMatchKeywords, isEmpty, isMac, isNumberFiled, isSameFieldOption, isSystemField, isWindows, isWindowsOS, isWithinFrozenColumnBoundary, scrollMax, setMouseStyle, shortIdCreator, shortIdsCreator, stringInclude, textDataCache, transformCellValue, zhIntlCollator };
7227
7294
  //# sourceMappingURL=ai-table-grid.mjs.map