@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,586 @@
|
|
1
|
+
import _ from 'lodash';
|
2
|
+
import { AI_TABLE_CELL_ADD_ITEM_BUTTON_SIZE, AI_TABLE_CELL_DELETE_ITEM_BUTTON_SIZE, AI_TABLE_CELL_DELETE_ITEM_BUTTON_SIZE_OFFSET, AI_TABLE_CELL_EMOJI_PADDING, AI_TABLE_CELL_EMOJI_SIZE, AI_TABLE_CELL_MAX_ROW_COUNT, AI_TABLE_CELL_MEMBER_ITEM_HEIGHT, AI_TABLE_CELL_MEMBER_ITEM_PADDING, AI_TABLE_CELL_MULTI_DOT_RADIUS, AI_TABLE_CELL_MULTI_ITEM_MARGIN_TOP, AI_TABLE_CELL_MULTI_ITEM_MIN_WIDTH, AI_TABLE_CELL_MULTI_PADDING_LEFT, AI_TABLE_CELL_MULTI_PADDING_TOP, AI_TABLE_CELL_PADDING, AI_TABLE_COMMON_FONT_SIZE, AI_TABLE_DOT_RADIUS, AI_TABLE_MEMBER_AVATAR_SIZE, AI_TABLE_MEMBER_ITEM_AVATAR_MARGIN_RIGHT, AI_TABLE_MEMBER_ITEM_PADDING_RIGHT, AI_TABLE_MIN_TEXT_WIDTH, AI_TABLE_OFFSET, AI_TABLE_OPTION_ITEM_FONT_SIZE, AI_TABLE_OPTION_ITEM_HEIGHT, AI_TABLE_OPTION_ITEM_PADDING, AI_TABLE_OPTION_ITEM_RADIUS, AI_TABLE_PIECE_RADIUS, AI_TABLE_PIECE_WIDTH, AI_TABLE_PROGRESS_BAR_HEIGHT, AI_TABLE_PROGRESS_BAR_RADIUS, AI_TABLE_PROGRESS_TEXT_Width, AI_TABLE_ROW_BLANK_HEIGHT, AI_TABLE_TAG_FONT_SIZE, AI_TABLE_TAG_PADDING, AI_TABLE_TEXT_GAP, Colors, DEFAULT_FONT_FAMILY, DEFAULT_FONT_SIZE, DEFAULT_FONT_WEIGHT, DEFAULT_TEXT_ALIGN_LEFT, DEFAULT_TEXT_ALIGN_RIGHT, DEFAULT_TEXT_DECORATION, DEFAULT_TEXT_LINE_HEIGHT, DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE, FONT_SIZE_SM, StarFill } from '../../constants';
|
3
|
+
import { AITable, AITableFieldType, AITableSelectOptionStyle } from '../../core';
|
4
|
+
import { AITableAvatarSize, AITableAvatarType, AITableMemberType } from '../../types';
|
5
|
+
import { getAvatarBgColor, getAvatarShortName, getTextWidth } from '../../utils';
|
6
|
+
import { Drawer } from './drawer';
|
7
|
+
/**
|
8
|
+
* 处理和渲染表格单元格的内容
|
9
|
+
*/
|
10
|
+
export class CellDrawer extends Drawer {
|
11
|
+
// 样式初始化
|
12
|
+
initStyle(field, styleProps) {
|
13
|
+
const { type: fieldType } = field;
|
14
|
+
const { fontWeight = DEFAULT_FONT_WEIGHT } = styleProps;
|
15
|
+
switch (fieldType) {
|
16
|
+
case AITableFieldType.text:
|
17
|
+
case AITableFieldType.date:
|
18
|
+
case AITableFieldType.createdAt:
|
19
|
+
case AITableFieldType.updatedAt:
|
20
|
+
case AITableFieldType.rate:
|
21
|
+
case AITableFieldType.progress:
|
22
|
+
case AITableFieldType.member:
|
23
|
+
case AITableFieldType.createdBy:
|
24
|
+
case AITableFieldType.updatedBy:
|
25
|
+
return this.setStyle({ fontSize: DEFAULT_FONT_SIZE, fontWeight });
|
26
|
+
default:
|
27
|
+
return null;
|
28
|
+
}
|
29
|
+
}
|
30
|
+
// 单元格渲染
|
31
|
+
renderCell(render, ctx) {
|
32
|
+
const { field } = render;
|
33
|
+
const fieldType = field.type;
|
34
|
+
switch (fieldType) {
|
35
|
+
case AITableFieldType.text:
|
36
|
+
case AITableFieldType.number:
|
37
|
+
case AITableFieldType.link:
|
38
|
+
return this.renderCellText(render, ctx);
|
39
|
+
case AITableFieldType.select:
|
40
|
+
return this.renderCellSelect(render, ctx);
|
41
|
+
case AITableFieldType.date:
|
42
|
+
case AITableFieldType.createdAt:
|
43
|
+
case AITableFieldType.updatedAt:
|
44
|
+
return this.renderCellDate(render, ctx);
|
45
|
+
case AITableFieldType.rate:
|
46
|
+
return this.renderCellRate(render, ctx);
|
47
|
+
case AITableFieldType.progress:
|
48
|
+
return this.renderCellProgress(render, ctx);
|
49
|
+
case AITableFieldType.member:
|
50
|
+
case AITableFieldType.createdBy:
|
51
|
+
case AITableFieldType.updatedBy:
|
52
|
+
return this.renderCellMember(render, ctx);
|
53
|
+
default:
|
54
|
+
return null;
|
55
|
+
}
|
56
|
+
}
|
57
|
+
renderCellText(render, ctx) {
|
58
|
+
const { x, y, transformValue, field, columnWidth, style } = render;
|
59
|
+
const fieldType = field.type;
|
60
|
+
let renderText = fieldType === AITableFieldType.link ? transformValue.text : transformValue;
|
61
|
+
if (renderText == null) {
|
62
|
+
return;
|
63
|
+
}
|
64
|
+
const isSingleLine = !columnWidth;
|
65
|
+
const isTextField = fieldType === AITableFieldType.text;
|
66
|
+
const isNumberField = fieldType === AITableFieldType.number;
|
67
|
+
if (isTextField && isSingleLine) {
|
68
|
+
renderText = renderText.replace(/\r|\n/g, ' ');
|
69
|
+
}
|
70
|
+
const color = style?.color || this.colors.gray800;
|
71
|
+
const textAlign = style?.textAlign || DEFAULT_TEXT_ALIGN_LEFT;
|
72
|
+
const fontWeight = style?.fontWeight;
|
73
|
+
const textMaxWidth = columnWidth - 2 * AI_TABLE_CELL_PADDING;
|
74
|
+
const renderX = textAlign === DEFAULT_TEXT_ALIGN_RIGHT ? x + columnWidth - AI_TABLE_CELL_PADDING : x + AI_TABLE_CELL_PADDING;
|
75
|
+
const renderY = y + AI_TABLE_ROW_BLANK_HEIGHT / 2;
|
76
|
+
const textDecoration = DEFAULT_TEXT_DECORATION;
|
77
|
+
if (isNumberField) {
|
78
|
+
renderText = String(renderText);
|
79
|
+
const { text } = this.textEllipsis({
|
80
|
+
text: renderText,
|
81
|
+
maxWidth: columnWidth && textMaxWidth,
|
82
|
+
fontWeight
|
83
|
+
});
|
84
|
+
if (ctx) {
|
85
|
+
let pureText = text;
|
86
|
+
this.text({
|
87
|
+
x: renderX,
|
88
|
+
y: renderY,
|
89
|
+
text: pureText,
|
90
|
+
textAlign,
|
91
|
+
fillStyle: color,
|
92
|
+
fontWeight,
|
93
|
+
textDecoration,
|
94
|
+
verticalAlign: DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE
|
95
|
+
});
|
96
|
+
}
|
97
|
+
}
|
98
|
+
else {
|
99
|
+
this.wrapText({
|
100
|
+
x: renderX,
|
101
|
+
y: renderY,
|
102
|
+
text: renderText,
|
103
|
+
maxWidth: textMaxWidth,
|
104
|
+
maxRow: AI_TABLE_CELL_MAX_ROW_COUNT,
|
105
|
+
lineHeight: DEFAULT_TEXT_LINE_HEIGHT,
|
106
|
+
textAlign,
|
107
|
+
verticalAlign: DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE,
|
108
|
+
fillStyle: fieldType === AITableFieldType.link ? Colors.primary : color,
|
109
|
+
fontWeight,
|
110
|
+
textDecoration,
|
111
|
+
fieldType,
|
112
|
+
needDraw: true
|
113
|
+
});
|
114
|
+
}
|
115
|
+
}
|
116
|
+
renderCellSelect(render, ctx) {
|
117
|
+
const { field } = render;
|
118
|
+
if (field.settings?.is_multiple) {
|
119
|
+
this.renderCellMultiSelect(render, ctx);
|
120
|
+
}
|
121
|
+
else {
|
122
|
+
this.renderSingleSelectCell(render, ctx);
|
123
|
+
}
|
124
|
+
}
|
125
|
+
renderCellMultiSelect(render, ctx) {
|
126
|
+
const { x, y, field, transformValue, columnWidth } = render;
|
127
|
+
if (!transformValue?.length || !Array.isArray(transformValue))
|
128
|
+
return;
|
129
|
+
let currentX = x + AI_TABLE_CELL_PADDING;
|
130
|
+
const maxContainerWidth = columnWidth - 2 * AI_TABLE_CELL_PADDING;
|
131
|
+
const optionStyle = field.settings.option_style;
|
132
|
+
const fontStyle = `${DEFAULT_FONT_WEIGHT} ${AI_TABLE_OPTION_ITEM_FONT_SIZE}px ${DEFAULT_FONT_FAMILY}`;
|
133
|
+
const isDotOrPiece = optionStyle === AITableSelectOptionStyle.dot || optionStyle === AITableSelectOptionStyle.piece;
|
134
|
+
let totalWidth = 0;
|
135
|
+
const cellItemInfoMap = new Map();
|
136
|
+
let drawableIndex = 0;
|
137
|
+
transformValue.forEach((optionId, index) => {
|
138
|
+
const item = field.settings.options?.find((option) => option._id === optionId);
|
139
|
+
const textWidth = getTextWidth(ctx, item?.text, fontStyle);
|
140
|
+
totalWidth += textWidth + 2 * AI_TABLE_CELL_PADDING;
|
141
|
+
if (index < transformValue.length - 1) {
|
142
|
+
totalWidth += AI_TABLE_CELL_MULTI_PADDING_LEFT;
|
143
|
+
}
|
144
|
+
if (isDotOrPiece) {
|
145
|
+
totalWidth += AI_TABLE_CELL_MULTI_DOT_RADIUS * 2 + AI_TABLE_CELL_MULTI_PADDING_LEFT;
|
146
|
+
}
|
147
|
+
if (totalWidth < maxContainerWidth || totalWidth === maxContainerWidth) {
|
148
|
+
drawableIndex = index;
|
149
|
+
}
|
150
|
+
cellItemInfoMap.set(optionId, { textWidth, item, offset: totalWidth });
|
151
|
+
});
|
152
|
+
const baseWidth = AI_TABLE_MIN_TEXT_WIDTH + AI_TABLE_CELL_PADDING * 2;
|
153
|
+
const minWidth = isDotOrPiece ? baseWidth + AI_TABLE_CELL_MULTI_DOT_RADIUS * 2 + AI_TABLE_CELL_MULTI_PADDING_LEFT : baseWidth;
|
154
|
+
if (transformValue[drawableIndex + 1]) {
|
155
|
+
const { offset: currentOffset } = cellItemInfoMap.get(transformValue[drawableIndex]);
|
156
|
+
const canDrawerNext = maxContainerWidth - currentOffset > minWidth;
|
157
|
+
drawableIndex = canDrawerNext ? drawableIndex + 1 : drawableIndex;
|
158
|
+
// 上面过程是 没有 +数字 的情况下最大能放几个;
|
159
|
+
const number = transformValue.length - (drawableIndex + 1);
|
160
|
+
if (number > 0) {
|
161
|
+
// 说明有 +数字,重新计算
|
162
|
+
const circleWidth = getTextWidth(ctx, `+{number}`, fontStyle) + 2 * AI_TABLE_CELL_PADDING;
|
163
|
+
const max = maxContainerWidth - AI_TABLE_CELL_MULTI_PADDING_LEFT - circleWidth;
|
164
|
+
// 如果当前已经超出了,看是否能容下当前的,不能就减去 1;
|
165
|
+
const currentItemHasOver = currentOffset > max;
|
166
|
+
if (currentItemHasOver) {
|
167
|
+
const lastOffset = drawableIndex === 0 ? 0 : cellItemInfoMap.get(transformValue[drawableIndex - 1]);
|
168
|
+
drawableIndex = max - lastOffset > minWidth ? drawableIndex : drawableIndex - 1;
|
169
|
+
}
|
170
|
+
else {
|
171
|
+
// 还有剩余空间, 看是否能多渲染一个
|
172
|
+
drawableIndex = max - currentOffset > minWidth ? drawableIndex + 1 : drawableIndex;
|
173
|
+
}
|
174
|
+
}
|
175
|
+
}
|
176
|
+
const circleText = `+${transformValue.length - (drawableIndex + 1)}`;
|
177
|
+
const circleWidth = transformValue.length - (drawableIndex + 1) > 0 ? getTextWidth(ctx, circleText, fontStyle) + 2 * AI_TABLE_CELL_PADDING : 0;
|
178
|
+
// 剩余空间
|
179
|
+
let remainSpace = maxContainerWidth - circleWidth - (circleWidth > 0 ? AI_TABLE_CELL_MULTI_PADDING_LEFT : 0);
|
180
|
+
for (let index = 0; index < transformValue.length; index++) {
|
181
|
+
const optionId = transformValue[index];
|
182
|
+
const bgConfig = {
|
183
|
+
x: currentX,
|
184
|
+
y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_OPTION_ITEM_HEIGHT) / 2,
|
185
|
+
height: AI_TABLE_OPTION_ITEM_HEIGHT,
|
186
|
+
radius: AI_TABLE_PIECE_RADIUS,
|
187
|
+
fill: Colors.gray100,
|
188
|
+
width: 0
|
189
|
+
};
|
190
|
+
const commonItem = (optionStyle, shape) => {
|
191
|
+
const baseWidth = isDotOrPiece
|
192
|
+
? AI_TABLE_CELL_MULTI_DOT_RADIUS * 2 + AI_TABLE_CELL_MULTI_PADDING_LEFT + AI_TABLE_CELL_PADDING * 2
|
193
|
+
: AI_TABLE_CELL_PADDING * 2;
|
194
|
+
if (remainSpace < minWidth) {
|
195
|
+
return;
|
196
|
+
}
|
197
|
+
const { textWidth, item } = cellItemInfoMap.get(optionId);
|
198
|
+
const completeWidth = baseWidth + textWidth;
|
199
|
+
if (index !== transformValue.length - 1) {
|
200
|
+
remainSpace -= AI_TABLE_CELL_MULTI_PADDING_LEFT;
|
201
|
+
}
|
202
|
+
const bgWidth = remainSpace > completeWidth ? completeWidth : remainSpace;
|
203
|
+
bgConfig.width = bgWidth;
|
204
|
+
if (isDotOrPiece) {
|
205
|
+
this.rect(bgConfig);
|
206
|
+
if (shape === 'rect') {
|
207
|
+
this.rect({
|
208
|
+
x: bgConfig.x + AI_TABLE_CELL_PADDING,
|
209
|
+
y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_CELL_MULTI_DOT_RADIUS * 2) / 2,
|
210
|
+
width: AI_TABLE_CELL_MULTI_DOT_RADIUS * 2,
|
211
|
+
height: AI_TABLE_CELL_MULTI_DOT_RADIUS * 2,
|
212
|
+
radius: AI_TABLE_PIECE_RADIUS,
|
213
|
+
fill: item?.bg_color ?? item?.color ?? Colors.primary
|
214
|
+
});
|
215
|
+
}
|
216
|
+
else if (shape === 'arc') {
|
217
|
+
this.arc({
|
218
|
+
x: bgConfig.x + AI_TABLE_CELL_PADDING,
|
219
|
+
y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_CELL_MULTI_DOT_RADIUS * 2) / 2 + AI_TABLE_CELL_MULTI_DOT_RADIUS,
|
220
|
+
radius: AI_TABLE_CELL_MULTI_DOT_RADIUS,
|
221
|
+
fill: item?.bg_color ?? item?.color ?? Colors.primary
|
222
|
+
});
|
223
|
+
}
|
224
|
+
this.text({
|
225
|
+
x: bgConfig.x + AI_TABLE_CELL_PADDING + AI_TABLE_CELL_MULTI_DOT_RADIUS * 2 + AI_TABLE_CELL_MULTI_PADDING_LEFT,
|
226
|
+
y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_OPTION_ITEM_FONT_SIZE) / 2,
|
227
|
+
text: this.textEllipsis({
|
228
|
+
text: item.text,
|
229
|
+
maxWidth: bgWidth - baseWidth,
|
230
|
+
fontSize: AI_TABLE_OPTION_ITEM_FONT_SIZE
|
231
|
+
}).text,
|
232
|
+
fillStyle: Colors.gray700,
|
233
|
+
fontSize: AI_TABLE_OPTION_ITEM_FONT_SIZE
|
234
|
+
});
|
235
|
+
}
|
236
|
+
else if (optionStyle === AITableSelectOptionStyle.tag) {
|
237
|
+
this.tag({
|
238
|
+
x: bgConfig.x,
|
239
|
+
y: bgConfig.y,
|
240
|
+
width: bgConfig.width,
|
241
|
+
text: this.textEllipsis({
|
242
|
+
text: item.text,
|
243
|
+
maxWidth: bgWidth - baseWidth,
|
244
|
+
fontSize: AI_TABLE_TAG_FONT_SIZE
|
245
|
+
}).text,
|
246
|
+
radius: AI_TABLE_OPTION_ITEM_RADIUS,
|
247
|
+
fontSize: AI_TABLE_TAG_FONT_SIZE,
|
248
|
+
height: bgConfig.height,
|
249
|
+
color: Colors.white,
|
250
|
+
padding: AI_TABLE_CELL_PADDING,
|
251
|
+
background: item?.bg_color ?? item?.color ?? Colors.primary
|
252
|
+
});
|
253
|
+
}
|
254
|
+
else {
|
255
|
+
this.rect(bgConfig);
|
256
|
+
this.text({
|
257
|
+
x: bgConfig.x + AI_TABLE_CELL_PADDING,
|
258
|
+
y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_TAG_FONT_SIZE) / 2,
|
259
|
+
text: this.textEllipsis({
|
260
|
+
text: item.text,
|
261
|
+
maxWidth: bgWidth - baseWidth,
|
262
|
+
fontSize: AI_TABLE_TAG_FONT_SIZE
|
263
|
+
}).text,
|
264
|
+
fillStyle: Colors.gray700,
|
265
|
+
fontSize: AI_TABLE_TAG_FONT_SIZE
|
266
|
+
});
|
267
|
+
}
|
268
|
+
const currentWidth = bgConfig.width;
|
269
|
+
remainSpace -= currentWidth;
|
270
|
+
currentX += currentWidth + AI_TABLE_CELL_MULTI_PADDING_LEFT;
|
271
|
+
};
|
272
|
+
switch (optionStyle) {
|
273
|
+
case AITableSelectOptionStyle.dot:
|
274
|
+
commonItem(AITableSelectOptionStyle.dot, 'arc');
|
275
|
+
break;
|
276
|
+
case AITableSelectOptionStyle.piece:
|
277
|
+
commonItem(AITableSelectOptionStyle.piece, 'rect');
|
278
|
+
break;
|
279
|
+
case AITableSelectOptionStyle.tag:
|
280
|
+
commonItem(AITableSelectOptionStyle.tag, '');
|
281
|
+
break;
|
282
|
+
default:
|
283
|
+
commonItem(AITableSelectOptionStyle.text, '');
|
284
|
+
break;
|
285
|
+
}
|
286
|
+
}
|
287
|
+
if (circleWidth > 0) {
|
288
|
+
if (optionStyle === AITableSelectOptionStyle.tag) {
|
289
|
+
this.tag({
|
290
|
+
x: currentX,
|
291
|
+
y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_OPTION_ITEM_HEIGHT) / 2,
|
292
|
+
width: circleWidth,
|
293
|
+
height: AI_TABLE_OPTION_ITEM_HEIGHT,
|
294
|
+
text: circleText,
|
295
|
+
background: Colors.gray100,
|
296
|
+
color: Colors.gray700,
|
297
|
+
radius: AI_TABLE_OPTION_ITEM_RADIUS,
|
298
|
+
padding: AI_TABLE_CELL_PADDING,
|
299
|
+
fontSize: AI_TABLE_TAG_FONT_SIZE
|
300
|
+
});
|
301
|
+
}
|
302
|
+
else {
|
303
|
+
this.rect({
|
304
|
+
x: currentX,
|
305
|
+
y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_OPTION_ITEM_HEIGHT) / 2,
|
306
|
+
width: circleWidth,
|
307
|
+
height: AI_TABLE_OPTION_ITEM_HEIGHT,
|
308
|
+
fill: Colors.gray100,
|
309
|
+
radius: AI_TABLE_PIECE_RADIUS
|
310
|
+
});
|
311
|
+
this.text({
|
312
|
+
x: currentX + AI_TABLE_CELL_PADDING,
|
313
|
+
y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_TAG_FONT_SIZE) / 2,
|
314
|
+
text: circleText,
|
315
|
+
fillStyle: Colors.gray700,
|
316
|
+
fontSize: AI_TABLE_TAG_FONT_SIZE
|
317
|
+
});
|
318
|
+
}
|
319
|
+
}
|
320
|
+
}
|
321
|
+
renderSingleSelectCell(render, ctx) {
|
322
|
+
const { x, y, transformValue, field, columnWidth, isActive } = render;
|
323
|
+
if (transformValue == null || transformValue === '') {
|
324
|
+
return;
|
325
|
+
}
|
326
|
+
const isOperating = isActive;
|
327
|
+
const item = field.settings.options?.find((option) => option._id === transformValue[0]);
|
328
|
+
const itemName = item?.text || '';
|
329
|
+
const getTextEllipsis = (maxTextWidth, fontSize = AI_TABLE_COMMON_FONT_SIZE) => {
|
330
|
+
maxTextWidth -= isOperating ? AI_TABLE_CELL_DELETE_ITEM_BUTTON_SIZE - AI_TABLE_CELL_DELETE_ITEM_BUTTON_SIZE_OFFSET : 0;
|
331
|
+
return this.textEllipsis({
|
332
|
+
text: itemName,
|
333
|
+
maxWidth: columnWidth && maxTextWidth,
|
334
|
+
fontSize: fontSize
|
335
|
+
});
|
336
|
+
};
|
337
|
+
if (ctx) {
|
338
|
+
ctx.save();
|
339
|
+
ctx.globalAlpha = 1;
|
340
|
+
const colors = AITable.getColors();
|
341
|
+
const optionStyle = field.settings.option_style;
|
342
|
+
let background = item?.bg_color ?? item?.color ?? colors.primary;
|
343
|
+
const dotMaxTextWidth = columnWidth - 2 * AI_TABLE_CELL_PADDING - AI_TABLE_PIECE_WIDTH - AI_TABLE_TEXT_GAP;
|
344
|
+
const borderWidth = 1;
|
345
|
+
switch (optionStyle) {
|
346
|
+
case AITableSelectOptionStyle.dot:
|
347
|
+
// 这里的 AI_TABLE_OFFSET 偏移不确定是为啥(包括 piece 的),只是为了保持和编辑组件中的对齐
|
348
|
+
this.arc({
|
349
|
+
x: x + AI_TABLE_CELL_PADDING + AI_TABLE_DOT_RADIUS,
|
350
|
+
y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_PIECE_WIDTH) / 2 + AI_TABLE_DOT_RADIUS - AI_TABLE_OFFSET,
|
351
|
+
radius: AI_TABLE_DOT_RADIUS,
|
352
|
+
fill: background
|
353
|
+
});
|
354
|
+
this.text({
|
355
|
+
x: x + AI_TABLE_PIECE_WIDTH + AI_TABLE_TEXT_GAP + AI_TABLE_CELL_PADDING,
|
356
|
+
y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_OPTION_ITEM_FONT_SIZE) / 2,
|
357
|
+
text: getTextEllipsis(dotMaxTextWidth).text,
|
358
|
+
fillStyle: colors.gray800
|
359
|
+
});
|
360
|
+
break;
|
361
|
+
case AITableSelectOptionStyle.piece:
|
362
|
+
this.rect({
|
363
|
+
x: x + AI_TABLE_CELL_PADDING,
|
364
|
+
y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_PIECE_WIDTH) / 2 - AI_TABLE_OFFSET,
|
365
|
+
width: AI_TABLE_PIECE_WIDTH,
|
366
|
+
height: AI_TABLE_PIECE_WIDTH,
|
367
|
+
radius: AI_TABLE_PIECE_RADIUS,
|
368
|
+
fill: background
|
369
|
+
});
|
370
|
+
this.text({
|
371
|
+
x: x + AI_TABLE_PIECE_WIDTH + AI_TABLE_TEXT_GAP + AI_TABLE_CELL_PADDING,
|
372
|
+
y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_OPTION_ITEM_FONT_SIZE) / 2,
|
373
|
+
text: getTextEllipsis(dotMaxTextWidth).text,
|
374
|
+
fillStyle: colors.gray800
|
375
|
+
});
|
376
|
+
break;
|
377
|
+
case AITableSelectOptionStyle.tag:
|
378
|
+
const maxTextWidth = columnWidth - 2 * (AI_TABLE_CELL_PADDING + AI_TABLE_TAG_PADDING);
|
379
|
+
const { textWidth, text } = getTextEllipsis(maxTextWidth, AI_TABLE_TAG_FONT_SIZE);
|
380
|
+
const width = Math.max(textWidth + 2 * AI_TABLE_TAG_PADDING, AI_TABLE_CELL_MULTI_ITEM_MIN_WIDTH);
|
381
|
+
this.tag({
|
382
|
+
x: x + AI_TABLE_CELL_PADDING,
|
383
|
+
y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_OPTION_ITEM_HEIGHT) / 2,
|
384
|
+
width,
|
385
|
+
height: AI_TABLE_OPTION_ITEM_HEIGHT,
|
386
|
+
text,
|
387
|
+
background,
|
388
|
+
color: colors.white,
|
389
|
+
radius: AI_TABLE_OPTION_ITEM_RADIUS,
|
390
|
+
padding: AI_TABLE_OPTION_ITEM_PADDING,
|
391
|
+
fontSize: AI_TABLE_TAG_FONT_SIZE,
|
392
|
+
stroke: background
|
393
|
+
});
|
394
|
+
break;
|
395
|
+
default:
|
396
|
+
const textMaxTextWidth = columnWidth - 2 * AI_TABLE_CELL_PADDING;
|
397
|
+
this.text({
|
398
|
+
x: x + AI_TABLE_CELL_PADDING,
|
399
|
+
y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_OPTION_ITEM_FONT_SIZE) / 2,
|
400
|
+
text: getTextEllipsis(textMaxTextWidth).text,
|
401
|
+
fillStyle: colors.gray800
|
402
|
+
});
|
403
|
+
break;
|
404
|
+
}
|
405
|
+
ctx.restore();
|
406
|
+
}
|
407
|
+
}
|
408
|
+
renderCellDate(render, ctx) {
|
409
|
+
const { x, y, transformValue, columnWidth, style } = render;
|
410
|
+
const colors = AITable.getColors();
|
411
|
+
let cellText = transformValue;
|
412
|
+
if (cellText == null || !_.isString(cellText)) {
|
413
|
+
return;
|
414
|
+
}
|
415
|
+
const textMaxWidth = columnWidth - 2 * AI_TABLE_CELL_PADDING;
|
416
|
+
const { text } = this.textEllipsis({ text: cellText, maxWidth: columnWidth && textMaxWidth });
|
417
|
+
if (ctx) {
|
418
|
+
const color = style?.color || colors.gray800;
|
419
|
+
this.text({
|
420
|
+
x: x + AI_TABLE_CELL_PADDING,
|
421
|
+
y: y + AI_TABLE_ROW_BLANK_HEIGHT / 2,
|
422
|
+
text,
|
423
|
+
fillStyle: color,
|
424
|
+
fontWeight: style?.fontWeight,
|
425
|
+
verticalAlign: DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE
|
426
|
+
});
|
427
|
+
}
|
428
|
+
}
|
429
|
+
renderCellRate(render, ctx) {
|
430
|
+
const { x, y, transformValue: _cellValue } = render;
|
431
|
+
const max = 5;
|
432
|
+
const cellValue = _cellValue || 0;
|
433
|
+
const size = AI_TABLE_CELL_EMOJI_SIZE;
|
434
|
+
return [...Array(max).keys()].map((item, index) => {
|
435
|
+
const value = index + 1;
|
436
|
+
const checked = value <= cellValue;
|
437
|
+
const iconX = index * size + AI_TABLE_CELL_PADDING + index * AI_TABLE_CELL_EMOJI_PADDING;
|
438
|
+
const iconY = (AI_TABLE_ROW_BLANK_HEIGHT - size) / 2;
|
439
|
+
if (ctx && checked) {
|
440
|
+
this.path({
|
441
|
+
x: x + iconX,
|
442
|
+
y: y + iconY,
|
443
|
+
size: 22,
|
444
|
+
data: StarFill,
|
445
|
+
fill: this.colors.waring,
|
446
|
+
scaleX: 1.14,
|
447
|
+
scaleY: 1.14
|
448
|
+
});
|
449
|
+
}
|
450
|
+
});
|
451
|
+
}
|
452
|
+
renderCellProgress(render, ctx) {
|
453
|
+
const { x, y, transformValue, columnWidth, style } = render;
|
454
|
+
const colors = AITable.getColors();
|
455
|
+
const cellText = transformValue;
|
456
|
+
if (cellText == null || !_.isNumber(cellText)) {
|
457
|
+
return;
|
458
|
+
}
|
459
|
+
const width = columnWidth - 2 * AI_TABLE_CELL_PADDING - AI_TABLE_PROGRESS_TEXT_Width;
|
460
|
+
const height = AI_TABLE_PROGRESS_BAR_HEIGHT;
|
461
|
+
const textHeight = AI_TABLE_COMMON_FONT_SIZE;
|
462
|
+
const offsetX = AI_TABLE_CELL_PADDING;
|
463
|
+
const offsetY = (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_PROGRESS_BAR_HEIGHT) / 2;
|
464
|
+
const textOffsetY = (AI_TABLE_ROW_BLANK_HEIGHT - textHeight) / 2;
|
465
|
+
// 绘制背景
|
466
|
+
this.rect({
|
467
|
+
x: x + offsetX,
|
468
|
+
y: y + offsetY,
|
469
|
+
width,
|
470
|
+
height,
|
471
|
+
radius: AI_TABLE_PROGRESS_BAR_RADIUS,
|
472
|
+
fill: colors.gray200
|
473
|
+
});
|
474
|
+
// 计算并绘制进度
|
475
|
+
const progressWidth = (transformValue / 100) * width;
|
476
|
+
this.rect({
|
477
|
+
x: x + offsetX,
|
478
|
+
y: y + offsetY,
|
479
|
+
width: progressWidth,
|
480
|
+
height,
|
481
|
+
radius: AI_TABLE_PROGRESS_BAR_RADIUS,
|
482
|
+
fill: colors.success
|
483
|
+
});
|
484
|
+
this.text({
|
485
|
+
x: x + offsetX + width + AI_TABLE_TEXT_GAP,
|
486
|
+
y: y + textOffsetY,
|
487
|
+
text: `${transformValue}%`,
|
488
|
+
fillStyle: colors.gray800
|
489
|
+
});
|
490
|
+
}
|
491
|
+
renderCellMember(render, ctx) {
|
492
|
+
const { references, x, y, field, transformValue: _cellValue, rowHeight, columnWidth, isActive } = render;
|
493
|
+
const cellValue = _cellValue;
|
494
|
+
if (!cellValue?.length || !references) {
|
495
|
+
return;
|
496
|
+
}
|
497
|
+
const settings = field.settings;
|
498
|
+
const avatarSize = AI_TABLE_MEMBER_AVATAR_SIZE;
|
499
|
+
const itemHeight = AI_TABLE_CELL_MEMBER_ITEM_HEIGHT;
|
500
|
+
const isOperating = isActive;
|
501
|
+
const isMulti = settings?.is_multiple;
|
502
|
+
let currentX = AI_TABLE_CELL_PADDING;
|
503
|
+
let currentY = (AI_TABLE_ROW_BLANK_HEIGHT - avatarSize) / 2;
|
504
|
+
const itemOtherWidth = avatarSize + AI_TABLE_MEMBER_ITEM_PADDING_RIGHT + AI_TABLE_MEMBER_ITEM_AVATAR_MARGIN_RIGHT;
|
505
|
+
const maxHeight = isActive ? 130 - AI_TABLE_CELL_MULTI_PADDING_TOP : rowHeight - AI_TABLE_CELL_MULTI_PADDING_TOP;
|
506
|
+
const maxTextWidth = isOperating
|
507
|
+
? columnWidth - 2 * AI_TABLE_CELL_PADDING - itemOtherWidth - AI_TABLE_CELL_DELETE_ITEM_BUTTON_SIZE - 12
|
508
|
+
: columnWidth - 2 * AI_TABLE_CELL_PADDING - itemOtherWidth;
|
509
|
+
const listCount = cellValue.length;
|
510
|
+
let isOverflow = false;
|
511
|
+
for (let index = 0; index < listCount; index++) {
|
512
|
+
const userInfo = references?.members[cellValue[index]];
|
513
|
+
if (!userInfo)
|
514
|
+
continue;
|
515
|
+
const { uid, display_name, avatar } = userInfo;
|
516
|
+
const type = AITableMemberType.member;
|
517
|
+
const itemWidth = AITableAvatarSize.size24 + (isMulti ? AI_TABLE_CELL_MEMBER_ITEM_PADDING : 0);
|
518
|
+
currentX = AI_TABLE_CELL_PADDING + index * itemWidth;
|
519
|
+
let realMaxTextWidth = maxTextWidth < 0 ? 0 : maxTextWidth;
|
520
|
+
if (index === 0 && isOperating) {
|
521
|
+
const operatingMaxWidth = maxTextWidth - (AI_TABLE_CELL_ADD_ITEM_BUTTON_SIZE + 4);
|
522
|
+
// item No space to display, then perform a line feed
|
523
|
+
if (operatingMaxWidth <= 20) {
|
524
|
+
currentX = AI_TABLE_CELL_PADDING;
|
525
|
+
currentY += AI_TABLE_OPTION_ITEM_HEIGHT + AI_TABLE_CELL_MULTI_ITEM_MARGIN_TOP;
|
526
|
+
}
|
527
|
+
else {
|
528
|
+
realMaxTextWidth = operatingMaxWidth;
|
529
|
+
}
|
530
|
+
}
|
531
|
+
let isMore = currentX + itemWidth > columnWidth - 2 * AI_TABLE_CELL_PADDING;
|
532
|
+
if (columnWidth != null) {
|
533
|
+
// 在非活动状态下,当超出列宽时,不会渲染后续内容
|
534
|
+
if (!isActive && currentX >= columnWidth - 2 * AI_TABLE_CELL_PADDING) {
|
535
|
+
break;
|
536
|
+
}
|
537
|
+
// 如果不是非活动状态的最后一行,则换行渲染溢出内容
|
538
|
+
if (!isActive && currentX > columnWidth - 2 * AI_TABLE_CELL_PADDING) {
|
539
|
+
currentX = AI_TABLE_CELL_PADDING;
|
540
|
+
}
|
541
|
+
if (isActive && currentX + itemWidth > columnWidth - AI_TABLE_CELL_PADDING) {
|
542
|
+
currentX = AI_TABLE_CELL_PADDING;
|
543
|
+
currentY += itemHeight;
|
544
|
+
}
|
545
|
+
if (isActive && currentY >= maxHeight) {
|
546
|
+
isOverflow = true;
|
547
|
+
}
|
548
|
+
}
|
549
|
+
if (ctx && !isActive) {
|
550
|
+
this.avatar({
|
551
|
+
x: x + currentX,
|
552
|
+
y: y + currentY,
|
553
|
+
url: avatar,
|
554
|
+
id: uid,
|
555
|
+
title: getAvatarShortName(display_name),
|
556
|
+
bgColor: getAvatarBgColor(display_name),
|
557
|
+
type: AITableAvatarType.member,
|
558
|
+
size: AITableAvatarSize.size24
|
559
|
+
});
|
560
|
+
if (isMore) {
|
561
|
+
ctx.save();
|
562
|
+
ctx.globalAlpha = 0.3;
|
563
|
+
this.rect({
|
564
|
+
x: x + currentX,
|
565
|
+
y: y + currentY,
|
566
|
+
width: AITableAvatarSize.size24,
|
567
|
+
height: AITableAvatarSize.size24,
|
568
|
+
radius: 24,
|
569
|
+
fill: this.colors.black
|
570
|
+
});
|
571
|
+
ctx.restore();
|
572
|
+
this.text({
|
573
|
+
x: x + currentX + FONT_SIZE_SM / 2,
|
574
|
+
y: y + AI_TABLE_ROW_BLANK_HEIGHT / 2,
|
575
|
+
fillStyle: this.colors.white,
|
576
|
+
fontSize: FONT_SIZE_SM,
|
577
|
+
text: `+${listCount - index - 1}`,
|
578
|
+
verticalAlign: DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE
|
579
|
+
});
|
580
|
+
}
|
581
|
+
}
|
582
|
+
}
|
583
|
+
}
|
584
|
+
}
|
585
|
+
export const cellDrawer = new CellDrawer();
|
586
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cell-drawer.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/drawers/cell-drawer.ts"],"names":[],"mappings":"AAAA,OAAO,CAAC,MAAM,QAAQ,CAAC;AACvB,OAAO,EACH,kCAAkC,EAClC,qCAAqC,EACrC,4CAA4C,EAC5C,2BAA2B,EAC3B,wBAAwB,EACxB,2BAA2B,EAC3B,gCAAgC,EAChC,iCAAiC,EACjC,8BAA8B,EAC9B,mCAAmC,EACnC,kCAAkC,EAClC,gCAAgC,EAChC,+BAA+B,EAC/B,qBAAqB,EACrB,yBAAyB,EACzB,mBAAmB,EACnB,2BAA2B,EAC3B,wCAAwC,EACxC,kCAAkC,EAClC,uBAAuB,EACvB,eAAe,EACf,8BAA8B,EAC9B,2BAA2B,EAC3B,4BAA4B,EAC5B,2BAA2B,EAC3B,qBAAqB,EACrB,oBAAoB,EACpB,4BAA4B,EAC5B,4BAA4B,EAC5B,4BAA4B,EAC5B,yBAAyB,EACzB,sBAAsB,EACtB,oBAAoB,EACpB,iBAAiB,EACjB,MAAM,EACN,mBAAmB,EACnB,iBAAiB,EACjB,mBAAmB,EACnB,uBAAuB,EACvB,wBAAwB,EACxB,uBAAuB,EACvB,wBAAwB,EACxB,kCAAkC,EAClC,YAAY,EACZ,QAAQ,EACX,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,OAAO,EAAgB,gBAAgB,EAAE,wBAAwB,EAAkC,MAAM,YAAY,CAAC;AAC/H,OAAO,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,iBAAiB,EAAqC,MAAM,aAAa,CAAC;AACzH,OAAO,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AACjF,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAElC;;GAEG;AACH,MAAM,OAAO,UAAW,SAAQ,MAAM;IAClC,QAAQ;IACD,SAAS,CAAC,KAAmB,EAAE,UAA+B;QACjE,MAAM,EAAE,IAAI,EAAE,SAAS,EAAE,GAAG,KAAK,CAAC;QAClC,MAAM,EAAE,UAAU,GAAG,mBAAmB,EAAE,GAAG,UAAU,CAAC;QAExD,QAAQ,SAAS,EAAE,CAAC;YAChB,KAAK,gBAAgB,CAAC,IAAI,CAAC;YAC3B,KAAK,gBAAgB,CAAC,IAAI,CAAC;YAC3B,KAAK,gBAAgB,CAAC,SAAS,CAAC;YAChC,KAAK,gBAAgB,CAAC,SAAS,CAAC;YAChC,KAAK,gBAAgB,CAAC,IAAI,CAAC;YAC3B,KAAK,gBAAgB,CAAC,QAAQ,CAAC;YAC/B,KAAK,gBAAgB,CAAC,MAAM,CAAC;YAC7B,KAAK,gBAAgB,CAAC,SAAS,CAAC;YAChC,KAAK,gBAAgB,CAAC,SAAS;gBAC3B,OAAO,IAAI,CAAC,QAAQ,CAAC,EAAE,QAAQ,EAAE,iBAAiB,EAAE,UAAU,EAAE,CAAC,CAAC;YACtE;gBACI,OAAO,IAAI,CAAC;QACpB,CAAC;IACL,CAAC;IAED,QAAQ;IACD,UAAU,CAAC,MAAqB,EAAE,GAA0C;QAC/E,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM,CAAC;QACzB,MAAM,SAAS,GAAG,KAAK,CAAC,IAAI,CAAC;QAE7B,QAAQ,SAAS,EAAE,CAAC;YAChB,KAAK,gBAAgB,CAAC,IAAI,CAAC;YAC3B,KAAK,gBAAgB,CAAC,MAAM,CAAC;YAC7B,KAAK,gBAAgB,CAAC,IAAI;gBACtB,OAAO,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;YAC5C,KAAK,gBAAgB,CAAC,MAAM;gBACxB,OAAO,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;YAC9C,KAAK,gBAAgB,CAAC,IAAI,CAAC;YAC3B,KAAK,gBAAgB,CAAC,SAAS,CAAC;YAChC,KAAK,gBAAgB,CAAC,SAAS;gBAC3B,OAAO,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;YAC5C,KAAK,gBAAgB,CAAC,IAAI;gBACtB,OAAO,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;YAC5C,KAAK,gBAAgB,CAAC,QAAQ;gBAC1B,OAAO,IAAI,CAAC,kBAAkB,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;YAChD,KAAK,gBAAgB,CAAC,MAAM,CAAC;YAC7B,KAAK,gBAAgB,CAAC,SAAS,CAAC;YAChC,KAAK,gBAAgB,CAAC,SAAS;gBAC3B,OAAO,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;YAC9C;gBACI,OAAO,IAAI,CAAC;QACpB,CAAC;IACL,CAAC;IAEO,cAAc,CAAC,MAAqB,EAAE,GAAS;QACnD,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,cAAc,EAAE,KAAK,EAAE,WAAW,EAAE,KAAK,EAAE,GAAG,MAAM,CAAC;QACnE,MAAM,SAAS,GAAG,KAAK,CAAC,IAAI,CAAC;QAC7B,IAAI,UAAU,GAAkB,SAAS,KAAK,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,cAAc,CAAC;QAC3G,IAAI,UAAU,IAAI,IAAI,EAAE,CAAC;YACrB,OAAO;QACX,CAAC;QACD,MAAM,YAAY,GAAG,CAAC,WAAW,CAAC;QAClC,MAAM,WAAW,GAAG,SAAS,KAAK,gBAAgB,CAAC,IAAI,CAAC;QACxD,MAAM,aAAa,GAAG,SAAS,KAAK,gBAAgB,CAAC,MAAM,CAAC;QAE5D,IAAI,WAAW,IAAI,YAAY,EAAE,CAAC;YAC9B,UAAU,GAAG,UAAU,CAAC,OAAO,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;QACnD,CAAC;QAED,MAAM,KAAK,GAAG,KAAK,EAAE,KAAK,IAAI,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;QAClD,MAAM,SAAS,GAAG,KAAK,EAAE,SAAS,IAAI,uBAAuB,CAAC;QAC9D,MAAM,UAAU,GAAG,KAAK,EAAE,UAAU,CAAC;QACrC,MAAM,YAAY,GAAG,WAAW,GAAG,CAAC,GAAG,qBAAqB,CAAC;QAC7D,MAAM,OAAO,GAAG,SAAS,KAAK,wBAAwB,CAAC,CAAC,CAAC,CAAC,GAAG,WAAW,GAAG,qBAAqB,CAAC,CAAC,CAAC,CAAC,GAAG,qBAAqB,CAAC;QAC7H,MAAM,OAAO,GAAG,CAAC,GAAG,yBAAyB,GAAG,CAAC,CAAC;QAClD,MAAM,cAAc,GAAG,uBAAuB,CAAC;QAE/C,IAAI,aAAa,EAAE,CAAC;YAChB,UAAU,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;YAChC,MAAM,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,YAAY,CAAC;gBAC/B,IAAI,EAAE,UAAU;gBAChB,QAAQ,EAAE,WAAW,IAAI,YAAY;gBACrC,UAAU;aACb,CAAC,CAAC;YACH,IAAI,GAAG,EAAE,CAAC;gBACN,IAAI,QAAQ,GAAG,IAAI,CAAC;gBACpB,IAAI,CAAC,IAAI,CAAC;oBACN,CAAC,EAAE,OAAO;oBACV,CAAC,EAAE,OAAO;oBACV,IAAI,EAAE,QAAQ;oBACd,SAAS;oBACT,SAAS,EAAE,KAAK;oBAChB,UAAU;oBACV,cAAc;oBACd,aAAa,EAAE,kCAAkC;iBACpD,CAAC,CAAC;YACP,CAAC;QACL,CAAC;aAAM,CAAC;YACJ,IAAI,CAAC,QAAQ,CAAC;gBACV,CAAC,EAAE,OAAO;gBACV,CAAC,EAAE,OAAO;gBACV,IAAI,EAAE,UAAU;gBAChB,QAAQ,EAAE,YAAY;gBACtB,MAAM,EAAE,2BAA2B;gBACnC,UAAU,EAAE,wBAAwB;gBACpC,SAAS;gBACT,aAAa,EAAE,kCAAkC;gBACjD,SAAS,EAAE,SAAS,KAAK,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK;gBACvE,UAAU;gBACV,cAAc;gBACd,SAAS;gBACT,QAAQ,EAAE,IAAI;aACjB,CAAC,CAAC;QACP,CAAC;IACL,CAAC;IAEO,gBAAgB,CAAC,MAAqB,EAAE,GAAS;QACrD,MAAM,EAAE,KAAK,EAAE,GAAG,MAAM,CAAC;QACzB,IAAK,KAA4B,CAAC,QAAQ,EAAE,WAAW,EAAE,CAAC;YACtD,IAAI,CAAC,qBAAqB,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;QAC5C,CAAC;aAAM,CAAC;YACJ,IAAI,CAAC,sBAAsB,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;QAC7C,CAAC;IACL,CAAC;IAEO,qBAAqB,CAAC,MAAqB,EAAE,GAAS;QAC1D,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,cAAc,EAAE,WAAW,EAAE,GAAG,MAAM,CAAC;QAC5D,IAAI,CAAC,cAAc,EAAE,MAAM,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,cAAc,CAAC;YAAE,OAAO;QACtE,IAAI,QAAQ,GAAG,CAAC,GAAG,qBAAqB,CAAC;QACzC,MAAM,iBAAiB,GAAG,WAAW,GAAG,CAAC,GAAG,qBAAqB,CAAC;QAClE,MAAM,WAAW,GAAI,KAA4B,CAAC,QAAQ,CAAC,YAAY,CAAC;QACxE,MAAM,SAAS,GAAG,GAAG,mBAAmB,IAAI,8BAA8B,MAAM,mBAAmB,EAAE,CAAC;QACtG,MAAM,YAAY,GAAG,WAAW,KAAK,wBAAwB,CAAC,GAAG,IAAI,WAAW,KAAK,wBAAwB,CAAC,KAAK,CAAC;QAEpH,IAAI,UAAU,GAAG,CAAC,CAAC;QACnB,MAAM,eAAe,GAAG,IAAI,GAAG,EAAE,CAAC;QAClC,IAAI,aAAa,GAAG,CAAC,CAAC;QACtB,cAAc,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,KAAK,EAAE,EAAE;YACvC,MAAM,IAAI,GAAI,KAA4B,CAAC,QAAQ,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,GAAG,KAAK,QAAQ,CAAC,CAAC;YACvG,MAAM,SAAS,GAAG,YAAY,CAAC,GAAG,EAAE,IAAI,EAAE,IAAc,EAAE,SAAS,CAAC,CAAC;YACrE,UAAU,IAAI,SAAS,GAAG,CAAC,GAAG,qBAAqB,CAAC;YACpD,IAAI,KAAK,GAAG,cAAc,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACpC,UAAU,IAAI,gCAAgC,CAAC;YACnD,CAAC;YACD,IAAI,YAAY,EAAE,CAAC;gBACf,UAAU,IAAI,8BAA8B,GAAG,CAAC,GAAG,gCAAgC,CAAC;YACxF,CAAC;YACD,IAAI,UAAU,GAAG,iBAAiB,IAAI,UAAU,KAAK,iBAAiB,EAAE,CAAC;gBACrE,aAAa,GAAG,KAAK,CAAC;YAC1B,CAAC;YACD,eAAe,CAAC,GAAG,CAAC,QAAQ,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC,CAAC;QAC3E,CAAC,CAAC,CAAC;QAEH,MAAM,SAAS,GAAG,uBAAuB,GAAG,qBAAqB,GAAG,CAAC,CAAC;QACtE,MAAM,QAAQ,GAAG,YAAY,CAAC,CAAC,CAAC,SAAS,GAAG,8BAA8B,GAAG,CAAC,GAAG,gCAAgC,CAAC,CAAC,CAAC,SAAS,CAAC;QAE9H,IAAI,cAAc,CAAC,aAAa,GAAG,CAAC,CAAC,EAAE,CAAC;YACpC,MAAM,EAAE,MAAM,EAAE,aAAa,EAAE,GAAG,eAAe,CAAC,GAAG,CAAC,cAAc,CAAC,aAAa,CAAC,CAAC,CAAC;YACrF,MAAM,aAAa,GAAG,iBAAiB,GAAG,aAAa,GAAG,QAAQ,CAAC;YACnE,aAAa,GAAG,aAAa,CAAC,CAAC,CAAC,aAAa,GAAG,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC;YAClE,6BAA6B;YAC7B,MAAM,MAAM,GAAG,cAAc,CAAC,MAAM,GAAG,CAAC,aAAa,GAAG,CAAC,CAAC,CAAC;YAE3D,IAAI,MAAM,GAAG,CAAC,EAAE,CAAC;gBACb,eAAe;gBACf,MAAM,WAAW,GAAG,YAAY,CAAC,GAAG,EAAE,WAAW,EAAE,SAAS,CAAC,GAAG,CAAC,GAAG,qBAAqB,CAAC;gBAC1F,MAAM,GAAG,GAAG,iBAAiB,GAAG,gCAAgC,GAAG,WAAW,CAAC;gBAC/E,gCAAgC;gBAChC,MAAM,kBAAkB,GAAG,aAAa,GAAG,GAAG,CAAC;gBAC/C,IAAI,kBAAkB,EAAE,CAAC;oBACrB,MAAM,UAAU,GAAG,aAAa,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,eAAe,CAAC,GAAG,CAAC,cAAc,CAAC,aAAa,GAAG,CAAC,CAAC,CAAC,CAAC;oBACpG,aAAa,GAAG,GAAG,GAAG,UAAU,GAAG,QAAQ,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,aAAa,GAAG,CAAC,CAAC;gBACpF,CAAC;qBAAM,CAAC;oBACJ,oBAAoB;oBACpB,aAAa,GAAG,GAAG,GAAG,aAAa,GAAG,QAAQ,CAAC,CAAC,CAAC,aAAa,GAAG,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC;gBACvF,CAAC;YACL,CAAC;QACL,CAAC;QAED,MAAM,UAAU,GAAG,IAAI,cAAc,CAAC,MAAM,GAAG,CAAC,aAAa,GAAG,CAAC,CAAC,EAAE,CAAC;QACrE,MAAM,WAAW,GACb,cAAc,CAAC,MAAM,GAAG,CAAC,aAAa,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,GAAG,EAAE,UAAU,EAAE,SAAS,CAAC,GAAG,CAAC,GAAG,qBAAqB,CAAC,CAAC,CAAC,CAAC,CAAC;QAC/H,OAAO;QACP,IAAI,WAAW,GAAG,iBAAiB,GAAG,WAAW,GAAG,CAAC,WAAW,GAAG,CAAC,CAAC,CAAC,CAAC,gCAAgC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAE7G,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,cAAc,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE,CAAC;YACzD,MAAM,QAAQ,GAAG,cAAc,CAAC,KAAK,CAAC,CAAC;YACvC,MAAM,QAAQ,GAAG;gBACb,CAAC,EAAE,QAAQ;gBACX,CAAC,EAAE,CAAC,GAAG,CAAC,yBAAyB,GAAG,2BAA2B,CAAC,GAAG,CAAC;gBACpE,MAAM,EAAE,2BAA2B;gBACnC,MAAM,EAAE,qBAAqB;gBAC7B,IAAI,EAAE,MAAM,CAAC,OAAO;gBACpB,KAAK,EAAE,CAAC;aACX,CAAC;YAEF,MAAM,UAAU,GAAG,CAAC,WAAqC,EAAE,KAAa,EAAE,EAAE;gBACxE,MAAM,SAAS,GAAG,YAAY;oBAC1B,CAAC,CAAC,8BAA8B,GAAG,CAAC,GAAG,gCAAgC,GAAG,qBAAqB,GAAG,CAAC;oBACnG,CAAC,CAAC,qBAAqB,GAAG,CAAC,CAAC;gBAChC,IAAI,WAAW,GAAG,QAAQ,EAAE,CAAC;oBACzB,OAAO;gBACX,CAAC;gBACD,MAAM,EAAE,SAAS,EAAE,IAAI,EAAE,GAAG,eAAe,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;gBAC1D,MAAM,aAAa,GAAG,SAAS,GAAG,SAAS,CAAC;gBAC5C,IAAI,KAAK,KAAK,cAAc,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBACtC,WAAW,IAAI,gCAAgC,CAAC;gBACpD,CAAC;gBACD,MAAM,OAAO,GAAG,WAAW,GAAG,aAAa,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,WAAW,CAAC;gBAC1E,QAAQ,CAAC,KAAK,GAAG,OAAO,CAAC;gBACzB,IAAI,YAAY,EAAE,CAAC;oBACf,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;oBACpB,IAAI,KAAK,KAAK,MAAM,EAAE,CAAC;wBACnB,IAAI,CAAC,IAAI,CAAC;4BACN,CAAC,EAAE,QAAQ,CAAC,CAAC,GAAG,qBAAqB;4BACrC,CAAC,EAAE,CAAC,GAAG,CAAC,yBAAyB,GAAG,8BAA8B,GAAG,CAAC,CAAC,GAAG,CAAC;4BAC3E,KAAK,EAAE,8BAA8B,GAAG,CAAC;4BACzC,MAAM,EAAE,8BAA8B,GAAG,CAAC;4BAC1C,MAAM,EAAE,qBAAqB;4BAC7B,IAAI,EAAE,IAAI,EAAE,QAAQ,IAAI,IAAI,EAAE,KAAK,IAAI,MAAM,CAAC,OAAO;yBACxD,CAAC,CAAC;oBACP,CAAC;yBAAM,IAAI,KAAK,KAAK,KAAK,EAAE,CAAC;wBACzB,IAAI,CAAC,GAAG,CAAC;4BACL,CAAC,EAAE,QAAQ,CAAC,CAAC,GAAG,qBAAqB;4BACrC,CAAC,EAAE,CAAC,GAAG,CAAC,yBAAyB,GAAG,8BAA8B,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,8BAA8B;4BAC5G,MAAM,EAAE,8BAA8B;4BACtC,IAAI,EAAE,IAAI,EAAE,QAAQ,IAAI,IAAI,EAAE,KAAK,IAAI,MAAM,CAAC,OAAO;yBACxD,CAAC,CAAC;oBACP,CAAC;oBAED,IAAI,CAAC,IAAI,CAAC;wBACN,CAAC,EAAE,QAAQ,CAAC,CAAC,GAAG,qBAAqB,GAAG,8BAA8B,GAAG,CAAC,GAAG,gCAAgC;wBAC7G,CAAC,EAAE,CAAC,GAAG,CAAC,yBAAyB,GAAG,8BAA8B,CAAC,GAAG,CAAC;wBACvE,IAAI,EAAE,IAAI,CAAC,YAAY,CAAC;4BACpB,IAAI,EAAE,IAAI,CAAC,IAAI;4BACf,QAAQ,EAAE,OAAO,GAAG,SAAS;4BAC7B,QAAQ,EAAE,8BAA8B;yBAC3C,CAAC,CAAC,IAAI;wBACP,SAAS,EAAE,MAAM,CAAC,OAAO;wBACzB,QAAQ,EAAE,8BAA8B;qBAC3C,CAAC,CAAC;gBACP,CAAC;qBAAM,IAAI,WAAW,KAAK,wBAAwB,CAAC,GAAG,EAAE,CAAC;oBACtD,IAAI,CAAC,GAAG,CAAC;wBACL,CAAC,EAAE,QAAQ,CAAC,CAAC;wBACb,CAAC,EAAE,QAAQ,CAAC,CAAC;wBACb,KAAK,EAAE,QAAQ,CAAC,KAAK;wBACrB,IAAI,EAAE,IAAI,CAAC,YAAY,CAAC;4BACpB,IAAI,EAAE,IAAI,CAAC,IAAI;4BACf,QAAQ,EAAE,OAAO,GAAG,SAAS;4BAC7B,QAAQ,EAAE,sBAAsB;yBACnC,CAAC,CAAC,IAAI;wBACP,MAAM,EAAE,2BAA2B;wBACnC,QAAQ,EAAE,sBAAsB;wBAChC,MAAM,EAAE,QAAQ,CAAC,MAAM;wBACvB,KAAK,EAAE,MAAM,CAAC,KAAK;wBACnB,OAAO,EAAE,qBAAqB;wBAC9B,UAAU,EAAE,IAAI,EAAE,QAAQ,IAAI,IAAI,EAAE,KAAK,IAAI,MAAM,CAAC,OAAO;qBAC9D,CAAC,CAAC;gBACP,CAAC;qBAAM,CAAC;oBACJ,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;oBACpB,IAAI,CAAC,IAAI,CAAC;wBACN,CAAC,EAAE,QAAQ,CAAC,CAAC,GAAG,qBAAqB;wBACrC,CAAC,EAAE,CAAC,GAAG,CAAC,yBAAyB,GAAG,sBAAsB,CAAC,GAAG,CAAC;wBAC/D,IAAI,EAAE,IAAI,CAAC,YAAY,CAAC;4BACpB,IAAI,EAAE,IAAI,CAAC,IAAI;4BACf,QAAQ,EAAE,OAAO,GAAG,SAAS;4BAC7B,QAAQ,EAAE,sBAAsB;yBACnC,CAAC,CAAC,IAAI;wBACP,SAAS,EAAE,MAAM,CAAC,OAAO;wBACzB,QAAQ,EAAE,sBAAsB;qBACnC,CAAC,CAAC;gBACP,CAAC;gBACD,MAAM,YAAY,GAAG,QAAQ,CAAC,KAAK,CAAC;gBACpC,WAAW,IAAI,YAAY,CAAC;gBAC5B,QAAQ,IAAI,YAAY,GAAG,gCAAgC,CAAC;YAChE,CAAC,CAAC;YAEF,QAAQ,WAAW,EAAE,CAAC;gBAClB,KAAK,wBAAwB,CAAC,GAAG;oBAC7B,UAAU,CAAC,wBAAwB,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;oBAChD,MAAM;gBACV,KAAK,wBAAwB,CAAC,KAAK;oBAC/B,UAAU,CAAC,wBAAwB,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;oBACnD,MAAM;gBACV,KAAK,wBAAwB,CAAC,GAAG;oBAC7B,UAAU,CAAC,wBAAwB,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;oBAC7C,MAAM;gBACV;oBACI,UAAU,CAAC,wBAAwB,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;oBAC9C,MAAM;YACd,CAAC;QACL,CAAC;QAED,IAAI,WAAW,GAAG,CAAC,EAAE,CAAC;YAClB,IAAI,WAAW,KAAK,wBAAwB,CAAC,GAAG,EAAE,CAAC;gBAC/C,IAAI,CAAC,GAAG,CAAC;oBACL,CAAC,EAAE,QAAQ;oBACX,CAAC,EAAE,CAAC,GAAG,CAAC,yBAAyB,GAAG,2BAA2B,CAAC,GAAG,CAAC;oBACpE,KAAK,EAAE,WAAW;oBAClB,MAAM,EAAE,2BAA2B;oBACnC,IAAI,EAAE,UAAU;oBAChB,UAAU,EAAE,MAAM,CAAC,OAAO;oBAC1B,KAAK,EAAE,MAAM,CAAC,OAAO;oBACrB,MAAM,EAAE,2BAA2B;oBACnC,OAAO,EAAE,qBAAqB;oBAC9B,QAAQ,EAAE,sBAAsB;iBACnC,CAAC,CAAC;YACP,CAAC;iBAAM,CAAC;gBACJ,IAAI,CAAC,IAAI,CAAC;oBACN,CAAC,EAAE,QAAQ;oBACX,CAAC,EAAE,CAAC,GAAG,CAAC,yBAAyB,GAAG,2BAA2B,CAAC,GAAG,CAAC;oBACpE,KAAK,EAAE,WAAW;oBAClB,MAAM,EAAE,2BAA2B;oBACnC,IAAI,EAAE,MAAM,CAAC,OAAO;oBACpB,MAAM,EAAE,qBAAqB;iBAChC,CAAC,CAAC;gBACH,IAAI,CAAC,IAAI,CAAC;oBACN,CAAC,EAAE,QAAQ,GAAG,qBAAqB;oBACnC,CAAC,EAAE,CAAC,GAAG,CAAC,yBAAyB,GAAG,sBAAsB,CAAC,GAAG,CAAC;oBAC/D,IAAI,EAAE,UAAU;oBAChB,SAAS,EAAE,MAAM,CAAC,OAAO;oBACzB,QAAQ,EAAE,sBAAsB;iBACnC,CAAC,CAAC;YACP,CAAC;QACL,CAAC;IACL,CAAC;IAEO,sBAAsB,CAAC,MAAqB,EAAE,GAAS;QAC3D,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,cAAc,EAAE,KAAK,EAAE,WAAW,EAAE,QAAQ,EAAE,GAAG,MAAM,CAAC;QACtE,IAAI,cAAc,IAAI,IAAI,IAAI,cAAc,KAAK,EAAE,EAAE,CAAC;YAClD,OAAO;QACX,CAAC;QACD,MAAM,WAAW,GAAG,QAAQ,CAAC;QAC7B,MAAM,IAAI,GAAI,KAA4B,CAAC,QAAQ,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,GAAG,KAAK,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC;QAChH,MAAM,QAAQ,GAAG,IAAI,EAAE,IAAI,IAAI,EAAE,CAAC;QAClC,MAAM,eAAe,GAAG,CAAC,YAAoB,EAAE,WAAmB,yBAAyB,EAAE,EAAE;YAC3F,YAAY,IAAI,WAAW,CAAC,CAAC,CAAC,qCAAqC,GAAG,4CAA4C,CAAC,CAAC,CAAC,CAAC,CAAC;YACvH,OAAO,IAAI,CAAC,YAAY,CAAC;gBACrB,IAAI,EAAE,QAAQ;gBACd,QAAQ,EAAE,WAAW,IAAI,YAAY;gBACrC,QAAQ,EAAE,QAAQ;aACrB,CAAC,CAAC;QACP,CAAC,CAAC;QACF,IAAI,GAAG,EAAE,CAAC;YACN,GAAG,CAAC,IAAI,EAAE,CAAC;YACX,GAAG,CAAC,WAAW,GAAG,CAAC,CAAC;YACpB,MAAM,MAAM,GAAG,OAAO,CAAC,SAAS,EAAE,CAAC;YACnC,MAAM,WAAW,GAAI,KAA4B,CAAC,QAAQ,CAAC,YAAY,CAAC;YACxE,IAAI,UAAU,GAAG,IAAI,EAAE,QAAQ,IAAI,IAAI,EAAE,KAAK,IAAI,MAAM,CAAC,OAAO,CAAC;YACjE,MAAM,eAAe,GAAG,WAAW,GAAG,CAAC,GAAG,qBAAqB,GAAG,oBAAoB,GAAG,iBAAiB,CAAC;YAC3G,MAAM,WAAW,GAAG,CAAC,CAAC;YACtB,QAAQ,WAAW,EAAE,CAAC;gBAClB,KAAK,wBAAwB,CAAC,GAAG;oBAC7B,2DAA2D;oBAC3D,IAAI,CAAC,GAAG,CAAC;wBACL,CAAC,EAAE,CAAC,GAAG,qBAAqB,GAAG,mBAAmB;wBAClD,CAAC,EAAE,CAAC,GAAG,CAAC,yBAAyB,GAAG,oBAAoB,CAAC,GAAG,CAAC,GAAG,mBAAmB,GAAG,eAAe;wBACrG,MAAM,EAAE,mBAAmB;wBAC3B,IAAI,EAAE,UAAU;qBACnB,CAAC,CAAC;oBACH,IAAI,CAAC,IAAI,CAAC;wBACN,CAAC,EAAE,CAAC,GAAG,oBAAoB,GAAG,iBAAiB,GAAG,qBAAqB;wBACvE,CAAC,EAAE,CAAC,GAAG,CAAC,yBAAyB,GAAG,8BAA8B,CAAC,GAAG,CAAC;wBACvE,IAAI,EAAE,eAAe,CAAC,eAAe,CAAC,CAAC,IAAI;wBAC3C,SAAS,EAAE,MAAM,CAAC,OAAO;qBAC5B,CAAC,CAAC;oBACH,MAAM;gBACV,KAAK,wBAAwB,CAAC,KAAK;oBAC/B,IAAI,CAAC,IAAI,CAAC;wBACN,CAAC,EAAE,CAAC,GAAG,qBAAqB;wBAC5B,CAAC,EAAE,CAAC,GAAG,CAAC,yBAAyB,GAAG,oBAAoB,CAAC,GAAG,CAAC,GAAG,eAAe;wBAC/E,KAAK,EAAE,oBAAoB;wBAC3B,MAAM,EAAE,oBAAoB;wBAC5B,MAAM,EAAE,qBAAqB;wBAC7B,IAAI,EAAE,UAAU;qBACnB,CAAC,CAAC;oBACH,IAAI,CAAC,IAAI,CAAC;wBACN,CAAC,EAAE,CAAC,GAAG,oBAAoB,GAAG,iBAAiB,GAAG,qBAAqB;wBACvE,CAAC,EAAE,CAAC,GAAG,CAAC,yBAAyB,GAAG,8BAA8B,CAAC,GAAG,CAAC;wBACvE,IAAI,EAAE,eAAe,CAAC,eAAe,CAAC,CAAC,IAAI;wBAC3C,SAAS,EAAE,MAAM,CAAC,OAAO;qBAC5B,CAAC,CAAC;oBACH,MAAM;gBAEV,KAAK,wBAAwB,CAAC,GAAG;oBAC7B,MAAM,YAAY,GAAG,WAAW,GAAG,CAAC,GAAG,CAAC,qBAAqB,GAAG,oBAAoB,CAAC,CAAC;oBACtF,MAAM,EAAE,SAAS,EAAE,IAAI,EAAE,GAAG,eAAe,CAAC,YAAY,EAAE,sBAAsB,CAAC,CAAC;oBAClF,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,SAAS,GAAG,CAAC,GAAG,oBAAoB,EAAE,kCAAkC,CAAC,CAAC;oBACjG,IAAI,CAAC,GAAG,CAAC;wBACL,CAAC,EAAE,CAAC,GAAG,qBAAqB;wBAC5B,CAAC,EAAE,CAAC,GAAG,CAAC,yBAAyB,GAAG,2BAA2B,CAAC,GAAG,CAAC;wBACpE,KAAK;wBACL,MAAM,EAAE,2BAA2B;wBACnC,IAAI;wBACJ,UAAU;wBACV,KAAK,EAAE,MAAM,CAAC,KAAK;wBACnB,MAAM,EAAE,2BAA2B;wBACnC,OAAO,EAAE,4BAA4B;wBACrC,QAAQ,EAAE,sBAAsB;wBAChC,MAAM,EAAE,UAAU;qBACrB,CAAC,CAAC;oBACH,MAAM;gBACV;oBACI,MAAM,gBAAgB,GAAG,WAAW,GAAG,CAAC,GAAG,qBAAqB,CAAC;oBACjE,IAAI,CAAC,IAAI,CAAC;wBACN,CAAC,EAAE,CAAC,GAAG,qBAAqB;wBAC5B,CAAC,EAAE,CAAC,GAAG,CAAC,yBAAyB,GAAG,8BAA8B,CAAC,GAAG,CAAC;wBACvE,IAAI,EAAE,eAAe,CAAC,gBAAgB,CAAC,CAAC,IAAI;wBAC5C,SAAS,EAAE,MAAM,CAAC,OAAO;qBAC5B,CAAC,CAAC;oBACH,MAAM;YACd,CAAC;YAED,GAAG,CAAC,OAAO,EAAE,CAAC;QAClB,CAAC;IACL,CAAC;IAEO,cAAc,CAAC,MAAqB,EAAE,GAAS;QACnD,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,cAAc,EAAE,WAAW,EAAE,KAAK,EAAE,GAAG,MAAM,CAAC;QAC5D,MAAM,MAAM,GAAG,OAAO,CAAC,SAAS,EAAE,CAAC;QACnC,IAAI,QAAQ,GAAG,cAAc,CAAC;QAE9B,IAAI,QAAQ,IAAI,IAAI,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC;YAC5C,OAAO;QACX,CAAC;QAED,MAAM,YAAY,GAAG,WAAW,GAAG,CAAC,GAAG,qBAAqB,CAAC;QAC7D,MAAM,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,YAAY,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,QAAQ,EAAE,WAAW,IAAI,YAAY,EAAE,CAAC,CAAC;QAC9F,IAAI,GAAG,EAAE,CAAC;YACN,MAAM,KAAK,GAAG,KAAK,EAAE,KAAK,IAAI,MAAM,CAAC,OAAO,CAAC;YAC7C,IAAI,CAAC,IAAI,CAAC;gBACN,CAAC,EAAE,CAAC,GAAG,qBAAqB;gBAC5B,CAAC,EAAE,CAAC,GAAG,yBAAyB,GAAG,CAAC;gBACpC,IAAI;gBACJ,SAAS,EAAE,KAAK;gBAChB,UAAU,EAAE,KAAK,EAAE,UAAU;gBAC7B,aAAa,EAAE,kCAAkC;aACpD,CAAC,CAAC;QACP,CAAC;IACL,CAAC;IAEO,cAAc,CAAC,MAAqB,EAAE,GAA0C;QACpF,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,cAAc,EAAE,UAAU,EAAE,GAAG,MAAM,CAAC;QACpD,MAAM,GAAG,GAAG,CAAC,CAAC;QACd,MAAM,SAAS,GAAI,UAA6B,IAAI,CAAC,CAAC;QACtD,MAAM,IAAI,GAAG,wBAAwB,CAAC;QAEtC,OAAO,CAAC,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;YAC9C,MAAM,KAAK,GAAG,KAAK,GAAG,CAAC,CAAC;YACxB,MAAM,OAAO,GAAG,KAAK,IAAI,SAAS,CAAC;YACnC,MAAM,KAAK,GAAG,KAAK,GAAG,IAAI,GAAG,qBAAqB,GAAG,KAAK,GAAG,2BAA2B,CAAC;YACzF,MAAM,KAAK,GAAG,CAAC,yBAAyB,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC;YAErD,IAAI,GAAG,IAAI,OAAO,EAAE,CAAC;gBACjB,IAAI,CAAC,IAAI,CAAC;oBACN,CAAC,EAAE,CAAC,GAAG,KAAK;oBACZ,CAAC,EAAE,CAAC,GAAG,KAAK;oBACZ,IAAI,EAAE,EAAE;oBACR,IAAI,EAAE,QAAQ;oBACd,IAAI,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM;oBACxB,MAAM,EAAE,IAAI;oBACZ,MAAM,EAAE,IAAI;iBACf,CAAC,CAAC;YACP,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,kBAAkB,CAAC,MAAqB,EAAE,GAAS;QACvD,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,cAAc,EAAE,WAAW,EAAE,KAAK,EAAE,GAAG,MAAM,CAAC;QAC5D,MAAM,MAAM,GAAG,OAAO,CAAC,SAAS,EAAE,CAAC;QACnC,MAAM,QAAQ,GAAG,cAAc,CAAC;QAEhC,IAAI,QAAQ,IAAI,IAAI,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,CAAC;YAC5C,OAAO;QACX,CAAC;QAED,MAAM,KAAK,GAAG,WAAW,GAAG,CAAC,GAAG,qBAAqB,GAAG,4BAA4B,CAAC;QACrF,MAAM,MAAM,GAAG,4BAA4B,CAAC;QAC5C,MAAM,UAAU,GAAG,yBAAyB,CAAC;QAC7C,MAAM,OAAO,GAAG,qBAAqB,CAAC;QACtC,MAAM,OAAO,GAAG,CAAC,yBAAyB,GAAG,4BAA4B,CAAC,GAAG,CAAC,CAAC;QAC/E,MAAM,WAAW,GAAG,CAAC,yBAAyB,GAAG,UAAU,CAAC,GAAG,CAAC,CAAC;QAEjE,OAAO;QACP,IAAI,CAAC,IAAI,CAAC;YACN,CAAC,EAAE,CAAC,GAAG,OAAO;YACd,CAAC,EAAE,CAAC,GAAG,OAAO;YACd,KAAK;YACL,MAAM;YACN,MAAM,EAAE,4BAA4B;YACpC,IAAI,EAAE,MAAM,CAAC,OAAO;SACvB,CAAC,CAAC;QAEH,UAAU;QACV,MAAM,aAAa,GAAG,CAAC,cAAc,GAAG,GAAG,CAAC,GAAG,KAAK,CAAC;QACrD,IAAI,CAAC,IAAI,CAAC;YACN,CAAC,EAAE,CAAC,GAAG,OAAO;YACd,CAAC,EAAE,CAAC,GAAG,OAAO;YACd,KAAK,EAAE,aAAa;YACpB,MAAM;YACN,MAAM,EAAE,4BAA4B;YACpC,IAAI,EAAE,MAAM,CAAC,OAAO;SACvB,CAAC,CAAC;QAEH,IAAI,CAAC,IAAI,CAAC;YACN,CAAC,EAAE,CAAC,GAAG,OAAO,GAAG,KAAK,GAAG,iBAAiB;YAC1C,CAAC,EAAE,CAAC,GAAG,WAAW;YAClB,IAAI,EAAE,GAAG,cAAc,GAAG;YAC1B,SAAS,EAAE,MAAM,CAAC,OAAO;SAC5B,CAAC,CAAC;IACP,CAAC;IAEO,gBAAgB,CAAC,MAAqB,EAAE,GAA0C;QACtF,MAAM,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,cAAc,EAAE,UAAU,EAAE,SAAS,EAAE,WAAW,EAAE,QAAQ,EAAE,GAAG,MAAM,CAAC;QACzG,MAAM,SAAS,GAAG,UAAU,CAAC;QAE7B,IAAI,CAAC,SAAS,EAAE,MAAM,IAAI,CAAC,UAAU,EAAE,CAAC;YACpC,OAAO;QACX,CAAC;QACD,MAAM,QAAQ,GAAG,KAAK,CAAC,QAA0B,CAAC;QAClD,MAAM,UAAU,GAAG,2BAA2B,CAAC;QAC/C,MAAM,UAAU,GAAG,gCAAgC,CAAC;QACpD,MAAM,WAAW,GAAG,QAAQ,CAAC;QAC7B,MAAM,OAAO,GAAG,QAAQ,EAAE,WAAW,CAAC;QAEtC,IAAI,QAAQ,GAAG,qBAAqB,CAAC;QACrC,IAAI,QAAQ,GAAG,CAAC,yBAAyB,GAAG,UAAU,CAAC,GAAG,CAAC,CAAC;QAC5D,MAAM,cAAc,GAAG,UAAU,GAAG,kCAAkC,GAAG,wCAAwC,CAAC;QAClH,MAAM,SAAS,GAAG,QAAQ,CAAC,CAAC,CAAC,GAAG,GAAG,+BAA+B,CAAC,CAAC,CAAC,SAAS,GAAG,+BAA+B,CAAC;QACjH,MAAM,YAAY,GAAG,WAAW;YAC5B,CAAC,CAAC,WAAW,GAAG,CAAC,GAAG,qBAAqB,GAAG,cAAc,GAAG,qCAAqC,GAAG,EAAE;YACvG,CAAC,CAAC,WAAW,GAAG,CAAC,GAAG,qBAAqB,GAAG,cAAc,CAAC;QAE/D,MAAM,SAAS,GAAG,SAAS,CAAC,MAAM,CAAC;QACnC,IAAI,UAAU,GAAG,KAAK,CAAC;QAEvB,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,SAAS,EAAE,KAAK,EAAE,EAAE,CAAC;YAC7C,MAAM,QAAQ,GAAG,UAAU,EAAE,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC;YACvD,IAAI,CAAC,QAAQ;gBAAE,SAAS;YAExB,MAAM,EAAE,GAAG,EAAE,YAAY,EAAE,MAAM,EAAE,GAAG,QAAQ,CAAC;YAC/C,MAAM,IAAI,GAAG,iBAAiB,CAAC,MAAM,CAAC;YACtC,MAAM,SAAS,GAAG,iBAAiB,CAAC,MAAM,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,iCAAiC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAE/F,QAAQ,GAAG,qBAAqB,GAAG,KAAK,GAAG,SAAS,CAAC;YAErD,IAAI,gBAAgB,GAAG,YAAY,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC;YAC3D,IAAI,KAAK,KAAK,CAAC,IAAI,WAAW,EAAE,CAAC;gBAC7B,MAAM,iBAAiB,GAAG,YAAY,GAAG,CAAC,kCAAkC,GAAG,CAAC,CAAC,CAAC;gBAClF,qDAAqD;gBACrD,IAAI,iBAAiB,IAAI,EAAE,EAAE,CAAC;oBAC1B,QAAQ,GAAG,qBAAqB,CAAC;oBACjC,QAAQ,IAAI,2BAA2B,GAAG,mCAAmC,CAAC;gBAClF,CAAC;qBAAM,CAAC;oBACJ,gBAAgB,GAAG,iBAAiB,CAAC;gBACzC,CAAC;YACL,CAAC;YAED,IAAI,MAAM,GAAG,QAAQ,GAAG,SAAS,GAAG,WAAW,GAAG,CAAC,GAAG,qBAAqB,CAAC;YAC5E,IAAI,WAAW,IAAI,IAAI,EAAE,CAAC;gBACtB,0BAA0B;gBAC1B,IAAI,CAAC,QAAQ,IAAI,QAAQ,IAAI,WAAW,GAAG,CAAC,GAAG,qBAAqB,EAAE,CAAC;oBACnE,MAAM;gBACV,CAAC;gBACD,2BAA2B;gBAC3B,IAAI,CAAC,QAAQ,IAAI,QAAQ,GAAG,WAAW,GAAG,CAAC,GAAG,qBAAqB,EAAE,CAAC;oBAClE,QAAQ,GAAG,qBAAqB,CAAC;gBACrC,CAAC;gBACD,IAAI,QAAQ,IAAI,QAAQ,GAAG,SAAS,GAAG,WAAW,GAAG,qBAAqB,EAAE,CAAC;oBACzE,QAAQ,GAAG,qBAAqB,CAAC;oBACjC,QAAQ,IAAI,UAAU,CAAC;gBAC3B,CAAC;gBACD,IAAI,QAAQ,IAAI,QAAQ,IAAI,SAAS,EAAE,CAAC;oBACpC,UAAU,GAAG,IAAI,CAAC;gBACtB,CAAC;YACL,CAAC;YAED,IAAI,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC;gBACnB,IAAI,CAAC,MAAM,CAAC;oBACR,CAAC,EAAE,CAAC,GAAG,QAAQ;oBACf,CAAC,EAAE,CAAC,GAAG,QAAQ;oBACf,GAAG,EAAE,MAAO;oBACZ,EAAE,EAAE,GAAI;oBACR,KAAK,EAAE,kBAAkB,CAAC,YAAY,CAAC;oBACvC,OAAO,EAAE,gBAAgB,CAAC,YAAa,CAAC;oBACxC,IAAI,EAAE,iBAAiB,CAAC,MAAM;oBAC9B,IAAI,EAAE,iBAAiB,CAAC,MAAM;iBACjC,CAAC,CAAC;gBAEH,IAAI,MAAM,EAAE,CAAC;oBACT,GAAG,CAAC,IAAI,EAAE,CAAC;oBACX,GAAG,CAAC,WAAW,GAAG,GAAG,CAAC;oBACtB,IAAI,CAAC,IAAI,CAAC;wBACN,CAAC,EAAE,CAAC,GAAG,QAAQ;wBACf,CAAC,EAAE,CAAC,GAAG,QAAQ;wBACf,KAAK,EAAE,iBAAiB,CAAC,MAAM;wBAC/B,MAAM,EAAE,iBAAiB,CAAC,MAAM;wBAChC,MAAM,EAAE,EAAE;wBACV,IAAI,EAAE,IAAI,CAAC,MAAM,CAAC,KAAK;qBAC1B,CAAC,CAAC;oBACH,GAAG,CAAC,OAAO,EAAE,CAAC;oBACd,IAAI,CAAC,IAAI,CAAC;wBACN,CAAC,EAAE,CAAC,GAAG,QAAQ,GAAG,YAAY,GAAG,CAAC;wBAClC,CAAC,EAAE,CAAC,GAAG,yBAAyB,GAAG,CAAC;wBACpC,SAAS,EAAE,IAAI,CAAC,MAAM,CAAC,KAAK;wBAC5B,QAAQ,EAAE,YAAY;wBACtB,IAAI,EAAE,IAAI,SAAS,GAAG,KAAK,GAAG,CAAC,EAAE;wBACjC,aAAa,EAAE,kCAAkC;qBACpD,CAAC,CAAC;gBACP,CAAC;YACL,CAAC;QACL,CAAC;IACL,CAAC;CACJ;AAED,MAAM,CAAC,MAAM,UAAU,GAAG,IAAI,UAAU,EAAE,CAAC","sourcesContent":["import _ from 'lodash';\nimport {\n    AI_TABLE_CELL_ADD_ITEM_BUTTON_SIZE,\n    AI_TABLE_CELL_DELETE_ITEM_BUTTON_SIZE,\n    AI_TABLE_CELL_DELETE_ITEM_BUTTON_SIZE_OFFSET,\n    AI_TABLE_CELL_EMOJI_PADDING,\n    AI_TABLE_CELL_EMOJI_SIZE,\n    AI_TABLE_CELL_MAX_ROW_COUNT,\n    AI_TABLE_CELL_MEMBER_ITEM_HEIGHT,\n    AI_TABLE_CELL_MEMBER_ITEM_PADDING,\n    AI_TABLE_CELL_MULTI_DOT_RADIUS,\n    AI_TABLE_CELL_MULTI_ITEM_MARGIN_TOP,\n    AI_TABLE_CELL_MULTI_ITEM_MIN_WIDTH,\n    AI_TABLE_CELL_MULTI_PADDING_LEFT,\n    AI_TABLE_CELL_MULTI_PADDING_TOP,\n    AI_TABLE_CELL_PADDING,\n    AI_TABLE_COMMON_FONT_SIZE,\n    AI_TABLE_DOT_RADIUS,\n    AI_TABLE_MEMBER_AVATAR_SIZE,\n    AI_TABLE_MEMBER_ITEM_AVATAR_MARGIN_RIGHT,\n    AI_TABLE_MEMBER_ITEM_PADDING_RIGHT,\n    AI_TABLE_MIN_TEXT_WIDTH,\n    AI_TABLE_OFFSET,\n    AI_TABLE_OPTION_ITEM_FONT_SIZE,\n    AI_TABLE_OPTION_ITEM_HEIGHT,\n    AI_TABLE_OPTION_ITEM_PADDING,\n    AI_TABLE_OPTION_ITEM_RADIUS,\n    AI_TABLE_PIECE_RADIUS,\n    AI_TABLE_PIECE_WIDTH,\n    AI_TABLE_PROGRESS_BAR_HEIGHT,\n    AI_TABLE_PROGRESS_BAR_RADIUS,\n    AI_TABLE_PROGRESS_TEXT_Width,\n    AI_TABLE_ROW_BLANK_HEIGHT,\n    AI_TABLE_TAG_FONT_SIZE,\n    AI_TABLE_TAG_PADDING,\n    AI_TABLE_TEXT_GAP,\n    Colors,\n    DEFAULT_FONT_FAMILY,\n    DEFAULT_FONT_SIZE,\n    DEFAULT_FONT_WEIGHT,\n    DEFAULT_TEXT_ALIGN_LEFT,\n    DEFAULT_TEXT_ALIGN_RIGHT,\n    DEFAULT_TEXT_DECORATION,\n    DEFAULT_TEXT_LINE_HEIGHT,\n    DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE,\n    FONT_SIZE_SM,\n    StarFill\n} from '../../constants';\nimport { AITable, AITableField, AITableFieldType, AITableSelectOptionStyle, MemberSettings, RateFieldValue } from '../../core';\nimport { AITableAvatarSize, AITableAvatarType, AITableMemberType, AITableRender, AITableSelectField } from '../../types';\nimport { getAvatarBgColor, getAvatarShortName, getTextWidth } from '../../utils';\nimport { Drawer } from './drawer';\n\n/**\n * 处理和渲染表格单元格的内容\n */\nexport class CellDrawer extends Drawer {\n    // 样式初始化\n    public initStyle(field: AITableField, styleProps: { fontWeight: any }): void | null {\n        const { type: fieldType } = field;\n        const { fontWeight = DEFAULT_FONT_WEIGHT } = styleProps;\n\n        switch (fieldType) {\n            case AITableFieldType.text:\n            case AITableFieldType.date:\n            case AITableFieldType.createdAt:\n            case AITableFieldType.updatedAt:\n            case AITableFieldType.rate:\n            case AITableFieldType.progress:\n            case AITableFieldType.member:\n            case AITableFieldType.createdBy:\n            case AITableFieldType.updatedBy:\n                return this.setStyle({ fontSize: DEFAULT_FONT_SIZE, fontWeight });\n            default:\n                return null;\n        }\n    }\n\n    // 单元格渲染\n    public renderCell(render: AITableRender, ctx?: CanvasRenderingContext2D | undefined) {\n        const { field } = render;\n        const fieldType = field.type;\n\n        switch (fieldType) {\n            case AITableFieldType.text:\n            case AITableFieldType.number:\n            case AITableFieldType.link:\n                return this.renderCellText(render, ctx);\n            case AITableFieldType.select:\n                return this.renderCellSelect(render, ctx);\n            case AITableFieldType.date:\n            case AITableFieldType.createdAt:\n            case AITableFieldType.updatedAt:\n                return this.renderCellDate(render, ctx);\n            case AITableFieldType.rate:\n                return this.renderCellRate(render, ctx);\n            case AITableFieldType.progress:\n                return this.renderCellProgress(render, ctx);\n            case AITableFieldType.member:\n            case AITableFieldType.createdBy:\n            case AITableFieldType.updatedBy:\n                return this.renderCellMember(render, ctx);\n            default:\n                return null;\n        }\n    }\n\n    private renderCellText(render: AITableRender, ctx?: any) {\n        const { x, y, transformValue, field, columnWidth, style } = render;\n        const fieldType = field.type;\n        let renderText: string | null = fieldType === AITableFieldType.link ? transformValue.text : transformValue;\n        if (renderText == null) {\n            return;\n        }\n        const isSingleLine = !columnWidth;\n        const isTextField = fieldType === AITableFieldType.text;\n        const isNumberField = fieldType === AITableFieldType.number;\n\n        if (isTextField && isSingleLine) {\n            renderText = renderText.replace(/\\r|\\n/g, ' ');\n        }\n\n        const color = style?.color || this.colors.gray800;\n        const textAlign = style?.textAlign || DEFAULT_TEXT_ALIGN_LEFT;\n        const fontWeight = style?.fontWeight;\n        const textMaxWidth = columnWidth - 2 * AI_TABLE_CELL_PADDING;\n        const renderX = textAlign === DEFAULT_TEXT_ALIGN_RIGHT ? x + columnWidth - AI_TABLE_CELL_PADDING : x + AI_TABLE_CELL_PADDING;\n        const renderY = y + AI_TABLE_ROW_BLANK_HEIGHT / 2;\n        const textDecoration = DEFAULT_TEXT_DECORATION;\n\n        if (isNumberField) {\n            renderText = String(renderText);\n            const { text } = this.textEllipsis({\n                text: renderText,\n                maxWidth: columnWidth && textMaxWidth,\n                fontWeight\n            });\n            if (ctx) {\n                let pureText = text;\n                this.text({\n                    x: renderX,\n                    y: renderY,\n                    text: pureText,\n                    textAlign,\n                    fillStyle: color,\n                    fontWeight,\n                    textDecoration,\n                    verticalAlign: DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE\n                });\n            }\n        } else {\n            this.wrapText({\n                x: renderX,\n                y: renderY,\n                text: renderText,\n                maxWidth: textMaxWidth,\n                maxRow: AI_TABLE_CELL_MAX_ROW_COUNT,\n                lineHeight: DEFAULT_TEXT_LINE_HEIGHT,\n                textAlign,\n                verticalAlign: DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE,\n                fillStyle: fieldType === AITableFieldType.link ? Colors.primary : color,\n                fontWeight,\n                textDecoration,\n                fieldType,\n                needDraw: true\n            });\n        }\n    }\n\n    private renderCellSelect(render: AITableRender, ctx?: any) {\n        const { field } = render;\n        if ((field as AITableSelectField).settings?.is_multiple) {\n            this.renderCellMultiSelect(render, ctx);\n        } else {\n            this.renderSingleSelectCell(render, ctx);\n        }\n    }\n\n    private renderCellMultiSelect(render: AITableRender, ctx?: any) {\n        const { x, y, field, transformValue, columnWidth } = render;\n        if (!transformValue?.length || !Array.isArray(transformValue)) return;\n        let currentX = x + AI_TABLE_CELL_PADDING;\n        const maxContainerWidth = columnWidth - 2 * AI_TABLE_CELL_PADDING;\n        const optionStyle = (field as AITableSelectField).settings.option_style;\n        const fontStyle = `${DEFAULT_FONT_WEIGHT} ${AI_TABLE_OPTION_ITEM_FONT_SIZE}px ${DEFAULT_FONT_FAMILY}`;\n        const isDotOrPiece = optionStyle === AITableSelectOptionStyle.dot || optionStyle === AITableSelectOptionStyle.piece;\n\n        let totalWidth = 0;\n        const cellItemInfoMap = new Map();\n        let drawableIndex = 0;\n        transformValue.forEach((optionId, index) => {\n            const item = (field as AITableSelectField).settings.options?.find((option) => option._id === optionId);\n            const textWidth = getTextWidth(ctx, item?.text as string, fontStyle);\n            totalWidth += textWidth + 2 * AI_TABLE_CELL_PADDING;\n            if (index < transformValue.length - 1) {\n                totalWidth += AI_TABLE_CELL_MULTI_PADDING_LEFT;\n            }\n            if (isDotOrPiece) {\n                totalWidth += AI_TABLE_CELL_MULTI_DOT_RADIUS * 2 + AI_TABLE_CELL_MULTI_PADDING_LEFT;\n            }\n            if (totalWidth < maxContainerWidth || totalWidth === maxContainerWidth) {\n                drawableIndex = index;\n            }\n            cellItemInfoMap.set(optionId, { textWidth, item, offset: totalWidth });\n        });\n\n        const baseWidth = AI_TABLE_MIN_TEXT_WIDTH + AI_TABLE_CELL_PADDING * 2;\n        const minWidth = isDotOrPiece ? baseWidth + AI_TABLE_CELL_MULTI_DOT_RADIUS * 2 + AI_TABLE_CELL_MULTI_PADDING_LEFT : baseWidth;\n\n        if (transformValue[drawableIndex + 1]) {\n            const { offset: currentOffset } = cellItemInfoMap.get(transformValue[drawableIndex]);\n            const canDrawerNext = maxContainerWidth - currentOffset > minWidth;\n            drawableIndex = canDrawerNext ? drawableIndex + 1 : drawableIndex;\n            // 上面过程是  没有 +数字  的情况下最大能放几个；\n            const number = transformValue.length - (drawableIndex + 1);\n\n            if (number > 0) {\n                // 说明有 +数字，重新计算\n                const circleWidth = getTextWidth(ctx, `+{number}`, fontStyle) + 2 * AI_TABLE_CELL_PADDING;\n                const max = maxContainerWidth - AI_TABLE_CELL_MULTI_PADDING_LEFT - circleWidth;\n                // 如果当前已经超出了，看是否能容下当前的，不能就减去  1；\n                const currentItemHasOver = currentOffset > max;\n                if (currentItemHasOver) {\n                    const lastOffset = drawableIndex === 0 ? 0 : cellItemInfoMap.get(transformValue[drawableIndex - 1]);\n                    drawableIndex = max - lastOffset > minWidth ? drawableIndex : drawableIndex - 1;\n                } else {\n                    // 还有剩余空间, 看是否能多渲染一个\n                    drawableIndex = max - currentOffset > minWidth ? drawableIndex + 1 : drawableIndex;\n                }\n            }\n        }\n\n        const circleText = `+${transformValue.length - (drawableIndex + 1)}`;\n        const circleWidth =\n            transformValue.length - (drawableIndex + 1) > 0 ? getTextWidth(ctx, circleText, fontStyle) + 2 * AI_TABLE_CELL_PADDING : 0;\n        // 剩余空间\n        let remainSpace = maxContainerWidth - circleWidth - (circleWidth > 0 ? AI_TABLE_CELL_MULTI_PADDING_LEFT : 0);\n\n        for (let index = 0; index < transformValue.length; index++) {\n            const optionId = transformValue[index];\n            const bgConfig = {\n                x: currentX,\n                y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_OPTION_ITEM_HEIGHT) / 2,\n                height: AI_TABLE_OPTION_ITEM_HEIGHT,\n                radius: AI_TABLE_PIECE_RADIUS,\n                fill: Colors.gray100,\n                width: 0\n            };\n\n            const commonItem = (optionStyle: AITableSelectOptionStyle, shape: string) => {\n                const baseWidth = isDotOrPiece\n                    ? AI_TABLE_CELL_MULTI_DOT_RADIUS * 2 + AI_TABLE_CELL_MULTI_PADDING_LEFT + AI_TABLE_CELL_PADDING * 2\n                    : AI_TABLE_CELL_PADDING * 2;\n                if (remainSpace < minWidth) {\n                    return;\n                }\n                const { textWidth, item } = cellItemInfoMap.get(optionId);\n                const completeWidth = baseWidth + textWidth;\n                if (index !== transformValue.length - 1) {\n                    remainSpace -= AI_TABLE_CELL_MULTI_PADDING_LEFT;\n                }\n                const bgWidth = remainSpace > completeWidth ? completeWidth : remainSpace;\n                bgConfig.width = bgWidth;\n                if (isDotOrPiece) {\n                    this.rect(bgConfig);\n                    if (shape === 'rect') {\n                        this.rect({\n                            x: bgConfig.x + AI_TABLE_CELL_PADDING,\n                            y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_CELL_MULTI_DOT_RADIUS * 2) / 2,\n                            width: AI_TABLE_CELL_MULTI_DOT_RADIUS * 2,\n                            height: AI_TABLE_CELL_MULTI_DOT_RADIUS * 2,\n                            radius: AI_TABLE_PIECE_RADIUS,\n                            fill: item?.bg_color ?? item?.color ?? Colors.primary\n                        });\n                    } else if (shape === 'arc') {\n                        this.arc({\n                            x: bgConfig.x + AI_TABLE_CELL_PADDING,\n                            y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_CELL_MULTI_DOT_RADIUS * 2) / 2 + AI_TABLE_CELL_MULTI_DOT_RADIUS,\n                            radius: AI_TABLE_CELL_MULTI_DOT_RADIUS,\n                            fill: item?.bg_color ?? item?.color ?? Colors.primary\n                        });\n                    }\n\n                    this.text({\n                        x: bgConfig.x + AI_TABLE_CELL_PADDING + AI_TABLE_CELL_MULTI_DOT_RADIUS * 2 + AI_TABLE_CELL_MULTI_PADDING_LEFT,\n                        y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_OPTION_ITEM_FONT_SIZE) / 2,\n                        text: this.textEllipsis({\n                            text: item.text,\n                            maxWidth: bgWidth - baseWidth,\n                            fontSize: AI_TABLE_OPTION_ITEM_FONT_SIZE\n                        }).text,\n                        fillStyle: Colors.gray700,\n                        fontSize: AI_TABLE_OPTION_ITEM_FONT_SIZE\n                    });\n                } else if (optionStyle === AITableSelectOptionStyle.tag) {\n                    this.tag({\n                        x: bgConfig.x,\n                        y: bgConfig.y,\n                        width: bgConfig.width,\n                        text: this.textEllipsis({\n                            text: item.text,\n                            maxWidth: bgWidth - baseWidth,\n                            fontSize: AI_TABLE_TAG_FONT_SIZE\n                        }).text,\n                        radius: AI_TABLE_OPTION_ITEM_RADIUS,\n                        fontSize: AI_TABLE_TAG_FONT_SIZE,\n                        height: bgConfig.height,\n                        color: Colors.white,\n                        padding: AI_TABLE_CELL_PADDING,\n                        background: item?.bg_color ?? item?.color ?? Colors.primary\n                    });\n                } else {\n                    this.rect(bgConfig);\n                    this.text({\n                        x: bgConfig.x + AI_TABLE_CELL_PADDING,\n                        y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_TAG_FONT_SIZE) / 2,\n                        text: this.textEllipsis({\n                            text: item.text,\n                            maxWidth: bgWidth - baseWidth,\n                            fontSize: AI_TABLE_TAG_FONT_SIZE\n                        }).text,\n                        fillStyle: Colors.gray700,\n                        fontSize: AI_TABLE_TAG_FONT_SIZE\n                    });\n                }\n                const currentWidth = bgConfig.width;\n                remainSpace -= currentWidth;\n                currentX += currentWidth + AI_TABLE_CELL_MULTI_PADDING_LEFT;\n            };\n\n            switch (optionStyle) {\n                case AITableSelectOptionStyle.dot:\n                    commonItem(AITableSelectOptionStyle.dot, 'arc');\n                    break;\n                case AITableSelectOptionStyle.piece:\n                    commonItem(AITableSelectOptionStyle.piece, 'rect');\n                    break;\n                case AITableSelectOptionStyle.tag:\n                    commonItem(AITableSelectOptionStyle.tag, '');\n                    break;\n                default:\n                    commonItem(AITableSelectOptionStyle.text, '');\n                    break;\n            }\n        }\n\n        if (circleWidth > 0) {\n            if (optionStyle === AITableSelectOptionStyle.tag) {\n                this.tag({\n                    x: currentX,\n                    y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_OPTION_ITEM_HEIGHT) / 2,\n                    width: circleWidth,\n                    height: AI_TABLE_OPTION_ITEM_HEIGHT,\n                    text: circleText,\n                    background: Colors.gray100,\n                    color: Colors.gray700,\n                    radius: AI_TABLE_OPTION_ITEM_RADIUS,\n                    padding: AI_TABLE_CELL_PADDING,\n                    fontSize: AI_TABLE_TAG_FONT_SIZE\n                });\n            } else {\n                this.rect({\n                    x: currentX,\n                    y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_OPTION_ITEM_HEIGHT) / 2,\n                    width: circleWidth,\n                    height: AI_TABLE_OPTION_ITEM_HEIGHT,\n                    fill: Colors.gray100,\n                    radius: AI_TABLE_PIECE_RADIUS\n                });\n                this.text({\n                    x: currentX + AI_TABLE_CELL_PADDING,\n                    y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_TAG_FONT_SIZE) / 2,\n                    text: circleText,\n                    fillStyle: Colors.gray700,\n                    fontSize: AI_TABLE_TAG_FONT_SIZE\n                });\n            }\n        }\n    }\n\n    private renderSingleSelectCell(render: AITableRender, ctx?: any) {\n        const { x, y, transformValue, field, columnWidth, isActive } = render;\n        if (transformValue == null || transformValue === '') {\n            return;\n        }\n        const isOperating = isActive;\n        const item = (field as AITableSelectField).settings.options?.find((option) => option._id === transformValue[0]);\n        const itemName = item?.text || '';\n        const getTextEllipsis = (maxTextWidth: number, fontSize: number = AI_TABLE_COMMON_FONT_SIZE) => {\n            maxTextWidth -= isOperating ? AI_TABLE_CELL_DELETE_ITEM_BUTTON_SIZE - AI_TABLE_CELL_DELETE_ITEM_BUTTON_SIZE_OFFSET : 0;\n            return this.textEllipsis({\n                text: itemName,\n                maxWidth: columnWidth && maxTextWidth,\n                fontSize: fontSize\n            });\n        };\n        if (ctx) {\n            ctx.save();\n            ctx.globalAlpha = 1;\n            const colors = AITable.getColors();\n            const optionStyle = (field as AITableSelectField).settings.option_style;\n            let background = item?.bg_color ?? item?.color ?? colors.primary;\n            const dotMaxTextWidth = columnWidth - 2 * AI_TABLE_CELL_PADDING - AI_TABLE_PIECE_WIDTH - AI_TABLE_TEXT_GAP;\n            const borderWidth = 1;\n            switch (optionStyle) {\n                case AITableSelectOptionStyle.dot:\n                    // 这里的 AI_TABLE_OFFSET 偏移不确定是为啥（包括 piece 的），只是为了保持和编辑组件中的对齐\n                    this.arc({\n                        x: x + AI_TABLE_CELL_PADDING + AI_TABLE_DOT_RADIUS,\n                        y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_PIECE_WIDTH) / 2 + AI_TABLE_DOT_RADIUS - AI_TABLE_OFFSET,\n                        radius: AI_TABLE_DOT_RADIUS,\n                        fill: background\n                    });\n                    this.text({\n                        x: x + AI_TABLE_PIECE_WIDTH + AI_TABLE_TEXT_GAP + AI_TABLE_CELL_PADDING,\n                        y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_OPTION_ITEM_FONT_SIZE) / 2,\n                        text: getTextEllipsis(dotMaxTextWidth).text,\n                        fillStyle: colors.gray800\n                    });\n                    break;\n                case AITableSelectOptionStyle.piece:\n                    this.rect({\n                        x: x + AI_TABLE_CELL_PADDING,\n                        y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_PIECE_WIDTH) / 2 - AI_TABLE_OFFSET,\n                        width: AI_TABLE_PIECE_WIDTH,\n                        height: AI_TABLE_PIECE_WIDTH,\n                        radius: AI_TABLE_PIECE_RADIUS,\n                        fill: background\n                    });\n                    this.text({\n                        x: x + AI_TABLE_PIECE_WIDTH + AI_TABLE_TEXT_GAP + AI_TABLE_CELL_PADDING,\n                        y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_OPTION_ITEM_FONT_SIZE) / 2,\n                        text: getTextEllipsis(dotMaxTextWidth).text,\n                        fillStyle: colors.gray800\n                    });\n                    break;\n\n                case AITableSelectOptionStyle.tag:\n                    const maxTextWidth = columnWidth - 2 * (AI_TABLE_CELL_PADDING + AI_TABLE_TAG_PADDING);\n                    const { textWidth, text } = getTextEllipsis(maxTextWidth, AI_TABLE_TAG_FONT_SIZE);\n                    const width = Math.max(textWidth + 2 * AI_TABLE_TAG_PADDING, AI_TABLE_CELL_MULTI_ITEM_MIN_WIDTH);\n                    this.tag({\n                        x: x + AI_TABLE_CELL_PADDING,\n                        y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_OPTION_ITEM_HEIGHT) / 2,\n                        width,\n                        height: AI_TABLE_OPTION_ITEM_HEIGHT,\n                        text,\n                        background,\n                        color: colors.white,\n                        radius: AI_TABLE_OPTION_ITEM_RADIUS,\n                        padding: AI_TABLE_OPTION_ITEM_PADDING,\n                        fontSize: AI_TABLE_TAG_FONT_SIZE,\n                        stroke: background\n                    });\n                    break;\n                default:\n                    const textMaxTextWidth = columnWidth - 2 * AI_TABLE_CELL_PADDING;\n                    this.text({\n                        x: x + AI_TABLE_CELL_PADDING,\n                        y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_OPTION_ITEM_FONT_SIZE) / 2,\n                        text: getTextEllipsis(textMaxTextWidth).text,\n                        fillStyle: colors.gray800\n                    });\n                    break;\n            }\n\n            ctx.restore();\n        }\n    }\n\n    private renderCellDate(render: AITableRender, ctx?: any) {\n        const { x, y, transformValue, columnWidth, style } = render;\n        const colors = AITable.getColors();\n        let cellText = transformValue;\n\n        if (cellText == null || !_.isString(cellText)) {\n            return;\n        }\n\n        const textMaxWidth = columnWidth - 2 * AI_TABLE_CELL_PADDING;\n        const { text } = this.textEllipsis({ text: cellText, maxWidth: columnWidth && textMaxWidth });\n        if (ctx) {\n            const color = style?.color || colors.gray800;\n            this.text({\n                x: x + AI_TABLE_CELL_PADDING,\n                y: y + AI_TABLE_ROW_BLANK_HEIGHT / 2,\n                text,\n                fillStyle: color,\n                fontWeight: style?.fontWeight,\n                verticalAlign: DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE\n            });\n        }\n    }\n\n    private renderCellRate(render: AITableRender, ctx?: CanvasRenderingContext2D | undefined) {\n        const { x, y, transformValue: _cellValue } = render;\n        const max = 5;\n        const cellValue = (_cellValue as RateFieldValue) || 0;\n        const size = AI_TABLE_CELL_EMOJI_SIZE;\n\n        return [...Array(max).keys()].map((item, index) => {\n            const value = index + 1;\n            const checked = value <= cellValue;\n            const iconX = index * size + AI_TABLE_CELL_PADDING + index * AI_TABLE_CELL_EMOJI_PADDING;\n            const iconY = (AI_TABLE_ROW_BLANK_HEIGHT - size) / 2;\n\n            if (ctx && checked) {\n                this.path({\n                    x: x + iconX,\n                    y: y + iconY,\n                    size: 22,\n                    data: StarFill,\n                    fill: this.colors.waring,\n                    scaleX: 1.14,\n                    scaleY: 1.14\n                });\n            }\n        });\n    }\n\n    private renderCellProgress(render: AITableRender, ctx?: any) {\n        const { x, y, transformValue, columnWidth, style } = render;\n        const colors = AITable.getColors();\n        const cellText = transformValue;\n\n        if (cellText == null || !_.isNumber(cellText)) {\n            return;\n        }\n\n        const width = columnWidth - 2 * AI_TABLE_CELL_PADDING - AI_TABLE_PROGRESS_TEXT_Width;\n        const height = AI_TABLE_PROGRESS_BAR_HEIGHT;\n        const textHeight = AI_TABLE_COMMON_FONT_SIZE;\n        const offsetX = AI_TABLE_CELL_PADDING;\n        const offsetY = (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_PROGRESS_BAR_HEIGHT) / 2;\n        const textOffsetY = (AI_TABLE_ROW_BLANK_HEIGHT - textHeight) / 2;\n\n        // 绘制背景\n        this.rect({\n            x: x + offsetX,\n            y: y + offsetY,\n            width,\n            height,\n            radius: AI_TABLE_PROGRESS_BAR_RADIUS,\n            fill: colors.gray200\n        });\n\n        // 计算并绘制进度\n        const progressWidth = (transformValue / 100) * width;\n        this.rect({\n            x: x + offsetX,\n            y: y + offsetY,\n            width: progressWidth,\n            height,\n            radius: AI_TABLE_PROGRESS_BAR_RADIUS,\n            fill: colors.success\n        });\n\n        this.text({\n            x: x + offsetX + width + AI_TABLE_TEXT_GAP,\n            y: y + textOffsetY,\n            text: `${transformValue}%`,\n            fillStyle: colors.gray800\n        });\n    }\n\n    private renderCellMember(render: AITableRender, ctx?: CanvasRenderingContext2D | undefined) {\n        const { references, x, y, field, transformValue: _cellValue, rowHeight, columnWidth, isActive } = render;\n        const cellValue = _cellValue;\n\n        if (!cellValue?.length || !references) {\n            return;\n        }\n        const settings = field.settings as MemberSettings;\n        const avatarSize = AI_TABLE_MEMBER_AVATAR_SIZE;\n        const itemHeight = AI_TABLE_CELL_MEMBER_ITEM_HEIGHT;\n        const isOperating = isActive;\n        const isMulti = settings?.is_multiple;\n\n        let currentX = AI_TABLE_CELL_PADDING;\n        let currentY = (AI_TABLE_ROW_BLANK_HEIGHT - avatarSize) / 2;\n        const itemOtherWidth = avatarSize + AI_TABLE_MEMBER_ITEM_PADDING_RIGHT + AI_TABLE_MEMBER_ITEM_AVATAR_MARGIN_RIGHT;\n        const maxHeight = isActive ? 130 - AI_TABLE_CELL_MULTI_PADDING_TOP : rowHeight - AI_TABLE_CELL_MULTI_PADDING_TOP;\n        const maxTextWidth = isOperating\n            ? columnWidth - 2 * AI_TABLE_CELL_PADDING - itemOtherWidth - AI_TABLE_CELL_DELETE_ITEM_BUTTON_SIZE - 12\n            : columnWidth - 2 * AI_TABLE_CELL_PADDING - itemOtherWidth;\n\n        const listCount = cellValue.length;\n        let isOverflow = false;\n\n        for (let index = 0; index < listCount; index++) {\n            const userInfo = references?.members[cellValue[index]];\n            if (!userInfo) continue;\n\n            const { uid, display_name, avatar } = userInfo;\n            const type = AITableMemberType.member;\n            const itemWidth = AITableAvatarSize.size24 + (isMulti ? AI_TABLE_CELL_MEMBER_ITEM_PADDING : 0);\n\n            currentX = AI_TABLE_CELL_PADDING + index * itemWidth;\n\n            let realMaxTextWidth = maxTextWidth < 0 ? 0 : maxTextWidth;\n            if (index === 0 && isOperating) {\n                const operatingMaxWidth = maxTextWidth - (AI_TABLE_CELL_ADD_ITEM_BUTTON_SIZE + 4);\n                // item No space to display, then perform a line feed\n                if (operatingMaxWidth <= 20) {\n                    currentX = AI_TABLE_CELL_PADDING;\n                    currentY += AI_TABLE_OPTION_ITEM_HEIGHT + AI_TABLE_CELL_MULTI_ITEM_MARGIN_TOP;\n                } else {\n                    realMaxTextWidth = operatingMaxWidth;\n                }\n            }\n\n            let isMore = currentX + itemWidth > columnWidth - 2 * AI_TABLE_CELL_PADDING;\n            if (columnWidth != null) {\n                // 在非活动状态下，当超出列宽时，不会渲染后续内容\n                if (!isActive && currentX >= columnWidth - 2 * AI_TABLE_CELL_PADDING) {\n                    break;\n                }\n                // 如果不是非活动状态的最后一行，则换行渲染溢出内容\n                if (!isActive && currentX > columnWidth - 2 * AI_TABLE_CELL_PADDING) {\n                    currentX = AI_TABLE_CELL_PADDING;\n                }\n                if (isActive && currentX + itemWidth > columnWidth - AI_TABLE_CELL_PADDING) {\n                    currentX = AI_TABLE_CELL_PADDING;\n                    currentY += itemHeight;\n                }\n                if (isActive && currentY >= maxHeight) {\n                    isOverflow = true;\n                }\n            }\n\n            if (ctx && !isActive) {\n                this.avatar({\n                    x: x + currentX,\n                    y: y + currentY,\n                    url: avatar!,\n                    id: uid!,\n                    title: getAvatarShortName(display_name),\n                    bgColor: getAvatarBgColor(display_name!),\n                    type: AITableAvatarType.member,\n                    size: AITableAvatarSize.size24\n                });\n\n                if (isMore) {\n                    ctx.save();\n                    ctx.globalAlpha = 0.3;\n                    this.rect({\n                        x: x + currentX,\n                        y: y + currentY,\n                        width: AITableAvatarSize.size24,\n                        height: AITableAvatarSize.size24,\n                        radius: 24,\n                        fill: this.colors.black\n                    });\n                    ctx.restore();\n                    this.text({\n                        x: x + currentX + FONT_SIZE_SM / 2,\n                        y: y + AI_TABLE_ROW_BLANK_HEIGHT / 2,\n                        fillStyle: this.colors.white,\n                        fontSize: FONT_SIZE_SM,\n                        text: `+${listCount - index - 1}`,\n                        verticalAlign: DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE\n                    });\n                }\n            }\n        }\n    }\n}\n\nexport const cellDrawer = new CellDrawer();\n"]}
|