@ant-design/agentic-ui 2.8.0 → 2.10.0

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 (585) hide show
  1. package/dist/AgentRunBar/Robot.js +105 -57
  2. package/dist/AgentRunBar/icons/PauseIcon.js +38 -38
  3. package/dist/AgentRunBar/icons/PlayIcon.js +38 -38
  4. package/dist/AgentRunBar/icons/SimplePauseIcon.js +38 -38
  5. package/dist/AgentRunBar/icons/SimplePlayIcon.js +38 -38
  6. package/dist/AgentRunBar/icons/SimpleStopIcon.js +38 -38
  7. package/dist/AgentRunBar/icons/StopIcon.js +41 -50
  8. package/dist/AgentRunBar/icons/index.js +0 -1
  9. package/dist/AgentRunBar/index.js +270 -237
  10. package/dist/AgentRunBar/style.js +273 -239
  11. package/dist/AgenticLayout/index.js +140 -85
  12. package/dist/AgenticLayout/style.js +126 -107
  13. package/dist/AnswerAlert/components/CloseIcon.js +12 -21
  14. package/dist/AnswerAlert/components/ErrorIcon.js +42 -38
  15. package/dist/AnswerAlert/components/InfoIcon.js +42 -38
  16. package/dist/AnswerAlert/components/LoaderIcon.js +12 -21
  17. package/dist/AnswerAlert/components/SuccessIcon.js +42 -38
  18. package/dist/AnswerAlert/components/WarningIcon.js +42 -38
  19. package/dist/AnswerAlert/index.js +155 -75
  20. package/dist/AnswerAlert/style.js +159 -147
  21. package/dist/BackTo/BackBottom.js +154 -70
  22. package/dist/BackTo/BackTop.js +148 -68
  23. package/dist/BackTo/ScrollVisibleButton.js +124 -98
  24. package/dist/BackTo/hooks/useScrollVisible.js +79 -33
  25. package/dist/BackTo/icons/BottomIcon.js +37 -37
  26. package/dist/BackTo/icons/TopIcon.js +37 -37
  27. package/dist/BackTo/index.js +22 -7
  28. package/dist/BackTo/style.js +93 -70
  29. package/dist/Bubble/AIBubble.js +469 -406
  30. package/dist/Bubble/Avatar/index.js +139 -85
  31. package/dist/Bubble/Avatar/isEmoji.js +2 -6
  32. package/dist/Bubble/Bubble.js +114 -38
  33. package/dist/Bubble/BubbleBeforeNode.js +104 -74
  34. package/dist/Bubble/BubbleConfigProvide.js +3 -7
  35. package/dist/Bubble/FileView.js +63 -69
  36. package/dist/Bubble/List/PureBubbleList.js +130 -131
  37. package/dist/Bubble/List/SkeletonList.js +33 -24
  38. package/dist/Bubble/List/index.js +187 -124
  39. package/dist/Bubble/List/style.js +76 -47
  40. package/dist/Bubble/MessagesContent/BubbleContext.js +6 -12
  41. package/dist/Bubble/MessagesContent/BubbleExtra.js +663 -355
  42. package/dist/Bubble/MessagesContent/CopyButton/index.js +326 -96
  43. package/dist/Bubble/MessagesContent/DocInfo.js +351 -386
  44. package/dist/Bubble/MessagesContent/EXCEPTION.js +42 -22
  45. package/dist/Bubble/MessagesContent/MarkdownPreview.js +206 -156
  46. package/dist/Bubble/MessagesContent/VoiceButton/index.js +213 -115
  47. package/dist/Bubble/MessagesContent/VoiceButton/style.js +129 -105
  48. package/dist/Bubble/MessagesContent/VoiceButton/types.js +9 -0
  49. package/dist/Bubble/MessagesContent/docInfoStyle.js +118 -88
  50. package/dist/Bubble/MessagesContent/icons.js +157 -57
  51. package/dist/Bubble/MessagesContent/index.js +609 -368
  52. package/dist/Bubble/PureBubble.js +439 -326
  53. package/dist/Bubble/Title.js +110 -87
  54. package/dist/Bubble/UserBubble.js +218 -279
  55. package/dist/Bubble/index.js +10 -16
  56. package/dist/Bubble/style.js +248 -227
  57. package/dist/Bubble/type.js +3 -0
  58. package/dist/Bubble/types/BubbleExtra.js +1 -0
  59. package/dist/Bubble/types/DocInfo.js +1 -0
  60. package/dist/ChatBootPage/ButtonTab.js +25 -45
  61. package/dist/ChatBootPage/ButtonTabGroup.js +74 -47
  62. package/dist/ChatBootPage/ButtonTabGroupStyle.js +73 -45
  63. package/dist/ChatBootPage/ButtonTabStyle.js +121 -98
  64. package/dist/ChatBootPage/CaseReply.js +119 -113
  65. package/dist/ChatBootPage/CaseReplyStyle.js +217 -189
  66. package/dist/ChatBootPage/Title.js +19 -23
  67. package/dist/ChatBootPage/index.js +9 -11
  68. package/dist/ChatBootPage/style.js +80 -50
  69. package/dist/ChatLayout/index.js +93 -57
  70. package/dist/ChatLayout/style.js +206 -176
  71. package/dist/ChatLayout/types.js +1 -0
  72. package/dist/Components/ActionIconBox/index.js +571 -197
  73. package/dist/Components/ActionIconBox/style.js +141 -111
  74. package/dist/Components/ActionItemBox/ActionItemBox.js +95 -149
  75. package/dist/Components/ActionItemBox/index.js +7 -7
  76. package/dist/Components/ActionItemBox/style.js +353 -361
  77. package/dist/Components/Button/IconButton/index.js +35 -43
  78. package/dist/Components/Button/IconButton/style.js +357 -331
  79. package/dist/Components/Button/SwitchButton/index.js +243 -87
  80. package/dist/Components/Button/SwitchButton/style.js +160 -146
  81. package/dist/Components/Button/ToggleButton/index.js +46 -57
  82. package/dist/Components/Button/ToggleButton/style.js +283 -258
  83. package/dist/Components/Button/index.js +6 -2
  84. package/dist/Components/GradientText/index.js +21 -27
  85. package/dist/Components/GradientText/style.js +88 -63
  86. package/dist/Components/ImageList.js +111 -133
  87. package/dist/Components/LayoutHeader/index.js +145 -81
  88. package/dist/Components/LayoutHeader/style.js +89 -64
  89. package/dist/Components/LayoutHeader/types.js +3 -0
  90. package/dist/Components/Loading/index.js +53 -22
  91. package/dist/Components/Robot/index.js +90 -56
  92. package/dist/Components/Robot/lotties/DazingLottie/index.js +78 -47
  93. package/dist/Components/Robot/lotties/ThinkingLottie/index.js +78 -47
  94. package/dist/Components/Robot/lotties/index.js +0 -1
  95. package/dist/Components/SuggestionList/index.js +354 -182
  96. package/dist/Components/SuggestionList/style.js +204 -186
  97. package/dist/Components/TextAnimate/index.js +494 -362
  98. package/dist/Components/TextAnimate/style.js +72 -48
  99. package/dist/Components/TypingAnimation/index.js +214 -169
  100. package/dist/Components/TypingAnimation/style.js +76 -52
  101. package/dist/Components/VisualList/index.js +267 -180
  102. package/dist/Components/VisualList/style.js +140 -124
  103. package/dist/Components/icons/LoadingSpinnerIcon.js +124 -73
  104. package/dist/Components/lotties/DazingLottie/index.js +78 -47
  105. package/dist/Components/lotties/LoadingLottie/index.js +82 -48
  106. package/dist/Components/lotties/TextLoading/index.js +73 -49
  107. package/dist/Components/lotties/TextLoading/style.js +95 -78
  108. package/dist/Components/lotties/ThinkingLottie/index.js +78 -47
  109. package/dist/Components/lotties/index.js +0 -1
  110. package/dist/Constants/colors.js +71 -97
  111. package/dist/History/components/HistoryActionsBox.js +407 -180
  112. package/dist/History/components/HistoryEmpty.js +38 -42
  113. package/dist/History/components/HistoryEmptyIcon.js +682 -964
  114. package/dist/History/components/HistoryItem.js +683 -471
  115. package/dist/History/components/HistoryList.js +170 -87
  116. package/dist/History/components/HistoryRunningIcon.js +160 -111
  117. package/dist/History/components/LoadMoreComponent.js +308 -103
  118. package/dist/History/components/NewChatComponent.js +261 -69
  119. package/dist/History/components/NewChatComponent.style.js +79 -53
  120. package/dist/History/components/SearchComponent.js +367 -156
  121. package/dist/History/components/index.js +11 -23
  122. package/dist/History/hooks/useHistory.js +404 -129
  123. package/dist/History/index.js +301 -186
  124. package/dist/History/menu.js +158 -212
  125. package/dist/History/style.js +282 -276
  126. package/dist/History/types/HistoryData.js +6 -10
  127. package/dist/History/types/HistoryList.js +3 -0
  128. package/dist/History/types/index.js +3 -0
  129. package/dist/History/utils/index.js +35 -32
  130. package/dist/Hooks/useAutoScroll.js +262 -84
  131. package/dist/Hooks/useClickAway.js +60 -21
  132. package/dist/Hooks/useCopied.js +72 -20
  133. package/dist/Hooks/useDebounceFn/index.js +213 -55
  134. package/dist/Hooks/useIntersectionOnce.js +163 -74
  135. package/dist/Hooks/useLanguage.d.ts +3 -0
  136. package/dist/Hooks/useLanguage.js +67 -26
  137. package/dist/Hooks/useRefFunction/index.js +76 -11
  138. package/dist/Hooks/useSpeechSynthesis.js +143 -99
  139. package/dist/Hooks/useStyle/index.js +95 -60
  140. package/dist/Hooks/useThrottleFn/index.js +41 -41
  141. package/dist/I18n/index.js +246 -109
  142. package/dist/I18n/locales.d.ts +3 -0
  143. package/dist/I18n/locales.js +724 -711
  144. package/dist/Icons/animated/VoicePlayLottie/index.js +75 -46
  145. package/dist/Icons/animated/VoicingLottie/index.js +78 -47
  146. package/dist/MarkdownEditor/BaseMarkdownEditor.js +421 -349
  147. package/dist/MarkdownEditor/editor/Editor.js +1160 -843
  148. package/dist/MarkdownEditor/editor/components/CommentList/index.js +407 -239
  149. package/dist/MarkdownEditor/editor/components/CommentList/style.js +119 -89
  150. package/dist/MarkdownEditor/editor/components/ContributorAvatar/index.js +61 -63
  151. package/dist/MarkdownEditor/editor/components/ContributorAvatar/style.js +82 -52
  152. package/dist/MarkdownEditor/editor/components/LazyElement/index.js +208 -106
  153. package/dist/MarkdownEditor/editor/components/LazyElement/style.js +69 -42
  154. package/dist/MarkdownEditor/editor/components/fntTag/index.js +7 -11
  155. package/dist/MarkdownEditor/editor/components/fntTag/style.js +66 -36
  156. package/dist/MarkdownEditor/editor/components/index.js +0 -1
  157. package/dist/MarkdownEditor/editor/elements/Blockquote.js +95 -37
  158. package/dist/MarkdownEditor/editor/elements/Break.js +56 -25
  159. package/dist/MarkdownEditor/editor/elements/Card/index.js +131 -52
  160. package/dist/MarkdownEditor/editor/elements/Code.js +89 -67
  161. package/dist/MarkdownEditor/editor/elements/Comment/index.js +79 -50
  162. package/dist/MarkdownEditor/editor/elements/ErrorBoundary.js +117 -21
  163. package/dist/MarkdownEditor/editor/elements/FootnoteDefinition.js +83 -64
  164. package/dist/MarkdownEditor/editor/elements/FootnoteReference.js +115 -41
  165. package/dist/MarkdownEditor/editor/elements/Head.js +131 -67
  166. package/dist/MarkdownEditor/editor/elements/Hr.js +63 -38
  167. package/dist/MarkdownEditor/editor/elements/Image/index.js +636 -494
  168. package/dist/MarkdownEditor/editor/elements/InlineKatex.js +60 -44
  169. package/dist/MarkdownEditor/editor/elements/Katex.js +71 -55
  170. package/dist/MarkdownEditor/editor/elements/LinkCard/index.js +79 -175
  171. package/dist/MarkdownEditor/editor/elements/LinkCard/style.js +130 -100
  172. package/dist/MarkdownEditor/editor/elements/List/List.js +96 -69
  173. package/dist/MarkdownEditor/editor/elements/List/ListItem.js +422 -247
  174. package/dist/MarkdownEditor/editor/elements/List/index.js +1 -5
  175. package/dist/MarkdownEditor/editor/elements/List/style.js +131 -117
  176. package/dist/MarkdownEditor/editor/elements/Media.js +637 -519
  177. package/dist/MarkdownEditor/editor/elements/Mermaid.js +79 -54
  178. package/dist/MarkdownEditor/editor/elements/Paragraph.js +144 -83
  179. package/dist/MarkdownEditor/editor/elements/Schema.js +167 -128
  180. package/dist/MarkdownEditor/editor/elements/Table/ReadonlyTableComponent.js +211 -178
  181. package/dist/MarkdownEditor/editor/elements/Table/SimpleTable.js +73 -49
  182. package/dist/MarkdownEditor/editor/elements/Table/Table.js +285 -204
  183. package/dist/MarkdownEditor/editor/elements/Table/TableCellIndex/index.js +397 -280
  184. package/dist/MarkdownEditor/editor/elements/Table/TableCellIndex/style.js +126 -101
  185. package/dist/MarkdownEditor/editor/elements/Table/TableCellIndexSpacer/index.js +381 -276
  186. package/dist/MarkdownEditor/editor/elements/Table/TableCellIndexSpacer/style.js +120 -98
  187. package/dist/MarkdownEditor/editor/elements/Table/TableContext.js +64 -21
  188. package/dist/MarkdownEditor/editor/elements/Table/TableRowIndex/index.js +52 -42
  189. package/dist/MarkdownEditor/editor/elements/Table/TableRowIndex/style.js +69 -39
  190. package/dist/MarkdownEditor/editor/elements/Table/Td/index.js +126 -72
  191. package/dist/MarkdownEditor/editor/elements/Table/Td/style.js +85 -55
  192. package/dist/MarkdownEditor/editor/elements/Table/index.js +204 -105
  193. package/dist/MarkdownEditor/editor/elements/Table/style.js +244 -233
  194. package/dist/MarkdownEditor/editor/elements/Table/useScrollShadow.js +119 -62
  195. package/dist/MarkdownEditor/editor/elements/TagPopup/index.js +438 -276
  196. package/dist/MarkdownEditor/editor/elements/TagPopup/style.js +103 -77
  197. package/dist/MarkdownEditor/editor/elements/index.js +437 -424
  198. package/dist/MarkdownEditor/editor/parser/json-parse.js +38 -9
  199. package/dist/MarkdownEditor/editor/parser/parserMarkdownToSlateNode.js +1753 -1168
  200. package/dist/MarkdownEditor/editor/parser/parserMdToSchema.js +16 -20
  201. package/dist/MarkdownEditor/editor/parser/parserSlateNodeToMarkdown.js +1021 -606
  202. package/dist/MarkdownEditor/editor/parser/remarkParse.js +158 -102
  203. package/dist/MarkdownEditor/editor/plugins/catchError.js +78 -17
  204. package/dist/MarkdownEditor/editor/plugins/elements.js +458 -342
  205. package/dist/MarkdownEditor/editor/plugins/handlePaste.js +752 -300
  206. package/dist/MarkdownEditor/editor/plugins/hotKeyCommands/arrow.js +215 -129
  207. package/dist/MarkdownEditor/editor/plugins/hotKeyCommands/backspace.js +325 -180
  208. package/dist/MarkdownEditor/editor/plugins/hotKeyCommands/enter.js +576 -418
  209. package/dist/MarkdownEditor/editor/plugins/hotKeyCommands/match.js +157 -47
  210. package/dist/MarkdownEditor/editor/plugins/hotKeyCommands/tab.js +331 -209
  211. package/dist/MarkdownEditor/editor/plugins/index.js +0 -1
  212. package/dist/MarkdownEditor/editor/plugins/insertParsedHtmlNodes.js +1245 -507
  213. package/dist/MarkdownEditor/editor/plugins/parseMarkdownToNodesAndInsert.js +36 -24
  214. package/dist/MarkdownEditor/editor/plugins/useHighlight.js +267 -116
  215. package/dist/MarkdownEditor/editor/plugins/useKeyboard.js +234 -160
  216. package/dist/MarkdownEditor/editor/plugins/useOnchange.js +253 -92
  217. package/dist/MarkdownEditor/editor/plugins/withMarkdown.js +728 -439
  218. package/dist/MarkdownEditor/editor/store.js +1819 -1389
  219. package/dist/MarkdownEditor/editor/style.js +551 -506
  220. package/dist/MarkdownEditor/editor/tagStyles.js +43 -43
  221. package/dist/MarkdownEditor/editor/tools/DragHandle.js +56 -54
  222. package/dist/MarkdownEditor/editor/tools/InsertAutocomplete.js +1049 -732
  223. package/dist/MarkdownEditor/editor/tools/InsertLink.js +232 -181
  224. package/dist/MarkdownEditor/editor/tools/Leading.js +566 -303
  225. package/dist/MarkdownEditor/editor/tools/ToolBar/BaseBar.js +415 -377
  226. package/dist/MarkdownEditor/editor/tools/ToolBar/FloatBar.js +162 -125
  227. package/dist/MarkdownEditor/editor/tools/ToolBar/ReadonlyBaseBar.js +480 -258
  228. package/dist/MarkdownEditor/editor/tools/ToolBar/ToolBar.js +44 -44
  229. package/dist/MarkdownEditor/editor/tools/ToolBar/components/ClearFormatButton.js +20 -35
  230. package/dist/MarkdownEditor/editor/tools/ToolBar/components/ColorPickerButton.js +69 -73
  231. package/dist/MarkdownEditor/editor/tools/ToolBar/components/FormatButton.js +13 -19
  232. package/dist/MarkdownEditor/editor/tools/ToolBar/components/FormattingTools.js +34 -41
  233. package/dist/MarkdownEditor/editor/tools/ToolBar/components/HeadingDropdown.js +53 -47
  234. package/dist/MarkdownEditor/editor/tools/ToolBar/components/LinkButton.js +11 -19
  235. package/dist/MarkdownEditor/editor/tools/ToolBar/components/ToolBarItem.js +23 -43
  236. package/dist/MarkdownEditor/editor/tools/ToolBar/components/UndoRedoButtons.js +14 -25
  237. package/dist/MarkdownEditor/editor/tools/ToolBar/config/toolsConfig.js +139 -102
  238. package/dist/MarkdownEditor/editor/tools/ToolBar/floatBarStyle.js +95 -65
  239. package/dist/MarkdownEditor/editor/tools/ToolBar/hooks/useToolBarLogic.js +252 -161
  240. package/dist/MarkdownEditor/editor/tools/ToolBar/index.js +14 -24
  241. package/dist/MarkdownEditor/editor/tools/ToolBar/toolBarStyle.js +95 -65
  242. package/dist/MarkdownEditor/editor/tools/insertAutocompleteStyle.js +82 -52
  243. package/dist/MarkdownEditor/editor/types/Table.js +1 -0
  244. package/dist/MarkdownEditor/editor/utils/InlineChromiumBugfix.js +11 -16
  245. package/dist/MarkdownEditor/editor/utils/ace.js +136 -40
  246. package/dist/MarkdownEditor/editor/utils/docx/docxDeserializer.js +29 -32
  247. package/dist/MarkdownEditor/editor/utils/docx/index.js +0 -1
  248. package/dist/MarkdownEditor/editor/utils/docx/module.js +193 -164
  249. package/dist/MarkdownEditor/editor/utils/docx/utils.js +113 -98
  250. package/dist/MarkdownEditor/editor/utils/dom.js +119 -90
  251. package/dist/MarkdownEditor/editor/utils/editorUtils.js +1369 -906
  252. package/dist/MarkdownEditor/editor/utils/htmlToMarkdown.js +196 -184
  253. package/dist/MarkdownEditor/editor/utils/index.js +354 -215
  254. package/dist/MarkdownEditor/editor/utils/isMarkdown.js +56 -44
  255. package/dist/MarkdownEditor/editor/utils/keyboard.js +1229 -664
  256. package/dist/MarkdownEditor/editor/utils/markdownToHtml.js +294 -76
  257. package/dist/MarkdownEditor/editor/utils/media.js +274 -99
  258. package/dist/MarkdownEditor/editor/utils/path.js +22 -16
  259. package/dist/MarkdownEditor/editor/utils/performanceMonitor.js +370 -168
  260. package/dist/MarkdownEditor/editor/utils/useLocalState.js +96 -37
  261. package/dist/MarkdownEditor/el.js +1 -0
  262. package/dist/MarkdownEditor/hooks/editor.js +123 -41
  263. package/dist/MarkdownEditor/hooks/subscribe.js +18 -15
  264. package/dist/MarkdownEditor/index.js +118 -30
  265. package/dist/MarkdownEditor/plugin.js +2 -5
  266. package/dist/MarkdownEditor/style.js +96 -66
  267. package/dist/MarkdownEditor/types.js +1 -0
  268. package/dist/MarkdownEditor/utils/exportHtml.js +42 -83
  269. package/dist/MarkdownEditor/utils/native-table/index.js +0 -1
  270. package/dist/MarkdownEditor/utils/native-table/native-table-editor.js +337 -222
  271. package/dist/MarkdownEditor/utils/native-table/native-table-keyboard.js +201 -113
  272. package/dist/MarkdownInputField/AttachmentButton/AttachmentButtonPopover.d.ts +4 -0
  273. package/dist/MarkdownInputField/AttachmentButton/AttachmentButtonPopover.js +277 -82
  274. package/dist/MarkdownInputField/AttachmentButton/AttachmentFileList/AttachmentFileIcon.js +62 -33
  275. package/dist/MarkdownInputField/AttachmentButton/AttachmentFileList/AttachmentFileListItem.js +147 -125
  276. package/dist/MarkdownInputField/AttachmentButton/AttachmentFileList/index.js +174 -129
  277. package/dist/MarkdownInputField/AttachmentButton/AttachmentFileList/style.js +263 -237
  278. package/dist/MarkdownInputField/AttachmentButton/index.js +480 -205
  279. package/dist/MarkdownInputField/AttachmentButton/style.js +143 -114
  280. package/dist/MarkdownInputField/AttachmentButton/types.js +3 -0
  281. package/dist/MarkdownInputField/AttachmentButton/utils.d.ts +60 -0
  282. package/dist/MarkdownInputField/AttachmentButton/utils.js +365 -33
  283. package/dist/MarkdownInputField/BeforeToolContainer/BeforeToolContainer.js +438 -404
  284. package/dist/MarkdownInputField/Enlargement/index.js +7 -17
  285. package/dist/MarkdownInputField/FileMapView/FileMapViewItem.js +193 -216
  286. package/dist/MarkdownInputField/FileMapView/index.js +387 -174
  287. package/dist/MarkdownInputField/FileMapView/style.js +281 -259
  288. package/dist/MarkdownInputField/FilePaste/index.js +239 -65
  289. package/dist/MarkdownInputField/FileUploadManager/index.js +504 -170
  290. package/dist/MarkdownInputField/MarkdownInputField.js +819 -549
  291. package/dist/MarkdownInputField/QuickActions/index.js +304 -134
  292. package/dist/MarkdownInputField/RefinePromptButton/index.js +24 -33
  293. package/dist/MarkdownInputField/RefinePromptButton/style.js +99 -73
  294. package/dist/MarkdownInputField/SendActions/index.js +179 -197
  295. package/dist/MarkdownInputField/SendButton/index.js +150 -110
  296. package/dist/MarkdownInputField/SendButton/style.js +95 -64
  297. package/dist/MarkdownInputField/SkillModeBar/hooks/index.js +3 -5
  298. package/dist/MarkdownInputField/SkillModeBar/hooks/useSkillModeState.js +51 -26
  299. package/dist/MarkdownInputField/SkillModeBar/index.js +119 -106
  300. package/dist/MarkdownInputField/SkillModeBar/style.js +124 -98
  301. package/dist/MarkdownInputField/Suggestion/index.js +391 -154
  302. package/dist/MarkdownInputField/TopOperatingArea/index.js +37 -44
  303. package/dist/MarkdownInputField/TopOperatingArea/style.js +98 -81
  304. package/dist/MarkdownInputField/VoiceInput/index.js +210 -82
  305. package/dist/MarkdownInputField/VoiceInput/style.js +85 -59
  306. package/dist/MarkdownInputField/VoiceInputManager/index.js +321 -94
  307. package/dist/MarkdownInputField/style.js +296 -233
  308. package/dist/Plugins/chart/AreaChart/index.js +541 -393
  309. package/dist/Plugins/chart/AreaChart/style.js +114 -90
  310. package/dist/Plugins/chart/BarChart/index.d.ts +4 -0
  311. package/dist/Plugins/chart/BarChart/index.js +865 -697
  312. package/dist/Plugins/chart/BarChart/style.js +114 -90
  313. package/dist/Plugins/chart/ChartAttrToolBar/ChartAttrToolBarStyle.js +82 -52
  314. package/dist/Plugins/chart/ChartAttrToolBar/index.js +94 -65
  315. package/dist/Plugins/chart/ChartMark/Area.js +176 -150
  316. package/dist/Plugins/chart/ChartMark/Bar.js +181 -152
  317. package/dist/Plugins/chart/ChartMark/Column.js +181 -151
  318. package/dist/Plugins/chart/ChartMark/Container.js +116 -75
  319. package/dist/Plugins/chart/ChartMark/Line.js +179 -151
  320. package/dist/Plugins/chart/ChartMark/Pie.js +79 -63
  321. package/dist/Plugins/chart/ChartMark/index.js +6 -13
  322. package/dist/Plugins/chart/ChartMark/useChart.js +1 -0
  323. package/dist/Plugins/chart/ChartRender.js +981 -696
  324. package/dist/Plugins/chart/ChartStatistic/index.js +47 -62
  325. package/dist/Plugins/chart/ChartStatistic/style.js +142 -143
  326. package/dist/Plugins/chart/ChartStatistic/utils.js +37 -27
  327. package/dist/Plugins/chart/DonutChart/Legend.js +94 -124
  328. package/dist/Plugins/chart/DonutChart/constants.js +4 -11
  329. package/dist/Plugins/chart/DonutChart/hooks.js +183 -112
  330. package/dist/Plugins/chart/DonutChart/index.js +588 -516
  331. package/dist/Plugins/chart/DonutChart/plugins.js +47 -44
  332. package/dist/Plugins/chart/DonutChart/style.js +186 -175
  333. package/dist/Plugins/chart/DonutChart/types.js +1 -0
  334. package/dist/Plugins/chart/FunnelChart/index.js +844 -647
  335. package/dist/Plugins/chart/FunnelChart/style.js +97 -71
  336. package/dist/Plugins/chart/LineChart/index.js +516 -393
  337. package/dist/Plugins/chart/LineChart/style.js +114 -90
  338. package/dist/Plugins/chart/RadarChart/index.js +580 -582
  339. package/dist/Plugins/chart/RadarChart/style.js +122 -112
  340. package/dist/Plugins/chart/ScatterChart/index.js +633 -640
  341. package/dist/Plugins/chart/ScatterChart/style.js +108 -94
  342. package/dist/Plugins/chart/components/ChartContainer/ChartContainer.js +151 -80
  343. package/dist/Plugins/chart/components/ChartContainer/ChartErrorBoundary.js +160 -41
  344. package/dist/Plugins/chart/components/ChartContainer/ChartErrorBoundaryExample.js +80 -62
  345. package/dist/Plugins/chart/components/ChartContainer/index.js +2 -7
  346. package/dist/Plugins/chart/components/ChartContainer/style.js +121 -91
  347. package/dist/Plugins/chart/components/ChartFilter/ChartFilter.js +58 -90
  348. package/dist/Plugins/chart/components/ChartFilter/style.js +169 -154
  349. package/dist/Plugins/chart/components/ChartToolBar/ChartToolBar.js +54 -59
  350. package/dist/Plugins/chart/components/ChartToolBar/style.js +132 -117
  351. package/dist/Plugins/chart/components/icons/TimeIcon.js +20 -26
  352. package/dist/Plugins/chart/components/index.js +32 -34
  353. package/dist/Plugins/chart/const.js +34 -25
  354. package/dist/Plugins/chart/hooks/useChartStatistic.js +1 -0
  355. package/dist/Plugins/chart/index.js +436 -339
  356. package/dist/Plugins/chart/loadChartRuntime.js +209 -110
  357. package/dist/Plugins/chart/utils.js +311 -87
  358. package/dist/Plugins/code/CodeUI/Katex/Katex.js +112 -66
  359. package/dist/Plugins/code/components/AceEditor.js +334 -237
  360. package/dist/Plugins/code/components/AceEditorContainer.js +23 -32
  361. package/dist/Plugins/code/components/CodeContainer.js +41 -56
  362. package/dist/Plugins/code/components/CodeRenderer.js +202 -155
  363. package/dist/Plugins/code/components/CodeToolbar.js +137 -181
  364. package/dist/Plugins/code/components/HtmlPreview.js +19 -22
  365. package/dist/Plugins/code/components/LanguageSelector.js +162 -96
  366. package/dist/Plugins/code/components/LoadImage.js +145 -46
  367. package/dist/Plugins/code/components/ThinkBlock.js +38 -42
  368. package/dist/Plugins/code/components/index.js +13 -23
  369. package/dist/Plugins/code/hooks/index.js +7 -9
  370. package/dist/Plugins/code/hooks/useCodeEditorState.js +139 -62
  371. package/dist/Plugins/code/hooks/useRenderConditions.js +31 -23
  372. package/dist/Plugins/code/hooks/useToolbarConfig.js +44 -46
  373. package/dist/Plugins/code/index.js +141 -89
  374. package/dist/Plugins/code/langIconMap.js +400 -108
  375. package/dist/Plugins/code/langIcons/AbapIcon.js +90 -57
  376. package/dist/Plugins/code/langIcons/ActionscriptIcon.js +89 -56
  377. package/dist/Plugins/code/langIcons/AdaIcon.js +89 -52
  378. package/dist/Plugins/code/langIcons/ApacheIcon.js +205 -254
  379. package/dist/Plugins/code/langIcons/ApexIcon.js +108 -82
  380. package/dist/Plugins/code/langIcons/AplIcon.js +90 -54
  381. package/dist/Plugins/code/langIcons/ApplescriptIcon.js +89 -56
  382. package/dist/Plugins/code/langIcons/AstroIcon.js +91 -58
  383. package/dist/Plugins/code/langIcons/AwkIcon.js +98 -68
  384. package/dist/Plugins/code/langIcons/BallerinaIcon.js +92 -59
  385. package/dist/Plugins/code/langIcons/BatIcon.js +158 -229
  386. package/dist/Plugins/code/langIcons/BicepIcon.js +91 -58
  387. package/dist/Plugins/code/langIcons/BladeIcon.js +90 -58
  388. package/dist/Plugins/code/langIcons/CIcon.js +90 -55
  389. package/dist/Plugins/code/langIcons/CadenceIcon.js +89 -56
  390. package/dist/Plugins/code/langIcons/ClojureIcon.js +96 -75
  391. package/dist/Plugins/code/langIcons/CmakeIcon.js +93 -62
  392. package/dist/Plugins/code/langIcons/CobolIcon.js +99 -70
  393. package/dist/Plugins/code/langIcons/CodeqlIcon.js +96 -76
  394. package/dist/Plugins/code/langIcons/CoffeeIcon.js +89 -56
  395. package/dist/Plugins/code/langIcons/ConsoleIcon.js +89 -56
  396. package/dist/Plugins/code/langIcons/CppIcon.js +90 -55
  397. package/dist/Plugins/code/langIcons/CrystalIcon.js +90 -57
  398. package/dist/Plugins/code/langIcons/CsharpIcon.js +90 -59
  399. package/dist/Plugins/code/langIcons/CssIcon.js +89 -52
  400. package/dist/Plugins/code/langIcons/DIcon.js +90 -53
  401. package/dist/Plugins/code/langIcons/DartIcon.js +92 -71
  402. package/dist/Plugins/code/langIcons/DatabaseIcon.js +90 -57
  403. package/dist/Plugins/code/langIcons/DiffIcon.js +90 -57
  404. package/dist/Plugins/code/langIcons/DockerIcon.js +89 -56
  405. package/dist/Plugins/code/langIcons/DotenvIcon.js +94 -56
  406. package/dist/Plugins/code/langIcons/ElixirIcon.js +91 -58
  407. package/dist/Plugins/code/langIcons/ElmIcon.js +105 -58
  408. package/dist/Plugins/code/langIcons/ErbIcon.js +90 -54
  409. package/dist/Plugins/code/langIcons/ErlangIcon.js +89 -56
  410. package/dist/Plugins/code/langIcons/FsharpIcon.js +93 -62
  411. package/dist/Plugins/code/langIcons/GdscriptIcon.js +96 -88
  412. package/dist/Plugins/code/langIcons/GlslIcon.js +90 -58
  413. package/dist/Plugins/code/langIcons/GnuplotIcon.js +98 -77
  414. package/dist/Plugins/code/langIcons/GoIcon.js +114 -93
  415. package/dist/Plugins/code/langIcons/GraphqlIcon.js +106 -66
  416. package/dist/Plugins/code/langIcons/GroovyIcon.js +89 -56
  417. package/dist/Plugins/code/langIcons/HackIcon.js +97 -64
  418. package/dist/Plugins/code/langIcons/HamlIcon.js +89 -56
  419. package/dist/Plugins/code/langIcons/HandlebarsIcon.js +89 -56
  420. package/dist/Plugins/code/langIcons/HaskellIcon.js +93 -64
  421. package/dist/Plugins/code/langIcons/HclIcon.js +118 -93
  422. package/dist/Plugins/code/langIcons/HclLightIcon.js +118 -97
  423. package/dist/Plugins/code/langIcons/HjsonIcon.js +94 -62
  424. package/dist/Plugins/code/langIcons/HlslIcon.js +96 -76
  425. package/dist/Plugins/code/langIcons/HtmlIcon.js +89 -56
  426. package/dist/Plugins/code/langIcons/HttpIcon.js +89 -56
  427. package/dist/Plugins/code/langIcons/ImbaIcon.js +98 -65
  428. package/dist/Plugins/code/langIcons/IniIcon.js +90 -54
  429. package/dist/Plugins/code/langIcons/JavaIcon.js +89 -56
  430. package/dist/Plugins/code/langIcons/JavascriptIcon.js +89 -56
  431. package/dist/Plugins/code/langIcons/JinjaIcon.js +100 -68
  432. package/dist/Plugins/code/langIcons/Json5Icon.js +100 -82
  433. package/dist/Plugins/code/langIcons/JsonIcon.js +89 -56
  434. package/dist/Plugins/code/langIcons/JsonnetIcon.js +102 -86
  435. package/dist/Plugins/code/langIcons/JuliaIcon.js +105 -52
  436. package/dist/Plugins/code/langIcons/KotlinIcon.js +104 -74
  437. package/dist/Plugins/code/langIcons/KustoIcon.js +90 -57
  438. package/dist/Plugins/code/langIcons/LessIcon.js +90 -57
  439. package/dist/Plugins/code/langIcons/LiquidIcon.js +91 -58
  440. package/dist/Plugins/code/langIcons/LispIcon.js +89 -56
  441. package/dist/Plugins/code/langIcons/LuaIcon.js +93 -60
  442. package/dist/Plugins/code/langIcons/MakefileIcon.js +91 -58
  443. package/dist/Plugins/code/langIcons/MarkdownIcon.js +89 -56
  444. package/dist/Plugins/code/langIcons/MarkojsIcon.js +96 -73
  445. package/dist/Plugins/code/langIcons/MatlabIcon.js +93 -64
  446. package/dist/Plugins/code/langIcons/MdxIcon.js +90 -53
  447. package/dist/Plugins/code/langIcons/MermaidIcon.js +95 -64
  448. package/dist/Plugins/code/langIcons/MojoIcon.js +95 -62
  449. package/dist/Plugins/code/langIcons/NginxIcon.js +94 -61
  450. package/dist/Plugins/code/langIcons/NimIcon.js +91 -54
  451. package/dist/Plugins/code/langIcons/NixIcon.js +92 -56
  452. package/dist/Plugins/code/langIcons/ObjectiveCIcon.js +90 -59
  453. package/dist/Plugins/code/langIcons/ObjectiveCppIcon.js +90 -57
  454. package/dist/Plugins/code/langIcons/OcamlIcon.js +90 -61
  455. package/dist/Plugins/code/langIcons/PascalIcon.js +95 -55
  456. package/dist/Plugins/code/langIcons/Perl6Icon.js +299 -320
  457. package/dist/Plugins/code/langIcons/PerlIcon.js +89 -56
  458. package/dist/Plugins/code/langIcons/PhpIcon.js +89 -52
  459. package/dist/Plugins/code/langIcons/PostcssIcon.js +130 -113
  460. package/dist/Plugins/code/langIcons/PowershellIcon.js +91 -58
  461. package/dist/Plugins/code/langIcons/PrismaIcon.js +97 -68
  462. package/dist/Plugins/code/langIcons/PrologIcon.js +91 -58
  463. package/dist/Plugins/code/langIcons/ProtoIcon.js +94 -68
  464. package/dist/Plugins/code/langIcons/PugIcon.js +177 -145
  465. package/dist/Plugins/code/langIcons/PuppetIcon.js +96 -52
  466. package/dist/Plugins/code/langIcons/PurescriptIcon.js +93 -61
  467. package/dist/Plugins/code/langIcons/PythonIcon.js +90 -61
  468. package/dist/Plugins/code/langIcons/RIcon.js +89 -52
  469. package/dist/Plugins/code/langIcons/RazorIcon.js +90 -57
  470. package/dist/Plugins/code/langIcons/ReactIcon.js +89 -56
  471. package/dist/Plugins/code/langIcons/ReactTsIcon.js +90 -57
  472. package/dist/Plugins/code/langIcons/RubyIcon.js +91 -58
  473. package/dist/Plugins/code/langIcons/RustIcon.js +89 -56
  474. package/dist/Plugins/code/langIcons/SasIcon.js +89 -52
  475. package/dist/Plugins/code/langIcons/SassIcon.js +90 -57
  476. package/dist/Plugins/code/langIcons/ScalaIcon.js +96 -53
  477. package/dist/Plugins/code/langIcons/SchemeIcon.js +91 -58
  478. package/dist/Plugins/code/langIcons/ShaderlabIcon.js +89 -56
  479. package/dist/Plugins/code/langIcons/SolidityIcon.js +94 -52
  480. package/dist/Plugins/code/langIcons/SparqlIcon.js +94 -64
  481. package/dist/Plugins/code/langIcons/StataIcon.js +126 -108
  482. package/dist/Plugins/code/langIcons/StylusIcon.js +92 -59
  483. package/dist/Plugins/code/langIcons/SvelteIcon.js +91 -58
  484. package/dist/Plugins/code/langIcons/SwiftIcon.js +90 -57
  485. package/dist/Plugins/code/langIcons/SystemverilogIcon.js +115 -102
  486. package/dist/Plugins/code/langIcons/TclIcon.js +89 -52
  487. package/dist/Plugins/code/langIcons/TexIcon.js +99 -65
  488. package/dist/Plugins/code/langIcons/TomlIcon.js +94 -70
  489. package/dist/Plugins/code/langIcons/TwigIcon.js +89 -56
  490. package/dist/Plugins/code/langIcons/TypescriptIcon.js +93 -60
  491. package/dist/Plugins/code/langIcons/VerilogIcon.js +89 -56
  492. package/dist/Plugins/code/langIcons/VhdlIcon.js +94 -64
  493. package/dist/Plugins/code/langIcons/VimIcon.js +278 -420
  494. package/dist/Plugins/code/langIcons/VueIcon.js +92 -59
  495. package/dist/Plugins/code/langIcons/WebassemblyIcon.js +103 -76
  496. package/dist/Plugins/code/langIcons/WenyanIcon.js +104 -100
  497. package/dist/Plugins/code/langIcons/WgslIcon.js +93 -77
  498. package/dist/Plugins/code/langIcons/WolframlanguageIcon.js +100 -71
  499. package/dist/Plugins/code/langIcons/XmlIcon.js +89 -52
  500. package/dist/Plugins/code/langIcons/XslIcon.js +94 -66
  501. package/dist/Plugins/code/langIcons/YamlIcon.js +89 -56
  502. package/dist/Plugins/code/langIcons/ZigIcon.js +106 -81
  503. package/dist/Plugins/code/langIcons/index.js +128 -259
  504. package/dist/Plugins/code/utils/index.js +5 -5
  505. package/dist/Plugins/code/utils/langOptions.js +86 -11
  506. package/dist/Plugins/defaultPlugins.js +9 -13
  507. package/dist/Plugins/formatter/index.js +205 -105
  508. package/dist/Plugins/index.js +6 -2
  509. package/dist/Plugins/katex/InlineKatex.js +196 -107
  510. package/dist/Plugins/katex/Katex.js +139 -65
  511. package/dist/Plugins/katex/index.js +163 -103
  512. package/dist/Plugins/mermaid/Mermaid.js +472 -197
  513. package/dist/Plugins/mermaid/index.js +237 -142
  514. package/dist/Quote/index.js +112 -73
  515. package/dist/Quote/style.js +176 -160
  516. package/dist/Schema/SchemaEditor/AceEditorWrapper.js +163 -119
  517. package/dist/Schema/SchemaEditor/index.js +385 -275
  518. package/dist/Schema/SchemaEditor/style.js +261 -269
  519. package/dist/Schema/SchemaForm/index.js +443 -268
  520. package/dist/Schema/SchemaForm/types.js +1 -0
  521. package/dist/Schema/SchemaRenderer/index.js +973 -588
  522. package/dist/Schema/SchemaRenderer/templateEngine.js +106 -26
  523. package/dist/Schema/index.js +7 -11
  524. package/dist/Schema/types.js +1 -0
  525. package/dist/Schema/validator.js +74 -36
  526. package/dist/TaskList/index.js +197 -142
  527. package/dist/TaskList/style.js +143 -122
  528. package/dist/ThoughtChainList/CostMillis.js +88 -54
  529. package/dist/ThoughtChainList/DeepThink.js +187 -152
  530. package/dist/ThoughtChainList/DotAni/index.js +29 -14
  531. package/dist/ThoughtChainList/DotAni/style.js +82 -50
  532. package/dist/ThoughtChainList/FlipText/index.js +74 -30
  533. package/dist/ThoughtChainList/MarkdownEditor.js +126 -72
  534. package/dist/ThoughtChainList/RagRetrievalInfo.js +113 -145
  535. package/dist/ThoughtChainList/TableSql.js +413 -459
  536. package/dist/ThoughtChainList/ThoughtChainListItem.js +388 -222
  537. package/dist/ThoughtChainList/TitleInfo.js +189 -185
  538. package/dist/ThoughtChainList/ToolCall.js +429 -463
  539. package/dist/ThoughtChainList/WebSearch.js +192 -162
  540. package/dist/ThoughtChainList/index.js +449 -410
  541. package/dist/ThoughtChainList/style.js +253 -232
  542. package/dist/ThoughtChainList/types.js +1 -0
  543. package/dist/ToolUseBar/ToolUseBarItem.js +183 -139
  544. package/dist/ToolUseBar/ToolUseBarItemComponents.js +345 -276
  545. package/dist/ToolUseBar/ToolUseBarThink.js +335 -396
  546. package/dist/ToolUseBar/index.js +226 -113
  547. package/dist/ToolUseBar/style.js +334 -308
  548. package/dist/ToolUseBar/thinkStyle.js +350 -328
  549. package/dist/Types/common.js +1 -0
  550. package/dist/Types/index.js +4 -2
  551. package/dist/Types/message.js +1 -0
  552. package/dist/Utils/easings.js +9 -12
  553. package/dist/Utils/formatTime.js +41 -17
  554. package/dist/Utils/getScroll.js +41 -41
  555. package/dist/Utils/language.js +355 -150
  556. package/dist/Utils/proxySandbox/ProxySandbox.js +1637 -1076
  557. package/dist/Utils/proxySandbox/SecurityContextManager.js +607 -343
  558. package/dist/Utils/proxySandbox/index.js +554 -267
  559. package/dist/Utils/proxySandbox/types.js +187 -52
  560. package/dist/Utils/scrollTo.js +48 -56
  561. package/dist/Utils/throttleByAnimationFrame.js +46 -20
  562. package/dist/WelcomeMessage/index.js +106 -58
  563. package/dist/WelcomeMessage/style.js +80 -55
  564. package/dist/Workspace/Browser/index.js +102 -40
  565. package/dist/Workspace/Browser/style.js +62 -33
  566. package/dist/Workspace/File/DataSourceStrategy.js +419 -217
  567. package/dist/Workspace/File/FileComponent.js +1004 -791
  568. package/dist/Workspace/File/FileTypeProcessor.js +337 -184
  569. package/dist/Workspace/File/PreviewComponent.js +472 -532
  570. package/dist/Workspace/File/index.js +3 -10
  571. package/dist/Workspace/File/style.js +397 -424
  572. package/dist/Workspace/File/utils.js +160 -106
  573. package/dist/Workspace/HtmlPreview/index.js +238 -137
  574. package/dist/Workspace/HtmlPreview/style.js +99 -77
  575. package/dist/Workspace/RealtimeFollow/index.js +411 -413
  576. package/dist/Workspace/RealtimeFollow/style.js +299 -303
  577. package/dist/Workspace/Task/index.js +53 -35
  578. package/dist/Workspace/Task/style.js +99 -73
  579. package/dist/Workspace/index.js +332 -254
  580. package/dist/Workspace/style.js +165 -146
  581. package/dist/Workspace/types.js +471 -252
  582. package/dist/Workspace/utils/codeLanguageUtils.js +148 -129
  583. package/dist/Workspace/utils.js +28 -20
  584. package/dist/index.js +27 -17
  585. package/package.json +3 -2
@@ -1,44 +1,225 @@
1
- var __defProp = Object.defineProperty;
2
- var __defProps = Object.defineProperties;
3
- var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
4
- var __getOwnPropSymbols = Object.getOwnPropertySymbols;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __propIsEnum = Object.prototype.propertyIsEnumerable;
7
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
8
- var __spreadValues = (a, b) => {
9
- for (var prop in b || (b = {}))
10
- if (__hasOwnProp.call(b, prop))
11
- __defNormalProp(a, prop, b[prop]);
12
- if (__getOwnPropSymbols)
13
- for (var prop of __getOwnPropSymbols(b)) {
14
- if (__propIsEnum.call(b, prop))
15
- __defNormalProp(a, prop, b[prop]);
1
+ function _array_like_to_array(arr, len) {
2
+ if (len == null || len > arr.length) len = arr.length;
3
+ for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
4
+ return arr2;
5
+ }
6
+ function _array_with_holes(arr) {
7
+ if (Array.isArray(arr)) return arr;
8
+ }
9
+ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
10
+ try {
11
+ var info = gen[key](arg);
12
+ var value = info.value;
13
+ } catch (error) {
14
+ reject(error);
15
+ return;
16
16
  }
17
- return a;
18
- };
19
- var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
20
- var __async = (__this, __arguments, generator) => {
21
- return new Promise((resolve, reject) => {
22
- var fulfilled = (value) => {
23
- try {
24
- step(generator.next(value));
25
- } catch (e) {
26
- reject(e);
27
- }
17
+ if (info.done) {
18
+ resolve(value);
19
+ } else {
20
+ Promise.resolve(value).then(_next, _throw);
21
+ }
22
+ }
23
+ function _async_to_generator(fn) {
24
+ return function() {
25
+ var self = this, args = arguments;
26
+ return new Promise(function(resolve, reject) {
27
+ var gen = fn.apply(self, args);
28
+ function _next(value) {
29
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
30
+ }
31
+ function _throw(err) {
32
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
33
+ }
34
+ _next(undefined);
35
+ });
28
36
  };
29
- var rejected = (value) => {
30
- try {
31
- step(generator.throw(value));
32
- } catch (e) {
33
- reject(e);
34
- }
37
+ }
38
+ function _define_property(obj, key, value) {
39
+ if (key in obj) {
40
+ Object.defineProperty(obj, key, {
41
+ value: value,
42
+ enumerable: true,
43
+ configurable: true,
44
+ writable: true
45
+ });
46
+ } else {
47
+ obj[key] = value;
48
+ }
49
+ return obj;
50
+ }
51
+ function _iterable_to_array_limit(arr, i) {
52
+ var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
53
+ if (_i == null) return;
54
+ var _arr = [];
55
+ var _n = true;
56
+ var _d = false;
57
+ var _s, _e;
58
+ try {
59
+ for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){
60
+ _arr.push(_s.value);
61
+ if (i && _arr.length === i) break;
62
+ }
63
+ } catch (err) {
64
+ _d = true;
65
+ _e = err;
66
+ } finally{
67
+ try {
68
+ if (!_n && _i["return"] != null) _i["return"]();
69
+ } finally{
70
+ if (_d) throw _e;
71
+ }
72
+ }
73
+ return _arr;
74
+ }
75
+ function _non_iterable_rest() {
76
+ throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
77
+ }
78
+ function _object_spread(target) {
79
+ for(var i = 1; i < arguments.length; i++){
80
+ var source = arguments[i] != null ? arguments[i] : {};
81
+ var ownKeys = Object.keys(source);
82
+ if (typeof Object.getOwnPropertySymbols === "function") {
83
+ ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
84
+ return Object.getOwnPropertyDescriptor(source, sym).enumerable;
85
+ }));
86
+ }
87
+ ownKeys.forEach(function(key) {
88
+ _define_property(target, key, source[key]);
89
+ });
90
+ }
91
+ return target;
92
+ }
93
+ function ownKeys(object, enumerableOnly) {
94
+ var keys = Object.keys(object);
95
+ if (Object.getOwnPropertySymbols) {
96
+ var symbols = Object.getOwnPropertySymbols(object);
97
+ if (enumerableOnly) {
98
+ symbols = symbols.filter(function(sym) {
99
+ return Object.getOwnPropertyDescriptor(object, sym).enumerable;
100
+ });
101
+ }
102
+ keys.push.apply(keys, symbols);
103
+ }
104
+ return keys;
105
+ }
106
+ function _object_spread_props(target, source) {
107
+ source = source != null ? source : {};
108
+ if (Object.getOwnPropertyDescriptors) {
109
+ Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
110
+ } else {
111
+ ownKeys(Object(source)).forEach(function(key) {
112
+ Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
113
+ });
114
+ }
115
+ return target;
116
+ }
117
+ function _sliced_to_array(arr, i) {
118
+ return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();
119
+ }
120
+ function _unsupported_iterable_to_array(o, minLen) {
121
+ if (!o) return;
122
+ if (typeof o === "string") return _array_like_to_array(o, minLen);
123
+ var n = Object.prototype.toString.call(o).slice(8, -1);
124
+ if (n === "Object" && o.constructor) n = o.constructor.name;
125
+ if (n === "Map" || n === "Set") return Array.from(n);
126
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
127
+ }
128
+ function _ts_generator(thisArg, body) {
129
+ var f, y, t, g, _ = {
130
+ label: 0,
131
+ sent: function() {
132
+ if (t[0] & 1) throw t[1];
133
+ return t[1];
134
+ },
135
+ trys: [],
136
+ ops: []
35
137
  };
36
- var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
37
- step((generator = generator.apply(__this, __arguments)).next());
38
- });
39
- };
40
-
41
- // src/Plugins/chart/ChartRender.tsx
138
+ return g = {
139
+ next: verb(0),
140
+ "throw": verb(1),
141
+ "return": verb(2)
142
+ }, typeof Symbol === "function" && (g[Symbol.iterator] = function() {
143
+ return this;
144
+ }), g;
145
+ function verb(n) {
146
+ return function(v) {
147
+ return step([
148
+ n,
149
+ v
150
+ ]);
151
+ };
152
+ }
153
+ function step(op) {
154
+ if (f) throw new TypeError("Generator is already executing.");
155
+ while(_)try {
156
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
157
+ if (y = 0, t) op = [
158
+ op[0] & 2,
159
+ t.value
160
+ ];
161
+ switch(op[0]){
162
+ case 0:
163
+ case 1:
164
+ t = op;
165
+ break;
166
+ case 4:
167
+ _.label++;
168
+ return {
169
+ value: op[1],
170
+ done: false
171
+ };
172
+ case 5:
173
+ _.label++;
174
+ y = op[1];
175
+ op = [
176
+ 0
177
+ ];
178
+ continue;
179
+ case 7:
180
+ op = _.ops.pop();
181
+ _.trys.pop();
182
+ continue;
183
+ default:
184
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
185
+ _ = 0;
186
+ continue;
187
+ }
188
+ if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
189
+ _.label = op[1];
190
+ break;
191
+ }
192
+ if (op[0] === 6 && _.label < t[1]) {
193
+ _.label = t[1];
194
+ t = op;
195
+ break;
196
+ }
197
+ if (t && _.label < t[2]) {
198
+ _.label = t[2];
199
+ _.ops.push(op);
200
+ break;
201
+ }
202
+ if (t[2]) _.ops.pop();
203
+ _.trys.pop();
204
+ continue;
205
+ }
206
+ op = body.call(thisArg, _);
207
+ } catch (e) {
208
+ op = [
209
+ 6,
210
+ e
211
+ ];
212
+ y = 0;
213
+ } finally{
214
+ f = t = 0;
215
+ }
216
+ if (op[0] & 5) throw op[1];
217
+ return {
218
+ value: op[0] ? op[1] : void 0,
219
+ done: true
220
+ };
221
+ }
222
+ }
42
223
  import { DownOutlined, SettingOutlined } from "@ant-design/icons";
43
224
  import { ProForm, ProFormSelect } from "@ant-design/pro-components";
44
225
  import { ConfigProvider, Descriptions, Dropdown, Popover, Table } from "antd";
@@ -49,684 +230,788 @@ import { useIntersectionOnce } from "../../Hooks/useIntersectionOnce";
49
230
  import { I18nContext } from "../../I18n";
50
231
  import { loadChartRuntime } from "./loadChartRuntime";
51
232
  import { isNotEmpty, toNumber } from "./utils";
52
- var getChartMap = (i18n) => {
53
- var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k;
54
- return {
55
- pie: {
56
- title: ((_a = i18n == null ? void 0 : i18n.locale) == null ? void 0 : _a.pieChart) || "饼图",
57
- changeData: ["donut"]
58
- },
59
- donut: {
60
- title: ((_b = i18n == null ? void 0 : i18n.locale) == null ? void 0 : _b.donutChart) || "环形图",
61
- changeData: ["pie"]
62
- },
63
- bar: {
64
- title: ((_c = i18n == null ? void 0 : i18n.locale) == null ? void 0 : _c.barChart) || "条形图",
65
- changeData: ["column", "line", "area"]
66
- },
67
- line: {
68
- title: ((_d = i18n == null ? void 0 : i18n.locale) == null ? void 0 : _d.lineChart) || "折线图",
69
- changeData: ["column", "bar", "area"]
70
- },
71
- column: {
72
- title: ((_e = i18n == null ? void 0 : i18n.locale) == null ? void 0 : _e.columnChart) || "柱状图",
73
- changeData: ["bar", "line", "area"]
74
- },
75
- area: {
76
- title: ((_f = i18n == null ? void 0 : i18n.locale) == null ? void 0 : _f.areaChart) || "面积图",
77
- changeData: ["column", "bar", "line"]
78
- },
79
- radar: {
80
- title: ((_g = i18n == null ? void 0 : i18n.locale) == null ? void 0 : _g.radarChart) || "雷达图",
81
- changeData: []
82
- },
83
- scatter: {
84
- title: ((_h = i18n == null ? void 0 : i18n.locale) == null ? void 0 : _h.scatterChart) || "散点图",
85
- changeData: []
86
- },
87
- funnel: {
88
- title: ((_i = i18n == null ? void 0 : i18n.locale) == null ? void 0 : _i.funnelChart) || "漏斗图",
89
- changeData: []
90
- },
91
- table: {
92
- title: ((_j = i18n == null ? void 0 : i18n.locale) == null ? void 0 : _j.table) || "表格",
93
- changeData: ["column", "line", "area", "pie", "donut"]
94
- },
95
- descriptions: {
96
- title: ((_k = i18n == null ? void 0 : i18n.locale) == null ? void 0 : _k.descriptions) || "定义列表",
97
- changeData: ["column", "line", "area", "pie", "donut"]
98
- }
99
- };
100
- };
101
- var ChartRuntimeRendererImpl = ({
102
- chartType,
103
- runtime,
104
- convertDonutData,
105
- convertFlatData,
106
- config,
107
- renderKey,
108
- title,
109
- dataTime,
110
- toolBar,
111
- filterBy,
112
- groupBy,
113
- colorLegend,
114
- chartData,
115
- getFieldValue
116
- }) => {
117
- var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r;
118
- const {
119
- DonutChart,
120
- FunnelChart,
121
- AreaChart,
122
- BarChart,
123
- LineChart,
124
- RadarChart,
125
- ScatterChart
126
- } = runtime;
127
- if (chartType === "pie") {
128
- return /* @__PURE__ */ React.createElement(
129
- DonutChart,
130
- {
131
- key: `${config == null ? void 0 : config.index}-pie-${renderKey}`,
132
- data: convertDonutData,
133
- configs: [{ chartStyle: "pie", showLegend: true }],
134
- height: (config == null ? void 0 : config.height) || 400,
135
- title,
136
- showToolbar: true,
137
- dataTime,
138
- toolbarExtra: toolBar
139
- }
140
- );
141
- }
142
- if (chartType === "donut") {
143
- return /* @__PURE__ */ React.createElement(
144
- DonutChart,
145
- {
146
- key: `${config == null ? void 0 : config.index}-donut-${renderKey}`,
147
- data: convertDonutData,
148
- configs: [{ chartStyle: "donut", showLegend: true }],
149
- height: (config == null ? void 0 : config.height) || 400,
150
- title,
151
- showToolbar: true,
152
- dataTime,
153
- toolbarExtra: toolBar
154
- }
155
- );
156
- }
157
- if (chartType === "bar") {
158
- return /* @__PURE__ */ React.createElement(
159
- BarChart,
160
- {
161
- key: `${config == null ? void 0 : config.index}-bar-${renderKey}`,
162
- data: convertFlatData,
163
- height: (config == null ? void 0 : config.height) || 400,
164
- title: title || "",
165
- indexAxis: "y",
166
- stacked: (_a = config == null ? void 0 : config.rest) == null ? void 0 : _a.stacked,
167
- showLegend: (_c = (_b = config == null ? void 0 : config.rest) == null ? void 0 : _b.showLegend) != null ? _c : true,
168
- showGrid: (_e = (_d = config == null ? void 0 : config.rest) == null ? void 0 : _d.showGrid) != null ? _e : true,
169
- dataTime,
170
- toolbarExtra: toolBar
171
- }
172
- );
173
- }
174
- if (chartType === "line") {
175
- return /* @__PURE__ */ React.createElement(
176
- LineChart,
177
- {
178
- key: `${config == null ? void 0 : config.index}-line-${renderKey}`,
179
- data: convertFlatData,
180
- height: (config == null ? void 0 : config.height) || 400,
181
- title: title || "",
182
- showLegend: (_g = (_f = config == null ? void 0 : config.rest) == null ? void 0 : _f.showLegend) != null ? _g : true,
183
- showGrid: (_i = (_h = config == null ? void 0 : config.rest) == null ? void 0 : _h.showGrid) != null ? _i : true,
184
- dataTime,
185
- toolbarExtra: toolBar
186
- }
187
- );
188
- }
189
- if (chartType === "column") {
190
- return /* @__PURE__ */ React.createElement(
191
- BarChart,
192
- {
193
- key: `${config == null ? void 0 : config.index}-column-${renderKey}`,
194
- data: convertFlatData,
195
- height: (config == null ? void 0 : config.height) || 400,
196
- title: title || "",
197
- indexAxis: "x",
198
- stacked: (_j = config == null ? void 0 : config.rest) == null ? void 0 : _j.stacked,
199
- showLegend: (_l = (_k = config == null ? void 0 : config.rest) == null ? void 0 : _k.showLegend) != null ? _l : true,
200
- showGrid: (_n = (_m = config == null ? void 0 : config.rest) == null ? void 0 : _m.showGrid) != null ? _n : true,
201
- dataTime,
202
- toolbarExtra: toolBar
203
- }
204
- );
205
- }
206
- if (chartType === "area") {
207
- return /* @__PURE__ */ React.createElement(
208
- AreaChart,
209
- {
210
- key: `${config == null ? void 0 : config.index}-area-${renderKey}`,
211
- data: convertFlatData,
212
- height: (config == null ? void 0 : config.height) || 400,
213
- title: title || "",
214
- showLegend: (_p = (_o = config == null ? void 0 : config.rest) == null ? void 0 : _o.showLegend) != null ? _p : true,
215
- showGrid: (_r = (_q = config == null ? void 0 : config.rest) == null ? void 0 : _q.showGrid) != null ? _r : true,
216
- dataTime,
217
- toolbarExtra: toolBar
218
- }
219
- );
220
- }
221
- if (chartType === "radar") {
222
- const radarData = (chartData || []).map((row, i) => {
223
- var _a2;
224
- const filterLabel = getFieldValue(row, filterBy);
225
- const category = getFieldValue(row, groupBy);
226
- const type = getFieldValue(row, colorLegend);
227
- return __spreadValues(__spreadValues(__spreadValues({
228
- label: String((_a2 = row == null ? void 0 : row[config == null ? void 0 : config.x]) != null ? _a2 : i + 1),
229
- score: row == null ? void 0 : row[config == null ? void 0 : config.y]
230
- }, category ? { category } : {}), type ? { type } : {}), filterLabel ? { filterLabel } : {});
231
- });
232
- return /* @__PURE__ */ React.createElement(
233
- RadarChart,
234
- {
235
- key: `${config == null ? void 0 : config.index}-radar-${renderKey}`,
236
- data: radarData,
237
- height: (config == null ? void 0 : config.height) || 400,
238
- title: title || "",
239
- dataTime,
240
- toolbarExtra: toolBar
241
- }
242
- );
243
- }
244
- if (chartType === "scatter") {
245
- const scatterData = (chartData || []).map((row) => {
246
- const filterLabel = getFieldValue(row, filterBy);
247
- const category = getFieldValue(row, groupBy);
248
- const type = getFieldValue(row, colorLegend);
249
- return __spreadValues(__spreadValues(__spreadValues({
250
- x: row == null ? void 0 : row[config == null ? void 0 : config.x],
251
- y: row == null ? void 0 : row[config == null ? void 0 : config.y]
252
- }, category ? { category } : {}), type ? { type } : {}), filterLabel ? { filterLabel } : {});
253
- });
254
- return /* @__PURE__ */ React.createElement(
255
- ScatterChart,
256
- {
257
- key: `${config == null ? void 0 : config.index}-scatter-${renderKey}`,
258
- data: scatterData,
259
- height: (config == null ? void 0 : config.height) || 400,
260
- title: title || "",
261
- dataTime,
262
- toolbarExtra: toolBar
263
- }
264
- );
265
- }
266
- if (chartType === "funnel") {
267
- const funnelData = (chartData || []).map((row, i) => {
268
- var _a2;
269
- const filterLabel = getFieldValue(row, filterBy);
270
- const category = getFieldValue(row, groupBy);
271
- const type = getFieldValue(row, colorLegend);
272
- return __spreadValues(__spreadValues(__spreadValues(__spreadValues({
273
- x: String((_a2 = row == null ? void 0 : row[config == null ? void 0 : config.x]) != null ? _a2 : i + 1),
274
- y: toNumber(row == null ? void 0 : row[config == null ? void 0 : config.y], 0)
275
- }, (row == null ? void 0 : row.ratio) !== void 0 ? { ratio: row.ratio } : {}), category ? { category } : {}), type ? { type } : {}), filterLabel ? { filterLabel } : {});
276
- });
277
- return /* @__PURE__ */ React.createElement(
278
- FunnelChart,
279
- {
280
- key: `${config == null ? void 0 : config.index}-funnel-${renderKey}`,
281
- data: funnelData,
282
- height: (config == null ? void 0 : config.height) || 400,
283
- title: title || "",
284
- dataTime,
285
- typeNames: { rate: "转化率", name: colorLegend || "转化" },
286
- toolbarExtra: toolBar
287
- }
288
- );
289
- }
290
- return null;
291
- };
292
- var ChartRuntimeRenderer = lazy(() => __async(void 0, null, function* () {
293
- const runtime = yield loadChartRuntime();
294
- return {
295
- default: (props) => /* @__PURE__ */ React.createElement(ChartRuntimeRendererImpl, __spreadProps(__spreadValues({}, props), { runtime }))
296
- };
297
- }));
298
- var ChartRuntimeFallback = ({ height = 240 }) => /* @__PURE__ */ React.createElement(
299
- "div",
300
- {
301
- style: {
302
- minHeight: height,
303
- display: "flex",
304
- alignItems: "center",
305
- justifyContent: "center",
306
- width: "100%",
307
- color: "#6B7280"
308
- },
309
- role: "status",
310
- "aria-live": "polite"
311
- },
312
- /* @__PURE__ */ React.createElement(Loading, null)
313
- );
314
- var ChartRender = (props) => {
315
- const [chartType, setChartType] = useState(() => props.chartType);
316
- const {
317
- chartData,
318
- isChartList,
319
- onColumnLengthChange,
320
- columnLength,
321
- title,
322
- dataTime,
323
- groupBy,
324
- filterBy,
325
- colorLegend
326
- } = props;
327
- const i18n = useContext(I18nContext);
328
- const [config, setConfig] = useState(() => props.config);
329
- const [renderKey, setRenderKey] = useState(0);
330
- const containerRef = React.useRef(null);
331
- const isIntersecting = useIntersectionOnce(containerRef);
332
- const renderDescriptionsFallback = React.useMemo(() => {
333
- var _a;
334
- const columnCount = ((_a = config == null ? void 0 : config.columns) == null ? void 0 : _a.length) || 0;
335
- return chartData.length < 2 && columnCount > 8;
336
- }, [chartData, config == null ? void 0 : config.columns]);
337
- const shouldLoadRuntime = chartType !== "table" && chartType !== "descriptions" && !renderDescriptionsFallback;
338
- const ChartMap = useMemo(() => getChartMap(i18n), [i18n]);
339
- const getAxisTitles = () => {
340
- var _a, _b, _c, _d;
341
- const xCol = (_b = (_a = config == null ? void 0 : config.columns) == null ? void 0 : _a.find) == null ? void 0 : _b.call(
342
- _a,
343
- (c) => (c == null ? void 0 : c.dataIndex) === (config == null ? void 0 : config.x)
344
- );
345
- const yCol = (_d = (_c = config == null ? void 0 : config.columns) == null ? void 0 : _c.find) == null ? void 0 : _d.call(
346
- _c,
347
- (c) => (c == null ? void 0 : c.dataIndex) === (config == null ? void 0 : config.y)
348
- );
233
+ /**
234
+ * @fileoverview 图表渲染组件文件
235
+ *
236
+ * 该文件提供了统一的图表渲染组件,支持多种图表类型的渲染和配置。
237
+ * 包括图表类型切换、配置管理、数据处理等功能。
238
+ *
239
+ * @author md-editor
240
+ * @version 1.0.0
241
+ * @since 2024
242
+ */ /**
243
+ * 获取图表类型映射配置
244
+ *
245
+ * 根据国际化上下文返回图表类型的配置映射,包括图表标题和可切换的图表类型。
246
+ * 支持多种图表类型:饼图、环形图、条形图、折线图、柱状图、面积图、雷达图、散点图、漏斗图、表格、定义列表。
247
+ *
248
+ * @param {object} i18n - 国际化上下文对象
249
+ * @returns {Object} 图表类型映射对象,包含每种图表类型的配置信息
250
+ *
251
+ * @example
252
+ * ```typescript
253
+ * const chartMap = getChartMap(i18n);
254
+ * console.log(chartMap.pie.title); // '饼图'
255
+ * console.log(chartMap.pie.changeData); // ['donut']
256
+ * ```
257
+ *
258
+ * @since 1.0.0
259
+ */ var getChartMap = function(i18n) {
260
+ var _i18n_locale, _i18n_locale1, _i18n_locale2, _i18n_locale3, _i18n_locale4, _i18n_locale5, _i18n_locale6, _i18n_locale7, _i18n_locale8, _i18n_locale9, _i18n_locale10;
349
261
  return {
350
- xTitle: (xCol == null ? void 0 : xCol.title) || String((config == null ? void 0 : config.x) || ""),
351
- yTitle: (yCol == null ? void 0 : yCol.title) || String((config == null ? void 0 : config.y) || "")
262
+ pie: {
263
+ title: (i18n === null || i18n === void 0 ? void 0 : (_i18n_locale = i18n.locale) === null || _i18n_locale === void 0 ? void 0 : _i18n_locale.pieChart) || '饼图',
264
+ changeData: [
265
+ 'donut'
266
+ ]
267
+ },
268
+ donut: {
269
+ title: (i18n === null || i18n === void 0 ? void 0 : (_i18n_locale1 = i18n.locale) === null || _i18n_locale1 === void 0 ? void 0 : _i18n_locale1.donutChart) || '环形图',
270
+ changeData: [
271
+ 'pie'
272
+ ]
273
+ },
274
+ bar: {
275
+ title: (i18n === null || i18n === void 0 ? void 0 : (_i18n_locale2 = i18n.locale) === null || _i18n_locale2 === void 0 ? void 0 : _i18n_locale2.barChart) || '条形图',
276
+ changeData: [
277
+ 'column',
278
+ 'line',
279
+ 'area'
280
+ ]
281
+ },
282
+ line: {
283
+ title: (i18n === null || i18n === void 0 ? void 0 : (_i18n_locale3 = i18n.locale) === null || _i18n_locale3 === void 0 ? void 0 : _i18n_locale3.lineChart) || '折线图',
284
+ changeData: [
285
+ 'column',
286
+ 'bar',
287
+ 'area'
288
+ ]
289
+ },
290
+ column: {
291
+ title: (i18n === null || i18n === void 0 ? void 0 : (_i18n_locale4 = i18n.locale) === null || _i18n_locale4 === void 0 ? void 0 : _i18n_locale4.columnChart) || '柱状图',
292
+ changeData: [
293
+ 'bar',
294
+ 'line',
295
+ 'area'
296
+ ]
297
+ },
298
+ area: {
299
+ title: (i18n === null || i18n === void 0 ? void 0 : (_i18n_locale5 = i18n.locale) === null || _i18n_locale5 === void 0 ? void 0 : _i18n_locale5.areaChart) || '面积图',
300
+ changeData: [
301
+ 'column',
302
+ 'bar',
303
+ 'line'
304
+ ]
305
+ },
306
+ radar: {
307
+ title: (i18n === null || i18n === void 0 ? void 0 : (_i18n_locale6 = i18n.locale) === null || _i18n_locale6 === void 0 ? void 0 : _i18n_locale6.radarChart) || '雷达图',
308
+ changeData: []
309
+ },
310
+ scatter: {
311
+ title: (i18n === null || i18n === void 0 ? void 0 : (_i18n_locale7 = i18n.locale) === null || _i18n_locale7 === void 0 ? void 0 : _i18n_locale7.scatterChart) || '散点图',
312
+ changeData: []
313
+ },
314
+ funnel: {
315
+ title: (i18n === null || i18n === void 0 ? void 0 : (_i18n_locale8 = i18n.locale) === null || _i18n_locale8 === void 0 ? void 0 : _i18n_locale8.funnelChart) || '漏斗图',
316
+ changeData: []
317
+ },
318
+ table: {
319
+ title: (i18n === null || i18n === void 0 ? void 0 : (_i18n_locale9 = i18n.locale) === null || _i18n_locale9 === void 0 ? void 0 : _i18n_locale9.table) || '表格',
320
+ changeData: [
321
+ 'column',
322
+ 'line',
323
+ 'area',
324
+ 'pie',
325
+ 'donut'
326
+ ]
327
+ },
328
+ descriptions: {
329
+ title: (i18n === null || i18n === void 0 ? void 0 : (_i18n_locale10 = i18n.locale) === null || _i18n_locale10 === void 0 ? void 0 : _i18n_locale10.descriptions) || '定义列表',
330
+ changeData: [
331
+ 'column',
332
+ 'line',
333
+ 'area',
334
+ 'pie',
335
+ 'donut'
336
+ ]
337
+ }
352
338
  };
353
- };
354
- const buildXIndexer = () => {
355
- const map = /* @__PURE__ */ new Map();
356
- let idx = 1;
357
- (chartData || []).forEach((row) => {
358
- const key = row == null ? void 0 : row[config == null ? void 0 : config.x];
359
- if (isNotEmpty(key) && !map.has(key)) {
360
- map.set(key, idx++);
361
- }
362
- });
363
- return map;
364
- };
365
- const getFieldValue = (row, field) => {
366
- if (field && isNotEmpty(row[field])) {
367
- return String(row[field]);
339
+ };
340
+ /**
341
+ * 图表运行时渲染器组件实现
342
+ * 负责使用已加载的 runtime 渲染图表
343
+ */ var ChartRuntimeRendererImpl = function(param) {
344
+ var chartType = param.chartType, runtime = param.runtime, convertDonutData = param.convertDonutData, convertFlatData = param.convertFlatData, config = param.config, renderKey = param.renderKey, title = param.title, dataTime = param.dataTime, toolBar = param.toolBar, filterBy = param.filterBy, groupBy = param.groupBy, colorLegend = param.colorLegend, chartData = param.chartData, getFieldValue = param.getFieldValue;
345
+ var DonutChart = runtime.DonutChart, FunnelChart = runtime.FunnelChart, AreaChart = runtime.AreaChart, BarChart = runtime.BarChart, LineChart = runtime.LineChart, RadarChart = runtime.RadarChart, ScatterChart = runtime.ScatterChart;
346
+ if (chartType === 'pie') {
347
+ return /*#__PURE__*/ React.createElement(DonutChart, {
348
+ key: "".concat(config === null || config === void 0 ? void 0 : config.index, "-pie-").concat(renderKey),
349
+ data: convertDonutData,
350
+ configs: [
351
+ {
352
+ chartStyle: 'pie',
353
+ showLegend: true
354
+ }
355
+ ],
356
+ height: (config === null || config === void 0 ? void 0 : config.height) || 400,
357
+ title: title,
358
+ showToolbar: true,
359
+ dataTime: dataTime,
360
+ toolbarExtra: toolBar
361
+ });
368
362
  }
369
- return void 0;
370
- };
371
- const convertFlatData = useMemo(() => {
372
- const { xTitle, yTitle } = getAxisTitles();
373
- const xIndexer = buildXIndexer();
374
- return (chartData || []).map((row, i) => {
375
- var _a;
376
- const rawX = row == null ? void 0 : row[config == null ? void 0 : config.x];
377
- const rawY = row == null ? void 0 : row[config == null ? void 0 : config.y];
378
- const category = getFieldValue(row, groupBy);
379
- const type = getFieldValue(row, colorLegend);
380
- const filterLabel = getFieldValue(row, filterBy);
381
- const x = typeof rawX === "number" ? rawX : isNotEmpty(rawX) ? String(rawX) : String((_a = xIndexer.get(rawX)) != null ? _a : i + 1);
382
- const y = typeof rawY === "number" ? rawY : isNotEmpty(rawY) ? String(rawY) : "";
383
- return __spreadValues(__spreadValues(__spreadValues({
384
- x,
385
- y,
386
- xtitle: xTitle,
387
- ytitle: yTitle
388
- }, type ? { type } : {}), category ? { category } : {}), filterLabel ? { filterLabel } : {});
389
- });
390
- }, [
391
- JSON.stringify(chartData),
392
- JSON.stringify(config),
393
- title,
394
- groupBy,
395
- colorLegend,
396
- filterBy
397
- ]);
398
- const convertDonutData = useMemo(() => {
399
- return (chartData || []).map((row) => {
400
- var _a;
401
- const category = getFieldValue(row, groupBy);
402
- const label = String((_a = row == null ? void 0 : row[config == null ? void 0 : config.x]) != null ? _a : "");
403
- const value = toNumber(row == null ? void 0 : row[config == null ? void 0 : config.y], 0);
404
- const filterLabel = getFieldValue(row, filterBy);
405
- return __spreadValues(__spreadValues({
406
- label,
407
- value
408
- }, category ? { category } : {}), filterLabel ? { filterLabel } : {});
409
- });
410
- }, [
411
- JSON.stringify(chartData),
412
- JSON.stringify(config),
413
- title,
414
- groupBy,
415
- filterBy
416
- ]);
417
- React.useEffect(() => {
418
- setChartType(props.chartType);
419
- }, [props.chartType]);
420
- const getChartPopover = () => {
421
- var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k;
422
- return [
423
- /* @__PURE__ */ React.createElement(
424
- Dropdown,
425
- {
426
- key: "dropdown",
427
- menu: {
428
- items: ((_b = (_a = ChartMap[chartType]) == null ? void 0 : _a.changeData) == null ? void 0 : _b.map((key) => {
429
- var _a2, _b2;
430
- return {
431
- key,
432
- label: ((_a2 = i18n == null ? void 0 : i18n.locale) == null ? void 0 : _a2[key + "eChart"]) || ((_b2 = ChartMap[key]) == null ? void 0 : _b2.title),
433
- onClick: () => {
434
- setChartType(key);
363
+ if (chartType === 'donut') {
364
+ return /*#__PURE__*/ React.createElement(DonutChart, {
365
+ key: "".concat(config === null || config === void 0 ? void 0 : config.index, "-donut-").concat(renderKey),
366
+ data: convertDonutData,
367
+ configs: [
368
+ {
369
+ chartStyle: 'donut',
370
+ showLegend: true
435
371
  }
436
- };
437
- })) || []
438
- },
439
- getPopupContainer: () => document.body
372
+ ],
373
+ height: (config === null || config === void 0 ? void 0 : config.height) || 400,
374
+ title: title,
375
+ showToolbar: true,
376
+ dataTime: dataTime,
377
+ toolbarExtra: toolBar
378
+ });
379
+ }
380
+ if (chartType === 'bar') {
381
+ var _config_rest, _config_rest1, _config_rest2;
382
+ var _config_rest_showLegend, _config_rest_showGrid;
383
+ return /*#__PURE__*/ React.createElement(BarChart, {
384
+ key: "".concat(config === null || config === void 0 ? void 0 : config.index, "-bar-").concat(renderKey),
385
+ data: convertFlatData,
386
+ height: (config === null || config === void 0 ? void 0 : config.height) || 400,
387
+ title: title || '',
388
+ indexAxis: 'y',
389
+ stacked: config === null || config === void 0 ? void 0 : (_config_rest = config.rest) === null || _config_rest === void 0 ? void 0 : _config_rest.stacked,
390
+ showLegend: (_config_rest_showLegend = config === null || config === void 0 ? void 0 : (_config_rest1 = config.rest) === null || _config_rest1 === void 0 ? void 0 : _config_rest1.showLegend) !== null && _config_rest_showLegend !== void 0 ? _config_rest_showLegend : true,
391
+ showGrid: (_config_rest_showGrid = config === null || config === void 0 ? void 0 : (_config_rest2 = config.rest) === null || _config_rest2 === void 0 ? void 0 : _config_rest2.showGrid) !== null && _config_rest_showGrid !== void 0 ? _config_rest_showGrid : true,
392
+ dataTime: dataTime,
393
+ toolbarExtra: toolBar
394
+ });
395
+ }
396
+ if (chartType === 'line') {
397
+ var _config_rest3, _config_rest4;
398
+ var _config_rest_showLegend1, _config_rest_showGrid1;
399
+ return /*#__PURE__*/ React.createElement(LineChart, {
400
+ key: "".concat(config === null || config === void 0 ? void 0 : config.index, "-line-").concat(renderKey),
401
+ data: convertFlatData,
402
+ height: (config === null || config === void 0 ? void 0 : config.height) || 400,
403
+ title: title || '',
404
+ showLegend: (_config_rest_showLegend1 = config === null || config === void 0 ? void 0 : (_config_rest3 = config.rest) === null || _config_rest3 === void 0 ? void 0 : _config_rest3.showLegend) !== null && _config_rest_showLegend1 !== void 0 ? _config_rest_showLegend1 : true,
405
+ showGrid: (_config_rest_showGrid1 = config === null || config === void 0 ? void 0 : (_config_rest4 = config.rest) === null || _config_rest4 === void 0 ? void 0 : _config_rest4.showGrid) !== null && _config_rest_showGrid1 !== void 0 ? _config_rest_showGrid1 : true,
406
+ dataTime: dataTime,
407
+ toolbarExtra: toolBar
408
+ });
409
+ }
410
+ if (chartType === 'column') {
411
+ var _config_rest5, _config_rest6, _config_rest7;
412
+ var _config_rest_showLegend2, _config_rest_showGrid2;
413
+ return /*#__PURE__*/ React.createElement(BarChart, {
414
+ key: "".concat(config === null || config === void 0 ? void 0 : config.index, "-column-").concat(renderKey),
415
+ data: convertFlatData,
416
+ height: (config === null || config === void 0 ? void 0 : config.height) || 400,
417
+ title: title || '',
418
+ indexAxis: 'x',
419
+ stacked: config === null || config === void 0 ? void 0 : (_config_rest5 = config.rest) === null || _config_rest5 === void 0 ? void 0 : _config_rest5.stacked,
420
+ showLegend: (_config_rest_showLegend2 = config === null || config === void 0 ? void 0 : (_config_rest6 = config.rest) === null || _config_rest6 === void 0 ? void 0 : _config_rest6.showLegend) !== null && _config_rest_showLegend2 !== void 0 ? _config_rest_showLegend2 : true,
421
+ showGrid: (_config_rest_showGrid2 = config === null || config === void 0 ? void 0 : (_config_rest7 = config.rest) === null || _config_rest7 === void 0 ? void 0 : _config_rest7.showGrid) !== null && _config_rest_showGrid2 !== void 0 ? _config_rest_showGrid2 : true,
422
+ dataTime: dataTime,
423
+ toolbarExtra: toolBar
424
+ });
425
+ }
426
+ if (chartType === 'area') {
427
+ var _config_rest8, _config_rest9;
428
+ var _config_rest_showLegend3, _config_rest_showGrid3;
429
+ return /*#__PURE__*/ React.createElement(AreaChart, {
430
+ key: "".concat(config === null || config === void 0 ? void 0 : config.index, "-area-").concat(renderKey),
431
+ data: convertFlatData,
432
+ height: (config === null || config === void 0 ? void 0 : config.height) || 400,
433
+ title: title || '',
434
+ showLegend: (_config_rest_showLegend3 = config === null || config === void 0 ? void 0 : (_config_rest8 = config.rest) === null || _config_rest8 === void 0 ? void 0 : _config_rest8.showLegend) !== null && _config_rest_showLegend3 !== void 0 ? _config_rest_showLegend3 : true,
435
+ showGrid: (_config_rest_showGrid3 = config === null || config === void 0 ? void 0 : (_config_rest9 = config.rest) === null || _config_rest9 === void 0 ? void 0 : _config_rest9.showGrid) !== null && _config_rest_showGrid3 !== void 0 ? _config_rest_showGrid3 : true,
436
+ dataTime: dataTime,
437
+ toolbarExtra: toolBar
438
+ });
439
+ }
440
+ if (chartType === 'radar') {
441
+ var radarData = (chartData || []).map(function(row, i) {
442
+ var filterLabel = getFieldValue(row, filterBy);
443
+ var category = getFieldValue(row, groupBy);
444
+ var type = getFieldValue(row, colorLegend);
445
+ var _row_config_x;
446
+ return _object_spread({
447
+ label: String((_row_config_x = row === null || row === void 0 ? void 0 : row[config === null || config === void 0 ? void 0 : config.x]) !== null && _row_config_x !== void 0 ? _row_config_x : i + 1),
448
+ score: row === null || row === void 0 ? void 0 : row[config === null || config === void 0 ? void 0 : config.y]
449
+ }, category ? {
450
+ category: category
451
+ } : {}, type ? {
452
+ type: type
453
+ } : {}, filterLabel ? {
454
+ filterLabel: filterLabel
455
+ } : {});
456
+ });
457
+ return /*#__PURE__*/ React.createElement(RadarChart, {
458
+ key: "".concat(config === null || config === void 0 ? void 0 : config.index, "-radar-").concat(renderKey),
459
+ data: radarData,
460
+ height: (config === null || config === void 0 ? void 0 : config.height) || 400,
461
+ title: title || '',
462
+ dataTime: dataTime,
463
+ toolbarExtra: toolBar
464
+ });
465
+ }
466
+ if (chartType === 'scatter') {
467
+ var scatterData = (chartData || []).map(function(row) {
468
+ var filterLabel = getFieldValue(row, filterBy);
469
+ var category = getFieldValue(row, groupBy);
470
+ var type = getFieldValue(row, colorLegend);
471
+ return _object_spread({
472
+ x: row === null || row === void 0 ? void 0 : row[config === null || config === void 0 ? void 0 : config.x],
473
+ y: row === null || row === void 0 ? void 0 : row[config === null || config === void 0 ? void 0 : config.y]
474
+ }, category ? {
475
+ category: category
476
+ } : {}, type ? {
477
+ type: type
478
+ } : {}, filterLabel ? {
479
+ filterLabel: filterLabel
480
+ } : {});
481
+ });
482
+ return /*#__PURE__*/ React.createElement(ScatterChart, {
483
+ key: "".concat(config === null || config === void 0 ? void 0 : config.index, "-scatter-").concat(renderKey),
484
+ data: scatterData,
485
+ height: (config === null || config === void 0 ? void 0 : config.height) || 400,
486
+ title: title || '',
487
+ dataTime: dataTime,
488
+ toolbarExtra: toolBar
489
+ });
490
+ }
491
+ if (chartType === 'funnel') {
492
+ var funnelData = (chartData || []).map(function(row, i) {
493
+ var filterLabel = getFieldValue(row, filterBy);
494
+ var category = getFieldValue(row, groupBy);
495
+ var type = getFieldValue(row, colorLegend);
496
+ var _row_config_x;
497
+ return _object_spread({
498
+ x: String((_row_config_x = row === null || row === void 0 ? void 0 : row[config === null || config === void 0 ? void 0 : config.x]) !== null && _row_config_x !== void 0 ? _row_config_x : i + 1),
499
+ y: toNumber(row === null || row === void 0 ? void 0 : row[config === null || config === void 0 ? void 0 : config.y], 0)
500
+ }, (row === null || row === void 0 ? void 0 : row.ratio) !== undefined ? {
501
+ ratio: row.ratio
502
+ } : {}, category ? {
503
+ category: category
504
+ } : {}, type ? {
505
+ type: type
506
+ } : {}, filterLabel ? {
507
+ filterLabel: filterLabel
508
+ } : {});
509
+ });
510
+ return /*#__PURE__*/ React.createElement(FunnelChart, {
511
+ key: "".concat(config === null || config === void 0 ? void 0 : config.index, "-funnel-").concat(renderKey),
512
+ data: funnelData,
513
+ height: (config === null || config === void 0 ? void 0 : config.height) || 400,
514
+ title: title || '',
515
+ dataTime: dataTime,
516
+ typeNames: {
517
+ rate: '转化率',
518
+ name: colorLegend || '转化'
519
+ },
520
+ toolbarExtra: toolBar
521
+ });
522
+ }
523
+ return null;
524
+ };
525
+ /**
526
+ * 图表运行时渲染器组件
527
+ * 使用 React.lazy 延迟加载,仅在需要时加载图表运行时
528
+ */ var ChartRuntimeRenderer = /*#__PURE__*/ lazy(/*#__PURE__*/ _async_to_generator(function() {
529
+ var runtime;
530
+ return _ts_generator(this, function(_state) {
531
+ switch(_state.label){
532
+ case 0:
533
+ return [
534
+ 4,
535
+ loadChartRuntime()
536
+ ];
537
+ case 1:
538
+ runtime = _state.sent();
539
+ return [
540
+ 2,
541
+ {
542
+ default: function(props) {
543
+ return /*#__PURE__*/ React.createElement(ChartRuntimeRendererImpl, _object_spread_props(_object_spread({}, props), {
544
+ runtime: runtime
545
+ }));
546
+ }
547
+ }
548
+ ];
549
+ }
550
+ });
551
+ }));
552
+ /**
553
+ * 加载中的占位组件
554
+ */ var ChartRuntimeFallback = function(param) {
555
+ var _param_height = param.height, height = _param_height === void 0 ? 240 : _param_height;
556
+ return /*#__PURE__*/ React.createElement("div", {
557
+ style: {
558
+ minHeight: height,
559
+ display: 'flex',
560
+ alignItems: 'center',
561
+ justifyContent: 'center',
562
+ width: '100%',
563
+ color: '#6B7280'
440
564
  },
441
- /* @__PURE__ */ React.createElement(
442
- "span",
443
- {
444
- style: {
445
- fontSize: 12,
446
- display: "flex",
447
- alignItems: "center",
448
- gap: 4,
449
- border: "1px solid #f0f0f0",
450
- padding: "4px 12px",
451
- borderRadius: "1em"
452
- }
453
- },
454
- (_c = ChartMap[chartType]) == null ? void 0 : _c.title,
455
- /* @__PURE__ */ React.createElement(
456
- DownOutlined,
457
- {
458
- style: {
459
- fontSize: 8
460
- }
565
+ role: "status",
566
+ "aria-live": "polite"
567
+ }, /*#__PURE__*/ React.createElement(Loading, null));
568
+ };
569
+ /**
570
+ * ChartRender 组件 - 图表渲染组件
571
+ *
572
+ * 该组件用于渲染各种类型的图表,支持饼图、柱状图、折线图、面积图、表格等。
573
+ * 提供图表类型切换、全屏显示、下载、配置等功能。
574
+ * 使用 React.lazy 和 Suspense 实现代码分割和延迟加载,优化性能。
575
+ *
576
+ * @component
577
+ * @description 图表渲染组件,支持多种图表类型的渲染和交互
578
+ * @param {Object} props - 组件属性
579
+ * @param {'pie'|'bar'|'line'|'column'|'area'|'descriptions'|'table'} props.chartType - 图表类型
580
+ * @param {Record<string, any>[]} props.chartData - 图表数据
581
+ * @param {Object} props.config - 图表配置
582
+ * @param {any} props.config.height - 图表高度
583
+ * @param {any} props.config.x - X轴字段
584
+ * @param {any} props.config.y - Y轴字段
585
+ * @param {any} props.config.rest - 其他配置
586
+ * @param {any} [props.config.index] - 图表索引
587
+ * @param {any} [props.config.chartData] - 图表数据
588
+ * @param {any} [props.config.columns] - 列配置
589
+ * @param {any} [props.node] - 节点数据
590
+ * @param {any} [props.title] - 图表标题
591
+ * @param {boolean} [props.isChartList] - 是否为图表列表
592
+ * @param {number} [props.columnLength] - 列长度
593
+ * @param {(value: number) => void} [props.onColumnLengthChange] - 列长度变化回调
594
+ * @param {string} [props.dataTime] - 数据时间
595
+ * @param {string} [props.groupBy] - 业务分组维度
596
+ * @param {string} [props.filterBy] - 主筛选维度
597
+ * @param {string} [props.colorLegend] - 数据系列维度
598
+ *
599
+ * @example
600
+ * ```tsx
601
+ * <ChartRender
602
+ * chartType="pie"
603
+ * chartData={[{ name: "A", value: 10 }, { name: "B", value: 20 }]}
604
+ * config={{
605
+ * height: 300,
606
+ * x: "name",
607
+ * y: "value"
608
+ * }}
609
+ * title="销售数据"
610
+ * dataTime="2025-06-30 00:00:00"
611
+ * />
612
+ * ```
613
+ *
614
+ * @returns {React.ReactElement} 渲染的图表组件
615
+ *
616
+ * @remarks
617
+ * - 支持多种图表类型(饼图、柱状图、折线图、面积图、表格等)
618
+ * - 提供图表类型切换功能
619
+ * - 支持全屏显示
620
+ * - 提供图表下载功能
621
+ * - 支持图表配置和自定义
622
+ * - 提供响应式布局
623
+ * - 集成国际化支持
624
+ * - 提供图表属性工具栏
625
+ * - 使用 React.lazy 和 Suspense 实现代码分割
626
+ */ export var ChartRender = function(props) {
627
+ var _useState = _sliced_to_array(useState(function() {
628
+ return props.chartType;
629
+ }), 2), chartType = _useState[0], setChartType = _useState[1];
630
+ var chartData = props.chartData, isChartList = props.isChartList, onColumnLengthChange = props.onColumnLengthChange, columnLength = props.columnLength, title = props.title, dataTime = props.dataTime, groupBy = props.groupBy, filterBy = props.filterBy, colorLegend = props.colorLegend;
631
+ var i18n = useContext(I18nContext);
632
+ var _useState1 = _sliced_to_array(useState(function() {
633
+ return props.config;
634
+ }), 2), config = _useState1[0], setConfig = _useState1[1];
635
+ var _useState2 = _sliced_to_array(useState(0), 2), renderKey = _useState2[0], setRenderKey = _useState2[1];
636
+ var containerRef = React.useRef(null);
637
+ var isIntersecting = useIntersectionOnce(containerRef);
638
+ var renderDescriptionsFallback = React.useMemo(function() {
639
+ var _config_columns;
640
+ var columnCount = (config === null || config === void 0 ? void 0 : (_config_columns = config.columns) === null || _config_columns === void 0 ? void 0 : _config_columns.length) || 0;
641
+ return chartData.length < 2 && columnCount > 8;
642
+ }, [
643
+ chartData,
644
+ config === null || config === void 0 ? void 0 : config.columns
645
+ ]);
646
+ var shouldLoadRuntime = chartType !== 'table' && chartType !== 'descriptions' && !renderDescriptionsFallback;
647
+ // 获取国际化的图表类型映射
648
+ var ChartMap = useMemo(function() {
649
+ return getChartMap(i18n);
650
+ }, [
651
+ i18n
652
+ ]);
653
+ var getAxisTitles = function() {
654
+ var _config_columns_find, _config_columns, _config_columns_find1, _config_columns1;
655
+ var xCol = config === null || config === void 0 ? void 0 : (_config_columns = config.columns) === null || _config_columns === void 0 ? void 0 : (_config_columns_find = _config_columns.find) === null || _config_columns_find === void 0 ? void 0 : _config_columns_find.call(_config_columns, function(c) {
656
+ return (c === null || c === void 0 ? void 0 : c.dataIndex) === (config === null || config === void 0 ? void 0 : config.x);
657
+ });
658
+ var yCol = config === null || config === void 0 ? void 0 : (_config_columns1 = config.columns) === null || _config_columns1 === void 0 ? void 0 : (_config_columns_find1 = _config_columns1.find) === null || _config_columns_find1 === void 0 ? void 0 : _config_columns_find1.call(_config_columns1, function(c) {
659
+ return (c === null || c === void 0 ? void 0 : c.dataIndex) === (config === null || config === void 0 ? void 0 : config.y);
660
+ });
661
+ return {
662
+ xTitle: (xCol === null || xCol === void 0 ? void 0 : xCol.title) || String((config === null || config === void 0 ? void 0 : config.x) || ''),
663
+ yTitle: (yCol === null || yCol === void 0 ? void 0 : yCol.title) || String((config === null || config === void 0 ? void 0 : config.y) || '')
664
+ };
665
+ };
666
+ var buildXIndexer = function() {
667
+ var map = new Map();
668
+ var idx = 1;
669
+ (chartData || []).forEach(function(row) {
670
+ var key = row === null || row === void 0 ? void 0 : row[config === null || config === void 0 ? void 0 : config.x];
671
+ if (isNotEmpty(key) && !map.has(key)) {
672
+ map.set(key, idx++);
461
673
  }
462
- )
463
- )
464
- ),
465
- isChartList ? /* @__PURE__ */ React.createElement(
466
- Dropdown,
467
- {
468
- key: "dropdown",
469
- menu: {
470
- items: new Array(4).fill(0).map((_, i) => {
471
- return {
472
- key: i + 1,
473
- label: i + 1,
474
- onClick: () => {
475
- onColumnLengthChange == null ? void 0 : onColumnLengthChange(i + 1);
674
+ });
675
+ return map;
676
+ };
677
+ var getFieldValue = function(row, field) {
678
+ if (field && isNotEmpty(row[field])) {
679
+ return String(row[field]);
680
+ }
681
+ return undefined;
682
+ };
683
+ var convertFlatData = useMemo(function() {
684
+ var _getAxisTitles = getAxisTitles(), xTitle = _getAxisTitles.xTitle, yTitle = _getAxisTitles.yTitle;
685
+ var xIndexer = buildXIndexer();
686
+ return (chartData || []).map(function(row, i) {
687
+ var rawX = row === null || row === void 0 ? void 0 : row[config === null || config === void 0 ? void 0 : config.x];
688
+ var rawY = row === null || row === void 0 ? void 0 : row[config === null || config === void 0 ? void 0 : config.y];
689
+ var category = getFieldValue(row, groupBy);
690
+ var type = getFieldValue(row, colorLegend);
691
+ var filterLabel = getFieldValue(row, filterBy);
692
+ var _xIndexer_get;
693
+ var x = typeof rawX === 'number' ? rawX : isNotEmpty(rawX) ? String(rawX) : String((_xIndexer_get = xIndexer.get(rawX)) !== null && _xIndexer_get !== void 0 ? _xIndexer_get : i + 1);
694
+ var y = typeof rawY === 'number' ? rawY : isNotEmpty(rawY) ? String(rawY) : '';
695
+ return _object_spread({
696
+ x: x,
697
+ y: y,
698
+ xtitle: xTitle,
699
+ ytitle: yTitle
700
+ }, type ? {
701
+ type: type
702
+ } : {}, category ? {
703
+ category: category
704
+ } : {}, filterLabel ? {
705
+ filterLabel: filterLabel
706
+ } : {});
707
+ });
708
+ }, [
709
+ JSON.stringify(chartData),
710
+ JSON.stringify(config),
711
+ title,
712
+ groupBy,
713
+ colorLegend,
714
+ filterBy
715
+ ]);
716
+ var convertDonutData = useMemo(function() {
717
+ return (chartData || []).map(function(row) {
718
+ var category = getFieldValue(row, groupBy);
719
+ var _row_config_x;
720
+ var label = String((_row_config_x = row === null || row === void 0 ? void 0 : row[config === null || config === void 0 ? void 0 : config.x]) !== null && _row_config_x !== void 0 ? _row_config_x : '');
721
+ var value = toNumber(row === null || row === void 0 ? void 0 : row[config === null || config === void 0 ? void 0 : config.y], 0);
722
+ var filterLabel = getFieldValue(row, filterBy);
723
+ return _object_spread({
724
+ label: label,
725
+ value: value
726
+ }, category ? {
727
+ category: category
728
+ } : {}, filterLabel ? {
729
+ filterLabel: filterLabel
730
+ } : {});
731
+ });
732
+ }, [
733
+ JSON.stringify(chartData),
734
+ JSON.stringify(config),
735
+ title,
736
+ groupBy,
737
+ filterBy
738
+ ]);
739
+ React.useEffect(function() {
740
+ setChartType(props.chartType);
741
+ }, [
742
+ props.chartType
743
+ ]);
744
+ /**
745
+ * 图表配置
746
+ */ var getChartPopover = function() {
747
+ var _ChartMap_chartType_changeData, _ChartMap_chartType, _ChartMap_chartType1, _i18n_locale, _i18n_locale1, _i18n_locale2, _config_columns_filter, _config_columns, _config_columns_filter1, _config_columns1, _i18n_locale3;
748
+ return [
749
+ /*#__PURE__*/ React.createElement(Dropdown, {
750
+ key: "dropdown",
751
+ menu: {
752
+ items: ((_ChartMap_chartType = ChartMap[chartType]) === null || _ChartMap_chartType === void 0 ? void 0 : (_ChartMap_chartType_changeData = _ChartMap_chartType.changeData) === null || _ChartMap_chartType_changeData === void 0 ? void 0 : _ChartMap_chartType_changeData.map(function(key) {
753
+ var _i18n_locale, _ChartMap_key;
754
+ return {
755
+ key: key,
756
+ label: (i18n === null || i18n === void 0 ? void 0 : (_i18n_locale = i18n.locale) === null || _i18n_locale === void 0 ? void 0 : _i18n_locale[key + 'eChart']) || ((_ChartMap_key = ChartMap[key]) === null || _ChartMap_key === void 0 ? void 0 : _ChartMap_key.title),
757
+ onClick: function() {
758
+ setChartType(key);
759
+ }
760
+ };
761
+ })) || []
762
+ },
763
+ getPopupContainer: function() {
764
+ return document.body;
476
765
  }
477
- };
478
- })
479
- },
480
- getPopupContainer: () => document.body
481
- },
482
- /* @__PURE__ */ React.createElement(
483
- "span",
484
- {
485
- style: {
486
- fontSize: 12,
487
- display: "flex",
488
- alignItems: "center",
489
- gap: 4,
490
- border: "1px solid #f0f0f0",
491
- padding: "4px 12px",
492
- borderRadius: "1em"
493
- }
494
- },
495
- columnLength,
496
- " ",
497
- ((_d = i18n == null ? void 0 : i18n.locale) == null ? void 0 : _d.columns) || "列",
498
- /* @__PURE__ */ React.createElement(
499
- DownOutlined,
500
- {
501
- style: {
502
- fontSize: 8
503
- }
504
- }
505
- )
506
- )
507
- ) : null,
508
- /* @__PURE__ */ React.createElement(
509
- Popover,
510
- {
511
- arrow: false,
512
- styles: {
513
- body: {
514
- padding: 8
515
- }
516
- },
517
- key: "config",
518
- title: ((_e = i18n == null ? void 0 : i18n.locale) == null ? void 0 : _e.configChart) || "配置图表",
519
- trigger: "click",
520
- getPopupContainer: () => document.body,
521
- content: /* @__PURE__ */ React.createElement(ConfigProvider, { componentSize: "small" }, /* @__PURE__ */ React.createElement(
522
- ProForm,
523
- {
524
- submitter: {
525
- searchConfig: {
526
- submitText: ((_f = i18n == null ? void 0 : i18n.locale) == null ? void 0 : _f.updateChart) || "更新"
766
+ }, /*#__PURE__*/ React.createElement("span", {
767
+ style: {
768
+ fontSize: 12,
769
+ display: 'flex',
770
+ alignItems: 'center',
771
+ gap: 4,
772
+ border: '1px solid #f0f0f0',
773
+ padding: '4px 12px',
774
+ borderRadius: '1em'
527
775
  }
528
- },
529
- style: {
530
- width: 300
531
- },
532
- initialValues: config,
533
- onFinish: (values) => {
534
- setConfig(__spreadValues(__spreadValues({}, props.config), values));
535
- setRenderKey((k) => k + 1);
536
- }
537
- },
538
- /* @__PURE__ */ React.createElement(
539
- "div",
540
- {
776
+ }, (_ChartMap_chartType1 = ChartMap[chartType]) === null || _ChartMap_chartType1 === void 0 ? void 0 : _ChartMap_chartType1.title, /*#__PURE__*/ React.createElement(DownOutlined, {
541
777
  style: {
542
- maxHeight: "70vh",
543
- overflow: "auto"
778
+ fontSize: 8
544
779
  }
545
- },
546
- /* @__PURE__ */ React.createElement(
547
- "div",
548
- {
549
- style: {
550
- display: "flex",
551
- gap: 8
552
- }
780
+ }))),
781
+ isChartList ? /*#__PURE__*/ React.createElement(Dropdown, {
782
+ key: "dropdown",
783
+ menu: {
784
+ items: new Array(4).fill(0).map(function(_, i) {
785
+ return {
786
+ key: i + 1,
787
+ label: i + 1,
788
+ onClick: function() {
789
+ onColumnLengthChange === null || onColumnLengthChange === void 0 ? void 0 : onColumnLengthChange(i + 1);
790
+ }
791
+ };
792
+ })
793
+ },
794
+ getPopupContainer: function() {
795
+ return document.body;
796
+ }
797
+ }, /*#__PURE__*/ React.createElement("span", {
798
+ style: {
799
+ fontSize: 12,
800
+ display: 'flex',
801
+ alignItems: 'center',
802
+ gap: 4,
803
+ border: '1px solid #f0f0f0',
804
+ padding: '4px 12px',
805
+ borderRadius: '1em'
806
+ }
807
+ }, columnLength, " ", (i18n === null || i18n === void 0 ? void 0 : (_i18n_locale = i18n.locale) === null || _i18n_locale === void 0 ? void 0 : _i18n_locale.columns) || '列', /*#__PURE__*/ React.createElement(DownOutlined, {
808
+ style: {
809
+ fontSize: 8
810
+ }
811
+ }))) : null,
812
+ /*#__PURE__*/ React.createElement(Popover, {
813
+ arrow: false,
814
+ styles: {
815
+ body: {
816
+ padding: 8
817
+ }
818
+ },
819
+ key: "config",
820
+ title: (i18n === null || i18n === void 0 ? void 0 : (_i18n_locale1 = i18n.locale) === null || _i18n_locale1 === void 0 ? void 0 : _i18n_locale1.configChart) || '配置图表',
821
+ trigger: 'click',
822
+ getPopupContainer: function() {
823
+ return document.body;
553
824
  },
554
- /* @__PURE__ */ React.createElement(
555
- ProFormSelect,
556
- {
825
+ content: /*#__PURE__*/ React.createElement(ConfigProvider, {
826
+ componentSize: "small"
827
+ }, /*#__PURE__*/ React.createElement(ProForm, {
828
+ submitter: {
829
+ searchConfig: {
830
+ submitText: (i18n === null || i18n === void 0 ? void 0 : (_i18n_locale2 = i18n.locale) === null || _i18n_locale2 === void 0 ? void 0 : _i18n_locale2.updateChart) || '更新'
831
+ }
832
+ },
833
+ style: {
834
+ width: 300
835
+ },
836
+ initialValues: config,
837
+ onFinish: function(values) {
838
+ setConfig(_object_spread({}, props.config, values));
839
+ setRenderKey(function(k) {
840
+ return k + 1;
841
+ });
842
+ }
843
+ }, /*#__PURE__*/ React.createElement("div", {
844
+ style: {
845
+ maxHeight: '70vh',
846
+ overflow: 'auto'
847
+ }
848
+ }, /*#__PURE__*/ React.createElement("div", {
849
+ style: {
850
+ display: 'flex',
851
+ gap: 8
852
+ }
853
+ }, /*#__PURE__*/ React.createElement(ProFormSelect, {
557
854
  label: "X",
558
855
  name: "x",
559
856
  fieldProps: {
560
- onClick: (e) => {
561
- e.stopPropagation();
562
- }
857
+ onClick: function(e) {
858
+ e.stopPropagation();
859
+ }
563
860
  },
564
- options: (_h = (_g = config.columns) == null ? void 0 : _g.filter((item) => item.title)) == null ? void 0 : _h.map((item) => {
565
- return {
566
- label: item.title,
567
- value: item.dataIndex
568
- };
861
+ options: (_config_columns = config.columns) === null || _config_columns === void 0 ? void 0 : (_config_columns_filter = _config_columns.filter(function(item) {
862
+ return item.title;
863
+ })) === null || _config_columns_filter === void 0 ? void 0 : _config_columns_filter.map(function(item) {
864
+ return {
865
+ label: item.title,
866
+ value: item.dataIndex
867
+ };
569
868
  })
570
- }
571
- ),
572
- /* @__PURE__ */ React.createElement(
573
- ProFormSelect,
574
- {
869
+ }), /*#__PURE__*/ React.createElement(ProFormSelect, {
575
870
  name: "y",
576
871
  label: "Y",
577
872
  fieldProps: {
578
- onClick: (e) => {
579
- e.stopPropagation();
580
- }
873
+ onClick: function(e) {
874
+ e.stopPropagation();
875
+ }
581
876
  },
582
- options: (_j = (_i = config.columns) == null ? void 0 : _i.filter((item) => item.title)) == null ? void 0 : _j.map((item) => {
583
- return {
584
- label: item.title,
585
- value: item.dataIndex
586
- };
877
+ options: (_config_columns1 = config.columns) === null || _config_columns1 === void 0 ? void 0 : (_config_columns_filter1 = _config_columns1.filter(function(item) {
878
+ return item.title;
879
+ })) === null || _config_columns_filter1 === void 0 ? void 0 : _config_columns_filter1.map(function(item) {
880
+ return {
881
+ label: item.title,
882
+ value: item.dataIndex
883
+ };
587
884
  })
588
- }
589
- )
590
- )
591
- )
592
- ))
593
- },
594
- /* @__PURE__ */ React.createElement(
595
- ActionIconBox,
596
- {
597
- title: ((_k = i18n == null ? void 0 : i18n.locale) == null ? void 0 : _k.configChart) || "配置图表",
598
- onClick: () => setRenderKey((k) => k + 1)
599
- },
600
- /* @__PURE__ */ React.createElement(SettingOutlined, { style: { color: "rgba(0, 25, 61, 0.3255)" } })
601
- )
602
- )
603
- ].filter((item) => !!item);
604
- };
605
- const toolBar = getChartPopover();
606
- const chartDom = useMemo(() => {
607
- if (typeof window === "undefined")
608
- return null;
609
- if (false)
610
- return null;
611
- if (window == null ? void 0 : window.notRenderChart)
612
- return null;
613
- if (chartType === "table") {
614
- return /* @__PURE__ */ React.createElement(
615
- "div",
616
- {
617
- key: config == null ? void 0 : config.index,
618
- contentEditable: false,
619
- style: {
620
- margin: 12,
621
- overflow: "auto",
622
- border: "1px solid #eee",
623
- borderRadius: "0.5em",
624
- flex: 1,
625
- maxWidth: "calc(100% - 32px)",
626
- maxHeight: 400,
627
- userSelect: "none"
628
- }
629
- },
630
- /* @__PURE__ */ React.createElement(
631
- Table,
632
- {
633
- size: "small",
634
- dataSource: chartData,
635
- columns: config == null ? void 0 : config.columns,
636
- pagination: false,
637
- rowKey: (record) => record.key
638
- }
639
- )
640
- );
641
- }
642
- if (chartType === "descriptions" || renderDescriptionsFallback) {
643
- return /* @__PURE__ */ React.createElement(
644
- "div",
645
- {
646
- key: config == null ? void 0 : config.index,
647
- style: {
648
- display: "flex",
649
- flexDirection: "column",
650
- gap: 8
651
- }
652
- },
653
- chartData.map((row, rowIndex) => {
654
- var _a;
655
- return /* @__PURE__ */ React.createElement(
656
- Descriptions,
657
- {
658
- bordered: true,
659
- key: `${config == null ? void 0 : config.index}-${rowIndex}`,
660
- column: {
661
- xxl: 2,
662
- xl: 2,
663
- lg: 2,
664
- md: 2,
665
- sm: 1,
666
- xs: 1
667
- },
668
- items: (_a = config == null ? void 0 : config.columns) == null ? void 0 : _a.map((column) => {
669
- if (!column.title || !column.dataIndex)
670
- return null;
671
- return {
672
- label: column.title || "",
673
- children: row[column.dataIndex]
674
- };
675
- }).filter((item) => !!item)
676
- }
677
- );
678
- })
679
- );
680
- }
681
- if (shouldLoadRuntime && isIntersecting) {
682
- return /* @__PURE__ */ React.createElement(
683
- Suspense,
684
- {
685
- fallback: /* @__PURE__ */ React.createElement(ChartRuntimeFallback, { height: (config == null ? void 0 : config.height) || 240 })
885
+ })))))
886
+ }, /*#__PURE__*/ React.createElement(ActionIconBox, {
887
+ title: (i18n === null || i18n === void 0 ? void 0 : (_i18n_locale3 = i18n.locale) === null || _i18n_locale3 === void 0 ? void 0 : _i18n_locale3.configChart) || '配置图表',
888
+ onClick: function() {
889
+ return setRenderKey(function(k) {
890
+ return k + 1;
891
+ });
892
+ }
893
+ }, /*#__PURE__*/ React.createElement(SettingOutlined, {
894
+ style: {
895
+ color: 'rgba(0, 25, 61, 0.3255)'
896
+ }
897
+ })))
898
+ ].filter(function(item) {
899
+ return !!item;
900
+ });
901
+ };
902
+ var toolBar = getChartPopover();
903
+ var chartDom = useMemo(function() {
904
+ var _window;
905
+ if (typeof window === 'undefined') return null;
906
+ if (process.env.NODE_ENV === 'test') return null;
907
+ //@ts-ignore
908
+ if ((_window = window) === null || _window === void 0 ? void 0 : _window.notRenderChart) return null;
909
+ if (chartType === 'table') {
910
+ return /*#__PURE__*/ React.createElement("div", {
911
+ key: config === null || config === void 0 ? void 0 : config.index,
912
+ contentEditable: false,
913
+ style: {
914
+ margin: 12,
915
+ overflow: 'auto',
916
+ border: '1px solid #eee',
917
+ borderRadius: '0.5em',
918
+ flex: 1,
919
+ maxWidth: 'calc(100% - 32px)',
920
+ maxHeight: 400,
921
+ userSelect: 'none'
922
+ }
923
+ }, /*#__PURE__*/ React.createElement(Table, {
924
+ size: "small",
925
+ dataSource: chartData,
926
+ columns: config === null || config === void 0 ? void 0 : config.columns,
927
+ pagination: false,
928
+ rowKey: function(record) {
929
+ return record.key;
930
+ }
931
+ }));
932
+ }
933
+ if (chartType === 'descriptions' || renderDescriptionsFallback) {
934
+ return /*#__PURE__*/ React.createElement("div", {
935
+ key: config === null || config === void 0 ? void 0 : config.index,
936
+ style: {
937
+ display: 'flex',
938
+ flexDirection: 'column',
939
+ gap: 8
940
+ }
941
+ }, chartData.map(function(row, rowIndex) {
942
+ var _config_columns;
943
+ return /*#__PURE__*/ React.createElement(Descriptions, {
944
+ bordered: true,
945
+ key: "".concat(config === null || config === void 0 ? void 0 : config.index, "-").concat(rowIndex),
946
+ column: {
947
+ xxl: 2,
948
+ xl: 2,
949
+ lg: 2,
950
+ md: 2,
951
+ sm: 1,
952
+ xs: 1
953
+ },
954
+ items: config === null || config === void 0 ? void 0 : (_config_columns = config.columns) === null || _config_columns === void 0 ? void 0 : _config_columns.map(function(column) {
955
+ if (!column.title || !column.dataIndex) return null;
956
+ return {
957
+ label: column.title || '',
958
+ children: row[column.dataIndex]
959
+ };
960
+ }).filter(function(item) {
961
+ return !!item;
962
+ })
963
+ });
964
+ }));
965
+ }
966
+ if (shouldLoadRuntime && isIntersecting) {
967
+ return /*#__PURE__*/ React.createElement(Suspense, {
968
+ fallback: /*#__PURE__*/ React.createElement(ChartRuntimeFallback, {
969
+ height: (config === null || config === void 0 ? void 0 : config.height) || 240
970
+ })
971
+ }, /*#__PURE__*/ React.createElement(ChartRuntimeRenderer, {
972
+ chartType: chartType,
973
+ convertDonutData: convertDonutData,
974
+ convertFlatData: convertFlatData,
975
+ config: config,
976
+ renderKey: renderKey,
977
+ title: title,
978
+ dataTime: dataTime,
979
+ toolBar: toolBar,
980
+ filterBy: filterBy,
981
+ groupBy: groupBy,
982
+ colorLegend: colorLegend,
983
+ chartData: chartData,
984
+ getFieldValue: getFieldValue
985
+ }));
986
+ }
987
+ if (shouldLoadRuntime && !isIntersecting) {
988
+ return /*#__PURE__*/ React.createElement(ChartRuntimeFallback, {
989
+ height: (config === null || config === void 0 ? void 0 : config.height) || 240
990
+ });
991
+ }
992
+ return null;
993
+ }, [
994
+ chartType,
995
+ JSON.stringify(chartData),
996
+ JSON.stringify(config),
997
+ renderKey,
998
+ toolBar,
999
+ convertDonutData,
1000
+ convertFlatData,
1001
+ title,
1002
+ dataTime,
1003
+ filterBy,
1004
+ groupBy,
1005
+ colorLegend,
1006
+ isIntersecting,
1007
+ shouldLoadRuntime,
1008
+ renderDescriptionsFallback
1009
+ ]);
1010
+ return /*#__PURE__*/ React.createElement("div", {
1011
+ ref: containerRef,
1012
+ style: {
1013
+ width: '100%'
686
1014
  },
687
- /* @__PURE__ */ React.createElement(
688
- ChartRuntimeRenderer,
689
- {
690
- chartType,
691
- convertDonutData,
692
- convertFlatData,
693
- config,
694
- renderKey,
695
- title,
696
- dataTime,
697
- toolBar,
698
- filterBy,
699
- groupBy,
700
- colorLegend,
701
- chartData,
702
- getFieldValue
703
- }
704
- )
705
- );
706
- }
707
- if (shouldLoadRuntime && !isIntersecting) {
708
- return /* @__PURE__ */ React.createElement(ChartRuntimeFallback, { height: (config == null ? void 0 : config.height) || 240 });
709
- }
710
- return null;
711
- }, [
712
- chartType,
713
- JSON.stringify(chartData),
714
- JSON.stringify(config),
715
- renderKey,
716
- toolBar,
717
- convertDonutData,
718
- convertFlatData,
719
- title,
720
- dataTime,
721
- filterBy,
722
- groupBy,
723
- colorLegend,
724
- isIntersecting,
725
- shouldLoadRuntime,
726
- renderDescriptionsFallback
727
- ]);
728
- return /* @__PURE__ */ React.createElement("div", { ref: containerRef, style: { width: "100%" }, contentEditable: false }, chartDom);
729
- };
730
- export {
731
- ChartRender
1015
+ contentEditable: false
1016
+ }, chartDom);
732
1017
  };