@ai-table/grid 0.0.73 → 0.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (234) hide show
  1. package/angular-konva/components/container.component.d.ts.map +1 -1
  2. package/angular-konva/components/shape.component.d.ts.map +1 -1
  3. package/angular-konva/components/stage.component.d.ts.map +1 -1
  4. package/components/cell-editors/abstract-cell-editor.component.d.ts.map +1 -1
  5. package/components/cell-editors/date/date-editor.component.d.ts.map +1 -1
  6. package/components/cell-editors/link/edit-link/edit-link.component.d.ts.map +1 -1
  7. package/components/cell-editors/link/link-editor.component.d.ts.map +1 -1
  8. package/components/cell-editors/number/number-editor.component.d.ts.map +1 -1
  9. package/components/cell-editors/select/select-editor.component.d.ts.map +1 -1
  10. package/components/cell-editors/text/text-editor.component.d.ts.map +1 -1
  11. package/components/cell-views/select/option.component.d.ts.map +1 -1
  12. package/components/context-menu/context-menu.component.d.ts.map +1 -1
  13. package/components/drag/drag.component.d.ts.map +1 -1
  14. package/components/field-menu/field-menu.component.d.ts.map +1 -1
  15. package/components/field-setting/field-setting.component.d.ts.map +1 -1
  16. package/core/context.d.ts +2 -0
  17. package/core/context.d.ts.map +1 -1
  18. package/core/types/ai-table.d.ts.map +1 -1
  19. package/core/utils/field.d.ts.map +1 -1
  20. package/core/utils/queries.d.ts.map +1 -1
  21. package/core/utils/short-id.d.ts.map +1 -1
  22. package/dom-grid.component.d.ts.map +1 -1
  23. package/fesm2022/ai-table-grid.mjs +347 -317
  24. package/fesm2022/ai-table-grid.mjs.map +1 -1
  25. package/grid-base.component.d.ts +3 -1
  26. package/grid-base.component.d.ts.map +1 -1
  27. package/grid.component.d.ts +1 -1
  28. package/grid.component.d.ts.map +1 -1
  29. package/package.json +3 -5
  30. package/pipes/grid.pipe.d.ts.map +1 -1
  31. package/renderer/components/action-icon.component.d.ts.map +1 -1
  32. package/renderer/components/add-field-column.component.d.ts.map +1 -1
  33. package/renderer/components/cells/attachment.component.d.ts.map +1 -1
  34. package/renderer/components/cells/link.component.d.ts.map +1 -1
  35. package/renderer/components/cells/progress.component.d.ts.map +1 -1
  36. package/renderer/components/cells/rate.component.d.ts.map +1 -1
  37. package/renderer/components/cells/rich-text.component.d.ts.map +1 -1
  38. package/renderer/components/cells.component.d.ts.map +1 -1
  39. package/renderer/components/field-head.component.d.ts +2 -2
  40. package/renderer/components/field-head.component.d.ts.map +1 -1
  41. package/renderer/components/field-icon.component.d.ts.map +1 -1
  42. package/renderer/components/frozen-cells.component.d.ts.map +1 -1
  43. package/renderer/components/frozen-heads.component.d.ts +1 -1
  44. package/renderer/components/frozen-heads.component.d.ts.map +1 -1
  45. package/renderer/components/frozen-placeholder-cells.component.d.ts.map +1 -1
  46. package/renderer/components/heads.component.d.ts +1 -1
  47. package/renderer/components/heads.component.d.ts.map +1 -1
  48. package/renderer/components/hover-cell.component.d.ts.map +1 -1
  49. package/renderer/components/hover-row-heads.component.d.ts.map +1 -1
  50. package/renderer/components/icon.component.d.ts.map +1 -1
  51. package/renderer/components/other-rows.component.d.ts.map +1 -1
  52. package/renderer/components/placeholder-cells.component.d.ts.map +1 -1
  53. package/renderer/components/text.component.d.ts.map +1 -1
  54. package/renderer/creations/create-active-cell-border.d.ts.map +1 -1
  55. package/renderer/creations/create-cells.d.ts.map +1 -1
  56. package/renderer/creations/create-heads.d.ts.map +1 -1
  57. package/renderer/drawers/add-row-layout-drawer.d.ts +1 -1
  58. package/renderer/drawers/add-row-layout-drawer.d.ts.map +1 -1
  59. package/renderer/drawers/cell-drawer.d.ts.map +1 -1
  60. package/renderer/drawers/drawer.d.ts +1 -1
  61. package/renderer/renderer.component.d.ts +7 -4
  62. package/renderer/renderer.component.d.ts.map +1 -1
  63. package/types/cell.d.ts +2 -0
  64. package/types/cell.d.ts.map +1 -1
  65. package/types/component-config.d.ts +2 -0
  66. package/types/component-config.d.ts.map +1 -1
  67. package/types/grid.d.ts +4 -0
  68. package/types/grid.d.ts.map +1 -1
  69. package/types/row.d.ts +1 -0
  70. package/types/row.d.ts.map +1 -1
  71. package/utils/build.d.ts.map +1 -1
  72. package/utils/clipboard/clipboard.d.ts.map +1 -1
  73. package/utils/clipboard/copy.d.ts.map +1 -1
  74. package/utils/clipboard/paste.d.ts +5 -1
  75. package/utils/clipboard/paste.d.ts.map +1 -1
  76. package/utils/common.d.ts.map +1 -1
  77. package/utils/field/model/date.d.ts.map +1 -1
  78. package/utils/field/model/link.d.ts.map +1 -1
  79. package/utils/field/model/progress.d.ts.map +1 -1
  80. package/utils/field/model/select.d.ts +4 -1
  81. package/utils/field/model/select.d.ts.map +1 -1
  82. package/utils/field/model/text.d.ts.map +1 -1
  83. package/utils/get-text-width.d.ts.map +1 -1
  84. package/utils/i18n.d.ts +2 -0
  85. package/utils/i18n.d.ts.map +1 -1
  86. package/utils/match-keywords.d.ts.map +1 -1
  87. package/utils/position.d.ts.map +1 -1
  88. package/utils/style.d.ts.map +1 -1
  89. package/utils/text-measure.d.ts.map +1 -1
  90. package/utils/visible-range.d.ts.map +1 -1
  91. package/esm2022/ai-table-grid.mjs +0 -5
  92. package/esm2022/angular-konva/components/container.component.mjs +0 -29
  93. package/esm2022/angular-konva/components/container.token.mjs +0 -3
  94. package/esm2022/angular-konva/components/index.mjs +0 -4
  95. package/esm2022/angular-konva/components/shape.component.mjs +0 -142
  96. package/esm2022/angular-konva/components/stage.component.mjs +0 -123
  97. package/esm2022/angular-konva/index.mjs +0 -5
  98. package/esm2022/angular-konva/interfaces/component.mjs +0 -4
  99. package/esm2022/angular-konva/interfaces/config.mjs +0 -2
  100. package/esm2022/angular-konva/interfaces/event-object.mjs +0 -2
  101. package/esm2022/angular-konva/interfaces/index.mjs +0 -5
  102. package/esm2022/angular-konva/interfaces/shape.mjs +0 -42
  103. package/esm2022/angular-konva/utils/apply-node-props.mjs +0 -67
  104. package/esm2022/angular-konva/utils/common.mjs +0 -48
  105. package/esm2022/angular-konva/utils/index.mjs +0 -5
  106. package/esm2022/angular-konva/utils/types.mjs +0 -2
  107. package/esm2022/angular-konva/utils/update-picture.mjs +0 -7
  108. package/esm2022/components/cell-editors/abstract-cell-editor.component.mjs +0 -56
  109. package/esm2022/components/cell-editors/date/date-editor.component.mjs +0 -87
  110. package/esm2022/components/cell-editors/link/edit-link/edit-link.component.mjs +0 -81
  111. package/esm2022/components/cell-editors/link/link-editor.component.mjs +0 -122
  112. package/esm2022/components/cell-editors/number/number-editor.component.mjs +0 -41
  113. package/esm2022/components/cell-editors/select/select-editor.component.mjs +0 -74
  114. package/esm2022/components/cell-editors/text/text-editor.component.mjs +0 -76
  115. package/esm2022/components/cell-views/select/option.component.mjs +0 -28
  116. package/esm2022/components/context-menu/context-menu.component.mjs +0 -42
  117. package/esm2022/components/drag/drag.component.mjs +0 -300
  118. package/esm2022/components/field-menu/field-menu.component.mjs +0 -47
  119. package/esm2022/components/field-setting/field-setting.component.mjs +0 -142
  120. package/esm2022/components/index.mjs +0 -10
  121. package/esm2022/constants/colors.mjs +0 -19
  122. package/esm2022/constants/editor.mjs +0 -11
  123. package/esm2022/constants/file-icon.mjs +0 -342
  124. package/esm2022/constants/grid.mjs +0 -35
  125. package/esm2022/constants/icon.mjs +0 -30
  126. package/esm2022/constants/index.mjs +0 -7
  127. package/esm2022/constants/table.mjs +0 -78
  128. package/esm2022/constants/text.mjs +0 -23
  129. package/esm2022/core/constants/field.mjs +0 -107
  130. package/esm2022/core/context.mjs +0 -29
  131. package/esm2022/core/coordinate.mjs +0 -222
  132. package/esm2022/core/index.mjs +0 -6
  133. package/esm2022/core/types/ai-table.mjs +0 -57
  134. package/esm2022/core/types/core.mjs +0 -2
  135. package/esm2022/core/types/index.mjs +0 -3
  136. package/esm2022/core/utils/common.mjs +0 -45
  137. package/esm2022/core/utils/field.mjs +0 -64
  138. package/esm2022/core/utils/id-creator.mjs +0 -21
  139. package/esm2022/core/utils/index.mjs +0 -5
  140. package/esm2022/core/utils/queries.mjs +0 -80
  141. package/esm2022/core/utils/short-id.mjs +0 -53
  142. package/esm2022/dom-grid.component.mjs +0 -80
  143. package/esm2022/grid-base.component.mjs +0 -145
  144. package/esm2022/grid.component.mjs +0 -649
  145. package/esm2022/index.mjs +0 -2
  146. package/esm2022/pipes/grid.pipe.mjs +0 -110
  147. package/esm2022/pipes/index.mjs +0 -2
  148. package/esm2022/public-api.mjs +0 -12
  149. package/esm2022/renderer/components/action-icon.component.mjs +0 -117
  150. package/esm2022/renderer/components/add-field-column.component.mjs +0 -88
  151. package/esm2022/renderer/components/cells/attachment.component.mjs +0 -107
  152. package/esm2022/renderer/components/cells/cells.mjs +0 -6
  153. package/esm2022/renderer/components/cells/index.mjs +0 -7
  154. package/esm2022/renderer/components/cells/link.component.mjs +0 -89
  155. package/esm2022/renderer/components/cells/progress.component.mjs +0 -268
  156. package/esm2022/renderer/components/cells/rate.component.mjs +0 -153
  157. package/esm2022/renderer/components/cells/rich-text.component.mjs +0 -95
  158. package/esm2022/renderer/components/cells.component.mjs +0 -35
  159. package/esm2022/renderer/components/field-head.component.mjs +0 -146
  160. package/esm2022/renderer/components/field-icon.component.mjs +0 -72
  161. package/esm2022/renderer/components/frozen-cells.component.mjs +0 -36
  162. package/esm2022/renderer/components/frozen-heads.component.mjs +0 -214
  163. package/esm2022/renderer/components/frozen-placeholder-cells.component.mjs +0 -38
  164. package/esm2022/renderer/components/heads.component.mjs +0 -38
  165. package/esm2022/renderer/components/hover-cell.component.mjs +0 -104
  166. package/esm2022/renderer/components/hover-row-heads.component.mjs +0 -132
  167. package/esm2022/renderer/components/icon.component.mjs +0 -84
  168. package/esm2022/renderer/components/index.mjs +0 -15
  169. package/esm2022/renderer/components/other-rows.component.mjs +0 -68
  170. package/esm2022/renderer/components/placeholder-cells.component.mjs +0 -33
  171. package/esm2022/renderer/components/text.component.mjs +0 -67
  172. package/esm2022/renderer/creations/create-active-cell-border.mjs +0 -70
  173. package/esm2022/renderer/creations/create-cells.mjs +0 -190
  174. package/esm2022/renderer/creations/create-heads.mjs +0 -51
  175. package/esm2022/renderer/drawers/add-row-layout-drawer.mjs +0 -98
  176. package/esm2022/renderer/drawers/cell-drawer.mjs +0 -673
  177. package/esm2022/renderer/drawers/drawer.mjs +0 -947
  178. package/esm2022/renderer/drawers/layout-drawer.mjs +0 -64
  179. package/esm2022/renderer/drawers/record-row-layout-drawer.mjs +0 -131
  180. package/esm2022/renderer/index.mjs +0 -4
  181. package/esm2022/renderer/interfaces/hover-cell.mjs +0 -4
  182. package/esm2022/renderer/interfaces/index.mjs +0 -2
  183. package/esm2022/renderer/renderer.component.mjs +0 -197
  184. package/esm2022/services/event.service.mjs +0 -241
  185. package/esm2022/services/field.service.mjs +0 -56
  186. package/esm2022/services/index.mjs +0 -4
  187. package/esm2022/services/selection.service.mjs +0 -151
  188. package/esm2022/types/avatar.mjs +0 -27
  189. package/esm2022/types/canvas.mjs +0 -2
  190. package/esm2022/types/cell.mjs +0 -2
  191. package/esm2022/types/clipboard.mjs +0 -2
  192. package/esm2022/types/component-config.mjs +0 -7
  193. package/esm2022/types/field.mjs +0 -2
  194. package/esm2022/types/grid.mjs +0 -17
  195. package/esm2022/types/index.mjs +0 -10
  196. package/esm2022/types/layout.mjs +0 -2
  197. package/esm2022/types/row.mjs +0 -6
  198. package/esm2022/utils/build.mjs +0 -39
  199. package/esm2022/utils/cell.mjs +0 -80
  200. package/esm2022/utils/clear-cells.mjs +0 -23
  201. package/esm2022/utils/clipboard/clipboard.mjs +0 -88
  202. package/esm2022/utils/clipboard/copy.mjs +0 -99
  203. package/esm2022/utils/clipboard/extract.mjs +0 -38
  204. package/esm2022/utils/clipboard/index.mjs +0 -5
  205. package/esm2022/utils/clipboard/paste.mjs +0 -188
  206. package/esm2022/utils/common.mjs +0 -50
  207. package/esm2022/utils/field/field-operable.mjs +0 -2
  208. package/esm2022/utils/field/field.mjs +0 -20
  209. package/esm2022/utils/field/index.mjs +0 -4
  210. package/esm2022/utils/field/model/attachment.mjs +0 -56
  211. package/esm2022/utils/field/model/date.mjs +0 -141
  212. package/esm2022/utils/field/model/index.mjs +0 -12
  213. package/esm2022/utils/field/model/link.mjs +0 -56
  214. package/esm2022/utils/field/model/member.mjs +0 -81
  215. package/esm2022/utils/field/model/number.mjs +0 -59
  216. package/esm2022/utils/field/model/progress.mjs +0 -69
  217. package/esm2022/utils/field/model/rate.mjs +0 -58
  218. package/esm2022/utils/field/model/rich-text.mjs +0 -39
  219. package/esm2022/utils/field/model/select.mjs +0 -131
  220. package/esm2022/utils/field/model/text.mjs +0 -32
  221. package/esm2022/utils/field/operate.mjs +0 -73
  222. package/esm2022/utils/file.mjs +0 -116
  223. package/esm2022/utils/get-placeholder-cells.mjs +0 -66
  224. package/esm2022/utils/get-text-width.mjs +0 -30
  225. package/esm2022/utils/hover-cell.mjs +0 -25
  226. package/esm2022/utils/i18n.mjs +0 -87
  227. package/esm2022/utils/image-cache.mjs +0 -57
  228. package/esm2022/utils/index.mjs +0 -19
  229. package/esm2022/utils/match-keywords.mjs +0 -15
  230. package/esm2022/utils/os.mjs +0 -16
  231. package/esm2022/utils/position.mjs +0 -48
  232. package/esm2022/utils/style.mjs +0 -37
  233. package/esm2022/utils/text-measure.mjs +0 -122
  234. package/esm2022/utils/visible-range.mjs +0 -42
@@ -1,673 +0,0 @@
1
- import { isNil } 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_FIELD_ITEM_MARGIN_RIGHT, AI_TABLE_FILE_ICON_ITEM_HEIGHT, AI_TABLE_FILE_ICON_SIZE, AI_TABLE_MEMBER_AVATAR_SIZE, AI_TABLE_MEMBER_ITEM_AVATAR_MARGIN_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, AI_TABLE_RATE_MAX, StarFill } from '../../constants';
3
- import { AITable } from '../../core';
4
- import { AITableFieldType, AITableSelectOptionStyle } from '@ai-table/utils';
5
- import { AITableAvatarSize, AITableAvatarType } from '../../types';
6
- import { FieldModelMap, getAvatarBgColor, getAvatarShortName, getTextWidth } from '../../utils';
7
- import { Drawer } from './drawer';
8
- import { helpers } from 'ngx-tethys/util';
9
- import { getFileThumbnailSvgString } from '../../utils/file';
10
- /**
11
- * 处理和渲染表格单元格的内容
12
- */
13
- export class CellDrawer extends Drawer {
14
- // 样式初始化
15
- initStyle(field, styleProps) {
16
- const { type: fieldType } = field;
17
- const { fontWeight = DEFAULT_FONT_WEIGHT } = styleProps;
18
- switch (fieldType) {
19
- case AITableFieldType.text:
20
- case AITableFieldType.date:
21
- case AITableFieldType.createdAt:
22
- case AITableFieldType.updatedAt:
23
- case AITableFieldType.rate:
24
- case AITableFieldType.progress:
25
- case AITableFieldType.member:
26
- case AITableFieldType.createdBy:
27
- case AITableFieldType.updatedBy:
28
- return this.setStyle({ fontSize: DEFAULT_FONT_SIZE, fontWeight });
29
- default:
30
- return null;
31
- }
32
- }
33
- // 单元格渲染
34
- renderCell(render, ctx, columnWidth) {
35
- const { field, cellValue } = render;
36
- const fieldType = field.type;
37
- const fieldMethod = FieldModelMap[fieldType];
38
- if (!fieldMethod.isValid(cellValue)) {
39
- return;
40
- }
41
- switch (fieldType) {
42
- case AITableFieldType.text:
43
- case AITableFieldType.richText:
44
- case AITableFieldType.number:
45
- case AITableFieldType.link:
46
- return this.renderCellText(render, ctx);
47
- case AITableFieldType.select:
48
- return this.renderCellSelect(render, ctx);
49
- case AITableFieldType.date:
50
- case AITableFieldType.createdAt:
51
- case AITableFieldType.updatedAt:
52
- return this.renderCellDate(render, ctx);
53
- case AITableFieldType.rate:
54
- return this.renderCellRate(render, ctx, columnWidth);
55
- case AITableFieldType.progress:
56
- return this.renderCellProgress(render, ctx);
57
- case AITableFieldType.member:
58
- case AITableFieldType.createdBy:
59
- case AITableFieldType.updatedBy:
60
- return this.renderCellMember(render, ctx);
61
- case AITableFieldType.attachment:
62
- return this.renderCellAttachment(render, ctx);
63
- default:
64
- return null;
65
- }
66
- }
67
- renderCellText(render, ctx) {
68
- const { x, y, transformValue, field, columnWidth, style } = render;
69
- if (isNil(transformValue)) {
70
- return;
71
- }
72
- const fieldType = field.type;
73
- let renderText = fieldType === AITableFieldType.link ? transformValue?.text : transformValue;
74
- if (renderText == null) {
75
- return;
76
- }
77
- // const isSingleLine = !columnWidth;
78
- const isSingleLine = true;
79
- const isTextField = fieldType === AITableFieldType.text || fieldType === AITableFieldType.richText;
80
- const isNumberField = fieldType === AITableFieldType.number;
81
- if (isTextField && isSingleLine) {
82
- renderText = renderText.replace(/\r|\n/g, ' ');
83
- }
84
- const color = style?.color || this.colors.gray800;
85
- const textAlign = style?.textAlign || DEFAULT_TEXT_ALIGN_LEFT;
86
- const fontWeight = style?.fontWeight;
87
- const textMaxWidth = columnWidth - 2 * AI_TABLE_CELL_PADDING;
88
- const renderX = textAlign === DEFAULT_TEXT_ALIGN_RIGHT ? x + columnWidth - AI_TABLE_CELL_PADDING : x + AI_TABLE_CELL_PADDING;
89
- const renderY = y + AI_TABLE_ROW_BLANK_HEIGHT / 2;
90
- const textDecoration = DEFAULT_TEXT_DECORATION;
91
- if (isNumberField) {
92
- renderText = String(renderText);
93
- const { text } = this.textEllipsis({
94
- text: renderText,
95
- maxWidth: columnWidth && textMaxWidth,
96
- fontWeight
97
- });
98
- if (ctx) {
99
- let pureText = text;
100
- this.text({
101
- x: renderX,
102
- y: renderY,
103
- text: pureText,
104
- textAlign,
105
- fillStyle: color,
106
- fontWeight,
107
- textDecoration,
108
- verticalAlign: DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE
109
- });
110
- }
111
- }
112
- else {
113
- this.wrapText({
114
- x: renderX,
115
- y: renderY,
116
- text: renderText,
117
- maxWidth: textMaxWidth,
118
- maxRow: AI_TABLE_CELL_MAX_ROW_COUNT,
119
- lineHeight: DEFAULT_TEXT_LINE_HEIGHT,
120
- textAlign,
121
- verticalAlign: DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE,
122
- fillStyle: fieldType === AITableFieldType.link ? Colors.primary : color,
123
- fontWeight,
124
- textDecoration,
125
- fieldType,
126
- needDraw: true
127
- });
128
- }
129
- }
130
- renderCellSelect(render, ctx) {
131
- const { field } = render;
132
- if (field.settings?.is_multiple) {
133
- this.renderCellMultiSelect(render, ctx);
134
- }
135
- else {
136
- this.renderSingleSelectCell(render, ctx);
137
- }
138
- }
139
- getValidSelectedValue(field, transformValue) {
140
- const fieldOptionsMap = helpers.keyBy(field.settings.options || [], '_id');
141
- return (transformValue || []).filter((optionId) => !!fieldOptionsMap[optionId]);
142
- }
143
- renderCellMultiSelect(render, ctx) {
144
- const { x, y, field, columnWidth } = render;
145
- let transformValue = this.getValidSelectedValue(field, render.transformValue);
146
- if (!transformValue.length) {
147
- return;
148
- }
149
- let currentX = x + AI_TABLE_CELL_PADDING;
150
- const maxContainerWidth = columnWidth - 2 * AI_TABLE_CELL_PADDING;
151
- const optionStyle = field.settings.option_style;
152
- const fontStyle = `${DEFAULT_FONT_WEIGHT} ${AI_TABLE_OPTION_ITEM_FONT_SIZE}px ${DEFAULT_FONT_FAMILY}`;
153
- const isDotOrPiece = optionStyle === AITableSelectOptionStyle.dot || optionStyle === AITableSelectOptionStyle.piece;
154
- let totalWidth = 0;
155
- const cellItemInfoMap = new Map();
156
- let drawableIndex = 0;
157
- transformValue.forEach((optionId, index) => {
158
- const item = field.settings.options?.find((option) => option._id === optionId);
159
- const textWidth = getTextWidth(ctx, item?.text, fontStyle);
160
- totalWidth += textWidth + 2 * AI_TABLE_CELL_PADDING;
161
- if (index < transformValue.length - 1) {
162
- totalWidth += AI_TABLE_CELL_MULTI_PADDING_LEFT;
163
- }
164
- if (isDotOrPiece) {
165
- totalWidth += AI_TABLE_CELL_MULTI_DOT_RADIUS * 2 + AI_TABLE_CELL_MULTI_PADDING_LEFT;
166
- }
167
- if (totalWidth < maxContainerWidth || totalWidth === maxContainerWidth) {
168
- drawableIndex = index;
169
- }
170
- cellItemInfoMap.set(optionId, { textWidth, item, offset: totalWidth });
171
- });
172
- const baseWidth = AI_TABLE_MIN_TEXT_WIDTH + AI_TABLE_CELL_PADDING * 2;
173
- const minWidth = isDotOrPiece ? baseWidth + AI_TABLE_CELL_MULTI_DOT_RADIUS * 2 + AI_TABLE_CELL_MULTI_PADDING_LEFT : baseWidth;
174
- if (transformValue[drawableIndex + 1]) {
175
- const { offset: currentOffset } = cellItemInfoMap.get(transformValue[drawableIndex]);
176
- const canDrawerNext = maxContainerWidth - currentOffset > minWidth;
177
- drawableIndex = canDrawerNext ? drawableIndex + 1 : drawableIndex;
178
- // 上面过程是 没有 +数字 的情况下最大能放几个;
179
- const number = transformValue.length - (drawableIndex + 1);
180
- if (number > 0) {
181
- // 说明有 +数字,重新计算
182
- const circleWidth = getTextWidth(ctx, `+{number}`, fontStyle) + 2 * AI_TABLE_CELL_PADDING;
183
- const max = maxContainerWidth - AI_TABLE_CELL_MULTI_PADDING_LEFT - circleWidth;
184
- // 如果当前已经超出了,看是否能容下当前的,不能就减去 1;
185
- const currentItemHasOver = currentOffset > max;
186
- if (currentItemHasOver) {
187
- const lastOffset = drawableIndex === 0 ? 0 : cellItemInfoMap.get(transformValue[drawableIndex - 1]);
188
- drawableIndex = max - lastOffset > minWidth ? drawableIndex : drawableIndex - 1;
189
- }
190
- else {
191
- // 还有剩余空间, 看是否能多渲染一个
192
- drawableIndex = max - currentOffset > minWidth ? drawableIndex + 1 : drawableIndex;
193
- }
194
- }
195
- }
196
- const circleText = `+${transformValue.length - (drawableIndex + 1)}`;
197
- const circleWidth = transformValue.length - (drawableIndex + 1) > 0 ? getTextWidth(ctx, circleText, fontStyle) + 2 * AI_TABLE_CELL_PADDING : 0;
198
- // 剩余空间
199
- let remainSpace = maxContainerWidth - circleWidth - (circleWidth > 0 ? AI_TABLE_CELL_MULTI_PADDING_LEFT : 0);
200
- for (let index = 0; index < transformValue.length; index++) {
201
- const optionId = transformValue[index];
202
- const bgConfig = {
203
- x: currentX,
204
- y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_OPTION_ITEM_HEIGHT) / 2,
205
- height: AI_TABLE_OPTION_ITEM_HEIGHT,
206
- radius: AI_TABLE_PIECE_RADIUS,
207
- fill: Colors.gray100,
208
- width: 0
209
- };
210
- const commonItem = (optionStyle, shape) => {
211
- const baseWidth = isDotOrPiece
212
- ? AI_TABLE_CELL_MULTI_DOT_RADIUS * 2 + AI_TABLE_CELL_MULTI_PADDING_LEFT + AI_TABLE_CELL_PADDING * 2
213
- : AI_TABLE_CELL_PADDING * 2;
214
- if (remainSpace < minWidth) {
215
- return;
216
- }
217
- const { textWidth, item } = cellItemInfoMap.get(optionId);
218
- const completeWidth = baseWidth + textWidth;
219
- if (index !== transformValue.length - 1) {
220
- remainSpace -= AI_TABLE_CELL_MULTI_PADDING_LEFT;
221
- }
222
- const bgWidth = remainSpace > completeWidth ? completeWidth : remainSpace;
223
- bgConfig.width = bgWidth;
224
- if (isDotOrPiece) {
225
- this.rect(bgConfig);
226
- if (shape === 'rect') {
227
- this.rect({
228
- x: bgConfig.x + AI_TABLE_CELL_PADDING,
229
- y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_CELL_MULTI_DOT_RADIUS * 2) / 2,
230
- width: AI_TABLE_CELL_MULTI_DOT_RADIUS * 2,
231
- height: AI_TABLE_CELL_MULTI_DOT_RADIUS * 2,
232
- radius: AI_TABLE_PIECE_RADIUS,
233
- fill: item?.bg_color ?? item?.color ?? Colors.primary
234
- });
235
- }
236
- else if (shape === 'arc') {
237
- this.arc({
238
- x: bgConfig.x + AI_TABLE_CELL_PADDING,
239
- y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_CELL_MULTI_DOT_RADIUS * 2) / 2 + AI_TABLE_CELL_MULTI_DOT_RADIUS,
240
- radius: AI_TABLE_CELL_MULTI_DOT_RADIUS,
241
- fill: item?.bg_color ?? item?.color ?? Colors.primary
242
- });
243
- }
244
- this.text({
245
- x: bgConfig.x + AI_TABLE_CELL_PADDING + AI_TABLE_CELL_MULTI_DOT_RADIUS * 2 + AI_TABLE_CELL_MULTI_PADDING_LEFT,
246
- y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_OPTION_ITEM_FONT_SIZE) / 2,
247
- text: this.textEllipsis({
248
- text: item.text,
249
- maxWidth: bgWidth - baseWidth,
250
- fontSize: AI_TABLE_OPTION_ITEM_FONT_SIZE
251
- }).text,
252
- fillStyle: Colors.gray700,
253
- fontSize: AI_TABLE_OPTION_ITEM_FONT_SIZE
254
- });
255
- }
256
- else if (optionStyle === AITableSelectOptionStyle.tag) {
257
- this.tag({
258
- x: bgConfig.x,
259
- y: bgConfig.y,
260
- width: bgConfig.width,
261
- text: this.textEllipsis({
262
- text: item.text,
263
- maxWidth: bgWidth - baseWidth,
264
- fontSize: AI_TABLE_TAG_FONT_SIZE
265
- }).text,
266
- radius: AI_TABLE_OPTION_ITEM_RADIUS,
267
- fontSize: AI_TABLE_TAG_FONT_SIZE,
268
- height: bgConfig.height,
269
- color: Colors.white,
270
- padding: AI_TABLE_CELL_PADDING,
271
- background: item?.bg_color ?? item?.color ?? Colors.primary
272
- });
273
- }
274
- else {
275
- this.rect(bgConfig);
276
- this.text({
277
- x: bgConfig.x + AI_TABLE_CELL_PADDING,
278
- y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_TAG_FONT_SIZE) / 2,
279
- text: this.textEllipsis({
280
- text: item.text,
281
- maxWidth: bgWidth - baseWidth,
282
- fontSize: AI_TABLE_TAG_FONT_SIZE
283
- }).text,
284
- fillStyle: Colors.gray700,
285
- fontSize: AI_TABLE_TAG_FONT_SIZE
286
- });
287
- }
288
- const currentWidth = bgConfig.width;
289
- remainSpace -= currentWidth;
290
- currentX += currentWidth + AI_TABLE_CELL_MULTI_PADDING_LEFT;
291
- };
292
- switch (optionStyle) {
293
- case AITableSelectOptionStyle.dot:
294
- commonItem(AITableSelectOptionStyle.dot, 'arc');
295
- break;
296
- case AITableSelectOptionStyle.piece:
297
- commonItem(AITableSelectOptionStyle.piece, 'rect');
298
- break;
299
- case AITableSelectOptionStyle.tag:
300
- commonItem(AITableSelectOptionStyle.tag, '');
301
- break;
302
- default:
303
- commonItem(AITableSelectOptionStyle.text, '');
304
- break;
305
- }
306
- }
307
- if (circleWidth > 0) {
308
- if (optionStyle === AITableSelectOptionStyle.tag) {
309
- this.tag({
310
- x: currentX,
311
- y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_OPTION_ITEM_HEIGHT) / 2,
312
- width: circleWidth,
313
- height: AI_TABLE_OPTION_ITEM_HEIGHT,
314
- text: circleText,
315
- background: Colors.gray100,
316
- color: Colors.gray700,
317
- radius: AI_TABLE_OPTION_ITEM_RADIUS,
318
- padding: AI_TABLE_CELL_PADDING,
319
- fontSize: AI_TABLE_TAG_FONT_SIZE
320
- });
321
- }
322
- else {
323
- this.rect({
324
- x: currentX,
325
- y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_OPTION_ITEM_HEIGHT) / 2,
326
- width: circleWidth,
327
- height: AI_TABLE_OPTION_ITEM_HEIGHT,
328
- fill: Colors.gray100,
329
- radius: AI_TABLE_PIECE_RADIUS
330
- });
331
- this.text({
332
- x: currentX + AI_TABLE_CELL_PADDING,
333
- y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_TAG_FONT_SIZE) / 2,
334
- text: circleText,
335
- fillStyle: Colors.gray700,
336
- fontSize: AI_TABLE_TAG_FONT_SIZE
337
- });
338
- }
339
- }
340
- }
341
- renderSingleSelectCell(render, ctx) {
342
- const { x, y, field, columnWidth, isActive } = render;
343
- const transformValue = this.getValidSelectedValue(field, render.transformValue);
344
- if (!transformValue.length) {
345
- return;
346
- }
347
- if (!transformValue[0]) {
348
- console.warn(`single select field unexpected value: ${transformValue[0]}`);
349
- }
350
- const isOperating = isActive;
351
- const item = field.settings.options?.find((option) => option._id === transformValue[0]);
352
- const itemName = item?.text || '';
353
- const getTextEllipsis = (maxTextWidth, fontSize = AI_TABLE_COMMON_FONT_SIZE) => {
354
- maxTextWidth -= isOperating ? AI_TABLE_CELL_DELETE_ITEM_BUTTON_SIZE - AI_TABLE_CELL_DELETE_ITEM_BUTTON_SIZE_OFFSET : 0;
355
- return this.textEllipsis({
356
- text: itemName,
357
- maxWidth: columnWidth && maxTextWidth,
358
- fontSize: fontSize
359
- });
360
- };
361
- if (ctx) {
362
- ctx.save();
363
- ctx.globalAlpha = 1;
364
- const colors = AITable.getColors();
365
- const optionStyle = field.settings.option_style;
366
- let background = item?.bg_color ?? item?.color ?? colors.primary;
367
- const dotMaxTextWidth = columnWidth - 2 * AI_TABLE_CELL_PADDING - AI_TABLE_PIECE_WIDTH - AI_TABLE_TEXT_GAP;
368
- const borderWidth = 1;
369
- switch (optionStyle) {
370
- case AITableSelectOptionStyle.dot:
371
- // 这里的 AI_TABLE_OFFSET 偏移不确定是为啥(包括 piece 的),只是为了保持和编辑组件中的对齐
372
- this.arc({
373
- x: x + AI_TABLE_CELL_PADDING + AI_TABLE_DOT_RADIUS,
374
- y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_PIECE_WIDTH) / 2 + AI_TABLE_DOT_RADIUS - AI_TABLE_OFFSET,
375
- radius: AI_TABLE_DOT_RADIUS,
376
- fill: background
377
- });
378
- this.text({
379
- x: x + AI_TABLE_PIECE_WIDTH + AI_TABLE_TEXT_GAP + AI_TABLE_CELL_PADDING,
380
- y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_OPTION_ITEM_FONT_SIZE) / 2,
381
- text: getTextEllipsis(dotMaxTextWidth).text,
382
- fillStyle: colors.gray800
383
- });
384
- break;
385
- case AITableSelectOptionStyle.piece:
386
- this.rect({
387
- x: x + AI_TABLE_CELL_PADDING,
388
- y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_PIECE_WIDTH) / 2 - AI_TABLE_OFFSET,
389
- width: AI_TABLE_PIECE_WIDTH,
390
- height: AI_TABLE_PIECE_WIDTH,
391
- radius: AI_TABLE_PIECE_RADIUS,
392
- fill: background
393
- });
394
- this.text({
395
- x: x + AI_TABLE_PIECE_WIDTH + AI_TABLE_TEXT_GAP + AI_TABLE_CELL_PADDING,
396
- y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_OPTION_ITEM_FONT_SIZE) / 2,
397
- text: getTextEllipsis(dotMaxTextWidth).text,
398
- fillStyle: colors.gray800
399
- });
400
- break;
401
- case AITableSelectOptionStyle.tag:
402
- const maxTextWidth = columnWidth - 2 * (AI_TABLE_CELL_PADDING + AI_TABLE_TAG_PADDING);
403
- const { textWidth, text } = getTextEllipsis(maxTextWidth, AI_TABLE_TAG_FONT_SIZE);
404
- const width = Math.max(textWidth + 2 * AI_TABLE_TAG_PADDING, AI_TABLE_CELL_MULTI_ITEM_MIN_WIDTH);
405
- this.tag({
406
- x: x + AI_TABLE_CELL_PADDING,
407
- y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_OPTION_ITEM_HEIGHT) / 2,
408
- width,
409
- height: AI_TABLE_OPTION_ITEM_HEIGHT,
410
- text,
411
- background,
412
- color: colors.white,
413
- radius: AI_TABLE_OPTION_ITEM_RADIUS,
414
- padding: AI_TABLE_OPTION_ITEM_PADDING,
415
- fontSize: AI_TABLE_TAG_FONT_SIZE,
416
- stroke: background
417
- });
418
- break;
419
- default:
420
- const textMaxTextWidth = columnWidth - 2 * AI_TABLE_CELL_PADDING;
421
- this.text({
422
- x: x + AI_TABLE_CELL_PADDING,
423
- y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_OPTION_ITEM_FONT_SIZE) / 2,
424
- text: getTextEllipsis(textMaxTextWidth).text,
425
- fillStyle: colors.gray800
426
- });
427
- break;
428
- }
429
- ctx.restore();
430
- }
431
- }
432
- renderCellDate(render, ctx) {
433
- const { x, y, transformValue, columnWidth, style } = render;
434
- const colors = AITable.getColors();
435
- if (isNil(transformValue)) {
436
- return;
437
- }
438
- const textMaxWidth = columnWidth - 2 * AI_TABLE_CELL_PADDING;
439
- const { text } = this.textEllipsis({ text: transformValue, maxWidth: columnWidth && textMaxWidth });
440
- if (ctx) {
441
- const color = style?.color || colors.gray800;
442
- this.text({
443
- x: x + AI_TABLE_CELL_PADDING,
444
- y: y + AI_TABLE_ROW_BLANK_HEIGHT / 2,
445
- text,
446
- fillStyle: color,
447
- fontWeight: style?.fontWeight,
448
- verticalAlign: DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE
449
- });
450
- }
451
- }
452
- renderCellRate(render, ctx, columnWidth) {
453
- const { x, y, transformValue } = render;
454
- const max = AI_TABLE_RATE_MAX;
455
- const size = AI_TABLE_CELL_EMOJI_SIZE;
456
- const renderWidth = columnWidth - AI_TABLE_CELL_PADDING;
457
- const starWidth = AI_TABLE_CELL_EMOJI_SIZE + AI_TABLE_CELL_EMOJI_PADDING;
458
- const maxStar = Math.min(max, Math.floor(renderWidth / starWidth));
459
- return [...Array(maxStar).keys()].map((item, index) => {
460
- const value = index + 1;
461
- const checked = value <= (transformValue || 0);
462
- const iconX = index * size + AI_TABLE_CELL_PADDING + index * AI_TABLE_CELL_EMOJI_PADDING;
463
- const iconY = (AI_TABLE_ROW_BLANK_HEIGHT - size) / 2;
464
- if (ctx) {
465
- this.path({
466
- x: x + iconX,
467
- y: y + iconY,
468
- size: 22,
469
- data: StarFill,
470
- fill: checked ? this.colors.waring : this.colors.gray100,
471
- scaleX: 1.14,
472
- scaleY: 1.14
473
- });
474
- }
475
- });
476
- }
477
- renderCellProgress(render, ctx) {
478
- const { x, y, transformValue, columnWidth, style } = render;
479
- const colors = AITable.getColors();
480
- let validateTransformValue = transformValue;
481
- if (isNil(validateTransformValue)) {
482
- validateTransformValue = 0;
483
- }
484
- const width = columnWidth - 2 * AI_TABLE_CELL_PADDING - AI_TABLE_PROGRESS_TEXT_WIDTH;
485
- const height = AI_TABLE_PROGRESS_BAR_HEIGHT;
486
- const textHeight = AI_TABLE_COMMON_FONT_SIZE;
487
- const offsetX = AI_TABLE_CELL_PADDING;
488
- const offsetY = (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_PROGRESS_BAR_HEIGHT) / 2;
489
- const textOffsetY = (AI_TABLE_ROW_BLANK_HEIGHT - textHeight) / 2;
490
- // 绘制背景
491
- this.rect({
492
- x: x + offsetX,
493
- y: y + offsetY,
494
- width,
495
- height,
496
- radius: AI_TABLE_PROGRESS_BAR_RADIUS,
497
- fill: colors.gray200
498
- });
499
- // 计算并绘制进度
500
- const progressWidth = (validateTransformValue / 100) * width;
501
- this.rect({
502
- x: x + offsetX,
503
- y: y + offsetY,
504
- width: progressWidth,
505
- height,
506
- radius: AI_TABLE_PROGRESS_BAR_RADIUS,
507
- fill: colors.success
508
- });
509
- this.text({
510
- x: x + offsetX + width + AI_TABLE_TEXT_GAP,
511
- y: y + textOffsetY,
512
- text: `${validateTransformValue}%`,
513
- fillStyle: colors.gray800
514
- });
515
- }
516
- renderCellMember(render, ctx) {
517
- const { references, x, y, field, transformValue, rowHeight, columnWidth, isActive } = render;
518
- if (!transformValue?.length || !references) {
519
- return;
520
- }
521
- const settings = field.settings;
522
- const avatarSize = AI_TABLE_MEMBER_AVATAR_SIZE;
523
- const itemHeight = AI_TABLE_CELL_MEMBER_ITEM_HEIGHT;
524
- const isOperating = isActive;
525
- const isMultiple = settings?.is_multiple;
526
- let currentX = AI_TABLE_CELL_PADDING;
527
- let currentY = (AI_TABLE_ROW_BLANK_HEIGHT - avatarSize) / 2;
528
- const itemOtherWidth = avatarSize + AI_TABLE_MEMBER_ITEM_AVATAR_MARGIN_RIGHT;
529
- const maxHeight = isActive ? 130 - AI_TABLE_CELL_MULTI_PADDING_TOP : rowHeight - AI_TABLE_CELL_MULTI_PADDING_TOP;
530
- const maxTextWidth = isOperating
531
- ? columnWidth - 2 * AI_TABLE_CELL_PADDING - itemOtherWidth - AI_TABLE_CELL_DELETE_ITEM_BUTTON_SIZE - 12
532
- : columnWidth - 2 * AI_TABLE_CELL_PADDING - itemOtherWidth;
533
- const listCount = transformValue.length;
534
- let isOverflow = false;
535
- for (let index = 0; index < listCount; index++) {
536
- const userInfo = references?.members[transformValue[index]];
537
- if (!userInfo)
538
- continue;
539
- const { uid, display_name, avatar } = userInfo;
540
- const itemWidth = AITableAvatarSize.size24 + (isMultiple ? AI_TABLE_CELL_MEMBER_ITEM_PADDING : 0);
541
- currentX = AI_TABLE_CELL_PADDING + index * itemWidth;
542
- let realMaxTextWidth = maxTextWidth < 0 ? 0 : maxTextWidth;
543
- if (index === 0 && isOperating) {
544
- const operatingMaxWidth = maxTextWidth - (AI_TABLE_CELL_ADD_ITEM_BUTTON_SIZE + 4);
545
- // item No space to display, then perform a line feed
546
- if (operatingMaxWidth <= 20) {
547
- currentX = AI_TABLE_CELL_PADDING;
548
- currentY += AI_TABLE_OPTION_ITEM_HEIGHT + AI_TABLE_CELL_MULTI_ITEM_MARGIN_TOP;
549
- }
550
- else {
551
- realMaxTextWidth = operatingMaxWidth;
552
- }
553
- }
554
- let isMore = currentX + itemWidth > columnWidth - 2 * AI_TABLE_CELL_PADDING;
555
- if (columnWidth != null) {
556
- // 在非活动状态下,当超出列宽时,不会渲染后续内容
557
- if (currentX >= columnWidth - 2 * AI_TABLE_CELL_PADDING) {
558
- break;
559
- }
560
- // 如果不是非活动状态的最后一行,则换行渲染溢出内容
561
- if (currentX > columnWidth - 2 * AI_TABLE_CELL_PADDING) {
562
- currentX = AI_TABLE_CELL_PADDING;
563
- }
564
- if (currentX + itemWidth > columnWidth - AI_TABLE_CELL_PADDING) {
565
- currentX = AI_TABLE_CELL_PADDING;
566
- currentY += itemHeight;
567
- }
568
- if (currentY >= maxHeight) {
569
- isOverflow = true;
570
- }
571
- }
572
- if (ctx) {
573
- this.avatar({
574
- x: x + currentX,
575
- y: y + currentY,
576
- url: avatar,
577
- id: uid,
578
- title: getAvatarShortName(display_name),
579
- bgColor: getAvatarBgColor(display_name),
580
- type: AITableAvatarType.member,
581
- size: AITableAvatarSize.size24
582
- });
583
- // 在非多选模式下显示名称
584
- if (!isMultiple) {
585
- const textX = x + currentX + AITableAvatarSize.size24 + AI_TABLE_MEMBER_ITEM_AVATAR_MARGIN_RIGHT;
586
- this.text({
587
- x: textX,
588
- y: y + AI_TABLE_ROW_BLANK_HEIGHT / 2,
589
- text: this.textEllipsis({
590
- text: display_name || '',
591
- maxWidth: maxTextWidth,
592
- fontSize: AI_TABLE_COMMON_FONT_SIZE
593
- }).text,
594
- fillStyle: this.colors.gray800,
595
- fontSize: AI_TABLE_COMMON_FONT_SIZE,
596
- verticalAlign: DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE
597
- });
598
- }
599
- if (isMore) {
600
- ctx.save();
601
- ctx.globalAlpha = 0.3;
602
- this.rect({
603
- x: x + currentX,
604
- y: y + currentY,
605
- width: AITableAvatarSize.size24,
606
- height: AITableAvatarSize.size24,
607
- radius: 24,
608
- fill: this.colors.black
609
- });
610
- ctx.restore();
611
- this.text({
612
- x: x + currentX + FONT_SIZE_SM / 2,
613
- y: y + AI_TABLE_ROW_BLANK_HEIGHT / 2,
614
- fillStyle: this.colors.white,
615
- fontSize: FONT_SIZE_SM,
616
- text: `+${listCount - index - 1}`,
617
- verticalAlign: DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE
618
- });
619
- }
620
- }
621
- }
622
- }
623
- renderCellAttachment(render, ctx) {
624
- const { references, x, y, field, transformValue, rowHeight, columnWidth, isActive } = render;
625
- if (isNil(transformValue)) {
626
- return;
627
- }
628
- const fileIconSize = AI_TABLE_FILE_ICON_SIZE;
629
- const itemHeight = AI_TABLE_FILE_ICON_ITEM_HEIGHT;
630
- const isOperating = isActive;
631
- let currentX = AI_TABLE_CELL_PADDING;
632
- let currentY = (AI_TABLE_ROW_BLANK_HEIGHT - itemHeight) / 2;
633
- const itemOtherWidth = fileIconSize + AI_TABLE_FIELD_ITEM_MARGIN_RIGHT;
634
- const maxTextWidth = isOperating
635
- ? columnWidth - 2 * AI_TABLE_CELL_PADDING - itemOtherWidth - AI_TABLE_CELL_DELETE_ITEM_BUTTON_SIZE - 12
636
- : columnWidth - 2 * AI_TABLE_CELL_PADDING - itemOtherWidth;
637
- const listCount = transformValue.length;
638
- for (let index = 0; index < listCount; index++) {
639
- const attachmentInfo = references?.attachments[transformValue[index]];
640
- if (!attachmentInfo)
641
- continue;
642
- const { title, addition } = attachmentInfo;
643
- const itemWidth = AI_TABLE_FILE_ICON_SIZE + AI_TABLE_FIELD_ITEM_MARGIN_RIGHT;
644
- currentX = AI_TABLE_CELL_PADDING + index * itemWidth;
645
- let realMaxTextWidth = maxTextWidth < 0 ? 0 : maxTextWidth;
646
- if (index === 0 && isOperating) {
647
- const operatingMaxWidth = maxTextWidth - (AI_TABLE_CELL_ADD_ITEM_BUTTON_SIZE + 4);
648
- realMaxTextWidth = operatingMaxWidth;
649
- }
650
- if (columnWidth != null) {
651
- // 在非活动状态下,当超出列宽时,不会渲染后续内容
652
- if (currentX >= columnWidth - 2 * AI_TABLE_CELL_PADDING) {
653
- break;
654
- }
655
- }
656
- const svgString = getFileThumbnailSvgString(addition?.ext);
657
- const img = new Image();
658
- img.src = `data:image/svg+xml;charset=utf-8,${encodeURIComponent(svgString)}`;
659
- if (ctx) {
660
- this.image({
661
- name: img.src,
662
- x: x + currentX,
663
- y: y + currentY,
664
- url: img.src,
665
- width: AI_TABLE_FILE_ICON_SIZE,
666
- height: AI_TABLE_FILE_ICON_SIZE
667
- });
668
- }
669
- }
670
- }
671
- }
672
- export const cellDrawer = new CellDrawer();
673
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cell-drawer.js","sourceRoot":"","sources":["../../../../../packages/grid/src/renderer/drawers/cell-drawer.ts"],"names":[],"mappings":"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","sourcesContent":["import _, { isNil } 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_FIELD_ITEM_MARGIN_RIGHT,\n    AI_TABLE_FILE_ICON_ITEM_HEIGHT,\n    AI_TABLE_FILE_ICON_SIZE,\n    AI_TABLE_MEMBER_AVATAR_SIZE,\n    AI_TABLE_MEMBER_ITEM_AVATAR_MARGIN_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    AI_TABLE_RATE_MAX,\n    StarFill\n} from '../../constants';\nimport { AITable } from '../../core';\nimport { AITableField, AITableFieldType, AITableSelectOptionStyle, MemberSettings } from '@ai-table/utils';\nimport { AITableAvatarSize, AITableAvatarType, AITableRender, AITableSelectField } from '../../types';\nimport { FieldModelMap, getAvatarBgColor, getAvatarShortName, getTextWidth } from '../../utils';\nimport { Drawer } from './drawer';\nimport { helpers } from 'ngx-tethys/util';\nimport { getFileThumbnailSvgString } from '../../utils/file';\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, columnWidth: number) {\n        const { field, cellValue } = render;\n        const fieldType = field.type;\n        const fieldMethod = FieldModelMap[fieldType];\n        if (!fieldMethod.isValid(cellValue)) {\n            return;\n        }\n        switch (fieldType) {\n            case AITableFieldType.text:\n            case AITableFieldType.richText:\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, columnWidth);\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            case AITableFieldType.attachment:\n                return this.renderCellAttachment(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        if (isNil(transformValue)) {\n            return;\n        }\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 isSingleLine = true;\n        const isTextField = fieldType === AITableFieldType.text || fieldType === AITableFieldType.richText;\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 getValidSelectedValue(field: AITableField, transformValue: string[]) {\n        const fieldOptionsMap = helpers.keyBy((field as AITableSelectField).settings.options || [], '_id');\n        return (transformValue || []).filter((optionId: string) => !!fieldOptionsMap[optionId]);\n    }\n\n    private renderCellMultiSelect(render: AITableRender, ctx?: any) {\n        const { x, y, field, columnWidth } = render;\n        let transformValue = this.getValidSelectedValue(field, render.transformValue);\n        if (!transformValue.length) {\n            return;\n        }\n\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, field, columnWidth, isActive } = render;\n        const transformValue = this.getValidSelectedValue(field, render.transformValue);\n        if (!transformValue.length) {\n            return;\n        }\n        if (!transformValue[0]) {\n            console.warn(`single select field unexpected value: ${transformValue[0]}`);\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\n        if (isNil(transformValue)) {\n            return;\n        }\n\n        const textMaxWidth = columnWidth - 2 * AI_TABLE_CELL_PADDING;\n        const { text } = this.textEllipsis({ text: transformValue, 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, columnWidth: number) {\n        const { x, y, transformValue } = render;\n        const max = AI_TABLE_RATE_MAX;\n        const size = AI_TABLE_CELL_EMOJI_SIZE;\n\n        const renderWidth = columnWidth - AI_TABLE_CELL_PADDING;\n        const starWidth = AI_TABLE_CELL_EMOJI_SIZE + AI_TABLE_CELL_EMOJI_PADDING;\n        const maxStar = Math.min(max, Math.floor(renderWidth / starWidth));\n\n        return [...Array(maxStar).keys()].map((item, index) => {\n            const value = index + 1;\n            const checked = value <= (transformValue || 0);\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) {\n                this.path({\n                    x: x + iconX,\n                    y: y + iconY,\n                    size: 22,\n                    data: StarFill,\n                    fill: checked ? this.colors.waring : this.colors.gray100,\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        let validateTransformValue = transformValue;\n        if (isNil(validateTransformValue)) {\n            validateTransformValue = 0;\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 = (validateTransformValue / 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: `${validateTransformValue}%`,\n            fillStyle: colors.gray800\n        });\n    }\n\n    private renderCellMember(render: AITableRender, ctx?: CanvasRenderingContext2D | undefined) {\n        const { references, x, y, field, transformValue, rowHeight, columnWidth, isActive } = render;\n        if (!transformValue?.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 isMultiple = 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_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 = transformValue.length;\n        let isOverflow = false;\n\n        for (let index = 0; index < listCount; index++) {\n            const userInfo = references?.members[transformValue[index]];\n            if (!userInfo) continue;\n\n            const { uid, display_name, avatar } = userInfo;\n            const itemWidth = AITableAvatarSize.size24 + (isMultiple ? 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 (currentX >= columnWidth - 2 * AI_TABLE_CELL_PADDING) {\n                    break;\n                }\n                // 如果不是非活动状态的最后一行，则换行渲染溢出内容\n                if (currentX > columnWidth - 2 * AI_TABLE_CELL_PADDING) {\n                    currentX = AI_TABLE_CELL_PADDING;\n                }\n                if (currentX + itemWidth > columnWidth - AI_TABLE_CELL_PADDING) {\n                    currentX = AI_TABLE_CELL_PADDING;\n                    currentY += itemHeight;\n                }\n                if (currentY >= maxHeight) {\n                    isOverflow = true;\n                }\n            }\n\n            if (ctx) {\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                // 在非多选模式下显示名称\n                if (!isMultiple) {\n                    const textX = x + currentX + AITableAvatarSize.size24 + AI_TABLE_MEMBER_ITEM_AVATAR_MARGIN_RIGHT;\n                    this.text({\n                        x: textX,\n                        y: y + AI_TABLE_ROW_BLANK_HEIGHT / 2,\n                        text: this.textEllipsis({\n                            text: display_name || '',\n                            maxWidth: maxTextWidth,\n                            fontSize: AI_TABLE_COMMON_FONT_SIZE\n                        }).text,\n                        fillStyle: this.colors.gray800,\n                        fontSize: AI_TABLE_COMMON_FONT_SIZE,\n                        verticalAlign: DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE\n                    });\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    private renderCellAttachment(render: AITableRender, ctx?: CanvasRenderingContext2D | undefined) {\n        const { references, x, y, field, transformValue, rowHeight, columnWidth, isActive } = render;\n        if (isNil(transformValue)) {\n            return;\n        }\n\n        const fileIconSize = AI_TABLE_FILE_ICON_SIZE;\n        const itemHeight = AI_TABLE_FILE_ICON_ITEM_HEIGHT;\n        const isOperating = isActive;\n\n        let currentX = AI_TABLE_CELL_PADDING;\n        let currentY = (AI_TABLE_ROW_BLANK_HEIGHT - itemHeight) / 2;\n        const itemOtherWidth = fileIconSize + AI_TABLE_FIELD_ITEM_MARGIN_RIGHT;\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 = transformValue.length;\n        for (let index = 0; index < listCount; index++) {\n            const attachmentInfo = references?.attachments[transformValue[index]];\n            if (!attachmentInfo) continue;\n            const { title, addition } = attachmentInfo;\n            const itemWidth = AI_TABLE_FILE_ICON_SIZE + AI_TABLE_FIELD_ITEM_MARGIN_RIGHT;\n            currentX = AI_TABLE_CELL_PADDING + index * itemWidth;\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                realMaxTextWidth = operatingMaxWidth;\n            }\n            if (columnWidth != null) {\n                // 在非活动状态下，当超出列宽时，不会渲染后续内容\n                if (currentX >= columnWidth - 2 * AI_TABLE_CELL_PADDING) {\n                    break;\n                }\n            }\n            const svgString = getFileThumbnailSvgString(addition?.ext);\n            const img = new Image();\n            img.src = `data:image/svg+xml;charset=utf-8,${encodeURIComponent(svgString)}`;\n            if (ctx) {\n                this.image({\n                    name: img.src,\n                    x: x + currentX,\n                    y: y + currentY,\n                    url: img.src,\n                    width: AI_TABLE_FILE_ICON_SIZE,\n                    height: AI_TABLE_FILE_ICON_SIZE\n                });\n            }\n        }\n    }\n}\n\nexport const cellDrawer = new CellDrawer();\n"]}