@ant-design/agentic-ui 2.7.1 → 2.9.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 (583) 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 -268
  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.js +67 -26
  136. package/dist/Hooks/useRefFunction/index.js +76 -11
  137. package/dist/Hooks/useSpeechSynthesis.js +143 -99
  138. package/dist/Hooks/useStyle/index.js +95 -60
  139. package/dist/Hooks/useThrottleFn/index.js +41 -41
  140. package/dist/I18n/index.js +246 -109
  141. package/dist/I18n/locales.js +718 -711
  142. package/dist/Icons/animated/VoicePlayLottie/index.js +75 -46
  143. package/dist/Icons/animated/VoicingLottie/index.js +78 -47
  144. package/dist/MarkdownEditor/BaseMarkdownEditor.js +421 -349
  145. package/dist/MarkdownEditor/editor/Editor.js +1160 -843
  146. package/dist/MarkdownEditor/editor/components/CommentList/index.js +407 -239
  147. package/dist/MarkdownEditor/editor/components/CommentList/style.js +119 -89
  148. package/dist/MarkdownEditor/editor/components/ContributorAvatar/index.js +61 -63
  149. package/dist/MarkdownEditor/editor/components/ContributorAvatar/style.js +82 -52
  150. package/dist/MarkdownEditor/editor/components/LazyElement/index.js +208 -106
  151. package/dist/MarkdownEditor/editor/components/LazyElement/style.js +69 -42
  152. package/dist/MarkdownEditor/editor/components/fntTag/index.js +7 -11
  153. package/dist/MarkdownEditor/editor/components/fntTag/style.js +66 -36
  154. package/dist/MarkdownEditor/editor/components/index.js +0 -1
  155. package/dist/MarkdownEditor/editor/elements/Blockquote.js +95 -37
  156. package/dist/MarkdownEditor/editor/elements/Break.js +56 -25
  157. package/dist/MarkdownEditor/editor/elements/Card/index.js +131 -52
  158. package/dist/MarkdownEditor/editor/elements/Code.js +89 -67
  159. package/dist/MarkdownEditor/editor/elements/Comment/index.js +79 -50
  160. package/dist/MarkdownEditor/editor/elements/ErrorBoundary.js +117 -21
  161. package/dist/MarkdownEditor/editor/elements/FootnoteDefinition.js +83 -64
  162. package/dist/MarkdownEditor/editor/elements/FootnoteReference.js +115 -41
  163. package/dist/MarkdownEditor/editor/elements/Head.js +131 -67
  164. package/dist/MarkdownEditor/editor/elements/Hr.js +63 -38
  165. package/dist/MarkdownEditor/editor/elements/Image/index.js +636 -494
  166. package/dist/MarkdownEditor/editor/elements/InlineKatex.js +60 -44
  167. package/dist/MarkdownEditor/editor/elements/Katex.js +71 -55
  168. package/dist/MarkdownEditor/editor/elements/LinkCard/index.js +79 -175
  169. package/dist/MarkdownEditor/editor/elements/LinkCard/style.js +130 -100
  170. package/dist/MarkdownEditor/editor/elements/List/List.js +96 -69
  171. package/dist/MarkdownEditor/editor/elements/List/ListItem.js +422 -247
  172. package/dist/MarkdownEditor/editor/elements/List/index.js +1 -5
  173. package/dist/MarkdownEditor/editor/elements/List/style.js +131 -117
  174. package/dist/MarkdownEditor/editor/elements/Media.js +637 -519
  175. package/dist/MarkdownEditor/editor/elements/Mermaid.js +79 -54
  176. package/dist/MarkdownEditor/editor/elements/Paragraph.js +144 -83
  177. package/dist/MarkdownEditor/editor/elements/Schema.js +167 -128
  178. package/dist/MarkdownEditor/editor/elements/Table/ReadonlyTableComponent.js +211 -178
  179. package/dist/MarkdownEditor/editor/elements/Table/SimpleTable.js +73 -49
  180. package/dist/MarkdownEditor/editor/elements/Table/Table.js +285 -204
  181. package/dist/MarkdownEditor/editor/elements/Table/TableCellIndex/index.js +397 -280
  182. package/dist/MarkdownEditor/editor/elements/Table/TableCellIndex/style.js +126 -101
  183. package/dist/MarkdownEditor/editor/elements/Table/TableCellIndexSpacer/index.js +381 -276
  184. package/dist/MarkdownEditor/editor/elements/Table/TableCellIndexSpacer/style.js +120 -98
  185. package/dist/MarkdownEditor/editor/elements/Table/TableContext.js +64 -21
  186. package/dist/MarkdownEditor/editor/elements/Table/TableRowIndex/index.js +52 -42
  187. package/dist/MarkdownEditor/editor/elements/Table/TableRowIndex/style.js +69 -39
  188. package/dist/MarkdownEditor/editor/elements/Table/Td/index.js +126 -72
  189. package/dist/MarkdownEditor/editor/elements/Table/Td/style.js +85 -55
  190. package/dist/MarkdownEditor/editor/elements/Table/index.js +204 -105
  191. package/dist/MarkdownEditor/editor/elements/Table/style.js +244 -233
  192. package/dist/MarkdownEditor/editor/elements/Table/useScrollShadow.js +119 -62
  193. package/dist/MarkdownEditor/editor/elements/TagPopup/index.js +438 -276
  194. package/dist/MarkdownEditor/editor/elements/TagPopup/style.js +103 -77
  195. package/dist/MarkdownEditor/editor/elements/index.js +437 -424
  196. package/dist/MarkdownEditor/editor/parser/json-parse.js +38 -9
  197. package/dist/MarkdownEditor/editor/parser/parserMarkdownToSlateNode.js +1753 -1168
  198. package/dist/MarkdownEditor/editor/parser/parserMdToSchema.js +16 -20
  199. package/dist/MarkdownEditor/editor/parser/parserSlateNodeToMarkdown.js +1021 -606
  200. package/dist/MarkdownEditor/editor/parser/remarkParse.js +158 -102
  201. package/dist/MarkdownEditor/editor/plugins/catchError.js +78 -17
  202. package/dist/MarkdownEditor/editor/plugins/elements.js +458 -342
  203. package/dist/MarkdownEditor/editor/plugins/handlePaste.js +752 -300
  204. package/dist/MarkdownEditor/editor/plugins/hotKeyCommands/arrow.js +215 -129
  205. package/dist/MarkdownEditor/editor/plugins/hotKeyCommands/backspace.js +325 -180
  206. package/dist/MarkdownEditor/editor/plugins/hotKeyCommands/enter.js +576 -418
  207. package/dist/MarkdownEditor/editor/plugins/hotKeyCommands/match.js +157 -47
  208. package/dist/MarkdownEditor/editor/plugins/hotKeyCommands/tab.js +331 -209
  209. package/dist/MarkdownEditor/editor/plugins/index.js +0 -1
  210. package/dist/MarkdownEditor/editor/plugins/insertParsedHtmlNodes.js +1245 -507
  211. package/dist/MarkdownEditor/editor/plugins/parseMarkdownToNodesAndInsert.js +36 -24
  212. package/dist/MarkdownEditor/editor/plugins/useHighlight.js +267 -116
  213. package/dist/MarkdownEditor/editor/plugins/useKeyboard.js +234 -160
  214. package/dist/MarkdownEditor/editor/plugins/useOnchange.js +253 -92
  215. package/dist/MarkdownEditor/editor/plugins/withMarkdown.js +728 -439
  216. package/dist/MarkdownEditor/editor/store.js +1819 -1389
  217. package/dist/MarkdownEditor/editor/style.js +551 -506
  218. package/dist/MarkdownEditor/editor/tagStyles.js +43 -43
  219. package/dist/MarkdownEditor/editor/tools/DragHandle.js +56 -54
  220. package/dist/MarkdownEditor/editor/tools/InsertAutocomplete.js +1049 -732
  221. package/dist/MarkdownEditor/editor/tools/InsertLink.js +232 -181
  222. package/dist/MarkdownEditor/editor/tools/Leading.js +566 -303
  223. package/dist/MarkdownEditor/editor/tools/ToolBar/BaseBar.js +415 -377
  224. package/dist/MarkdownEditor/editor/tools/ToolBar/FloatBar.js +162 -125
  225. package/dist/MarkdownEditor/editor/tools/ToolBar/ReadonlyBaseBar.js +480 -258
  226. package/dist/MarkdownEditor/editor/tools/ToolBar/ToolBar.js +44 -44
  227. package/dist/MarkdownEditor/editor/tools/ToolBar/components/ClearFormatButton.js +20 -35
  228. package/dist/MarkdownEditor/editor/tools/ToolBar/components/ColorPickerButton.js +69 -73
  229. package/dist/MarkdownEditor/editor/tools/ToolBar/components/FormatButton.js +13 -19
  230. package/dist/MarkdownEditor/editor/tools/ToolBar/components/FormattingTools.js +34 -41
  231. package/dist/MarkdownEditor/editor/tools/ToolBar/components/HeadingDropdown.js +53 -47
  232. package/dist/MarkdownEditor/editor/tools/ToolBar/components/LinkButton.js +11 -19
  233. package/dist/MarkdownEditor/editor/tools/ToolBar/components/ToolBarItem.js +23 -43
  234. package/dist/MarkdownEditor/editor/tools/ToolBar/components/UndoRedoButtons.js +14 -25
  235. package/dist/MarkdownEditor/editor/tools/ToolBar/config/toolsConfig.js +139 -102
  236. package/dist/MarkdownEditor/editor/tools/ToolBar/floatBarStyle.js +95 -65
  237. package/dist/MarkdownEditor/editor/tools/ToolBar/hooks/useToolBarLogic.js +252 -161
  238. package/dist/MarkdownEditor/editor/tools/ToolBar/index.js +14 -24
  239. package/dist/MarkdownEditor/editor/tools/ToolBar/toolBarStyle.js +95 -65
  240. package/dist/MarkdownEditor/editor/tools/insertAutocompleteStyle.js +82 -52
  241. package/dist/MarkdownEditor/editor/types/Table.js +1 -0
  242. package/dist/MarkdownEditor/editor/utils/InlineChromiumBugfix.js +11 -16
  243. package/dist/MarkdownEditor/editor/utils/ace.js +136 -40
  244. package/dist/MarkdownEditor/editor/utils/docx/docxDeserializer.js +29 -32
  245. package/dist/MarkdownEditor/editor/utils/docx/index.js +0 -1
  246. package/dist/MarkdownEditor/editor/utils/docx/module.js +193 -164
  247. package/dist/MarkdownEditor/editor/utils/docx/utils.js +113 -98
  248. package/dist/MarkdownEditor/editor/utils/dom.js +119 -90
  249. package/dist/MarkdownEditor/editor/utils/editorUtils.js +1369 -906
  250. package/dist/MarkdownEditor/editor/utils/htmlToMarkdown.js +196 -184
  251. package/dist/MarkdownEditor/editor/utils/index.js +354 -215
  252. package/dist/MarkdownEditor/editor/utils/isMarkdown.js +56 -44
  253. package/dist/MarkdownEditor/editor/utils/keyboard.js +1229 -664
  254. package/dist/MarkdownEditor/editor/utils/markdownToHtml.js +294 -76
  255. package/dist/MarkdownEditor/editor/utils/media.js +274 -99
  256. package/dist/MarkdownEditor/editor/utils/path.js +22 -16
  257. package/dist/MarkdownEditor/editor/utils/performanceMonitor.js +370 -168
  258. package/dist/MarkdownEditor/editor/utils/useLocalState.js +96 -37
  259. package/dist/MarkdownEditor/el.js +1 -0
  260. package/dist/MarkdownEditor/hooks/editor.js +123 -41
  261. package/dist/MarkdownEditor/hooks/subscribe.js +18 -15
  262. package/dist/MarkdownEditor/index.js +118 -30
  263. package/dist/MarkdownEditor/plugin.js +2 -5
  264. package/dist/MarkdownEditor/style.js +96 -66
  265. package/dist/MarkdownEditor/types.js +1 -0
  266. package/dist/MarkdownEditor/utils/exportHtml.js +42 -83
  267. package/dist/MarkdownEditor/utils/native-table/index.js +0 -1
  268. package/dist/MarkdownEditor/utils/native-table/native-table-editor.js +337 -222
  269. package/dist/MarkdownEditor/utils/native-table/native-table-keyboard.js +201 -113
  270. package/dist/MarkdownInputField/AttachmentButton/AttachmentButtonPopover.js +86 -79
  271. package/dist/MarkdownInputField/AttachmentButton/AttachmentFileList/AttachmentFileIcon.js +62 -33
  272. package/dist/MarkdownInputField/AttachmentButton/AttachmentFileList/AttachmentFileListItem.js +147 -125
  273. package/dist/MarkdownInputField/AttachmentButton/AttachmentFileList/index.js +174 -129
  274. package/dist/MarkdownInputField/AttachmentButton/AttachmentFileList/style.js +263 -237
  275. package/dist/MarkdownInputField/AttachmentButton/index.js +465 -205
  276. package/dist/MarkdownInputField/AttachmentButton/style.js +143 -114
  277. package/dist/MarkdownInputField/AttachmentButton/types.js +3 -0
  278. package/dist/MarkdownInputField/AttachmentButton/utils.js +64 -34
  279. package/dist/MarkdownInputField/BeforeToolContainer/BeforeToolContainer.js +438 -404
  280. package/dist/MarkdownInputField/Enlargement/index.js +7 -17
  281. package/dist/MarkdownInputField/FileMapView/FileMapViewItem.js +193 -216
  282. package/dist/MarkdownInputField/FileMapView/index.js +387 -174
  283. package/dist/MarkdownInputField/FileMapView/style.js +281 -259
  284. package/dist/MarkdownInputField/FilePaste/index.js +239 -65
  285. package/dist/MarkdownInputField/FileUploadManager/index.js +460 -170
  286. package/dist/MarkdownInputField/MarkdownInputField.js +819 -549
  287. package/dist/MarkdownInputField/QuickActions/index.js +304 -134
  288. package/dist/MarkdownInputField/RefinePromptButton/index.js +24 -33
  289. package/dist/MarkdownInputField/RefinePromptButton/style.js +99 -73
  290. package/dist/MarkdownInputField/SendActions/index.js +179 -197
  291. package/dist/MarkdownInputField/SendButton/index.js +150 -110
  292. package/dist/MarkdownInputField/SendButton/style.js +95 -64
  293. package/dist/MarkdownInputField/SkillModeBar/hooks/index.js +3 -5
  294. package/dist/MarkdownInputField/SkillModeBar/hooks/useSkillModeState.js +51 -26
  295. package/dist/MarkdownInputField/SkillModeBar/index.js +119 -106
  296. package/dist/MarkdownInputField/SkillModeBar/style.js +124 -98
  297. package/dist/MarkdownInputField/Suggestion/index.js +391 -154
  298. package/dist/MarkdownInputField/TopOperatingArea/index.js +37 -44
  299. package/dist/MarkdownInputField/TopOperatingArea/style.js +98 -81
  300. package/dist/MarkdownInputField/VoiceInput/index.js +210 -82
  301. package/dist/MarkdownInputField/VoiceInput/style.js +85 -59
  302. package/dist/MarkdownInputField/VoiceInputManager/index.js +321 -94
  303. package/dist/MarkdownInputField/style.js +296 -233
  304. package/dist/Plugins/chart/AreaChart/index.js +541 -393
  305. package/dist/Plugins/chart/AreaChart/style.js +114 -90
  306. package/dist/Plugins/chart/BarChart/index.d.ts +4 -0
  307. package/dist/Plugins/chart/BarChart/index.js +865 -697
  308. package/dist/Plugins/chart/BarChart/style.js +114 -90
  309. package/dist/Plugins/chart/ChartAttrToolBar/ChartAttrToolBarStyle.js +82 -52
  310. package/dist/Plugins/chart/ChartAttrToolBar/index.js +94 -65
  311. package/dist/Plugins/chart/ChartMark/Area.js +176 -150
  312. package/dist/Plugins/chart/ChartMark/Bar.js +181 -152
  313. package/dist/Plugins/chart/ChartMark/Column.js +181 -151
  314. package/dist/Plugins/chart/ChartMark/Container.js +116 -75
  315. package/dist/Plugins/chart/ChartMark/Line.js +179 -151
  316. package/dist/Plugins/chart/ChartMark/Pie.js +79 -63
  317. package/dist/Plugins/chart/ChartMark/index.js +6 -13
  318. package/dist/Plugins/chart/ChartMark/useChart.js +1 -0
  319. package/dist/Plugins/chart/ChartRender.d.ts +2 -0
  320. package/dist/Plugins/chart/ChartRender.js +981 -705
  321. package/dist/Plugins/chart/ChartStatistic/index.js +47 -62
  322. package/dist/Plugins/chart/ChartStatistic/style.js +142 -143
  323. package/dist/Plugins/chart/ChartStatistic/utils.js +37 -27
  324. package/dist/Plugins/chart/DonutChart/Legend.js +94 -124
  325. package/dist/Plugins/chart/DonutChart/constants.js +4 -11
  326. package/dist/Plugins/chart/DonutChart/hooks.js +183 -112
  327. package/dist/Plugins/chart/DonutChart/index.js +588 -516
  328. package/dist/Plugins/chart/DonutChart/plugins.js +47 -44
  329. package/dist/Plugins/chart/DonutChart/style.js +186 -175
  330. package/dist/Plugins/chart/DonutChart/types.js +1 -0
  331. package/dist/Plugins/chart/FunnelChart/index.js +844 -647
  332. package/dist/Plugins/chart/FunnelChart/style.js +97 -71
  333. package/dist/Plugins/chart/LineChart/index.js +516 -393
  334. package/dist/Plugins/chart/LineChart/style.js +114 -90
  335. package/dist/Plugins/chart/RadarChart/index.js +580 -582
  336. package/dist/Plugins/chart/RadarChart/style.js +122 -112
  337. package/dist/Plugins/chart/ScatterChart/index.js +633 -640
  338. package/dist/Plugins/chart/ScatterChart/style.js +108 -94
  339. package/dist/Plugins/chart/components/ChartContainer/ChartContainer.js +151 -80
  340. package/dist/Plugins/chart/components/ChartContainer/ChartErrorBoundary.js +160 -41
  341. package/dist/Plugins/chart/components/ChartContainer/ChartErrorBoundaryExample.js +80 -62
  342. package/dist/Plugins/chart/components/ChartContainer/index.js +2 -7
  343. package/dist/Plugins/chart/components/ChartContainer/style.js +121 -91
  344. package/dist/Plugins/chart/components/ChartFilter/ChartFilter.js +58 -90
  345. package/dist/Plugins/chart/components/ChartFilter/style.js +169 -154
  346. package/dist/Plugins/chart/components/ChartToolBar/ChartToolBar.js +54 -59
  347. package/dist/Plugins/chart/components/ChartToolBar/style.js +132 -117
  348. package/dist/Plugins/chart/components/icons/TimeIcon.js +20 -26
  349. package/dist/Plugins/chart/components/index.js +32 -34
  350. package/dist/Plugins/chart/const.js +34 -25
  351. package/dist/Plugins/chart/hooks/useChartStatistic.js +1 -0
  352. package/dist/Plugins/chart/index.js +436 -339
  353. package/dist/Plugins/chart/loadChartRuntime.js +209 -87
  354. package/dist/Plugins/chart/utils.js +311 -87
  355. package/dist/Plugins/code/CodeUI/Katex/Katex.js +112 -66
  356. package/dist/Plugins/code/components/AceEditor.js +334 -237
  357. package/dist/Plugins/code/components/AceEditorContainer.js +23 -32
  358. package/dist/Plugins/code/components/CodeContainer.js +41 -56
  359. package/dist/Plugins/code/components/CodeRenderer.js +202 -155
  360. package/dist/Plugins/code/components/CodeToolbar.js +137 -181
  361. package/dist/Plugins/code/components/HtmlPreview.js +19 -22
  362. package/dist/Plugins/code/components/LanguageSelector.js +162 -96
  363. package/dist/Plugins/code/components/LoadImage.js +145 -46
  364. package/dist/Plugins/code/components/ThinkBlock.js +38 -42
  365. package/dist/Plugins/code/components/index.js +13 -23
  366. package/dist/Plugins/code/hooks/index.js +7 -9
  367. package/dist/Plugins/code/hooks/useCodeEditorState.js +139 -62
  368. package/dist/Plugins/code/hooks/useRenderConditions.js +31 -23
  369. package/dist/Plugins/code/hooks/useToolbarConfig.js +44 -46
  370. package/dist/Plugins/code/index.js +141 -89
  371. package/dist/Plugins/code/langIconMap.js +400 -108
  372. package/dist/Plugins/code/langIcons/AbapIcon.js +90 -57
  373. package/dist/Plugins/code/langIcons/ActionscriptIcon.js +89 -56
  374. package/dist/Plugins/code/langIcons/AdaIcon.js +89 -52
  375. package/dist/Plugins/code/langIcons/ApacheIcon.js +205 -254
  376. package/dist/Plugins/code/langIcons/ApexIcon.js +108 -82
  377. package/dist/Plugins/code/langIcons/AplIcon.js +90 -54
  378. package/dist/Plugins/code/langIcons/ApplescriptIcon.js +89 -56
  379. package/dist/Plugins/code/langIcons/AstroIcon.js +91 -58
  380. package/dist/Plugins/code/langIcons/AwkIcon.js +98 -68
  381. package/dist/Plugins/code/langIcons/BallerinaIcon.js +92 -59
  382. package/dist/Plugins/code/langIcons/BatIcon.js +158 -229
  383. package/dist/Plugins/code/langIcons/BicepIcon.js +91 -58
  384. package/dist/Plugins/code/langIcons/BladeIcon.js +90 -58
  385. package/dist/Plugins/code/langIcons/CIcon.js +90 -55
  386. package/dist/Plugins/code/langIcons/CadenceIcon.js +89 -56
  387. package/dist/Plugins/code/langIcons/ClojureIcon.js +96 -75
  388. package/dist/Plugins/code/langIcons/CmakeIcon.js +93 -62
  389. package/dist/Plugins/code/langIcons/CobolIcon.js +99 -70
  390. package/dist/Plugins/code/langIcons/CodeqlIcon.js +96 -76
  391. package/dist/Plugins/code/langIcons/CoffeeIcon.js +89 -56
  392. package/dist/Plugins/code/langIcons/ConsoleIcon.js +89 -56
  393. package/dist/Plugins/code/langIcons/CppIcon.js +90 -55
  394. package/dist/Plugins/code/langIcons/CrystalIcon.js +90 -57
  395. package/dist/Plugins/code/langIcons/CsharpIcon.js +90 -59
  396. package/dist/Plugins/code/langIcons/CssIcon.js +89 -52
  397. package/dist/Plugins/code/langIcons/DIcon.js +90 -53
  398. package/dist/Plugins/code/langIcons/DartIcon.js +92 -71
  399. package/dist/Plugins/code/langIcons/DatabaseIcon.js +90 -57
  400. package/dist/Plugins/code/langIcons/DiffIcon.js +90 -57
  401. package/dist/Plugins/code/langIcons/DockerIcon.js +89 -56
  402. package/dist/Plugins/code/langIcons/DotenvIcon.js +94 -56
  403. package/dist/Plugins/code/langIcons/ElixirIcon.js +91 -58
  404. package/dist/Plugins/code/langIcons/ElmIcon.js +105 -58
  405. package/dist/Plugins/code/langIcons/ErbIcon.js +90 -54
  406. package/dist/Plugins/code/langIcons/ErlangIcon.js +89 -56
  407. package/dist/Plugins/code/langIcons/FsharpIcon.js +93 -62
  408. package/dist/Plugins/code/langIcons/GdscriptIcon.js +96 -88
  409. package/dist/Plugins/code/langIcons/GlslIcon.js +90 -58
  410. package/dist/Plugins/code/langIcons/GnuplotIcon.js +98 -77
  411. package/dist/Plugins/code/langIcons/GoIcon.js +114 -93
  412. package/dist/Plugins/code/langIcons/GraphqlIcon.js +106 -66
  413. package/dist/Plugins/code/langIcons/GroovyIcon.js +89 -56
  414. package/dist/Plugins/code/langIcons/HackIcon.js +97 -64
  415. package/dist/Plugins/code/langIcons/HamlIcon.js +89 -56
  416. package/dist/Plugins/code/langIcons/HandlebarsIcon.js +89 -56
  417. package/dist/Plugins/code/langIcons/HaskellIcon.js +93 -64
  418. package/dist/Plugins/code/langIcons/HclIcon.js +118 -93
  419. package/dist/Plugins/code/langIcons/HclLightIcon.js +118 -97
  420. package/dist/Plugins/code/langIcons/HjsonIcon.js +94 -62
  421. package/dist/Plugins/code/langIcons/HlslIcon.js +96 -76
  422. package/dist/Plugins/code/langIcons/HtmlIcon.js +89 -56
  423. package/dist/Plugins/code/langIcons/HttpIcon.js +89 -56
  424. package/dist/Plugins/code/langIcons/ImbaIcon.js +98 -65
  425. package/dist/Plugins/code/langIcons/IniIcon.js +90 -54
  426. package/dist/Plugins/code/langIcons/JavaIcon.js +89 -56
  427. package/dist/Plugins/code/langIcons/JavascriptIcon.js +89 -56
  428. package/dist/Plugins/code/langIcons/JinjaIcon.js +100 -68
  429. package/dist/Plugins/code/langIcons/Json5Icon.js +100 -82
  430. package/dist/Plugins/code/langIcons/JsonIcon.js +89 -56
  431. package/dist/Plugins/code/langIcons/JsonnetIcon.js +102 -86
  432. package/dist/Plugins/code/langIcons/JuliaIcon.js +105 -52
  433. package/dist/Plugins/code/langIcons/KotlinIcon.js +104 -74
  434. package/dist/Plugins/code/langIcons/KustoIcon.js +90 -57
  435. package/dist/Plugins/code/langIcons/LessIcon.js +90 -57
  436. package/dist/Plugins/code/langIcons/LiquidIcon.js +91 -58
  437. package/dist/Plugins/code/langIcons/LispIcon.js +89 -56
  438. package/dist/Plugins/code/langIcons/LuaIcon.js +93 -60
  439. package/dist/Plugins/code/langIcons/MakefileIcon.js +91 -58
  440. package/dist/Plugins/code/langIcons/MarkdownIcon.js +89 -56
  441. package/dist/Plugins/code/langIcons/MarkojsIcon.js +96 -73
  442. package/dist/Plugins/code/langIcons/MatlabIcon.js +93 -64
  443. package/dist/Plugins/code/langIcons/MdxIcon.js +90 -53
  444. package/dist/Plugins/code/langIcons/MermaidIcon.js +95 -64
  445. package/dist/Plugins/code/langIcons/MojoIcon.js +95 -62
  446. package/dist/Plugins/code/langIcons/NginxIcon.js +94 -61
  447. package/dist/Plugins/code/langIcons/NimIcon.js +91 -54
  448. package/dist/Plugins/code/langIcons/NixIcon.js +92 -56
  449. package/dist/Plugins/code/langIcons/ObjectiveCIcon.js +90 -59
  450. package/dist/Plugins/code/langIcons/ObjectiveCppIcon.js +90 -57
  451. package/dist/Plugins/code/langIcons/OcamlIcon.js +90 -61
  452. package/dist/Plugins/code/langIcons/PascalIcon.js +95 -55
  453. package/dist/Plugins/code/langIcons/Perl6Icon.js +299 -320
  454. package/dist/Plugins/code/langIcons/PerlIcon.js +89 -56
  455. package/dist/Plugins/code/langIcons/PhpIcon.js +89 -52
  456. package/dist/Plugins/code/langIcons/PostcssIcon.js +130 -113
  457. package/dist/Plugins/code/langIcons/PowershellIcon.js +91 -58
  458. package/dist/Plugins/code/langIcons/PrismaIcon.js +97 -68
  459. package/dist/Plugins/code/langIcons/PrologIcon.js +91 -58
  460. package/dist/Plugins/code/langIcons/ProtoIcon.js +94 -68
  461. package/dist/Plugins/code/langIcons/PugIcon.js +177 -145
  462. package/dist/Plugins/code/langIcons/PuppetIcon.js +96 -52
  463. package/dist/Plugins/code/langIcons/PurescriptIcon.js +93 -61
  464. package/dist/Plugins/code/langIcons/PythonIcon.js +90 -61
  465. package/dist/Plugins/code/langIcons/RIcon.js +89 -52
  466. package/dist/Plugins/code/langIcons/RazorIcon.js +90 -57
  467. package/dist/Plugins/code/langIcons/ReactIcon.js +89 -56
  468. package/dist/Plugins/code/langIcons/ReactTsIcon.js +90 -57
  469. package/dist/Plugins/code/langIcons/RubyIcon.js +91 -58
  470. package/dist/Plugins/code/langIcons/RustIcon.js +89 -56
  471. package/dist/Plugins/code/langIcons/SasIcon.js +89 -52
  472. package/dist/Plugins/code/langIcons/SassIcon.js +90 -57
  473. package/dist/Plugins/code/langIcons/ScalaIcon.js +96 -53
  474. package/dist/Plugins/code/langIcons/SchemeIcon.js +91 -58
  475. package/dist/Plugins/code/langIcons/ShaderlabIcon.js +89 -56
  476. package/dist/Plugins/code/langIcons/SolidityIcon.js +94 -52
  477. package/dist/Plugins/code/langIcons/SparqlIcon.js +94 -64
  478. package/dist/Plugins/code/langIcons/StataIcon.js +126 -108
  479. package/dist/Plugins/code/langIcons/StylusIcon.js +92 -59
  480. package/dist/Plugins/code/langIcons/SvelteIcon.js +91 -58
  481. package/dist/Plugins/code/langIcons/SwiftIcon.js +90 -57
  482. package/dist/Plugins/code/langIcons/SystemverilogIcon.js +115 -102
  483. package/dist/Plugins/code/langIcons/TclIcon.js +89 -52
  484. package/dist/Plugins/code/langIcons/TexIcon.js +99 -65
  485. package/dist/Plugins/code/langIcons/TomlIcon.js +94 -70
  486. package/dist/Plugins/code/langIcons/TwigIcon.js +89 -56
  487. package/dist/Plugins/code/langIcons/TypescriptIcon.js +93 -60
  488. package/dist/Plugins/code/langIcons/VerilogIcon.js +89 -56
  489. package/dist/Plugins/code/langIcons/VhdlIcon.js +94 -64
  490. package/dist/Plugins/code/langIcons/VimIcon.js +278 -420
  491. package/dist/Plugins/code/langIcons/VueIcon.js +92 -59
  492. package/dist/Plugins/code/langIcons/WebassemblyIcon.js +103 -76
  493. package/dist/Plugins/code/langIcons/WenyanIcon.js +104 -100
  494. package/dist/Plugins/code/langIcons/WgslIcon.js +93 -77
  495. package/dist/Plugins/code/langIcons/WolframlanguageIcon.js +100 -71
  496. package/dist/Plugins/code/langIcons/XmlIcon.js +89 -52
  497. package/dist/Plugins/code/langIcons/XslIcon.js +94 -66
  498. package/dist/Plugins/code/langIcons/YamlIcon.js +89 -56
  499. package/dist/Plugins/code/langIcons/ZigIcon.js +106 -81
  500. package/dist/Plugins/code/langIcons/index.js +128 -259
  501. package/dist/Plugins/code/utils/index.js +5 -5
  502. package/dist/Plugins/code/utils/langOptions.js +86 -11
  503. package/dist/Plugins/defaultPlugins.js +9 -13
  504. package/dist/Plugins/formatter/index.js +205 -105
  505. package/dist/Plugins/index.js +6 -2
  506. package/dist/Plugins/katex/InlineKatex.js +196 -107
  507. package/dist/Plugins/katex/Katex.js +139 -65
  508. package/dist/Plugins/katex/index.js +163 -103
  509. package/dist/Plugins/mermaid/Mermaid.d.ts +9 -4
  510. package/dist/Plugins/mermaid/Mermaid.js +475 -178
  511. package/dist/Plugins/mermaid/index.js +237 -142
  512. package/dist/Quote/index.js +112 -73
  513. package/dist/Quote/style.js +176 -160
  514. package/dist/Schema/SchemaEditor/AceEditorWrapper.js +163 -119
  515. package/dist/Schema/SchemaEditor/index.js +385 -275
  516. package/dist/Schema/SchemaEditor/style.js +261 -269
  517. package/dist/Schema/SchemaForm/index.js +443 -268
  518. package/dist/Schema/SchemaForm/types.js +1 -0
  519. package/dist/Schema/SchemaRenderer/index.js +973 -588
  520. package/dist/Schema/SchemaRenderer/templateEngine.js +106 -26
  521. package/dist/Schema/index.js +7 -11
  522. package/dist/Schema/types.js +1 -0
  523. package/dist/Schema/validator.js +74 -36
  524. package/dist/TaskList/index.js +197 -142
  525. package/dist/TaskList/style.js +143 -122
  526. package/dist/ThoughtChainList/CostMillis.js +88 -54
  527. package/dist/ThoughtChainList/DeepThink.js +187 -152
  528. package/dist/ThoughtChainList/DotAni/index.js +29 -14
  529. package/dist/ThoughtChainList/DotAni/style.js +82 -50
  530. package/dist/ThoughtChainList/FlipText/index.js +74 -30
  531. package/dist/ThoughtChainList/MarkdownEditor.js +126 -72
  532. package/dist/ThoughtChainList/RagRetrievalInfo.js +113 -145
  533. package/dist/ThoughtChainList/TableSql.js +413 -459
  534. package/dist/ThoughtChainList/ThoughtChainListItem.js +388 -222
  535. package/dist/ThoughtChainList/TitleInfo.js +189 -185
  536. package/dist/ThoughtChainList/ToolCall.js +429 -463
  537. package/dist/ThoughtChainList/WebSearch.js +192 -162
  538. package/dist/ThoughtChainList/index.js +449 -410
  539. package/dist/ThoughtChainList/style.js +253 -232
  540. package/dist/ThoughtChainList/types.js +1 -0
  541. package/dist/ToolUseBar/ToolUseBarItem.js +183 -139
  542. package/dist/ToolUseBar/ToolUseBarItemComponents.js +345 -276
  543. package/dist/ToolUseBar/ToolUseBarThink.js +335 -396
  544. package/dist/ToolUseBar/index.js +226 -113
  545. package/dist/ToolUseBar/style.js +334 -308
  546. package/dist/ToolUseBar/thinkStyle.js +350 -328
  547. package/dist/Types/common.js +1 -0
  548. package/dist/Types/index.js +4 -2
  549. package/dist/Types/message.js +1 -0
  550. package/dist/Utils/easings.js +9 -12
  551. package/dist/Utils/formatTime.js +41 -17
  552. package/dist/Utils/getScroll.js +41 -41
  553. package/dist/Utils/language.js +355 -150
  554. package/dist/Utils/proxySandbox/ProxySandbox.js +1637 -1076
  555. package/dist/Utils/proxySandbox/SecurityContextManager.js +607 -343
  556. package/dist/Utils/proxySandbox/index.js +554 -267
  557. package/dist/Utils/proxySandbox/types.js +187 -52
  558. package/dist/Utils/scrollTo.js +48 -56
  559. package/dist/Utils/throttleByAnimationFrame.js +46 -20
  560. package/dist/WelcomeMessage/index.js +106 -58
  561. package/dist/WelcomeMessage/style.js +80 -55
  562. package/dist/Workspace/Browser/index.js +102 -40
  563. package/dist/Workspace/Browser/style.js +62 -33
  564. package/dist/Workspace/File/DataSourceStrategy.js +419 -217
  565. package/dist/Workspace/File/FileComponent.js +1004 -791
  566. package/dist/Workspace/File/FileTypeProcessor.js +337 -184
  567. package/dist/Workspace/File/PreviewComponent.js +472 -532
  568. package/dist/Workspace/File/index.js +3 -10
  569. package/dist/Workspace/File/style.js +397 -424
  570. package/dist/Workspace/File/utils.js +160 -106
  571. package/dist/Workspace/HtmlPreview/index.js +238 -137
  572. package/dist/Workspace/HtmlPreview/style.js +99 -77
  573. package/dist/Workspace/RealtimeFollow/index.js +411 -413
  574. package/dist/Workspace/RealtimeFollow/style.js +299 -303
  575. package/dist/Workspace/Task/index.js +53 -35
  576. package/dist/Workspace/Task/style.js +99 -73
  577. package/dist/Workspace/index.js +332 -254
  578. package/dist/Workspace/style.js +165 -146
  579. package/dist/Workspace/types.js +471 -252
  580. package/dist/Workspace/utils/codeLanguageUtils.js +148 -129
  581. package/dist/Workspace/utils.js +28 -20
  582. package/dist/index.js +27 -17
  583. package/package.json +3 -2
@@ -1,741 +1,1017 @@
1
- var __defProp = Object.defineProperty;
2
- var __getOwnPropSymbols = Object.getOwnPropertySymbols;
3
- var __hasOwnProp = Object.prototype.hasOwnProperty;
4
- var __propIsEnum = Object.prototype.propertyIsEnumerable;
5
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
6
- var __spreadValues = (a, b) => {
7
- for (var prop in b || (b = {}))
8
- if (__hasOwnProp.call(b, prop))
9
- __defNormalProp(a, prop, b[prop]);
10
- if (__getOwnPropSymbols)
11
- for (var prop of __getOwnPropSymbols(b)) {
12
- if (__propIsEnum.call(b, prop))
13
- __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;
14
16
  }
15
- return a;
16
- };
17
-
18
- // src/Plugins/chart/ChartRender.tsx
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
+ });
36
+ };
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: []
137
+ };
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
+ }
19
223
  import { DownOutlined, SettingOutlined } from "@ant-design/icons";
20
224
  import { ProForm, ProFormSelect } from "@ant-design/pro-components";
21
225
  import { ConfigProvider, Descriptions, Dropdown, Popover, Table } from "antd";
22
- import React, { useContext, useMemo, useState } from "react";
226
+ import React, { lazy, Suspense, useContext, useMemo, useState } from "react";
23
227
  import { ActionIconBox } from "../../Components/ActionIconBox";
24
228
  import { Loading } from "../../Components/Loading";
25
229
  import { useIntersectionOnce } from "../../Hooks/useIntersectionOnce";
26
230
  import { I18nContext } from "../../I18n";
27
231
  import { loadChartRuntime } from "./loadChartRuntime";
28
232
  import { isNotEmpty, toNumber } from "./utils";
29
- var getChartMap = (i18n) => {
30
- var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k;
31
- return {
32
- pie: {
33
- title: ((_a = i18n == null ? void 0 : i18n.locale) == null ? void 0 : _a.pieChart) || "饼图",
34
- changeData: ["donut"]
35
- },
36
- donut: {
37
- title: ((_b = i18n == null ? void 0 : i18n.locale) == null ? void 0 : _b.donutChart) || "环形图",
38
- changeData: ["pie"]
39
- },
40
- bar: {
41
- title: ((_c = i18n == null ? void 0 : i18n.locale) == null ? void 0 : _c.barChart) || "条形图",
42
- changeData: ["column", "line", "area"]
43
- },
44
- line: {
45
- title: ((_d = i18n == null ? void 0 : i18n.locale) == null ? void 0 : _d.lineChart) || "折线图",
46
- changeData: ["column", "bar", "area"]
47
- },
48
- column: {
49
- title: ((_e = i18n == null ? void 0 : i18n.locale) == null ? void 0 : _e.columnChart) || "柱状图",
50
- changeData: ["bar", "line", "area"]
51
- },
52
- area: {
53
- title: ((_f = i18n == null ? void 0 : i18n.locale) == null ? void 0 : _f.areaChart) || "面积图",
54
- changeData: ["column", "bar", "line"]
55
- },
56
- radar: {
57
- title: ((_g = i18n == null ? void 0 : i18n.locale) == null ? void 0 : _g.radarChart) || "雷达图",
58
- changeData: []
59
- },
60
- scatter: {
61
- title: ((_h = i18n == null ? void 0 : i18n.locale) == null ? void 0 : _h.scatterChart) || "散点图",
62
- changeData: []
63
- },
64
- funnel: {
65
- title: ((_i = i18n == null ? void 0 : i18n.locale) == null ? void 0 : _i.funnelChart) || "漏斗图",
66
- changeData: []
67
- },
68
- table: {
69
- title: ((_j = i18n == null ? void 0 : i18n.locale) == null ? void 0 : _j.table) || "表格",
70
- changeData: ["column", "line", "area", "pie", "donut"]
71
- },
72
- descriptions: {
73
- title: ((_k = i18n == null ? void 0 : i18n.locale) == null ? void 0 : _k.descriptions) || "定义列表",
74
- changeData: ["column", "line", "area", "pie", "donut"]
75
- }
76
- };
77
- };
78
- var ChartRender = (props) => {
79
- const [chartType, setChartType] = useState(() => props.chartType);
80
- const {
81
- chartData,
82
- isChartList,
83
- onColumnLengthChange,
84
- columnLength,
85
- title,
86
- dataTime,
87
- groupBy,
88
- filterBy,
89
- colorLegend
90
- } = props;
91
- const i18n = useContext(I18nContext);
92
- const [config, setConfig] = useState(() => props.config);
93
- const [renderKey, setRenderKey] = useState(0);
94
- const [runtime, setRuntime] = useState(null);
95
- const [runtimeError, setRuntimeError] = useState(null);
96
- const [isRuntimeLoading, setRuntimeLoading] = useState(false);
97
- const containerRef = React.useRef(null);
98
- const isIntersecting = useIntersectionOnce(containerRef);
99
- const renderDescriptionsFallback = React.useMemo(() => {
100
- var _a;
101
- const columnCount = ((_a = config == null ? void 0 : config.columns) == null ? void 0 : _a.length) || 0;
102
- return chartData.length < 2 && columnCount > 8;
103
- }, [chartData, config == null ? void 0 : config.columns]);
104
- const shouldLoadRuntime = chartType !== "table" && chartType !== "descriptions" && !renderDescriptionsFallback;
105
- React.useEffect(() => {
106
- if (runtime)
107
- return;
108
- if (isRuntimeLoading)
109
- return;
110
- if (runtimeError)
111
- return;
112
- let cancelled = false;
113
- setRuntimeLoading(true);
114
- loadChartRuntime().then((module) => {
115
- if (cancelled)
116
- return;
117
- setRuntime(module);
118
- }).catch((error) => {
119
- if (cancelled)
120
- return;
121
- const message = error instanceof Error ? error.message : String(error);
122
- setRuntimeError(message);
123
- }).finally(() => {
124
- if (cancelled)
125
- return;
126
- setRuntimeLoading(false);
127
- });
128
- return () => {
129
- cancelled = true;
130
- };
131
- }, [
132
- shouldLoadRuntime,
133
- isIntersecting,
134
- runtime,
135
- isRuntimeLoading,
136
- runtimeError
137
- ]);
138
- const handleRetryRuntime = React.useCallback(() => {
139
- setRuntime(null);
140
- setRuntimeError(null);
141
- }, []);
142
- const ChartMap = useMemo(() => getChartMap(i18n), [i18n]);
143
- const getAxisTitles = () => {
144
- var _a, _b, _c, _d;
145
- const xCol = (_b = (_a = config == null ? void 0 : config.columns) == null ? void 0 : _a.find) == null ? void 0 : _b.call(
146
- _a,
147
- (c) => (c == null ? void 0 : c.dataIndex) === (config == null ? void 0 : config.x)
148
- );
149
- const yCol = (_d = (_c = config == null ? void 0 : config.columns) == null ? void 0 : _c.find) == null ? void 0 : _d.call(
150
- _c,
151
- (c) => (c == null ? void 0 : c.dataIndex) === (config == null ? void 0 : config.y)
152
- );
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;
153
261
  return {
154
- xTitle: (xCol == null ? void 0 : xCol.title) || String((config == null ? void 0 : config.x) || ""),
155
- 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
+ }
156
338
  };
157
- };
158
- const buildXIndexer = () => {
159
- const map = /* @__PURE__ */ new Map();
160
- let idx = 1;
161
- (chartData || []).forEach((row) => {
162
- const key = row == null ? void 0 : row[config == null ? void 0 : config.x];
163
- if (isNotEmpty(key) && !map.has(key)) {
164
- map.set(key, idx++);
165
- }
166
- });
167
- return map;
168
- };
169
- const getFieldValue = (row, field) => {
170
- if (field && isNotEmpty(row[field])) {
171
- 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
+ });
172
362
  }
173
- return void 0;
174
- };
175
- const convertFlatData = useMemo(() => {
176
- const { xTitle, yTitle } = getAxisTitles();
177
- const xIndexer = buildXIndexer();
178
- return (chartData || []).map((row, i) => {
179
- var _a;
180
- const rawX = row == null ? void 0 : row[config == null ? void 0 : config.x];
181
- const rawY = row == null ? void 0 : row[config == null ? void 0 : config.y];
182
- const category = getFieldValue(row, groupBy);
183
- const type = getFieldValue(row, colorLegend);
184
- const filterLabel = getFieldValue(row, filterBy);
185
- const x = typeof rawX === "number" ? rawX : isNotEmpty(rawX) ? String(rawX) : String((_a = xIndexer.get(rawX)) != null ? _a : i + 1);
186
- const y = typeof rawY === "number" ? rawY : isNotEmpty(rawY) ? String(rawY) : "";
187
- return __spreadValues(__spreadValues(__spreadValues({
188
- x,
189
- y,
190
- xtitle: xTitle,
191
- ytitle: yTitle
192
- }, type ? { type } : {}), category ? { category } : {}), filterLabel ? { filterLabel } : {});
193
- });
194
- }, [
195
- JSON.stringify(chartData),
196
- JSON.stringify(config),
197
- title,
198
- groupBy,
199
- colorLegend,
200
- filterBy
201
- ]);
202
- const convertDonutData = useMemo(() => {
203
- return (chartData || []).map((row) => {
204
- var _a;
205
- const category = getFieldValue(row, groupBy);
206
- const label = String((_a = row == null ? void 0 : row[config == null ? void 0 : config.x]) != null ? _a : "");
207
- const value = toNumber(row == null ? void 0 : row[config == null ? void 0 : config.y], 0);
208
- const filterLabel = getFieldValue(row, filterBy);
209
- return __spreadValues(__spreadValues({
210
- label,
211
- value
212
- }, category ? { category } : {}), filterLabel ? { filterLabel } : {});
213
- });
214
- }, [
215
- JSON.stringify(chartData),
216
- JSON.stringify(config),
217
- title,
218
- groupBy,
219
- filterBy
220
- ]);
221
- React.useEffect(() => {
222
- setChartType(props.chartType);
223
- }, [props.chartType]);
224
- const getChartPopover = () => {
225
- var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k;
226
- return [
227
- /* @__PURE__ */ React.createElement(
228
- Dropdown,
229
- {
230
- key: "dropdown",
231
- menu: {
232
- items: ((_b = (_a = ChartMap[chartType]) == null ? void 0 : _a.changeData) == null ? void 0 : _b.map((key) => {
233
- var _a2, _b2;
234
- return {
235
- key,
236
- label: ((_a2 = i18n == null ? void 0 : i18n.locale) == null ? void 0 : _a2[key + "eChart"]) || ((_b2 = ChartMap[key]) == null ? void 0 : _b2.title),
237
- onClick: () => {
238
- 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
239
371
  }
240
- };
241
- })) || []
242
- },
243
- 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'
244
564
  },
245
- /* @__PURE__ */ React.createElement(
246
- "span",
247
- {
248
- style: {
249
- fontSize: 12,
250
- display: "flex",
251
- alignItems: "center",
252
- gap: 4,
253
- border: "1px solid #f0f0f0",
254
- padding: "4px 12px",
255
- borderRadius: "1em"
256
- }
257
- },
258
- (_c = ChartMap[chartType]) == null ? void 0 : _c.title,
259
- /* @__PURE__ */ React.createElement(
260
- DownOutlined,
261
- {
262
- style: {
263
- fontSize: 8
264
- }
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++);
265
673
  }
266
- )
267
- )
268
- ),
269
- isChartList ? /* @__PURE__ */ React.createElement(
270
- Dropdown,
271
- {
272
- key: "dropdown",
273
- menu: {
274
- items: new Array(4).fill(0).map((_, i) => {
275
- return {
276
- key: i + 1,
277
- label: i + 1,
278
- onClick: () => {
279
- 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;
280
765
  }
281
- };
282
- })
283
- },
284
- getPopupContainer: () => document.body
285
- },
286
- /* @__PURE__ */ React.createElement(
287
- "span",
288
- {
289
- style: {
290
- fontSize: 12,
291
- display: "flex",
292
- alignItems: "center",
293
- gap: 4,
294
- border: "1px solid #f0f0f0",
295
- padding: "4px 12px",
296
- borderRadius: "1em"
297
- }
298
- },
299
- columnLength,
300
- " ",
301
- ((_d = i18n == null ? void 0 : i18n.locale) == null ? void 0 : _d.columns) || "列",
302
- /* @__PURE__ */ React.createElement(
303
- DownOutlined,
304
- {
305
- style: {
306
- fontSize: 8
307
- }
308
- }
309
- )
310
- )
311
- ) : null,
312
- /* @__PURE__ */ React.createElement(
313
- Popover,
314
- {
315
- arrow: false,
316
- styles: {
317
- body: {
318
- padding: 8
319
- }
320
- },
321
- key: "config",
322
- title: ((_e = i18n == null ? void 0 : i18n.locale) == null ? void 0 : _e.configChart) || "配置图表",
323
- trigger: "click",
324
- getPopupContainer: () => document.body,
325
- content: /* @__PURE__ */ React.createElement(ConfigProvider, { componentSize: "small" }, /* @__PURE__ */ React.createElement(
326
- ProForm,
327
- {
328
- submitter: {
329
- searchConfig: {
330
- 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'
331
775
  }
332
- },
333
- style: {
334
- width: 300
335
- },
336
- initialValues: config,
337
- onFinish: (values) => {
338
- setConfig(__spreadValues(__spreadValues({}, props.config), values));
339
- setRenderKey((k) => k + 1);
340
- }
341
- },
342
- /* @__PURE__ */ React.createElement(
343
- "div",
344
- {
776
+ }, (_ChartMap_chartType1 = ChartMap[chartType]) === null || _ChartMap_chartType1 === void 0 ? void 0 : _ChartMap_chartType1.title, /*#__PURE__*/ React.createElement(DownOutlined, {
345
777
  style: {
346
- maxHeight: "70vh",
347
- overflow: "auto"
778
+ fontSize: 8
348
779
  }
349
- },
350
- /* @__PURE__ */ React.createElement(
351
- "div",
352
- {
353
- style: {
354
- display: "flex",
355
- gap: 8
356
- }
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;
357
824
  },
358
- /* @__PURE__ */ React.createElement(
359
- ProFormSelect,
360
- {
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, {
361
854
  label: "X",
362
855
  name: "x",
363
856
  fieldProps: {
364
- onClick: (e) => {
365
- e.stopPropagation();
366
- }
857
+ onClick: function(e) {
858
+ e.stopPropagation();
859
+ }
367
860
  },
368
- options: (_h = (_g = config.columns) == null ? void 0 : _g.filter((item) => item.title)) == null ? void 0 : _h.map((item) => {
369
- return {
370
- label: item.title,
371
- value: item.dataIndex
372
- };
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
+ };
373
868
  })
374
- }
375
- ),
376
- /* @__PURE__ */ React.createElement(
377
- ProFormSelect,
378
- {
869
+ }), /*#__PURE__*/ React.createElement(ProFormSelect, {
379
870
  name: "y",
380
871
  label: "Y",
381
872
  fieldProps: {
382
- onClick: (e) => {
383
- e.stopPropagation();
384
- }
873
+ onClick: function(e) {
874
+ e.stopPropagation();
875
+ }
385
876
  },
386
- options: (_j = (_i = config.columns) == null ? void 0 : _i.filter((item) => item.title)) == null ? void 0 : _j.map((item) => {
387
- return {
388
- label: item.title,
389
- value: item.dataIndex
390
- };
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
+ };
391
884
  })
392
- }
393
- )
394
- )
395
- )
396
- ))
397
- },
398
- /* @__PURE__ */ React.createElement(
399
- ActionIconBox,
400
- {
401
- title: ((_k = i18n == null ? void 0 : i18n.locale) == null ? void 0 : _k.configChart) || "配置图表",
402
- onClick: () => setRenderKey((k) => k + 1)
403
- },
404
- /* @__PURE__ */ React.createElement(SettingOutlined, { style: { color: "rgba(0, 25, 61, 0.3255)" } })
405
- )
406
- )
407
- ].filter((item) => !!item);
408
- };
409
- const toolBar = getChartPopover();
410
- const chartDom = useMemo(() => {
411
- var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r;
412
- if (typeof window === "undefined")
413
- return null;
414
- if (false)
415
- return null;
416
- if (window == null ? void 0 : window.notRenderChart)
417
- return null;
418
- if (chartType === "table") {
419
- return /* @__PURE__ */ React.createElement(
420
- "div",
421
- {
422
- key: config == null ? void 0 : config.index,
423
- contentEditable: false,
424
- style: {
425
- margin: 12,
426
- overflow: "auto",
427
- border: "1px solid #eee",
428
- borderRadius: "0.5em",
429
- flex: 1,
430
- maxWidth: "calc(100% - 32px)",
431
- maxHeight: 400,
432
- userSelect: "none"
433
- }
434
- },
435
- /* @__PURE__ */ React.createElement(
436
- Table,
437
- {
438
- size: "small",
439
- dataSource: chartData,
440
- columns: config == null ? void 0 : config.columns,
441
- pagination: false,
442
- rowKey: (record) => record.key
443
- }
444
- )
445
- );
446
- }
447
- if (chartType === "descriptions" || renderDescriptionsFallback) {
448
- return /* @__PURE__ */ React.createElement(
449
- "div",
450
- {
451
- key: config == null ? void 0 : config.index,
452
- style: {
453
- display: "flex",
454
- flexDirection: "column",
455
- gap: 8
456
- }
457
- },
458
- chartData.map((row, rowIndex) => {
459
- var _a2;
460
- return /* @__PURE__ */ React.createElement(
461
- Descriptions,
462
- {
463
- bordered: true,
464
- key: `${config == null ? void 0 : config.index}-${rowIndex}`,
465
- column: {
466
- xxl: 2,
467
- xl: 2,
468
- lg: 2,
469
- md: 2,
470
- sm: 1,
471
- xs: 1
472
- },
473
- items: (_a2 = config == null ? void 0 : config.columns) == null ? void 0 : _a2.map((column) => {
474
- if (!column.title || !column.dataIndex)
475
- return null;
476
- return {
477
- label: column.title || "",
478
- children: row[column.dataIndex]
479
- };
480
- }).filter((item) => !!item)
481
- }
482
- );
483
- })
484
- );
485
- }
486
- if (!runtime && shouldLoadRuntime) {
487
- const height = (config == null ? void 0 : config.height) || 240;
488
- if (runtimeError) {
489
- return /* @__PURE__ */ React.createElement(
490
- "div",
491
- {
492
- style: {
493
- minHeight: height,
494
- display: "flex",
495
- flexDirection: "column",
496
- alignItems: "center",
497
- justifyContent: "center",
498
- width: "100%",
499
- gap: 8,
500
- color: "rgba(239, 68, 68, 0.8)"
501
- },
502
- role: "alert"
503
- },
504
- /* @__PURE__ */ React.createElement("span", null, runtimeError),
505
- /* @__PURE__ */ React.createElement(
506
- "button",
507
- {
508
- type: "button",
509
- onClick: handleRetryRuntime,
510
- style: {
511
- padding: "4px 12px",
512
- borderRadius: "0.5em",
513
- border: "1px solid rgba(239, 68, 68, 0.5)",
514
- background: "transparent",
515
- color: "rgba(239, 68, 68, 0.8)",
516
- cursor: "pointer"
517
- }
518
- },
519
- "重试加载"
520
- )
521
- );
522
- }
523
- return /* @__PURE__ */ React.createElement(
524
- "div",
525
- {
526
- style: {
527
- minHeight: height,
528
- display: "flex",
529
- alignItems: "center",
530
- justifyContent: "center",
531
- width: "100%",
532
- color: "#6B7280"
533
- },
534
- role: "status",
535
- "aria-live": "polite"
536
- },
537
- isRuntimeLoading || !isIntersecting ? /* @__PURE__ */ React.createElement(Loading, null) : null
538
- );
539
- }
540
- if (!runtime) {
541
- return null;
542
- }
543
- const {
544
- DonutChart,
545
- FunnelChart,
546
- AreaChart,
547
- BarChart,
548
- LineChart,
549
- RadarChart,
550
- ScatterChart
551
- } = runtime;
552
- if (chartType === "pie") {
553
- return /* @__PURE__ */ React.createElement(
554
- DonutChart,
555
- {
556
- key: `${config == null ? void 0 : config.index}-pie-${renderKey}`,
557
- data: convertDonutData,
558
- configs: [{ chartStyle: "pie", showLegend: true }],
559
- height: (config == null ? void 0 : config.height) || 400,
560
- title,
561
- showToolbar: true,
562
- dataTime,
563
- toolbarExtra: toolBar
564
- }
565
- );
566
- }
567
- if (chartType === "donut") {
568
- return /* @__PURE__ */ React.createElement(
569
- DonutChart,
570
- {
571
- key: `${config == null ? void 0 : config.index}-donut-${renderKey}`,
572
- data: convertDonutData,
573
- configs: [{ chartStyle: "donut", showLegend: true }],
574
- height: (config == null ? void 0 : config.height) || 400,
575
- title,
576
- showToolbar: true,
577
- dataTime,
578
- toolbarExtra: toolBar
579
- }
580
- );
581
- }
582
- if (chartType === "bar") {
583
- return /* @__PURE__ */ React.createElement(
584
- BarChart,
585
- {
586
- key: `${config == null ? void 0 : config.index}-bar-${renderKey}`,
587
- data: convertFlatData,
588
- height: (config == null ? void 0 : config.height) || 400,
589
- title: title || "",
590
- indexAxis: "y",
591
- stacked: (_a = config == null ? void 0 : config.rest) == null ? void 0 : _a.stacked,
592
- showLegend: (_c = (_b = config == null ? void 0 : config.rest) == null ? void 0 : _b.showLegend) != null ? _c : true,
593
- showGrid: (_e = (_d = config == null ? void 0 : config.rest) == null ? void 0 : _d.showGrid) != null ? _e : true,
594
- dataTime,
595
- toolbarExtra: toolBar
596
- }
597
- );
598
- }
599
- if (chartType === "line") {
600
- return /* @__PURE__ */ React.createElement(
601
- LineChart,
602
- {
603
- key: `${config == null ? void 0 : config.index}-line-${renderKey}`,
604
- data: convertFlatData,
605
- height: (config == null ? void 0 : config.height) || 400,
606
- title: title || "",
607
- showLegend: (_g = (_f = config == null ? void 0 : config.rest) == null ? void 0 : _f.showLegend) != null ? _g : true,
608
- showGrid: (_i = (_h = config == null ? void 0 : config.rest) == null ? void 0 : _h.showGrid) != null ? _i : true,
609
- dataTime,
610
- toolbarExtra: toolBar
611
- }
612
- );
613
- }
614
- if (chartType === "column") {
615
- return /* @__PURE__ */ React.createElement(
616
- BarChart,
617
- {
618
- key: `${config == null ? void 0 : config.index}-column-${renderKey}`,
619
- data: convertFlatData,
620
- height: (config == null ? void 0 : config.height) || 400,
621
- title: title || "",
622
- indexAxis: "x",
623
- stacked: (_j = config == null ? void 0 : config.rest) == null ? void 0 : _j.stacked,
624
- showLegend: (_l = (_k = config == null ? void 0 : config.rest) == null ? void 0 : _k.showLegend) != null ? _l : true,
625
- showGrid: (_n = (_m = config == null ? void 0 : config.rest) == null ? void 0 : _m.showGrid) != null ? _n : true,
626
- dataTime,
627
- toolbarExtra: toolBar
628
- }
629
- );
630
- }
631
- if (chartType === "area") {
632
- return /* @__PURE__ */ React.createElement(
633
- AreaChart,
634
- {
635
- key: `${config == null ? void 0 : config.index}-area-${renderKey}`,
636
- data: convertFlatData,
637
- height: (config == null ? void 0 : config.height) || 400,
638
- title: title || "",
639
- showLegend: (_p = (_o = config == null ? void 0 : config.rest) == null ? void 0 : _o.showLegend) != null ? _p : true,
640
- showGrid: (_r = (_q = config == null ? void 0 : config.rest) == null ? void 0 : _q.showGrid) != null ? _r : true,
641
- dataTime,
642
- toolbarExtra: toolBar
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
+ }));
643
932
  }
644
- );
645
- }
646
- if (chartType === "radar") {
647
- const radarData = (chartData || []).map((row, i) => {
648
- var _a2;
649
- const filterLabel = getFieldValue(row, filterBy);
650
- const category = getFieldValue(row, groupBy);
651
- const type = getFieldValue(row, colorLegend);
652
- return __spreadValues(__spreadValues(__spreadValues({
653
- label: String((_a2 = row == null ? void 0 : row[config == null ? void 0 : config.x]) != null ? _a2 : i + 1),
654
- score: row == null ? void 0 : row[config == null ? void 0 : config.y]
655
- }, category ? { category } : {}), type ? { type } : {}), filterLabel ? { filterLabel } : {});
656
- });
657
- return /* @__PURE__ */ React.createElement(
658
- RadarChart,
659
- {
660
- key: `${config == null ? void 0 : config.index}-radar-${renderKey}`,
661
- data: radarData,
662
- height: (config == null ? void 0 : config.height) || 400,
663
- title: title || "",
664
- dataTime,
665
- toolbarExtra: toolBar
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
+ }));
666
965
  }
667
- );
668
- }
669
- if (chartType === "scatter") {
670
- const scatterData = (chartData || []).map((row) => {
671
- const filterLabel = getFieldValue(row, filterBy);
672
- const category = getFieldValue(row, groupBy);
673
- const type = getFieldValue(row, colorLegend);
674
- return __spreadValues(__spreadValues(__spreadValues({
675
- x: row == null ? void 0 : row[config == null ? void 0 : config.x],
676
- y: row == null ? void 0 : row[config == null ? void 0 : config.y]
677
- }, category ? { category } : {}), type ? { type } : {}), filterLabel ? { filterLabel } : {});
678
- });
679
- return /* @__PURE__ */ React.createElement(
680
- ScatterChart,
681
- {
682
- key: `${config == null ? void 0 : config.index}-scatter-${renderKey}`,
683
- data: scatterData,
684
- height: (config == null ? void 0 : config.height) || 400,
685
- title: title || "",
686
- dataTime,
687
- toolbarExtra: toolBar
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
+ }));
688
986
  }
689
- );
690
- }
691
- if (chartType === "funnel") {
692
- const funnelData = (chartData || []).map((row, i) => {
693
- var _a2;
694
- const filterLabel = getFieldValue(row, filterBy);
695
- const category = getFieldValue(row, groupBy);
696
- const type = getFieldValue(row, colorLegend);
697
- return __spreadValues(__spreadValues(__spreadValues(__spreadValues({
698
- x: String((_a2 = row == null ? void 0 : row[config == null ? void 0 : config.x]) != null ? _a2 : i + 1),
699
- y: toNumber(row == null ? void 0 : row[config == null ? void 0 : config.y], 0)
700
- }, (row == null ? void 0 : row.ratio) !== void 0 ? { ratio: row.ratio } : {}), category ? { category } : {}), type ? { type } : {}), filterLabel ? { filterLabel } : {});
701
- });
702
- return /* @__PURE__ */ React.createElement(
703
- FunnelChart,
704
- {
705
- key: `${config == null ? void 0 : config.index}-funnel-${renderKey}`,
706
- data: funnelData,
707
- height: (config == null ? void 0 : config.height) || 400,
708
- title: title || "",
709
- dataTime,
710
- typeNames: { rate: "转化率", name: colorLegend || "转化" },
711
- toolbarExtra: toolBar
987
+ if (shouldLoadRuntime && !isIntersecting) {
988
+ return /*#__PURE__*/ React.createElement(ChartRuntimeFallback, {
989
+ height: (config === null || config === void 0 ? void 0 : config.height) || 240
990
+ });
712
991
  }
713
- );
714
- }
715
- return null;
716
- }, [
717
- chartType,
718
- JSON.stringify(chartData),
719
- JSON.stringify(config),
720
- renderKey,
721
- toolBar,
722
- convertDonutData,
723
- convertFlatData,
724
- title,
725
- dataTime,
726
- filterBy,
727
- groupBy,
728
- colorLegend,
729
- runtime,
730
- runtimeError,
731
- isRuntimeLoading,
732
- isIntersecting,
733
- shouldLoadRuntime,
734
- renderDescriptionsFallback,
735
- handleRetryRuntime
736
- ]);
737
- return /* @__PURE__ */ React.createElement("div", { ref: containerRef, style: { width: "100%" }, contentEditable: false }, chartDom);
738
- };
739
- export {
740
- ChartRender
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%'
1014
+ },
1015
+ contentEditable: false
1016
+ }, chartDom);
741
1017
  };