@ai-table/grid 0.0.11 → 0.0.13
Sign up to get free protection for your applications and to get access to all the features.
- package/angular-konva/components/container.component.d.ts +7 -0
- package/angular-konva/components/container.component.d.ts.map +1 -0
- package/angular-konva/components/container.token.d.ts +3 -0
- package/angular-konva/components/container.token.d.ts.map +1 -0
- package/angular-konva/components/index.d.ts +4 -0
- package/angular-konva/components/index.d.ts.map +1 -0
- package/angular-konva/components/shape.component.d.ts +61 -0
- package/angular-konva/components/shape.component.d.ts.map +1 -0
- package/angular-konva/components/stage.component.d.ts +40 -0
- package/angular-konva/components/stage.component.d.ts.map +1 -0
- package/angular-konva/index.d.ts +5 -0
- package/angular-konva/index.d.ts.map +1 -0
- package/angular-konva/interfaces/component.d.ts +49 -0
- package/angular-konva/interfaces/component.d.ts.map +1 -0
- package/angular-konva/interfaces/config.d.ts +26 -0
- package/angular-konva/interfaces/config.d.ts.map +1 -0
- package/angular-konva/interfaces/event-object.d.ts +7 -0
- package/angular-konva/interfaces/event-object.d.ts.map +1 -0
- package/angular-konva/interfaces/index.d.ts +5 -0
- package/angular-konva/interfaces/index.d.ts.map +1 -0
- package/angular-konva/interfaces/shape.d.ts +42 -0
- package/angular-konva/interfaces/shape.d.ts.map +1 -0
- package/angular-konva/utils/apply-node-props.d.ts +4 -0
- package/angular-konva/utils/apply-node-props.d.ts.map +1 -0
- package/angular-konva/utils/common.d.ts +8 -0
- package/angular-konva/utils/common.d.ts.map +1 -0
- package/angular-konva/utils/index.d.ts +5 -0
- package/angular-konva/utils/index.d.ts.map +1 -0
- package/angular-konva/utils/types.d.ts +4 -0
- package/angular-konva/utils/types.d.ts.map +1 -0
- package/angular-konva/utils/update-picture.d.ts +4 -0
- package/angular-konva/utils/update-picture.d.ts.map +1 -0
- package/components/cell-editors/abstract-cell-editor.component.d.ts +7 -5
- package/components/cell-editors/abstract-cell-editor.component.d.ts.map +1 -1
- package/components/cell-editors/cell-editor.scss +38 -25
- package/components/cell-editors/cell-editor.variables.scss +5 -0
- package/components/cell-editors/date/date-editor.component.d.ts.map +1 -1
- package/components/cell-editors/link/edit-link/edit-link.component.d.ts +33 -0
- package/components/cell-editors/link/edit-link/edit-link.component.d.ts.map +1 -0
- package/components/cell-editors/link/link-editor.component.d.ts +36 -0
- package/components/cell-editors/link/link-editor.component.d.ts.map +1 -0
- package/components/cell-editors/link/link-editor.component.scss +21 -0
- package/components/cell-editors/progress/progress-editor.component.d.ts +0 -1
- package/components/cell-editors/progress/progress-editor.component.d.ts.map +1 -1
- package/components/cell-editors/progress/progress-editor.component.scss +12 -4
- package/components/cell-editors/rating/rating-editor.component.d.ts +0 -1
- package/components/cell-editors/rating/rating-editor.component.d.ts.map +1 -1
- package/components/cell-editors/rating/rating-editor.component.scss +10 -0
- package/components/cell-editors/select/select-editor.component.d.ts +1 -3
- package/components/cell-editors/select/select-editor.component.d.ts.map +1 -1
- package/components/cell-editors/text/text-editor.component.d.ts +0 -1
- package/components/cell-editors/text/text-editor.component.d.ts.map +1 -1
- package/components/cell-views/select/option.component.d.ts.map +1 -1
- package/components/cell-views/select/option.scss +10 -0
- package/components/field-menu/field-menu.component.d.ts +8 -3
- package/components/field-menu/field-menu.component.d.ts.map +1 -1
- package/components/field-property-editor/field-property-editor.component.d.ts +4 -2
- package/components/field-property-editor/field-property-editor.component.d.ts.map +1 -1
- package/components/index.d.ts +3 -1
- package/components/index.d.ts.map +1 -1
- package/constants/colors.d.ts +18 -0
- package/constants/colors.d.ts.map +1 -0
- package/constants/grid.d.ts +17 -1
- package/constants/grid.d.ts.map +1 -1
- package/constants/icon.d.ts +19 -0
- package/constants/icon.d.ts.map +1 -0
- package/constants/index.d.ts +5 -1
- package/constants/index.d.ts.map +1 -1
- package/constants/table.d.ts +60 -0
- package/constants/table.d.ts.map +1 -0
- package/constants/text.d.ts +22 -0
- package/constants/text.d.ts.map +1 -0
- package/core/context.d.ts +14 -0
- package/core/context.d.ts.map +1 -0
- package/core/coordinate.d.ts +96 -0
- package/core/coordinate.d.ts.map +1 -0
- package/core/index.d.ts +3 -2
- package/core/index.d.ts.map +1 -1
- package/core/types/ai-table.d.ts +56 -0
- package/core/types/ai-table.d.ts.map +1 -0
- package/core/types/core.d.ts +29 -23
- package/core/types/core.d.ts.map +1 -1
- package/core/types/index.d.ts +1 -1
- package/core/types/index.d.ts.map +1 -1
- package/core/utils/common.d.ts +1 -2
- package/core/utils/common.d.ts.map +1 -1
- package/core/utils/field.d.ts +1 -1
- package/core/utils/field.d.ts.map +1 -1
- package/core/utils/index.d.ts +0 -1
- package/core/utils/index.d.ts.map +1 -1
- package/core/utils/queries.d.ts +5 -5
- package/core/utils/queries.d.ts.map +1 -1
- package/dom-grid.component.d.ts +11 -0
- package/dom-grid.component.d.ts.map +1 -0
- package/esm2022/angular-konva/components/container.component.mjs +29 -0
- package/esm2022/angular-konva/components/container.token.mjs +3 -0
- package/esm2022/angular-konva/components/index.mjs +4 -0
- package/esm2022/angular-konva/components/shape.component.mjs +142 -0
- package/esm2022/angular-konva/components/stage.component.mjs +123 -0
- package/esm2022/angular-konva/index.mjs +5 -0
- package/esm2022/angular-konva/interfaces/component.mjs +4 -0
- package/esm2022/angular-konva/interfaces/config.mjs +2 -0
- package/esm2022/angular-konva/interfaces/event-object.mjs +2 -0
- package/esm2022/angular-konva/interfaces/index.mjs +5 -0
- package/esm2022/angular-konva/interfaces/shape.mjs +42 -0
- package/esm2022/angular-konva/utils/apply-node-props.mjs +67 -0
- package/esm2022/angular-konva/utils/common.mjs +48 -0
- package/esm2022/angular-konva/utils/index.mjs +5 -0
- package/esm2022/angular-konva/utils/types.mjs +2 -0
- package/esm2022/angular-konva/utils/update-picture.mjs +7 -0
- package/esm2022/components/cell-editors/abstract-cell-editor.component.mjs +12 -7
- package/esm2022/components/cell-editors/date/date-editor.component.mjs +6 -3
- package/esm2022/components/cell-editors/link/edit-link/edit-link.component.mjs +66 -0
- package/esm2022/components/cell-editors/link/link-editor.component.mjs +117 -0
- package/esm2022/components/cell-editors/number/number-editor.component.mjs +2 -2
- package/esm2022/components/cell-editors/progress/progress-editor.component.mjs +3 -6
- package/esm2022/components/cell-editors/rating/rating-editor.component.mjs +4 -7
- package/esm2022/components/cell-editors/select/select-editor.component.mjs +11 -16
- package/esm2022/components/cell-editors/text/text-editor.component.mjs +10 -11
- package/esm2022/components/cell-views/select/option.component.mjs +6 -5
- package/esm2022/components/field-menu/field-menu.component.mjs +11 -8
- package/esm2022/components/field-property-editor/field-property-editor.component.mjs +17 -12
- package/esm2022/components/index.mjs +4 -2
- package/esm2022/constants/colors.mjs +18 -0
- package/esm2022/constants/editor.mjs +2 -3
- package/esm2022/constants/grid.mjs +22 -4
- package/esm2022/constants/icon.mjs +26 -0
- package/esm2022/constants/index.mjs +6 -2
- package/esm2022/constants/table.mjs +62 -0
- package/esm2022/constants/text.mjs +23 -0
- package/esm2022/core/context.mjs +25 -0
- package/esm2022/core/coordinate.mjs +222 -0
- package/esm2022/core/index.mjs +4 -3
- package/esm2022/core/types/ai-table.mjs +44 -0
- package/esm2022/core/types/core.mjs +6 -1
- package/esm2022/core/types/index.mjs +2 -2
- package/esm2022/core/utils/common.mjs +3 -20
- package/esm2022/core/utils/field.mjs +9 -5
- package/esm2022/core/utils/index.mjs +1 -2
- package/esm2022/core/utils/queries.mjs +4 -4
- package/esm2022/dom-grid.component.mjs +82 -0
- package/esm2022/grid-base.component.mjs +154 -0
- package/esm2022/grid.component.mjs +336 -160
- package/esm2022/public-api.mjs +9 -5
- package/esm2022/renderer/components/add-field-column.component.mjs +68 -0
- package/esm2022/renderer/components/cells.component.mjs +35 -0
- package/esm2022/renderer/components/field-head.component.mjs +130 -0
- package/esm2022/renderer/components/field-icon.component.mjs +66 -0
- package/esm2022/renderer/components/frozen-cells.component.mjs +36 -0
- package/esm2022/renderer/components/frozen-heads.component.mjs +117 -0
- package/esm2022/renderer/components/frozen-placeholder-cells.component.mjs +38 -0
- package/esm2022/renderer/components/heads.component.mjs +38 -0
- package/esm2022/renderer/components/hover-row-heads.component.mjs +107 -0
- package/esm2022/renderer/components/icon.component.mjs +80 -0
- package/esm2022/renderer/components/index.mjs +14 -0
- package/esm2022/renderer/components/other-rows.component.mjs +68 -0
- package/esm2022/renderer/components/placeholder-cells.component.mjs +33 -0
- package/esm2022/renderer/components/text.component.mjs +45 -0
- package/esm2022/renderer/creations/create-active-cell-border.mjs +68 -0
- package/esm2022/renderer/creations/create-cells.mjs +135 -0
- package/esm2022/renderer/creations/create-heads.mjs +45 -0
- package/esm2022/renderer/drawers/add-row-layout-drawer.mjs +97 -0
- package/esm2022/renderer/drawers/cell-drawer.mjs +586 -0
- package/esm2022/renderer/drawers/drawer.mjs +936 -0
- package/esm2022/renderer/drawers/layout-drawer.mjs +58 -0
- package/esm2022/renderer/drawers/record-row-layout-drawer.mjs +101 -0
- package/esm2022/renderer/index.mjs +4 -0
- package/esm2022/renderer/renderer.component.mjs +174 -0
- package/esm2022/services/event.service.mjs +115 -11
- package/esm2022/services/field.service.mjs +28 -5
- package/esm2022/services/index.mjs +4 -0
- package/esm2022/services/selection.service.mjs +8 -1
- package/esm2022/types/avatar.mjs +27 -0
- package/esm2022/types/canvas.mjs +2 -0
- package/esm2022/types/cell.mjs +2 -0
- package/esm2022/types/component-config.mjs +7 -0
- package/esm2022/types/field.mjs +1 -1
- package/esm2022/types/grid.mjs +16 -2
- package/esm2022/types/index.mjs +8 -2
- package/esm2022/types/layout.mjs +2 -0
- package/esm2022/types/row.mjs +6 -0
- package/esm2022/utils/build.mjs +39 -0
- package/esm2022/utils/cell.mjs +71 -0
- package/esm2022/utils/common.mjs +49 -0
- package/esm2022/utils/get-placeholder-cells.mjs +66 -0
- package/esm2022/utils/get-text-width.mjs +30 -0
- package/esm2022/utils/image-cache.mjs +57 -0
- package/esm2022/utils/index.mjs +12 -0
- package/esm2022/utils/os.mjs +16 -0
- package/esm2022/utils/position.mjs +48 -0
- package/esm2022/utils/style.mjs +25 -0
- package/esm2022/utils/text-measure.mjs +122 -0
- package/esm2022/utils/visible-range.mjs +38 -0
- package/fesm2022/ai-table-grid.mjs +5526 -693
- package/fesm2022/ai-table-grid.mjs.map +1 -1
- package/grid-base.component.d.ts +52 -0
- package/grid-base.component.d.ts.map +1 -0
- package/grid.component.d.ts +43 -40
- package/grid.component.d.ts.map +1 -1
- package/package.json +5 -2
- package/public-api.d.ts +8 -4
- package/public-api.d.ts.map +1 -1
- package/renderer/components/add-field-column.component.d.ts +16 -0
- package/renderer/components/add-field-column.component.d.ts.map +1 -0
- package/renderer/components/cells.component.d.ts +14 -0
- package/renderer/components/cells.component.d.ts.map +1 -0
- package/renderer/components/field-head.component.d.ts +73 -0
- package/renderer/components/field-head.component.d.ts.map +1 -0
- package/renderer/components/field-icon.component.d.ts +17 -0
- package/renderer/components/field-icon.component.d.ts.map +1 -0
- package/renderer/components/frozen-cells.component.d.ts +14 -0
- package/renderer/components/frozen-cells.component.d.ts.map +1 -0
- package/renderer/components/frozen-heads.component.d.ts +47 -0
- package/renderer/components/frozen-heads.component.d.ts.map +1 -0
- package/renderer/components/frozen-placeholder-cells.component.d.ts +22 -0
- package/renderer/components/frozen-placeholder-cells.component.d.ts.map +1 -0
- package/renderer/components/heads.component.d.ts +9 -0
- package/renderer/components/heads.component.d.ts.map +1 -0
- package/renderer/components/hover-row-heads.component.d.ts +11 -0
- package/renderer/components/hover-row-heads.component.d.ts.map +1 -0
- package/renderer/components/icon.component.d.ts +37 -0
- package/renderer/components/icon.component.d.ts.map +1 -0
- package/renderer/components/index.d.ts +14 -0
- package/renderer/components/index.d.ts.map +1 -0
- package/renderer/components/other-rows.component.d.ts +31 -0
- package/renderer/components/other-rows.component.d.ts.map +1 -0
- package/renderer/components/placeholder-cells.component.d.ts +22 -0
- package/renderer/components/placeholder-cells.component.d.ts.map +1 -0
- package/renderer/components/text.component.d.ts +99 -0
- package/renderer/components/text.component.d.ts.map +1 -0
- package/renderer/creations/create-active-cell-border.d.ts +7 -0
- package/renderer/creations/create-active-cell-border.d.ts.map +1 -0
- package/renderer/creations/create-cells.d.ts +8 -0
- package/renderer/creations/create-cells.d.ts.map +1 -0
- package/renderer/creations/create-heads.d.ts +3 -0
- package/renderer/creations/create-heads.d.ts.map +1 -0
- package/renderer/drawers/add-row-layout-drawer.d.ts +12 -0
- package/renderer/drawers/add-row-layout-drawer.d.ts.map +1 -0
- package/renderer/drawers/cell-drawer.d.ts +22 -0
- package/renderer/drawers/cell-drawer.d.ts.map +1 -0
- package/renderer/drawers/drawer.d.ts +136 -0
- package/renderer/drawers/drawer.d.ts.map +1 -0
- package/renderer/drawers/layout-drawer.d.ts +22 -0
- package/renderer/drawers/layout-drawer.d.ts.map +1 -0
- package/renderer/drawers/record-row-layout-drawer.d.ts +14 -0
- package/renderer/drawers/record-row-layout-drawer.d.ts.map +1 -0
- package/renderer/index.d.ts +4 -0
- package/renderer/index.d.ts.map +1 -0
- package/renderer/renderer.component.d.ts +64 -0
- package/renderer/renderer.component.d.ts.map +1 -0
- package/services/event.service.d.ts +17 -3
- package/services/event.service.d.ts.map +1 -1
- package/services/field.service.d.ts +5 -4
- package/services/field.service.d.ts.map +1 -1
- package/services/index.d.ts +4 -0
- package/services/index.d.ts.map +1 -0
- package/services/selection.service.d.ts.map +1 -1
- package/styles/styles.scss +71 -11
- package/types/avatar.d.ts +24 -0
- package/types/avatar.d.ts.map +1 -0
- package/types/canvas.d.ts +83 -0
- package/types/canvas.d.ts.map +1 -0
- package/types/cell.d.ts +43 -0
- package/types/cell.d.ts.map +1 -0
- package/types/component-config.d.ts +50 -0
- package/types/component-config.d.ts.map +1 -0
- package/types/field.d.ts +27 -1
- package/types/field.d.ts.map +1 -1
- package/types/grid.d.ts +80 -2
- package/types/grid.d.ts.map +1 -1
- package/types/index.d.ts +7 -1
- package/types/index.d.ts.map +1 -1
- package/types/layout.d.ts +11 -0
- package/types/layout.d.ts.map +1 -0
- package/types/row.d.ts +27 -0
- package/types/row.d.ts.map +1 -0
- package/utils/build.d.ts +5 -0
- package/utils/build.d.ts.map +1 -0
- package/utils/cell.d.ts +19 -0
- package/utils/cell.d.ts.map +1 -0
- package/utils/common.d.ts +20 -0
- package/utils/common.d.ts.map +1 -0
- package/utils/get-placeholder-cells.d.ts +16 -0
- package/utils/get-placeholder-cells.d.ts.map +1 -0
- package/utils/get-text-width.d.ts +9 -0
- package/utils/get-text-width.d.ts.map +1 -0
- package/utils/image-cache.d.ts +16 -0
- package/utils/image-cache.d.ts.map +1 -0
- package/utils/index.d.ts +12 -0
- package/utils/index.d.ts.map +1 -0
- package/utils/os.d.ts +4 -0
- package/utils/os.d.ts.map +1 -0
- package/utils/position.d.ts +20 -0
- package/utils/position.d.ts.map +1 -0
- package/utils/style.d.ts +4 -0
- package/utils/style.d.ts.map +1 -0
- package/utils/text-measure.d.ts +32 -0
- package/utils/text-measure.d.ts.map +1 -0
- package/utils/visible-range.d.ts +13 -0
- package/utils/visible-range.d.ts.map +1 -0
- package/components/cell-editors/link/number-editor.component.d.ts +0 -8
- package/components/cell-editors/link/number-editor.component.d.ts.map +0 -1
- package/constants/field.d.ts +0 -20
- package/constants/field.d.ts.map +0 -1
- package/core/action/field.d.ts +0 -12
- package/core/action/field.d.ts.map +0 -1
- package/core/action/general.d.ts +0 -5
- package/core/action/general.d.ts.map +0 -1
- package/core/action/index.d.ts +0 -12
- package/core/action/index.d.ts.map +0 -1
- package/core/action/record.d.ts +0 -12
- package/core/action/record.d.ts.map +0 -1
- package/core/types/action.d.ts +0 -64
- package/core/types/action.d.ts.map +0 -1
- package/core/utils/weak-map.d.ts +0 -3
- package/core/utils/weak-map.d.ts.map +0 -1
- package/esm2022/components/cell-editors/link/number-editor.component.mjs +0 -25
- package/esm2022/constants/field.mjs +0 -25
- package/esm2022/core/action/field.mjs +0 -57
- package/esm2022/core/action/general.mjs +0 -116
- package/esm2022/core/action/index.mjs +0 -9
- package/esm2022/core/action/record.mjs +0 -44
- package/esm2022/core/types/action.mjs +0 -18
- package/esm2022/core/utils/weak-map.mjs +0 -2
@@ -0,0 +1,135 @@
|
|
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
|
+
import { AITable, AITableQueries } from '../../core';
|
3
|
+
import { AITableAreaType, AITableRowType } from '../../types';
|
4
|
+
import { getCellHorizontalPosition, transformCellValue } from '../../utils';
|
5
|
+
import { addRowLayout } from '../drawers/add-row-layout-drawer';
|
6
|
+
import { cellDrawer } from '../drawers/cell-drawer';
|
7
|
+
import { recordRowLayout } from '../drawers/record-row-layout-drawer';
|
8
|
+
/**
|
9
|
+
* 绘制单元格内容的函数
|
10
|
+
* 利用 Canvas API 绘制每个单元格的背景颜色、文本以及其他可能的样式。这个函数通常用于自定义表格渲染,尤其是在处理大量数据时,通过直接操作 Canvas 来提高渲染性能
|
11
|
+
* @param config
|
12
|
+
*/
|
13
|
+
export const createCells = (config) => {
|
14
|
+
const { aiTable, coordinate, references, ctx, rowStartIndex, rowStopIndex, columnStartIndex, columnStopIndex } = config;
|
15
|
+
const context = aiTable.context;
|
16
|
+
const { rowHeight, columnCount, rowCount } = coordinate;
|
17
|
+
const colors = AITable.getColors();
|
18
|
+
const visibleColumns = AITable.getVisibleFields(aiTable);
|
19
|
+
// 初始化绘图上下文, 为后续的绘制操作做准备
|
20
|
+
cellDrawer.initCtx(ctx);
|
21
|
+
addRowLayout.initCtx(ctx);
|
22
|
+
recordRowLayout.initCtx(ctx);
|
23
|
+
// 遍历列, 确定在哪些列上绘制单元格
|
24
|
+
for (let columnIndex = columnStartIndex; columnIndex <= columnStopIndex; columnIndex++) {
|
25
|
+
if (columnIndex > columnCount - 1)
|
26
|
+
break;
|
27
|
+
// 获取该列对应的 field,如果 field 不再展示范围,则跳过该列
|
28
|
+
const field = visibleColumns[columnIndex];
|
29
|
+
if (field == null)
|
30
|
+
continue;
|
31
|
+
// 获取该列对应的宽度
|
32
|
+
const columnWidth = coordinate.getColumnWidth(columnIndex);
|
33
|
+
const x = coordinate.getColumnOffset(columnIndex) + AI_TABLE_OFFSET;
|
34
|
+
const isLastColumn = columnIndex === aiTable.fields.length - 1;
|
35
|
+
if (columnIndex === 1) {
|
36
|
+
cellDrawer.initStyle(field, { fontWeight: DEFAULT_FONT_STYLE });
|
37
|
+
}
|
38
|
+
// 遍历行, 从 rowStartIndex 到 rowStopIndex 的所有行,决定将在哪些行上绘制单元格
|
39
|
+
for (let rowIndex = rowStartIndex; rowIndex <= rowStopIndex; rowIndex++) {
|
40
|
+
if (rowIndex > rowCount - 1)
|
41
|
+
break;
|
42
|
+
const row = context.linearRows()[rowIndex];
|
43
|
+
const { _id: recordId, type } = row;
|
44
|
+
const y = coordinate.getRowOffset(rowIndex) + AI_TABLE_OFFSET;
|
45
|
+
const { rowIndex: pointRowIndex, areaType, targetName } = context.pointPosition();
|
46
|
+
const isHover = pointRowIndex === rowIndex && areaType !== AITableAreaType.none;
|
47
|
+
switch (type) {
|
48
|
+
case AITableRowType.add: {
|
49
|
+
const isHoverRow = isHover && targetName === AI_TABLE_ROW_ADD_BUTTON;
|
50
|
+
addRowLayout.init({
|
51
|
+
x,
|
52
|
+
y,
|
53
|
+
rowIndex,
|
54
|
+
columnIndex,
|
55
|
+
columnWidth,
|
56
|
+
rowHeight: AI_TABLE_FIELD_HEAD_HEIGHT,
|
57
|
+
columnCount,
|
58
|
+
containerWidth: coordinate.containerWidth
|
59
|
+
});
|
60
|
+
addRowLayout.render({
|
61
|
+
isHoverRow
|
62
|
+
});
|
63
|
+
break;
|
64
|
+
}
|
65
|
+
case AITableRowType.record: {
|
66
|
+
let background = colors.white;
|
67
|
+
const isCheckedRow = aiTable.selection().selectedRecords.has(row._id);
|
68
|
+
const isSelected = aiTable.selection().selectedFields.has(field._id);
|
69
|
+
const isHoverRow = isHover && targetName !== AI_TABLE_FIELD_HEAD;
|
70
|
+
if (isCheckedRow || isSelected) {
|
71
|
+
background = colors.itemActiveBgColor;
|
72
|
+
}
|
73
|
+
else if (isHoverRow) {
|
74
|
+
background = colors.gray80;
|
75
|
+
}
|
76
|
+
recordRowLayout.init({
|
77
|
+
x,
|
78
|
+
y,
|
79
|
+
rowIndex,
|
80
|
+
columnIndex,
|
81
|
+
columnWidth,
|
82
|
+
rowHeight,
|
83
|
+
columnCount,
|
84
|
+
containerWidth: coordinate.containerWidth
|
85
|
+
});
|
86
|
+
recordRowLayout.render({
|
87
|
+
row,
|
88
|
+
style: { fill: background },
|
89
|
+
isHoverRow,
|
90
|
+
isCheckedRow
|
91
|
+
});
|
92
|
+
const { width, offset } = getCellHorizontalPosition({
|
93
|
+
columnIndex,
|
94
|
+
columnWidth,
|
95
|
+
columnCount
|
96
|
+
});
|
97
|
+
const realX = x + offset + AI_TABLE_OFFSET;
|
98
|
+
const realY = y + AI_TABLE_OFFSET;
|
99
|
+
const style = { fontWeight: DEFAULT_FONT_STYLE };
|
100
|
+
const cellValue = AITableQueries.getFieldValue(aiTable, [recordId, field._id]);
|
101
|
+
const transformValue = transformCellValue(aiTable, field, cellValue);
|
102
|
+
const render = {
|
103
|
+
aiTable,
|
104
|
+
x: realX,
|
105
|
+
y: realY,
|
106
|
+
columnWidth: width,
|
107
|
+
rowHeight,
|
108
|
+
recordId: recordId,
|
109
|
+
field,
|
110
|
+
cellValue,
|
111
|
+
transformValue,
|
112
|
+
references,
|
113
|
+
isActive: isSelected,
|
114
|
+
style,
|
115
|
+
colors
|
116
|
+
};
|
117
|
+
cellDrawer.initStyle(field, style);
|
118
|
+
// 最后一列,且单元格内容存在,需要裁剪内容,以防止文本溢出单元格边界
|
119
|
+
// 然后,根据计算好的样式和布局绘制单元格内容
|
120
|
+
if (isLastColumn && cellValue != null) {
|
121
|
+
ctx.save();
|
122
|
+
ctx.rect(realX, realY, width, rowHeight);
|
123
|
+
ctx.clip();
|
124
|
+
cellDrawer.renderCell(render, ctx);
|
125
|
+
ctx.restore();
|
126
|
+
}
|
127
|
+
else {
|
128
|
+
cellDrawer.renderCell(render, ctx);
|
129
|
+
}
|
130
|
+
}
|
131
|
+
}
|
132
|
+
}
|
133
|
+
}
|
134
|
+
};
|
135
|
+
//# 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 { AITable, AITableQueries, RendererContext } from '../../core';\nimport { AITableAreaType, 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, areaType, targetName } = context.pointPosition();\n            const isHover = pointRowIndex === rowIndex && areaType !== AITableAreaType.none;\n\n            switch (type) {\n                case AITableRowType.add: {\n                    const isHoverRow = isHover && targetName === AI_TABLE_ROW_ADD_BUTTON;\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                    });\n                    break;\n                }\n                case AITableRowType.record: {\n                    let background = colors.white;\n                    const isCheckedRow = aiTable.selection().selectedRecords.has(row._id);\n                    const isSelected = aiTable.selection().selectedFields.has(field._id);\n                    const isHoverRow = isHover && targetName !== AI_TABLE_FIELD_HEAD;\n                    if (isCheckedRow || isSelected) {\n                        background = colors.itemActiveBgColor;\n                    } else if (isHoverRow) {\n                        background = colors.gray80;\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,\n                        isCheckedRow\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, field._id]);\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: isSelected,\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"]}
|
@@ -0,0 +1,45 @@
|
|
1
|
+
import { AI_TABLE_FIELD_HEAD, AI_TABLE_FIELD_HEAD_MORE, Colors } from '../../constants';
|
2
|
+
export const createColumnHeads = (config) => {
|
3
|
+
const { coordinate, columnStartIndex, columnStopIndex, pointPosition, aiTable } = config;
|
4
|
+
const colors = Colors;
|
5
|
+
const { columnCount, rowInitSize: fieldHeadHeight } = coordinate;
|
6
|
+
const { columnIndex: pointColumnIndex, targetName: pointTargetName } = pointPosition;
|
7
|
+
const { fields } = aiTable;
|
8
|
+
const getFieldHeadStatus = (fieldId) => {
|
9
|
+
const iconVisible = [AI_TABLE_FIELD_HEAD, AI_TABLE_FIELD_HEAD_MORE].includes(pointTargetName) && fields()[pointColumnIndex]?._id === fieldId;
|
10
|
+
const isHoverIcon = pointTargetName === AI_TABLE_FIELD_HEAD_MORE && fields()[pointColumnIndex]?._id === fieldId;
|
11
|
+
const isSelected = aiTable.selection().selectedFields.has(fieldId);
|
12
|
+
return {
|
13
|
+
iconVisible,
|
14
|
+
isSelected,
|
15
|
+
isHoverIcon
|
16
|
+
};
|
17
|
+
};
|
18
|
+
const fieldHeads = [];
|
19
|
+
for (let columnIndex = columnStartIndex; columnIndex <= columnStopIndex; columnIndex++) {
|
20
|
+
if (columnIndex > columnCount - 1)
|
21
|
+
break;
|
22
|
+
if (columnIndex < 0)
|
23
|
+
continue;
|
24
|
+
const field = fields()[columnIndex];
|
25
|
+
if (field == null)
|
26
|
+
continue;
|
27
|
+
const x = coordinate.getColumnOffset(columnIndex);
|
28
|
+
const columnWidth = coordinate.getColumnWidth(columnIndex);
|
29
|
+
const { iconVisible, isSelected, isHoverIcon } = getFieldHeadStatus(field._id);
|
30
|
+
const fieldHead = {
|
31
|
+
x,
|
32
|
+
y: 0,
|
33
|
+
width: columnWidth,
|
34
|
+
height: fieldHeadHeight,
|
35
|
+
field,
|
36
|
+
stroke: columnIndex === 0 ? colors.transparent : undefined,
|
37
|
+
iconVisible,
|
38
|
+
isSelected,
|
39
|
+
isHoverIcon
|
40
|
+
};
|
41
|
+
fieldHeads.push(fieldHead);
|
42
|
+
}
|
43
|
+
return fieldHeads;
|
44
|
+
};
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlLWhlYWRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvZ3JpZC9zcmMvcmVuZGVyZXIvY3JlYXRpb25zL2NyZWF0ZS1oZWFkcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFHeEYsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsQ0FBQyxNQUFnQyxFQUFFLEVBQUU7SUFDbEUsTUFBTSxFQUFFLFVBQVUsRUFBRSxnQkFBZ0IsRUFBRSxlQUFlLEVBQUUsYUFBYSxFQUFFLE9BQU8sRUFBRSxHQUFHLE1BQU0sQ0FBQztJQUN6RixNQUFNLE1BQU0sR0FBRyxNQUFNLENBQUM7SUFDdEIsTUFBTSxFQUFFLFdBQVcsRUFBRSxXQUFXLEVBQUUsZUFBZSxFQUFFLEdBQUcsVUFBVSxDQUFDO0lBQ2pFLE1BQU0sRUFBRSxXQUFXLEVBQUUsZ0JBQWdCLEVBQUUsVUFBVSxFQUFFLGVBQWUsRUFBRSxHQUFHLGFBQWEsQ0FBQztJQUNyRixNQUFNLEVBQUUsTUFBTSxFQUFFLEdBQUcsT0FBTyxDQUFDO0lBRTNCLE1BQU0sa0JBQWtCLEdBQUcsQ0FBQyxPQUFlLEVBQUUsRUFBRTtRQUMzQyxNQUFNLFdBQVcsR0FDYixDQUFDLG1CQUFtQixFQUFFLHdCQUF3QixDQUFDLENBQUMsUUFBUSxDQUFDLGVBQWUsQ0FBQyxJQUFJLE1BQU0sRUFBRSxDQUFDLGdCQUFnQixDQUFDLEVBQUUsR0FBRyxLQUFLLE9BQU8sQ0FBQztRQUM3SCxNQUFNLFdBQVcsR0FBRyxlQUFlLEtBQUssd0JBQXdCLElBQUksTUFBTSxFQUFFLENBQUMsZ0JBQWdCLENBQUMsRUFBRSxHQUFHLEtBQUssT0FBTyxDQUFDO1FBQ2hILE1BQU0sVUFBVSxHQUFHLE9BQU8sQ0FBQyxTQUFTLEVBQUUsQ0FBQyxjQUFjLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ25FLE9BQU87WUFDSCxXQUFXO1lBQ1gsVUFBVTtZQUNWLFdBQVc7U0FDZCxDQUFDO0lBQ04sQ0FBQyxDQUFDO0lBRUYsTUFBTSxVQUFVLEdBQTZCLEVBQUUsQ0FBQztJQUNoRCxLQUFLLElBQUksV0FBVyxHQUFHLGdCQUFnQixFQUFFLFdBQVcsSUFBSSxlQUFlLEVBQUUsV0FBVyxFQUFFLEVBQUUsQ0FBQztRQUNyRixJQUFJLFdBQVcsR0FBRyxXQUFXLEdBQUcsQ0FBQztZQUFFLE1BQU07UUFDekMsSUFBSSxXQUFXLEdBQUcsQ0FBQztZQUFFLFNBQVM7UUFDOUIsTUFBTSxLQUFLLEdBQUcsTUFBTSxFQUFFLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDcEMsSUFBSSxLQUFLLElBQUksSUFBSTtZQUFFLFNBQVM7UUFDNUIsTUFBTSxDQUFDLEdBQUcsVUFBVSxDQUFDLGVBQWUsQ0FBQyxXQUFXLENBQUMsQ0FBQztRQUNsRCxNQUFNLFdBQVcsR0FBRyxVQUFVLENBQUMsY0FBYyxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQzNELE1BQU0sRUFBRSxXQUFXLEVBQUUsVUFBVSxFQUFFLFdBQVcsRUFBRSxHQUFHLGtCQUFrQixDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUMvRSxNQUFNLFNBQVMsR0FBRztZQUNkLENBQUM7WUFDRCxDQUFDLEVBQUUsQ0FBQztZQUNKLEtBQUssRUFBRSxXQUFXO1lBQ2xCLE1BQU0sRUFBRSxlQUFlO1lBQ3ZCLEtBQUs7WUFDTCxNQUFNLEVBQUUsV0FBVyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLFdBQVcsQ0FBQyxDQUFDLENBQUMsU0FBUztZQUMxRCxXQUFXO1lBQ1gsVUFBVTtZQUNWLFdBQVc7U0FDZCxDQUFDO1FBRUYsVUFBVSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUMvQixDQUFDO0lBQ0QsT0FBTyxVQUFVLENBQUM7QUFDdEIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQUlfVEFCTEVfRklFTERfSEVBRCwgQUlfVEFCTEVfRklFTERfSEVBRF9NT1JFLCBDb2xvcnMgfSBmcm9tICcuLi8uLi9jb25zdGFudHMnO1xuaW1wb3J0IHsgQUlUYWJsZUNyZWF0ZUhlYWRzQ29uZmlnLCBBSVRhYmxlRmllbGRIZWFkQ29uZmlnIH0gZnJvbSAnLi4vLi4vdHlwZXMnO1xuXG5leHBvcnQgY29uc3QgY3JlYXRlQ29sdW1uSGVhZHMgPSAoY29uZmlnOiBBSVRhYmxlQ3JlYXRlSGVhZHNDb25maWcpID0+IHtcbiAgICBjb25zdCB7IGNvb3JkaW5hdGUsIGNvbHVtblN0YXJ0SW5kZXgsIGNvbHVtblN0b3BJbmRleCwgcG9pbnRQb3NpdGlvbiwgYWlUYWJsZSB9ID0gY29uZmlnO1xuICAgIGNvbnN0IGNvbG9ycyA9IENvbG9ycztcbiAgICBjb25zdCB7IGNvbHVtbkNvdW50LCByb3dJbml0U2l6ZTogZmllbGRIZWFkSGVpZ2h0IH0gPSBjb29yZGluYXRlO1xuICAgIGNvbnN0IHsgY29sdW1uSW5kZXg6IHBvaW50Q29sdW1uSW5kZXgsIHRhcmdldE5hbWU6IHBvaW50VGFyZ2V0TmFtZSB9ID0gcG9pbnRQb3NpdGlvbjtcbiAgICBjb25zdCB7IGZpZWxkcyB9ID0gYWlUYWJsZTtcblxuICAgIGNvbnN0IGdldEZpZWxkSGVhZFN0YXR1cyA9IChmaWVsZElkOiBzdHJpbmcpID0+IHtcbiAgICAgICAgY29uc3QgaWNvblZpc2libGUgPVxuICAgICAgICAgICAgW0FJX1RBQkxFX0ZJRUxEX0hFQUQsIEFJX1RBQkxFX0ZJRUxEX0hFQURfTU9SRV0uaW5jbHVkZXMocG9pbnRUYXJnZXROYW1lKSAmJiBmaWVsZHMoKVtwb2ludENvbHVtbkluZGV4XT8uX2lkID09PSBmaWVsZElkO1xuICAgICAgICBjb25zdCBpc0hvdmVySWNvbiA9IHBvaW50VGFyZ2V0TmFtZSA9PT0gQUlfVEFCTEVfRklFTERfSEVBRF9NT1JFICYmIGZpZWxkcygpW3BvaW50Q29sdW1uSW5kZXhdPy5faWQgPT09IGZpZWxkSWQ7XG4gICAgICAgIGNvbnN0IGlzU2VsZWN0ZWQgPSBhaVRhYmxlLnNlbGVjdGlvbigpLnNlbGVjdGVkRmllbGRzLmhhcyhmaWVsZElkKTtcbiAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgIGljb25WaXNpYmxlLFxuICAgICAgICAgICAgaXNTZWxlY3RlZCxcbiAgICAgICAgICAgIGlzSG92ZXJJY29uXG4gICAgICAgIH07XG4gICAgfTtcblxuICAgIGNvbnN0IGZpZWxkSGVhZHM6IEFJVGFibGVGaWVsZEhlYWRDb25maWdbXSA9IFtdO1xuICAgIGZvciAobGV0IGNvbHVtbkluZGV4ID0gY29sdW1uU3RhcnRJbmRleDsgY29sdW1uSW5kZXggPD0gY29sdW1uU3RvcEluZGV4OyBjb2x1bW5JbmRleCsrKSB7XG4gICAgICAgIGlmIChjb2x1bW5JbmRleCA+IGNvbHVtbkNvdW50IC0gMSkgYnJlYWs7XG4gICAgICAgIGlmIChjb2x1bW5JbmRleCA8IDApIGNvbnRpbnVlO1xuICAgICAgICBjb25zdCBmaWVsZCA9IGZpZWxkcygpW2NvbHVtbkluZGV4XTtcbiAgICAgICAgaWYgKGZpZWxkID09IG51bGwpIGNvbnRpbnVlO1xuICAgICAgICBjb25zdCB4ID0gY29vcmRpbmF0ZS5nZXRDb2x1bW5PZmZzZXQoY29sdW1uSW5kZXgpO1xuICAgICAgICBjb25zdCBjb2x1bW5XaWR0aCA9IGNvb3JkaW5hdGUuZ2V0Q29sdW1uV2lkdGgoY29sdW1uSW5kZXgpO1xuICAgICAgICBjb25zdCB7IGljb25WaXNpYmxlLCBpc1NlbGVjdGVkLCBpc0hvdmVySWNvbiB9ID0gZ2V0RmllbGRIZWFkU3RhdHVzKGZpZWxkLl9pZCk7XG4gICAgICAgIGNvbnN0IGZpZWxkSGVhZCA9IHtcbiAgICAgICAgICAgIHgsXG4gICAgICAgICAgICB5OiAwLFxuICAgICAgICAgICAgd2lkdGg6IGNvbHVtbldpZHRoLFxuICAgICAgICAgICAgaGVpZ2h0OiBmaWVsZEhlYWRIZWlnaHQsXG4gICAgICAgICAgICBmaWVsZCxcbiAgICAgICAgICAgIHN0cm9rZTogY29sdW1uSW5kZXggPT09IDAgPyBjb2xvcnMudHJhbnNwYXJlbnQgOiB1bmRlZmluZWQsXG4gICAgICAgICAgICBpY29uVmlzaWJsZSxcbiAgICAgICAgICAgIGlzU2VsZWN0ZWQsXG4gICAgICAgICAgICBpc0hvdmVySWNvblxuICAgICAgICB9O1xuXG4gICAgICAgIGZpZWxkSGVhZHMucHVzaChmaWVsZEhlYWQpO1xuICAgIH1cbiAgICByZXR1cm4gZmllbGRIZWFkcztcbn07XG4iXX0=
|
@@ -0,0 +1,97 @@
|
|
1
|
+
import { AddOutlinedPath, AI_TABLE_CELL_PADDING, AI_TABLE_FIELD_ADD_BUTTON_WIDTH, AI_TABLE_ICON_COMMON_SIZE, AI_TABLE_OFFSET, AI_TABLE_ROW_HEAD_SIZE, AI_TABLE_ROW_HEAD_WIDTH } from '../../constants';
|
2
|
+
import { Layout } from './layout-drawer';
|
3
|
+
export class AddRowLayout extends Layout {
|
4
|
+
renderAddFieldBlank() {
|
5
|
+
super.renderAddFieldBlank();
|
6
|
+
const rowHeight = this.rowHeight;
|
7
|
+
const defaultWidth = AI_TABLE_FIELD_ADD_BUTTON_WIDTH;
|
8
|
+
const width = this.containerWidth - this.x < defaultWidth ? defaultWidth : this.containerWidth - this.x;
|
9
|
+
this.line({
|
10
|
+
x: this.x + this.columnWidth,
|
11
|
+
y: this.y,
|
12
|
+
points: [0, rowHeight, width, rowHeight],
|
13
|
+
stroke: this.colors.gray200
|
14
|
+
});
|
15
|
+
}
|
16
|
+
renderCell({ width, isHoverRow }) {
|
17
|
+
const x = this.x;
|
18
|
+
const y = this.y;
|
19
|
+
const rowHeight = this.rowHeight;
|
20
|
+
const fill = isHoverRow ? this.colors.gray80 : this.colors.transparent;
|
21
|
+
this.rect({
|
22
|
+
x,
|
23
|
+
y: y + AI_TABLE_OFFSET,
|
24
|
+
width: width,
|
25
|
+
height: rowHeight,
|
26
|
+
fill
|
27
|
+
});
|
28
|
+
this.line({
|
29
|
+
x,
|
30
|
+
y: y + rowHeight,
|
31
|
+
points: [0, 0, width, 0],
|
32
|
+
stroke: this.colors.gray200
|
33
|
+
});
|
34
|
+
}
|
35
|
+
renderFirstCell({ isHoverRow }) {
|
36
|
+
if (!this.isFirst)
|
37
|
+
return;
|
38
|
+
const y = this.y;
|
39
|
+
const rowHeight = this.rowHeight;
|
40
|
+
const columnWidth = this.columnWidth;
|
41
|
+
const frozenOffset = AI_TABLE_OFFSET;
|
42
|
+
const fill = isHoverRow ? this.colors.gray80 : this.colors.transparent;
|
43
|
+
this.rect({
|
44
|
+
x: frozenOffset,
|
45
|
+
y: y + AI_TABLE_OFFSET,
|
46
|
+
width: columnWidth + AI_TABLE_ROW_HEAD_WIDTH - frozenOffset + 1,
|
47
|
+
height: rowHeight,
|
48
|
+
fill
|
49
|
+
});
|
50
|
+
this.line({
|
51
|
+
x: frozenOffset,
|
52
|
+
y,
|
53
|
+
points: [0, rowHeight, columnWidth + AI_TABLE_ROW_HEAD_WIDTH - frozenOffset + 1, rowHeight],
|
54
|
+
stroke: this.colors.gray200
|
55
|
+
});
|
56
|
+
this.path({
|
57
|
+
x: AI_TABLE_CELL_PADDING,
|
58
|
+
y: y + (rowHeight - AI_TABLE_ICON_COMMON_SIZE) / 2 - AI_TABLE_OFFSET,
|
59
|
+
data: AddOutlinedPath,
|
60
|
+
size: AI_TABLE_ROW_HEAD_SIZE,
|
61
|
+
fill: this.colors.gray600
|
62
|
+
});
|
63
|
+
}
|
64
|
+
renderLastCell({ isHoverRow }) {
|
65
|
+
if (!this.isLast)
|
66
|
+
return;
|
67
|
+
const width = this.columnWidth;
|
68
|
+
if (!this.isFirst) {
|
69
|
+
this.renderCell({
|
70
|
+
width,
|
71
|
+
isHoverRow
|
72
|
+
});
|
73
|
+
}
|
74
|
+
this.renderAddFieldBlank();
|
75
|
+
}
|
76
|
+
renderCommonCell({ isHoverRow }) {
|
77
|
+
if (this.isFirst || this.isLast)
|
78
|
+
return;
|
79
|
+
this.renderCell({
|
80
|
+
width: this.columnWidth,
|
81
|
+
isHoverRow
|
82
|
+
});
|
83
|
+
}
|
84
|
+
render({ isHoverRow }) {
|
85
|
+
this.renderFirstCell({
|
86
|
+
isHoverRow
|
87
|
+
});
|
88
|
+
this.renderCommonCell({
|
89
|
+
isHoverRow
|
90
|
+
});
|
91
|
+
this.renderLastCell({
|
92
|
+
isHoverRow
|
93
|
+
});
|
94
|
+
}
|
95
|
+
}
|
96
|
+
export const addRowLayout = new AddRowLayout();
|
97
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-row-layout-drawer.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/drawers/add-row-layout-drawer.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AddOutlinedPath,\n    AI_TABLE_CELL_PADDING,\n    AI_TABLE_FIELD_ADD_BUTTON_WIDTH,\n    AI_TABLE_ICON_COMMON_SIZE,\n    AI_TABLE_OFFSET,\n    AI_TABLE_ROW_HEAD_SIZE,\n    AI_TABLE_ROW_HEAD_WIDTH\n} from '../../constants';\nimport { AITableCell } from '../../types';\nimport { Layout } from './layout-drawer';\n\nexport class AddRowLayout extends Layout {\n    override renderAddFieldBlank() {\n        super.renderAddFieldBlank();\n\n        const rowHeight = this.rowHeight;\n        const defaultWidth = AI_TABLE_FIELD_ADD_BUTTON_WIDTH;\n        const width = this.containerWidth - this.x < defaultWidth ? defaultWidth : this.containerWidth - this.x;\n\n        this.line({\n            x: this.x + this.columnWidth,\n            y: this.y,\n            points: [0, rowHeight, width, rowHeight],\n            stroke: this.colors.gray200\n        });\n    }\n\n    private renderCell({ width, isHoverRow }: Pick<AITableCell, 'width' | 'isHoverRow'>) {\n        const x = this.x;\n        const y = this.y;\n        const rowHeight = this.rowHeight;\n        const fill = isHoverRow ? this.colors.gray80 : this.colors.transparent;\n\n        this.rect({\n            x,\n            y: y + AI_TABLE_OFFSET,\n            width: width as number,\n            height: rowHeight,\n            fill\n        });\n        this.line({\n            x,\n            y: y + rowHeight,\n            points: [0, 0, width as number, 0],\n            stroke: this.colors.gray200\n        });\n    }\n\n    private renderFirstCell({ isHoverRow }: Pick<AITableCell, 'isHoverRow'>) {\n        if (!this.isFirst) return;\n        const y = this.y;\n        const rowHeight = this.rowHeight;\n        const columnWidth = this.columnWidth;\n        const frozenOffset = AI_TABLE_OFFSET;\n        const fill = isHoverRow ? this.colors.gray80 : this.colors.transparent;\n\n        this.rect({\n            x: frozenOffset,\n            y: y + AI_TABLE_OFFSET,\n            width: columnWidth + AI_TABLE_ROW_HEAD_WIDTH - frozenOffset + 1,\n            height: rowHeight,\n            fill\n        });\n        this.line({\n            x: frozenOffset,\n            y,\n            points: [0, rowHeight, columnWidth + AI_TABLE_ROW_HEAD_WIDTH - frozenOffset + 1, rowHeight],\n            stroke: this.colors.gray200\n        });\n\n        this.path({\n            x: AI_TABLE_CELL_PADDING,\n            y: y + (rowHeight - AI_TABLE_ICON_COMMON_SIZE) / 2 - AI_TABLE_OFFSET,\n            data: AddOutlinedPath,\n            size: AI_TABLE_ROW_HEAD_SIZE,\n            fill: this.colors.gray600\n        });\n    }\n\n    private renderLastCell({ isHoverRow }: Pick<AITableCell, 'isHoverRow'>) {\n        if (!this.isLast) return;\n        const width = this.columnWidth;\n        if (!this.isFirst) {\n            this.renderCell({\n                width,\n                isHoverRow\n            });\n        }\n        this.renderAddFieldBlank();\n    }\n\n    private renderCommonCell({ isHoverRow }: Pick<AITableCell, 'isHoverRow'>) {\n        if (this.isFirst || this.isLast) return;\n        this.renderCell({\n            width: this.columnWidth,\n            isHoverRow\n        });\n    }\n\n    render({ isHoverRow }: Pick<AITableCell, 'isHoverRow'>) {\n        this.renderFirstCell({\n            isHoverRow\n        });\n        this.renderCommonCell({\n            isHoverRow\n        });\n        this.renderLastCell({\n            isHoverRow\n        });\n    }\n}\n\nexport const addRowLayout = new AddRowLayout();\n"]}
|