@ai-table/grid 0.0.34 → 0.0.36
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/core/utils/common.d.ts.map +1 -1
- package/esm2022/components/cell-editors/link/link-editor.component.mjs +3 -3
- package/esm2022/core/utils/common.mjs +4 -2
- package/esm2022/grid.component.mjs +22 -4
- package/esm2022/renderer/components/cells/cells.mjs +6 -0
- package/esm2022/renderer/components/cells/index.mjs +2 -0
- package/esm2022/renderer/components/cells/link.component.mjs +90 -0
- package/esm2022/renderer/components/field-head.component.mjs +2 -2
- package/esm2022/renderer/components/frozen-heads.component.mjs +4 -4
- package/esm2022/renderer/components/hover-cell.component.mjs +103 -0
- package/esm2022/renderer/components/index.mjs +2 -1
- package/esm2022/renderer/components/text.component.mjs +13 -4
- package/esm2022/renderer/creations/create-cells.mjs +9 -3
- package/esm2022/renderer/drawers/cell-drawer.mjs +22 -6
- package/esm2022/renderer/interfaces/hover-cell.mjs +4 -0
- package/esm2022/renderer/interfaces/index.mjs +2 -0
- package/esm2022/renderer/renderer.component.mjs +8 -4
- package/esm2022/services/selection.service.mjs +33 -10
- package/esm2022/types/cell.mjs +1 -1
- package/esm2022/types/component-config.mjs +1 -1
- package/esm2022/types/grid.mjs +7 -1
- package/esm2022/utils/get-placeholder-cells.mjs +5 -5
- package/esm2022/utils/hover-cell.mjs +31 -0
- package/esm2022/utils/index.mjs +2 -1
- package/fesm2022/ai-table-grid.mjs +1246 -954
- package/fesm2022/ai-table-grid.mjs.map +1 -1
- package/grid.component.d.ts.map +1 -1
- package/package.json +1 -1
- package/renderer/components/cells/cells.d.ts +5 -0
- package/renderer/components/cells/cells.d.ts.map +1 -0
- package/renderer/components/cells/index.d.ts +2 -0
- package/renderer/components/cells/index.d.ts.map +1 -0
- package/renderer/components/cells/link.component.d.ts +23 -0
- package/renderer/components/cells/link.component.d.ts.map +1 -0
- package/renderer/components/frozen-heads.component.d.ts.map +1 -1
- package/renderer/components/hover-cell.component.d.ts +23 -0
- package/renderer/components/hover-cell.component.d.ts.map +1 -0
- package/renderer/components/index.d.ts +1 -0
- package/renderer/components/index.d.ts.map +1 -1
- package/renderer/components/text.component.d.ts +6 -1
- package/renderer/components/text.component.d.ts.map +1 -1
- package/renderer/creations/create-cells.d.ts +2 -0
- package/renderer/creations/create-cells.d.ts.map +1 -1
- package/renderer/drawers/cell-drawer.d.ts.map +1 -1
- package/renderer/interfaces/hover-cell.d.ts +8 -0
- package/renderer/interfaces/hover-cell.d.ts.map +1 -0
- package/renderer/interfaces/index.d.ts +2 -0
- package/renderer/interfaces/index.d.ts.map +1 -0
- package/renderer/renderer.component.d.ts.map +1 -1
- package/services/selection.service.d.ts +2 -0
- package/services/selection.service.d.ts.map +1 -1
- package/types/cell.d.ts +1 -0
- package/types/cell.d.ts.map +1 -1
- package/types/component-config.d.ts +10 -0
- package/types/component-config.d.ts.map +1 -1
- package/types/grid.d.ts +6 -0
- package/types/grid.d.ts.map +1 -1
- package/utils/hover-cell.d.ts +8 -0
- package/utils/hover-cell.d.ts.map +1 -0
- package/utils/index.d.ts +1 -0
- package/utils/index.d.ts.map +1 -1
@@ -104,7 +104,7 @@ export class AITableFieldHead {
|
|
104
104
|
}
|
105
105
|
</ko-group>
|
106
106
|
</ko-group>
|
107
|
-
`, isInline: true, dependencies: [{ kind: "component", type: KoContainer, selector: "ko-layer, ko-fastlayer, ko-group" }, { kind: "component", type: KoShape, selector: "ko-shape, ko-circle, ko-label, ko-rect, ko-ellipse, ko-wedge, ko-line, ko-sprite, ko-image, ko-text, ko-text-path, ko-star, ko-ring, ko-arc, ko-tag, ko-path, ko-regular-polygon, ko-arrow, ko-transformer", inputs: ["config"], outputs: ["koMouseover", "koMousemove", "koMouseout", "koMouseenter", "koMouseleave", "koMousedown", "koMouseup", "koWheel", "koContextmenu", "koClick", "koDblclick", "koTouchstart", "koTouchmove", "koTouchend", "koTap", "koDbltap", "koDragstart", "koDragmove", "koDragend"] }, { kind: "component", type: AITableFieldIcon, selector: "ai-table-field-icon", inputs: ["config"] }, { kind: "component", type: AITableText, selector: "ai-table-text", inputs: ["config"] }, { kind: "component", type: AITableIcon, selector: "ai-table-icon", inputs: ["config"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
107
|
+
`, isInline: true, dependencies: [{ kind: "component", type: KoContainer, selector: "ko-layer, ko-fastlayer, ko-group" }, { kind: "component", type: KoShape, selector: "ko-shape, ko-circle, ko-label, ko-rect, ko-ellipse, ko-wedge, ko-line, ko-sprite, ko-image, ko-text, ko-text-path, ko-star, ko-ring, ko-arc, ko-tag, ko-path, ko-regular-polygon, ko-arrow, ko-transformer", inputs: ["config"], outputs: ["koMouseover", "koMousemove", "koMouseout", "koMouseenter", "koMouseleave", "koMousedown", "koMouseup", "koWheel", "koContextmenu", "koClick", "koDblclick", "koTouchstart", "koTouchmove", "koTouchend", "koTap", "koDbltap", "koDragstart", "koDragmove", "koDragend"] }, { kind: "component", type: AITableFieldIcon, selector: "ai-table-field-icon", inputs: ["config"] }, { kind: "component", type: AITableText, selector: "ai-table-text", inputs: ["config"], outputs: ["koClick", "koMouseMove"] }, { kind: "component", type: AITableIcon, selector: "ai-table-icon", inputs: ["config"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
108
108
|
}
|
109
109
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableFieldHead, decorators: [{
|
110
110
|
type: Component,
|
@@ -127,4 +127,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
127
127
|
changeDetection: ChangeDetectionStrategy.OnPush
|
128
128
|
}]
|
129
129
|
}] });
|
130
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"field-head.component.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/components/field-head.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';\nimport { StageConfig } from 'konva/lib/Stage';\nimport { KoContainer, KoShape, KoStage } from '../../angular-konva';\nimport {\n    AI_TABLE_ACTION_COMMON_SIZE,\n    AI_TABLE_CELL_PADDING,\n    AI_TABLE_FIELD_HEAD,\n    AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE,\n    AI_TABLE_FIELD_HEAD_MORE,\n    AI_TABLE_FIELD_HEAD_TEXT_MIN_WIDTH,\n    AI_TABLE_ICON_COMMON_SIZE,\n    AI_TABLE_OFFSET,\n    Colors,\n    DEFAULT_FONT_SIZE,\n    MoreStandOutlinedPath\n} from '../../constants';\nimport { AITableFieldHeadConfig } from '../../types';\nimport { generateTargetName, TextMeasure } from '../../utils';\nimport { AITableFieldIcon } from './field-icon.component';\nimport { AITableIcon } from './icon.component';\nimport { AITableText } from './text.component';\n\n@Component({\n    selector: 'ai-table-field-head',\n    template: `\n        <ko-group [config]=\"groupConfig()\">\n            <ko-rect [config]=\"bgConfig()\"></ko-rect>\n            <ko-group>\n                <ai-table-field-icon [config]=\"fieldIconConfig()\"></ai-table-field-icon>\n                <ai-table-text [config]=\"textConfig()\"></ai-table-text>\n                @if (config().iconVisible) {\n                    <ai-table-icon [config]=\"moreIconConfig()\"></ai-table-icon>\n                }\n            </ko-group>\n        </ko-group>\n    `,\n    standalone: true,\n    imports: [KoContainer, KoShape, AITableFieldIcon, AITableText, AITableIcon],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableFieldHead {\n    config = input.required<AITableFieldHeadConfig>();\n\n    textOffset = AI_TABLE_CELL_PADDING + AI_TABLE_ICON_COMMON_SIZE + AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE;\n\n    textMeasure = TextMeasure();\n\n    availableTextWidth = computed(() => {\n        const { width, iconVisible } = this.config();\n        return (\n            width -\n            (iconVisible\n                ? 2 * (AI_TABLE_CELL_PADDING + AI_TABLE_ICON_COMMON_SIZE + AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE)\n                : 2 * AI_TABLE_CELL_PADDING + AI_TABLE_ICON_COMMON_SIZE + AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE)\n        );\n    });\n\n    textData = computed(() => {\n        const fieldName = this.config().field.name.replace(/\\r|\\n/g, ' ');\n        this.textMeasure.setFont({ fontSize: DEFAULT_FONT_SIZE });\n        const { width, height, isOverflow } = this.textMeasure.measureText(fieldName, this.availableTextWidth(), 1);\n        return {\n            width: Math.min(width, this.availableTextWidth()),\n            height,\n            isOverflow\n        };\n    });\n\n    groupConfig = computed<Partial<StageConfig>>(() => {\n        return {\n            x: this.config().x,\n            y: this.config().y\n        };\n    });\n\n    bgConfig = computed(() => {\n        const { field, width, height, stroke, isSelected, iconVisible } = this.config();\n        return {\n            x: AI_TABLE_OFFSET,\n            y: AI_TABLE_OFFSET,\n            name: generateTargetName({\n                targetName: AI_TABLE_FIELD_HEAD,\n                fieldId: field._id\n            }),\n            width: width,\n            height: height,\n            fill: isSelected ? Colors.headSelectedBgColor : iconVisible ? Colors.gray80 : Colors.white,\n            stroke: stroke || Colors.gray200,\n            strokeWidth: 1,\n            opacity: 1\n        };\n    });\n\n    fieldIconConfig = computed(() => {\n        const { field, height } = this.config();\n        return {\n            field: field,\n            x: AI_TABLE_CELL_PADDING,\n            y: (height - AI_TABLE_ICON_COMMON_SIZE) / 2,\n            width: AI_TABLE_ICON_COMMON_SIZE,\n            height: AI_TABLE_ICON_COMMON_SIZE,\n            fill: Colors.gray600\n        };\n    });\n\n    textConfig = computed(() => {\n        const { field, height } = this.config();\n        return {\n            x: this.textOffset,\n            y: undefined,\n            width: Math.max(this.textData().width, AI_TABLE_FIELD_HEAD_TEXT_MIN_WIDTH),\n            height: height + 2,\n            text: field.name,\n            lineHeight: 1.84\n        };\n    });\n\n    moreIconConfig = computed(() => {\n        const { field, width, height, isHoverIcon, isSelected } = this.config();\n        const commonIconOffsetY = (height - AI_TABLE_ACTION_COMMON_SIZE) / 2;\n        return {\n            name: generateTargetName({\n                targetName: AI_TABLE_FIELD_HEAD_MORE,\n                fieldId: field._id\n            }),\n            x: width - AI_TABLE_ACTION_COMMON_SIZE,\n            y: commonIconOffsetY,\n            data: MoreStandOutlinedPath,\n            fill: isHoverIcon ? Colors.primary : Colors.gray600,\n            background: Colors.transparent,\n            backgroundWidth: AI_TABLE_ACTION_COMMON_SIZE,\n            backgroundHeight: AI_TABLE_ACTION_COMMON_SIZE,\n            cornerRadius: 4\n        };\n    });\n}\n"]}
|
130
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"field-head.component.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/components/field-head.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';\nimport { StageConfig } from 'konva/lib/Stage';\nimport { KoContainer, KoShape, KoStage } from '../../angular-konva';\nimport {\n    AI_TABLE_ACTION_COMMON_SIZE,\n    AI_TABLE_CELL_PADDING,\n    AI_TABLE_FIELD_HEAD,\n    AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE,\n    AI_TABLE_FIELD_HEAD_MORE,\n    AI_TABLE_FIELD_HEAD_TEXT_MIN_WIDTH,\n    AI_TABLE_ICON_COMMON_SIZE,\n    AI_TABLE_OFFSET,\n    Colors,\n    DEFAULT_FONT_SIZE,\n    MoreStandOutlinedPath\n} from '../../constants';\nimport { AITableFieldHeadConfig } from '../../types';\nimport { generateTargetName, TextMeasure } from '../../utils';\nimport { AITableFieldIcon } from './field-icon.component';\nimport { AITableIcon } from './icon.component';\nimport { AITableText } from './text.component';\n\n@Component({\n    selector: 'ai-table-field-head',\n    template: `\n        <ko-group [config]=\"groupConfig()\">\n            <ko-rect [config]=\"bgConfig()\"></ko-rect>\n            <ko-group>\n                <ai-table-field-icon [config]=\"fieldIconConfig()\"></ai-table-field-icon>\n                <ai-table-text [config]=\"textConfig()\"></ai-table-text>\n                @if (config().iconVisible) {\n                    <ai-table-icon [config]=\"moreIconConfig()\"></ai-table-icon>\n                }\n            </ko-group>\n        </ko-group>\n    `,\n    standalone: true,\n    imports: [KoContainer, KoShape, AITableFieldIcon, AITableText, AITableIcon],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableFieldHead {\n    config = input.required<AITableFieldHeadConfig>();\n\n    textOffset = AI_TABLE_CELL_PADDING + AI_TABLE_ICON_COMMON_SIZE + AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE;\n\n    textMeasure = TextMeasure();\n\n    availableTextWidth = computed(() => {\n        const { width, iconVisible } = this.config();\n        return (\n            width -\n            (iconVisible\n                ? 2 * (AI_TABLE_CELL_PADDING + AI_TABLE_ICON_COMMON_SIZE + AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE)\n                : 2 * AI_TABLE_CELL_PADDING + AI_TABLE_ICON_COMMON_SIZE + AI_TABLE_FIELD_HEAD_ICON_GAP_SIZE)\n        );\n    });\n\n    textData = computed(() => {\n        const fieldName = this.config().field.name.replace(/\\r|\\n/g, ' ');\n        this.textMeasure.setFont({ fontSize: DEFAULT_FONT_SIZE });\n        const { width, height, isOverflow } = this.textMeasure.measureText(fieldName, this.availableTextWidth(), 1);\n        return {\n            width: Math.min(width, this.availableTextWidth()),\n            height,\n            isOverflow\n        };\n    });\n\n    groupConfig = computed<Partial<StageConfig>>(() => {\n        return {\n            x: this.config().x,\n            y: this.config().y\n        };\n    });\n\n    bgConfig = computed(() => {\n        const { field, width, height, stroke, isSelected, iconVisible } = this.config();\n        return {\n            x: AI_TABLE_OFFSET,\n            y: AI_TABLE_OFFSET,\n            name: generateTargetName({\n                targetName: AI_TABLE_FIELD_HEAD,\n                fieldId: field._id\n            }),\n            width: width,\n            height: height,\n            fill: isSelected ? Colors.headSelectedBgColor : iconVisible ? Colors.gray80 : Colors.white,\n            stroke: stroke || Colors.gray200,\n            strokeWidth: 1,\n            opacity: 1\n        };\n    });\n\n    fieldIconConfig = computed(() => {\n        const { field, height } = this.config();\n        return {\n            field: field,\n            x: AI_TABLE_CELL_PADDING,\n            y: (height - AI_TABLE_ICON_COMMON_SIZE) / 2,\n            width: AI_TABLE_ICON_COMMON_SIZE,\n            height: AI_TABLE_ICON_COMMON_SIZE,\n            fill: Colors.gray600\n        };\n    });\n\n    textConfig = computed(() => {\n        const { field, height } = this.config();\n        return {\n            x: this.textOffset,\n            y: undefined,\n            width: Math.max(this.textData().width, AI_TABLE_FIELD_HEAD_TEXT_MIN_WIDTH),\n            height: height + 2,\n            text: field.name,\n            lineHeight: 1.84\n        };\n    });\n\n    moreIconConfig = computed(() => {\n        const { field, width, height, isHoverIcon, isSelected } = this.config();\n        const commonIconOffsetY = (height - AI_TABLE_ACTION_COMMON_SIZE) / 2;\n        return {\n            name: generateTargetName({\n                targetName: AI_TABLE_FIELD_HEAD_MORE,\n                fieldId: field._id\n            }),\n            x: width - AI_TABLE_ACTION_COMMON_SIZE,\n            y: commonIconOffsetY,\n            data: MoreStandOutlinedPath,\n            fill: isHoverIcon ? Colors.primary : Colors.gray600,\n            background: Colors.transparent,\n            backgroundWidth: AI_TABLE_ACTION_COMMON_SIZE,\n            backgroundHeight: AI_TABLE_ACTION_COMMON_SIZE,\n            cornerRadius: 4\n        };\n    });\n}\n"]}
|
@@ -1,7 +1,7 @@
|
|
1
1
|
import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';
|
2
2
|
import { KoShape, KoContainer } from '../../angular-konva';
|
3
3
|
import { AI_TABLE_CELL_PADDING, AI_TABLE_FIELD_HEAD_SELECT_CHECKBOX, AI_TABLE_ICON_COMMON_SIZE, AI_TABLE_OFFSET, AI_TABLE_ROW_HEAD_WIDTH, Colors } from '../../constants';
|
4
|
-
import { AITableCheckType } from '../../types';
|
4
|
+
import { AITableCheckType, AITableSelectAllState } from '../../types';
|
5
5
|
import { createColumnHeads } from '../creations/create-heads';
|
6
6
|
import { AITableFieldHead } from './field-head.component';
|
7
7
|
import { AITableIcon } from './icon.component';
|
@@ -13,8 +13,8 @@ export class AITableFrozenColumnHeads {
|
|
13
13
|
return this.config().coordinate;
|
14
14
|
});
|
15
15
|
this.isChecked = computed(() => {
|
16
|
-
|
17
|
-
return selection().
|
16
|
+
// 目前只需要展示全部选中和空的状态
|
17
|
+
return this.config().aiTable.selection().selectAllState === AITableSelectAllState.all;
|
18
18
|
});
|
19
19
|
this.fieldHeadHeight = computed(() => {
|
20
20
|
return this.coordinate().rowInitSize;
|
@@ -114,4 +114,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
114
114
|
changeDetection: ChangeDetectionStrategy.OnPush
|
115
115
|
}]
|
116
116
|
}] });
|
117
|
-
//# sourceMappingURL=data:application/json;base64,
|
117
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"frozen-heads.component.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/components/frozen-heads.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';\nimport { StageConfig } from 'konva/lib/Stage';\nimport { KoShape, KoContainer } from '../../angular-konva';\nimport {\n    AI_TABLE_CELL_PADDING,\n    AI_TABLE_FIELD_HEAD_SELECT_CHECKBOX,\n    AI_TABLE_ICON_COMMON_SIZE,\n    AI_TABLE_OFFSET,\n    AI_TABLE_ROW_HEAD_WIDTH,\n    Colors\n} from '../../constants';\nimport { AITableCheckType, AITableColumnHeadsConfig, AITableSelectAllState } from '../../types';\nimport { createColumnHeads } from '../creations/create-heads';\nimport { AITableFieldHead } from './field-head.component';\nimport { AITableIcon } from './icon.component';\n\n@Component({\n    selector: 'ai-table-frozen-column-heads',\n    template: `\n        <ko-rect [config]=\"numberHeadBgConfig()\"></ko-rect>\n        <ko-line [config]=\"topLineConfig\"></ko-line>\n        <ko-line [config]=\"bottomLineConfig()\"></ko-line>\n        <ko-group>\n            <ai-table-icon [config]=\"iconConfig()\"></ai-table-icon>\n        </ko-group>\n        @for (config of headConfigs(); track $index) {\n            <ai-table-field-head [config]=\"config\"></ai-table-field-head>\n        }\n        <ko-rect [config]=\"headBgConfig()\"></ko-rect>\n    `,\n    standalone: true,\n    imports: [KoShape, AITableFieldHead, AITableIcon, KoContainer],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableFrozenColumnHeads {\n    config = input.required<AITableColumnHeadsConfig>();\n\n    coordinate = computed(() => {\n        return this.config().coordinate;\n    });\n\n    isChecked = computed(() => {\n        // 目前只需要展示全部选中和空的状态\n        return this.config().aiTable.selection().selectAllState === AITableSelectAllState.all;\n    });\n\n    fieldHeadHeight = computed(() => {\n        return this.coordinate().rowInitSize;\n    });\n\n    headConfigs = computed(() => {\n        return createColumnHeads({\n            ...this.config(),\n            columnStartIndex: 0,\n            columnStopIndex: this.coordinate().frozenColumnCount - 1\n        });\n    });\n\n    numberHeadBgConfig = computed<Partial<StageConfig>>(() => {\n        return {\n            x: AI_TABLE_OFFSET,\n            y: AI_TABLE_OFFSET,\n            width: AI_TABLE_ROW_HEAD_WIDTH,\n            height: this.fieldHeadHeight(),\n            fill: Colors.white,\n            listening: false\n        };\n    });\n\n    topLineConfig = {\n        x: AI_TABLE_OFFSET,\n        y: AI_TABLE_OFFSET,\n        points: [0, 0, AI_TABLE_ROW_HEAD_WIDTH, 0],\n        stroke: Colors.gray200,\n        strokeWidth: 1,\n        listening: false\n    };\n\n    bottomLineConfig = computed(() => {\n        return {\n            x: AI_TABLE_OFFSET,\n            y: AI_TABLE_OFFSET,\n            points: [AI_TABLE_ROW_HEAD_WIDTH, this.fieldHeadHeight(), 0, this.fieldHeadHeight()],\n            stroke: Colors.gray200,\n            strokeWidth: 1,\n            listening: false\n        };\n    });\n\n    iconConfig = computed(() => {\n        return {\n            name: AI_TABLE_FIELD_HEAD_SELECT_CHECKBOX,\n            x: AI_TABLE_CELL_PADDING,\n            y: (this.fieldHeadHeight() - AI_TABLE_ICON_COMMON_SIZE) / 2,\n            type: this.isChecked() ? AITableCheckType.checked : AITableCheckType.unchecked,\n            fill:\n                this.isChecked() || (this.config().pointPosition.targetName === AI_TABLE_FIELD_HEAD_SELECT_CHECKBOX && !this.isChecked())\n                    ? Colors.primary\n                    : Colors.gray300\n        };\n    });\n\n    headBgConfig = computed(() => {\n        const { frozenColumnWidth } = this.coordinate();\n        return {\n            x: AI_TABLE_ROW_HEAD_WIDTH,\n            y: AI_TABLE_OFFSET,\n            width: frozenColumnWidth + AI_TABLE_OFFSET,\n            height: this.fieldHeadHeight(),\n            stroke: Colors.gray200,\n            strokeWidth: 1,\n            fill: Colors.transparent,\n            listening: false\n        };\n    });\n}\n"]}
|
@@ -0,0 +1,103 @@
|
|
1
|
+
import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';
|
2
|
+
import { KoContainer, KoShape } from '../../angular-konva';
|
3
|
+
import { AITableQueries } from '../../core';
|
4
|
+
import { CommonModule } from '@angular/common';
|
5
|
+
import { AI_TABLE_CELL_PADDING, AI_TABLE_OFFSET, DEFAULT_TEXT_ALIGN_LEFT, DEFAULT_TEXT_ALIGN_RIGHT } from '../../constants';
|
6
|
+
import { getCellHorizontalPosition, getHoverCell, transformCellValue } from '../../utils';
|
7
|
+
import { isSelectedField } from '../creations/create-cells';
|
8
|
+
import * as i0 from "@angular/core";
|
9
|
+
import * as i1 from "@angular/common";
|
10
|
+
export class AITableHoverCells {
|
11
|
+
constructor() {
|
12
|
+
this.config = input.required();
|
13
|
+
this.componentMap = {};
|
14
|
+
this.groupConfig = computed(() => {
|
15
|
+
return {
|
16
|
+
x: this.hoverCellConfig()?.x,
|
17
|
+
y: this.hoverCellConfig()?.y
|
18
|
+
};
|
19
|
+
});
|
20
|
+
this.hoverCellConfig = computed(() => {
|
21
|
+
const { aiTable, coordinate } = this.config();
|
22
|
+
const pointPosition = aiTable.context.pointPosition();
|
23
|
+
const hoverCell = this.hoverCell();
|
24
|
+
if (!hoverCell) {
|
25
|
+
return;
|
26
|
+
}
|
27
|
+
const { field, recordId, fieldId, renderComponentDefinition } = hoverCell;
|
28
|
+
const cellValue = AITableQueries.getFieldValue(aiTable, [recordId, field._id]);
|
29
|
+
const transformValue = transformCellValue(aiTable, field, cellValue) || {};
|
30
|
+
if (Object.keys(transformValue).length === 0) {
|
31
|
+
return;
|
32
|
+
}
|
33
|
+
const { rowHeight, columnCount, rowCount } = coordinate;
|
34
|
+
const columnIndex = pointPosition.columnIndex;
|
35
|
+
const rowIndex = pointPosition.rowIndex;
|
36
|
+
const x = coordinate.getColumnOffset(columnIndex) + AI_TABLE_OFFSET;
|
37
|
+
const columnWidth = coordinate.getColumnWidth(columnIndex);
|
38
|
+
const y = coordinate.getRowOffset(rowIndex) + AI_TABLE_OFFSET;
|
39
|
+
const { width } = getCellHorizontalPosition({
|
40
|
+
columnWidth,
|
41
|
+
columnIndex,
|
42
|
+
columnCount
|
43
|
+
});
|
44
|
+
const style = {
|
45
|
+
textAlign: DEFAULT_TEXT_ALIGN_LEFT
|
46
|
+
};
|
47
|
+
const textAlign = style.textAlign;
|
48
|
+
const renderX = textAlign === DEFAULT_TEXT_ALIGN_RIGHT
|
49
|
+
? columnWidth - AI_TABLE_CELL_PADDING + AI_TABLE_OFFSET
|
50
|
+
: AI_TABLE_CELL_PADDING + AI_TABLE_OFFSET;
|
51
|
+
const renderY = 0 - AI_TABLE_OFFSET * 2;
|
52
|
+
const result = {
|
53
|
+
field,
|
54
|
+
aiTable,
|
55
|
+
coordinate,
|
56
|
+
x,
|
57
|
+
y,
|
58
|
+
render: {
|
59
|
+
aiTable,
|
60
|
+
recordId,
|
61
|
+
field,
|
62
|
+
isActive: isSelectedField(field._id, aiTable),
|
63
|
+
x: renderX,
|
64
|
+
y: renderY,
|
65
|
+
columnWidth: width,
|
66
|
+
rowHeight,
|
67
|
+
cellValue,
|
68
|
+
transformValue,
|
69
|
+
style
|
70
|
+
}
|
71
|
+
};
|
72
|
+
return result;
|
73
|
+
});
|
74
|
+
this.hoverCell = computed(() => getHoverCell(this.config().aiTable));
|
75
|
+
}
|
76
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableHoverCells, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
77
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: AITableHoverCells, isStandalone: true, selector: "ai-table-hover-cell", inputs: { config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: `
|
78
|
+
@if (hoverCell()) {
|
79
|
+
<ko-group [config]="groupConfig()">
|
80
|
+
<ng-container *ngComponentOutlet="hoverCell()!.renderComponentDefinition; inputs: { config: hoverCellConfig() }">
|
81
|
+
</ng-container>
|
82
|
+
</ko-group>
|
83
|
+
}
|
84
|
+
`, isInline: true, dependencies: [{ kind: "component", type: KoContainer, selector: "ko-layer, ko-fastlayer, ko-group" }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgComponentOutlet, selector: "[ngComponentOutlet]", inputs: ["ngComponentOutlet", "ngComponentOutletInputs", "ngComponentOutletInjector", "ngComponentOutletContent", "ngComponentOutletNgModule", "ngComponentOutletNgModuleFactory"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
85
|
+
}
|
86
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableHoverCells, decorators: [{
|
87
|
+
type: Component,
|
88
|
+
args: [{
|
89
|
+
selector: 'ai-table-hover-cell',
|
90
|
+
template: `
|
91
|
+
@if (hoverCell()) {
|
92
|
+
<ko-group [config]="groupConfig()">
|
93
|
+
<ng-container *ngComponentOutlet="hoverCell()!.renderComponentDefinition; inputs: { config: hoverCellConfig() }">
|
94
|
+
</ng-container>
|
95
|
+
</ko-group>
|
96
|
+
}
|
97
|
+
`,
|
98
|
+
standalone: true,
|
99
|
+
imports: [KoShape, KoContainer, CommonModule],
|
100
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
101
|
+
}]
|
102
|
+
}] });
|
103
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hover-cell.component.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/components/hover-cell.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, effect, input, SimpleChanges } from '@angular/core';\nimport { KoContainer, KoShape } from '../../angular-konva';\nimport { AITableCellsConfig, AITableHoverCellConfig } from '../../types';\nimport { AITableField, AITableFieldType, AITableQueries } from '../../core';\nimport { AITableCellLink } from './cells/link.component';\nimport { CommonModule } from '@angular/common';\nimport {\n    AI_TABLE_CELL_BORDER,\n    AI_TABLE_CELL_PADDING,\n    AI_TABLE_OFFSET,\n    Colors,\n    DEFAULT_TEXT_ALIGN_LEFT,\n    DEFAULT_TEXT_ALIGN_RIGHT\n} from '../../constants';\nimport { getCellHorizontalPosition, getHoverCell, transformCellValue } from '../../utils';\nimport { isSelectedField } from '../creations/create-cells';\nimport _ from 'lodash';\n\nimport * as cellComponents from './cells';\nimport { HoverCellComponent } from '../interfaces';\nimport { Constructor } from 'ngx-tethys/core';\n\n@Component({\n    selector: 'ai-table-hover-cell',\n    template: `\n        @if (hoverCell()) {\n            <ko-group [config]=\"groupConfig()\">\n                <ng-container *ngComponentOutlet=\"hoverCell()!.renderComponentDefinition; inputs: { config: hoverCellConfig() }\">\n                </ng-container>\n            </ko-group>\n        }\n    `,\n    standalone: true,\n    imports: [KoShape, KoContainer, CommonModule],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableHoverCells {\n    config = input.required<AITableCellsConfig>();\n\n    componentMap: Partial<Record<AITableFieldType, Constructor<HoverCellComponent>>> = {};\n\n    groupConfig = computed(() => {\n        return {\n            x: this.hoverCellConfig()?.x,\n            y: this.hoverCellConfig()?.y\n        };\n    });\n\n    hoverCellConfig = computed(() => {\n        const { aiTable, coordinate } = this.config();\n        const pointPosition = aiTable.context!.pointPosition();\n        const hoverCell = this.hoverCell();\n        if (!hoverCell) {\n            return;\n        }\n        const { field, recordId, fieldId, renderComponentDefinition } = hoverCell;\n        const cellValue = AITableQueries.getFieldValue(aiTable, [recordId, field._id]);\n        const transformValue = transformCellValue(aiTable, field, cellValue) || {};\n        if (Object.keys(transformValue).length === 0) {\n            return;\n        }\n\n        const { rowHeight, columnCount, rowCount } = coordinate;\n        const columnIndex = pointPosition.columnIndex;\n        const rowIndex = pointPosition.rowIndex;\n\n        const x = coordinate.getColumnOffset(columnIndex) + AI_TABLE_OFFSET;\n        const columnWidth = coordinate.getColumnWidth(columnIndex);\n        const y = coordinate.getRowOffset(rowIndex) + AI_TABLE_OFFSET;\n        const { width } = getCellHorizontalPosition({\n            columnWidth,\n            columnIndex,\n            columnCount\n        });\n\n        const style = {\n            textAlign: DEFAULT_TEXT_ALIGN_LEFT\n        } as any;\n        const textAlign = style.textAlign;\n        const renderX =\n            textAlign === DEFAULT_TEXT_ALIGN_RIGHT\n                ? columnWidth - AI_TABLE_CELL_PADDING + AI_TABLE_OFFSET\n                : AI_TABLE_CELL_PADDING + AI_TABLE_OFFSET;\n        const renderY = 0 - AI_TABLE_OFFSET * 2;\n\n        const result: AITableHoverCellConfig = {\n            field,\n            aiTable,\n            coordinate,\n            x,\n            y,\n            render: {\n                aiTable,\n                recordId,\n                field,\n                isActive: isSelectedField(field._id, aiTable),\n                x: renderX,\n                y: renderY,\n                columnWidth: width,\n                rowHeight,\n                cellValue,\n                transformValue,\n                style\n            }\n        };\n\n        return result;\n    });\n\n    hoverCell = computed(() => getHoverCell(this.config().aiTable));\n}\n"]}
|
@@ -11,4 +11,5 @@ export * from './icon.component';
|
|
11
11
|
export * from './other-rows.component';
|
12
12
|
export * from './placeholder-cells.component';
|
13
13
|
export * from './text.component';
|
14
|
-
|
14
|
+
export * from './cells';
|
15
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9ncmlkL3NyYy9yZW5kZXJlci9jb21wb25lbnRzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2FkZC1maWVsZC1jb2x1bW4uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vY2VsbHMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZmllbGQtaGVhZC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9maWVsZC1pY29uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2Zyb3plbi1jZWxscy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9mcm96ZW4taGVhZHMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZnJvemVuLXBsYWNlaG9sZGVyLWNlbGxzLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2hlYWRzLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2hvdmVyLXJvdy1oZWFkcy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9pY29uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL290aGVyLXJvd3MuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vcGxhY2Vob2xkZXItY2VsbHMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vdGV4dC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9jZWxscyc7XG4iXX0=
|
@@ -1,10 +1,13 @@
|
|
1
|
-
import { ChangeDetectionStrategy, Component, computed, input } from '@angular/core';
|
1
|
+
import { ChangeDetectionStrategy, Component, computed, input, output } from '@angular/core';
|
2
2
|
import { KoShape } from '../../angular-konva/components/shape.component';
|
3
3
|
import { DEFAULT_FONT_FAMILY, DEFAULT_FONT_SIZE, DEFAULT_FONT_STYLE, DEFAULT_TEXT_ALIGN_LEFT, DEFAULT_TEXT_ELLIPSIS, DEFAULT_TEXT_FILL, DEFAULT_TEXT_LISTENING, DEFAULT_TEXT_TRANSFORMS_ENABLED, DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE, DEFAULT_TEXT_WRAP } from '../../constants';
|
4
4
|
import * as i0 from "@angular/core";
|
5
5
|
export class AITableText {
|
6
6
|
constructor() {
|
7
7
|
this.config = input.required();
|
8
|
+
// @Output() koClick = new EventEmitter<KoEventObject<MouseEvent>>();
|
9
|
+
this.koClick = output();
|
10
|
+
this.koMouseMove = output();
|
8
11
|
this.textConfig = computed(() => {
|
9
12
|
const { x, y, width, height, text, padding, align = DEFAULT_TEXT_ALIGN_LEFT, verticalAlign = DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE, fill = DEFAULT_TEXT_FILL, textDecoration, fontSize = DEFAULT_FONT_SIZE, fontStyle = DEFAULT_FONT_STYLE, ellipsis = DEFAULT_TEXT_ELLIPSIS, wrap = DEFAULT_TEXT_WRAP, transformsEnabled = DEFAULT_TEXT_TRANSFORMS_ENABLED, listening = DEFAULT_TEXT_LISTENING, fontFamily = DEFAULT_FONT_FAMILY, ...rest } = this.config();
|
10
13
|
return {
|
@@ -29,17 +32,23 @@ export class AITableText {
|
|
29
32
|
};
|
30
33
|
});
|
31
34
|
}
|
35
|
+
onClick(e) {
|
36
|
+
this.koClick.emit(e);
|
37
|
+
}
|
38
|
+
onMousemove(e) {
|
39
|
+
this.koMouseMove.emit(e);
|
40
|
+
}
|
32
41
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableText, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
33
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: AITableText, isStandalone: true, selector: "ai-table-text", inputs: { config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: ` <ko-text [config]="textConfig()"></ko-text> `, isInline: true, dependencies: [{ kind: "component", type: KoShape, selector: "ko-shape, ko-circle, ko-label, ko-rect, ko-ellipse, ko-wedge, ko-line, ko-sprite, ko-image, ko-text, ko-text-path, ko-star, ko-ring, ko-arc, ko-tag, ko-path, ko-regular-polygon, ko-arrow, ko-transformer", inputs: ["config"], outputs: ["koMouseover", "koMousemove", "koMouseout", "koMouseenter", "koMouseleave", "koMousedown", "koMouseup", "koWheel", "koContextmenu", "koClick", "koDblclick", "koTouchstart", "koTouchmove", "koTouchend", "koTap", "koDbltap", "koDragstart", "koDragmove", "koDragend"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
42
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: AITableText, isStandalone: true, selector: "ai-table-text", inputs: { config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: true, transformFunction: null } }, outputs: { koClick: "koClick", koMouseMove: "koMouseMove" }, ngImport: i0, template: ` <ko-text [config]="textConfig()" (koClick)="onClick($event)" (koMousemove)="onMousemove($event)"></ko-text> `, isInline: true, dependencies: [{ kind: "component", type: KoShape, selector: "ko-shape, ko-circle, ko-label, ko-rect, ko-ellipse, ko-wedge, ko-line, ko-sprite, ko-image, ko-text, ko-text-path, ko-star, ko-ring, ko-arc, ko-tag, ko-path, ko-regular-polygon, ko-arrow, ko-transformer", inputs: ["config"], outputs: ["koMouseover", "koMousemove", "koMouseout", "koMouseenter", "koMouseleave", "koMousedown", "koMouseup", "koWheel", "koContextmenu", "koClick", "koDblclick", "koTouchstart", "koTouchmove", "koTouchend", "koTap", "koDbltap", "koDragstart", "koDragmove", "koDragend"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
34
43
|
}
|
35
44
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AITableText, decorators: [{
|
36
45
|
type: Component,
|
37
46
|
args: [{
|
38
47
|
selector: 'ai-table-text',
|
39
|
-
template: ` <ko-text [config]="textConfig()"></ko-text> `,
|
48
|
+
template: ` <ko-text [config]="textConfig()" (koClick)="onClick($event)" (koMousemove)="onMousemove($event)"></ko-text> `,
|
40
49
|
standalone: true,
|
41
50
|
imports: [KoShape],
|
42
51
|
changeDetection: ChangeDetectionStrategy.OnPush
|
43
52
|
}]
|
44
53
|
}] });
|
45
|
-
//# sourceMappingURL=data:application/json;base64,
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9ncmlkL3NyYy9yZW5kZXJlci9jb21wb25lbnRzL3RleHQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsUUFBUSxFQUFnQixLQUFLLEVBQUUsTUFBTSxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBRWxILE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxnREFBZ0QsQ0FBQztBQUN6RSxPQUFPLEVBQ0gsbUJBQW1CLEVBQ25CLGlCQUFpQixFQUNqQixrQkFBa0IsRUFDbEIsdUJBQXVCLEVBQ3ZCLHFCQUFxQixFQUNyQixpQkFBaUIsRUFDakIsc0JBQXNCLEVBQ3RCLCtCQUErQixFQUMvQixrQ0FBa0MsRUFDbEMsaUJBQWlCLEVBQ3BCLE1BQU0saUJBQWlCLENBQUM7O0FBVXpCLE1BQU0sT0FBTyxXQUFXO0lBUHhCO1FBUUksV0FBTSxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQXFCLENBQUM7UUFFN0MscUVBQXFFO1FBQ3JFLFlBQU8sR0FBRyxNQUFNLEVBQTZCLENBQUM7UUFFOUMsZ0JBQVcsR0FBRyxNQUFNLEVBQTZCLENBQUM7UUFFbEQsZUFBVSxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUU7WUFDdkIsTUFBTSxFQUNGLENBQUMsRUFDRCxDQUFDLEVBQ0QsS0FBSyxFQUNMLE1BQU0sRUFDTixJQUFJLEVBQ0osT0FBTyxFQUNQLEtBQUssR0FBRyx1QkFBdUIsRUFDL0IsYUFBYSxHQUFHLGtDQUFrQyxFQUNsRCxJQUFJLEdBQUcsaUJBQWlCLEVBQ3hCLGNBQWMsRUFDZCxRQUFRLEdBQUcsaUJBQWlCLEVBQzVCLFNBQVMsR0FBRyxrQkFBa0IsRUFDOUIsUUFBUSxHQUFHLHFCQUFxQixFQUNoQyxJQUFJLEdBQUcsaUJBQWlCLEVBQ3hCLGlCQUFpQixHQUFHLCtCQUErQixFQUNuRCxTQUFTLEdBQUcsc0JBQXNCLEVBQ2xDLFVBQVUsR0FBRyxtQkFBbUIsRUFDaEMsR0FBRyxJQUFJLEVBQ1YsR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDbEIsT0FBTztnQkFDSCxDQUFDO2dCQUNELENBQUM7Z0JBQ0QsS0FBSztnQkFDTCxNQUFNO2dCQUNOLElBQUk7Z0JBQ0osT0FBTztnQkFDUCxLQUFLO2dCQUNMLGFBQWE7Z0JBQ2IsSUFBSTtnQkFDSixjQUFjO2dCQUNkLFFBQVE7Z0JBQ1IsU0FBUztnQkFDVCxRQUFRO2dCQUNSLElBQUk7Z0JBQ0osaUJBQWlCO2dCQUNqQixTQUFTO2dCQUNULFVBQVU7Z0JBQ1YsR0FBRyxJQUFJO2FBQ1YsQ0FBQztRQUNOLENBQUMsQ0FBQyxDQUFDO0tBUU47SUFORyxPQUFPLENBQUMsQ0FBNEI7UUFDaEMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDekIsQ0FBQztJQUNELFdBQVcsQ0FBQyxDQUE0QjtRQUNwQyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUM3QixDQUFDOytHQXhEUSxXQUFXO21HQUFYLFdBQVcsNFFBTFYsK0dBQStHLDREQUUvRyxPQUFPOzs0RkFHUixXQUFXO2tCQVB2QixTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxlQUFlO29CQUN6QixRQUFRLEVBQUUsK0dBQStHO29CQUN6SCxVQUFVLEVBQUUsSUFBSTtvQkFDaEIsT0FBTyxFQUFFLENBQUMsT0FBTyxDQUFDO29CQUNsQixlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDbEQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBjb21wdXRlZCwgRXZlbnRFbWl0dGVyLCBpbnB1dCwgb3V0cHV0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCBLb252YSBmcm9tICdrb252YSc7XG5pbXBvcnQgeyBLb1NoYXBlIH0gZnJvbSAnLi4vLi4vYW5ndWxhci1rb252YS9jb21wb25lbnRzL3NoYXBlLmNvbXBvbmVudCc7XG5pbXBvcnQge1xuICAgIERFRkFVTFRfRk9OVF9GQU1JTFksXG4gICAgREVGQVVMVF9GT05UX1NJWkUsXG4gICAgREVGQVVMVF9GT05UX1NUWUxFLFxuICAgIERFRkFVTFRfVEVYVF9BTElHTl9MRUZULFxuICAgIERFRkFVTFRfVEVYVF9FTExJUFNJUyxcbiAgICBERUZBVUxUX1RFWFRfRklMTCxcbiAgICBERUZBVUxUX1RFWFRfTElTVEVOSU5HLFxuICAgIERFRkFVTFRfVEVYVF9UUkFOU0ZPUk1TX0VOQUJMRUQsXG4gICAgREVGQVVMVF9URVhUX1ZFUlRJQ0FMX0FMSUdOX01JRERMRSxcbiAgICBERUZBVUxUX1RFWFRfV1JBUFxufSBmcm9tICcuLi8uLi9jb25zdGFudHMnO1xuaW1wb3J0IHsgS29FdmVudE9iamVjdCB9IGZyb20gJy4uLy4uL2FuZ3VsYXIta29udmEnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2FpLXRhYmxlLXRleHQnLFxuICAgIHRlbXBsYXRlOiBgIDxrby10ZXh0IFtjb25maWddPVwidGV4dENvbmZpZygpXCIgKGtvQ2xpY2spPVwib25DbGljaygkZXZlbnQpXCIgKGtvTW91c2Vtb3ZlKT1cIm9uTW91c2Vtb3ZlKCRldmVudClcIj48L2tvLXRleHQ+IGAsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBpbXBvcnRzOiBbS29TaGFwZV0sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgQUlUYWJsZVRleHQge1xuICAgIGNvbmZpZyA9IGlucHV0LnJlcXVpcmVkPEtvbnZhLlNoYXBlQ29uZmlnPigpO1xuXG4gICAgLy8gQE91dHB1dCgpIGtvQ2xpY2sgPSBuZXcgRXZlbnRFbWl0dGVyPEtvRXZlbnRPYmplY3Q8TW91c2VFdmVudD4+KCk7XG4gICAga29DbGljayA9IG91dHB1dDxLb0V2ZW50T2JqZWN0PE1vdXNlRXZlbnQ+PigpO1xuXG4gICAga29Nb3VzZU1vdmUgPSBvdXRwdXQ8S29FdmVudE9iamVjdDxNb3VzZUV2ZW50Pj4oKTtcblxuICAgIHRleHRDb25maWcgPSBjb21wdXRlZCgoKSA9PiB7XG4gICAgICAgIGNvbnN0IHtcbiAgICAgICAgICAgIHgsXG4gICAgICAgICAgICB5LFxuICAgICAgICAgICAgd2lkdGgsXG4gICAgICAgICAgICBoZWlnaHQsXG4gICAgICAgICAgICB0ZXh0LFxuICAgICAgICAgICAgcGFkZGluZyxcbiAgICAgICAgICAgIGFsaWduID0gREVGQVVMVF9URVhUX0FMSUdOX0xFRlQsXG4gICAgICAgICAgICB2ZXJ0aWNhbEFsaWduID0gREVGQVVMVF9URVhUX1ZFUlRJQ0FMX0FMSUdOX01JRERMRSxcbiAgICAgICAgICAgIGZpbGwgPSBERUZBVUxUX1RFWFRfRklMTCxcbiAgICAgICAgICAgIHRleHREZWNvcmF0aW9uLFxuICAgICAgICAgICAgZm9udFNpemUgPSBERUZBVUxUX0ZPTlRfU0laRSxcbiAgICAgICAgICAgIGZvbnRTdHlsZSA9IERFRkFVTFRfRk9OVF9TVFlMRSxcbiAgICAgICAgICAgIGVsbGlwc2lzID0gREVGQVVMVF9URVhUX0VMTElQU0lTLFxuICAgICAgICAgICAgd3JhcCA9IERFRkFVTFRfVEVYVF9XUkFQLFxuICAgICAgICAgICAgdHJhbnNmb3Jtc0VuYWJsZWQgPSBERUZBVUxUX1RFWFRfVFJBTlNGT1JNU19FTkFCTEVELFxuICAgICAgICAgICAgbGlzdGVuaW5nID0gREVGQVVMVF9URVhUX0xJU1RFTklORyxcbiAgICAgICAgICAgIGZvbnRGYW1pbHkgPSBERUZBVUxUX0ZPTlRfRkFNSUxZLFxuICAgICAgICAgICAgLi4ucmVzdFxuICAgICAgICB9ID0gdGhpcy5jb25maWcoKTtcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgIHgsXG4gICAgICAgICAgICB5LFxuICAgICAgICAgICAgd2lkdGgsXG4gICAgICAgICAgICBoZWlnaHQsXG4gICAgICAgICAgICB0ZXh0LFxuICAgICAgICAgICAgcGFkZGluZyxcbiAgICAgICAgICAgIGFsaWduLFxuICAgICAgICAgICAgdmVydGljYWxBbGlnbixcbiAgICAgICAgICAgIGZpbGwsXG4gICAgICAgICAgICB0ZXh0RGVjb3JhdGlvbixcbiAgICAgICAgICAgIGZvbnRTaXplLFxuICAgICAgICAgICAgZm9udFN0eWxlLFxuICAgICAgICAgICAgZWxsaXBzaXMsXG4gICAgICAgICAgICB3cmFwLFxuICAgICAgICAgICAgdHJhbnNmb3Jtc0VuYWJsZWQsXG4gICAgICAgICAgICBsaXN0ZW5pbmcsXG4gICAgICAgICAgICBmb250RmFtaWx5LFxuICAgICAgICAgICAgLi4ucmVzdFxuICAgICAgICB9O1xuICAgIH0pO1xuXG4gICAgb25DbGljayhlOiBLb0V2ZW50T2JqZWN0PE1vdXNlRXZlbnQ+KSB7XG4gICAgICAgIHRoaXMua29DbGljay5lbWl0KGUpO1xuICAgIH1cbiAgICBvbk1vdXNlbW92ZShlOiBLb0V2ZW50T2JqZWN0PE1vdXNlRXZlbnQ+KSB7XG4gICAgICAgIHRoaXMua29Nb3VzZU1vdmUuZW1pdChlKTtcbiAgICB9XG59XG4iXX0=
|
@@ -1,7 +1,7 @@
|
|
1
1
|
import { AI_TABLE_FIELD_HEAD, AI_TABLE_FIELD_HEAD_HEIGHT, AI_TABLE_OFFSET, AI_TABLE_ROW_ADD_BUTTON, DEFAULT_FONT_STYLE } from '../../constants';
|
2
2
|
import { AITable, AITableQueries } from '../../core';
|
3
3
|
import { AITableRowType } from '../../types';
|
4
|
-
import { getCellHorizontalPosition, transformCellValue } from '../../utils';
|
4
|
+
import { getCellHorizontalPosition, getHoverCell, transformCellValue } from '../../utils';
|
5
5
|
import { addRowLayout } from '../drawers/add-row-layout-drawer';
|
6
6
|
import { cellDrawer } from '../drawers/cell-drawer';
|
7
7
|
import { recordRowLayout } from '../drawers/record-row-layout-drawer';
|
@@ -20,6 +20,7 @@ export const createCells = (config) => {
|
|
20
20
|
cellDrawer.initCtx(ctx);
|
21
21
|
addRowLayout.initCtx(ctx);
|
22
22
|
recordRowLayout.initCtx(ctx);
|
23
|
+
const hoverCell = getHoverCell(aiTable);
|
23
24
|
// 遍历列, 确定在哪些列上绘制单元格
|
24
25
|
for (let columnIndex = columnStartIndex; columnIndex <= columnStopIndex; columnIndex++) {
|
25
26
|
if (columnIndex > columnCount - 1)
|
@@ -109,6 +110,11 @@ export const createCells = (config) => {
|
|
109
110
|
style,
|
110
111
|
colors
|
111
112
|
};
|
113
|
+
// hover 组件渲染时,底层的 cell 渲染为空
|
114
|
+
if (hoverCell && hoverCell.recordId === recordId && hoverCell.fieldId === fieldId) {
|
115
|
+
render.cellValue = '';
|
116
|
+
render.transformValue = '';
|
117
|
+
}
|
112
118
|
cellDrawer.initStyle(field, style);
|
113
119
|
// 最后一列,且单元格内容存在,需要裁剪内容,以防止文本溢出单元格边界
|
114
120
|
// 然后,根据计算好的样式和布局绘制单元格内容
|
@@ -167,7 +173,7 @@ const isSelectedCell = (cell, aiTable) => {
|
|
167
173
|
const [recordId, fieldId] = cell;
|
168
174
|
return aiTable.selection().selectedCells.has(`${recordId}:${fieldId}`);
|
169
175
|
};
|
170
|
-
const isSelectedField = (fieldId, aiTable) => {
|
176
|
+
export const isSelectedField = (fieldId, aiTable) => {
|
171
177
|
return aiTable.selection().selectedFields.has(fieldId);
|
172
178
|
};
|
173
179
|
const isSelectedRecord = (recordId, aiTable) => {
|
@@ -176,4 +182,4 @@ const isSelectedRecord = (recordId, aiTable) => {
|
|
176
182
|
const isHoverRecord = (isHover, targetName) => {
|
177
183
|
return isHover && targetName !== AI_TABLE_FIELD_HEAD;
|
178
184
|
};
|
179
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-cells.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/creations/create-cells.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AI_TABLE_FIELD_HEAD,\n    AI_TABLE_FIELD_HEAD_HEIGHT,\n    AI_TABLE_OFFSET,\n    AI_TABLE_ROW_ADD_BUTTON,\n    DEFAULT_FONT_STYLE\n} from '../../constants';\nimport { AIRecordFieldIdPath, AITable, AITableQueries, RendererContext } from '../../core';\nimport { AITableCellsDrawerConfig, AITableRender, AITableRowType } from '../../types';\nimport { getCellHorizontalPosition, transformCellValue } from '../../utils';\nimport { addRowLayout } from '../drawers/add-row-layout-drawer';\nimport { cellDrawer } from '../drawers/cell-drawer';\nimport { recordRowLayout } from '../drawers/record-row-layout-drawer';\n\n/**\n * 绘制单元格内容的函数\n * 利用 Canvas API 绘制每个单元格的背景颜色、文本以及其他可能的样式。这个函数通常用于自定义表格渲染，尤其是在处理大量数据时，通过直接操作 Canvas 来提高渲染性能\n * @param config\n */\nexport const createCells = (config: AITableCellsDrawerConfig) => {\n    const { aiTable, coordinate, references, ctx, rowStartIndex, rowStopIndex, columnStartIndex, columnStopIndex } = config;\n    const context = aiTable.context as RendererContext;\n    const { rowHeight, columnCount, rowCount } = coordinate;\n    const colors = AITable.getColors();\n    const visibleColumns = AITable.getVisibleFields(aiTable);\n\n    // 初始化绘图上下文, 为后续的绘制操作做准备\n    cellDrawer.initCtx(ctx as CanvasRenderingContext2D);\n    addRowLayout.initCtx(ctx as CanvasRenderingContext2D);\n    recordRowLayout.initCtx(ctx as CanvasRenderingContext2D);\n\n    // 遍历列, 确定在哪些列上绘制单元格\n    for (let columnIndex = columnStartIndex; columnIndex <= columnStopIndex; columnIndex++) {\n        if (columnIndex > columnCount - 1) break;\n\n        // 获取该列对应的 field，如果 field 不再展示范围，则跳过该列\n        const field = visibleColumns[columnIndex];\n        if (field == null) continue;\n\n        // 获取该列对应的宽度\n        const columnWidth = coordinate.getColumnWidth(columnIndex);\n        const x = coordinate.getColumnOffset(columnIndex) + AI_TABLE_OFFSET;\n        const isLastColumn = columnIndex === aiTable.fields.length - 1;\n\n        if (columnIndex === 1) {\n            cellDrawer.initStyle(field, { fontWeight: DEFAULT_FONT_STYLE });\n        }\n\n        // 遍历行, 从 rowStartIndex 到 rowStopIndex 的所有行，决定将在哪些行上绘制单元格\n        for (let rowIndex = rowStartIndex; rowIndex <= rowStopIndex; rowIndex++) {\n            if (rowIndex > rowCount - 1) break;\n            const row = context.linearRows()[rowIndex];\n            const { _id: recordId, type } = row;\n            const y = coordinate.getRowOffset(rowIndex) + AI_TABLE_OFFSET;\n            const { rowIndex: pointRowIndex, targetName } = context.pointPosition();\n            const isHover = pointRowIndex === rowIndex;\n\n            switch (type) {\n                case AITableRowType.add: {\n                    const isHoverRow = isHover && targetName === AI_TABLE_ROW_ADD_BUTTON;\n                    const isCheckedRow = aiTable.selection().selectedRecords.has(row._id);\n                    addRowLayout.init({\n                        x,\n                        y,\n                        rowIndex,\n                        columnIndex,\n                        columnWidth,\n                        rowHeight: AI_TABLE_FIELD_HEAD_HEIGHT,\n                        columnCount,\n                        containerWidth: coordinate.containerWidth\n                    });\n                    addRowLayout.render({\n                        isHoverRow,\n                        isCheckedRow\n                    });\n                    break;\n                }\n                case AITableRowType.record: {\n                    const fieldId = field._id;\n                    const cell: AIRecordFieldIdPath = [recordId, fieldId];\n                    let background = getCellBackground(cell, isHover, targetName, aiTable);\n\n                    recordRowLayout.init({\n                        x,\n                        y,\n                        rowIndex,\n                        columnIndex,\n                        columnWidth,\n                        rowHeight,\n                        columnCount,\n                        containerWidth: coordinate.containerWidth\n                    });\n                    recordRowLayout.render({\n                        row,\n                        style: { fill: background },\n                        isHoverRow: isHoverRecord(isHover, targetName),\n                        isCheckedRow: isSelectedRecord(recordId, aiTable)\n                    });\n                    const { width, offset } = getCellHorizontalPosition({\n                        columnIndex,\n                        columnWidth,\n                        columnCount\n                    });\n                    const realX = x + offset + AI_TABLE_OFFSET;\n                    const realY = y + AI_TABLE_OFFSET;\n                    const style = { fontWeight: DEFAULT_FONT_STYLE };\n                    const cellValue = AITableQueries.getFieldValue(aiTable, [recordId, fieldId]);\n                    const transformValue = transformCellValue(aiTable, field, cellValue);\n                    const render = {\n                        aiTable,\n                        x: realX,\n                        y: realY,\n                        columnWidth: width,\n                        rowHeight,\n                        recordId: recordId,\n                        field,\n                        cellValue,\n                        transformValue,\n                        references,\n                        isActive: isSelectedField(fieldId, aiTable),\n                        style,\n                        colors\n                    };\n\n                    cellDrawer.initStyle(field, style);\n                    // 最后一列，且单元格内容存在，需要裁剪内容，以防止文本溢出单元格边界\n                    // 然后，根据计算好的样式和布局绘制单元格内容\n                    if (isLastColumn && cellValue != null) {\n                        ctx.save();\n                        ctx.rect(realX, realY, width, rowHeight);\n                        ctx.clip();\n                        cellDrawer.renderCell(render as AITableRender, ctx as CanvasRenderingContext2D);\n                        ctx.restore();\n                    } else {\n                        cellDrawer.renderCell(render as AITableRender, ctx as CanvasRenderingContext2D);\n                    }\n                }\n            }\n        }\n    }\n};\n\nconst getCellBackground = (cell: AIRecordFieldIdPath, isHover: boolean, targetName: string, aiTable: AITable): string => {\n    const colors = AITable.getColors();\n    const [recordId, fieldId] = cell;\n    let background = colors.white;\n\n    const _isHoverRecord = isHoverRecord(isHover, targetName);\n    const _isSelectedRecord = isSelectedRecord(recordId, aiTable);\n    const _isSelectedField = isSelectedField(fieldId, aiTable);\n    const _isSiblingCell = isSiblingCell(cell, aiTable);\n    const _isActiveCell = isActiveCell(cell, aiTable);\n    const _isSelectedCell = isSelectedCell(cell, aiTable);\n    const _isKeywordsMatchedCell = isKeywordsMatchedCell(cell, aiTable);\n\n    if (_isKeywordsMatchedCell) {\n        background = colors.itemMatchBgColor;\n    } else if (_isSelectedRecord || _isSelectedField || _isSiblingCell || (_isSelectedCell && !_isActiveCell)) {\n        background = colors.itemActiveBgColor;\n    } else if (_isHoverRecord && !_isActiveCell) {\n        background = colors.gray80;\n    }\n\n    return background;\n};\n\nconst isActiveCell = (cell: AIRecordFieldIdPath, aiTable: AITable): boolean => {\n    const [recordId, fieldId] = cell;\n    const [activeRecordId, activeFieldId] = AITable.getActiveCell(aiTable) || [];\n    return recordId === activeRecordId && fieldId === activeFieldId;\n};\n\nconst isSiblingCell = (cell: AIRecordFieldIdPath, aiTable: AITable): boolean => {\n    const [recordId, fieldId] = cell;\n    const [activeRecordId, activeFieldId] = AITable.getActiveCell(aiTable) || [];\n    return AITable.getActiveRecordIds(aiTable).length === 1 && recordId === activeRecordId && fieldId !== activeFieldId;\n};\n\nconst isKeywordsMatchedCell = (cell: AIRecordFieldIdPath, aiTable: AITable): boolean => {\n    const [recordId, fieldId] = cell;\n    return aiTable.keywordsMatchedCells().has(`${recordId}:${fieldId}`);\n};\n\nconst isSelectedCell = (cell: AIRecordFieldIdPath, aiTable: AITable): boolean => {\n    const [recordId, fieldId] = cell;\n    return aiTable.selection().selectedCells.has(`${recordId}:${fieldId}`);\n};\n\nconst isSelectedField = (fieldId: string, aiTable: AITable): boolean => {\n    return aiTable.selection().selectedFields.has(fieldId);\n};\n\nconst isSelectedRecord = (recordId: string, aiTable: AITable): boolean => {\n    return aiTable.selection().selectedRecords.has(recordId);\n};\n\nconst isHoverRecord = (isHover: boolean, targetName: string): boolean => {\n    return isHover && targetName !== AI_TABLE_FIELD_HEAD;\n};\n"]}
|
185
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-cells.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/creations/create-cells.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AI_TABLE_FIELD_HEAD,\n    AI_TABLE_FIELD_HEAD_HEIGHT,\n    AI_TABLE_OFFSET,\n    AI_TABLE_ROW_ADD_BUTTON,\n    DEFAULT_FONT_STYLE\n} from '../../constants';\nimport { AIRecordFieldIdPath, AITable, AITableQueries, RendererContext } from '../../core';\nimport { AITableCellsDrawerConfig, AITableRender, AITableRowType } from '../../types';\nimport { getCellHorizontalPosition, getHoverCell, transformCellValue } from '../../utils';\nimport { addRowLayout } from '../drawers/add-row-layout-drawer';\nimport { cellDrawer } from '../drawers/cell-drawer';\nimport { recordRowLayout } from '../drawers/record-row-layout-drawer';\n\n/**\n * 绘制单元格内容的函数\n * 利用 Canvas API 绘制每个单元格的背景颜色、文本以及其他可能的样式。这个函数通常用于自定义表格渲染，尤其是在处理大量数据时，通过直接操作 Canvas 来提高渲染性能\n * @param config\n */\nexport const createCells = (config: AITableCellsDrawerConfig) => {\n    const { aiTable, coordinate, references, ctx, rowStartIndex, rowStopIndex, columnStartIndex, columnStopIndex } = config;\n    const context = aiTable.context as RendererContext;\n    const { rowHeight, columnCount, rowCount } = coordinate;\n    const colors = AITable.getColors();\n    const visibleColumns = AITable.getVisibleFields(aiTable);\n\n    // 初始化绘图上下文, 为后续的绘制操作做准备\n    cellDrawer.initCtx(ctx as CanvasRenderingContext2D);\n    addRowLayout.initCtx(ctx as CanvasRenderingContext2D);\n    recordRowLayout.initCtx(ctx as CanvasRenderingContext2D);\n\n    const hoverCell = getHoverCell(aiTable);\n\n    // 遍历列, 确定在哪些列上绘制单元格\n    for (let columnIndex = columnStartIndex; columnIndex <= columnStopIndex; columnIndex++) {\n        if (columnIndex > columnCount - 1) break;\n\n        // 获取该列对应的 field，如果 field 不再展示范围，则跳过该列\n        const field = visibleColumns[columnIndex];\n        if (field == null) continue;\n\n        // 获取该列对应的宽度\n        const columnWidth = coordinate.getColumnWidth(columnIndex);\n        const x = coordinate.getColumnOffset(columnIndex) + AI_TABLE_OFFSET;\n        const isLastColumn = columnIndex === aiTable.fields.length - 1;\n\n        if (columnIndex === 1) {\n            cellDrawer.initStyle(field, { fontWeight: DEFAULT_FONT_STYLE });\n        }\n\n        // 遍历行, 从 rowStartIndex 到 rowStopIndex 的所有行，决定将在哪些行上绘制单元格\n        for (let rowIndex = rowStartIndex; rowIndex <= rowStopIndex; rowIndex++) {\n            if (rowIndex > rowCount - 1) break;\n            const row = context.linearRows()[rowIndex];\n            const { _id: recordId, type } = row;\n            const y = coordinate.getRowOffset(rowIndex) + AI_TABLE_OFFSET;\n            const { rowIndex: pointRowIndex, targetName } = context.pointPosition();\n            const isHover = pointRowIndex === rowIndex;\n\n            switch (type) {\n                case AITableRowType.add: {\n                    const isHoverRow = isHover && targetName === AI_TABLE_ROW_ADD_BUTTON;\n                    const isCheckedRow = aiTable.selection().selectedRecords.has(row._id);\n                    addRowLayout.init({\n                        x,\n                        y,\n                        rowIndex,\n                        columnIndex,\n                        columnWidth,\n                        rowHeight: AI_TABLE_FIELD_HEAD_HEIGHT,\n                        columnCount,\n                        containerWidth: coordinate.containerWidth\n                    });\n                    addRowLayout.render({\n                        isHoverRow,\n                        isCheckedRow\n                    });\n                    break;\n                }\n                case AITableRowType.record: {\n                    const fieldId = field._id;\n                    const cell: AIRecordFieldIdPath = [recordId, fieldId];\n                    let background = getCellBackground(cell, isHover, targetName, aiTable);\n\n                    recordRowLayout.init({\n                        x,\n                        y,\n                        rowIndex,\n                        columnIndex,\n                        columnWidth,\n                        rowHeight,\n                        columnCount,\n                        containerWidth: coordinate.containerWidth\n                    });\n                    recordRowLayout.render({\n                        row,\n                        style: { fill: background },\n                        isHoverRow: isHoverRecord(isHover, targetName),\n                        isCheckedRow: isSelectedRecord(recordId, aiTable)\n                    });\n                    const { width, offset } = getCellHorizontalPosition({\n                        columnIndex,\n                        columnWidth,\n                        columnCount\n                    });\n                    const realX = x + offset + AI_TABLE_OFFSET;\n                    const realY = y + AI_TABLE_OFFSET;\n                    const style = { fontWeight: DEFAULT_FONT_STYLE };\n                    const cellValue = AITableQueries.getFieldValue(aiTable, [recordId, fieldId]);\n                    const transformValue = transformCellValue(aiTable, field, cellValue);\n                    const render = {\n                        aiTable,\n                        x: realX,\n                        y: realY,\n                        columnWidth: width,\n                        rowHeight,\n                        recordId: recordId,\n                        field,\n                        cellValue,\n                        transformValue,\n                        references,\n                        isActive: isSelectedField(fieldId, aiTable),\n                        style,\n                        colors\n                    };\n                    // hover 组件渲染时，底层的 cell 渲染为空\n                    if (hoverCell && hoverCell.recordId === recordId && hoverCell.fieldId === fieldId) {\n                        render.cellValue = '';\n                        render.transformValue = '';\n                    }\n\n                    cellDrawer.initStyle(field, style);\n                    // 最后一列，且单元格内容存在，需要裁剪内容，以防止文本溢出单元格边界\n                    // 然后，根据计算好的样式和布局绘制单元格内容\n                    if (isLastColumn && cellValue != null) {\n                        ctx.save();\n                        ctx.rect(realX, realY, width, rowHeight);\n                        ctx.clip();\n                        cellDrawer.renderCell(render as AITableRender, ctx as CanvasRenderingContext2D);\n                        ctx.restore();\n                    } else {\n                        cellDrawer.renderCell(render as AITableRender, ctx as CanvasRenderingContext2D);\n                    }\n                }\n            }\n        }\n    }\n};\n\nconst getCellBackground = (cell: AIRecordFieldIdPath, isHover: boolean, targetName: string, aiTable: AITable): string => {\n    const colors = AITable.getColors();\n    const [recordId, fieldId] = cell;\n    let background = colors.white;\n\n    const _isHoverRecord = isHoverRecord(isHover, targetName);\n    const _isSelectedRecord = isSelectedRecord(recordId, aiTable);\n    const _isSelectedField = isSelectedField(fieldId, aiTable);\n    const _isSiblingCell = isSiblingCell(cell, aiTable);\n    const _isActiveCell = isActiveCell(cell, aiTable);\n    const _isSelectedCell = isSelectedCell(cell, aiTable);\n    const _isKeywordsMatchedCell = isKeywordsMatchedCell(cell, aiTable);\n\n    if (_isKeywordsMatchedCell) {\n        background = colors.itemMatchBgColor;\n    } else if (_isSelectedRecord || _isSelectedField || _isSiblingCell || (_isSelectedCell && !_isActiveCell)) {\n        background = colors.itemActiveBgColor;\n    } else if (_isHoverRecord && !_isActiveCell) {\n        background = colors.gray80;\n    }\n\n    return background;\n};\n\nconst isActiveCell = (cell: AIRecordFieldIdPath, aiTable: AITable): boolean => {\n    const [recordId, fieldId] = cell;\n    const [activeRecordId, activeFieldId] = AITable.getActiveCell(aiTable) || [];\n    return recordId === activeRecordId && fieldId === activeFieldId;\n};\n\nconst isSiblingCell = (cell: AIRecordFieldIdPath, aiTable: AITable): boolean => {\n    const [recordId, fieldId] = cell;\n    const [activeRecordId, activeFieldId] = AITable.getActiveCell(aiTable) || [];\n    return AITable.getActiveRecordIds(aiTable).length === 1 && recordId === activeRecordId && fieldId !== activeFieldId;\n};\n\nconst isKeywordsMatchedCell = (cell: AIRecordFieldIdPath, aiTable: AITable): boolean => {\n    const [recordId, fieldId] = cell;\n    return aiTable.keywordsMatchedCells().has(`${recordId}:${fieldId}`);\n};\n\nconst isSelectedCell = (cell: AIRecordFieldIdPath, aiTable: AITable): boolean => {\n    const [recordId, fieldId] = cell;\n    return aiTable.selection().selectedCells.has(`${recordId}:${fieldId}`);\n};\n\nexport const isSelectedField = (fieldId: string, aiTable: AITable): boolean => {\n    return aiTable.selection().selectedFields.has(fieldId);\n};\n\nconst isSelectedRecord = (recordId: string, aiTable: AITable): boolean => {\n    return aiTable.selection().selectedRecords.has(recordId);\n};\n\nconst isHoverRecord = (isHover: boolean, targetName: string): boolean => {\n    return isHover && targetName !== AI_TABLE_FIELD_HEAD;\n};\n"]}
|