@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,397 @@
1
+ "use strict";
2
+
3
+ var _interopRequireWildcard = require("@babel/runtime-corejs3/helpers/interopRequireWildcard");
4
+
5
+ var _interopRequireDefault = require("@babel/runtime-corejs3/helpers/interopRequireDefault");
6
+
7
+ Object.defineProperty(exports, "__esModule", {
8
+ value: true
9
+ });
10
+ exports.contextMenu = contextMenu;
11
+
12
+ var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/classCallCheck"));
13
+
14
+ var _concat = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/concat"));
15
+
16
+ var _map = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/map"));
17
+
18
+ var _react = _interopRequireWildcard(require("react"));
19
+
20
+ var _reactDom = _interopRequireDefault(require("react-dom"));
21
+
22
+ var _commonViews = require("../../common-views");
23
+
24
+ var _utils = require("../../utils");
25
+
26
+ var _others = require("../../utils/others");
27
+
28
+ var _internals = require("../../internals");
29
+
30
+ var _styles = require("../../base/styles");
31
+
32
+ var stateKey = 'contextMenu';
33
+
34
+ function contextMenu() {
35
+ var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
36
+ return function step(pipeline) {
37
+ var popupParent = opts.popupParent || document.body;
38
+ var menuHelper = new MenuHelper();
39
+
40
+ var addPopup = function addPopup(menu) {
41
+ var ePopupDiv = document.createElement('div');
42
+ ePopupDiv.setAttribute('class', 'kd-table-popup');
43
+ popupParent.appendChild(ePopupDiv);
44
+ var popupHidden = false;
45
+ var eventList = ['mousedown', 'contextmenu'];
46
+
47
+ var hidePopup = function hidePopup(event) {
48
+ if (isEventFromCurrentPopup(event, ePopupDiv) || popupHidden) {
49
+ return;
50
+ }
51
+
52
+ popupHidden = true;
53
+ popupParent.removeChild(ePopupDiv);
54
+ eventList.forEach(function (eventType) {
55
+ window.removeEventListener(eventType, hidePopup, true);
56
+ });
57
+ };
58
+
59
+ _reactDom.default.render(menu, ePopupDiv, function () {
60
+ setTimeout(function () {
61
+ eventList.forEach(function (eventType) {
62
+ window.addEventListener(eventType, hidePopup, true);
63
+ });
64
+ }, 0);
65
+ });
66
+
67
+ return hidePopup;
68
+ };
69
+
70
+ var onContextMenu = function onContextMenu(e) {
71
+ e.preventDefault();
72
+ showContextMenu(e);
73
+ };
74
+
75
+ pipeline.addTableProps({
76
+ onContextMenu: onContextMenu
77
+ });
78
+
79
+ var getContextMenuOptions = function getContextMenuOptions(record, column, value) {
80
+ var defaultMenuOptions = [];
81
+
82
+ if (column) {
83
+ defaultMenuOptions.push(getCopyItem(value));
84
+ }
85
+
86
+ if (opts.getContextMenuItems) {
87
+ var params = {
88
+ record: record,
89
+ column: column,
90
+ value: value
91
+ };
92
+ return opts.getContextMenuItems(params);
93
+ }
94
+
95
+ return defaultMenuOptions;
96
+ };
97
+
98
+ var hideContextMenu = function hideContextMenu() {
99
+ menuHelper.destroy();
100
+ };
101
+
102
+ var getPopupParent = function getPopupParent() {
103
+ return popupParent;
104
+ };
105
+
106
+ var showContextMenu = function showContextMenu(e) {
107
+ var dataSource = pipeline.getDataSource();
108
+ var cellEle = getCellEleForEvent(e);
109
+ var code;
110
+ var rowIndex;
111
+
112
+ if (cellEle) {
113
+ code = cellEle.getAttribute('data-code'), rowIndex = cellEle.getAttribute('data-rowindex');
114
+ } else {
115
+ var rowEle = getRowEleForEvent(e, dataSource);
116
+ rowIndex = rowEle === null || rowEle === void 0 ? void 0 : rowEle.getAttribute('data-rowindex');
117
+ }
118
+
119
+ var record = dataSource[rowIndex];
120
+ var column = code !== undefined && (0, _others.findByTree)(pipeline.getColumns(), function (item, index) {
121
+ return item.code === code ? index : -1;
122
+ });
123
+
124
+ var value = column && record && _internals.internals.safeGetValue(column, record, rowIndex);
125
+
126
+ var options = getContextMenuOptions(record, column, value);
127
+
128
+ if (options.length === 0) {
129
+ _utils.console.warn('context menu options is empty');
130
+
131
+ return;
132
+ }
133
+
134
+ var position = positionForMenu(e, popupParent);
135
+
136
+ var menu = /*#__PURE__*/_react.default.createElement(Menu, {
137
+ options: options,
138
+ hideContextMenu: hideContextMenu,
139
+ position: position,
140
+ getPopupParent: getPopupParent
141
+ });
142
+
143
+ var _hidePopup = addPopup(menu);
144
+
145
+ menuHelper.init(_hidePopup);
146
+ };
147
+
148
+ return pipeline;
149
+ };
150
+ }
151
+
152
+ function getMenuItemKey(_ref) {
153
+ var name = _ref.name,
154
+ index = _ref.index;
155
+
156
+ if (name) {
157
+ var _context;
158
+
159
+ var _key = 0;
160
+ name = name + '';
161
+
162
+ for (var i = 0; i < name.length; i++) {
163
+ _key += name.charCodeAt(name[i]);
164
+ }
165
+
166
+ return (0, _concat.default)(_context = "".concat(_key, "_")).call(_context, index);
167
+ }
168
+
169
+ return index;
170
+ }
171
+
172
+ function Menu(props) {
173
+ var _props$options = props.options,
174
+ options = _props$options === void 0 ? [] : _props$options,
175
+ hideContextMenu = props.hideContextMenu,
176
+ position = props.position,
177
+ getPopupParent = props.getPopupParent;
178
+ var menuRef = (0, _react.useRef)();
179
+ (0, _react.useEffect)(function () {
180
+ if (menuRef.current) {
181
+ var popupParent = getPopupParent();
182
+ var x = position.x,
183
+ y = position.y;
184
+
185
+ var _keepWithinBounds = keepWithinBounds(popupParent, menuRef.current, x, y),
186
+ _x = _keepWithinBounds.x,
187
+ _y = _keepWithinBounds.y;
188
+
189
+ menuRef.current.style.left = _x + 'px';
190
+ menuRef.current.style.top = _y + 'px';
191
+ }
192
+ }, [position]);
193
+ return /*#__PURE__*/_react.default.createElement(_commonViews.ContextMenuStyleWrap, {
194
+ className: _styles.MenuClasses.menu,
195
+ ref: menuRef,
196
+ style: {
197
+ left: position.x,
198
+ top: position.y
199
+ }
200
+ }, /*#__PURE__*/_react.default.createElement("div", {
201
+ className: _styles.MenuClasses.menuList
202
+ }, (0, _map.default)(options).call(options, function (item, index) {
203
+ return /*#__PURE__*/_react.default.createElement(MenuItem, {
204
+ key: item.key ? item.key : getMenuItemKey({
205
+ name: item.name,
206
+ index: index
207
+ }),
208
+ name: item.name,
209
+ action: item.action,
210
+ hideContextMenu: hideContextMenu
211
+ });
212
+ })));
213
+ }
214
+
215
+ function MenuItem(props) {
216
+ var name = props.name,
217
+ action = props.action,
218
+ disabled = props.disabled,
219
+ hideContextMenu = props.hideContextMenu;
220
+ var itemRef = (0, _react.useRef)();
221
+
222
+ var handleClick = function handleClick() {
223
+ hideContextMenu();
224
+ typeof action === 'function' && action();
225
+ };
226
+
227
+ var handleMouseEnter = function handleMouseEnter(e) {
228
+ if (disabled) {
229
+ return;
230
+ }
231
+
232
+ var itemDom = itemRef.current;
233
+
234
+ if (itemDom) {
235
+ itemDom.classList.add(_styles.MenuClasses.menuOptionActive);
236
+ }
237
+ };
238
+
239
+ var handleMouseLeave = function handleMouseLeave(e) {
240
+ if (disabled) {
241
+ return;
242
+ }
243
+
244
+ var itemDom = itemRef.current;
245
+
246
+ if (itemDom) {
247
+ setTimeout(function () {
248
+ itemDom.classList.remove(_styles.MenuClasses.menuOptionActive);
249
+ }, 10);
250
+ }
251
+ };
252
+
253
+ return /*#__PURE__*/_react.default.createElement("div", {
254
+ className: _styles.MenuClasses.menuOption,
255
+ ref: itemRef,
256
+ onClick: handleClick,
257
+ onMouseEnter: handleMouseEnter,
258
+ onMouseLeave: handleMouseLeave
259
+ }, /*#__PURE__*/_react.default.createElement("span", {
260
+ className: _styles.MenuClasses.menuOptionText
261
+ }, name));
262
+ }
263
+
264
+ var MenuHelper = function MenuHelper() {
265
+ var _this = this;
266
+
267
+ (0, _classCallCheck2.default)(this, MenuHelper);
268
+
269
+ this.init = function (hidePopup) {
270
+ _this.hidePopup = hidePopup;
271
+ };
272
+
273
+ this.destroy = function () {
274
+ _this.hidePopup && _this.hidePopup();
275
+ _this.hidePopup = null;
276
+ };
277
+ };
278
+ /** 是否点击是外部 start */
279
+
280
+
281
+ function isEventFromCurrentPopup(event, ele) {
282
+ if (!event || !ele) {
283
+ return false;
284
+ }
285
+
286
+ if ((0, _utils.isElementInEventPath)(ele, event)) {
287
+ return true;
288
+ }
289
+
290
+ return false;
291
+ }
292
+
293
+ function getCellEleInEventPath(path) {
294
+ return (0, _utils.getTargetEleInEventPath)(path, function (ele) {
295
+ return ele && ele.getAttribute('data-role') === 'table-cell';
296
+ });
297
+ }
298
+
299
+ function getRowEleInEventPath(path) {
300
+ return (0, _utils.getTargetEleInEventPath)(path, function (ele) {
301
+ return ele && ele.getAttribute('data-role') === 'table-row';
302
+ });
303
+ }
304
+ /** 是否点击是外部 end */
305
+
306
+ /** 计算位置 start */
307
+
308
+
309
+ function calculatePointerRelative(event, popupParent) {
310
+ var parentRect = popupParent.getBoundingClientRect();
311
+ var documentRect = document.documentElement.getBoundingClientRect();
312
+ return {
313
+ x: event.clientX - (popupParent === document.body ? documentRect.left : parentRect.left),
314
+ y: event.clientY - (popupParent === document.body ? documentRect.top : parentRect.top)
315
+ };
316
+ }
317
+
318
+ function positionForMenu(event, popupParent, params) {
319
+ var _calculatePointerRela = calculatePointerRelative(event, popupParent),
320
+ x = _calculatePointerRela.x,
321
+ y = _calculatePointerRela.y;
322
+
323
+ if (params) {
324
+ var offsetX = params.offsetX,
325
+ offsetY = params.offsetY;
326
+
327
+ if (offsetX) {
328
+ x -= offsetX;
329
+ }
330
+
331
+ if (offsetY) {
332
+ y -= offsetY;
333
+ }
334
+ }
335
+
336
+ return {
337
+ x: x,
338
+ y: y
339
+ };
340
+ }
341
+
342
+ function keepWithinBounds(popupParent, ePopup, x, y) {
343
+ var parentRect = popupParent.getBoundingClientRect();
344
+ var docElement = document.documentElement;
345
+ var documentRect = docElement.getBoundingClientRect();
346
+ var ePopupRect = ePopup.getBoundingClientRect();
347
+ var parentWidth = parentRect.width;
348
+ var parentHeight = parentRect.height;
349
+
350
+ if (popupParent === document.body) {
351
+ parentWidth = documentRect.width;
352
+ parentWidth -= Math.abs(documentRect.left - parentRect.left);
353
+ parentHeight = documentRect.height + docElement.scrollTop;
354
+ parentHeight -= Math.abs(documentRect.top - parentRect.top);
355
+ }
356
+
357
+ if (x) {
358
+ var minWidth = Math.min(ePopupRect.width, 120);
359
+ ePopup.style.minWidth = minWidth + 'px';
360
+ var maxX = parentWidth - minWidth;
361
+ x = Math.min(Math.max(x, 0), Math.abs(maxX)); //目前位置,最大支持的位置
362
+ }
363
+
364
+ if (y) {
365
+ var minHeight = Math.min(ePopupRect.height, 180);
366
+ var maxY = parentHeight - minHeight;
367
+ y = Math.min(Math.max(y, 0), Math.abs(maxY)); //目前位置,最大支持的位置
368
+ }
369
+
370
+ return {
371
+ x: x,
372
+ y: y
373
+ };
374
+ }
375
+ /** 计算位置 end */
376
+
377
+ /** 获得点击的元素 start */
378
+
379
+
380
+ function getCellEleForEvent(event) {
381
+ return getCellEleInEventPath((0, _utils.getEventPath)(event));
382
+ }
383
+
384
+ function getRowEleForEvent(event, dataSource) {
385
+ return getRowEleInEventPath((0, _utils.getEventPath)(event));
386
+ }
387
+ /** 获得点击的元素 end */
388
+
389
+
390
+ function getCopyItem(v) {
391
+ return {
392
+ name: '复制',
393
+ action: function action() {
394
+ (0, _utils.executeOnTempElement)((0, _utils.copyDataToClipboard)(v));
395
+ }
396
+ };
397
+ }
@@ -0,0 +1,4 @@
1
+ /// <reference types="react" />
2
+ import { DefaultFilterPanelProps } from '../../../interfaces';
3
+ declare function DefaultFilterContent({ setFilterModel, filterModel, hidePanel }: DefaultFilterPanelProps): JSX.Element;
4
+ export default DefaultFilterContent;
@@ -0,0 +1,112 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime-corejs3/helpers/interopRequireDefault");
4
+
5
+ var _interopRequireWildcard = require("@babel/runtime-corejs3/helpers/interopRequireWildcard");
6
+
7
+ Object.defineProperty(exports, "__esModule", {
8
+ value: true
9
+ });
10
+ exports.default = void 0;
11
+
12
+ var _filter = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/filter"));
13
+
14
+ var _map = _interopRequireDefault(require("@babel/runtime-corejs3/core-js-stable/instance/map"));
15
+
16
+ var _defineProperty2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/defineProperty"));
17
+
18
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/slicedToArray"));
19
+
20
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/taggedTemplateLiteral"));
21
+
22
+ var _react = _interopRequireWildcard(require("react"));
23
+
24
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
25
+
26
+ var _classnames = _interopRequireDefault(require("classnames"));
27
+
28
+ var _util = require("./util");
29
+
30
+ var _styles = require("../../../base/styles");
31
+
32
+ var _templateObject;
33
+
34
+ var DefaultFilterContentStyle = _styledComponents.default.div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2.default)(["\n display: flex;\n flex-direction: column;\n background-color: #ffffff;\n border-radius: 2px;\n width: 100%;\n\n ", "\n .filter-option-list {\n display: flex;\n flex-direction: column;\n margin-top: 8px;\n ul {\n margin: 0;\n padding: 0;\n li {\n display: flex;\n position: relative;\n flex-shrink: 0;\n height: 32px;\n align-items: center;\n border-radius: 2px;\n font-size: 12px;\n color: var(--color);\n padding: 0 12px;\n overflow: hidden;\n cursor: pointer;\n &:hover{\n background-color: var(--primary-color-level1);\n }\n }\n li.active{\n background-color: var(--primary-color-level1);\n }\n }\n }\n\n .filter-search {\n display: flex;\n padding: 6px 12px;\n\n .filter-search-inner {\n width: 100%;\n font-size: 12px;\n color: #333333;\n height: 28px;\n line-height: 28px;\n padding: 0 8px;\n outline: none;\n background-color: #FAFAFA;\n border-radius: 2px;\n border: 1px solid var(--strong-border-color);\n &:hover{\n border-color: var(--primary-color)\n } \n &:focus{\n border-color: var(--primary-color)\n } \n }\n }\n\n .filter-footer {\n display: flex;\n flex-direction: row;\n padding: 8px 12px;\n justify-content: space-between;\n\n .filter-btn {\n text-align: center;\n font-size: 12px;\n width: 60px;\n height: 24px;\n line-height: 24px;\n }\n \n }\n"])), _styles.ButtonCSS);
35
+
36
+ function DefaultFilterContent(_ref) {
37
+ var _cx2;
38
+
39
+ var setFilterModel = _ref.setFilterModel,
40
+ filterModel = _ref.filterModel,
41
+ hidePanel = _ref.hidePanel;
42
+
43
+ var _React$useState = _react.default.useState((filterModel === null || filterModel === void 0 ? void 0 : filterModel.filterCondition) || 'contain'),
44
+ _React$useState2 = (0, _slicedToArray2.default)(_React$useState, 2),
45
+ selectedValue = _React$useState2[0],
46
+ setSelectedValue = _React$useState2[1];
47
+
48
+ var _React$useState3 = _react.default.useState((filterModel === null || filterModel === void 0 ? void 0 : (0, _filter.default)(filterModel)) || ''),
49
+ _React$useState4 = (0, _slicedToArray2.default)(_React$useState3, 2),
50
+ innerValue = _React$useState4[0],
51
+ setInnerValue = _React$useState4[1];
52
+
53
+ var handleClick = _react.default.useCallback(function (option) {
54
+ setSelectedValue(option.key);
55
+ }, []);
56
+
57
+ var reset = function reset() {
58
+ hidePanel();
59
+ setFilterModel();
60
+ };
61
+
62
+ var confirm = function confirm() {
63
+ hidePanel();
64
+ setFilterModel({
65
+ filter: [innerValue],
66
+ filterCondition: selectedValue
67
+ });
68
+ };
69
+
70
+ (0, _react.useEffect)(function () {
71
+ setSelectedValue((filterModel === null || filterModel === void 0 ? void 0 : filterModel.filterCondition) || 'contain');
72
+ setInnerValue((filterModel === null || filterModel === void 0 ? void 0 : (0, _filter.default)(filterModel)) || '');
73
+ }, [filterModel]);
74
+ return /*#__PURE__*/_react.default.createElement(DefaultFilterContentStyle, null, /*#__PURE__*/_react.default.createElement("div", {
75
+ className: 'filter-option-list'
76
+ }, /*#__PURE__*/_react.default.createElement("ul", null, (0, _map.default)(_util.DEFAULT_FILTER_OPTIONS).call(_util.DEFAULT_FILTER_OPTIONS, function (option, index) {
77
+ return (
78
+ /*#__PURE__*/
79
+ // eslint-disable-next-line jsx-a11y/no-noninteractive-element-interactions
80
+ _react.default.createElement("li", {
81
+ key: index,
82
+ className: option.key === selectedValue ? 'active' : '',
83
+ onClick: function onClick() {
84
+ return handleClick(option);
85
+ }
86
+ }, option.title)
87
+ );
88
+ }))), selectedValue !== 'notIsNull' && selectedValue !== 'isNull' && /*#__PURE__*/_react.default.createElement("div", {
89
+ className: 'filter-search'
90
+ }, /*#__PURE__*/_react.default.createElement("input", {
91
+ className: 'filter-search-inner',
92
+ value: innerValue,
93
+ onChange: function onChange(e) {
94
+ setInnerValue(e.target.value);
95
+ }
96
+ })), /*#__PURE__*/_react.default.createElement("div", {
97
+ className: 'filter-footer'
98
+ }, /*#__PURE__*/_react.default.createElement("button", {
99
+ className: (0, _classnames.default)((0, _defineProperty2.default)({
100
+ 'filter-btn': true
101
+ }, _styles.Classes.button, true)),
102
+ onClick: reset
103
+ }, "\u91CD\u7F6E"), /*#__PURE__*/_react.default.createElement("button", {
104
+ className: (0, _classnames.default)((_cx2 = {
105
+ 'filter-btn': true
106
+ }, (0, _defineProperty2.default)(_cx2, _styles.Classes.button, true), (0, _defineProperty2.default)(_cx2, _styles.Classes.buttonPrimary, true), _cx2)),
107
+ onClick: confirm
108
+ }, "\u786E\u5B9A")));
109
+ }
110
+
111
+ var _default = DefaultFilterContent;
112
+ exports.default = _default;
@@ -0,0 +1,17 @@
1
+ import React, { CSSProperties, ReactNode } from 'react';
2
+ import { FilterPanel as FilterPanelType, DefaultFilterPanelProps, CustomeFilterPanelProps } from '../../../interfaces';
3
+ interface FilterProps {
4
+ style?: CSSProperties;
5
+ className?: string;
6
+ size?: number;
7
+ isFilterActive: boolean;
8
+ FilterPanelContent?: FilterPanelType;
9
+ filterIcon?: ReactNode;
10
+ setFilterModel: DefaultFilterPanelProps['setFilterModel'];
11
+ filterModel: DefaultFilterPanelProps['filterModel'];
12
+ setFilter: CustomeFilterPanelProps['setFilter'];
13
+ onClick?: (e: React.MouseEvent) => any;
14
+ stopClickEventPropagation?: boolean;
15
+ }
16
+ declare function Filter({ size, style, className, FilterPanelContent, filterIcon, setFilter, setFilterModel, filterModel, isFilterActive, stopClickEventPropagation }: FilterProps): JSX.Element;
17
+ export default Filter;
@@ -0,0 +1,129 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime-corejs3/helpers/interopRequireDefault");
4
+
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.default = void 0;
9
+
10
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/slicedToArray"));
11
+
12
+ var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime-corejs3/helpers/taggedTemplateLiteral"));
13
+
14
+ var _react = _interopRequireDefault(require("react"));
15
+
16
+ var _reactDom = require("react-dom");
17
+
18
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
19
+
20
+ var _styles = require("../../../base/styles");
21
+
22
+ var _FilterPanel = _interopRequireDefault(require("./FilterPanel"));
23
+
24
+ var _DefaultFilterContent = _interopRequireDefault(require("./DefaultFilterContent"));
25
+
26
+ var _utils = require("../../../utils");
27
+
28
+ var _templateObject;
29
+
30
+ var HEADER_ICON_OFFSET_Y = 6 + 1; //padding-top + border
31
+
32
+ var HEADER_ICON_OFFSET_X = 16 + 1; //padding-left+ border
33
+
34
+ var FilterIconSpanStyle = _styledComponents.default.span(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2.default)(["\n position: absolute;\n right: 4px;\n cursor: pointer;\n transform: translateY(-50%);\n top: 50%;\n height: 12px; \n"])));
35
+
36
+ function Filter(_ref) {
37
+ var _ref$size = _ref.size,
38
+ size = _ref$size === void 0 ? 12 : _ref$size,
39
+ style = _ref.style,
40
+ className = _ref.className,
41
+ FilterPanelContent = _ref.FilterPanelContent,
42
+ filterIcon = _ref.filterIcon,
43
+ setFilter = _ref.setFilter,
44
+ setFilterModel = _ref.setFilterModel,
45
+ filterModel = _ref.filterModel,
46
+ isFilterActive = _ref.isFilterActive,
47
+ stopClickEventPropagation = _ref.stopClickEventPropagation;
48
+
49
+ var _React$useState = _react.default.useState(false),
50
+ _React$useState2 = (0, _slicedToArray2.default)(_React$useState, 2),
51
+ showPanel = _React$useState2[0],
52
+ setShowPanel = _React$useState2[1];
53
+
54
+ var iconRef = _react.default.useRef(null);
55
+
56
+ var hidePanel = function hidePanel() {
57
+ return setShowPanel(false);
58
+ };
59
+
60
+ var handleMouseDown = function handleMouseDown(e) {
61
+ e.stopPropagation(); // 阻止触发拖拽
62
+ };
63
+
64
+ var renderPanelContent = function renderPanelContent() {
65
+ if (FilterPanelContent) {
66
+ return /*#__PURE__*/_react.default.createElement(FilterPanelContent, {
67
+ setFilter: setFilter,
68
+ filterModel: filterModel,
69
+ isFilterActive: isFilterActive,
70
+ hidePanel: hidePanel
71
+ });
72
+ } else {
73
+ return /*#__PURE__*/_react.default.createElement(_DefaultFilterContent.default, {
74
+ setFilterModel: setFilterModel,
75
+ filterModel: filterModel,
76
+ isFilterActive: isFilterActive,
77
+ hidePanel: hidePanel
78
+ });
79
+ }
80
+ };
81
+
82
+ var renderPanel = function renderPanel(ele) {
83
+ var position = (0, _utils.calculatePopupRelative)(ele, document.body, {
84
+ x: HEADER_ICON_OFFSET_X,
85
+ y: HEADER_ICON_OFFSET_Y
86
+ });
87
+ var style = {
88
+ position: 'absolute',
89
+ zIndex: 1050
90
+ };
91
+ return /*#__PURE__*/_react.default.createElement(_FilterPanel.default, {
92
+ style: style,
93
+ onClose: hidePanel,
94
+ position: position,
95
+ filterIcon: filterIcon
96
+ }, renderPanelContent());
97
+ };
98
+
99
+ var handleIconClick = function handleIconClick(e) {
100
+ if (stopClickEventPropagation) {
101
+ e.stopPropagation();
102
+ }
103
+
104
+ setShowPanel(true);
105
+ };
106
+
107
+ return /*#__PURE__*/_react.default.createElement(FilterIconSpanStyle, {
108
+ style: style,
109
+ className: className,
110
+ onMouseDown: handleMouseDown,
111
+ ref: iconRef
112
+ }, /*#__PURE__*/_react.default.createElement("span", {
113
+ className: _styles.Classes.filterIcon,
114
+ onClick: handleIconClick
115
+ }, filterIcon || /*#__PURE__*/_react.default.createElement("svg", {
116
+ width: size,
117
+ height: size,
118
+ viewBox: "64 64 896 896",
119
+ focusable: "false",
120
+ "data-icon": "filter",
121
+ fill: "currentColor",
122
+ "aria-hidden": "true"
123
+ }, /*#__PURE__*/_react.default.createElement("path", {
124
+ 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"
125
+ }))), showPanel && /*#__PURE__*/(0, _reactDom.createPortal)(renderPanel(iconRef.current), document.body));
126
+ }
127
+
128
+ var _default = Filter;
129
+ exports.default = _default;
@@ -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;