@ai-table/grid 0.0.12 → 0.0.14

Sign up to get free protection for your applications and to get access to all the features.
Files changed (324) hide show
  1. package/angular-konva/components/container.component.d.ts +7 -0
  2. package/angular-konva/components/container.component.d.ts.map +1 -0
  3. package/angular-konva/components/container.token.d.ts +3 -0
  4. package/angular-konva/components/container.token.d.ts.map +1 -0
  5. package/angular-konva/components/index.d.ts +4 -0
  6. package/angular-konva/components/index.d.ts.map +1 -0
  7. package/angular-konva/components/shape.component.d.ts +61 -0
  8. package/angular-konva/components/shape.component.d.ts.map +1 -0
  9. package/angular-konva/components/stage.component.d.ts +40 -0
  10. package/angular-konva/components/stage.component.d.ts.map +1 -0
  11. package/angular-konva/index.d.ts +5 -0
  12. package/angular-konva/index.d.ts.map +1 -0
  13. package/angular-konva/interfaces/component.d.ts +49 -0
  14. package/angular-konva/interfaces/component.d.ts.map +1 -0
  15. package/angular-konva/interfaces/config.d.ts +26 -0
  16. package/angular-konva/interfaces/config.d.ts.map +1 -0
  17. package/angular-konva/interfaces/event-object.d.ts +7 -0
  18. package/angular-konva/interfaces/event-object.d.ts.map +1 -0
  19. package/angular-konva/interfaces/index.d.ts +5 -0
  20. package/angular-konva/interfaces/index.d.ts.map +1 -0
  21. package/angular-konva/interfaces/shape.d.ts +42 -0
  22. package/angular-konva/interfaces/shape.d.ts.map +1 -0
  23. package/angular-konva/utils/apply-node-props.d.ts +4 -0
  24. package/angular-konva/utils/apply-node-props.d.ts.map +1 -0
  25. package/angular-konva/utils/common.d.ts +8 -0
  26. package/angular-konva/utils/common.d.ts.map +1 -0
  27. package/angular-konva/utils/index.d.ts +5 -0
  28. package/angular-konva/utils/index.d.ts.map +1 -0
  29. package/angular-konva/utils/types.d.ts +4 -0
  30. package/angular-konva/utils/types.d.ts.map +1 -0
  31. package/angular-konva/utils/update-picture.d.ts +4 -0
  32. package/angular-konva/utils/update-picture.d.ts.map +1 -0
  33. package/components/cell-editors/abstract-cell-editor.component.d.ts +7 -5
  34. package/components/cell-editors/abstract-cell-editor.component.d.ts.map +1 -1
  35. package/components/cell-editors/cell-editor.scss +38 -25
  36. package/components/cell-editors/cell-editor.variables.scss +5 -0
  37. package/components/cell-editors/date/date-editor.component.d.ts.map +1 -1
  38. package/components/cell-editors/link/edit-link/edit-link.component.d.ts +33 -0
  39. package/components/cell-editors/link/edit-link/edit-link.component.d.ts.map +1 -0
  40. package/components/cell-editors/link/link-editor.component.d.ts +36 -0
  41. package/components/cell-editors/link/link-editor.component.d.ts.map +1 -0
  42. package/components/cell-editors/link/link-editor.component.scss +21 -0
  43. package/components/cell-editors/progress/progress-editor.component.d.ts +0 -1
  44. package/components/cell-editors/progress/progress-editor.component.d.ts.map +1 -1
  45. package/components/cell-editors/progress/progress-editor.component.scss +12 -4
  46. package/components/cell-editors/rating/rating-editor.component.d.ts +0 -1
  47. package/components/cell-editors/rating/rating-editor.component.d.ts.map +1 -1
  48. package/components/cell-editors/rating/rating-editor.component.scss +10 -0
  49. package/components/cell-editors/select/select-editor.component.d.ts +3 -4
  50. package/components/cell-editors/select/select-editor.component.d.ts.map +1 -1
  51. package/components/cell-editors/text/text-editor.component.d.ts +0 -1
  52. package/components/cell-editors/text/text-editor.component.d.ts.map +1 -1
  53. package/components/cell-views/select/option.component.d.ts.map +1 -1
  54. package/components/cell-views/select/option.scss +10 -0
  55. package/components/field-menu/field-menu.component.d.ts +8 -3
  56. package/components/field-menu/field-menu.component.d.ts.map +1 -1
  57. package/components/field-property-editor/field-property-editor.component.d.ts +4 -2
  58. package/components/field-property-editor/field-property-editor.component.d.ts.map +1 -1
  59. package/components/index.d.ts +3 -1
  60. package/components/index.d.ts.map +1 -1
  61. package/constants/colors.d.ts +18 -0
  62. package/constants/colors.d.ts.map +1 -0
  63. package/constants/grid.d.ts +17 -1
  64. package/constants/grid.d.ts.map +1 -1
  65. package/constants/icon.d.ts +19 -0
  66. package/constants/icon.d.ts.map +1 -0
  67. package/constants/index.d.ts +5 -1
  68. package/constants/index.d.ts.map +1 -1
  69. package/constants/table.d.ts +60 -0
  70. package/constants/table.d.ts.map +1 -0
  71. package/constants/text.d.ts +22 -0
  72. package/constants/text.d.ts.map +1 -0
  73. package/core/context.d.ts +14 -0
  74. package/core/context.d.ts.map +1 -0
  75. package/core/coordinate.d.ts +96 -0
  76. package/core/coordinate.d.ts.map +1 -0
  77. package/core/index.d.ts +3 -2
  78. package/core/index.d.ts.map +1 -1
  79. package/core/types/ai-table.d.ts +56 -0
  80. package/core/types/ai-table.d.ts.map +1 -0
  81. package/core/types/core.d.ts +29 -23
  82. package/core/types/core.d.ts.map +1 -1
  83. package/core/types/index.d.ts +1 -1
  84. package/core/types/index.d.ts.map +1 -1
  85. package/core/utils/common.d.ts +1 -2
  86. package/core/utils/common.d.ts.map +1 -1
  87. package/core/utils/field.d.ts +3 -1
  88. package/core/utils/field.d.ts.map +1 -1
  89. package/core/utils/index.d.ts +0 -1
  90. package/core/utils/index.d.ts.map +1 -1
  91. package/core/utils/queries.d.ts +5 -5
  92. package/core/utils/queries.d.ts.map +1 -1
  93. package/dom-grid.component.d.ts +11 -0
  94. package/dom-grid.component.d.ts.map +1 -0
  95. package/esm2022/angular-konva/components/container.component.mjs +29 -0
  96. package/esm2022/angular-konva/components/container.token.mjs +3 -0
  97. package/esm2022/angular-konva/components/index.mjs +4 -0
  98. package/esm2022/angular-konva/components/shape.component.mjs +142 -0
  99. package/esm2022/angular-konva/components/stage.component.mjs +123 -0
  100. package/esm2022/angular-konva/index.mjs +5 -0
  101. package/esm2022/angular-konva/interfaces/component.mjs +4 -0
  102. package/esm2022/angular-konva/interfaces/config.mjs +2 -0
  103. package/esm2022/angular-konva/interfaces/event-object.mjs +2 -0
  104. package/esm2022/angular-konva/interfaces/index.mjs +5 -0
  105. package/esm2022/angular-konva/interfaces/shape.mjs +42 -0
  106. package/esm2022/angular-konva/utils/apply-node-props.mjs +67 -0
  107. package/esm2022/angular-konva/utils/common.mjs +48 -0
  108. package/esm2022/angular-konva/utils/index.mjs +5 -0
  109. package/esm2022/angular-konva/utils/types.mjs +2 -0
  110. package/esm2022/angular-konva/utils/update-picture.mjs +7 -0
  111. package/esm2022/components/cell-editors/abstract-cell-editor.component.mjs +15 -7
  112. package/esm2022/components/cell-editors/date/date-editor.component.mjs +6 -3
  113. package/esm2022/components/cell-editors/link/edit-link/edit-link.component.mjs +66 -0
  114. package/esm2022/components/cell-editors/link/link-editor.component.mjs +117 -0
  115. package/esm2022/components/cell-editors/number/number-editor.component.mjs +2 -2
  116. package/esm2022/components/cell-editors/progress/progress-editor.component.mjs +3 -6
  117. package/esm2022/components/cell-editors/rating/rating-editor.component.mjs +4 -7
  118. package/esm2022/components/cell-editors/select/select-editor.component.mjs +19 -17
  119. package/esm2022/components/cell-editors/text/text-editor.component.mjs +10 -11
  120. package/esm2022/components/cell-views/select/option.component.mjs +6 -5
  121. package/esm2022/components/field-menu/field-menu.component.mjs +11 -8
  122. package/esm2022/components/field-property-editor/field-property-editor.component.mjs +17 -12
  123. package/esm2022/components/index.mjs +4 -2
  124. package/esm2022/constants/colors.mjs +18 -0
  125. package/esm2022/constants/editor.mjs +2 -3
  126. package/esm2022/constants/grid.mjs +22 -4
  127. package/esm2022/constants/icon.mjs +26 -0
  128. package/esm2022/constants/index.mjs +6 -2
  129. package/esm2022/constants/table.mjs +62 -0
  130. package/esm2022/constants/text.mjs +23 -0
  131. package/esm2022/core/context.mjs +25 -0
  132. package/esm2022/core/coordinate.mjs +222 -0
  133. package/esm2022/core/index.mjs +4 -3
  134. package/esm2022/core/types/ai-table.mjs +44 -0
  135. package/esm2022/core/types/core.mjs +6 -1
  136. package/esm2022/core/types/index.mjs +2 -2
  137. package/esm2022/core/utils/common.mjs +3 -20
  138. package/esm2022/core/utils/field.mjs +18 -5
  139. package/esm2022/core/utils/index.mjs +1 -2
  140. package/esm2022/core/utils/queries.mjs +4 -4
  141. package/esm2022/dom-grid.component.mjs +82 -0
  142. package/esm2022/grid-base.component.mjs +154 -0
  143. package/esm2022/grid.component.mjs +337 -160
  144. package/esm2022/public-api.mjs +9 -5
  145. package/esm2022/renderer/components/add-field-column.component.mjs +68 -0
  146. package/esm2022/renderer/components/cells.component.mjs +35 -0
  147. package/esm2022/renderer/components/field-head.component.mjs +130 -0
  148. package/esm2022/renderer/components/field-icon.component.mjs +66 -0
  149. package/esm2022/renderer/components/frozen-cells.component.mjs +36 -0
  150. package/esm2022/renderer/components/frozen-heads.component.mjs +117 -0
  151. package/esm2022/renderer/components/frozen-placeholder-cells.component.mjs +38 -0
  152. package/esm2022/renderer/components/heads.component.mjs +38 -0
  153. package/esm2022/renderer/components/hover-row-heads.component.mjs +107 -0
  154. package/esm2022/renderer/components/icon.component.mjs +80 -0
  155. package/esm2022/renderer/components/index.mjs +14 -0
  156. package/esm2022/renderer/components/other-rows.component.mjs +68 -0
  157. package/esm2022/renderer/components/placeholder-cells.component.mjs +33 -0
  158. package/esm2022/renderer/components/text.component.mjs +45 -0
  159. package/esm2022/renderer/creations/create-active-cell-border.mjs +68 -0
  160. package/esm2022/renderer/creations/create-cells.mjs +135 -0
  161. package/esm2022/renderer/creations/create-heads.mjs +45 -0
  162. package/esm2022/renderer/drawers/add-row-layout-drawer.mjs +97 -0
  163. package/esm2022/renderer/drawers/cell-drawer.mjs +587 -0
  164. package/esm2022/renderer/drawers/drawer.mjs +936 -0
  165. package/esm2022/renderer/drawers/layout-drawer.mjs +58 -0
  166. package/esm2022/renderer/drawers/record-row-layout-drawer.mjs +101 -0
  167. package/esm2022/renderer/index.mjs +4 -0
  168. package/esm2022/renderer/renderer.component.mjs +174 -0
  169. package/esm2022/services/event.service.mjs +120 -11
  170. package/esm2022/services/field.service.mjs +28 -5
  171. package/esm2022/services/index.mjs +4 -0
  172. package/esm2022/services/selection.service.mjs +8 -1
  173. package/esm2022/types/avatar.mjs +27 -0
  174. package/esm2022/types/canvas.mjs +2 -0
  175. package/esm2022/types/cell.mjs +2 -0
  176. package/esm2022/types/component-config.mjs +7 -0
  177. package/esm2022/types/field.mjs +1 -1
  178. package/esm2022/types/grid.mjs +16 -2
  179. package/esm2022/types/index.mjs +8 -2
  180. package/esm2022/types/layout.mjs +2 -0
  181. package/esm2022/types/row.mjs +6 -0
  182. package/esm2022/utils/build.mjs +39 -0
  183. package/esm2022/utils/cell.mjs +71 -0
  184. package/esm2022/utils/common.mjs +49 -0
  185. package/esm2022/utils/get-placeholder-cells.mjs +66 -0
  186. package/esm2022/utils/get-text-width.mjs +30 -0
  187. package/esm2022/utils/image-cache.mjs +57 -0
  188. package/esm2022/utils/index.mjs +12 -0
  189. package/esm2022/utils/os.mjs +16 -0
  190. package/esm2022/utils/position.mjs +48 -0
  191. package/esm2022/utils/style.mjs +25 -0
  192. package/esm2022/utils/text-measure.mjs +122 -0
  193. package/esm2022/utils/visible-range.mjs +38 -0
  194. package/fesm2022/ai-table-grid.mjs +5549 -690
  195. package/fesm2022/ai-table-grid.mjs.map +1 -1
  196. package/grid-base.component.d.ts +52 -0
  197. package/grid-base.component.d.ts.map +1 -0
  198. package/grid.component.d.ts +43 -40
  199. package/grid.component.d.ts.map +1 -1
  200. package/package.json +5 -2
  201. package/public-api.d.ts +8 -4
  202. package/public-api.d.ts.map +1 -1
  203. package/renderer/components/add-field-column.component.d.ts +16 -0
  204. package/renderer/components/add-field-column.component.d.ts.map +1 -0
  205. package/renderer/components/cells.component.d.ts +14 -0
  206. package/renderer/components/cells.component.d.ts.map +1 -0
  207. package/renderer/components/field-head.component.d.ts +73 -0
  208. package/renderer/components/field-head.component.d.ts.map +1 -0
  209. package/renderer/components/field-icon.component.d.ts +17 -0
  210. package/renderer/components/field-icon.component.d.ts.map +1 -0
  211. package/renderer/components/frozen-cells.component.d.ts +14 -0
  212. package/renderer/components/frozen-cells.component.d.ts.map +1 -0
  213. package/renderer/components/frozen-heads.component.d.ts +47 -0
  214. package/renderer/components/frozen-heads.component.d.ts.map +1 -0
  215. package/renderer/components/frozen-placeholder-cells.component.d.ts +22 -0
  216. package/renderer/components/frozen-placeholder-cells.component.d.ts.map +1 -0
  217. package/renderer/components/heads.component.d.ts +9 -0
  218. package/renderer/components/heads.component.d.ts.map +1 -0
  219. package/renderer/components/hover-row-heads.component.d.ts +11 -0
  220. package/renderer/components/hover-row-heads.component.d.ts.map +1 -0
  221. package/renderer/components/icon.component.d.ts +37 -0
  222. package/renderer/components/icon.component.d.ts.map +1 -0
  223. package/renderer/components/index.d.ts +14 -0
  224. package/renderer/components/index.d.ts.map +1 -0
  225. package/renderer/components/other-rows.component.d.ts +31 -0
  226. package/renderer/components/other-rows.component.d.ts.map +1 -0
  227. package/renderer/components/placeholder-cells.component.d.ts +22 -0
  228. package/renderer/components/placeholder-cells.component.d.ts.map +1 -0
  229. package/renderer/components/text.component.d.ts +99 -0
  230. package/renderer/components/text.component.d.ts.map +1 -0
  231. package/renderer/creations/create-active-cell-border.d.ts +7 -0
  232. package/renderer/creations/create-active-cell-border.d.ts.map +1 -0
  233. package/renderer/creations/create-cells.d.ts +8 -0
  234. package/renderer/creations/create-cells.d.ts.map +1 -0
  235. package/renderer/creations/create-heads.d.ts +3 -0
  236. package/renderer/creations/create-heads.d.ts.map +1 -0
  237. package/renderer/drawers/add-row-layout-drawer.d.ts +12 -0
  238. package/renderer/drawers/add-row-layout-drawer.d.ts.map +1 -0
  239. package/renderer/drawers/cell-drawer.d.ts +22 -0
  240. package/renderer/drawers/cell-drawer.d.ts.map +1 -0
  241. package/renderer/drawers/drawer.d.ts +136 -0
  242. package/renderer/drawers/drawer.d.ts.map +1 -0
  243. package/renderer/drawers/layout-drawer.d.ts +22 -0
  244. package/renderer/drawers/layout-drawer.d.ts.map +1 -0
  245. package/renderer/drawers/record-row-layout-drawer.d.ts +14 -0
  246. package/renderer/drawers/record-row-layout-drawer.d.ts.map +1 -0
  247. package/renderer/index.d.ts +4 -0
  248. package/renderer/index.d.ts.map +1 -0
  249. package/renderer/renderer.component.d.ts +64 -0
  250. package/renderer/renderer.component.d.ts.map +1 -0
  251. package/services/event.service.d.ts +17 -3
  252. package/services/event.service.d.ts.map +1 -1
  253. package/services/field.service.d.ts +5 -4
  254. package/services/field.service.d.ts.map +1 -1
  255. package/services/index.d.ts +4 -0
  256. package/services/index.d.ts.map +1 -0
  257. package/services/selection.service.d.ts.map +1 -1
  258. package/styles/styles.scss +71 -11
  259. package/types/avatar.d.ts +24 -0
  260. package/types/avatar.d.ts.map +1 -0
  261. package/types/canvas.d.ts +83 -0
  262. package/types/canvas.d.ts.map +1 -0
  263. package/types/cell.d.ts +43 -0
  264. package/types/cell.d.ts.map +1 -0
  265. package/types/component-config.d.ts +50 -0
  266. package/types/component-config.d.ts.map +1 -0
  267. package/types/field.d.ts +27 -1
  268. package/types/field.d.ts.map +1 -1
  269. package/types/grid.d.ts +81 -2
  270. package/types/grid.d.ts.map +1 -1
  271. package/types/index.d.ts +7 -1
  272. package/types/index.d.ts.map +1 -1
  273. package/types/layout.d.ts +11 -0
  274. package/types/layout.d.ts.map +1 -0
  275. package/types/row.d.ts +27 -0
  276. package/types/row.d.ts.map +1 -0
  277. package/utils/build.d.ts +5 -0
  278. package/utils/build.d.ts.map +1 -0
  279. package/utils/cell.d.ts +19 -0
  280. package/utils/cell.d.ts.map +1 -0
  281. package/utils/common.d.ts +20 -0
  282. package/utils/common.d.ts.map +1 -0
  283. package/utils/get-placeholder-cells.d.ts +16 -0
  284. package/utils/get-placeholder-cells.d.ts.map +1 -0
  285. package/utils/get-text-width.d.ts +9 -0
  286. package/utils/get-text-width.d.ts.map +1 -0
  287. package/utils/image-cache.d.ts +16 -0
  288. package/utils/image-cache.d.ts.map +1 -0
  289. package/utils/index.d.ts +12 -0
  290. package/utils/index.d.ts.map +1 -0
  291. package/utils/os.d.ts +4 -0
  292. package/utils/os.d.ts.map +1 -0
  293. package/utils/position.d.ts +20 -0
  294. package/utils/position.d.ts.map +1 -0
  295. package/utils/style.d.ts +4 -0
  296. package/utils/style.d.ts.map +1 -0
  297. package/utils/text-measure.d.ts +32 -0
  298. package/utils/text-measure.d.ts.map +1 -0
  299. package/utils/visible-range.d.ts +13 -0
  300. package/utils/visible-range.d.ts.map +1 -0
  301. package/components/cell-editors/link/number-editor.component.d.ts +0 -8
  302. package/components/cell-editors/link/number-editor.component.d.ts.map +0 -1
  303. package/constants/field.d.ts +0 -20
  304. package/constants/field.d.ts.map +0 -1
  305. package/core/action/field.d.ts +0 -12
  306. package/core/action/field.d.ts.map +0 -1
  307. package/core/action/general.d.ts +0 -5
  308. package/core/action/general.d.ts.map +0 -1
  309. package/core/action/index.d.ts +0 -12
  310. package/core/action/index.d.ts.map +0 -1
  311. package/core/action/record.d.ts +0 -12
  312. package/core/action/record.d.ts.map +0 -1
  313. package/core/types/action.d.ts +0 -64
  314. package/core/types/action.d.ts.map +0 -1
  315. package/core/utils/weak-map.d.ts +0 -3
  316. package/core/utils/weak-map.d.ts.map +0 -1
  317. package/esm2022/components/cell-editors/link/number-editor.component.mjs +0 -25
  318. package/esm2022/constants/field.mjs +0 -25
  319. package/esm2022/core/action/field.mjs +0 -57
  320. package/esm2022/core/action/general.mjs +0 -116
  321. package/esm2022/core/action/index.mjs +0 -9
  322. package/esm2022/core/action/record.mjs +0 -44
  323. package/esm2022/core/types/action.mjs +0 -18
  324. package/esm2022/core/utils/weak-map.mjs +0 -2
@@ -0,0 +1,587 @@
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
+ const isValid = transformValue && Array.isArray(transformValue);
324
+ if (!isValid || transformValue.length === 0) {
325
+ return;
326
+ }
327
+ const isOperating = isActive;
328
+ const item = field.settings.options?.find((option) => option._id === transformValue[0]);
329
+ const itemName = item?.text || '';
330
+ const getTextEllipsis = (maxTextWidth, fontSize = AI_TABLE_COMMON_FONT_SIZE) => {
331
+ maxTextWidth -= isOperating ? AI_TABLE_CELL_DELETE_ITEM_BUTTON_SIZE - AI_TABLE_CELL_DELETE_ITEM_BUTTON_SIZE_OFFSET : 0;
332
+ return this.textEllipsis({
333
+ text: itemName,
334
+ maxWidth: columnWidth && maxTextWidth,
335
+ fontSize: fontSize
336
+ });
337
+ };
338
+ if (ctx) {
339
+ ctx.save();
340
+ ctx.globalAlpha = 1;
341
+ const colors = AITable.getColors();
342
+ const optionStyle = field.settings.option_style;
343
+ let background = item?.bg_color ?? item?.color ?? colors.primary;
344
+ const dotMaxTextWidth = columnWidth - 2 * AI_TABLE_CELL_PADDING - AI_TABLE_PIECE_WIDTH - AI_TABLE_TEXT_GAP;
345
+ const borderWidth = 1;
346
+ switch (optionStyle) {
347
+ case AITableSelectOptionStyle.dot:
348
+ // 这里的 AI_TABLE_OFFSET 偏移不确定是为啥(包括 piece 的),只是为了保持和编辑组件中的对齐
349
+ this.arc({
350
+ x: x + AI_TABLE_CELL_PADDING + AI_TABLE_DOT_RADIUS,
351
+ y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_PIECE_WIDTH) / 2 + AI_TABLE_DOT_RADIUS - AI_TABLE_OFFSET,
352
+ radius: AI_TABLE_DOT_RADIUS,
353
+ fill: background
354
+ });
355
+ this.text({
356
+ x: x + AI_TABLE_PIECE_WIDTH + AI_TABLE_TEXT_GAP + AI_TABLE_CELL_PADDING,
357
+ y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_OPTION_ITEM_FONT_SIZE) / 2,
358
+ text: getTextEllipsis(dotMaxTextWidth).text,
359
+ fillStyle: colors.gray800
360
+ });
361
+ break;
362
+ case AITableSelectOptionStyle.piece:
363
+ this.rect({
364
+ x: x + AI_TABLE_CELL_PADDING,
365
+ y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_PIECE_WIDTH) / 2 - AI_TABLE_OFFSET,
366
+ width: AI_TABLE_PIECE_WIDTH,
367
+ height: AI_TABLE_PIECE_WIDTH,
368
+ radius: AI_TABLE_PIECE_RADIUS,
369
+ fill: background
370
+ });
371
+ this.text({
372
+ x: x + AI_TABLE_PIECE_WIDTH + AI_TABLE_TEXT_GAP + AI_TABLE_CELL_PADDING,
373
+ y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_OPTION_ITEM_FONT_SIZE) / 2,
374
+ text: getTextEllipsis(dotMaxTextWidth).text,
375
+ fillStyle: colors.gray800
376
+ });
377
+ break;
378
+ case AITableSelectOptionStyle.tag:
379
+ const maxTextWidth = columnWidth - 2 * (AI_TABLE_CELL_PADDING + AI_TABLE_TAG_PADDING);
380
+ const { textWidth, text } = getTextEllipsis(maxTextWidth, AI_TABLE_TAG_FONT_SIZE);
381
+ const width = Math.max(textWidth + 2 * AI_TABLE_TAG_PADDING, AI_TABLE_CELL_MULTI_ITEM_MIN_WIDTH);
382
+ this.tag({
383
+ x: x + AI_TABLE_CELL_PADDING,
384
+ y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_OPTION_ITEM_HEIGHT) / 2,
385
+ width,
386
+ height: AI_TABLE_OPTION_ITEM_HEIGHT,
387
+ text,
388
+ background,
389
+ color: colors.white,
390
+ radius: AI_TABLE_OPTION_ITEM_RADIUS,
391
+ padding: AI_TABLE_OPTION_ITEM_PADDING,
392
+ fontSize: AI_TABLE_TAG_FONT_SIZE,
393
+ stroke: background
394
+ });
395
+ break;
396
+ default:
397
+ const textMaxTextWidth = columnWidth - 2 * AI_TABLE_CELL_PADDING;
398
+ this.text({
399
+ x: x + AI_TABLE_CELL_PADDING,
400
+ y: y + (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_OPTION_ITEM_FONT_SIZE) / 2,
401
+ text: getTextEllipsis(textMaxTextWidth).text,
402
+ fillStyle: colors.gray800
403
+ });
404
+ break;
405
+ }
406
+ ctx.restore();
407
+ }
408
+ }
409
+ renderCellDate(render, ctx) {
410
+ const { x, y, transformValue, columnWidth, style } = render;
411
+ const colors = AITable.getColors();
412
+ let cellText = transformValue;
413
+ if (cellText == null || !_.isString(cellText)) {
414
+ return;
415
+ }
416
+ const textMaxWidth = columnWidth - 2 * AI_TABLE_CELL_PADDING;
417
+ const { text } = this.textEllipsis({ text: cellText, maxWidth: columnWidth && textMaxWidth });
418
+ if (ctx) {
419
+ const color = style?.color || colors.gray800;
420
+ this.text({
421
+ x: x + AI_TABLE_CELL_PADDING,
422
+ y: y + AI_TABLE_ROW_BLANK_HEIGHT / 2,
423
+ text,
424
+ fillStyle: color,
425
+ fontWeight: style?.fontWeight,
426
+ verticalAlign: DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE
427
+ });
428
+ }
429
+ }
430
+ renderCellRate(render, ctx) {
431
+ const { x, y, transformValue: _cellValue } = render;
432
+ const max = 5;
433
+ const cellValue = _cellValue || 0;
434
+ const size = AI_TABLE_CELL_EMOJI_SIZE;
435
+ return [...Array(max).keys()].map((item, index) => {
436
+ const value = index + 1;
437
+ const checked = value <= cellValue;
438
+ const iconX = index * size + AI_TABLE_CELL_PADDING + index * AI_TABLE_CELL_EMOJI_PADDING;
439
+ const iconY = (AI_TABLE_ROW_BLANK_HEIGHT - size) / 2;
440
+ if (ctx && checked) {
441
+ this.path({
442
+ x: x + iconX,
443
+ y: y + iconY,
444
+ size: 22,
445
+ data: StarFill,
446
+ fill: this.colors.waring,
447
+ scaleX: 1.14,
448
+ scaleY: 1.14
449
+ });
450
+ }
451
+ });
452
+ }
453
+ renderCellProgress(render, ctx) {
454
+ const { x, y, transformValue, columnWidth, style } = render;
455
+ const colors = AITable.getColors();
456
+ const cellText = transformValue;
457
+ if (cellText == null || !_.isNumber(cellText)) {
458
+ return;
459
+ }
460
+ const width = columnWidth - 2 * AI_TABLE_CELL_PADDING - AI_TABLE_PROGRESS_TEXT_Width;
461
+ const height = AI_TABLE_PROGRESS_BAR_HEIGHT;
462
+ const textHeight = AI_TABLE_COMMON_FONT_SIZE;
463
+ const offsetX = AI_TABLE_CELL_PADDING;
464
+ const offsetY = (AI_TABLE_ROW_BLANK_HEIGHT - AI_TABLE_PROGRESS_BAR_HEIGHT) / 2;
465
+ const textOffsetY = (AI_TABLE_ROW_BLANK_HEIGHT - textHeight) / 2;
466
+ // 绘制背景
467
+ this.rect({
468
+ x: x + offsetX,
469
+ y: y + offsetY,
470
+ width,
471
+ height,
472
+ radius: AI_TABLE_PROGRESS_BAR_RADIUS,
473
+ fill: colors.gray200
474
+ });
475
+ // 计算并绘制进度
476
+ const progressWidth = (transformValue / 100) * width;
477
+ this.rect({
478
+ x: x + offsetX,
479
+ y: y + offsetY,
480
+ width: progressWidth,
481
+ height,
482
+ radius: AI_TABLE_PROGRESS_BAR_RADIUS,
483
+ fill: colors.success
484
+ });
485
+ this.text({
486
+ x: x + offsetX + width + AI_TABLE_TEXT_GAP,
487
+ y: y + textOffsetY,
488
+ text: `${transformValue}%`,
489
+ fillStyle: colors.gray800
490
+ });
491
+ }
492
+ renderCellMember(render, ctx) {
493
+ const { references, x, y, field, transformValue: _cellValue, rowHeight, columnWidth, isActive } = render;
494
+ const cellValue = _cellValue;
495
+ if (!cellValue?.length || !references) {
496
+ return;
497
+ }
498
+ const settings = field.settings;
499
+ const avatarSize = AI_TABLE_MEMBER_AVATAR_SIZE;
500
+ const itemHeight = AI_TABLE_CELL_MEMBER_ITEM_HEIGHT;
501
+ const isOperating = isActive;
502
+ const isMulti = settings?.is_multiple;
503
+ let currentX = AI_TABLE_CELL_PADDING;
504
+ let currentY = (AI_TABLE_ROW_BLANK_HEIGHT - avatarSize) / 2;
505
+ const itemOtherWidth = avatarSize + AI_TABLE_MEMBER_ITEM_PADDING_RIGHT + AI_TABLE_MEMBER_ITEM_AVATAR_MARGIN_RIGHT;
506
+ const maxHeight = isActive ? 130 - AI_TABLE_CELL_MULTI_PADDING_TOP : rowHeight - AI_TABLE_CELL_MULTI_PADDING_TOP;
507
+ const maxTextWidth = isOperating
508
+ ? columnWidth - 2 * AI_TABLE_CELL_PADDING - itemOtherWidth - AI_TABLE_CELL_DELETE_ITEM_BUTTON_SIZE - 12
509
+ : columnWidth - 2 * AI_TABLE_CELL_PADDING - itemOtherWidth;
510
+ const listCount = cellValue.length;
511
+ let isOverflow = false;
512
+ for (let index = 0; index < listCount; index++) {
513
+ const userInfo = references?.members[cellValue[index]];
514
+ if (!userInfo)
515
+ continue;
516
+ const { uid, display_name, avatar } = userInfo;
517
+ const type = AITableMemberType.member;
518
+ const itemWidth = AITableAvatarSize.size24 + (isMulti ? AI_TABLE_CELL_MEMBER_ITEM_PADDING : 0);
519
+ currentX = AI_TABLE_CELL_PADDING + index * itemWidth;
520
+ let realMaxTextWidth = maxTextWidth < 0 ? 0 : maxTextWidth;
521
+ if (index === 0 && isOperating) {
522
+ const operatingMaxWidth = maxTextWidth - (AI_TABLE_CELL_ADD_ITEM_BUTTON_SIZE + 4);
523
+ // item No space to display, then perform a line feed
524
+ if (operatingMaxWidth <= 20) {
525
+ currentX = AI_TABLE_CELL_PADDING;
526
+ currentY += AI_TABLE_OPTION_ITEM_HEIGHT + AI_TABLE_CELL_MULTI_ITEM_MARGIN_TOP;
527
+ }
528
+ else {
529
+ realMaxTextWidth = operatingMaxWidth;
530
+ }
531
+ }
532
+ let isMore = currentX + itemWidth > columnWidth - 2 * AI_TABLE_CELL_PADDING;
533
+ if (columnWidth != null) {
534
+ // 在非活动状态下,当超出列宽时,不会渲染后续内容
535
+ if (!isActive && currentX >= columnWidth - 2 * AI_TABLE_CELL_PADDING) {
536
+ break;
537
+ }
538
+ // 如果不是非活动状态的最后一行,则换行渲染溢出内容
539
+ if (!isActive && currentX > columnWidth - 2 * AI_TABLE_CELL_PADDING) {
540
+ currentX = AI_TABLE_CELL_PADDING;
541
+ }
542
+ if (isActive && currentX + itemWidth > columnWidth - AI_TABLE_CELL_PADDING) {
543
+ currentX = AI_TABLE_CELL_PADDING;
544
+ currentY += itemHeight;
545
+ }
546
+ if (isActive && currentY >= maxHeight) {
547
+ isOverflow = true;
548
+ }
549
+ }
550
+ if (ctx && !isActive) {
551
+ this.avatar({
552
+ x: x + currentX,
553
+ y: y + currentY,
554
+ url: avatar,
555
+ id: uid,
556
+ title: getAvatarShortName(display_name),
557
+ bgColor: getAvatarBgColor(display_name),
558
+ type: AITableAvatarType.member,
559
+ size: AITableAvatarSize.size24
560
+ });
561
+ if (isMore) {
562
+ ctx.save();
563
+ ctx.globalAlpha = 0.3;
564
+ this.rect({
565
+ x: x + currentX,
566
+ y: y + currentY,
567
+ width: AITableAvatarSize.size24,
568
+ height: AITableAvatarSize.size24,
569
+ radius: 24,
570
+ fill: this.colors.black
571
+ });
572
+ ctx.restore();
573
+ this.text({
574
+ x: x + currentX + FONT_SIZE_SM / 2,
575
+ y: y + AI_TABLE_ROW_BLANK_HEIGHT / 2,
576
+ fillStyle: this.colors.white,
577
+ fontSize: FONT_SIZE_SM,
578
+ text: `+${listCount - index - 1}`,
579
+ verticalAlign: DEFAULT_TEXT_VERTICAL_ALIGN_MIDDLE
580
+ });
581
+ }
582
+ }
583
+ }
584
+ }
585
+ }
586
+ export const cellDrawer = new CellDrawer();
587
+ //# 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 _ 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        const isValid = transformValue && Array.isArray(transformValue);\n        if (!isValid || transformValue.length === 0) {\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"]}