feffery_antd_components 0.4.3-rc6 → 0.4.3

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 (462) hide show
  1. package/CONTRIBUTING.md +4 -4
  2. package/DESCRIPTION +1 -1
  3. package/LICENSE +21 -21
  4. package/MANIFEST.in +6 -6
  5. package/Project.toml +1 -1
  6. package/README-en_US.md +73 -73
  7. package/README.md +87 -87
  8. package/bug_fix.py +21 -36
  9. package/fac-logo.svg +151 -151
  10. package/feffery_antd_components/AntdAccordion.py +7 -7
  11. package/feffery_antd_components/AntdAffix.py +2 -2
  12. package/feffery_antd_components/AntdAlert.py +5 -5
  13. package/feffery_antd_components/AntdAnchor.py +5 -5
  14. package/feffery_antd_components/AntdAvatar.py +4 -4
  15. package/feffery_antd_components/AntdAvatarGroup.py +1 -1
  16. package/feffery_antd_components/AntdBackTop.py +4 -4
  17. package/feffery_antd_components/AntdBadge.py +5 -5
  18. package/feffery_antd_components/AntdBreadcrumb.py +4 -4
  19. package/feffery_antd_components/AntdButton.py +14 -14
  20. package/feffery_antd_components/AntdCalendar.py +4 -4
  21. package/feffery_antd_components/AntdCard.py +5 -5
  22. package/feffery_antd_components/AntdCardGrid.py +3 -3
  23. package/feffery_antd_components/AntdCardMeta.py +1 -1
  24. package/feffery_antd_components/AntdCarousel.py +13 -13
  25. package/feffery_antd_components/AntdCascader.py +16 -17
  26. package/feffery_antd_components/AntdCenter.py +3 -3
  27. package/feffery_antd_components/AntdCheckCard.py +7 -7
  28. package/feffery_antd_components/AntdCheckCardGroup.py +9 -9
  29. package/feffery_antd_components/AntdCheckableTag.py +2 -2
  30. package/feffery_antd_components/AntdCheckbox.py +8 -8
  31. package/feffery_antd_components/AntdCheckboxGroup.py +6 -6
  32. package/feffery_antd_components/AntdCol.py +5 -5
  33. package/feffery_antd_components/AntdCollapse.py +8 -8
  34. package/feffery_antd_components/AntdColorPicker.py +13 -13
  35. package/feffery_antd_components/AntdComment.py +7 -7
  36. package/feffery_antd_components/AntdCompact.py +3 -3
  37. package/feffery_antd_components/AntdConfigProvider.py +6 -6
  38. package/feffery_antd_components/AntdContent.py +1 -1
  39. package/feffery_antd_components/AntdCopyText.py +2 -2
  40. package/feffery_antd_components/AntdCountdown.py +1 -1
  41. package/feffery_antd_components/AntdCountup.py +1 -1
  42. package/feffery_antd_components/AntdCustomSkeleton.py +5 -5
  43. package/feffery_antd_components/AntdDatePicker.py +13 -13
  44. package/feffery_antd_components/AntdDateRangePicker.py +12 -12
  45. package/feffery_antd_components/AntdDescriptionItem.py +2 -2
  46. package/feffery_antd_components/AntdDescriptions.py +6 -6
  47. package/feffery_antd_components/AntdDivider.py +5 -5
  48. package/feffery_antd_components/AntdDraggerUpload.py +15 -15
  49. package/feffery_antd_components/AntdDrawer.py +12 -12
  50. package/feffery_antd_components/AntdDropdown.py +18 -18
  51. package/feffery_antd_components/AntdEmpty.py +2 -2
  52. package/feffery_antd_components/AntdFlex.py +6 -6
  53. package/feffery_antd_components/AntdFloatButton.py +5 -5
  54. package/feffery_antd_components/AntdFloatButtonGroup.py +3 -3
  55. package/feffery_antd_components/AntdFooter.py +1 -1
  56. package/feffery_antd_components/AntdForm.py +10 -6
  57. package/feffery_antd_components/AntdFormItem.py +4 -4
  58. package/feffery_antd_components/AntdFormRender.py +2 -2
  59. package/feffery_antd_components/AntdHappyProvider.py +2 -2
  60. package/feffery_antd_components/AntdHeader.py +1 -1
  61. package/feffery_antd_components/AntdIcon.py +3 -3
  62. package/feffery_antd_components/AntdImage.py +6 -6
  63. package/feffery_antd_components/AntdImageGroup.py +6 -6
  64. package/feffery_antd_components/AntdInput.py +17 -17
  65. package/feffery_antd_components/AntdInputNumber.py +12 -12
  66. package/feffery_antd_components/AntdLayout.py +1 -1
  67. package/feffery_antd_components/AntdMentions.py +9 -9
  68. package/feffery_antd_components/AntdMenu.py +9 -9
  69. package/feffery_antd_components/AntdMessage.py +3 -3
  70. package/feffery_antd_components/AntdModal.py +28 -28
  71. package/feffery_antd_components/AntdNotification.py +9 -9
  72. package/feffery_antd_components/AntdOTP.py +7 -7
  73. package/feffery_antd_components/AntdPageHeader.py +5 -5
  74. package/feffery_antd_components/AntdPagination.py +15 -15
  75. package/feffery_antd_components/AntdParagraph.py +2 -2
  76. package/feffery_antd_components/AntdPictureUpload.py +28 -28
  77. package/feffery_antd_components/AntdPopconfirm.py +21 -21
  78. package/feffery_antd_components/AntdPopover.py +9 -9
  79. package/feffery_antd_components/AntdPopupCard.py +9 -9
  80. package/feffery_antd_components/AntdProgress.py +9 -9
  81. package/feffery_antd_components/AntdQRCode.py +10 -10
  82. package/feffery_antd_components/AntdRadioGroup.py +9 -9
  83. package/feffery_antd_components/AntdRate.py +9 -9
  84. package/feffery_antd_components/AntdResult.py +1 -1
  85. package/feffery_antd_components/AntdRibbon.py +2 -2
  86. package/feffery_antd_components/AntdRow.py +3 -3
  87. package/feffery_antd_components/AntdSegmented.py +9 -9
  88. package/feffery_antd_components/AntdSegmentedColoring.py +11 -11
  89. package/feffery_antd_components/AntdSelect.py +19 -19
  90. package/feffery_antd_components/AntdSider.py +6 -6
  91. package/feffery_antd_components/AntdSkeleton.py +11 -11
  92. package/feffery_antd_components/AntdSkeletonAvatar.py +3 -3
  93. package/feffery_antd_components/AntdSkeletonButton.py +5 -5
  94. package/feffery_antd_components/AntdSkeletonImage.py +1 -1
  95. package/feffery_antd_components/AntdSkeletonInput.py +3 -3
  96. package/feffery_antd_components/AntdSlider.py +10 -10
  97. package/feffery_antd_components/AntdSpace.py +4 -4
  98. package/feffery_antd_components/AntdSpin.py +7 -8
  99. package/feffery_antd_components/AntdSplitter.py +5 -5
  100. package/feffery_antd_components/AntdSpoiler.py +5 -5
  101. package/feffery_antd_components/AntdStatistic.py +2 -2
  102. package/feffery_antd_components/AntdSteps.py +8 -8
  103. package/feffery_antd_components/AntdSwitch.py +8 -8
  104. package/feffery_antd_components/AntdTable.py +64 -63
  105. package/feffery_antd_components/AntdTabs.py +13 -14
  106. package/feffery_antd_components/AntdTag.py +4 -4
  107. package/feffery_antd_components/AntdText.py +2 -2
  108. package/feffery_antd_components/AntdTimePicker.py +16 -16
  109. package/feffery_antd_components/AntdTimeRangePicker.py +15 -15
  110. package/feffery_antd_components/AntdTimeline.py +2 -2
  111. package/feffery_antd_components/AntdTitle.py +2 -2
  112. package/feffery_antd_components/AntdTooltip.py +9 -9
  113. package/feffery_antd_components/AntdTour.py +9 -9
  114. package/feffery_antd_components/AntdTransfer.py +11 -11
  115. package/feffery_antd_components/AntdTree.py +17 -17
  116. package/feffery_antd_components/AntdTreeSelect.py +18 -18
  117. package/feffery_antd_components/AntdUpload.py +18 -18
  118. package/feffery_antd_components/AntdWatermark.py +6 -6
  119. package/feffery_antd_components/Fragment.py +1 -1
  120. package/feffery_antd_components/__init__.py +88 -88
  121. package/feffery_antd_components/_icons.py +559 -559
  122. package/feffery_antd_components/alias.py +222 -222
  123. package/feffery_antd_components/async-antd_table.js +2 -2
  124. package/feffery_antd_components/async-data_display.js +1 -1
  125. package/feffery_antd_components/async-data_entry.js +3 -3
  126. package/feffery_antd_components/async-upload.js +2 -2
  127. package/feffery_antd_components/feffery_antd_components.min.js +8 -8
  128. package/feffery_antd_components/metadata.json +1 -1
  129. package/feffery_antd_components/package-info.json +111 -96
  130. package/feffery_antd_components/utils.py +262 -262
  131. package/package.json +111 -96
  132. package/pytest.ini +5 -5
  133. package/release-to-test-pypi.sh +1 -1
  134. package/requirements.txt +2 -2
  135. package/review_checklist.md +47 -47
  136. package/ruff.toml +4 -4
  137. package/setup.py +33 -33
  138. package/src/jl/'feffery'_antdform.jl +2 -1
  139. package/src/jl/'feffery'_antdtable.jl +7 -6
  140. package/src/lib/components/dataDisplay/AntdAccordion.react.js +232 -232
  141. package/src/lib/components/dataDisplay/AntdAvatar.react.js +177 -177
  142. package/src/lib/components/dataDisplay/AntdAvatarGroup.react.js +133 -133
  143. package/src/lib/components/dataDisplay/AntdBadge.react.js +196 -196
  144. package/src/lib/components/dataDisplay/AntdCarousel.react.js +187 -187
  145. package/src/lib/components/dataDisplay/AntdCheckableTag.react.js +105 -105
  146. package/src/lib/components/dataDisplay/AntdCollapse.react.js +239 -239
  147. package/src/lib/components/dataDisplay/AntdComment.react.js +251 -251
  148. package/src/lib/components/dataDisplay/AntdCountdown.react.js +143 -143
  149. package/src/lib/components/dataDisplay/AntdCountup.react.js +133 -133
  150. package/src/lib/components/dataDisplay/AntdEmpty.react.js +162 -162
  151. package/src/lib/components/dataDisplay/AntdImage.react.js +202 -202
  152. package/src/lib/components/dataDisplay/AntdImageGroup.react.js +181 -181
  153. package/src/lib/components/dataDisplay/AntdPopover.react.js +220 -220
  154. package/src/lib/components/dataDisplay/AntdQRCode.react.js +191 -191
  155. package/src/lib/components/dataDisplay/AntdRibbon.react.js +105 -105
  156. package/src/lib/components/dataDisplay/AntdSegmented.react.js +234 -234
  157. package/src/lib/components/dataDisplay/AntdSpoiler.react.js +154 -154
  158. package/src/lib/components/dataDisplay/AntdStatistic.react.js +168 -168
  159. package/src/lib/components/dataDisplay/AntdTable.react.js +1859 -1858
  160. package/src/lib/components/dataDisplay/AntdTabs.react.js +352 -352
  161. package/src/lib/components/dataDisplay/AntdTag.react.js +135 -135
  162. package/src/lib/components/dataDisplay/AntdTimeline.react.js +136 -136
  163. package/src/lib/components/dataDisplay/AntdTooltip.react.js +230 -230
  164. package/src/lib/components/dataDisplay/AntdTree.react.js +641 -641
  165. package/src/lib/components/dataDisplay/card/AntdCard.react.js +249 -249
  166. package/src/lib/components/dataDisplay/card/AntdCardGrid.react.js +99 -99
  167. package/src/lib/components/dataDisplay/card/AntdCardMeta.react.js +97 -97
  168. package/src/lib/components/dataDisplay/descriptions/AntdDescriptionItem.react.js +130 -130
  169. package/src/lib/components/dataDisplay/descriptions/AntdDescriptions.react.js +237 -237
  170. package/src/lib/components/dataEntry/AntdCalendar.react.js +205 -205
  171. package/src/lib/components/dataEntry/AntdCascader.react.js +435 -435
  172. package/src/lib/components/dataEntry/AntdCheckbox.react.js +182 -182
  173. package/src/lib/components/dataEntry/AntdCheckboxGroup.react.js +193 -193
  174. package/src/lib/components/dataEntry/AntdColorPicker.react.js +240 -240
  175. package/src/lib/components/dataEntry/AntdDatePicker.react.js +432 -432
  176. package/src/lib/components/dataEntry/AntdDateRangePicker.react.js +439 -439
  177. package/src/lib/components/dataEntry/AntdInput.react.js +423 -423
  178. package/src/lib/components/dataEntry/AntdInputNumber.react.js +329 -329
  179. package/src/lib/components/dataEntry/AntdMentions.react.js +236 -236
  180. package/src/lib/components/dataEntry/AntdOTP.react.js +186 -186
  181. package/src/lib/components/dataEntry/AntdRadioGroup.react.js +241 -241
  182. package/src/lib/components/dataEntry/AntdRate.react.js +199 -199
  183. package/src/lib/components/dataEntry/AntdSegmentedColoring.react.js +251 -251
  184. package/src/lib/components/dataEntry/AntdSelect.react.js +492 -492
  185. package/src/lib/components/dataEntry/AntdSlider.react.js +325 -325
  186. package/src/lib/components/dataEntry/AntdSwitch.react.js +210 -210
  187. package/src/lib/components/dataEntry/AntdTimePicker.react.js +344 -344
  188. package/src/lib/components/dataEntry/AntdTimeRangePicker.react.js +325 -325
  189. package/src/lib/components/dataEntry/AntdTransfer.react.js +317 -317
  190. package/src/lib/components/dataEntry/AntdTreeSelect.react.js +573 -573
  191. package/src/lib/components/dataEntry/check-card/AntdCheckCard.react.js +186 -186
  192. package/src/lib/components/dataEntry/check-card/AntdCheckCardGroup.react.js +214 -214
  193. package/src/lib/components/dataEntry/form/AntdForm.react.js +201 -194
  194. package/src/lib/components/dataEntry/form/AntdFormItem.react.js +210 -210
  195. package/src/lib/components/dataEntry/upload/AntdDraggerUpload.react.js +504 -504
  196. package/src/lib/components/dataEntry/upload/AntdPictureUpload.react.js +530 -530
  197. package/src/lib/components/dataEntry/upload/AntdUpload.react.js +537 -537
  198. package/src/lib/components/feedback/AntdAlert.react.js +185 -185
  199. package/src/lib/components/feedback/AntdDrawer.react.js +306 -306
  200. package/src/lib/components/feedback/AntdMessage.react.js +143 -143
  201. package/src/lib/components/feedback/AntdModal.react.js +530 -530
  202. package/src/lib/components/feedback/AntdNotification.react.js +211 -211
  203. package/src/lib/components/feedback/AntdPopconfirm.react.js +433 -433
  204. package/src/lib/components/feedback/AntdPopupCard.react.js +362 -362
  205. package/src/lib/components/feedback/AntdProgress.react.js +300 -300
  206. package/src/lib/components/feedback/AntdResult.react.js +125 -125
  207. package/src/lib/components/feedback/AntdSpin.react.js +273 -273
  208. package/src/lib/components/feedback/skeleton/AntdCustomSkeleton.react.js +197 -197
  209. package/src/lib/components/feedback/skeleton/AntdSkeleton.react.js +291 -291
  210. package/src/lib/components/feedback/skeleton/AntdSkeletonAvatar.react.js +109 -109
  211. package/src/lib/components/feedback/skeleton/AntdSkeletonButton.react.js +114 -114
  212. package/src/lib/components/feedback/skeleton/AntdSkeletonImage.react.js +82 -82
  213. package/src/lib/components/feedback/skeleton/AntdSkeletonInput.react.js +98 -98
  214. package/src/lib/components/formRender/AntdFormRender.react.js +945 -945
  215. package/src/lib/components/general/AntdButton.react.js +328 -328
  216. package/src/lib/components/general/AntdFloatButton.react.js +157 -157
  217. package/src/lib/components/general/AntdFloatButtonGroup.react.js +162 -162
  218. package/src/lib/components/general/AntdIcon.react.js +176 -176
  219. package/src/lib/components/general/typography/AntdParagraph.react.js +202 -202
  220. package/src/lib/components/general/typography/AntdText.react.js +194 -194
  221. package/src/lib/components/general/typography/AntdTitle.react.js +186 -186
  222. package/src/lib/components/icons.react.js +1136 -1136
  223. package/src/lib/components/layout/AntdCenter.react.js +122 -122
  224. package/src/lib/components/layout/AntdCompact.react.js +108 -108
  225. package/src/lib/components/layout/AntdContent.react.js +92 -92
  226. package/src/lib/components/layout/AntdDivider.react.js +219 -219
  227. package/src/lib/components/layout/AntdFlex.react.js +143 -143
  228. package/src/lib/components/layout/AntdFooter.react.js +92 -92
  229. package/src/lib/components/layout/AntdHeader.react.js +92 -92
  230. package/src/lib/components/layout/AntdLayout.react.js +90 -90
  231. package/src/lib/components/layout/AntdSider.react.js +162 -162
  232. package/src/lib/components/layout/AntdSpace.react.js +213 -213
  233. package/src/lib/components/layout/AntdSplitter.react.js +173 -173
  234. package/src/lib/components/layout/grid/AntdCol.react.js +349 -349
  235. package/src/lib/components/layout/grid/AntdRow.react.js +152 -152
  236. package/src/lib/components/locales.react.js +197 -197
  237. package/src/lib/components/navigation/AntdAnchor.react.js +208 -208
  238. package/src/lib/components/navigation/AntdBreadcrumb.react.js +270 -270
  239. package/src/lib/components/navigation/AntdDropdown.react.js +469 -469
  240. package/src/lib/components/navigation/AntdMenu.react.js +573 -649
  241. package/src/lib/components/navigation/AntdPageHeader.react.js +139 -139
  242. package/src/lib/components/navigation/AntdPagination.react.js +303 -303
  243. package/src/lib/components/navigation/AntdSteps.react.js +199 -199
  244. package/src/lib/components/other/AntdAffix.react.js +120 -120
  245. package/src/lib/components/other/AntdBackTop.react.js +128 -128
  246. package/src/lib/components/other/AntdConfigProvider.react.js +246 -246
  247. package/src/lib/components/other/AntdCopyText.react.js +138 -138
  248. package/src/lib/components/other/AntdHappyProvider.react.js +50 -50
  249. package/src/lib/components/other/AntdTour.react.js +277 -277
  250. package/src/lib/components/other/AntdWatermark.react.js +179 -179
  251. package/src/lib/components/other/Fragment.react.js +50 -50
  252. package/src/lib/components/styles.css +513 -513
  253. package/src/lib/components/utils.js +51 -51
  254. package/src/lib/contexts/FormContext.js +4 -4
  255. package/src/lib/contexts/FormItemContext.js +4 -4
  256. package/src/lib/contexts/PropsContext.js +4 -4
  257. package/src/lib/fragments/AntdTable.react.js +2215 -2200
  258. package/src/lib/fragments/dataDisplay/AntdAccordion.react.js +101 -101
  259. package/src/lib/fragments/dataDisplay/AntdAvatar.react.js +127 -127
  260. package/src/lib/fragments/dataDisplay/AntdAvatarGroup.react.js +51 -51
  261. package/src/lib/fragments/dataDisplay/AntdBadge.react.js +73 -73
  262. package/src/lib/fragments/dataDisplay/AntdCarousel.react.js +71 -71
  263. package/src/lib/fragments/dataDisplay/AntdCheckableTag.react.js +57 -57
  264. package/src/lib/fragments/dataDisplay/AntdComment.react.js +178 -178
  265. package/src/lib/fragments/dataDisplay/AntdCountdown.react.js +83 -83
  266. package/src/lib/fragments/dataDisplay/AntdCountup.react.js +70 -70
  267. package/src/lib/fragments/dataDisplay/AntdEmpty.react.js +71 -71
  268. package/src/lib/fragments/dataDisplay/AntdImage.react.js +206 -206
  269. package/src/lib/fragments/dataDisplay/AntdImageGroup.react.js +91 -91
  270. package/src/lib/fragments/dataDisplay/AntdPopover.react.js +106 -106
  271. package/src/lib/fragments/dataDisplay/AntdQRCode.react.js +93 -93
  272. package/src/lib/fragments/dataDisplay/AntdRibbon.react.js +53 -53
  273. package/src/lib/fragments/dataDisplay/AntdSegmented.react.js +129 -129
  274. package/src/lib/fragments/dataDisplay/AntdSpoiler.react.js +96 -96
  275. package/src/lib/fragments/dataDisplay/AntdTabs.react.js +211 -211
  276. package/src/lib/fragments/dataDisplay/AntdTag.react.js +66 -66
  277. package/src/lib/fragments/dataDisplay/AntdTimeline.react.js +67 -67
  278. package/src/lib/fragments/dataDisplay/AntdTooltip.react.js +98 -98
  279. package/src/lib/fragments/dataDisplay/AntdTree.react.js +581 -581
  280. package/src/lib/fragments/dataDisplay/card/AntdCard.react.js +104 -104
  281. package/src/lib/fragments/dataDisplay/card/AntdCardGrid.react.js +54 -54
  282. package/src/lib/fragments/dataDisplay/card/AntdCardMeta.react.js +54 -54
  283. package/src/lib/fragments/dataDisplay/descriptions/AntdDescriptionItem.react.js +56 -56
  284. package/src/lib/fragments/dataDisplay/descriptions/AntdDescriptions.react.js +139 -139
  285. package/src/lib/fragments/dataEntry/AntdCalendar.react.js +178 -178
  286. package/src/lib/fragments/dataEntry/AntdCascader.react.js +319 -319
  287. package/src/lib/fragments/dataEntry/AntdCheckbox.react.js +119 -119
  288. package/src/lib/fragments/dataEntry/AntdCheckboxGroup.react.js +122 -122
  289. package/src/lib/fragments/dataEntry/AntdColorPicker.react.js +244 -244
  290. package/src/lib/fragments/dataEntry/AntdDatePicker.react.js +586 -586
  291. package/src/lib/fragments/dataEntry/AntdDateRangePicker.react.js +628 -628
  292. package/src/lib/fragments/dataEntry/AntdInput.react.js +450 -450
  293. package/src/lib/fragments/dataEntry/AntdInputNumber.react.js +194 -194
  294. package/src/lib/fragments/dataEntry/AntdMentions.react.js +180 -180
  295. package/src/lib/fragments/dataEntry/AntdOTP.react.js +127 -127
  296. package/src/lib/fragments/dataEntry/AntdRadioGroup.react.js +203 -203
  297. package/src/lib/fragments/dataEntry/AntdRate.react.js +131 -131
  298. package/src/lib/fragments/dataEntry/AntdSegmentedColoring.react.js +246 -246
  299. package/src/lib/fragments/dataEntry/AntdSelect.react.js +373 -373
  300. package/src/lib/fragments/dataEntry/AntdSlider.react.js +177 -177
  301. package/src/lib/fragments/dataEntry/AntdSwitch.react.js +132 -132
  302. package/src/lib/fragments/dataEntry/AntdTimePicker.react.js +191 -191
  303. package/src/lib/fragments/dataEntry/AntdTimeRangePicker.react.js +213 -213
  304. package/src/lib/fragments/dataEntry/AntdTransfer.react.js +183 -183
  305. package/src/lib/fragments/dataEntry/AntdTreeSelect.react.js +355 -355
  306. package/src/lib/fragments/dataEntry/check-card/AntdCheckCard.react.js +111 -111
  307. package/src/lib/fragments/dataEntry/check-card/AntdCheckCardGroup.react.js +122 -122
  308. package/src/lib/fragments/dataEntry/form/AntdForm.react.js +126 -120
  309. package/src/lib/fragments/dataEntry/form/AntdFormItem.react.js +85 -84
  310. package/src/lib/fragments/formRender/AntdFormRender.react.js +179 -179
  311. package/src/lib/fragments/upload/AntdDraggerUpload.react.js +622 -622
  312. package/src/lib/fragments/upload/AntdPictureUpload.react.js +577 -577
  313. package/src/lib/fragments/upload/AntdUpload.react.js +613 -613
  314. package/src/lib/hooks/useCss.js +28 -28
  315. package/src/lib/hooks/useStickyOffset.js +115 -115
  316. package/src/lib/index.js +240 -240
  317. package/src/lib/internal_components/UtilsLink.react.js +82 -0
  318. package/src/lib/store/formStore.js +54 -47
  319. package/tests/dash3.0tests/AntdQRCode/347/273/204/344/273/266loading/347/212/266/346/200/201/351/207/215/346/236/204/test.py +51 -51
  320. package/tests/dash3.0tests/AntdTable/345/207/275/346/225/260/345/274/217/346/224/271/351/200/240/test.py +62 -62
  321. package/tests/dash3.0tests/_dashprivate_layout/346/224/271/345/212/250/346/265/213/350/257/225/test.py +50 -50
  322. package/tests/dash3.0tests/loading_state/346/224/271/345/212/250/346/265/213/350/257/225/test.py +38 -38
  323. package/tests/dash3.0tests//345/207/275/346/225/260/345/274/217/347/273/204/344/273/266/351/273/230/350/256/244/345/200/274/351/207/215/346/236/204/test.py +30 -30
  324. package/tests/dash3.0tests//345/212/240/350/275/275/345/212/250/347/224/273/347/261/273/347/273/204/344/273/266/351/207/215/346/236/204/346/265/213/350/257/225/test.py +62 -62
  325. package/tests/dash3.0tests//347/273/204/344/273/266/345/261/236/346/200/247/345/237/272/347/241/200/346/214/201/344/271/205/345/214/226/351/207/215/346/236/204/346/265/213/350/257/225/test.py +25 -25
  326. package/tests/dataDisplay/AntdAccordion/feat_size.py +36 -36
  327. package/tests/dataDisplay/AntdAccordion/feat_styles.py +35 -35
  328. package/tests/dataDisplay/AntdCard/refactor_delete_props.py +83 -83
  329. package/tests/dataDisplay/AntdCarousel/feat_auto_play_dot_duration.py +34 -34
  330. package/tests/dataDisplay/AntdCollapse/feat_size.py +30 -30
  331. package/tests/dataDisplay/AntdCollapse/feat_styles.py +29 -29
  332. package/tests/dataDisplay/AntdCountdown/feat_finish_event.py +41 -41
  333. package/tests/dataDisplay/AntdCountdown/refactor_to_timer.py +57 -57
  334. package/tests/dataDisplay/AntdCountup/refactor_to_timer.py +57 -57
  335. package/tests/dataDisplay/AntdDescriptions/feat_span_filled.py +42 -42
  336. package/tests/dataDisplay/AntdImage/debug_preview_toolbar.py +23 -23
  337. package/tests/dataDisplay/AntdSegmented/feat_shape.py +39 -39
  338. package/tests/dataDisplay/AntdSegmented/feat_simple_options.py +43 -43
  339. package/tests/dataDisplay/AntdSegmented/feat_vertical.py +32 -32
  340. package/tests/dataDisplay/AntdTable/feat_button_mode_like_dcc_link.py +125 -0
  341. package/tests/dataDisplay/AntdTable/feat_button_mode_refactor.py +143 -143
  342. package/tests/dataDisplay/AntdTable/feat_button_mode_tooltip.py +47 -47
  343. package/tests/dataDisplay/AntdTable/feat_columns_fixed_bool.py +40 -40
  344. package/tests/dataDisplay/AntdTable/feat_columns_min_width.py +51 -51
  345. package/tests/dataDisplay/AntdTable/feat_columns_sort_order.py +131 -131
  346. package/tests/dataDisplay/AntdTable/feat_editable_disabled_keys.py +71 -71
  347. package/tests/dataDisplay/AntdTable/feat_header_align.py +38 -38
  348. package/tests/dataDisplay/AntdTable/feat_link_mode_like_dcc_link.py +49 -0
  349. package/tests/dataDisplay/AntdTable/feat_loading.py +76 -76
  350. package/tests/dataDisplay/AntdTable/feat_mini_chart_color.py +139 -139
  351. package/tests/dataDisplay/AntdTable/feat_row_class_name.py +39 -39
  352. package/tests/dataDisplay/AntdTable/feat_row_class_name_func.py +41 -41
  353. package/tests/dataDisplay/AntdTable/feat_select_mode_show_search.py +70 -70
  354. package/tests/dataDisplay/AntdTable/feat_sticky_header.py +81 -81
  355. package/tests/dataDisplay/AntdTable/feat_table_scroll.py +54 -54
  356. package/tests/dataDisplay/AntdTable/feat_tag_mode_tooltip.py +88 -88
  357. package/tests/dataDisplay/AntdTable/feat_title_popover_nodes.py +94 -79
  358. package/tests/dataDisplay/AntdTable/fix_context_locale.py +37 -37
  359. package/tests/dataDisplay/AntdTable/fix_field_bool.py +50 -50
  360. package/tests/dataDisplay/AntdTable/fix_nested_editable.py +115 -115
  361. package/tests/dataDisplay/AntdTable/fix_select_with_editable.py +84 -84
  362. package/tests/dataDisplay/AntdTable/fix_server_side_mode_filter_search.py +194 -194
  363. package/tests/dataDisplay/AntdTable/fix_summary.py +474 -474
  364. package/tests/dataDisplay/AntdTable/fix_summary_multi_level_header.py +85 -85
  365. package/tests/dataDisplay/AntdTable/fix_zero_value_filter.py +34 -34
  366. package/tests/dataDisplay/AntdTable/perf_button_mode_auto_wrap.py +39 -39
  367. package/tests/dataDisplay/AntdTable/perf_editable_column_format_constrait_message.py +65 -65
  368. package/tests/dataDisplay/AntdTable/refactor_mini_progress_mode.py +134 -134
  369. package/tests/dataDisplay/AntdTable/rollback_title_popover_info.py +46 -0
  370. package/tests/dataDisplay/AntdTabs/feat_item_icon.py +39 -39
  371. package/tests/dataDisplay/AntdTabs/feat_placeholder.py +124 -124
  372. package/tests/dataDisplay/AntdTabs/feat_tab_bar_style.py +40 -40
  373. package/tests/dataDisplay/AntdTree/feat_async_data_load.py +71 -71
  374. package/tests/dataDisplay/descriptions/AntdDescriptions/feat_extra.py +83 -83
  375. package/tests/dataEntry/AntdCalendar/feat_custom_cells.py +52 -52
  376. package/tests/dataEntry/AntdCascader/feat_prefix.py +62 -62
  377. package/tests/dataEntry/AntdCascader/feat_suffix_icon.py +62 -62
  378. package/tests/dataEntry/AntdCascader/fix_read_only.py +74 -74
  379. package/tests/dataEntry/AntdDatePicker/feat_custom_cells.py +79 -79
  380. package/tests/dataEntry/AntdDatePicker/feat_picker_value.py +38 -38
  381. package/tests/dataEntry/AntdDatePicker/feat_prefix.py +21 -21
  382. package/tests/dataEntry/AntdDatePicker/feat_suffix_icon.py +21 -21
  383. package/tests/dataEntry/AntdDateRangePicker/feat_custom_cells.py +79 -79
  384. package/tests/dataEntry/AntdDateRangePicker/feat_picker_value.py +38 -38
  385. package/tests/dataEntry/AntdDateRangePicker/feat_prefix.py +21 -21
  386. package/tests/dataEntry/AntdDateRangePicker/feat_suffix_icon.py +21 -21
  387. package/tests/dataEntry/AntdForm/feat_batch_control_tooltips.py +35 -0
  388. package/tests/dataEntry/AntdForm/feat_optional_batch_control.py +62 -62
  389. package/tests/dataEntry/AntdForm/fix_checkbox.py +65 -65
  390. package/tests/dataEntry/AntdRadioGroup/feat_block.py +40 -40
  391. package/tests/dataEntry/AntdSelect/feat_locale_ru.py +24 -24
  392. package/tests/dataEntry/AntdSelect/feat_max_count.py +28 -28
  393. package/tests/dataEntry/AntdSelect/feat_prefix.py +26 -26
  394. package/tests/dataEntry/AntdSelect/feat_show_search.py +32 -32
  395. package/tests/dataEntry/AntdSelect/feat_suffix_icon.py +46 -46
  396. package/tests/dataEntry/AntdSelect/fix_read_only.py +50 -50
  397. package/tests/dataEntry/AntdSelect/fix_read_only_with_allow_clear.py +29 -29
  398. package/tests/dataEntry/AntdSlider/feat_range_editable.py +49 -49
  399. package/tests/dataEntry/AntdTimePicker/feat_prefix.py +21 -21
  400. package/tests/dataEntry/AntdTimePicker/feat_suffix_icon.py +21 -21
  401. package/tests/dataEntry/AntdTimeRangePicker/feat_prefix.py +21 -21
  402. package/tests/dataEntry/AntdTimeRangePicker/feat_suffix_icon.py +21 -21
  403. package/tests/dataEntry/AntdTreeSelect/feat_async_data_load.py +69 -69
  404. package/tests/dataEntry/AntdTreeSelect/feat_max_count.py +71 -71
  405. package/tests/dataEntry/AntdTreeSelect/feat_prefix.py +43 -43
  406. package/tests/dataEntry/AntdTreeSelect/fix_read_only.py +50 -50
  407. package/tests/dataEntry/AntdUpload/feat_pastable.py +22 -22
  408. package/tests/dataEntry/AntdUpload/fix_follow_theme.py +28 -28
  409. package/tests/feat_variant_underlined.py +100 -100
  410. package/tests/feedback/AntdAlert/feat_icon.py +35 -35
  411. package/tests/feedback/AntdMessage/fix_follow_config_provider.py +44 -44
  412. package/tests/feedback/AntdModal/feat_force_render.py +57 -57
  413. package/tests/feedback/AntdModal/feat_loading_title.py +92 -92
  414. package/tests/feedback/AntdModal/feat_prevent_close.py +54 -54
  415. package/tests/feedback/AntdModal/feat_responsive_width.py +31 -31
  416. package/tests/feedback/AntdNotification/feat_component_content.py +64 -64
  417. package/tests/feedback/AntdNotification/feat_number_of_stack.py +40 -40
  418. package/tests/feedback/AntdNotification/feat_show_progress.py +40 -40
  419. package/tests/feedback/AntdNotification/fix_follow_config_provider.py +46 -46
  420. package/tests/feedback/AntdPopupCard/feat_force_render.py +61 -61
  421. package/tests/feedback/AntdProgress/feat_percent_position.py +39 -39
  422. package/tests/feedback/AntdProgress/perf_size.py +26 -26
  423. package/tests/feedback/AntdProgress/perf_steps.py +37 -37
  424. package/tests/feedback/AntdProgress/perf_stroke_color.py +58 -58
  425. package/tests/feedback/AntdResult/feat_extra.py +26 -26
  426. package/tests/feedback/AntdSkeleton/fix_dash3.py +43 -43
  427. package/tests/general/AntdButton/feat_color_and_variant.py +40 -40
  428. package/tests/general/AntdButton/feat_preset_color.py +46 -46
  429. package/tests/general/AntdFloatButtonGroup/feat_placement.py +83 -83
  430. package/tests/general/AntdFloatButtonGroup/feat_tooltip.py +34 -34
  431. package/tests/general/AntdIcon/feat_iconfont.py +41 -41
  432. package/tests/layout/AntdCenter/feat_use_token.py +41 -41
  433. package/tests/layout/AntdDivider/feat_plain.py +21 -21
  434. package/tests/layout/AntdDivider/feat_size.py +36 -36
  435. package/tests/layout/AntdSplitter/feat_AntdSplitter.py +210 -210
  436. package/tests/layout/AntdSplitter/feat_lazy.py +56 -56
  437. package/tests/layout/AntdSplitter/refactor.py +303 -303
  438. package/tests/navigation/AntdAnchor/feat_current_anchor.py +43 -43
  439. package/tests/navigation/AntdAnchor/feat_direction.py +43 -43
  440. package/tests/navigation/AntdAnchor/feat_replace.py +43 -43
  441. package/tests/navigation/AntdBreadcrumb/feat_menu_item_event.py +64 -64
  442. package/tests/navigation/AntdBreadcrumb/refactor_items.py +140 -140
  443. package/tests/navigation/AntdDropdown/feat_extra.py +29 -29
  444. package/tests/navigation/AntdMenu/feat_currentItem.py +85 -85
  445. package/tests/navigation/AntdMenu/feat_currentItemPath.py +85 -85
  446. package/tests/navigation/AntdMenu/feat_currentKeyPath.py +85 -85
  447. package/tests/navigation/AntdMenu/feat_custom_icon.py +57 -57
  448. package/tests/navigation/AntdMenu/feat_expandIcon.py +70 -70
  449. package/tests/navigation/AntdMenu/feat_triggerSubMenuAction.py +67 -67
  450. package/tests/navigation/AntdMenu/fix_onlyExpandCurrentSubMenu.py +57 -57
  451. package/tests/navigation/AntdMenu/fix_with_sider.py +71 -71
  452. package/tests/navigation/AntdPagination/feat_align.py +31 -31
  453. package/tests/other/AntdAffix/feat_listen_affixed.py +41 -41
  454. package/tests/other/AntdBackTop/refactor.py +18 -18
  455. package/tests/other/AntdConfigProvider/feat_use_css.py +67 -67
  456. package/tests/other/AntdCopyText/feat_copy_table.py +67 -67
  457. package/tests/other/AntdCopyText/feat_tooltips.py +61 -61
  458. package/tests/other/AntdHappyProvider/feat_component.py +60 -60
  459. package/tests/other/Fragment/feat_use_token.py +32 -32
  460. package/usage.py +34 -34
  461. package/webpack.config.js +181 -181
  462. package/webpack.serve.config.js +12 -12
@@ -1,434 +1,434 @@
1
- // react核心
2
- import React, { useContext, useMemo } from 'react';
3
- import PropTypes from 'prop-types';
4
- // antd核心
5
- import { Popconfirm, ConfigProvider } from 'antd';
6
- // 辅助库
7
- import { str2Locale } from '../locales.react';
8
- import { parseChildrenToArray, useLoading } from '../utils';
9
- import { isString, isUndefined } from 'lodash';
10
- import { pickBy } from 'ramda';
11
- // 自定义hooks
12
- import useCss from '../../hooks/useCss';
13
- // 自定义上下文
14
- import PropsContext from '../../contexts/PropsContext';
15
-
16
- /**
17
- * 气泡确认框组件AntdPopconfirm
18
- */
19
- const AntdPopconfirm = ({
20
- id,
21
- children,
22
- className,
23
- style,
24
- styles,
25
- classNames,
26
- key,
27
- locale = 'zh-cn',
28
- icon,
29
- title,
30
- description,
31
- disabled = false,
32
- placement = 'top',
33
- mouseEnterDelay = 0.1,
34
- mouseLeaveDelay = 0.1,
35
- okText,
36
- okButtonProps,
37
- cancelText,
38
- cancelButtonProps,
39
- showCancel = true,
40
- confirmCounts = 0,
41
- cancelCounts = 0,
42
- trigger = 'click',
43
- zIndex,
44
- arrow = 'show',
45
- fresh = false,
46
- open = false,
47
- permanent = false,
48
- popupContainer = 'body',
49
- setProps,
50
- ...others
51
- }) => {
52
-
53
- const arrowPoint = useMemo(() => {
54
- if (arrow === 'hide') {
55
- return false;
56
- }
57
- if (arrow === 'show') {
58
- return true;
59
- }
60
- return {
61
- pointAtCenter: true,
62
- };
63
- }, [arrow])
64
-
65
- const context = useContext(PropsContext)
66
- locale = (context && context.locale) || locale
67
-
68
- children = parseChildrenToArray(children)
69
-
70
- // 监听确认按钮点击事件
71
- const listenConfirm = () => {
72
- setProps({ confirmCounts: confirmCounts + 1 })
73
- };
74
-
75
- // 监听取消按钮点击事件
76
- const listenCancel = () => {
77
- setProps({ cancelCounts: cancelCounts + 1 })
78
- };
79
-
80
- return (
81
- <ConfigProvider locale={str2Locale.get(locale)}>
82
- <Popconfirm
83
- // 提取具有data-*或aria-*通配格式的属性
84
- {...pickBy((_, k) => k.startsWith('data-') || k.startsWith('aria-'), others)}
85
- id={id}
86
- className={
87
- isString(className) ?
88
- className :
89
- (className ? useCss(className) : undefined)
90
- }
91
- style={style}
92
- styles={styles}
93
- classNames={classNames}
94
- key={key}
95
- icon={icon}
96
- title={title}
97
- description={description}
98
- disabled={
99
- context && !isUndefined(context.componentDisabled) ?
100
- context.componentDisabled :
101
- disabled
102
- }
103
- placement={placement}
104
- mouseEnterDelay={mouseEnterDelay}
105
- mouseLeaveDelay={mouseLeaveDelay}
106
- trigger={trigger}
107
- okText={okText}
108
- okButtonProps={okButtonProps}
109
- cancelText={cancelText}
110
- cancelButtonProps={cancelButtonProps}
111
- zIndex={zIndex}
112
- arrow={arrowPoint}
113
- fresh={fresh}
114
- open={open}
115
- showCancel={showCancel}
116
- onOpenChange={
117
- permanent ? undefined : (e) => setProps({ open: e })
118
- }
119
- getPopupContainer={
120
- popupContainer === 'parent' ?
121
- (triggerNode) => triggerNode.parentNode :
122
- undefined
123
- }
124
- onCancel={listenCancel}
125
- onConfirm={listenConfirm}
126
- data-dash-is-loading={useLoading()}>
127
- {children}
128
- </Popconfirm>
129
- </ConfigProvider>
130
- );
131
- }
132
-
133
- AntdPopconfirm.propTypes = {
134
- /**
135
- * 组件唯一id
136
- */
137
- id: PropTypes.string,
138
-
139
- /**
140
- * 对当前组件的`key`值进行更新,可实现强制重绘当前组件的效果
141
- */
142
- key: PropTypes.string,
143
-
144
- /**
145
- * 组件型,气泡确认框挂载元素
146
- */
147
- children: PropTypes.node,
148
-
149
- /**
150
- * 当前组件css样式
151
- */
152
- style: PropTypes.object,
153
-
154
- /**
155
- * 当前组件css类名,支持[动态css](/advanced-classname)
156
- */
157
- className: PropTypes.oneOfType([
158
- PropTypes.string,
159
- PropTypes.object
160
- ]),
161
-
162
- /**
163
- * 细分控制子元素css样式
164
- */
165
- styles: PropTypes.exact({
166
- /**
167
- * 根元素(包含箭头、内容元素)css样式
168
- */
169
- root: PropTypes.object,
170
- /**
171
- * 内容元素css样式
172
- */
173
- body: PropTypes.object
174
- }),
175
-
176
- /**
177
- * 细分控制子元素css类名
178
- */
179
- classNames: PropTypes.exact({
180
- /**
181
- * 根元素(包含箭头、内容元素)css类名
182
- */
183
- root: PropTypes.string,
184
- /**
185
- * 内容元素css类名
186
- */
187
- body: PropTypes.string
188
- }),
189
-
190
- /**
191
- * 组件文案语种,可选项有`'zh-cn'`(简体中文)、`'en-us'`(英语)、`'de-de'`(德语)、`'ru-ru'`(俄语)
192
- * 默认值:`'zh-cn'`
193
- */
194
- locale: PropTypes.oneOf(['zh-cn', 'en-us', 'de-de', 'ru-ru']),
195
-
196
- /**
197
- * 组件型,提示图标
198
- */
199
- icon: PropTypes.node,
200
-
201
- /**
202
- * 组件型,标题内容
203
- */
204
- title: PropTypes.node,
205
-
206
- /**
207
- * 组件型,描述内容
208
- */
209
- description: PropTypes.node,
210
-
211
- /**
212
- * 是否禁用当前组件
213
- * 默认值:`false`
214
- */
215
- disabled: PropTypes.bool,
216
-
217
- /**
218
- * 气泡确认框弹出位置,可选项有`'top'`、`'left'`、`'right'`、`'bottom'`、`'topLeft'`、`'topRight'`、`'bottomLeft'`、`'bottomRight'`、`'leftTop'`、`'leftBottom'`、`'rightTop'`、`'rightBottom'`
219
- * 默认值:`'top'`
220
- */
221
- placement: PropTypes.oneOf([
222
- 'top', 'left', 'right', 'bottom', 'topLeft', 'topRight', 'bottomLeft',
223
- 'bottomRight', 'leftTop', 'leftBottom', 'rightTop', 'rightBottom'
224
- ]),
225
-
226
- /**
227
- * 从鼠标移入挂载元素,到气泡确认框显示的延时,单位:秒
228
- * 默认值:`0.1`
229
- */
230
- mouseEnterDelay: PropTypes.number,
231
-
232
- /**
233
- * 从鼠标移出挂载元素,到气泡确认框消失的延时,单位:秒
234
- * 默认值:`0.1`
235
- */
236
- mouseLeaveDelay: PropTypes.number,
237
-
238
- /**
239
- * 组件型,确认按钮内容
240
- */
241
- okText: PropTypes.node,
242
-
243
- /**
244
- * 配置确认按钮相关参数
245
- */
246
- okButtonProps: PropTypes.exact({
247
- /**
248
- * 按钮尺寸规格,可选项有`'small'`、`'middle'`、`'large'`
249
- * 默认值:`'middle'`
250
- */
251
- size: PropTypes.oneOf(['small', 'middle', 'large']),
252
-
253
- /**
254
- * 按钮类型,可选项有`'default'`、`'primary'`、`'ghost'`、`'dashed'`、`'link'`、`'text'`
255
- * 默认值:`'default'`
256
- */
257
- type: PropTypes.oneOf(['primary', 'ghost', 'dashed', 'link', 'text', 'default']),
258
-
259
- /**
260
- * 按钮是否呈现危险样式
261
- * 默认值:`false`
262
- */
263
- danger: PropTypes.bool,
264
-
265
- /**
266
- * 按钮是否呈现禁用状态
267
- * 默认值:`false`
268
- */
269
- disabled: PropTypes.bool,
270
-
271
- /**
272
- * 按钮形状,可选项有`'default'`、`'circle'`、`'round'`
273
- * 默认值:`'default'`
274
- */
275
- shape: PropTypes.oneOf(['circle', 'round']),
276
-
277
- /**
278
- * 按钮css样式
279
- */
280
- style: PropTypes.object,
281
-
282
- /**
283
- * 按钮css类名
284
- */
285
- className: PropTypes.string
286
- }),
287
-
288
- /**
289
- * 组件型,取消按钮内容
290
- */
291
- cancelText: PropTypes.node,
292
-
293
- /**
294
- * 配置取消按钮相关参数
295
- */
296
- cancelButtonProps: PropTypes.exact({
297
- /**
298
- * 按钮尺寸规格,可选项有`'small'`、`'middle'`、`'large'`
299
- * 默认值:`'middle'`
300
- */
301
- size: PropTypes.oneOf(['small', 'middle', 'large']),
302
-
303
- /**
304
- * 按钮类型,可选项有`'default'`、`'primary'`、`'ghost'`、`'dashed'`、`'link'`、`'text'`
305
- * 默认值:`'default'`
306
- */
307
- type: PropTypes.oneOf(['primary', 'ghost', 'dashed', 'link', 'text', 'default']),
308
-
309
- /**
310
- * 按钮是否呈现危险样式
311
- * 默认值:`false`
312
- */
313
- danger: PropTypes.bool,
314
-
315
- /**
316
- * 按钮是否呈现禁用状态
317
- * 默认值:`false`
318
- */
319
- disabled: PropTypes.bool,
320
-
321
- /**
322
- * 按钮形状,可选项有`'default'`、`'circle'`、`'round'`
323
- * 默认值:`'default'`
324
- */
325
- shape: PropTypes.oneOf(['circle', 'round']),
326
-
327
- /**
328
- * 按钮css样式
329
- */
330
- style: PropTypes.object,
331
-
332
- /**
333
- * 按钮css类名
334
- */
335
- className: PropTypes.string
336
- }),
337
-
338
- /**
339
- * 是否显示取消按钮
340
- * 默认值:`true`
341
- */
342
- showCancel: PropTypes.bool,
343
-
344
- /**
345
- * 监听确认按钮累计点击次数
346
- * 默认值:`0`
347
- */
348
- confirmCounts: PropTypes.number,
349
-
350
- /**
351
- * 监听取消按钮累计点击次数
352
- * 默认值:`0`
353
- */
354
- cancelCounts: PropTypes.number,
355
-
356
- /**
357
- * 气泡确认框触发行为,可选项有`'hover'`、`'focus'`、`'click'`,可多选组合
358
- * 默认值:`'click'`
359
- */
360
- trigger: PropTypes.oneOfType(
361
- [
362
- PropTypes.oneOf(['hover', 'focus', 'click']),
363
- PropTypes.arrayOf(PropTypes.oneOf(['hover', 'focus', 'click']))
364
- ]
365
- ),
366
-
367
- /**
368
- * 气泡确认框z-index
369
- */
370
- zIndex: PropTypes.number,
371
-
372
- /**
373
- * 指示箭头显示形式,可选项有`'show'`、`'hide'`、`'center'`
374
- * 默认值:`'show'`
375
- */
376
- arrow: PropTypes.oneOf(['show', 'hide', 'center']),
377
-
378
- /**
379
- * 是否保持内容更新
380
- * 默认值:`false`
381
- */
382
- fresh: PropTypes.bool,
383
-
384
- /**
385
- * 监听或设置气泡确认框的显示状态
386
- * 默认值:`false`
387
- */
388
- open: PropTypes.bool,
389
-
390
- /**
391
- * 是否保持气泡确认框显示/隐藏
392
- * 默认值:`false`
393
- */
394
- permanent: PropTypes.bool,
395
-
396
- /**
397
- * 悬浮层渲染挂载父节点策略,可选项有`'parent'`、`'body'`
398
- * 默认值:`'body'`
399
- */
400
- popupContainer: PropTypes.oneOf(['parent', 'body']),
401
-
402
- /**
403
- * `data-*`格式属性通配
404
- */
405
- 'data-*': PropTypes.string,
406
-
407
- /**
408
- * `aria-*`格式属性通配
409
- */
410
- 'aria-*': PropTypes.string,
411
-
412
- loading_state: PropTypes.shape({
413
- /**
414
- * Determines if the component is loading or not
415
- */
416
- is_loading: PropTypes.bool,
417
- /**
418
- * Holds which property is loading
419
- */
420
- prop_name: PropTypes.string,
421
- /**
422
- * Holds the name of the component that is loading
423
- */
424
- component_name: PropTypes.string
425
- }),
426
-
427
- /**
428
- * Dash-assigned callback that should be called to report property changes
429
- * to Dash, to make them available for callbacks.
430
- */
431
- setProps: PropTypes.func
432
- };
433
-
1
+ // react核心
2
+ import React, { useContext, useMemo } from 'react';
3
+ import PropTypes from 'prop-types';
4
+ // antd核心
5
+ import { Popconfirm, ConfigProvider } from 'antd';
6
+ // 辅助库
7
+ import { str2Locale } from '../locales.react';
8
+ import { parseChildrenToArray, useLoading } from '../utils';
9
+ import { isString, isUndefined } from 'lodash';
10
+ import { pickBy } from 'ramda';
11
+ // 自定义hooks
12
+ import useCss from '../../hooks/useCss';
13
+ // 自定义上下文
14
+ import PropsContext from '../../contexts/PropsContext';
15
+
16
+ /**
17
+ * 气泡确认框组件AntdPopconfirm
18
+ */
19
+ const AntdPopconfirm = ({
20
+ id,
21
+ children,
22
+ className,
23
+ style,
24
+ styles,
25
+ classNames,
26
+ key,
27
+ locale = 'zh-cn',
28
+ icon,
29
+ title,
30
+ description,
31
+ disabled = false,
32
+ placement = 'top',
33
+ mouseEnterDelay = 0.1,
34
+ mouseLeaveDelay = 0.1,
35
+ okText,
36
+ okButtonProps,
37
+ cancelText,
38
+ cancelButtonProps,
39
+ showCancel = true,
40
+ confirmCounts = 0,
41
+ cancelCounts = 0,
42
+ trigger = 'click',
43
+ zIndex,
44
+ arrow = 'show',
45
+ fresh = false,
46
+ open = false,
47
+ permanent = false,
48
+ popupContainer = 'body',
49
+ setProps,
50
+ ...others
51
+ }) => {
52
+
53
+ const arrowPoint = useMemo(() => {
54
+ if (arrow === 'hide') {
55
+ return false;
56
+ }
57
+ if (arrow === 'show') {
58
+ return true;
59
+ }
60
+ return {
61
+ pointAtCenter: true,
62
+ };
63
+ }, [arrow])
64
+
65
+ const context = useContext(PropsContext)
66
+ locale = (context && context.locale) || locale
67
+
68
+ children = parseChildrenToArray(children)
69
+
70
+ // 监听确认按钮点击事件
71
+ const listenConfirm = () => {
72
+ setProps({ confirmCounts: confirmCounts + 1 })
73
+ };
74
+
75
+ // 监听取消按钮点击事件
76
+ const listenCancel = () => {
77
+ setProps({ cancelCounts: cancelCounts + 1 })
78
+ };
79
+
80
+ return (
81
+ <ConfigProvider locale={str2Locale.get(locale)}>
82
+ <Popconfirm
83
+ // 提取具有data-*或aria-*通配格式的属性
84
+ {...pickBy((_, k) => k.startsWith('data-') || k.startsWith('aria-'), others)}
85
+ id={id}
86
+ className={
87
+ isString(className) ?
88
+ className :
89
+ (className ? useCss(className) : undefined)
90
+ }
91
+ style={style}
92
+ styles={styles}
93
+ classNames={classNames}
94
+ key={key}
95
+ icon={icon}
96
+ title={title}
97
+ description={description}
98
+ disabled={
99
+ context && !isUndefined(context.componentDisabled) ?
100
+ context.componentDisabled :
101
+ disabled
102
+ }
103
+ placement={placement}
104
+ mouseEnterDelay={mouseEnterDelay}
105
+ mouseLeaveDelay={mouseLeaveDelay}
106
+ trigger={trigger}
107
+ okText={okText}
108
+ okButtonProps={okButtonProps}
109
+ cancelText={cancelText}
110
+ cancelButtonProps={cancelButtonProps}
111
+ zIndex={zIndex}
112
+ arrow={arrowPoint}
113
+ fresh={fresh}
114
+ open={open}
115
+ showCancel={showCancel}
116
+ onOpenChange={
117
+ permanent ? undefined : (e) => setProps({ open: e })
118
+ }
119
+ getPopupContainer={
120
+ popupContainer === 'parent' ?
121
+ (triggerNode) => triggerNode.parentNode :
122
+ undefined
123
+ }
124
+ onCancel={listenCancel}
125
+ onConfirm={listenConfirm}
126
+ data-dash-is-loading={useLoading()}>
127
+ {children}
128
+ </Popconfirm>
129
+ </ConfigProvider>
130
+ );
131
+ }
132
+
133
+ AntdPopconfirm.propTypes = {
134
+ /**
135
+ * 组件唯一id
136
+ */
137
+ id: PropTypes.string,
138
+
139
+ /**
140
+ * 对当前组件的`key`值进行更新,可实现强制重绘当前组件的效果
141
+ */
142
+ key: PropTypes.string,
143
+
144
+ /**
145
+ * 组件型,气泡确认框挂载元素
146
+ */
147
+ children: PropTypes.node,
148
+
149
+ /**
150
+ * 当前组件css样式
151
+ */
152
+ style: PropTypes.object,
153
+
154
+ /**
155
+ * 当前组件css类名,支持[动态css](/advanced-classname)
156
+ */
157
+ className: PropTypes.oneOfType([
158
+ PropTypes.string,
159
+ PropTypes.object
160
+ ]),
161
+
162
+ /**
163
+ * 细分控制子元素css样式
164
+ */
165
+ styles: PropTypes.exact({
166
+ /**
167
+ * 根元素(包含箭头、内容元素)css样式
168
+ */
169
+ root: PropTypes.object,
170
+ /**
171
+ * 内容元素css样式
172
+ */
173
+ body: PropTypes.object
174
+ }),
175
+
176
+ /**
177
+ * 细分控制子元素css类名
178
+ */
179
+ classNames: PropTypes.exact({
180
+ /**
181
+ * 根元素(包含箭头、内容元素)css类名
182
+ */
183
+ root: PropTypes.string,
184
+ /**
185
+ * 内容元素css类名
186
+ */
187
+ body: PropTypes.string
188
+ }),
189
+
190
+ /**
191
+ * 组件文案语种,可选项有`'zh-cn'`(简体中文)、`'en-us'`(英语)、`'de-de'`(德语)、`'ru-ru'`(俄语)
192
+ * 默认值:`'zh-cn'`
193
+ */
194
+ locale: PropTypes.oneOf(['zh-cn', 'en-us', 'de-de', 'ru-ru']),
195
+
196
+ /**
197
+ * 组件型,提示图标
198
+ */
199
+ icon: PropTypes.node,
200
+
201
+ /**
202
+ * 组件型,标题内容
203
+ */
204
+ title: PropTypes.node,
205
+
206
+ /**
207
+ * 组件型,描述内容
208
+ */
209
+ description: PropTypes.node,
210
+
211
+ /**
212
+ * 是否禁用当前组件
213
+ * 默认值:`false`
214
+ */
215
+ disabled: PropTypes.bool,
216
+
217
+ /**
218
+ * 气泡确认框弹出位置,可选项有`'top'`、`'left'`、`'right'`、`'bottom'`、`'topLeft'`、`'topRight'`、`'bottomLeft'`、`'bottomRight'`、`'leftTop'`、`'leftBottom'`、`'rightTop'`、`'rightBottom'`
219
+ * 默认值:`'top'`
220
+ */
221
+ placement: PropTypes.oneOf([
222
+ 'top', 'left', 'right', 'bottom', 'topLeft', 'topRight', 'bottomLeft',
223
+ 'bottomRight', 'leftTop', 'leftBottom', 'rightTop', 'rightBottom'
224
+ ]),
225
+
226
+ /**
227
+ * 从鼠标移入挂载元素,到气泡确认框显示的延时,单位:秒
228
+ * 默认值:`0.1`
229
+ */
230
+ mouseEnterDelay: PropTypes.number,
231
+
232
+ /**
233
+ * 从鼠标移出挂载元素,到气泡确认框消失的延时,单位:秒
234
+ * 默认值:`0.1`
235
+ */
236
+ mouseLeaveDelay: PropTypes.number,
237
+
238
+ /**
239
+ * 组件型,确认按钮内容
240
+ */
241
+ okText: PropTypes.node,
242
+
243
+ /**
244
+ * 配置确认按钮相关参数
245
+ */
246
+ okButtonProps: PropTypes.exact({
247
+ /**
248
+ * 按钮尺寸规格,可选项有`'small'`、`'middle'`、`'large'`
249
+ * 默认值:`'middle'`
250
+ */
251
+ size: PropTypes.oneOf(['small', 'middle', 'large']),
252
+
253
+ /**
254
+ * 按钮类型,可选项有`'default'`、`'primary'`、`'ghost'`、`'dashed'`、`'link'`、`'text'`
255
+ * 默认值:`'default'`
256
+ */
257
+ type: PropTypes.oneOf(['primary', 'ghost', 'dashed', 'link', 'text', 'default']),
258
+
259
+ /**
260
+ * 按钮是否呈现危险样式
261
+ * 默认值:`false`
262
+ */
263
+ danger: PropTypes.bool,
264
+
265
+ /**
266
+ * 按钮是否呈现禁用状态
267
+ * 默认值:`false`
268
+ */
269
+ disabled: PropTypes.bool,
270
+
271
+ /**
272
+ * 按钮形状,可选项有`'default'`、`'circle'`、`'round'`
273
+ * 默认值:`'default'`
274
+ */
275
+ shape: PropTypes.oneOf(['circle', 'round']),
276
+
277
+ /**
278
+ * 按钮css样式
279
+ */
280
+ style: PropTypes.object,
281
+
282
+ /**
283
+ * 按钮css类名
284
+ */
285
+ className: PropTypes.string
286
+ }),
287
+
288
+ /**
289
+ * 组件型,取消按钮内容
290
+ */
291
+ cancelText: PropTypes.node,
292
+
293
+ /**
294
+ * 配置取消按钮相关参数
295
+ */
296
+ cancelButtonProps: PropTypes.exact({
297
+ /**
298
+ * 按钮尺寸规格,可选项有`'small'`、`'middle'`、`'large'`
299
+ * 默认值:`'middle'`
300
+ */
301
+ size: PropTypes.oneOf(['small', 'middle', 'large']),
302
+
303
+ /**
304
+ * 按钮类型,可选项有`'default'`、`'primary'`、`'ghost'`、`'dashed'`、`'link'`、`'text'`
305
+ * 默认值:`'default'`
306
+ */
307
+ type: PropTypes.oneOf(['primary', 'ghost', 'dashed', 'link', 'text', 'default']),
308
+
309
+ /**
310
+ * 按钮是否呈现危险样式
311
+ * 默认值:`false`
312
+ */
313
+ danger: PropTypes.bool,
314
+
315
+ /**
316
+ * 按钮是否呈现禁用状态
317
+ * 默认值:`false`
318
+ */
319
+ disabled: PropTypes.bool,
320
+
321
+ /**
322
+ * 按钮形状,可选项有`'default'`、`'circle'`、`'round'`
323
+ * 默认值:`'default'`
324
+ */
325
+ shape: PropTypes.oneOf(['circle', 'round']),
326
+
327
+ /**
328
+ * 按钮css样式
329
+ */
330
+ style: PropTypes.object,
331
+
332
+ /**
333
+ * 按钮css类名
334
+ */
335
+ className: PropTypes.string
336
+ }),
337
+
338
+ /**
339
+ * 是否显示取消按钮
340
+ * 默认值:`true`
341
+ */
342
+ showCancel: PropTypes.bool,
343
+
344
+ /**
345
+ * 监听确认按钮累计点击次数
346
+ * 默认值:`0`
347
+ */
348
+ confirmCounts: PropTypes.number,
349
+
350
+ /**
351
+ * 监听取消按钮累计点击次数
352
+ * 默认值:`0`
353
+ */
354
+ cancelCounts: PropTypes.number,
355
+
356
+ /**
357
+ * 气泡确认框触发行为,可选项有`'hover'`、`'focus'`、`'click'`,可多选组合
358
+ * 默认值:`'click'`
359
+ */
360
+ trigger: PropTypes.oneOfType(
361
+ [
362
+ PropTypes.oneOf(['hover', 'focus', 'click']),
363
+ PropTypes.arrayOf(PropTypes.oneOf(['hover', 'focus', 'click']))
364
+ ]
365
+ ),
366
+
367
+ /**
368
+ * 气泡确认框z-index
369
+ */
370
+ zIndex: PropTypes.number,
371
+
372
+ /**
373
+ * 指示箭头显示形式,可选项有`'show'`、`'hide'`、`'center'`
374
+ * 默认值:`'show'`
375
+ */
376
+ arrow: PropTypes.oneOf(['show', 'hide', 'center']),
377
+
378
+ /**
379
+ * 是否保持内容更新
380
+ * 默认值:`false`
381
+ */
382
+ fresh: PropTypes.bool,
383
+
384
+ /**
385
+ * 监听或设置气泡确认框的显示状态
386
+ * 默认值:`false`
387
+ */
388
+ open: PropTypes.bool,
389
+
390
+ /**
391
+ * 是否保持气泡确认框显示/隐藏
392
+ * 默认值:`false`
393
+ */
394
+ permanent: PropTypes.bool,
395
+
396
+ /**
397
+ * 悬浮层渲染挂载父节点策略,可选项有`'parent'`、`'body'`
398
+ * 默认值:`'body'`
399
+ */
400
+ popupContainer: PropTypes.oneOf(['parent', 'body']),
401
+
402
+ /**
403
+ * `data-*`格式属性通配
404
+ */
405
+ 'data-*': PropTypes.string,
406
+
407
+ /**
408
+ * `aria-*`格式属性通配
409
+ */
410
+ 'aria-*': PropTypes.string,
411
+
412
+ loading_state: PropTypes.shape({
413
+ /**
414
+ * Determines if the component is loading or not
415
+ */
416
+ is_loading: PropTypes.bool,
417
+ /**
418
+ * Holds which property is loading
419
+ */
420
+ prop_name: PropTypes.string,
421
+ /**
422
+ * Holds the name of the component that is loading
423
+ */
424
+ component_name: PropTypes.string
425
+ }),
426
+
427
+ /**
428
+ * Dash-assigned callback that should be called to report property changes
429
+ * to Dash, to make them available for callbacks.
430
+ */
431
+ setProps: PropTypes.func
432
+ };
433
+
434
434
  export default AntdPopconfirm;