@ai-table/grid 0.0.58 → 0.0.59
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/esm2022/renderer/components/cells/rate.component.mjs +5 -2
- package/esm2022/renderer/creations/create-cells.mjs +3 -3
- package/esm2022/renderer/drawers/cell-drawer.mjs +8 -5
- package/fesm2022/ai-table-grid.mjs +13 -7
- package/fesm2022/ai-table-grid.mjs.map +1 -1
- package/package.json +1 -1
- package/renderer/components/cells/rate.component.d.ts.map +1 -1
- package/renderer/drawers/cell-drawer.d.ts +1 -1
- package/renderer/drawers/cell-drawer.d.ts.map +1 -1
@@ -54,7 +54,10 @@ export class AITableCellRate {
|
|
54
54
|
this.pointerX() <= lastStarRightX &&
|
55
55
|
this.pointerY() >= startTopY &&
|
56
56
|
this.pointerY() <= startBottomY;
|
57
|
-
|
57
|
+
const renderWidth = coordinate.getColumnWidth(columnIndex) - AI_TABLE_CELL_PADDING;
|
58
|
+
const starWidth = AI_TABLE_CELL_EMOJI_SIZE + AI_TABLE_CELL_EMOJI_PADDING;
|
59
|
+
const maxStar = Math.min(max, Math.floor(renderWidth / starWidth));
|
60
|
+
return [...Array(maxStar).keys()].map((item, index) => {
|
58
61
|
const value = index + 1;
|
59
62
|
const checked = value <= transformValue;
|
60
63
|
const starX = x + index * (AI_TABLE_CELL_EMOJI_SIZE + AI_TABLE_CELL_EMOJI_PADDING);
|
@@ -147,4 +150,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
147
150
|
changeDetection: ChangeDetectionStrategy.OnPush
|
148
151
|
}]
|
149
152
|
}] });
|
150
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rate.component.js","sourceRoot":"","sources":["../../../../../../packages/grid/src/renderer/components/cells/rate.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, input, signal } from '@angular/core';\nimport { ChangeDetectionStrategy } from '@angular/core';\nimport { KoShape, KoEventObject } from '../../../angular-konva';\nimport { HoverCellComponent } from '../../interfaces';\nimport { AITableHoverCellConfig } from '../../../types';\nimport { AITableFieldType } from '../../../core';\nimport { generateTargetName } from '../../../utils';\nimport { isActiveCell } from '../../../renderer';\nimport {\n    StarFill,\n    Colors,\n    AI_TABLE_CELL_EMOJI_PADDING,\n    AI_TABLE_CELL_PADDING,\n    AI_TABLE_ROW_BLANK_HEIGHT,\n    AI_TABLE_CELL_EMOJI_SIZE,\n    AI_TABLE_OFFSET,\n    AI_TABLE_CELL,\n    AI_TABLE_RATE_MAX,\n    AI_TABLE_CELL_BORDER\n} from '../../../constants';\n\n@Component({\n    selector: 'ai-table-rate',\n    template: `\n        @if (!readonly()) {\n            <ko-rect [config]=\"whiteBgConfig()\" (koMousemove)=\"koMousemove($event)\"></ko-rect>\n        }\n        @for (config of starConfigs(); let index = $index; track $index) {\n            <ko-path [config]=\"config\" (koClick)=\"koClick($event, index)\"></ko-path>\n        }\n    `,\n    standalone: true,\n    imports: [KoShape],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableCellRate implements HoverCellComponent {\n    static fieldType = AITableFieldType.rate;\n\n    private pointerX = signal<number>(0);\n\n    private pointerY = signal<number>(0);\n\n    private resetStatus = signal<boolean>(false);\n\n    config = input<AITableHoverCellConfig>();\n\n    readonly = computed(() => {\n        return this.config()?.readonly;\n    });\n\n    whiteBgConfig = computed(() => {\n        const { aiTable, render, field, recordId, coordinate } = this.config()!;\n        const pointPosition = aiTable.context!.pointPosition();\n        const { x, y } = render;\n        const { columnIndex } = pointPosition;\n        const isActive = isActiveCell([recordId!, field._id], aiTable);\n\n        return {\n            x: x - AI_TABLE_CELL_PADDING + AI_TABLE_CELL_BORDER,\n            y: y + AI_TABLE_CELL_BORDER + AI_TABLE_OFFSET,\n            width: coordinate.getColumnWidth(columnIndex) - (AI_TABLE_CELL_BORDER + AI_TABLE_OFFSET) * 2,\n            height: AI_TABLE_ROW_BLANK_HEIGHT - (AI_TABLE_CELL_BORDER + AI_TABLE_OFFSET),\n            fill: Colors.white,\n            stroke: isActive ? null : Colors.white,\n            zIndex: 0,\n            name: generateTargetName({\n                targetName: AI_TABLE_CELL,\n                fieldId: field._id,\n                recordId\n            })\n        };\n    });\n\n    starConfigs = computed(() => {\n        const { render, field, recordId, readonly, aiTable, coordinate } = this.config()!;\n        const { x, transformValue } = render;\n        const max = AI_TABLE_RATE_MAX;\n        const starY = (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_CELL_EMOJI_SIZE) / 2 + AI_TABLE_OFFSET;\n\n        const pointPosition = aiTable.context!.pointPosition();\n        const { rowIndex, columnIndex } = pointPosition;\n        const { scrollLeft, scrollTop } = aiTable.context!.scrollState();\n        const columnLeftX = coordinate.getColumnOffset(columnIndex) - scrollLeft + AI_TABLE_OFFSET;\n        const columnTopY = coordinate.getRowOffset(rowIndex) - scrollTop + AI_TABLE_OFFSET;\n        const firstStarLeftX = columnLeftX + AI_TABLE_CELL_PADDING;\n        const lastStarRightX =\n            columnLeftX + AI_TABLE_CELL_PADDING + max * AI_TABLE_CELL_EMOJI_SIZE + (max - 1) * AI_TABLE_CELL_EMOJI_PADDING;\n        const startTopY = columnTopY + starY;\n        const startBottomY = columnTopY + starY + AI_TABLE_CELL_EMOJI_SIZE;\n\n        const isHoverStar =\n            this.pointerX() >= firstStarLeftX &&\n            this.pointerX() <= lastStarRightX &&\n            this.pointerY() >= startTopY &&\n            this.pointerY() <= startBottomY;\n\n        return [...Array(max).keys()].map((item, index) => {\n            const value = index + 1;\n            const checked = value <= transformValue;\n            const starX = x + index * (AI_TABLE_CELL_EMOJI_SIZE + AI_TABLE_CELL_EMOJI_PADDING);\n\n            let fill = null;\n            if (this.resetStatus()) {\n                fill = Colors.gray100;\n            } else {\n                if (isHoverStar) {\n                    fill = columnLeftX + starX <= this.pointerX() ? Colors.waring : Colors.gray100;\n                } else {\n                    fill = checked ? Colors.waring : Colors.gray100;\n                }\n            }\n\n            return {\n                x: starX,\n                y: starY,\n                size: 22,\n                data: StarFill,\n                fill,\n                scaleX: 1.14,\n                scaleY: 1.14,\n                name: generateTargetName({\n                    targetName: AI_TABLE_CELL,\n                    fieldId: field._id,\n                    recordId,\n                    mouseStyle: readonly ? 'default' : 'pointer'\n                })\n            };\n        });\n    });\n\n    koMousemove(e: KoEventObject<MouseEvent>) {\n        if (this.readonly()) {\n            return;\n        }\n\n        this.resetStatus.set(false);\n        const pos = e.event.target.getStage()?.getPointerPosition();\n        if (!pos) return;\n        const { x, y } = pos;\n        this.pointerX.set(x);\n        this.pointerY.set(y);\n    }\n\n    koClick(e: KoEventObject<MouseEvent>, index: number) {\n        if (this.readonly()) {\n            return;\n        }\n\n        this.resetStatus.set(false);\n        const { render, readonly, field, recordId, actions } = this.config()!;\n        const { transformValue } = render;\n\n        let value = index + 1;\n        if (transformValue === value) {\n            value = 0;\n            this.resetStatus.set(true);\n        }\n\n        if (!readonly && actions && actions.updateFieldValue) {\n            actions.updateFieldValue({\n                value,\n                path: [recordId!, field._id]\n            });\n        }\n    }\n}\n"]}
|
153
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rate.component.js","sourceRoot":"","sources":["../../../../../../packages/grid/src/renderer/components/cells/rate.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, input, signal } from '@angular/core';\nimport { ChangeDetectionStrategy } from '@angular/core';\nimport { KoShape, KoEventObject } from '../../../angular-konva';\nimport { HoverCellComponent } from '../../interfaces';\nimport { AITableHoverCellConfig } from '../../../types';\nimport { AITableFieldType } from '../../../core';\nimport { generateTargetName } from '../../../utils';\nimport { isActiveCell } from '../../../renderer';\nimport {\n    StarFill,\n    Colors,\n    AI_TABLE_CELL_EMOJI_PADDING,\n    AI_TABLE_CELL_PADDING,\n    AI_TABLE_ROW_BLANK_HEIGHT,\n    AI_TABLE_CELL_EMOJI_SIZE,\n    AI_TABLE_OFFSET,\n    AI_TABLE_CELL,\n    AI_TABLE_RATE_MAX,\n    AI_TABLE_CELL_BORDER\n} from '../../../constants';\n\n@Component({\n    selector: 'ai-table-rate',\n    template: `\n        @if (!readonly()) {\n            <ko-rect [config]=\"whiteBgConfig()\" (koMousemove)=\"koMousemove($event)\"></ko-rect>\n        }\n        @for (config of starConfigs(); let index = $index; track $index) {\n            <ko-path [config]=\"config\" (koClick)=\"koClick($event, index)\"></ko-path>\n        }\n    `,\n    standalone: true,\n    imports: [KoShape],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class AITableCellRate implements HoverCellComponent {\n    static fieldType = AITableFieldType.rate;\n\n    private pointerX = signal<number>(0);\n\n    private pointerY = signal<number>(0);\n\n    private resetStatus = signal<boolean>(false);\n\n    config = input<AITableHoverCellConfig>();\n\n    readonly = computed(() => {\n        return this.config()?.readonly;\n    });\n\n    whiteBgConfig = computed(() => {\n        const { aiTable, render, field, recordId, coordinate } = this.config()!;\n        const pointPosition = aiTable.context!.pointPosition();\n        const { x, y } = render;\n        const { columnIndex } = pointPosition;\n        const isActive = isActiveCell([recordId!, field._id], aiTable);\n\n        return {\n            x: x - AI_TABLE_CELL_PADDING + AI_TABLE_CELL_BORDER,\n            y: y + AI_TABLE_CELL_BORDER + AI_TABLE_OFFSET,\n            width: coordinate.getColumnWidth(columnIndex) - (AI_TABLE_CELL_BORDER + AI_TABLE_OFFSET) * 2,\n            height: AI_TABLE_ROW_BLANK_HEIGHT - (AI_TABLE_CELL_BORDER + AI_TABLE_OFFSET),\n            fill: Colors.white,\n            stroke: isActive ? null : Colors.white,\n            zIndex: 0,\n            name: generateTargetName({\n                targetName: AI_TABLE_CELL,\n                fieldId: field._id,\n                recordId\n            })\n        };\n    });\n\n    starConfigs = computed(() => {\n        const { render, field, recordId, readonly, aiTable, coordinate } = this.config()!;\n        const { x, transformValue } = render;\n        const max = AI_TABLE_RATE_MAX;\n        const starY = (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_CELL_EMOJI_SIZE) / 2 + AI_TABLE_OFFSET;\n\n        const pointPosition = aiTable.context!.pointPosition();\n        const { rowIndex, columnIndex } = pointPosition;\n        const { scrollLeft, scrollTop } = aiTable.context!.scrollState();\n        const columnLeftX = coordinate.getColumnOffset(columnIndex) - scrollLeft + AI_TABLE_OFFSET;\n        const columnTopY = coordinate.getRowOffset(rowIndex) - scrollTop + AI_TABLE_OFFSET;\n        const firstStarLeftX = columnLeftX + AI_TABLE_CELL_PADDING;\n        const lastStarRightX =\n            columnLeftX + AI_TABLE_CELL_PADDING + max * AI_TABLE_CELL_EMOJI_SIZE + (max - 1) * AI_TABLE_CELL_EMOJI_PADDING;\n        const startTopY = columnTopY + starY;\n        const startBottomY = columnTopY + starY + AI_TABLE_CELL_EMOJI_SIZE;\n\n        const isHoverStar =\n            this.pointerX() >= firstStarLeftX &&\n            this.pointerX() <= lastStarRightX &&\n            this.pointerY() >= startTopY &&\n            this.pointerY() <= startBottomY;\n\n        const renderWidth = coordinate.getColumnWidth(columnIndex) - AI_TABLE_CELL_PADDING;\n        const starWidth = AI_TABLE_CELL_EMOJI_SIZE + AI_TABLE_CELL_EMOJI_PADDING;\n        const maxStar = Math.min(max, Math.floor(renderWidth / starWidth));\n\n        return [...Array(maxStar).keys()].map((item, index) => {\n            const value = index + 1;\n            const checked = value <= transformValue;\n            const starX = x + index * (AI_TABLE_CELL_EMOJI_SIZE + AI_TABLE_CELL_EMOJI_PADDING);\n\n            let fill = null;\n            if (this.resetStatus()) {\n                fill = Colors.gray100;\n            } else {\n                if (isHoverStar) {\n                    fill = columnLeftX + starX <= this.pointerX() ? Colors.waring : Colors.gray100;\n                } else {\n                    fill = checked ? Colors.waring : Colors.gray100;\n                }\n            }\n\n            return {\n                x: starX,\n                y: starY,\n                size: 22,\n                data: StarFill,\n                fill,\n                scaleX: 1.14,\n                scaleY: 1.14,\n                name: generateTargetName({\n                    targetName: AI_TABLE_CELL,\n                    fieldId: field._id,\n                    recordId,\n                    mouseStyle: readonly ? 'default' : 'pointer'\n                })\n            };\n        });\n    });\n\n    koMousemove(e: KoEventObject<MouseEvent>) {\n        if (this.readonly()) {\n            return;\n        }\n\n        this.resetStatus.set(false);\n        const pos = e.event.target.getStage()?.getPointerPosition();\n        if (!pos) return;\n        const { x, y } = pos;\n        this.pointerX.set(x);\n        this.pointerY.set(y);\n    }\n\n    koClick(e: KoEventObject<MouseEvent>, index: number) {\n        if (this.readonly()) {\n            return;\n        }\n\n        this.resetStatus.set(false);\n        const { render, readonly, field, recordId, actions } = this.config()!;\n        const { transformValue } = render;\n\n        let value = index + 1;\n        if (transformValue === value) {\n            value = 0;\n            this.resetStatus.set(true);\n        }\n\n        if (!readonly && actions && actions.updateFieldValue) {\n            actions.updateFieldValue({\n                value,\n                path: [recordId!, field._id]\n            });\n        }\n    }\n}\n"]}
|
@@ -122,11 +122,11 @@ export const createCells = (config) => {
|
|
122
122
|
ctx.save();
|
123
123
|
ctx.rect(realX, realY, width, rowHeight);
|
124
124
|
ctx.clip();
|
125
|
-
cellDrawer.renderCell(render, ctx);
|
125
|
+
cellDrawer.renderCell(render, ctx, columnWidth);
|
126
126
|
ctx.restore();
|
127
127
|
}
|
128
128
|
else {
|
129
|
-
cellDrawer.renderCell(render, ctx);
|
129
|
+
cellDrawer.renderCell(render, ctx, columnWidth);
|
130
130
|
}
|
131
131
|
}
|
132
132
|
}
|
@@ -182,4 +182,4 @@ const isSelectedRecord = (recordId, aiTable) => {
|
|
182
182
|
const isHoverRecord = (isHover, targetName) => {
|
183
183
|
return isHover && targetName !== AI_TABLE_FIELD_HEAD;
|
184
184
|
};
|
185
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-cells.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/creations/create-cells.ts"],"names":[],"mappings":"AAAA,OAAO,EACH,mBAAmB,EACnB,0BAA0B,EAC1B,eAAe,EACf,uBAAuB,EACvB,kBAAkB,EACrB,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAuB,OAAO,EAAE,cAAc,EAAmB,MAAM,YAAY,CAAC;AAC3F,OAAO,EAA2C,cAAc,EAAE,MAAM,aAAa,CAAC;AACtF,OAAO,EAAE,yBAAyB,EAAE,YAAY,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AAC1F,OAAO,EAAE,YAAY,EAAE,MAAM,kCAAkC,CAAC;AAChE,OAAO,EAAE,UAAU,EAAE,MAAM,wBAAwB,CAAC;AACpD,OAAO,EAAE,eAAe,EAAE,MAAM,qCAAqC,CAAC;AAEtE;;;;GAIG;AACH,MAAM,CAAC,MAAM,WAAW,GAAG,CAAC,MAAgC,EAAE,EAAE;IAC5D,MAAM,EAAE,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,GAAG,EAAE,aAAa,EAAE,YAAY,EAAE,gBAAgB,EAAE,eAAe,EAAE,GAAG,MAAM,CAAC;IACxH,MAAM,OAAO,GAAG,OAAO,CAAC,OAA0B,CAAC;IACnD,MAAM,EAAE,SAAS,EAAE,WAAW,EAAE,QAAQ,EAAE,GAAG,UAAU,CAAC;IACxD,MAAM,MAAM,GAAG,OAAO,CAAC,SAAS,EAAE,CAAC;IACnC,MAAM,cAAc,GAAG,OAAO,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;IAEzD,wBAAwB;IACxB,UAAU,CAAC,OAAO,CAAC,GAA+B,CAAC,CAAC;IACpD,YAAY,CAAC,OAAO,CAAC,GAA+B,CAAC,CAAC;IACtD,eAAe,CAAC,OAAO,CAAC,GAA+B,CAAC,CAAC;IAEzD,MAAM,SAAS,GAAG,YAAY,CAAC,OAAO,CAAC,CAAC;IAExC,oBAAoB;IACpB,KAAK,IAAI,WAAW,GAAG,gBAAgB,EAAE,WAAW,IAAI,eAAe,EAAE,WAAW,EAAE,EAAE,CAAC;QACrF,IAAI,WAAW,GAAG,WAAW,GAAG,CAAC;YAAE,MAAM;QAEzC,sCAAsC;QACtC,MAAM,KAAK,GAAG,cAAc,CAAC,WAAW,CAAC,CAAC;QAC1C,IAAI,KAAK,IAAI,IAAI;YAAE,SAAS;QAE5B,YAAY;QACZ,MAAM,WAAW,GAAG,UAAU,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC;QAC3D,MAAM,CAAC,GAAG,UAAU,CAAC,eAAe,CAAC,WAAW,CAAC,GAAG,eAAe,CAAC;QACpE,MAAM,YAAY,GAAG,WAAW,KAAK,OAAO,CAAC,QAAQ,EAAE,CAAC,MAAM,EAAE,MAAM,GAAG,CAAC,CAAC;QAE3E,IAAI,WAAW,KAAK,CAAC,EAAE,CAAC;YACpB,UAAU,CAAC,SAAS,CAAC,KAAK,EAAE,EAAE,UAAU,EAAE,kBAAkB,EAAE,CAAC,CAAC;QACpE,CAAC;QAED,yDAAyD;QACzD,KAAK,IAAI,QAAQ,GAAG,aAAa,EAAE,QAAQ,IAAI,YAAY,EAAE,QAAQ,EAAE,EAAE,CAAC;YACtE,IAAI,QAAQ,GAAG,QAAQ,GAAG,CAAC;gBAAE,MAAM;YACnC,MAAM,GAAG,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC,QAAQ,CAAC,CAAC;YAC3C,MAAM,EAAE,GAAG,EAAE,QAAQ,EAAE,IAAI,EAAE,GAAG,GAAG,CAAC;YACpC,MAAM,CAAC,GAAG,UAAU,CAAC,YAAY,CAAC,QAAQ,CAAC,GAAG,eAAe,CAAC;YAC9D,MAAM,EAAE,QAAQ,EAAE,aAAa,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC,aAAa,EAAE,CAAC;YACxE,MAAM,OAAO,GAAG,aAAa,KAAK,QAAQ,CAAC;YAE3C,QAAQ,IAAI,EAAE,CAAC;gBACX,KAAK,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC;oBACtB,MAAM,UAAU,GAAG,OAAO,IAAI,UAAU,KAAK,uBAAuB,CAAC;oBACrE,MAAM,YAAY,GAAG,OAAO,CAAC,SAAS,EAAE,CAAC,eAAe,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;oBACtE,YAAY,CAAC,IAAI,CAAC;wBACd,CAAC;wBACD,CAAC;wBACD,QAAQ;wBACR,WAAW;wBACX,WAAW;wBACX,SAAS,EAAE,0BAA0B;wBACrC,WAAW;wBACX,cAAc,EAAE,UAAU,CAAC,cAAc;qBAC5C,CAAC,CAAC;oBACH,YAAY,CAAC,MAAM,CAAC;wBAChB,UAAU;wBACV,YAAY;qBACf,CAAC,CAAC;oBACH,MAAM;gBACV,CAAC;gBACD,KAAK,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC;oBACzB,MAAM,OAAO,GAAG,KAAK,CAAC,GAAG,CAAC;oBAC1B,MAAM,IAAI,GAAwB,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;oBACtD,IAAI,UAAU,GAAG,iBAAiB,CAAC,IAAI,EAAE,OAAO,EAAE,UAAU,EAAE,OAAO,CAAC,CAAC;oBAEvE,eAAe,CAAC,IAAI,CAAC;wBACjB,CAAC;wBACD,CAAC;wBACD,QAAQ;wBACR,WAAW;wBACX,WAAW;wBACX,SAAS;wBACT,WAAW;wBACX,cAAc,EAAE,UAAU,CAAC,cAAc;qBAC5C,CAAC,CAAC;oBACH,eAAe,CAAC,MAAM,CAAC;wBACnB,GAAG;wBACH,KAAK,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE;wBAC3B,UAAU,EAAE,aAAa,CAAC,OAAO,EAAE,UAAU,CAAC;wBAC9C,YAAY,EAAE,gBAAgB,CAAC,QAAQ,EAAE,OAAO,CAAC;qBACpD,CAAC,CAAC;oBACH,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,GAAG,yBAAyB,CAAC;wBAChD,WAAW;wBACX,WAAW;wBACX,WAAW;qBACd,CAAC,CAAC;oBACH,MAAM,KAAK,GAAG,CAAC,GAAG,MAAM,GAAG,eAAe,CAAC;oBAC3C,MAAM,KAAK,GAAG,CAAC,GAAG,eAAe,CAAC;oBAClC,MAAM,KAAK,GAAG,EAAE,UAAU,EAAE,kBAAkB,EAAE,CAAC;oBACjD,MAAM,SAAS,GAAG,cAAc,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC,CAAC;oBAC7E,MAAM,cAAc,GAAG,kBAAkB,CAAC,OAAO,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC;oBACrE,MAAM,MAAM,GAAG;wBACX,OAAO;wBACP,CAAC,EAAE,KAAK;wBACR,CAAC,EAAE,KAAK;wBACR,WAAW,EAAE,KAAK;wBAClB,SAAS;wBACT,QAAQ,EAAE,QAAQ;wBAClB,KAAK;wBACL,SAAS;wBACT,cAAc;wBACd,UAAU;wBACV,QAAQ,EAAE,eAAe,CAAC,OAAO,EAAE,OAAO,CAAC;wBAC3C,KAAK;wBACL,MAAM;qBACT,CAAC;oBACF,4BAA4B;oBAC5B,IAAI,SAAS,IAAI,SAAS,CAAC,QAAQ,KAAK,QAAQ,IAAI,SAAS,CAAC,OAAO,KAAK,OAAO,EAAE,CAAC;wBAChF,MAAM,CAAC,SAAS,GAAG,EAAE,CAAC;wBACtB,MAAM,CAAC,cAAc,GAAG,EAAE,CAAC;oBAC/B,CAAC;oBAED,UAAU,CAAC,SAAS,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;oBACnC,oCAAoC;oBACpC,wBAAwB;oBACxB,IAAI,YAAY,IAAI,SAAS,IAAI,IAAI,EAAE,CAAC;wBACpC,GAAG,CAAC,IAAI,EAAE,CAAC;wBACX,GAAG,CAAC,IAAI,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,SAAS,CAAC,CAAC;wBACzC,GAAG,CAAC,IAAI,EAAE,CAAC;wBACX,UAAU,CAAC,UAAU,CAAC,MAAuB,EAAE,GAA+B,CAAC,CAAC;wBAChF,GAAG,CAAC,OAAO,EAAE,CAAC;oBAClB,CAAC;yBAAM,CAAC;wBACJ,UAAU,CAAC,UAAU,CAAC,MAAuB,EAAE,GAA+B,CAAC,CAAC;oBACpF,CAAC;gBACL,CAAC;YACL,CAAC;QACL,CAAC;IACL,CAAC;AACL,CAAC,CAAC;AAEF,MAAM,iBAAiB,GAAG,CAAC,IAAyB,EAAE,OAAgB,EAAE,UAAkB,EAAE,OAAgB,EAAU,EAAE;IACpH,MAAM,MAAM,GAAG,OAAO,CAAC,SAAS,EAAE,CAAC;IACnC,MAAM,CAAC,QAAQ,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;IACjC,IAAI,UAAU,GAAG,MAAM,CAAC,KAAK,CAAC;IAE9B,MAAM,cAAc,GAAG,aAAa,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC;IAC1D,MAAM,iBAAiB,GAAG,gBAAgB,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;IAC9D,MAAM,gBAAgB,GAAG,eAAe,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;IAC3D,MAAM,cAAc,GAAG,aAAa,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;IACpD,MAAM,aAAa,GAAG,YAAY,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;IAClD,MAAM,eAAe,GAAG,cAAc,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;IACtD,MAAM,sBAAsB,GAAG,qBAAqB,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;IAEpE,IAAI,sBAAsB,EAAE,CAAC;QACzB,UAAU,GAAG,MAAM,CAAC,gBAAgB,CAAC;IACzC,CAAC;SAAM,IAAI,iBAAiB,IAAI,gBAAgB,IAAI,cAAc,IAAI,CAAC,eAAe,IAAI,CAAC,aAAa,CAAC,EAAE,CAAC;QACxG,UAAU,GAAG,MAAM,CAAC,iBAAiB,CAAC;IAC1C,CAAC;SAAM,IAAI,cAAc,IAAI,CAAC,aAAa,EAAE,CAAC;QAC1C,UAAU,GAAG,MAAM,CAAC,MAAM,CAAC;IAC/B,CAAC;IAED,OAAO,UAAU,CAAC;AACtB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,IAAyB,EAAE,OAAgB,EAAW,EAAE;IACjF,MAAM,CAAC,QAAQ,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;IACjC,MAAM,CAAC,cAAc,EAAE,aAAa,CAAC,GAAG,OAAO,CAAC,aAAa,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;IAC7E,OAAO,QAAQ,KAAK,cAAc,IAAI,OAAO,KAAK,aAAa,CAAC;AACpE,CAAC,CAAC;AAEF,MAAM,aAAa,GAAG,CAAC,IAAyB,EAAE,OAAgB,EAAW,EAAE;IAC3E,MAAM,CAAC,QAAQ,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;IACjC,MAAM,CAAC,cAAc,EAAE,aAAa,CAAC,GAAG,OAAO,CAAC,aAAa,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;IAC7E,OAAO,OAAO,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC,MAAM,KAAK,CAAC,IAAI,QAAQ,KAAK,cAAc,IAAI,OAAO,KAAK,aAAa,CAAC;AACxH,CAAC,CAAC;AAEF,MAAM,qBAAqB,GAAG,CAAC,IAAyB,EAAE,OAAgB,EAAW,EAAE;IACnF,MAAM,CAAC,QAAQ,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;IACjC,OAAO,OAAO,CAAC,oBAAoB,EAAE,CAAC,GAAG,CAAC,GAAG,QAAQ,IAAI,OAAO,EAAE,CAAC,CAAC;AACxE,CAAC,CAAC;AAEF,MAAM,cAAc,GAAG,CAAC,IAAyB,EAAE,OAAgB,EAAW,EAAE;IAC5E,MAAM,CAAC,QAAQ,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;IACjC,OAAO,OAAO,CAAC,SAAS,EAAE,CAAC,aAAa,CAAC,GAAG,CAAC,GAAG,QAAQ,IAAI,OAAO,EAAE,CAAC,CAAC;AAC3E,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,OAAe,EAAE,OAAgB,EAAW,EAAE;IAC1E,OAAO,OAAO,CAAC,SAAS,EAAE,CAAC,cAAc,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;AAC3D,CAAC,CAAC;AAEF,MAAM,gBAAgB,GAAG,CAAC,QAAgB,EAAE,OAAgB,EAAW,EAAE;IACrE,OAAO,OAAO,CAAC,SAAS,EAAE,CAAC,eAAe,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;AAC7D,CAAC,CAAC;AAEF,MAAM,aAAa,GAAG,CAAC,OAAgB,EAAE,UAAkB,EAAW,EAAE;IACpE,OAAO,OAAO,IAAI,UAAU,KAAK,mBAAmB,CAAC;AACzD,CAAC,CAAC","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.gridData().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\nexport const 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"]}
|
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.gridData().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, columnWidth);\n                        ctx.restore();\n                    } else {\n                        cellDrawer.renderCell(render as AITableRender, ctx as CanvasRenderingContext2D, columnWidth);\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\nexport const 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"]}
|