@kdcloudjs/table 1.0.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 (572) hide show
  1. package/LICENSE +568 -0
  2. package/README.md +111 -0
  3. package/dist/@kdcloudjs/table.css +422 -0
  4. package/dist/@kdcloudjs/table.css.map +1 -0
  5. package/dist/@kdcloudjs/table.js +38578 -0
  6. package/dist/@kdcloudjs/table.js.map +1 -0
  7. package/dist/@kdcloudjs/table.min.css +9 -0
  8. package/dist/@kdcloudjs/table.min.js +208 -0
  9. package/dist/@kdcloudjs/table.min.js.map +1 -0
  10. package/dist/default-theme.js +344 -0
  11. package/dist/kd-table.css +422 -0
  12. package/dist/kd-table.css.map +1 -0
  13. package/dist/kd-table.js +38578 -0
  14. package/dist/kd-table.js.map +1 -0
  15. package/dist/kd-table.min.css +9 -0
  16. package/dist/kd-table.min.js +208 -0
  17. package/dist/kd-table.min.js.map +1 -0
  18. package/dist/kd-ui-complete.less +779 -0
  19. package/dist/kd-ui.less +2 -0
  20. package/dist/theme.js +13 -0
  21. package/es/_utils/arrayUtil.d.ts +5 -0
  22. package/es/_utils/arrayUtil.js +17 -0
  23. package/es/_utils/devwarning.d.ts +1 -0
  24. package/es/_utils/devwarning.js +10 -0
  25. package/es/_utils/formatUtil.d.ts +46 -0
  26. package/es/_utils/formatUtil.js +346 -0
  27. package/es/_utils/hooks.d.ts +51 -0
  28. package/es/_utils/hooks.js +165 -0
  29. package/es/_utils/index.d.ts +8 -0
  30. package/es/_utils/index.js +15 -0
  31. package/es/_utils/numberUtil.d.ts +34 -0
  32. package/es/_utils/numberUtil.js +181 -0
  33. package/es/_utils/omit.d.ts +1 -0
  34. package/es/_utils/omit.js +11 -0
  35. package/es/_utils/react-children.d.ts +2 -0
  36. package/es/_utils/react-children.js +8 -0
  37. package/es/_utils/type.d.ts +12 -0
  38. package/es/_utils/type.js +15 -0
  39. package/es/_utils/usePopper.d.ts +29 -0
  40. package/es/_utils/usePopper.js +546 -0
  41. package/es/config-provider/ConfigContext.d.ts +22 -0
  42. package/es/config-provider/ConfigContext.js +7 -0
  43. package/es/config-provider/compDefaultProps.d.ts +8 -0
  44. package/es/config-provider/compDefaultProps.js +10 -0
  45. package/es/config-provider/configProvider.d.ts +11 -0
  46. package/es/config-provider/configProvider.js +40 -0
  47. package/es/config-provider/defaultConfig.d.ts +10 -0
  48. package/es/config-provider/defaultConfig.js +18 -0
  49. package/es/config-provider/index.d.ts +6 -0
  50. package/es/config-provider/index.js +6 -0
  51. package/es/index.d.ts +2 -0
  52. package/es/index.js +4 -0
  53. package/es/locale/index.d.ts +3 -0
  54. package/es/locale/index.js +3 -0
  55. package/es/locale/locale.d.ts +50 -0
  56. package/es/locale/locale.js +251 -0
  57. package/es/locale/zh-CN.d.ts +8 -0
  58. package/es/locale/zh-CN.js +8 -0
  59. package/es/style/color/colors.less +2 -0
  60. package/es/style/core/index.less +2 -0
  61. package/es/style/core/motion/other.less +28 -0
  62. package/es/style/core/motion/slide.less +53 -0
  63. package/es/style/core/motion.less +2 -0
  64. package/es/style/core/reset.less +186 -0
  65. package/es/style/css.js +1 -0
  66. package/es/style/index.css +410 -0
  67. package/es/style/index.d.ts +1 -0
  68. package/es/style/index.js +1 -0
  69. package/es/style/index.less +2 -0
  70. package/es/style/mixins/index.less +19 -0
  71. package/es/style/mixins/overlay.less +22 -0
  72. package/es/style/mixins/reset.less +13 -0
  73. package/es/style/themes/default.less +445 -0
  74. package/es/style/themes/index.less +1 -0
  75. package/es/table/base/calculations.d.ts +5 -0
  76. package/es/table/base/calculations.js +364 -0
  77. package/es/table/base/colgroup.d.ts +5 -0
  78. package/es/table/base/colgroup.js +22 -0
  79. package/es/table/base/empty.d.ts +9 -0
  80. package/es/table/base/empty.js +38 -0
  81. package/es/table/base/header.d.ts +5 -0
  82. package/es/table/base/header.js +324 -0
  83. package/es/table/base/helpers/SpanManager.d.ts +9 -0
  84. package/es/table/base/helpers/SpanManager.js +50 -0
  85. package/es/table/base/helpers/TableDOMUtils.d.ts +18 -0
  86. package/es/table/base/helpers/TableDOMUtils.js +104 -0
  87. package/es/table/base/helpers/__test__/SpanManager.test.d.ts +1 -0
  88. package/es/table/base/helpers/__test__/SpanManager.test.js +18 -0
  89. package/es/table/base/helpers/__test__/TableDOMUtils.test.d.ts +1 -0
  90. package/es/table/base/helpers/__test__/TableDOMUtils.test.js +34 -0
  91. package/es/table/base/helpers/__test__/rowHeightManager.test.d.ts +1 -0
  92. package/es/table/base/helpers/__test__/rowHeightManager.test.js +30 -0
  93. package/es/table/base/helpers/__test__/visible-part.test.d.ts +1 -0
  94. package/es/table/base/helpers/__test__/visible-part.test.js +28 -0
  95. package/es/table/base/helpers/rowHeightManager.d.ts +7 -0
  96. package/es/table/base/helpers/rowHeightManager.js +157 -0
  97. package/es/table/base/helpers/visible-part.d.ts +23 -0
  98. package/es/table/base/helpers/visible-part.js +58 -0
  99. package/es/table/base/html-table.d.ts +15 -0
  100. package/es/table/base/html-table.js +132 -0
  101. package/es/table/base/index.d.ts +3 -0
  102. package/es/table/base/index.js +2 -0
  103. package/es/table/base/interfaces.d.ts +54 -0
  104. package/es/table/base/interfaces.js +0 -0
  105. package/es/table/base/loading.d.ts +13 -0
  106. package/es/table/base/loading.js +60 -0
  107. package/es/table/base/styles.d.ts +132 -0
  108. package/es/table/base/styles.js +112 -0
  109. package/es/table/base/table.d.ts +150 -0
  110. package/es/table/base/table.js +733 -0
  111. package/es/table/base/utils.d.ts +36 -0
  112. package/es/table/base/utils.js +193 -0
  113. package/es/table/common-views.d.ts +24 -0
  114. package/es/table/common-views.js +70 -0
  115. package/es/table/index.d.ts +6 -0
  116. package/es/table/index.js +6 -0
  117. package/es/table/interfaces.d.ts +98 -0
  118. package/es/table/interfaces.js +0 -0
  119. package/es/table/internals.d.ts +14 -0
  120. package/es/table/internals.js +56 -0
  121. package/es/table/pipeline/features/__test__/multiSelect.test.d.ts +1 -0
  122. package/es/table/pipeline/features/__test__/multiSelect.test.js +152 -0
  123. package/es/table/pipeline/features/__test__/rowDetail.test.d.ts +1 -0
  124. package/es/table/pipeline/features/__test__/rowDetail.test.js +223 -0
  125. package/es/table/pipeline/features/__test__/rowGrouping.test.d.ts +1 -0
  126. package/es/table/pipeline/features/__test__/rowGrouping.test.js +120 -0
  127. package/es/table/pipeline/features/__test__/singleSelect.test.d.ts +1 -0
  128. package/es/table/pipeline/features/__test__/singleSelect.test.js +191 -0
  129. package/es/table/pipeline/features/__test__/sort.test.d.ts +1 -0
  130. package/es/table/pipeline/features/__test__/sort.test.js +213 -0
  131. package/es/table/pipeline/features/__test__/tips.test.d.ts +1 -0
  132. package/es/table/pipeline/features/__test__/tips.test.js +123 -0
  133. package/es/table/pipeline/features/__test__/treeMode.test.d.ts +1 -0
  134. package/es/table/pipeline/features/__test__/treeMode.test.js +202 -0
  135. package/es/table/pipeline/features/autoFill.d.ts +4 -0
  136. package/es/table/pipeline/features/autoFill.js +63 -0
  137. package/es/table/pipeline/features/autoRowSpan.d.ts +2 -0
  138. package/es/table/pipeline/features/autoRowSpan.js +72 -0
  139. package/es/table/pipeline/features/buildTree.d.ts +2 -0
  140. package/es/table/pipeline/features/buildTree.js +8 -0
  141. package/es/table/pipeline/features/columnDrag.d.ts +6 -0
  142. package/es/table/pipeline/features/columnDrag.js +265 -0
  143. package/es/table/pipeline/features/columnFilter.d.ts +20 -0
  144. package/es/table/pipeline/features/columnFilter.js +173 -0
  145. package/es/table/pipeline/features/columnHover.d.ts +12 -0
  146. package/es/table/pipeline/features/columnHover.js +51 -0
  147. package/es/table/pipeline/features/columnRangeHover.d.ts +15 -0
  148. package/es/table/pipeline/features/columnRangeHover.js +83 -0
  149. package/es/table/pipeline/features/columnResizeWidth.d.ts +21 -0
  150. package/es/table/pipeline/features/columnResizeWidth.js +173 -0
  151. package/es/table/pipeline/features/contextMenu.d.ts +14 -0
  152. package/es/table/pipeline/features/contextMenu.js +370 -0
  153. package/es/table/pipeline/features/filter/DefaultFilterContent.d.ts +4 -0
  154. package/es/table/pipeline/features/filter/DefaultFilterContent.js +91 -0
  155. package/es/table/pipeline/features/filter/Filter.d.ts +17 -0
  156. package/es/table/pipeline/features/filter/Filter.js +111 -0
  157. package/es/table/pipeline/features/filter/FilterPanel.d.ts +20 -0
  158. package/es/table/pipeline/features/filter/FilterPanel.js +81 -0
  159. package/es/table/pipeline/features/filter/__test__/Filter.test.d.ts +1 -0
  160. package/es/table/pipeline/features/filter/__test__/Filter.test.js +29 -0
  161. package/es/table/pipeline/features/filter/index.d.ts +4 -0
  162. package/es/table/pipeline/features/filter/index.js +4 -0
  163. package/es/table/pipeline/features/filter/util.d.ts +10 -0
  164. package/es/table/pipeline/features/filter/util.js +67 -0
  165. package/es/table/pipeline/features/index.d.ts +16 -0
  166. package/es/table/pipeline/features/index.js +16 -0
  167. package/es/table/pipeline/features/multiSelect.d.ts +27 -0
  168. package/es/table/pipeline/features/multiSelect.js +208 -0
  169. package/es/table/pipeline/features/rowDetail.d.ts +35 -0
  170. package/es/table/pipeline/features/rowDetail.js +254 -0
  171. package/es/table/pipeline/features/rowGrouping.d.ts +14 -0
  172. package/es/table/pipeline/features/rowGrouping.js +200 -0
  173. package/es/table/pipeline/features/singleSelect.d.ts +23 -0
  174. package/es/table/pipeline/features/singleSelect.js +122 -0
  175. package/es/table/pipeline/features/sort.d.ts +40 -0
  176. package/es/table/pipeline/features/sort.js +332 -0
  177. package/es/table/pipeline/features/tips.d.ts +2 -0
  178. package/es/table/pipeline/features/tips.js +57 -0
  179. package/es/table/pipeline/features/treeMode.d.ts +37 -0
  180. package/es/table/pipeline/features/treeMode.js +234 -0
  181. package/es/table/pipeline/features/treeSelect.d.ts +38 -0
  182. package/es/table/pipeline/features/treeSelect.js +154 -0
  183. package/es/table/pipeline/index.d.ts +3 -0
  184. package/es/table/pipeline/index.js +3 -0
  185. package/es/table/pipeline/pipeline.d.ts +85 -0
  186. package/es/table/pipeline/pipeline.js +272 -0
  187. package/es/table/pivot/cross-table/buildCrossTable.d.ts +14 -0
  188. package/es/table/pivot/cross-table/buildCrossTable.js +294 -0
  189. package/es/table/pivot/cross-table/constants.d.ts +1 -0
  190. package/es/table/pivot/cross-table/constants.js +1 -0
  191. package/es/table/pivot/cross-table/cross-table.d.ts +18 -0
  192. package/es/table/pivot/cross-table/cross-table.js +55 -0
  193. package/es/table/pivot/cross-table/index.d.ts +4 -0
  194. package/es/table/pivot/cross-table/index.js +3 -0
  195. package/es/table/pivot/cross-table/interfaces.d.ts +29 -0
  196. package/es/table/pivot/cross-table/interfaces.js +0 -0
  197. package/es/table/pivot/cross-table/internals.d.ts +13 -0
  198. package/es/table/pivot/cross-table/internals.js +0 -0
  199. package/es/table/pivot/cross-tree-table/buildCrossTreeTable.d.ts +14 -0
  200. package/es/table/pivot/cross-tree-table/buildCrossTreeTable.js +219 -0
  201. package/es/table/pivot/cross-tree-table/cross-tree-table.d.ts +38 -0
  202. package/es/table/pivot/cross-tree-table/cross-tree-table.js +127 -0
  203. package/es/table/pivot/cross-tree-table/index.d.ts +2 -0
  204. package/es/table/pivot/cross-tree-table/index.js +2 -0
  205. package/es/table/pivot/pivot-utils/buildDrillTree.d.ts +16 -0
  206. package/es/table/pivot/pivot-utils/buildDrillTree.js +93 -0
  207. package/es/table/pivot/pivot-utils/builders.d.ts +26 -0
  208. package/es/table/pivot/pivot-utils/builders.js +252 -0
  209. package/es/table/pivot/pivot-utils/convert-utils.d.ts +31 -0
  210. package/es/table/pivot/pivot-utils/convert-utils.js +180 -0
  211. package/es/table/pivot/pivot-utils/index.d.ts +5 -0
  212. package/es/table/pivot/pivot-utils/index.js +4 -0
  213. package/es/table/pivot/pivot-utils/interfaces.d.ts +12 -0
  214. package/es/table/pivot/pivot-utils/interfaces.js +0 -0
  215. package/es/table/pivot/pivot-utils/simpleEncode.d.ts +1 -0
  216. package/es/table/pivot/pivot-utils/simpleEncode.js +7 -0
  217. package/es/table/style/css.js +2 -0
  218. package/es/table/style/index.css +0 -0
  219. package/es/table/style/index.d.ts +2 -0
  220. package/es/table/style/index.js +2 -0
  221. package/es/table/style/index.less +1 -0
  222. package/es/table/transforms/autoRowSpan.d.ts +3 -0
  223. package/es/table/transforms/autoRowSpan.js +73 -0
  224. package/es/table/transforms/autoWidth.d.ts +25 -0
  225. package/es/table/transforms/autoWidth.js +160 -0
  226. package/es/table/transforms/buildTree.d.ts +3 -0
  227. package/es/table/transforms/buildTree.js +15 -0
  228. package/es/table/transforms/columnHover.d.ts +17 -0
  229. package/es/table/transforms/columnHover.js +59 -0
  230. package/es/table/transforms/columnRangeHover.d.ts +17 -0
  231. package/es/table/transforms/columnRangeHover.js +94 -0
  232. package/es/table/transforms/columnResize.d.ts +27 -0
  233. package/es/table/transforms/columnResize.js +152 -0
  234. package/es/table/transforms/flatten.d.ts +3 -0
  235. package/es/table/transforms/flatten.js +16 -0
  236. package/es/table/transforms/index.d.ts +12 -0
  237. package/es/table/transforms/index.js +12 -0
  238. package/es/table/transforms/orderField.d.ts +3 -0
  239. package/es/table/transforms/orderField.js +22 -0
  240. package/es/table/transforms/sort.d.ts +43 -0
  241. package/es/table/transforms/sort.js +338 -0
  242. package/es/table/transforms/tips.d.ts +8 -0
  243. package/es/table/transforms/tips.js +54 -0
  244. package/es/table/transforms/treeMode.d.ts +30 -0
  245. package/es/table/transforms/treeMode.js +252 -0
  246. package/es/table/transforms/visible.d.ts +5 -0
  247. package/es/table/transforms/visible.js +19 -0
  248. package/es/table/transforms/warnTransformsDeprecated.d.ts +1 -0
  249. package/es/table/transforms/warnTransformsDeprecated.js +8 -0
  250. package/es/table/use/useResizeObserver.d.ts +2 -0
  251. package/es/table/use/useResizeObserver.js +20 -0
  252. package/es/table/utils/applyTransforms.d.ts +6 -0
  253. package/es/table/utils/applyTransforms.js +15 -0
  254. package/es/table/utils/buildTree.d.ts +36 -0
  255. package/es/table/utils/buildTree.js +119 -0
  256. package/es/table/utils/collectNodes.d.ts +8 -0
  257. package/es/table/utils/collectNodes.js +59 -0
  258. package/es/table/utils/console.d.ts +11 -0
  259. package/es/table/utils/console.js +58 -0
  260. package/es/table/utils/copyToClipboard.d.ts +3 -0
  261. package/es/table/utils/copyToClipboard.js +30 -0
  262. package/es/table/utils/element.d.ts +42 -0
  263. package/es/table/utils/element.js +228 -0
  264. package/es/table/utils/exportTableAsExcel.d.ts +4 -0
  265. package/es/table/utils/exportTableAsExcel.js +188 -0
  266. package/es/table/utils/getTreeDepth.d.ts +3 -0
  267. package/es/table/utils/getTreeDepth.js +41 -0
  268. package/es/table/utils/groupBy.d.ts +1 -0
  269. package/es/table/utils/groupBy.js +37 -0
  270. package/es/table/utils/index.d.ts +18 -0
  271. package/es/table/utils/index.js +18 -0
  272. package/es/table/utils/isGroupColumn.d.ts +2 -0
  273. package/es/table/utils/isGroupColumn.js +7 -0
  274. package/es/table/utils/isLeafNode.d.ts +2 -0
  275. package/es/table/utils/isLeafNode.js +4 -0
  276. package/es/table/utils/layeredFilter.d.ts +2 -0
  277. package/es/table/utils/layeredFilter.js +25 -0
  278. package/es/table/utils/layeredSort.d.ts +5 -0
  279. package/es/table/utils/layeredSort.js +26 -0
  280. package/es/table/utils/makeRecursiveMapper.d.ts +9 -0
  281. package/es/table/utils/makeRecursiveMapper.js +76 -0
  282. package/es/table/utils/mergeCellProps.d.ts +8 -0
  283. package/es/table/utils/mergeCellProps.js +67 -0
  284. package/es/table/utils/others.d.ts +16 -0
  285. package/es/table/utils/others.js +80 -0
  286. package/es/table/utils/proto.d.ts +21 -0
  287. package/es/table/utils/proto.js +106 -0
  288. package/es/table/utils/smartCompare.d.ts +9 -0
  289. package/es/table/utils/smartCompare.js +51 -0
  290. package/es/table/utils/traverseColumn.d.ts +11 -0
  291. package/es/table/utils/traverseColumn.js +88 -0
  292. package/es/table/utils/tree-data-helpers/StrictTreeDataHelper.d.ts +22 -0
  293. package/es/table/utils/tree-data-helpers/StrictTreeDataHelper.js +138 -0
  294. package/es/table/utils/tree-data-helpers/TreeDataHelper.d.ts +26 -0
  295. package/es/table/utils/tree-data-helpers/TreeDataHelper.js +337 -0
  296. package/lib/_utils/arrayUtil.d.ts +5 -0
  297. package/lib/_utils/arrayUtil.js +26 -0
  298. package/lib/_utils/devwarning.d.ts +1 -0
  299. package/lib/_utils/devwarning.js +21 -0
  300. package/lib/_utils/formatUtil.d.ts +46 -0
  301. package/lib/_utils/formatUtil.js +358 -0
  302. package/lib/_utils/hooks.d.ts +51 -0
  303. package/lib/_utils/hooks.js +187 -0
  304. package/lib/_utils/index.d.ts +8 -0
  305. package/lib/_utils/index.js +28 -0
  306. package/lib/_utils/numberUtil.d.ts +34 -0
  307. package/lib/_utils/numberUtil.js +202 -0
  308. package/lib/_utils/omit.d.ts +1 -0
  309. package/lib/_utils/omit.js +21 -0
  310. package/lib/_utils/react-children.d.ts +2 -0
  311. package/lib/_utils/react-children.js +20 -0
  312. package/lib/_utils/type.d.ts +12 -0
  313. package/lib/_utils/type.js +27 -0
  314. package/lib/_utils/usePopper.d.ts +29 -0
  315. package/lib/_utils/usePopper.js +574 -0
  316. package/lib/config-provider/ConfigContext.d.ts +22 -0
  317. package/lib/config-provider/ConfigContext.js +19 -0
  318. package/lib/config-provider/compDefaultProps.d.ts +8 -0
  319. package/lib/config-provider/compDefaultProps.js +17 -0
  320. package/lib/config-provider/configProvider.d.ts +11 -0
  321. package/lib/config-provider/configProvider.js +56 -0
  322. package/lib/config-provider/defaultConfig.d.ts +10 -0
  323. package/lib/config-provider/defaultConfig.js +30 -0
  324. package/lib/config-provider/index.d.ts +6 -0
  325. package/lib/config-provider/index.js +37 -0
  326. package/lib/index.d.ts +2 -0
  327. package/lib/index.js +45 -0
  328. package/lib/locale/index.d.ts +3 -0
  329. package/lib/locale/index.js +25 -0
  330. package/lib/locale/locale.d.ts +50 -0
  331. package/lib/locale/locale.js +277 -0
  332. package/lib/locale/zh-CN.d.ts +8 -0
  333. package/lib/locale/zh-CN.js +15 -0
  334. package/lib/style/color/colors.less +2 -0
  335. package/lib/style/components.less +1 -0
  336. package/lib/style/core/index.less +2 -0
  337. package/lib/style/core/motion/other.less +28 -0
  338. package/lib/style/core/motion/slide.less +53 -0
  339. package/lib/style/core/motion.less +2 -0
  340. package/lib/style/core/reset.less +186 -0
  341. package/lib/style/css.js +3 -0
  342. package/lib/style/index.css +410 -0
  343. package/lib/style/index.d.ts +1 -0
  344. package/lib/style/index.js +3 -0
  345. package/lib/style/index.less +2 -0
  346. package/lib/style/mixins/index.less +19 -0
  347. package/lib/style/mixins/overlay.less +22 -0
  348. package/lib/style/mixins/reset.less +13 -0
  349. package/lib/style/themes/default.less +445 -0
  350. package/lib/style/themes/index.less +1 -0
  351. package/lib/table/base/calculations.d.ts +5 -0
  352. package/lib/table/base/calculations.js +385 -0
  353. package/lib/table/base/colgroup.d.ts +5 -0
  354. package/lib/table/base/colgroup.js +33 -0
  355. package/lib/table/base/empty.d.ts +9 -0
  356. package/lib/table/base/empty.js +54 -0
  357. package/lib/table/base/header.d.ts +5 -0
  358. package/lib/table/base/header.js +340 -0
  359. package/lib/table/base/helpers/SpanManager.d.ts +9 -0
  360. package/lib/table/base/helpers/SpanManager.js +59 -0
  361. package/lib/table/base/helpers/TableDOMUtils.d.ts +18 -0
  362. package/lib/table/base/helpers/TableDOMUtils.js +113 -0
  363. package/lib/table/base/helpers/__test__/SpanManager.test.d.ts +1 -0
  364. package/lib/table/base/helpers/__test__/SpanManager.test.js +23 -0
  365. package/lib/table/base/helpers/__test__/TableDOMUtils.test.d.ts +1 -0
  366. package/lib/table/base/helpers/__test__/TableDOMUtils.test.js +41 -0
  367. package/lib/table/base/helpers/__test__/rowHeightManager.test.d.ts +1 -0
  368. package/lib/table/base/helpers/__test__/rowHeightManager.test.js +33 -0
  369. package/lib/table/base/helpers/__test__/visible-part.test.d.ts +1 -0
  370. package/lib/table/base/helpers/__test__/visible-part.test.js +31 -0
  371. package/lib/table/base/helpers/rowHeightManager.d.ts +7 -0
  372. package/lib/table/base/helpers/rowHeightManager.js +170 -0
  373. package/lib/table/base/helpers/visible-part.d.ts +23 -0
  374. package/lib/table/base/helpers/visible-part.js +72 -0
  375. package/lib/table/base/html-table.d.ts +15 -0
  376. package/lib/table/base/html-table.js +149 -0
  377. package/lib/table/base/index.d.ts +3 -0
  378. package/lib/table/base/index.js +21 -0
  379. package/lib/table/base/interfaces.d.ts +54 -0
  380. package/lib/table/base/interfaces.js +0 -0
  381. package/lib/table/base/loading.d.ts +13 -0
  382. package/lib/table/base/loading.js +71 -0
  383. package/lib/table/base/styles.d.ts +132 -0
  384. package/lib/table/base/styles.js +136 -0
  385. package/lib/table/base/table.d.ts +150 -0
  386. package/lib/table/base/table.js +773 -0
  387. package/lib/table/base/utils.d.ts +36 -0
  388. package/lib/table/base/utils.js +234 -0
  389. package/lib/table/common-views.d.ts +24 -0
  390. package/lib/table/common-views.js +90 -0
  391. package/lib/table/index.d.ts +6 -0
  392. package/lib/table/index.js +85 -0
  393. package/lib/table/interfaces.d.ts +98 -0
  394. package/lib/table/interfaces.js +0 -0
  395. package/lib/table/internals.d.ts +14 -0
  396. package/lib/table/internals.js +64 -0
  397. package/lib/table/pipeline/features/__test__/multiSelect.test.d.ts +1 -0
  398. package/lib/table/pipeline/features/__test__/multiSelect.test.js +163 -0
  399. package/lib/table/pipeline/features/__test__/rowDetail.test.d.ts +1 -0
  400. package/lib/table/pipeline/features/__test__/rowDetail.test.js +230 -0
  401. package/lib/table/pipeline/features/__test__/rowGrouping.test.d.ts +1 -0
  402. package/lib/table/pipeline/features/__test__/rowGrouping.test.js +129 -0
  403. package/lib/table/pipeline/features/__test__/singleSelect.test.d.ts +1 -0
  404. package/lib/table/pipeline/features/__test__/singleSelect.test.js +201 -0
  405. package/lib/table/pipeline/features/__test__/sort.test.d.ts +1 -0
  406. package/lib/table/pipeline/features/__test__/sort.test.js +218 -0
  407. package/lib/table/pipeline/features/__test__/tips.test.d.ts +1 -0
  408. package/lib/table/pipeline/features/__test__/tips.test.js +133 -0
  409. package/lib/table/pipeline/features/__test__/treeMode.test.d.ts +1 -0
  410. package/lib/table/pipeline/features/__test__/treeMode.test.js +206 -0
  411. package/lib/table/pipeline/features/autoFill.d.ts +4 -0
  412. package/lib/table/pipeline/features/autoFill.js +80 -0
  413. package/lib/table/pipeline/features/autoRowSpan.d.ts +2 -0
  414. package/lib/table/pipeline/features/autoRowSpan.js +84 -0
  415. package/lib/table/pipeline/features/buildTree.d.ts +2 -0
  416. package/lib/table/pipeline/features/buildTree.js +16 -0
  417. package/lib/table/pipeline/features/columnDrag.d.ts +6 -0
  418. package/lib/table/pipeline/features/columnDrag.js +278 -0
  419. package/lib/table/pipeline/features/columnFilter.d.ts +20 -0
  420. package/lib/table/pipeline/features/columnFilter.js +197 -0
  421. package/lib/table/pipeline/features/columnHover.d.ts +12 -0
  422. package/lib/table/pipeline/features/columnHover.js +62 -0
  423. package/lib/table/pipeline/features/columnRangeHover.d.ts +15 -0
  424. package/lib/table/pipeline/features/columnRangeHover.js +95 -0
  425. package/lib/table/pipeline/features/columnResizeWidth.d.ts +21 -0
  426. package/lib/table/pipeline/features/columnResizeWidth.js +192 -0
  427. package/lib/table/pipeline/features/contextMenu.d.ts +14 -0
  428. package/lib/table/pipeline/features/contextMenu.js +397 -0
  429. package/lib/table/pipeline/features/filter/DefaultFilterContent.d.ts +4 -0
  430. package/lib/table/pipeline/features/filter/DefaultFilterContent.js +112 -0
  431. package/lib/table/pipeline/features/filter/Filter.d.ts +17 -0
  432. package/lib/table/pipeline/features/filter/Filter.js +129 -0
  433. package/lib/table/pipeline/features/filter/FilterPanel.d.ts +20 -0
  434. package/lib/table/pipeline/features/filter/FilterPanel.js +98 -0
  435. package/lib/table/pipeline/features/filter/__test__/Filter.test.d.ts +1 -0
  436. package/lib/table/pipeline/features/filter/__test__/Filter.test.js +36 -0
  437. package/lib/table/pipeline/features/filter/index.d.ts +4 -0
  438. package/lib/table/pipeline/features/filter/index.js +39 -0
  439. package/lib/table/pipeline/features/filter/util.d.ts +10 -0
  440. package/lib/table/pipeline/features/filter/util.js +77 -0
  441. package/lib/table/pipeline/features/index.d.ts +16 -0
  442. package/lib/table/pipeline/features/index.js +141 -0
  443. package/lib/table/pipeline/features/multiSelect.d.ts +27 -0
  444. package/lib/table/pipeline/features/multiSelect.js +227 -0
  445. package/lib/table/pipeline/features/rowDetail.d.ts +35 -0
  446. package/lib/table/pipeline/features/rowDetail.js +283 -0
  447. package/lib/table/pipeline/features/rowGrouping.d.ts +14 -0
  448. package/lib/table/pipeline/features/rowGrouping.js +227 -0
  449. package/lib/table/pipeline/features/singleSelect.d.ts +23 -0
  450. package/lib/table/pipeline/features/singleSelect.js +138 -0
  451. package/lib/table/pipeline/features/sort.d.ts +40 -0
  452. package/lib/table/pipeline/features/sort.js +361 -0
  453. package/lib/table/pipeline/features/tips.d.ts +2 -0
  454. package/lib/table/pipeline/features/tips.js +73 -0
  455. package/lib/table/pipeline/features/treeMode.d.ts +37 -0
  456. package/lib/table/pipeline/features/treeMode.js +266 -0
  457. package/lib/table/pipeline/features/treeSelect.d.ts +38 -0
  458. package/lib/table/pipeline/features/treeSelect.js +169 -0
  459. package/lib/table/pipeline/index.d.ts +3 -0
  460. package/lib/table/pipeline/index.js +26 -0
  461. package/lib/table/pipeline/pipeline.d.ts +85 -0
  462. package/lib/table/pipeline/pipeline.js +291 -0
  463. package/lib/table/pivot/cross-table/buildCrossTable.d.ts +14 -0
  464. package/lib/table/pivot/cross-table/buildCrossTable.js +313 -0
  465. package/lib/table/pivot/cross-table/constants.d.ts +1 -0
  466. package/lib/table/pivot/cross-table/constants.js +8 -0
  467. package/lib/table/pivot/cross-table/cross-table.d.ts +18 -0
  468. package/lib/table/pivot/cross-table/cross-table.js +71 -0
  469. package/lib/table/pivot/cross-table/index.d.ts +4 -0
  470. package/lib/table/pivot/cross-table/index.js +31 -0
  471. package/lib/table/pivot/cross-table/interfaces.d.ts +29 -0
  472. package/lib/table/pivot/cross-table/interfaces.js +0 -0
  473. package/lib/table/pivot/cross-table/internals.d.ts +13 -0
  474. package/lib/table/pivot/cross-table/internals.js +0 -0
  475. package/lib/table/pivot/cross-tree-table/buildCrossTreeTable.d.ts +14 -0
  476. package/lib/table/pivot/cross-tree-table/buildCrossTreeTable.js +240 -0
  477. package/lib/table/pivot/cross-tree-table/cross-tree-table.d.ts +38 -0
  478. package/lib/table/pivot/cross-tree-table/cross-tree-table.js +144 -0
  479. package/lib/table/pivot/cross-tree-table/index.d.ts +2 -0
  480. package/lib/table/pivot/cross-tree-table/index.js +23 -0
  481. package/lib/table/pivot/pivot-utils/buildDrillTree.d.ts +16 -0
  482. package/lib/table/pivot/pivot-utils/buildDrillTree.js +106 -0
  483. package/lib/table/pivot/pivot-utils/builders.d.ts +26 -0
  484. package/lib/table/pivot/pivot-utils/builders.js +272 -0
  485. package/lib/table/pivot/pivot-utils/convert-utils.d.ts +31 -0
  486. package/lib/table/pivot/pivot-utils/convert-utils.js +204 -0
  487. package/lib/table/pivot/pivot-utils/index.d.ts +5 -0
  488. package/lib/table/pivot/pivot-utils/index.js +59 -0
  489. package/lib/table/pivot/pivot-utils/interfaces.d.ts +12 -0
  490. package/lib/table/pivot/pivot-utils/interfaces.js +0 -0
  491. package/lib/table/pivot/pivot-utils/simpleEncode.d.ts +1 -0
  492. package/lib/table/pivot/pivot-utils/simpleEncode.js +14 -0
  493. package/lib/table/style/css.js +5 -0
  494. package/lib/table/style/index.css +0 -0
  495. package/lib/table/style/index.d.ts +2 -0
  496. package/lib/table/style/index.js +5 -0
  497. package/lib/table/style/index.less +1 -0
  498. package/lib/table/transforms/autoRowSpan.d.ts +3 -0
  499. package/lib/table/transforms/autoRowSpan.js +86 -0
  500. package/lib/table/transforms/autoWidth.d.ts +25 -0
  501. package/lib/table/transforms/autoWidth.js +187 -0
  502. package/lib/table/transforms/buildTree.d.ts +3 -0
  503. package/lib/table/transforms/buildTree.js +23 -0
  504. package/lib/table/transforms/columnHover.d.ts +17 -0
  505. package/lib/table/transforms/columnHover.js +74 -0
  506. package/lib/table/transforms/columnRangeHover.d.ts +17 -0
  507. package/lib/table/transforms/columnRangeHover.js +110 -0
  508. package/lib/table/transforms/columnResize.d.ts +27 -0
  509. package/lib/table/transforms/columnResize.js +176 -0
  510. package/lib/table/transforms/flatten.d.ts +3 -0
  511. package/lib/table/transforms/flatten.js +24 -0
  512. package/lib/table/transforms/index.d.ts +12 -0
  513. package/lib/table/transforms/index.js +131 -0
  514. package/lib/table/transforms/orderField.d.ts +3 -0
  515. package/lib/table/transforms/orderField.js +33 -0
  516. package/lib/table/transforms/sort.d.ts +43 -0
  517. package/lib/table/transforms/sort.js +369 -0
  518. package/lib/table/transforms/tips.d.ts +8 -0
  519. package/lib/table/transforms/tips.js +71 -0
  520. package/lib/table/transforms/treeMode.d.ts +30 -0
  521. package/lib/table/transforms/treeMode.js +286 -0
  522. package/lib/table/transforms/visible.d.ts +5 -0
  523. package/lib/table/transforms/visible.js +31 -0
  524. package/lib/table/transforms/warnTransformsDeprecated.d.ts +1 -0
  525. package/lib/table/transforms/warnTransformsDeprecated.js +19 -0
  526. package/lib/table/use/useResizeObserver.d.ts +2 -0
  527. package/lib/table/use/useResizeObserver.js +32 -0
  528. package/lib/table/utils/applyTransforms.d.ts +6 -0
  529. package/lib/table/utils/applyTransforms.js +24 -0
  530. package/lib/table/utils/buildTree.d.ts +36 -0
  531. package/lib/table/utils/buildTree.js +140 -0
  532. package/lib/table/utils/collectNodes.d.ts +8 -0
  533. package/lib/table/utils/collectNodes.js +72 -0
  534. package/lib/table/utils/console.d.ts +11 -0
  535. package/lib/table/utils/console.js +68 -0
  536. package/lib/table/utils/copyToClipboard.d.ts +3 -0
  537. package/lib/table/utils/copyToClipboard.js +40 -0
  538. package/lib/table/utils/element.d.ts +42 -0
  539. package/lib/table/utils/element.js +243 -0
  540. package/lib/table/utils/exportTableAsExcel.d.ts +4 -0
  541. package/lib/table/utils/exportTableAsExcel.js +205 -0
  542. package/lib/table/utils/getTreeDepth.d.ts +3 -0
  543. package/lib/table/utils/getTreeDepth.js +54 -0
  544. package/lib/table/utils/groupBy.d.ts +1 -0
  545. package/lib/table/utils/groupBy.js +48 -0
  546. package/lib/table/utils/index.d.ts +18 -0
  547. package/lib/table/utils/index.js +187 -0
  548. package/lib/table/utils/isGroupColumn.d.ts +2 -0
  549. package/lib/table/utils/isGroupColumn.js +17 -0
  550. package/lib/table/utils/isLeafNode.d.ts +2 -0
  551. package/lib/table/utils/isLeafNode.js +11 -0
  552. package/lib/table/utils/layeredFilter.d.ts +2 -0
  553. package/lib/table/utils/layeredFilter.js +38 -0
  554. package/lib/table/utils/layeredSort.d.ts +5 -0
  555. package/lib/table/utils/layeredSort.js +37 -0
  556. package/lib/table/utils/makeRecursiveMapper.d.ts +9 -0
  557. package/lib/table/utils/makeRecursiveMapper.js +94 -0
  558. package/lib/table/utils/mergeCellProps.d.ts +8 -0
  559. package/lib/table/utils/mergeCellProps.js +78 -0
  560. package/lib/table/utils/others.d.ts +16 -0
  561. package/lib/table/utils/others.js +108 -0
  562. package/lib/table/utils/proto.d.ts +21 -0
  563. package/lib/table/utils/proto.js +117 -0
  564. package/lib/table/utils/smartCompare.d.ts +9 -0
  565. package/lib/table/utils/smartCompare.js +58 -0
  566. package/lib/table/utils/traverseColumn.d.ts +11 -0
  567. package/lib/table/utils/traverseColumn.js +103 -0
  568. package/lib/table/utils/tree-data-helpers/StrictTreeDataHelper.d.ts +22 -0
  569. package/lib/table/utils/tree-data-helpers/StrictTreeDataHelper.js +154 -0
  570. package/lib/table/utils/tree-data-helpers/TreeDataHelper.d.ts +26 -0
  571. package/lib/table/utils/tree-data-helpers/TreeDataHelper.js +358 -0
  572. package/package.json +213 -0
@@ -0,0 +1,111 @@
1
+ import _slicedToArray from "@babel/runtime-corejs3/helpers/slicedToArray";
2
+ import _taggedTemplateLiteral from "@babel/runtime-corejs3/helpers/taggedTemplateLiteral";
3
+
4
+ var _templateObject;
5
+
6
+ import React from 'react';
7
+ import { createPortal } from 'react-dom';
8
+ import styled from 'styled-components';
9
+ import { Classes } from '../../../base/styles';
10
+ import FilterPanel from './FilterPanel';
11
+ import DefaultFilterContent from './DefaultFilterContent';
12
+ import { calculatePopupRelative } from '../../../utils';
13
+ var HEADER_ICON_OFFSET_Y = 6 + 1; //padding-top + border
14
+
15
+ var HEADER_ICON_OFFSET_X = 16 + 1; //padding-left+ border
16
+
17
+ var FilterIconSpanStyle = styled.span(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n position: absolute;\n right: 4px;\n cursor: pointer;\n transform: translateY(-50%);\n top: 50%;\n height: 12px; \n"])));
18
+
19
+ function Filter(_ref) {
20
+ var _ref$size = _ref.size,
21
+ size = _ref$size === void 0 ? 12 : _ref$size,
22
+ style = _ref.style,
23
+ className = _ref.className,
24
+ FilterPanelContent = _ref.FilterPanelContent,
25
+ filterIcon = _ref.filterIcon,
26
+ setFilter = _ref.setFilter,
27
+ setFilterModel = _ref.setFilterModel,
28
+ filterModel = _ref.filterModel,
29
+ isFilterActive = _ref.isFilterActive,
30
+ stopClickEventPropagation = _ref.stopClickEventPropagation;
31
+
32
+ var _React$useState = React.useState(false),
33
+ _React$useState2 = _slicedToArray(_React$useState, 2),
34
+ showPanel = _React$useState2[0],
35
+ setShowPanel = _React$useState2[1];
36
+
37
+ var iconRef = React.useRef(null);
38
+
39
+ var hidePanel = function hidePanel() {
40
+ return setShowPanel(false);
41
+ };
42
+
43
+ var handleMouseDown = function handleMouseDown(e) {
44
+ e.stopPropagation(); // 阻止触发拖拽
45
+ };
46
+
47
+ var renderPanelContent = function renderPanelContent() {
48
+ if (FilterPanelContent) {
49
+ return /*#__PURE__*/React.createElement(FilterPanelContent, {
50
+ setFilter: setFilter,
51
+ filterModel: filterModel,
52
+ isFilterActive: isFilterActive,
53
+ hidePanel: hidePanel
54
+ });
55
+ } else {
56
+ return /*#__PURE__*/React.createElement(DefaultFilterContent, {
57
+ setFilterModel: setFilterModel,
58
+ filterModel: filterModel,
59
+ isFilterActive: isFilterActive,
60
+ hidePanel: hidePanel
61
+ });
62
+ }
63
+ };
64
+
65
+ var renderPanel = function renderPanel(ele) {
66
+ var position = calculatePopupRelative(ele, document.body, {
67
+ x: HEADER_ICON_OFFSET_X,
68
+ y: HEADER_ICON_OFFSET_Y
69
+ });
70
+ var style = {
71
+ position: 'absolute',
72
+ zIndex: 1050
73
+ };
74
+ return /*#__PURE__*/React.createElement(FilterPanel, {
75
+ style: style,
76
+ onClose: hidePanel,
77
+ position: position,
78
+ filterIcon: filterIcon
79
+ }, renderPanelContent());
80
+ };
81
+
82
+ var handleIconClick = function handleIconClick(e) {
83
+ if (stopClickEventPropagation) {
84
+ e.stopPropagation();
85
+ }
86
+
87
+ setShowPanel(true);
88
+ };
89
+
90
+ return /*#__PURE__*/React.createElement(FilterIconSpanStyle, {
91
+ style: style,
92
+ className: className,
93
+ onMouseDown: handleMouseDown,
94
+ ref: iconRef
95
+ }, /*#__PURE__*/React.createElement("span", {
96
+ className: Classes.filterIcon,
97
+ onClick: handleIconClick
98
+ }, filterIcon || /*#__PURE__*/React.createElement("svg", {
99
+ width: size,
100
+ height: size,
101
+ viewBox: "64 64 896 896",
102
+ focusable: "false",
103
+ "data-icon": "filter",
104
+ fill: "currentColor",
105
+ "aria-hidden": "true"
106
+ }, /*#__PURE__*/React.createElement("path", {
107
+ d: "M349 838c0 17.7 14.2 32 31.8 32h262.4c17.6 0 31.8-14.3\n 31.8-32V642H349v196zm531.1-684H143.9c-24.5 0-39.8 26.7-27.5\n 48l221.3 376h348.8l221.3-376c12.1-21.3-3.2-48-27.7-48z"
108
+ }))), showPanel && /*#__PURE__*/createPortal(renderPanel(iconRef.current), document.body));
109
+ }
110
+
111
+ export default Filter;
@@ -0,0 +1,20 @@
1
+ import { CSSProperties, ReactNode } from 'react';
2
+ interface PositionType {
3
+ x: number;
4
+ y: number;
5
+ }
6
+ export interface FilterPanel {
7
+ onClose: () => any;
8
+ position: PositionType;
9
+ style?: CSSProperties;
10
+ filterIcon: ReactNode;
11
+ children?: ReactNode;
12
+ }
13
+ declare function FilterPanel({ style, children, position, filterIcon, onClose }: {
14
+ style: any;
15
+ children: any;
16
+ position: any;
17
+ filterIcon: any;
18
+ onClose: any;
19
+ }): JSX.Element;
20
+ export default FilterPanel;
@@ -0,0 +1,81 @@
1
+ import _extends from "@babel/runtime-corejs3/helpers/extends";
2
+ import _slicedToArray from "@babel/runtime-corejs3/helpers/slicedToArray";
3
+ import _taggedTemplateLiteral from "@babel/runtime-corejs3/helpers/taggedTemplateLiteral";
4
+
5
+ var _templateObject;
6
+
7
+ import React, { useEffect, useState } from 'react';
8
+ import styled from 'styled-components';
9
+ import { isElementInEventPath, keepWithinBounds } from '../../../utils/';
10
+ var FilterPanelStyle = styled.div(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n display: flex;\n flex-direction: column;\n max-height: 450px;\n min-width: 160px;\n border-radius: 2px;\n background-color: #fff;\n box-shadow: 0 0 5px 0 rgba(154,154,154,.5);\n cursor: default;\n\n .popup-header {\n display: flex;\n background-color: #ebedf1;\n\n .popup-header-icon {\n color:#666;\n background-color: #fff;\n padding: 6px 16px 6px 16px;\n display: inline-block;\n border-right: 1px solid transparent;\n border-left: 1px solid transparent;\n border-top: 1px solid transparent;\n border-top-right-radius: 2px;\n border-top-left-radius: 2px;\n }\n }\n\n .popup-body {\n display: flex;\n }\n"])));
11
+
12
+ var useWindowEvents = function useWindowEvents(func, evens) {
13
+ React.useEffect(function () {
14
+ evens.forEach(function (event) {
15
+ return window.addEventListener(event, func, true);
16
+ });
17
+ return function () {
18
+ return evens.forEach(function (event) {
19
+ return window.removeEventListener(event, func, true);
20
+ });
21
+ };
22
+ }, [evens, func]);
23
+ };
24
+
25
+ function FilterPanel(_ref) {
26
+ var style = _ref.style,
27
+ children = _ref.children,
28
+ position = _ref.position,
29
+ filterIcon = _ref.filterIcon,
30
+ onClose = _ref.onClose;
31
+
32
+ var _useState = useState(position),
33
+ _useState2 = _slicedToArray(_useState, 2),
34
+ perfectPosition = _useState2[0],
35
+ setPerfectPosition = _useState2[1];
36
+
37
+ var _useState3 = useState(false),
38
+ _useState4 = _slicedToArray(_useState3, 2),
39
+ opaque = _useState4[0],
40
+ setOpaque = _useState4[1];
41
+
42
+ var ref = React.useRef(null);
43
+
44
+ var isContainPanel = function isContainPanel(e) {
45
+ return isElementInEventPath(ref.current, e);
46
+ };
47
+
48
+ useEffect(function () {
49
+ setPerfectPosition(keepWithinBounds(document.body, ref.current, position.x, position.y, true));
50
+ setOpaque(true);
51
+ }, [position]);
52
+ useWindowEvents(function (e) {
53
+ return !isContainPanel(e) && onClose();
54
+ }, ['mousedown']);
55
+ return /*#__PURE__*/React.createElement(FilterPanelStyle, {
56
+ style: _extends(_extends({}, style), {
57
+ left: perfectPosition.x,
58
+ top: perfectPosition.y,
59
+ opacity: opaque ? 1 : 0
60
+ }),
61
+ ref: ref
62
+ }, /*#__PURE__*/React.createElement("div", {
63
+ className: 'popup-header'
64
+ }, /*#__PURE__*/React.createElement("span", {
65
+ className: 'popup-header-icon'
66
+ }, filterIcon || /*#__PURE__*/React.createElement("svg", {
67
+ width: 14,
68
+ height: 14,
69
+ viewBox: "64 64 896 896",
70
+ focusable: "false",
71
+ "data-icon": "filter",
72
+ fill: "currentColor",
73
+ "aria-hidden": "true"
74
+ }, /*#__PURE__*/React.createElement("path", {
75
+ d: "M349 838c0 17.7 14.2 32 31.8 32h262.4c17.6 0 31.8-14.3\n 31.8-32V642H349v196zm531.1-684H143.9c-24.5 0-39.8 26.7-27.5\n 48l221.3 376h348.8l221.3-376c12.1-21.3-3.2-48-27.7-48z"
76
+ })))), /*#__PURE__*/React.createElement("div", {
77
+ className: "popup-body"
78
+ }, children));
79
+ }
80
+
81
+ export default FilterPanel;
@@ -0,0 +1,29 @@
1
+ import _findInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/find";
2
+ import React from 'react';
3
+ import { mount } from 'enzyme';
4
+ import { Classes } from '../../../../base/styles';
5
+ import Filter from '../Filter';
6
+ import DefaultFilterContent from '../DefaultFilterContent';
7
+ var NAME = 'Filter';
8
+ var setFilter = jest.fn();
9
+ var setFilterModel = jest.fn();
10
+ describe("".concat(NAME), function () {
11
+ it('render and test event', function () {
12
+ var wrapper = mount( /*#__PURE__*/React.createElement(Filter, {
13
+ setFilter: setFilter,
14
+ setFilterModel: setFilterModel,
15
+ filterModel: {
16
+ filter: []
17
+ },
18
+ stopClickEventPropagation: true,
19
+ isFilterActive: true
20
+ }));
21
+
22
+ _findInstanceProperty(wrapper).call(wrapper, ".".concat(Classes.filterIcon)).at(0).simulate('click');
23
+
24
+ _findInstanceProperty(wrapper).call(wrapper, 'div').at(0).simulate('mousedown');
25
+
26
+ expect(_findInstanceProperty(wrapper).call(wrapper, DefaultFilterContent).length).toBe(1);
27
+ wrapper.unmount();
28
+ });
29
+ });
@@ -0,0 +1,4 @@
1
+ export { default as FilterPanel } from './FilterPanel';
2
+ export { default as DefaultFilterContent } from './DefaultFilterContent';
3
+ export { default as Filter } from './Filter';
4
+ export { DEFAULT_FILTER_OPTIONS } from './util';
@@ -0,0 +1,4 @@
1
+ export { default as FilterPanel } from './FilterPanel';
2
+ export { default as DefaultFilterContent } from './DefaultFilterContent';
3
+ export { default as Filter } from './Filter';
4
+ export { DEFAULT_FILTER_OPTIONS } from './util';
@@ -0,0 +1,10 @@
1
+ declare const DEFAULT_FILTER_OPTIONS: ({
2
+ title: string;
3
+ key: string;
4
+ filter: (value: any) => (data: any) => any;
5
+ } | {
6
+ title: string;
7
+ key: string;
8
+ filter: () => (data: any) => boolean;
9
+ })[];
10
+ export { DEFAULT_FILTER_OPTIONS };
@@ -0,0 +1,67 @@
1
+ import _includesInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/includes";
2
+ var DEFAULT_FILTER_OPTIONS = [{
3
+ title: '包含',
4
+ key: 'contain',
5
+ filter: function filter(value) {
6
+ return function (data) {
7
+ if (data == null) {
8
+ return false;
9
+ }
10
+
11
+ if (typeof data === 'number') {
12
+ data = data + '';
13
+ }
14
+
15
+ return _includesInstanceProperty(data).call(data, value);
16
+ };
17
+ }
18
+ }, {
19
+ title: '不包含',
20
+ key: 'notContain',
21
+ filter: function filter(value) {
22
+ return function (data) {
23
+ if (data == null) {
24
+ return true;
25
+ }
26
+
27
+ if (typeof data === 'number') {
28
+ data = data + '';
29
+ }
30
+
31
+ return !_includesInstanceProperty(data).call(data, value);
32
+ };
33
+ }
34
+ }, {
35
+ title: '等于',
36
+ key: 'equal',
37
+ filter: function filter(value) {
38
+ return function (data) {
39
+ return value !== data;
40
+ };
41
+ }
42
+ }, {
43
+ title: '不等于',
44
+ key: 'notEqual',
45
+ filter: function filter(value) {
46
+ return function (data) {
47
+ return value !== data;
48
+ };
49
+ }
50
+ }, {
51
+ title: '为空',
52
+ key: 'isNull',
53
+ filter: function filter() {
54
+ return function (data) {
55
+ return !data;
56
+ };
57
+ }
58
+ }, {
59
+ title: '不为空',
60
+ key: 'notIsNull',
61
+ filter: function filter() {
62
+ return function (data) {
63
+ return !!data;
64
+ };
65
+ }
66
+ }];
67
+ export { DEFAULT_FILTER_OPTIONS };
@@ -0,0 +1,16 @@
1
+ export { autoRowSpan } from './autoRowSpan';
2
+ export { buildTree } from './buildTree';
3
+ export { columnHover, ColumnHoverFeatureOptions } from './columnHover';
4
+ export { columnRangeHover, ColumnRangeHoverFeatureOptions } from './columnRangeHover';
5
+ export { multiSelect, MultiSelectFeatureOptions } from './multiSelect';
6
+ export { rowDetail, RowDetailFeatureOptions } from './rowDetail';
7
+ export { rowGrouping, RowGroupingFeatureOptions } from './rowGrouping';
8
+ export { singleSelect, SingleSelectFeatureOptions } from './singleSelect';
9
+ export { sort, SortFeatureOptions } from './sort';
10
+ export { tips } from './tips';
11
+ export { treeMode, TreeModeFeatureOptions, treeMetaSymbol } from './treeMode';
12
+ export { treeSelect, TreeSelectFeatureOptions } from './treeSelect';
13
+ export { columnDrag, ColumnDragOptions } from './columnDrag';
14
+ export { columnResize, ColumnResizeOptions } from './columnResizeWidth';
15
+ export { contextMenu, ContextMenuFeatureOptions } from './contextMenu';
16
+ export { filter, FilterFeatureOptions } from './columnFilter';
@@ -0,0 +1,16 @@
1
+ export { autoRowSpan } from './autoRowSpan';
2
+ export { buildTree } from './buildTree';
3
+ export { columnHover } from './columnHover';
4
+ export { columnRangeHover } from './columnRangeHover';
5
+ export { multiSelect } from './multiSelect';
6
+ export { rowDetail } from './rowDetail';
7
+ export { rowGrouping } from './rowGrouping';
8
+ export { singleSelect } from './singleSelect';
9
+ export { sort } from './sort';
10
+ export { tips } from './tips';
11
+ export { treeMode, treeMetaSymbol } from './treeMode';
12
+ export { treeSelect } from './treeSelect';
13
+ export { columnDrag } from './columnDrag';
14
+ export { columnResize } from './columnResizeWidth';
15
+ export { contextMenu } from './contextMenu';
16
+ export { filter } from './columnFilter';
@@ -0,0 +1,27 @@
1
+ import { ArtColumn } from '../../interfaces';
2
+ import { TablePipeline } from '../pipeline';
3
+ export interface MultiSelectFeatureOptions {
4
+ /** 非受控用法:默认选中的值 */
5
+ defaultValue?: string[];
6
+ /** 非受控用法:默认 lastKey */
7
+ defaultLastKey?: string;
8
+ /** 受控用法:当前选中的 keys */
9
+ value?: string[];
10
+ /** 受控用法:上一次操作对应的 rowKey */
11
+ lastKey?: string;
12
+ /** 受控用法:状态改变回调 */
13
+ onChange?: (nextValue: string[], key: string, keys: string[], action: 'check' | 'uncheck' | 'check-all' | 'uncheck-all') => void;
14
+ /** 复选框所在列的位置 */
15
+ checkboxPlacement?: 'start' | 'end';
16
+ /** 复选框所在列的 column 配置,可指定 width,lock, title, align, features 等属性 */
17
+ checkboxColumn?: Partial<ArtColumn>;
18
+ /** 是否高亮被选中的行 */
19
+ highlightRowWhenSelected?: boolean;
20
+ /** 判断一行中的 checkbox 是否要禁用 */
21
+ isDisabled?(row: any, rowIndex: number): boolean;
22
+ /** 点击事件的响应区域 */
23
+ clickArea?: 'checkbox' | 'cell' | 'row';
24
+ /** 是否对触发 onChange 的 click 事件调用 event.stopPropagation() */
25
+ stopClickEventPropagation?: boolean;
26
+ }
27
+ export declare function multiSelect(opts?: MultiSelectFeatureOptions): (pipeline: TablePipeline) => TablePipeline;
@@ -0,0 +1,208 @@
1
+ import _slicedToArray from "@babel/runtime-corejs3/helpers/slicedToArray";
2
+ import _extends from "@babel/runtime-corejs3/helpers/extends";
3
+ import _Set from "@babel/runtime-corejs3/core-js-stable/set";
4
+ import _sliceInstanceProperty from "@babel/runtime-corejs3/core-js-stable/instance/slice";
5
+ import React from 'react';
6
+ import { internals } from '../../internals';
7
+ import { always, arrayUtils } from '../../utils/others';
8
+ import { mergeCellProps } from '../../utils';
9
+ export function multiSelect() {
10
+ var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
11
+ return function multiSelectStep(pipeline) {
12
+ var _context;
13
+
14
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l;
15
+
16
+ var stateKey = 'multiSelect';
17
+ var Checkbox = pipeline.ctx.components.Checkbox;
18
+
19
+ if (Checkbox == null) {
20
+ throw new Error('使用 multiSelect 之前需要设置 pipeline.ctx.components.Checkbox');
21
+ }
22
+
23
+ var primaryKey = pipeline.ensurePrimaryKey('multiSelect');
24
+ var isDisabled = (_a = opts.isDisabled) !== null && _a !== void 0 ? _a : always(false);
25
+ var clickArea = (_b = opts.clickArea) !== null && _b !== void 0 ? _b : 'checkbox';
26
+ var value = (_f = (_e = (_c = opts.value) !== null && _c !== void 0 ? _c : (_d = pipeline.getStateAtKey(stateKey)) === null || _d === void 0 ? void 0 : _d.value) !== null && _e !== void 0 ? _e : opts.defaultValue) !== null && _f !== void 0 ? _f : [];
27
+ var lastKey = (_k = (_j = (_g = opts.lastKey) !== null && _g !== void 0 ? _g : (_h = pipeline.getStateAtKey(stateKey)) === null || _h === void 0 ? void 0 : _h.lastKey) !== null && _j !== void 0 ? _j : opts.defaultLastKey) !== null && _k !== void 0 ? _k : '';
28
+
29
+ var _onChange = function onChange(nextValue, key, keys, action) {
30
+ var _a;
31
+
32
+ (_a = opts.onChange) === null || _a === void 0 ? void 0 : _a.call(opts, nextValue, key, keys, action);
33
+ pipeline.setStateAtKey(stateKey, {
34
+ value: nextValue,
35
+ lastKey: key
36
+ }, {
37
+ keys: keys,
38
+ action: action
39
+ });
40
+ };
41
+
42
+ var dataSource = pipeline.getDataSource();
43
+ /** dataSource 中包含的所有 keys */
44
+
45
+ var fullKeySet = new _Set();
46
+ /** 所有有效的 keys(disable 状态为 false) */
47
+
48
+ var allKeys = [];
49
+ dataSource.forEach(function (row, rowIndex) {
50
+ var rowKey = internals.safeGetRowKey(primaryKey, row, rowIndex);
51
+ fullKeySet.add(rowKey); // 在 allKeys 中排除被禁用的 key
52
+
53
+ if (!isDisabled(row, rowIndex)) {
54
+ allKeys.push(rowKey);
55
+ }
56
+ });
57
+ var set = new _Set(value);
58
+ var isAllChecked = allKeys.length > 0 && allKeys.every(function (key) {
59
+ return set.has(key);
60
+ });
61
+ var isAnyChecked = allKeys.some(function (key) {
62
+ return set.has(key);
63
+ });
64
+ var defaultCheckboxColumnTitle = /*#__PURE__*/React.createElement(Checkbox, {
65
+ checked: isAllChecked,
66
+ indeterminate: !isAllChecked && isAnyChecked,
67
+ onChange: function onChange(_) {
68
+ if (isAllChecked) {
69
+ _onChange(arrayUtils.diff(value, allKeys), '', allKeys, 'uncheck-all');
70
+ } else {
71
+ _onChange(arrayUtils.merge(value, allKeys), '', allKeys, 'check-all');
72
+ }
73
+ }
74
+ });
75
+
76
+ var checkboxColumn = _extends(_extends({
77
+ name: '是否选中',
78
+ title: defaultCheckboxColumnTitle,
79
+ width: 50,
80
+ align: 'center'
81
+ }, opts.checkboxColumn), {
82
+ getCellProps: function getCellProps(value, row, rowIndex) {
83
+ var _a, _b;
84
+
85
+ var rowKey = internals.safeGetRowKey(primaryKey, row, rowIndex);
86
+ var checkboxCellProps = {};
87
+ var preCellProps = (_b = (_a = opts.checkboxColumn) === null || _a === void 0 ? void 0 : _a.getCellProps) === null || _b === void 0 ? void 0 : _b.call(_a, value, row, rowIndex);
88
+
89
+ if (fullKeySet.has(rowKey) && clickArea === 'cell') {
90
+ var prevChecked = set.has(rowKey);
91
+ var disabled = isDisabled(row, rowIndex);
92
+ checkboxCellProps = {
93
+ style: {
94
+ cursor: disabled ? 'not-allowed' : 'pointer'
95
+ },
96
+ onClick: disabled ? undefined : function (e) {
97
+ if (opts.stopClickEventPropagation) {
98
+ e.stopPropagation();
99
+ }
100
+
101
+ onCheckboxChange(prevChecked, rowKey, e.shiftKey);
102
+ }
103
+ };
104
+ }
105
+
106
+ return mergeCellProps(preCellProps, checkboxCellProps);
107
+ },
108
+ render: function render(_, row, rowIndex) {
109
+ var key = internals.safeGetRowKey(primaryKey, row, rowIndex);
110
+ var checked = set.has(key);
111
+ return /*#__PURE__*/React.createElement(Checkbox, {
112
+ checked: checked,
113
+ disabled: isDisabled(row, rowIndex),
114
+ onChange: clickArea === 'checkbox' ? function (arg1, arg2) {
115
+ var _a; // 这里要同时兼容 antd 和 fusion 的用法
116
+ // fusion: arg2?.nativeEvent
117
+ // antd: arg1.nativeEvent
118
+
119
+
120
+ var nativeEvent = (_a = arg2 === null || arg2 === void 0 ? void 0 : arg2.nativeEvent) !== null && _a !== void 0 ? _a : arg1.nativeEvent;
121
+
122
+ if (nativeEvent) {
123
+ if (opts.stopClickEventPropagation) {
124
+ nativeEvent.stopPropagation();
125
+ }
126
+
127
+ onCheckboxChange(checked, key, nativeEvent.shiftKey);
128
+ }
129
+ } : undefined
130
+ });
131
+ }
132
+ });
133
+
134
+ var nextColumns = _sliceInstanceProperty(_context = pipeline.getColumns()).call(_context);
135
+
136
+ var checkboxPlacement = (_l = opts.checkboxPlacement) !== null && _l !== void 0 ? _l : 'start';
137
+
138
+ if (checkboxPlacement === 'start') {
139
+ nextColumns.unshift(checkboxColumn);
140
+ } else {
141
+ nextColumns.push(checkboxColumn);
142
+ }
143
+
144
+ pipeline.columns(nextColumns);
145
+ pipeline.appendRowPropsGetter(function (row, rowIndex) {
146
+ var rowKey = internals.safeGetRowKey(primaryKey, row, rowIndex);
147
+
148
+ if (!fullKeySet.has(rowKey)) {
149
+ // rowKey 不在 fullKeySet 中说明这一行是在 multiSelect 之后才生成的,multiSelect 不对之后生成的行进行处理
150
+ return;
151
+ }
152
+
153
+ var style = {};
154
+ var className;
155
+ var onClick;
156
+ var checked = set.has(rowKey);
157
+
158
+ if (opts.highlightRowWhenSelected && checked) {
159
+ className = 'highlight';
160
+ }
161
+
162
+ if (clickArea === 'row') {
163
+ var disabled = isDisabled(row, rowIndex);
164
+
165
+ if (!disabled) {
166
+ style.cursor = 'pointer';
167
+
168
+ onClick = function onClick(e) {
169
+ if (opts.stopClickEventPropagation) {
170
+ e.stopPropagation();
171
+ }
172
+
173
+ onCheckboxChange(checked, rowKey, e.shiftKey);
174
+ };
175
+ }
176
+ }
177
+
178
+ return {
179
+ className: className,
180
+ style: style,
181
+ onClick: onClick
182
+ };
183
+ });
184
+ return pipeline;
185
+
186
+ function onCheckboxChange(prevChecked, key, batch) {
187
+ var batchKeys = [key];
188
+
189
+ if (batch && lastKey) {
190
+ var lastIdx = allKeys.indexOf(lastKey);
191
+ var cntIdx = allKeys.indexOf(key);
192
+
193
+ var _ref = lastIdx < cntIdx ? [lastIdx, cntIdx] : [cntIdx, lastIdx],
194
+ _ref2 = _slicedToArray(_ref, 2),
195
+ start = _ref2[0],
196
+ end = _ref2[1];
197
+
198
+ batchKeys = _sliceInstanceProperty(allKeys).call(allKeys, start, end + 1);
199
+ }
200
+
201
+ if (prevChecked) {
202
+ _onChange(arrayUtils.diff(value, batchKeys), key, batchKeys, 'uncheck');
203
+ } else {
204
+ _onChange(arrayUtils.merge(value, batchKeys), key, batchKeys, 'check');
205
+ }
206
+ }
207
+ };
208
+ }
@@ -0,0 +1,35 @@
1
+ import React, { ReactNode } from 'react';
2
+ import { TablePipeline } from '../pipeline';
3
+ interface expandIconProps extends React.SVGProps<SVGElement> {
4
+ expanded: boolean;
5
+ }
6
+ export interface RowDetailFeatureOptions {
7
+ /** 非受控用法:是否默认展开所有详情单元格 */
8
+ defaultOpenAll?: boolean;
9
+ /** 非受控用法:默认展开的 keys */
10
+ defaultOpenKeys?: string[];
11
+ /** 受控用法:当前展开的 keys */
12
+ openKeys?: string[];
13
+ /** 受控用法:openKeys 改变的回调 */
14
+ onChangeOpenKeys?(nextKeys: string[], key: string, action: 'expand' | 'collapse'): void;
15
+ /** 详情单元格的渲染方法 */
16
+ renderDetail?(row: any, rowIndex: number): ReactNode;
17
+ /** 是否包含详情单元格 */
18
+ hasDetail?(row: any, rowIndex: number): ReactNode;
19
+ /** 获取详情单元格所在行的 key,默认为 `(row) => row[primaryKey] + '_detail'` */
20
+ getDetailKey?(row: any, rowIndex: number): string;
21
+ /** 详情单元格 td 的额外样式 */
22
+ detailCellStyle?: React.CSSProperties;
23
+ /** 点击事件的响应区域 */
24
+ clickArea?: 'cell' | 'content' | 'icon';
25
+ /** 是否对触发展开/收拢的 click 事件调用 event.stopPropagation() */
26
+ stopClickEventPropagation?: boolean;
27
+ /** 指定表格每一行元信息的记录字段 */
28
+ rowDetailMetaKey?: string | symbol;
29
+ /** 指定在哪一列设置展开按钮 */
30
+ expandColumnCode?: string;
31
+ /** 自定义展开图标 */
32
+ expandIcon?: (props: expandIconProps) => JSX.Element;
33
+ }
34
+ export declare function rowDetail(opts?: RowDetailFeatureOptions): (pipeline: TablePipeline) => TablePipeline;
35
+ export {};