@elliemae/ds-data-table 3.19.0 → 3.19.1-rc.1

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 (416) hide show
  1. package/dist/cjs/DataTable.js +2 -4
  2. package/dist/cjs/DataTable.js.map +2 -2
  3. package/dist/cjs/DataTableContext.js +2 -41
  4. package/dist/cjs/DataTableContext.js.map +2 -2
  5. package/dist/cjs/addons/Columns/ColumnAction/ColumnAction.js +3 -1
  6. package/dist/cjs/addons/Columns/ColumnAction/ColumnAction.js.map +2 -2
  7. package/dist/cjs/addons/Columns/ColumnDragHandle/ColumnDragHandle.js +3 -1
  8. package/dist/cjs/addons/Columns/ColumnDragHandle/ColumnDragHandle.js.map +2 -2
  9. package/dist/cjs/addons/Columns/ColumnExpand/ColumnExpand.js +3 -2
  10. package/dist/cjs/addons/Columns/ColumnExpand/ColumnExpand.js.map +2 -2
  11. package/dist/cjs/addons/Columns/ColumnSelectMultiple/ColumnSelectMultiple.js +7 -5
  12. package/dist/cjs/addons/Columns/ColumnSelectMultiple/ColumnSelectMultiple.js.map +3 -3
  13. package/dist/cjs/addons/Columns/ColumnSelectSingle/ColumnSelectSingle.js +5 -3
  14. package/dist/cjs/addons/Columns/ColumnSelectSingle/ColumnSelectSingle.js.map +2 -2
  15. package/dist/cjs/addons/Editables/ComboboxEditableCell/ComboboxEditableCell.js +10 -6
  16. package/dist/cjs/addons/Editables/ComboboxEditableCell/ComboboxEditableCell.js.map +2 -2
  17. package/dist/cjs/addons/Editables/DateEditableCell/DateEditableCell.js +6 -9
  18. package/dist/cjs/addons/Editables/DateEditableCell/DateEditableCell.js.map +2 -2
  19. package/dist/cjs/addons/Editables/TextEditableCell/TextEditableCell.js +2 -3
  20. package/dist/cjs/addons/Editables/TextEditableCell/TextEditableCell.js.map +2 -2
  21. package/dist/cjs/addons/Filters/Components/CurrencyRangeFilter/index.js +8 -7
  22. package/dist/cjs/addons/Filters/Components/CurrencyRangeFilter/index.js.map +2 -2
  23. package/dist/cjs/addons/Filters/Components/DateRangeFilter/index.js.map +2 -2
  24. package/dist/cjs/addons/Filters/Components/DateSwitcherFilter/index.js.map +2 -2
  25. package/dist/cjs/addons/Filters/Components/NumberRangeFilter/index.js +5 -4
  26. package/dist/cjs/addons/Filters/Components/NumberRangeFilter/index.js.map +2 -2
  27. package/dist/cjs/addons/Filters/Components/SelectFilter/BaseSelectFilter.js.map +2 -2
  28. package/dist/cjs/addons/Filters/Components/SelectFilter/MultiCreatableFilter.js.map +2 -2
  29. package/dist/cjs/addons/Filters/Components/SelectFilter/MultiSelectFilter.js.map +2 -2
  30. package/dist/cjs/addons/Filters/Components/SelectFilter/SingleCreatableFilter.js.map +2 -2
  31. package/dist/cjs/addons/Filters/Components/SelectFilter/SingleSelectFilter.js.map +2 -2
  32. package/dist/cjs/addons/Filters/Components/SingleDateFilter/index.js.map +2 -2
  33. package/dist/cjs/addons/Pagination/Pagination.js +2 -3
  34. package/dist/cjs/addons/Pagination/Pagination.js.map +2 -2
  35. package/dist/cjs/configs/constants.js +11 -5
  36. package/dist/cjs/configs/constants.js.map +3 -3
  37. package/dist/cjs/configs/useDatatableConfig.js +20 -20
  38. package/dist/cjs/configs/useDatatableConfig.js.map +2 -2
  39. package/dist/cjs/configs/useInternalStateConfig.js.map +2 -2
  40. package/dist/cjs/configs/usePaginationConfig.js.map +2 -2
  41. package/dist/cjs/configs/useRowFlattenization.js.map +2 -2
  42. package/dist/cjs/configs/useTableColsWithAddons.js.map +2 -2
  43. package/dist/cjs/configs/useTableResizeCb.js +2 -2
  44. package/dist/cjs/configs/useTableResizeCb.js.map +2 -2
  45. package/dist/cjs/exported-related/EditableCell.js.map +2 -2
  46. package/dist/cjs/exported-related/FilterBar/FilterBarDropdownMenu.js +5 -4
  47. package/dist/cjs/exported-related/FilterBar/FilterBarDropdownMenu.js.map +2 -2
  48. package/dist/cjs/exported-related/FilterPopover/index.js +13 -3
  49. package/dist/cjs/exported-related/FilterPopover/index.js.map +2 -2
  50. package/dist/cjs/exported-related/FilterPopover/types.js.map +1 -1
  51. package/dist/cjs/exported-related/FilterPopover/useGetFilterHandlers.js.map +2 -2
  52. package/dist/cjs/exported-related/FilterPopover/useGetFilterVisibility.js.map +2 -2
  53. package/dist/cjs/exported-related/Filters/applyOutOfTheBoxFilters.js.map +2 -2
  54. package/dist/cjs/exported-related/Filters/currencyRangeFilterFn.js +10 -3
  55. package/dist/cjs/exported-related/Filters/currencyRangeFilterFn.js.map +2 -2
  56. package/dist/cjs/exported-related/Filters/multiSelectFilterFn.js +1 -1
  57. package/dist/cjs/exported-related/Filters/multiSelectFilterFn.js.map +2 -2
  58. package/dist/cjs/exported-related/Filters/numberRangeFilterFn.js.map +2 -2
  59. package/dist/cjs/exported-related/Filters/singleSelectFilterFn.js +1 -1
  60. package/dist/cjs/exported-related/Filters/singleSelectFilterFn.js.map +2 -2
  61. package/dist/cjs/exported-related/Filters/types.js.map +1 -1
  62. package/dist/cjs/exported-related/RowRenderer/DefaultRowContentRenderer.js +3 -14
  63. package/dist/cjs/exported-related/RowRenderer/DefaultRowContentRenderer.js.map +2 -2
  64. package/dist/cjs/exported-related/RowRenderer/index.js.map +2 -2
  65. package/dist/cjs/exported-related/RowRenderer/useRowRendererHandlers.js.map +1 -1
  66. package/dist/cjs/exported-related/RowRenderer/useRowRendererProperties.js.map +2 -2
  67. package/dist/cjs/exported-related/RowRenderer/useRowStyle.js.map +1 -1
  68. package/dist/cjs/exported-related/Toolbar/Toolbar.js +2 -2
  69. package/dist/cjs/exported-related/Toolbar/Toolbar.js.map +2 -2
  70. package/dist/cjs/exported-related/groupBy.js.map +2 -2
  71. package/dist/cjs/helpers/addCellData.js.map +2 -2
  72. package/dist/cjs/helpers/cellPadding.js.map +1 -1
  73. package/dist/cjs/helpers/columnsToGrid.js +1 -1
  74. package/dist/cjs/helpers/columnsToGrid.js.map +2 -2
  75. package/dist/cjs/helpers/getIdFromUniqueRowAccessor.js +2 -2
  76. package/dist/cjs/helpers/getIdFromUniqueRowAccessor.js.map +2 -2
  77. package/dist/cjs/helpers/index.js +0 -1
  78. package/dist/cjs/helpers/index.js.map +2 -2
  79. package/dist/cjs/index.js +9 -1
  80. package/dist/cjs/index.js.map +2 -2
  81. package/dist/cjs/parts/Cells/Cell.js +1 -1
  82. package/dist/cjs/parts/Cells/Cell.js.map +2 -2
  83. package/dist/cjs/parts/Cells/index.js.map +2 -2
  84. package/dist/cjs/parts/Cells/useCellStyle.js.map +1 -1
  85. package/dist/cjs/parts/DnDHandle.js +2 -1
  86. package/dist/cjs/parts/DnDHandle.js.map +2 -2
  87. package/dist/cjs/parts/DropIndicator.js +11 -11
  88. package/dist/cjs/parts/DropIndicator.js.map +2 -2
  89. package/dist/cjs/parts/EmptyContent.js +8 -8
  90. package/dist/cjs/parts/EmptyContent.js.map +2 -2
  91. package/dist/cjs/parts/FilterBar/DeprecatedDropdown.js +81 -0
  92. package/dist/cjs/parts/FilterBar/DeprecatedDropdown.js.map +7 -0
  93. package/dist/cjs/parts/FilterBar/FiltersBar.js +9 -31
  94. package/dist/cjs/parts/FilterBar/FiltersBar.js.map +2 -2
  95. package/dist/cjs/parts/FilterBar/components/DateRangePill.js +1 -10
  96. package/dist/cjs/parts/FilterBar/components/DateRangePill.js.map +2 -2
  97. package/dist/cjs/parts/FilterBar/components/DateSwitcherPill.js +1 -10
  98. package/dist/cjs/parts/FilterBar/components/DateSwitcherPill.js.map +2 -2
  99. package/dist/cjs/parts/FilterBar/components/MultiSelectPill.js +3 -2
  100. package/dist/cjs/parts/FilterBar/components/MultiSelectPill.js.map +2 -2
  101. package/dist/cjs/parts/FilterBar/components/NumberRangePill.js.map +2 -2
  102. package/dist/cjs/parts/FilterBar/components/SelectPill.js.map +2 -2
  103. package/dist/cjs/parts/FilterBar/components/SingleDatePill.js.map +2 -2
  104. package/dist/cjs/parts/FilterBar/styled.js +0 -5
  105. package/dist/cjs/parts/FilterBar/styled.js.map +2 -2
  106. package/dist/cjs/parts/Filters/index.js +1 -0
  107. package/dist/cjs/parts/Filters/index.js.map +2 -2
  108. package/dist/cjs/parts/Headers/HeaderCell.js +16 -14
  109. package/dist/cjs/parts/Headers/HeaderCell.js.map +2 -2
  110. package/dist/cjs/parts/Headers/HeaderCellGroup.js.map +2 -2
  111. package/dist/cjs/parts/Headers/HeaderCellTitle.js +11 -2
  112. package/dist/cjs/parts/Headers/HeaderCellTitle.js.map +2 -2
  113. package/dist/cjs/parts/Headers/HeaderResizer.js +20 -71
  114. package/dist/cjs/parts/Headers/HeaderResizer.js.map +2 -2
  115. package/dist/cjs/parts/Headers/index.js +1 -2
  116. package/dist/cjs/parts/Headers/index.js.map +2 -2
  117. package/dist/cjs/parts/Headers/useHeaderCellConfig.js +2 -2
  118. package/dist/cjs/parts/Headers/useHeaderCellConfig.js.map +2 -2
  119. package/dist/cjs/parts/Headers/useHeaderCellHandlers.js +9 -3
  120. package/dist/cjs/parts/Headers/useHeaderCellHandlers.js.map +2 -2
  121. package/dist/cjs/parts/Headers/useHeaderResizer.js +139 -0
  122. package/dist/cjs/parts/Headers/useHeaderResizer.js.map +7 -0
  123. package/dist/cjs/parts/HoC/DnDTreeContext.js.map +1 -1
  124. package/dist/cjs/parts/HoC/SortableItemContext.js.map +1 -1
  125. package/dist/cjs/parts/HoC/withConditionalDnDColumnContext.js +5 -1
  126. package/dist/cjs/parts/HoC/withConditionalDnDColumnContext.js.map +2 -2
  127. package/dist/cjs/parts/HoC/withConditionalDnDRowContext.js +5 -1
  128. package/dist/cjs/parts/HoC/withConditionalDnDRowContext.js.map +2 -2
  129. package/dist/cjs/parts/HoC/withConditionalDnDSortableContext.js +2 -1
  130. package/dist/cjs/parts/HoC/withConditionalDnDSortableContext.js.map +2 -2
  131. package/dist/cjs/parts/HoC/withDnDSortableColumnContext.js +4 -3
  132. package/dist/cjs/parts/HoC/withDnDSortableColumnContext.js.map +2 -2
  133. package/dist/cjs/parts/HoC/withDnDSortableRowContext.js +1 -1
  134. package/dist/cjs/parts/HoC/withDnDSortableRowContext.js.map +2 -2
  135. package/dist/cjs/parts/Row.js.map +2 -2
  136. package/dist/cjs/parts/RowVariants/RowVariantHeader.js +4 -4
  137. package/dist/cjs/parts/RowVariants/RowVariantHeader.js.map +2 -2
  138. package/dist/cjs/parts/RowVariants/RowVariantPrimary.js +14 -21
  139. package/dist/cjs/parts/RowVariants/RowVariantPrimary.js.map +2 -2
  140. package/dist/cjs/parts/RowVariants/RowVariantSecondary.js +15 -22
  141. package/dist/cjs/parts/RowVariants/RowVariantSecondary.js.map +2 -2
  142. package/dist/cjs/parts/RowVariants/RowVariantSkeleton.js.map +2 -2
  143. package/dist/cjs/parts/RowVariants/index.js.map +2 -2
  144. package/dist/cjs/parts/RowVariants/types.js.map +1 -1
  145. package/dist/cjs/parts/Rows.js +4 -4
  146. package/dist/cjs/parts/Rows.js.map +2 -2
  147. package/dist/cjs/parts/SortByCaret.js +1 -1
  148. package/dist/cjs/parts/SortByCaret.js.map +2 -2
  149. package/dist/cjs/parts/SortableHeaderCell.js +17 -7
  150. package/dist/cjs/parts/SortableHeaderCell.js.map +2 -2
  151. package/dist/cjs/parts/VirtualRowsList.js +16 -7
  152. package/dist/cjs/parts/VirtualRowsList.js.map +2 -2
  153. package/dist/cjs/{DataTableSchema.js → react-desc-prop-types.js} +89 -44
  154. package/dist/cjs/react-desc-prop-types.js.map +7 -0
  155. package/dist/cjs/styled.js +54 -22
  156. package/dist/cjs/styled.js.map +2 -2
  157. package/dist/cjs/types/FunctionalHoC.js.map +1 -1
  158. package/dist/esm/DataTable.js +3 -5
  159. package/dist/esm/DataTable.js.map +2 -2
  160. package/dist/esm/DataTableContext.js +2 -41
  161. package/dist/esm/DataTableContext.js.map +2 -2
  162. package/dist/esm/addons/Columns/ColumnAction/ColumnAction.js +3 -1
  163. package/dist/esm/addons/Columns/ColumnAction/ColumnAction.js.map +2 -2
  164. package/dist/esm/addons/Columns/ColumnDragHandle/ColumnDragHandle.js +3 -1
  165. package/dist/esm/addons/Columns/ColumnDragHandle/ColumnDragHandle.js.map +2 -2
  166. package/dist/esm/addons/Columns/ColumnExpand/ColumnExpand.js +3 -2
  167. package/dist/esm/addons/Columns/ColumnExpand/ColumnExpand.js.map +2 -2
  168. package/dist/esm/addons/Columns/ColumnSelectMultiple/ColumnSelectMultiple.js +5 -3
  169. package/dist/esm/addons/Columns/ColumnSelectMultiple/ColumnSelectMultiple.js.map +3 -3
  170. package/dist/esm/addons/Columns/ColumnSelectSingle/ColumnSelectSingle.js +4 -2
  171. package/dist/esm/addons/Columns/ColumnSelectSingle/ColumnSelectSingle.js.map +2 -2
  172. package/dist/esm/addons/Editables/ComboboxEditableCell/ComboboxEditableCell.js +9 -5
  173. package/dist/esm/addons/Editables/ComboboxEditableCell/ComboboxEditableCell.js.map +2 -2
  174. package/dist/esm/addons/Editables/DateEditableCell/DateEditableCell.js +6 -9
  175. package/dist/esm/addons/Editables/DateEditableCell/DateEditableCell.js.map +2 -2
  176. package/dist/esm/addons/Editables/TextEditableCell/TextEditableCell.js +2 -3
  177. package/dist/esm/addons/Editables/TextEditableCell/TextEditableCell.js.map +2 -2
  178. package/dist/esm/addons/Filters/Components/CurrencyRangeFilter/index.js +2 -1
  179. package/dist/esm/addons/Filters/Components/CurrencyRangeFilter/index.js.map +2 -2
  180. package/dist/esm/addons/Filters/Components/DateRangeFilter/index.js.map +2 -2
  181. package/dist/esm/addons/Filters/Components/DateSwitcherFilter/index.js.map +2 -2
  182. package/dist/esm/addons/Filters/Components/NumberRangeFilter/index.js +2 -1
  183. package/dist/esm/addons/Filters/Components/NumberRangeFilter/index.js.map +2 -2
  184. package/dist/esm/addons/Filters/Components/SelectFilter/BaseSelectFilter.js.map +2 -2
  185. package/dist/esm/addons/Filters/Components/SelectFilter/MultiCreatableFilter.js.map +2 -2
  186. package/dist/esm/addons/Filters/Components/SelectFilter/MultiSelectFilter.js.map +2 -2
  187. package/dist/esm/addons/Filters/Components/SelectFilter/SingleCreatableFilter.js.map +2 -2
  188. package/dist/esm/addons/Filters/Components/SelectFilter/SingleSelectFilter.js.map +2 -2
  189. package/dist/esm/addons/Filters/Components/SingleDateFilter/index.js.map +2 -2
  190. package/dist/esm/addons/Pagination/Pagination.js +2 -3
  191. package/dist/esm/addons/Pagination/Pagination.js.map +2 -2
  192. package/dist/esm/configs/constants.js +11 -5
  193. package/dist/esm/configs/constants.js.map +3 -3
  194. package/dist/esm/configs/useDatatableConfig.js +20 -20
  195. package/dist/esm/configs/useDatatableConfig.js.map +2 -2
  196. package/dist/esm/configs/useInternalStateConfig.js.map +2 -2
  197. package/dist/esm/configs/usePaginationConfig.js.map +2 -2
  198. package/dist/esm/configs/useRowFlattenization.js.map +2 -2
  199. package/dist/esm/configs/useTableColsWithAddons.js.map +2 -2
  200. package/dist/esm/configs/useTableResizeCb.js +2 -2
  201. package/dist/esm/configs/useTableResizeCb.js.map +2 -2
  202. package/dist/esm/exported-related/EditableCell.js.map +2 -2
  203. package/dist/esm/exported-related/FilterBar/FilterBarDropdownMenu.js +3 -2
  204. package/dist/esm/exported-related/FilterBar/FilterBarDropdownMenu.js.map +2 -2
  205. package/dist/esm/exported-related/FilterPopover/index.js +13 -3
  206. package/dist/esm/exported-related/FilterPopover/index.js.map +2 -2
  207. package/dist/esm/exported-related/FilterPopover/useGetFilterHandlers.js.map +2 -2
  208. package/dist/esm/exported-related/FilterPopover/useGetFilterVisibility.js.map +2 -2
  209. package/dist/esm/exported-related/Filters/applyOutOfTheBoxFilters.js.map +2 -2
  210. package/dist/esm/exported-related/Filters/currencyRangeFilterFn.js +10 -3
  211. package/dist/esm/exported-related/Filters/currencyRangeFilterFn.js.map +2 -2
  212. package/dist/esm/exported-related/Filters/multiSelectFilterFn.js +1 -1
  213. package/dist/esm/exported-related/Filters/multiSelectFilterFn.js.map +2 -2
  214. package/dist/esm/exported-related/Filters/numberRangeFilterFn.js.map +2 -2
  215. package/dist/esm/exported-related/Filters/singleSelectFilterFn.js +1 -1
  216. package/dist/esm/exported-related/Filters/singleSelectFilterFn.js.map +2 -2
  217. package/dist/esm/exported-related/RowRenderer/DefaultRowContentRenderer.js +3 -14
  218. package/dist/esm/exported-related/RowRenderer/DefaultRowContentRenderer.js.map +2 -2
  219. package/dist/esm/exported-related/RowRenderer/index.js.map +2 -2
  220. package/dist/esm/exported-related/RowRenderer/useRowRendererHandlers.js.map +1 -1
  221. package/dist/esm/exported-related/RowRenderer/useRowRendererProperties.js.map +2 -2
  222. package/dist/esm/exported-related/RowRenderer/useRowStyle.js.map +1 -1
  223. package/dist/esm/exported-related/Toolbar/Toolbar.js +1 -1
  224. package/dist/esm/exported-related/Toolbar/Toolbar.js.map +2 -2
  225. package/dist/esm/exported-related/groupBy.js.map +2 -2
  226. package/dist/esm/helpers/addCellData.js.map +2 -2
  227. package/dist/esm/helpers/cellPadding.js.map +1 -1
  228. package/dist/esm/helpers/columnsToGrid.js +1 -1
  229. package/dist/esm/helpers/columnsToGrid.js.map +2 -2
  230. package/dist/esm/helpers/getIdFromUniqueRowAccessor.js +2 -2
  231. package/dist/esm/helpers/getIdFromUniqueRowAccessor.js.map +2 -2
  232. package/dist/esm/helpers/index.js +0 -1
  233. package/dist/esm/helpers/index.js.map +2 -2
  234. package/dist/esm/index.js +5 -1
  235. package/dist/esm/index.js.map +2 -2
  236. package/dist/esm/parts/Cells/Cell.js +1 -1
  237. package/dist/esm/parts/Cells/Cell.js.map +2 -2
  238. package/dist/esm/parts/Cells/index.js.map +2 -2
  239. package/dist/esm/parts/Cells/useCellStyle.js.map +1 -1
  240. package/dist/esm/parts/DnDHandle.js +2 -1
  241. package/dist/esm/parts/DnDHandle.js.map +2 -2
  242. package/dist/esm/parts/DropIndicator.js +2 -2
  243. package/dist/esm/parts/DropIndicator.js.map +2 -2
  244. package/dist/esm/parts/EmptyContent.js +8 -8
  245. package/dist/esm/parts/EmptyContent.js.map +2 -2
  246. package/dist/esm/parts/FilterBar/DeprecatedDropdown.js +51 -0
  247. package/dist/esm/parts/FilterBar/DeprecatedDropdown.js.map +7 -0
  248. package/dist/esm/parts/FilterBar/FiltersBar.js +10 -32
  249. package/dist/esm/parts/FilterBar/FiltersBar.js.map +2 -2
  250. package/dist/esm/parts/FilterBar/components/DateRangePill.js +1 -10
  251. package/dist/esm/parts/FilterBar/components/DateRangePill.js.map +2 -2
  252. package/dist/esm/parts/FilterBar/components/DateSwitcherPill.js +1 -10
  253. package/dist/esm/parts/FilterBar/components/DateSwitcherPill.js.map +2 -2
  254. package/dist/esm/parts/FilterBar/components/MultiSelectPill.js +3 -2
  255. package/dist/esm/parts/FilterBar/components/MultiSelectPill.js.map +2 -2
  256. package/dist/esm/parts/FilterBar/components/NumberRangePill.js.map +2 -2
  257. package/dist/esm/parts/FilterBar/components/SelectPill.js.map +2 -2
  258. package/dist/esm/parts/FilterBar/components/SingleDatePill.js.map +2 -2
  259. package/dist/esm/parts/FilterBar/styled.js +0 -5
  260. package/dist/esm/parts/FilterBar/styled.js.map +2 -2
  261. package/dist/esm/parts/Filters/index.js +1 -0
  262. package/dist/esm/parts/Filters/index.js.map +2 -2
  263. package/dist/esm/parts/Headers/HeaderCell.js +16 -14
  264. package/dist/esm/parts/Headers/HeaderCell.js.map +2 -2
  265. package/dist/esm/parts/Headers/HeaderCellGroup.js.map +2 -2
  266. package/dist/esm/parts/Headers/HeaderCellTitle.js +11 -2
  267. package/dist/esm/parts/Headers/HeaderCellTitle.js.map +2 -2
  268. package/dist/esm/parts/Headers/HeaderResizer.js +21 -72
  269. package/dist/esm/parts/Headers/HeaderResizer.js.map +2 -2
  270. package/dist/esm/parts/Headers/index.js +1 -2
  271. package/dist/esm/parts/Headers/index.js.map +2 -2
  272. package/dist/esm/parts/Headers/useHeaderCellConfig.js +2 -2
  273. package/dist/esm/parts/Headers/useHeaderCellConfig.js.map +2 -2
  274. package/dist/esm/parts/Headers/useHeaderCellHandlers.js +9 -3
  275. package/dist/esm/parts/Headers/useHeaderCellHandlers.js.map +2 -2
  276. package/dist/esm/parts/Headers/useHeaderResizer.js +109 -0
  277. package/dist/esm/parts/Headers/useHeaderResizer.js.map +7 -0
  278. package/dist/esm/parts/HoC/DnDTreeContext.js.map +1 -1
  279. package/dist/esm/parts/HoC/SortableItemContext.js.map +1 -1
  280. package/dist/esm/parts/HoC/withConditionalDnDColumnContext.js +5 -1
  281. package/dist/esm/parts/HoC/withConditionalDnDColumnContext.js.map +2 -2
  282. package/dist/esm/parts/HoC/withConditionalDnDRowContext.js +5 -1
  283. package/dist/esm/parts/HoC/withConditionalDnDRowContext.js.map +2 -2
  284. package/dist/esm/parts/HoC/withConditionalDnDSortableContext.js +2 -1
  285. package/dist/esm/parts/HoC/withConditionalDnDSortableContext.js.map +2 -2
  286. package/dist/esm/parts/HoC/withDnDSortableColumnContext.js +4 -3
  287. package/dist/esm/parts/HoC/withDnDSortableColumnContext.js.map +2 -2
  288. package/dist/esm/parts/HoC/withDnDSortableRowContext.js +1 -1
  289. package/dist/esm/parts/HoC/withDnDSortableRowContext.js.map +2 -2
  290. package/dist/esm/parts/Row.js.map +2 -2
  291. package/dist/esm/parts/RowVariants/RowVariantHeader.js +4 -4
  292. package/dist/esm/parts/RowVariants/RowVariantHeader.js.map +2 -2
  293. package/dist/esm/parts/RowVariants/RowVariantPrimary.js +14 -21
  294. package/dist/esm/parts/RowVariants/RowVariantPrimary.js.map +2 -2
  295. package/dist/esm/parts/RowVariants/RowVariantSecondary.js +15 -22
  296. package/dist/esm/parts/RowVariants/RowVariantSecondary.js.map +2 -2
  297. package/dist/esm/parts/RowVariants/RowVariantSkeleton.js.map +2 -2
  298. package/dist/esm/parts/RowVariants/index.js.map +2 -2
  299. package/dist/esm/parts/Rows.js +4 -4
  300. package/dist/esm/parts/Rows.js.map +2 -2
  301. package/dist/esm/parts/SortByCaret.js +1 -1
  302. package/dist/esm/parts/SortByCaret.js.map +2 -2
  303. package/dist/esm/parts/SortableHeaderCell.js +17 -7
  304. package/dist/esm/parts/SortableHeaderCell.js.map +2 -2
  305. package/dist/esm/parts/VirtualRowsList.js +16 -7
  306. package/dist/esm/parts/VirtualRowsList.js.map +2 -2
  307. package/dist/esm/{DataTableSchema.js → react-desc-prop-types.js} +86 -41
  308. package/dist/esm/react-desc-prop-types.js.map +7 -0
  309. package/dist/esm/styled.js +54 -22
  310. package/dist/esm/styled.js.map +2 -2
  311. package/dist/types/DataTable.d.ts +3 -86
  312. package/dist/types/DataTableContext.d.ts +2 -3
  313. package/dist/types/addons/Columns/ColumnAction/ColumnAction.d.ts +2 -2
  314. package/dist/types/addons/Columns/ColumnDragHandle/ColumnDragHandle.d.ts +2 -2
  315. package/dist/types/addons/Columns/ColumnExpand/ColumnExpand.d.ts +2 -2
  316. package/dist/types/addons/Columns/ColumnSelectMultiple/ColumnSelectMultiple.d.ts +2 -2
  317. package/dist/types/addons/Columns/ColumnSelectSingle/ColumnSelectSingle.d.ts +2 -2
  318. package/dist/types/addons/Editables/ComboboxEditableCell/ComboboxEditableCell.d.ts +6 -1
  319. package/dist/types/addons/Editables/DateEditableCell/DateEditableCell.d.ts +7 -1
  320. package/dist/types/addons/Editables/TextEditableCell/TextEditableCell.d.ts +6 -1
  321. package/dist/types/addons/Filters/Components/CurrencyRangeFilter/index.d.ts +2 -2
  322. package/dist/types/addons/Filters/Components/DateRangeFilter/index.d.ts +2 -2
  323. package/dist/types/addons/Filters/Components/DateSwitcherFilter/index.d.ts +2 -2
  324. package/dist/types/addons/Filters/Components/NumberRangeFilter/index.d.ts +2 -2
  325. package/dist/types/addons/Filters/Components/SelectFilter/BaseSelectFilter.d.ts +2 -2
  326. package/dist/types/addons/Filters/Components/SelectFilter/MultiCreatableFilter.d.ts +2 -2
  327. package/dist/types/addons/Filters/Components/SelectFilter/MultiSelectFilter.d.ts +2 -2
  328. package/dist/types/addons/Filters/Components/SelectFilter/SingleCreatableFilter.d.ts +2 -2
  329. package/dist/types/addons/Filters/Components/SelectFilter/SingleSelectFilter.d.ts +2 -2
  330. package/dist/types/addons/Filters/Components/SingleDateFilter/index.d.ts +2 -2
  331. package/dist/types/configs/constants.d.ts +10 -4
  332. package/dist/types/configs/useDatatableConfig.d.ts +2 -2
  333. package/dist/types/configs/useInternalStateConfig.d.ts +3 -3
  334. package/dist/types/configs/usePaginationConfig.d.ts +2 -2
  335. package/dist/types/configs/useRowFlattenization.d.ts +2 -2
  336. package/dist/types/configs/useTableColsWithAddons.d.ts +2 -2
  337. package/dist/types/configs/useTableResizeCb.d.ts +2 -2
  338. package/dist/types/exported-related/EditableCell.d.ts +7 -1
  339. package/dist/types/exported-related/FilterBar/FilterBarDropdownMenu.d.ts +2 -1
  340. package/dist/types/exported-related/FilterPopover/types.d.ts +5 -5
  341. package/dist/types/exported-related/FilterPopover/useGetFilterHandlers.d.ts +1 -1
  342. package/dist/types/exported-related/FilterPopover/useGetFilterVisibility.d.ts +2 -2
  343. package/dist/types/exported-related/Filters/applyOutOfTheBoxFilters.d.ts +2 -2
  344. package/dist/types/exported-related/Filters/numberRangeFilterFn.d.ts +2 -2
  345. package/dist/types/exported-related/Filters/types.d.ts +2 -2
  346. package/dist/types/exported-related/RowRenderer/index.d.ts +4 -4
  347. package/dist/types/exported-related/RowRenderer/useRowRendererHandlers.d.ts +3 -3
  348. package/dist/types/exported-related/RowRenderer/useRowRendererProperties.d.ts +4 -5
  349. package/dist/types/exported-related/RowRenderer/useRowStyle.d.ts +3 -3
  350. package/dist/types/exported-related/Toolbar/Toolbar.d.ts +2 -2
  351. package/dist/types/exported-related/groupBy.d.ts +2 -1
  352. package/dist/types/helpers/addCellData.d.ts +2 -2
  353. package/dist/types/helpers/cellPadding.d.ts +3 -3
  354. package/dist/types/helpers/columnsToGrid.d.ts +2 -3
  355. package/dist/types/helpers/getIdFromUniqueRowAccessor.d.ts +2 -2
  356. package/dist/types/helpers/index.d.ts +0 -1
  357. package/dist/types/index.d.ts +2 -1
  358. package/dist/types/parts/Cells/Cell.d.ts +4 -4
  359. package/dist/types/parts/Cells/index.d.ts +2 -2
  360. package/dist/types/parts/Cells/useCellStyle.d.ts +2 -2
  361. package/dist/types/parts/DnDHandle.d.ts +2 -2
  362. package/dist/types/parts/DropIndicator.d.ts +2 -2
  363. package/dist/types/parts/EmptyContent.d.ts +1 -3
  364. package/dist/types/parts/FilterBar/DeprecatedDropdown.d.ts +13 -0
  365. package/dist/types/parts/FilterBar/components/DateRangePill.d.ts +4 -3
  366. package/dist/types/parts/FilterBar/components/DateSwitcherPill.d.ts +4 -3
  367. package/dist/types/parts/FilterBar/components/MultiSelectPill.d.ts +3 -2
  368. package/dist/types/parts/FilterBar/components/NumberRangePill.d.ts +4 -3
  369. package/dist/types/parts/FilterBar/components/SelectPill.d.ts +3 -2
  370. package/dist/types/parts/FilterBar/components/SingleDatePill.d.ts +3 -2
  371. package/dist/types/parts/FilterBar/styled.d.ts +0 -1
  372. package/dist/types/parts/Filters/index.d.ts +2 -2
  373. package/dist/types/parts/Headers/HeaderCell.d.ts +3 -3
  374. package/dist/types/parts/Headers/HeaderCellGroup.d.ts +3 -3
  375. package/dist/types/parts/Headers/HeaderCellTitle.d.ts +5 -5
  376. package/dist/types/parts/Headers/HeaderResizer.d.ts +4 -2
  377. package/dist/types/parts/Headers/index.d.ts +2 -2
  378. package/dist/types/parts/Headers/useHeaderCellConfig.d.ts +3 -3
  379. package/dist/types/parts/Headers/useHeaderCellHandlers.d.ts +3 -2
  380. package/dist/types/parts/Headers/useHeaderResizer.d.ts +10 -0
  381. package/dist/types/parts/HoC/DnDTreeContext.d.ts +3 -3
  382. package/dist/types/parts/HoC/SortableItemContext.d.ts +2 -2
  383. package/dist/types/parts/HoC/withConditionalDnDSortableContext.d.ts +8 -3
  384. package/dist/types/parts/HoC/withDnDSortableColumnContext.d.ts +5 -2
  385. package/dist/types/parts/HoC/withDnDSortableRowContext.d.ts +5 -2
  386. package/dist/types/parts/Row.d.ts +14 -3
  387. package/dist/types/parts/RowVariants/RowVariantHeader.d.ts +2 -2
  388. package/dist/types/parts/RowVariants/RowVariantPrimary.d.ts +4 -2
  389. package/dist/types/parts/RowVariants/RowVariantSecondary.d.ts +4 -2
  390. package/dist/types/parts/RowVariants/RowVariantSkeleton.d.ts +2 -2
  391. package/dist/types/parts/RowVariants/index.d.ts +2 -11
  392. package/dist/types/parts/RowVariants/types.d.ts +6 -5
  393. package/dist/types/parts/Rows.d.ts +2 -2
  394. package/dist/types/parts/SortableHeaderCell.d.ts +2 -3
  395. package/dist/types/react-desc-prop-types.d.ts +310 -0
  396. package/dist/types/styled.d.ts +13 -16
  397. package/dist/types/types/FunctionalHoC.d.ts +1 -1
  398. package/package.json +22 -22
  399. package/dist/cjs/DataTableSchema.js.map +0 -7
  400. package/dist/cjs/helpers/refs-helpers.js +0 -51
  401. package/dist/cjs/helpers/refs-helpers.js.map +0 -7
  402. package/dist/cjs/parts/FilterBar/types.js +0 -28
  403. package/dist/cjs/parts/FilterBar/types.js.map +0 -7
  404. package/dist/cjs/types/props.js +0 -42
  405. package/dist/cjs/types/props.js.map +0 -7
  406. package/dist/esm/DataTableSchema.js.map +0 -7
  407. package/dist/esm/helpers/refs-helpers.js +0 -21
  408. package/dist/esm/helpers/refs-helpers.js.map +0 -7
  409. package/dist/esm/parts/FilterBar/types.js +0 -2
  410. package/dist/esm/parts/FilterBar/types.js.map +0 -7
  411. package/dist/esm/types/props.js +0 -12
  412. package/dist/esm/types/props.js.map +0 -7
  413. package/dist/types/DataTableSchema.d.ts +0 -2
  414. package/dist/types/helpers/refs-helpers.d.ts +0 -1
  415. package/dist/types/parts/FilterBar/types.d.ts +0 -19
  416. package/dist/types/types/props.d.ts +0 -276
@@ -13,7 +13,12 @@ import { useHeaderCellHandlers } from "./useHeaderCellHandlers.js";
13
13
  import { useHeaderCellConfig } from "./useHeaderCellConfig.js";
14
14
  import { DATA_TESTID } from "../../configs/constants.js";
15
15
  import { HeaderCellTitle } from "./HeaderCellTitle.js";
16
- const buildScreenReaderInstructions = (colSpan, draggable, filterable, sortable) => {
16
+ const buildScreenReaderInstructions = ({
17
+ colSpan,
18
+ draggable,
19
+ filterable,
20
+ sortable
21
+ }) => {
17
22
  const preffix = colSpan === 1 ? "" : "Column Group. ";
18
23
  if (!draggable && !filterable && !sortable)
19
24
  return preffix;
@@ -30,12 +35,12 @@ const HeaderCell = (props) => {
30
35
  const ctx = useContext(DataTableContext);
31
36
  const {
32
37
  tableProps: { isResizeable, disabledRows, dragAndDropColumns, onFiltersChange, filters, textWrap },
33
- flattenedData,
34
38
  reduxHeaders
35
39
  } = ctx;
36
40
  const reduxHeader = useMemo(() => reduxHeaders[column.id], [reduxHeaders, column]);
37
41
  const dragHandleRef = useRef(null);
38
42
  const filterIconRef = useRef(null);
43
+ const resizeHandlerRef = useRef(null);
39
44
  const { draggableProps } = useContext(SortableItemContext);
40
45
  const { hasFilter, hasDnD, hasSortingCaret, hasRightIcons, shouldShowDnD, hCols, isDragging } = useHeaderCellConfig(props);
41
46
  const rightIcons = useMemo(() => {
@@ -75,7 +80,8 @@ const HeaderCell = (props) => {
75
80
  column,
76
81
  hasDnD,
77
82
  dragHandleRef,
78
- filterIconRef
83
+ filterIconRef,
84
+ resizeHandlerRef
79
85
  });
80
86
  return /* @__PURE__ */ jsxs(
81
87
  StyledHeadTh,
@@ -83,29 +89,25 @@ const HeaderCell = (props) => {
83
89
  column,
84
90
  ...handlers,
85
91
  role: colSpan === 1 ? "columnheader" : "group",
86
- colSpan,
87
92
  "aria-describedby": `${column.id}-instructions`,
88
93
  "aria-sort": hasSortingCaret ? column.isSortedDesc ? "descending" : "ascending" : "none",
89
94
  "data-testid": DATA_TESTID.DATA_TABLE_HEADER,
90
- isFirstRowGroup: !!flattenedData[0]?.original?.dimsumHeaderValue,
91
95
  tabIndex: column.isFocuseable === false ? -1 : 0,
92
- isDragOverlay,
93
- isDraggingActive: draggableProps && draggableProps.active,
94
- shouldShowDnD,
96
+ isDraggingActive: Boolean(draggableProps && draggableProps.active),
95
97
  ref: column.ref,
96
98
  children: [
97
99
  /* @__PURE__ */ jsxs(Grid, { width: "100%", cols: hCols, children: [
98
100
  shouldShowDnD && DnDHandleComponent,
99
101
  /* @__PURE__ */ jsx(HeaderCellTitle, { column, ctx, draggableProps, textWrap }),
100
102
  rightIcons,
101
- isResizeable && column.canResize !== false && !column.columns && /* @__PURE__ */ jsx(HeaderResizer, { column })
103
+ isResizeable && column.canResize !== false && !column.columns && /* @__PURE__ */ jsx(HeaderResizer, { column, innerRef: resizeHandlerRef, isReachable: reduxHeader?.withTabStops ?? false })
102
104
  ] }),
103
- /* @__PURE__ */ jsx("span", { id: `${column.id}-instructions`, style: { display: "none" }, "aria-hidden": "false", children: buildScreenReaderInstructions(
105
+ /* @__PURE__ */ jsx("span", { id: `${column.id}-instructions`, style: { display: "none" }, "aria-hidden": "false", children: buildScreenReaderInstructions({
104
106
  colSpan,
105
- dragAndDropColumns && column.disableDnD !== true,
106
- hasFilter,
107
- column.canSort || false
108
- ) })
107
+ draggable: dragAndDropColumns && column.disableDnD !== true,
108
+ filterable: hasFilter,
109
+ sortable: column.canSort ?? false
110
+ }) })
109
111
  ]
110
112
  }
111
113
  );
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../../../scripts/build/transpile/react-shim.js", "../../../../src/parts/Headers/HeaderCell.tsx"],
4
- "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "/* eslint-disable max-params */\n/* eslint-disable max-lines */\n/* eslint-disable complexity */\nimport React, { useContext, useMemo, useRef } from 'react';\nimport { Grid } from '@elliemae/ds-grid';\nimport { StyledHeadTh, StyledHeaderRightIconsWrapper, StyledFocusWithin } from '../../styled.js';\nimport { DataTableContext } from '../../DataTableContext.js';\nimport { SortByCaret } from '../SortByCaret.js';\nimport { DragHandle } from '../DnDHandle.js';\nimport { SortableItemContext } from '../HoC/SortableItemContext.js';\nimport { FilterMapItem } from '../Filters/index.js';\nimport { HeaderResizer } from './HeaderResizer.js';\nimport type { InternalTypescriptColumn } from '../../types/props.js';\nimport { useHeaderCellHandlers } from './useHeaderCellHandlers.js';\nimport { useHeaderCellConfig } from './useHeaderCellConfig.js';\nimport { DATA_TESTID } from '../../configs/constants.js';\nimport { HeaderCellTitle } from './HeaderCellTitle.js';\n\nconst buildScreenReaderInstructions = (colSpan: number, draggable: boolean, filterable: boolean, sortable: boolean) => {\n const preffix = colSpan === 1 ? '' : 'Column Group. ';\n if (!draggable && !filterable && !sortable) return preffix;\n\n let message = sortable\n ? 'You can sort the data ascendingly/descendingly by this column. Use the up / down arrows keys to do so'\n : '';\n if (draggable && filterable) {\n message = `This column is draggable and filterable. To enable these interactions press the enter key. ${message}`;\n } else if (draggable || filterable) {\n message = `This column is ${\n draggable ? 'draggable' : 'filterable'\n }. To enable this interaction press the enter key. ${message}`;\n }\n return `${preffix}${message}`;\n};\n\ninterface HeaderCellCompProps {\n column: InternalTypescriptColumn;\n isDragOverlay: boolean;\n colSpan: number;\n}\n\nexport const HeaderCell: React.ComponentType<HeaderCellCompProps> = (props) => {\n const { column, isDragOverlay, colSpan } = props;\n const ctx = useContext(DataTableContext);\n const {\n tableProps: { isResizeable, disabledRows, dragAndDropColumns, onFiltersChange, filters, textWrap },\n flattenedData,\n reduxHeaders,\n } = ctx;\n const reduxHeader = useMemo(() => reduxHeaders[column.id], [reduxHeaders, column]);\n const dragHandleRef = useRef<HTMLDivElement | null>(null);\n const filterIconRef = useRef<HTMLButtonElement | null>(null);\n\n const { draggableProps } = useContext(SortableItemContext);\n\n const { hasFilter, hasDnD, hasSortingCaret, hasRightIcons, shouldShowDnD, hCols, isDragging } =\n useHeaderCellConfig(props);\n\n const rightIcons = useMemo(() => {\n if (!hasRightIcons) return null;\n return (\n <StyledHeaderRightIconsWrapper>\n <FilterMapItem\n column={column}\n ctx={ctx}\n onFiltersChange={onFiltersChange}\n reduxHeader={reduxHeader}\n filters={filters}\n innerRef={filterIconRef}\n />\n {hasSortingCaret && <SortByCaret isSortedDesc={column.isSortedDesc} />}\n </StyledHeaderRightIconsWrapper>\n );\n }, [hasRightIcons, column, ctx, onFiltersChange, reduxHeader, filters, hasSortingCaret]);\n\n const DnDHandleComponent = useMemo(\n () => (\n <Grid mr=\"2px\" alignItems=\"center\" style={{ position: 'relative' }}>\n <StyledFocusWithin hideFocus={isDragging}>\n <DragHandle\n key={column.id}\n innerRef={dragHandleRef}\n isReachable={reduxHeader?.withTabStops ?? false}\n id={column.id}\n isDragOverlay={isDragOverlay}\n isDisabled={disabledRows[column.id]}\n />\n </StyledFocusWithin>\n </Grid>\n ),\n [column.id, disabledRows, isDragOverlay, isDragging, reduxHeader?.withTabStops],\n );\n\n const handlers = useHeaderCellHandlers({\n hasFilter,\n column,\n hasDnD,\n dragHandleRef,\n filterIconRef,\n });\n\n return (\n <StyledHeadTh\n column={column}\n {...handlers}\n role={colSpan === 1 ? 'columnheader' : 'group'}\n colSpan={colSpan}\n aria-describedby={`${column.id}-instructions`}\n // eslint-disable-next-line no-nested-ternary\n aria-sort={hasSortingCaret ? (column.isSortedDesc ? 'descending' : 'ascending') : 'none'}\n data-testid={DATA_TESTID.DATA_TABLE_HEADER}\n isFirstRowGroup={!!flattenedData[0]?.original?.dimsumHeaderValue}\n tabIndex={column.isFocuseable === false ? -1 : 0}\n isDragOverlay={isDragOverlay}\n isDraggingActive={draggableProps && draggableProps.active}\n shouldShowDnD={shouldShowDnD}\n ref={column.ref}\n >\n <Grid width=\"100%\" cols={hCols}>\n {shouldShowDnD && DnDHandleComponent}\n <HeaderCellTitle column={column} ctx={ctx} draggableProps={draggableProps} textWrap={textWrap} />\n {rightIcons}\n {isResizeable && column.canResize !== false && !column.columns && <HeaderResizer column={column} />}\n </Grid>\n <span id={`${column.id}-instructions`} style={{ display: 'none' }} aria-hidden=\"false\">\n {buildScreenReaderInstructions(\n colSpan,\n dragAndDropColumns && column.disableDnD !== true,\n hasFilter,\n column.canSort || false,\n )}\n </span>\n </StyledHeadTh>\n );\n};\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "/* eslint-disable complexity */\nimport React, { useContext, useMemo, useRef } from 'react';\nimport { Grid } from '@elliemae/ds-grid';\nimport { StyledHeadTh, StyledHeaderRightIconsWrapper, StyledFocusWithin } from '../../styled.js';\nimport { DataTableContext } from '../../DataTableContext.js';\nimport { SortByCaret } from '../SortByCaret.js';\nimport { DragHandle } from '../DnDHandle.js';\nimport { SortableItemContext } from '../HoC/SortableItemContext.js';\nimport { FilterMapItem } from '../Filters/index.js';\nimport { HeaderResizer } from './HeaderResizer.js';\nimport type { DSDataTableT } from '../../react-desc-prop-types.js';\nimport { useHeaderCellHandlers } from './useHeaderCellHandlers.js';\nimport { useHeaderCellConfig } from './useHeaderCellConfig.js';\nimport { DATA_TESTID } from '../../configs/constants.js';\nimport { HeaderCellTitle } from './HeaderCellTitle.js';\n\nconst buildScreenReaderInstructions = ({\n colSpan,\n draggable,\n filterable,\n sortable,\n}: {\n colSpan: number;\n draggable: boolean;\n filterable: boolean;\n sortable: boolean;\n}) => {\n const preffix = colSpan === 1 ? '' : 'Column Group. ';\n if (!draggable && !filterable && !sortable) return preffix;\n\n let message = sortable\n ? 'You can sort the data ascendingly/descendingly by this column. Use the up / down arrows keys to do so'\n : '';\n if (draggable && filterable) {\n message = `This column is draggable and filterable. To enable these interactions press the enter key. ${message}`;\n } else if (draggable || filterable) {\n message = `This column is ${\n draggable ? 'draggable' : 'filterable'\n }. To enable this interaction press the enter key. ${message}`;\n }\n return `${preffix}${message}`;\n};\n\ninterface HeaderCellCompProps {\n column: DSDataTableT.InternalColumn;\n isDragOverlay?: boolean;\n colSpan: number;\n}\n\nexport const HeaderCell: React.ComponentType<HeaderCellCompProps> = (props) => {\n const { column, isDragOverlay, colSpan } = props;\n const ctx = useContext(DataTableContext);\n const {\n tableProps: { isResizeable, disabledRows, dragAndDropColumns, onFiltersChange, filters, textWrap },\n reduxHeaders,\n } = ctx;\n const reduxHeader = useMemo(() => reduxHeaders[column.id], [reduxHeaders, column]);\n const dragHandleRef = useRef<HTMLDivElement | null>(null);\n const filterIconRef = useRef<HTMLButtonElement | null>(null);\n const resizeHandlerRef = useRef<HTMLInputElement | null>(null);\n\n const { draggableProps } = useContext(SortableItemContext);\n\n const { hasFilter, hasDnD, hasSortingCaret, hasRightIcons, shouldShowDnD, hCols, isDragging } =\n useHeaderCellConfig(props);\n\n const rightIcons = useMemo(() => {\n if (!hasRightIcons) return null;\n return (\n <StyledHeaderRightIconsWrapper>\n <FilterMapItem\n column={column}\n ctx={ctx}\n onFiltersChange={onFiltersChange}\n reduxHeader={reduxHeader}\n filters={filters}\n innerRef={filterIconRef}\n />\n {hasSortingCaret && <SortByCaret isSortedDesc={column.isSortedDesc} />}\n </StyledHeaderRightIconsWrapper>\n );\n }, [hasRightIcons, column, ctx, onFiltersChange, reduxHeader, filters, hasSortingCaret]);\n\n const DnDHandleComponent = useMemo(\n () => (\n <Grid mr=\"2px\" alignItems=\"center\" style={{ position: 'relative' }}>\n <StyledFocusWithin hideFocus={isDragging}>\n <DragHandle\n key={column.id}\n innerRef={dragHandleRef}\n isReachable={reduxHeader?.withTabStops ?? false}\n id={column.id}\n isDragOverlay={isDragOverlay}\n isDisabled={disabledRows[column.id]}\n />\n </StyledFocusWithin>\n </Grid>\n ),\n [column.id, disabledRows, isDragOverlay, isDragging, reduxHeader?.withTabStops],\n );\n\n const handlers = useHeaderCellHandlers({\n hasFilter,\n column,\n hasDnD,\n dragHandleRef,\n filterIconRef,\n resizeHandlerRef,\n });\n\n return (\n <StyledHeadTh\n column={column}\n {...handlers}\n role={colSpan === 1 ? 'columnheader' : 'group'}\n aria-describedby={`${column.id}-instructions`}\n aria-sort={hasSortingCaret ? (column.isSortedDesc ? 'descending' : 'ascending') : 'none'}\n data-testid={DATA_TESTID.DATA_TABLE_HEADER}\n tabIndex={column.isFocuseable === false ? -1 : 0}\n isDraggingActive={Boolean(draggableProps && draggableProps.active)}\n ref={column.ref}\n >\n <Grid width=\"100%\" cols={hCols}>\n {shouldShowDnD && DnDHandleComponent}\n <HeaderCellTitle column={column} ctx={ctx} draggableProps={draggableProps} textWrap={textWrap} />\n {rightIcons}\n {isResizeable && column.canResize !== false && !column.columns && (\n <HeaderResizer column={column} innerRef={resizeHandlerRef} isReachable={reduxHeader?.withTabStops ?? false} />\n )}\n </Grid>\n <span id={`${column.id}-instructions`} style={{ display: 'none' }} aria-hidden=\"false\">\n {buildScreenReaderInstructions({\n colSpan,\n draggable: dragAndDropColumns && column.disableDnD !== true,\n filterable: hasFilter,\n sortable: column.canSort ?? false,\n })}\n </span>\n </StyledHeadTh>\n );\n};\n"],
5
+ "mappings": "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",
6
6
  "names": []
7
7
  }
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../../../scripts/build/transpile/react-shim.js", "../../../../src/parts/Headers/HeaderCellGroup.tsx"],
4
- "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "/* eslint-disable complexity */\nimport React, { useContext } from 'react';\nimport { Grid } from '@elliemae/ds-grid';\nimport { styled } from '@elliemae/ds-system';\nimport { HeaderCell } from './HeaderCell.js';\nimport { SortableItemContext } from '../HoC/SortableItemContext.js';\nimport { withDnDSortableColumnContext } from '../internal.js';\nimport { DropIndicator } from '../DropIndicator.js';\nimport { SortableHeaderCell } from '../SortableHeaderCell.js';\nimport type { TypescriptColumn } from '../../types/props.js';\nimport { EmptyChildrenGroup } from './EmptyChildrenGroup.js';\nimport { DATA_TESTID } from '../../configs/index.js';\nimport { DataTableContext } from '../../DataTableContext.js';\n\nconst StyledWrapper = styled(Grid)`\n position: relative;\n ${({ shouldDropOneLevel, isDragOverlay }) => (shouldDropOneLevel && !isDragOverlay ? `top: 50%; height: 50%;` : '')}\n width: ${(props) => (props.isDragOverlay ? 'fit-content' : '100%')};\n grid-column: ${(props) => props.gridColumn};\n background: ${(props) => (props.isDragging ? props.theme.colors.neutral['080'] : 'white')};\n opacity: ${(props) => (props.isDragging ? 0.8 : 1)};\n box-shadow: 0 2px 4px 0 ${(props) => (props.isDragOverlay ? 'rgba(0,0,0,0.5)' : 'transparent')};\n border-left: ${({ isFirst }) => (isFirst ? '0px' : '1px')} solid ${(props) => props.theme.colors.neutral['080']};\n`;\n\ninterface HeaderCellGroupCompProps {\n header: TypescriptColumn;\n isDragOverlay?: boolean;\n isDraggingParent?: boolean;\n isLast?: boolean;\n isFirst?: boolean;\n level?: number;\n}\n\nconst HeaderCellGroupComp: React.ComponentType<HeaderCellGroupCompProps> = ({\n header,\n isDragOverlay,\n isDraggingParent,\n isLast,\n isFirst,\n level = 0,\n}) => {\n const { visibleColumns } = useContext(DataTableContext);\n const { draggableProps } = useContext(SortableItemContext);\n\n const isMultiLevel = visibleColumns.some((col) => !!col.columns);\n\n const children = header.columns;\n\n const isDragging = (draggableProps && draggableProps.isDragging) || isDraggingParent;\n const dropIndicatorPosition =\n draggableProps && draggableProps.shouldShowDropIndicatorPosition && draggableProps.dropIndicatorPosition;\n\n const ChildGroup = isDragOverlay ? HeaderCellGroup : HeaderCellGroupSortable;\n\n const colSpan = children?.length ?? 1;\n return (\n <StyledWrapper\n ref={draggableProps ? draggableProps.setNodeRef : null}\n gridColumn={isDragOverlay ? 'auto' : `span ${colSpan}`}\n isDragOverlay={isDragOverlay}\n isDragging={isDragging}\n cols={['auto']}\n data-testid={isDragOverlay ? DATA_TESTID.DATA_TABLE_COLUMN_DRAG_OVERLAY : undefined}\n isFirst={isFirst}\n shouldDropOneLevel={isMultiLevel && level === 0 && !children}\n >\n <HeaderCell column={header} isDragOverlay={isDragOverlay} colSpan={colSpan} />\n {!!children?.length && !isDragOverlay && (\n <SortableHeaderCell isGroup items={children} isDragOverlay={isDragOverlay}>\n {children.map((h, index) => (\n <ChildGroup\n key={h.id}\n header={h}\n isDragOverlay={isDragOverlay}\n isDraggingParent={isDragging}\n isLast={index === children.length - 1}\n isFirst={index === 0}\n level={level + 1}\n />\n ))}\n </SortableHeaderCell>\n )}\n {children?.length && isDragOverlay && <EmptyChildrenGroup />}\n <DropIndicator vertical dropIndicatorPosition={dropIndicatorPosition} isLast={isLast && isDragging} isDropValid />\n </StyledWrapper>\n );\n};\n\n// We need to declare this because we MUST avoid the useSortable call in the recursive calls of the function\n\nexport const HeaderCellGroup = HeaderCellGroupComp;\n\nexport const HeaderCellGroupSortable = withDnDSortableColumnContext(HeaderCellGroupComp);\n"],
5
- "mappings": "AAAA,YAAY,WAAW;ACyDnB,SAUE,KAVF;AAxDJ,SAAgB,kBAAkB;AAClC,SAAS,YAAY;AACrB,SAAS,cAAc;AACvB,SAAS,kBAAkB;AAC3B,SAAS,2BAA2B;AACpC,SAAS,oCAAoC;AAC7C,SAAS,qBAAqB;AAC9B,SAAS,0BAA0B;AAEnC,SAAS,0BAA0B;AACnC,SAAS,mBAAmB;AAC5B,SAAS,wBAAwB;AAEjC,MAAM,gBAAgB,OAAO,IAAI;AAAA;AAAA,IAE7B,CAAC,EAAE,oBAAoB,cAAc,MAAO,sBAAsB,CAAC,gBAAgB,2BAA2B;AAAA,WACvG,CAAC,UAAW,MAAM,gBAAgB,gBAAgB;AAAA,iBAC5C,CAAC,UAAU,MAAM;AAAA,gBAClB,CAAC,UAAW,MAAM,aAAa,MAAM,MAAM,OAAO,QAAQ,KAAK,IAAI;AAAA,aACtE,CAAC,UAAW,MAAM,aAAa,MAAM;AAAA,4BACtB,CAAC,UAAW,MAAM,gBAAgB,oBAAoB;AAAA,iBACjE,CAAC,EAAE,QAAQ,MAAO,UAAU,QAAQ,eAAgB,CAAC,UAAU,MAAM,MAAM,OAAO,QAAQ,KAAK;AAAA;AAYhH,MAAM,sBAAqE,CAAC;AAAA,EAC1E;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,QAAQ;AACV,MAAM;AACJ,QAAM,EAAE,eAAe,IAAI,WAAW,gBAAgB;AACtD,QAAM,EAAE,eAAe,IAAI,WAAW,mBAAmB;AAEzD,QAAM,eAAe,eAAe,KAAK,CAAC,QAAQ,CAAC,CAAC,IAAI,OAAO;AAE/D,QAAM,WAAW,OAAO;AAExB,QAAM,aAAc,kBAAkB,eAAe,cAAe;AACpE,QAAM,wBACJ,kBAAkB,eAAe,mCAAmC,eAAe;AAErF,QAAM,aAAa,gBAAgB,kBAAkB;AAErD,QAAM,UAAU,UAAU,UAAU;AACpC,SACE;AAAA,IAAC;AAAA;AAAA,MACC,KAAK,iBAAiB,eAAe,aAAa;AAAA,MAClD,YAAY,gBAAgB,SAAS,QAAQ;AAAA,MAC7C;AAAA,MACA;AAAA,MACA,MAAM,CAAC,MAAM;AAAA,MACb,eAAa,gBAAgB,YAAY,iCAAiC;AAAA,MAC1E;AAAA,MACA,oBAAoB,gBAAgB,UAAU,KAAK,CAAC;AAAA,MAEpD;AAAA,4BAAC,cAAW,QAAQ,QAAQ,eAA8B,SAAkB;AAAA,QAC3E,CAAC,CAAC,UAAU,UAAU,CAAC,iBACtB,oBAAC,sBAAmB,SAAO,MAAC,OAAO,UAAU,eAC1C,mBAAS,IAAI,CAAC,GAAG,UAChB;AAAA,UAAC;AAAA;AAAA,YAEC,QAAQ;AAAA,YACR;AAAA,YACA,kBAAkB;AAAA,YAClB,QAAQ,UAAU,SAAS,SAAS;AAAA,YACpC,SAAS,UAAU;AAAA,YACnB,OAAO,QAAQ;AAAA;AAAA,UANV,EAAE;AAAA,QAOT,CACD,GACH;AAAA,QAED,UAAU,UAAU,iBAAiB,oBAAC,sBAAmB;AAAA,QAC1D,oBAAC,iBAAc,UAAQ,MAAC,uBAA8C,QAAQ,UAAU,YAAY,aAAW,MAAC;AAAA;AAAA;AAAA,EAClH;AAEJ;AAIO,MAAM,kBAAkB;AAExB,MAAM,0BAA0B,6BAA6B,mBAAmB;",
4
+ "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "/* eslint-disable @typescript-eslint/no-use-before-define */\n/* eslint-disable complexity */\nimport React, { useContext } from 'react';\nimport { Grid } from '@elliemae/ds-grid';\nimport { styled } from '@elliemae/ds-system';\nimport { HeaderCell } from './HeaderCell.js';\nimport { SortableItemContext } from '../HoC/SortableItemContext.js';\nimport { withDnDSortableColumnContext } from '../internal.js';\nimport { DropIndicator } from '../DropIndicator.js';\nimport { SortableHeaderCell } from '../SortableHeaderCell.js';\nimport type { DSDataTableT } from '../../react-desc-prop-types.js';\nimport { EmptyChildrenGroup } from './EmptyChildrenGroup.js';\nimport { DATA_TESTID } from '../../configs/index.js';\nimport { DataTableContext } from '../../DataTableContext.js';\n\nconst StyledWrapper = styled(Grid)<{\n shouldDropOneLevel: boolean;\n isDragOverlay?: boolean;\n isDragging?: boolean;\n isFirst?: boolean;\n gridColumn: string;\n}>`\n position: relative;\n ${({ shouldDropOneLevel, isDragOverlay }) => (shouldDropOneLevel && !isDragOverlay ? `top: 50%; height: 50%;` : '')}\n width: ${(props) => (props.isDragOverlay ? 'fit-content' : '100%')};\n grid-column: ${(props) => props.gridColumn};\n background: ${(props) => (props.isDragging ? props.theme.colors.neutral['080'] : 'white')};\n opacity: ${(props) => (props.isDragging ? 0.8 : 1)};\n box-shadow: 0 2px 4px 0 ${(props) => (props.isDragOverlay ? 'rgba(0,0,0,0.5)' : 'transparent')};\n border-left: ${({ isFirst }) => (isFirst ? '0px' : '1px')} solid ${(props) => props.theme.colors.neutral['080']};\n`;\n\ninterface HeaderCellGroupCompProps {\n header: DSDataTableT.InternalColumn;\n isDragOverlay?: boolean;\n isDraggingParent?: boolean;\n isLast?: boolean;\n isFirst?: boolean;\n level?: number;\n}\n\nconst HeaderCellGroupComp: React.ComponentType<HeaderCellGroupCompProps> = ({\n header,\n isDragOverlay,\n isDraggingParent,\n isLast,\n isFirst,\n level = 0,\n}) => {\n const { visibleColumns } = useContext(DataTableContext);\n const { draggableProps } = useContext(SortableItemContext);\n\n const isMultiLevel = visibleColumns.some((col) => !!col.columns);\n\n const children = header.columns;\n\n const isDragging = (draggableProps && draggableProps.isDragging) || isDraggingParent;\n const dropIndicatorPosition =\n draggableProps && draggableProps.shouldShowDropIndicatorPosition && draggableProps.dropIndicatorPosition;\n\n const ChildGroup = isDragOverlay ? HeaderCellGroup : HeaderCellGroupSortable;\n\n const colSpan = children?.length ?? 1;\n return (\n <StyledWrapper\n ref={draggableProps ? draggableProps.setNodeRef : null}\n gridColumn={isDragOverlay ? 'auto' : `span ${colSpan}`}\n isDragOverlay={isDragOverlay}\n isDragging={isDragging}\n cols={['auto']}\n data-testid={isDragOverlay ? DATA_TESTID.DATA_TABLE_COLUMN_DRAG_OVERLAY : undefined}\n isFirst={isFirst}\n shouldDropOneLevel={isMultiLevel && level === 0 && !children}\n >\n <HeaderCell column={header} isDragOverlay={isDragOverlay} colSpan={colSpan} />\n {!!children?.length && !isDragOverlay && (\n <SortableHeaderCell isGroup items={children} isDragOverlay={isDragOverlay}>\n {children.map((h, index) => (\n <ChildGroup\n key={h.id}\n header={h}\n isDragOverlay={isDragOverlay}\n isDraggingParent={isDragging}\n isLast={index === children.length - 1}\n isFirst={index === 0}\n level={level + 1}\n />\n ))}\n </SortableHeaderCell>\n )}\n {children?.length && isDragOverlay && <EmptyChildrenGroup />}\n <DropIndicator vertical dropIndicatorPosition={dropIndicatorPosition} isLast={isLast && isDragging} isDropValid />\n </StyledWrapper>\n );\n};\n\n// We need to declare this because we MUST avoid the useSortable call in the recursive calls of the function\n\nexport const HeaderCellGroup = HeaderCellGroupComp;\n\nexport const HeaderCellGroupSortable = withDnDSortableColumnContext(HeaderCellGroupComp);\n"],
5
+ "mappings": "AAAA,YAAY,WAAW;ACgEnB,SAUE,KAVF;AA9DJ,SAAgB,kBAAkB;AAClC,SAAS,YAAY;AACrB,SAAS,cAAc;AACvB,SAAS,kBAAkB;AAC3B,SAAS,2BAA2B;AACpC,SAAS,oCAAoC;AAC7C,SAAS,qBAAqB;AAC9B,SAAS,0BAA0B;AAEnC,SAAS,0BAA0B;AACnC,SAAS,mBAAmB;AAC5B,SAAS,wBAAwB;AAEjC,MAAM,gBAAgB,OAAO,IAAI;AAAA;AAAA,IAQ7B,CAAC,EAAE,oBAAoB,cAAc,MAAO,sBAAsB,CAAC,gBAAgB,2BAA2B;AAAA,WACvG,CAAC,UAAW,MAAM,gBAAgB,gBAAgB;AAAA,iBAC5C,CAAC,UAAU,MAAM;AAAA,gBAClB,CAAC,UAAW,MAAM,aAAa,MAAM,MAAM,OAAO,QAAQ,KAAK,IAAI;AAAA,aACtE,CAAC,UAAW,MAAM,aAAa,MAAM;AAAA,4BACtB,CAAC,UAAW,MAAM,gBAAgB,oBAAoB;AAAA,iBACjE,CAAC,EAAE,QAAQ,MAAO,UAAU,QAAQ,eAAgB,CAAC,UAAU,MAAM,MAAM,OAAO,QAAQ,KAAK;AAAA;AAYhH,MAAM,sBAAqE,CAAC;AAAA,EAC1E;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,QAAQ;AACV,MAAM;AACJ,QAAM,EAAE,eAAe,IAAI,WAAW,gBAAgB;AACtD,QAAM,EAAE,eAAe,IAAI,WAAW,mBAAmB;AAEzD,QAAM,eAAe,eAAe,KAAK,CAAC,QAAQ,CAAC,CAAC,IAAI,OAAO;AAE/D,QAAM,WAAW,OAAO;AAExB,QAAM,aAAc,kBAAkB,eAAe,cAAe;AACpE,QAAM,wBACJ,kBAAkB,eAAe,mCAAmC,eAAe;AAErF,QAAM,aAAa,gBAAgB,kBAAkB;AAErD,QAAM,UAAU,UAAU,UAAU;AACpC,SACE;AAAA,IAAC;AAAA;AAAA,MACC,KAAK,iBAAiB,eAAe,aAAa;AAAA,MAClD,YAAY,gBAAgB,SAAS,QAAQ;AAAA,MAC7C;AAAA,MACA;AAAA,MACA,MAAM,CAAC,MAAM;AAAA,MACb,eAAa,gBAAgB,YAAY,iCAAiC;AAAA,MAC1E;AAAA,MACA,oBAAoB,gBAAgB,UAAU,KAAK,CAAC;AAAA,MAEpD;AAAA,4BAAC,cAAW,QAAQ,QAAQ,eAA8B,SAAkB;AAAA,QAC3E,CAAC,CAAC,UAAU,UAAU,CAAC,iBACtB,oBAAC,sBAAmB,SAAO,MAAC,OAAO,UAAU,eAC1C,mBAAS,IAAI,CAAC,GAAG,UAChB;AAAA,UAAC;AAAA;AAAA,YAEC,QAAQ;AAAA,YACR;AAAA,YACA,kBAAkB;AAAA,YAClB,QAAQ,UAAU,SAAS,SAAS;AAAA,YACpC,SAAS,UAAU;AAAA,YACnB,OAAO,QAAQ;AAAA;AAAA,UANV,EAAE;AAAA,QAOT,CACD,GACH;AAAA,QAED,UAAU,UAAU,iBAAiB,oBAAC,sBAAmB;AAAA,QAC1D,oBAAC,iBAAc,UAAQ,MAAC,uBAA8C,QAAQ,UAAU,YAAY,aAAW,MAAC;AAAA;AAAA;AAAA,EAClH;AAEJ;AAIO,MAAM,kBAAkB;AAExB,MAAM,0BAA0B,6BAA6B,mBAAmB;",
6
6
  "names": []
7
7
  }
@@ -3,8 +3,17 @@ import { Fragment, jsx, jsxs } from "react/jsx-runtime";
3
3
  import { SimpleTruncatedTooltipText } from "@elliemae/ds-truncated-tooltip-text";
4
4
  import { RequiredDot } from "./RequiredDot.js";
5
5
  import { DATA_TESTID } from "../../configs/constants.js";
6
- const StringTitle = ({ column, textWrap }) => (column.textWrap || textWrap) === "truncate" ? /* @__PURE__ */ jsx(SimpleTruncatedTooltipText, { value: column.Header }) : /* @__PURE__ */ jsx(Fragment, { children: column.Header });
7
- const HeaderCellTitle = ({ column, ctx, draggableProps, textWrap }) => /* @__PURE__ */ jsxs("div", { style: { display: "flex", alignItems: "center" }, "data-testid": DATA_TESTID.DATA_TABLE_HEADER_CELL_TITLE, children: [
6
+ const StringTitle = ({ column, textWrap }) => (column.textWrap || textWrap) === "truncate" ? (
7
+ // TODO @carusox: remove this cast when we have proper TS for SimpleTruncatedTooltipText
8
+ // TODO or even better, remove this component in favor of the future approved one
9
+ /* @__PURE__ */ jsx(SimpleTruncatedTooltipText, { value: column.Header })
10
+ ) : /* @__PURE__ */ jsx(Fragment, { children: column.Header });
11
+ const HeaderCellTitle = ({
12
+ column,
13
+ ctx,
14
+ draggableProps,
15
+ textWrap
16
+ }) => /* @__PURE__ */ jsxs("div", { style: { display: "flex", alignItems: "center" }, "data-testid": DATA_TESTID.DATA_TABLE_HEADER_CELL_TITLE, children: [
8
17
  typeof column.Header === "string" ? /* @__PURE__ */ jsx(StringTitle, { column, textWrap }) : /* @__PURE__ */ jsx(column.Header, { column, ctx, draggableProps }),
9
18
  column.required && /* @__PURE__ */ jsx(RequiredDot, {})
10
19
  ] });
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../../../scripts/build/transpile/react-shim.js", "../../../../src/parts/Headers/HeaderCellTitle.tsx"],
4
- "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "import React from 'react';\nimport { SimpleTruncatedTooltipText } from '@elliemae/ds-truncated-tooltip-text';\nimport type { TypescriptColumn, TypescriptContext } from '../../types/props.js';\nimport type { SortableItemContextType } from '../HoC/SortableItemContext.js';\nimport { RequiredDot } from './RequiredDot.js';\nimport { DATA_TESTID } from '../../configs/constants.js';\n\ninterface HeaderCellTitle {\n column: TypescriptColumn;\n ctx: TypescriptContext;\n draggableProps: SortableItemContextType['draggableProps'];\n textWrap: 'wrap' | 'wrap-all' | 'truncate';\n}\n\nconst StringTitle = ({ column, textWrap }) =>\n (column.textWrap || textWrap) === 'truncate' ? (\n <SimpleTruncatedTooltipText value={column.Header} />\n ) : (\n <>{column.Header}</>\n );\n\nexport const HeaderCellTitle: React.ComponentType<HeaderCellTitle> = ({ column, ctx, draggableProps, textWrap }) => (\n <div style={{ display: 'flex', alignItems: 'center' }} data-testid={DATA_TESTID.DATA_TABLE_HEADER_CELL_TITLE}>\n {typeof column.Header === 'string' ? (\n <StringTitle column={column} textWrap={textWrap} />\n ) : (\n <column.Header column={column} ctx={ctx} draggableProps={draggableProps} />\n )}\n {column.required && <RequiredDot />}\n </div>\n);\n"],
5
- "mappings": "AAAA,YAAY,WAAW;ACgBnB,SAEA,UAFA,KAMF,YANE;AAfJ,SAAS,kCAAkC;AAG3C,SAAS,mBAAmB;AAC5B,SAAS,mBAAmB;AAS5B,MAAM,cAAc,CAAC,EAAE,QAAQ,SAAS,OACrC,OAAO,YAAY,cAAc,aAChC,oBAAC,8BAA2B,OAAO,OAAO,QAAQ,IAElD,gCAAG,iBAAO,QAAO;AAGd,MAAM,kBAAwD,CAAC,EAAE,QAAQ,KAAK,gBAAgB,SAAS,MAC5G,qBAAC,SAAI,OAAO,EAAE,SAAS,QAAQ,YAAY,SAAS,GAAG,eAAa,YAAY,8BAC7E;AAAA,SAAO,OAAO,WAAW,WACxB,oBAAC,eAAY,QAAgB,UAAoB,IAEjD,oBAAC,OAAO,QAAP,EAAc,QAAgB,KAAU,gBAAgC;AAAA,EAE1E,OAAO,YAAY,oBAAC,eAAY;AAAA,GACnC;",
4
+ "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "import React from 'react';\nimport { SimpleTruncatedTooltipText } from '@elliemae/ds-truncated-tooltip-text';\nimport type { DSDataTableT } from '../../react-desc-prop-types.js';\nimport type { SortableItemContextType } from '../HoC/SortableItemContext.js';\nimport { RequiredDot } from './RequiredDot.js';\nimport { DATA_TESTID } from '../../configs/constants.js';\n\ninterface HeaderCellTitleProps {\n column: DSDataTableT.InternalColumn;\n ctx: DSDataTableT.Context;\n draggableProps: SortableItemContextType['draggableProps'];\n textWrap: 'wrap' | 'wrap-all' | 'truncate';\n}\n\nconst StringTitle = ({ column, textWrap }: Pick<HeaderCellTitleProps, 'column' | 'textWrap'>) =>\n (column.textWrap || textWrap) === 'truncate' ? (\n // TODO @carusox: remove this cast when we have proper TS for SimpleTruncatedTooltipText\n // TODO or even better, remove this component in favor of the future approved one\n <SimpleTruncatedTooltipText value={column.Header as string} />\n ) : (\n <>{column.Header}</>\n );\n\nexport const HeaderCellTitle: React.ComponentType<HeaderCellTitleProps> = ({\n column,\n ctx,\n draggableProps,\n textWrap,\n}) => (\n <div style={{ display: 'flex', alignItems: 'center' }} data-testid={DATA_TESTID.DATA_TABLE_HEADER_CELL_TITLE}>\n {typeof column.Header === 'string' ? (\n <StringTitle column={column} textWrap={textWrap} />\n ) : (\n <column.Header column={column} ctx={ctx} draggableProps={draggableProps} />\n )}\n {column.required && <RequiredDot />}\n </div>\n);\n"],
5
+ "mappings": "AAAA,YAAY,WAAW;ACkBnB,SAEA,UAFA,KAWF,YAXE;AAjBJ,SAAS,kCAAkC;AAG3C,SAAS,mBAAmB;AAC5B,SAAS,mBAAmB;AAS5B,MAAM,cAAc,CAAC,EAAE,QAAQ,SAAS,OACrC,OAAO,YAAY,cAAc;AAAA;AAAA;AAAA,EAGhC,oBAAC,8BAA2B,OAAO,OAAO,QAAkB;AAAA,IAE5D,gCAAG,iBAAO,QAAO;AAGd,MAAM,kBAA6D,CAAC;AAAA,EACzE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,MACE,qBAAC,SAAI,OAAO,EAAE,SAAS,QAAQ,YAAY,SAAS,GAAG,eAAa,YAAY,8BAC7E;AAAA,SAAO,OAAO,WAAW,WACxB,oBAAC,eAAY,QAAgB,UAAoB,IAEjD,oBAAC,OAAO,QAAP,EAAc,QAAgB,KAAU,gBAAgC;AAAA,EAE1E,OAAO,YAAY,oBAAC,eAAY;AAAA,GACnC;",
6
6
  "names": []
7
7
  }
@@ -1,79 +1,26 @@
1
1
  import * as React from "react";
2
2
  import { jsx } from "react/jsx-runtime";
3
- import { useState, useCallback, useContext, useRef, useEffect, useMemo } from "react";
4
- import { ColsLayoutStyle } from "../../configs/constants.js";
5
- import { DataTableContext } from "../../DataTableContext.js";
6
- import { columnsToGrid } from "../../helpers/index.js";
3
+ import { useEffect } from "react";
7
4
  import { StyledResizer } from "../../styled.js";
8
- const narrow = (value, min, max) => Math.min(Math.max(value, min ?? 30), max ?? Infinity);
5
+ import { useHeaderResizer } from "./useHeaderResizer.js";
9
6
  const stopPropagation = (e) => e.stopPropagation();
10
- const HeaderResizer = ({ column }) => {
11
- const {
12
- layoutHelpers: { setGridLayout },
13
- visibleColumns,
14
- tableProps: { onColumnResize, onColumnSizeChange }
15
- } = useContext(DataTableContext);
16
- const [isResizing, setIsResizing] = useState(false);
17
- const [nextWidth, setNextWidth] = useState(column.width ?? 150);
18
- const visibleColumnsCopy = useMemo(
19
- () => visibleColumns.reduce((acc, col) => {
20
- if (col.columns) {
21
- return [...acc, ...col.columns];
22
- }
23
- return [...acc, { ...col }];
24
- }, []),
25
- [visibleColumns]
26
- );
27
- const realColumnIndex = useMemo(
28
- () => visibleColumnsCopy.findIndex((visibleColumn) => visibleColumn.id === column.id),
29
- [column.id, visibleColumnsCopy]
30
- );
31
- useEffect(() => {
32
- if (realColumnIndex > -1) {
33
- visibleColumnsCopy[realColumnIndex].width = nextWidth;
34
- setGridLayout(columnsToGrid(visibleColumnsCopy, ColsLayoutStyle.Fixed));
35
- }
36
- }, [realColumnIndex, column.id, nextWidth, setGridLayout, visibleColumnsCopy]);
37
- const ref = useRef(null);
38
- const onResizeStart = useCallback(() => {
39
- setIsResizing(true);
40
- }, []);
41
- const onResizeHandler = useCallback(
42
- (e) => {
43
- const delta = ("clientX" in e ? e.clientX : e.touches[0].clientX) - (ref.current?.getBoundingClientRect().x ?? 0);
44
- if (realColumnIndex > -1) {
45
- const widthWithDelta = narrow(
46
- nextWidth + delta,
47
- visibleColumnsCopy[realColumnIndex].minWidth,
48
- visibleColumnsCopy[realColumnIndex].maxWidth
49
- );
50
- setNextWidth(widthWithDelta);
51
- }
52
- e.preventDefault();
53
- e.stopPropagation();
54
- },
55
- [realColumnIndex, nextWidth, visibleColumnsCopy]
56
- );
57
- const onResizeEnd = useCallback(() => {
58
- setGridLayout(columnsToGrid(visibleColumns, ColsLayoutStyle.Fixed));
59
- setIsResizing(false);
60
- onColumnResize?.(column.id, nextWidth);
61
- onColumnSizeChange(visibleColumnsCopy, column.id, nextWidth);
62
- }, [setGridLayout, visibleColumns, onColumnResize, column.id, nextWidth, onColumnSizeChange, visibleColumnsCopy]);
7
+ const HeaderResizer = ({ column, innerRef, isReachable }) => {
8
+ const { isResizing, onResizeStart, onResizeEnd, onResizeHandler, handleKeyboardResize } = useHeaderResizer({
9
+ columnId: column.id,
10
+ innerRef
11
+ });
63
12
  useEffect(() => {
64
- const debouncedResizeHandler = onResizeHandler;
65
- const debouncedResizeEnd = onResizeEnd;
66
13
  const addEvents = () => {
67
- document.addEventListener("mousemove", debouncedResizeHandler);
68
- document.addEventListener("touchmove", debouncedResizeHandler);
69
- document.addEventListener("mouseup", debouncedResizeEnd);
70
- document.addEventListener("touchend", debouncedResizeEnd);
14
+ document.addEventListener("mousemove", onResizeHandler);
15
+ document.addEventListener("touchmove", onResizeHandler);
16
+ document.addEventListener("mouseup", onResizeEnd);
17
+ document.addEventListener("touchend", onResizeEnd);
71
18
  };
72
19
  const removeEvents = () => {
73
- document.removeEventListener("mousemove", debouncedResizeHandler);
74
- document.removeEventListener("touchmove", debouncedResizeHandler);
75
- document.removeEventListener("mouseup", debouncedResizeEnd);
76
- document.removeEventListener("touchend", debouncedResizeEnd);
20
+ document.removeEventListener("mousemove", onResizeHandler);
21
+ document.removeEventListener("touchmove", onResizeHandler);
22
+ document.removeEventListener("mouseup", onResizeEnd);
23
+ document.removeEventListener("touchend", onResizeEnd);
77
24
  };
78
25
  if (isResizing)
79
26
  addEvents();
@@ -84,15 +31,17 @@ const HeaderResizer = ({ column }) => {
84
31
  return /* @__PURE__ */ jsx(
85
32
  StyledResizer,
86
33
  {
87
- ref,
88
- role: "separator",
34
+ type: "range",
35
+ "aria-label": "Resize column",
36
+ tabIndex: isReachable ? 0 : -1,
37
+ innerRef,
89
38
  draggable: false,
90
- isResizing,
91
39
  onMouseDown: onResizeStart,
92
40
  onTouchStart: onResizeStart,
93
41
  onMouseUp: onResizeEnd,
94
42
  onTouchEnd: onResizeEnd,
95
- onClick: stopPropagation
43
+ onClick: stopPropagation,
44
+ onKeyDown: handleKeyboardResize
96
45
  }
97
46
  );
98
47
  };
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../../../scripts/build/transpile/react-shim.js", "../../../../src/parts/Headers/HeaderResizer.tsx"],
4
- "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "import React, { useState, useCallback, useContext, useRef, useEffect, useMemo } from 'react';\nimport { ColsLayoutStyle } from '../../configs/constants.js';\nimport { DataTableContext } from '../../DataTableContext.js';\nimport { columnsToGrid } from '../../helpers/index.js';\nimport { StyledResizer } from '../../styled.js';\nimport type { TypescriptColumn } from '../../types/props.js';\n\nconst narrow = (value: number, min: number | undefined, max: number | undefined): number =>\n Math.min(Math.max(value, min ?? 30), max ?? Infinity);\n\nconst stopPropagation = (e: React.MouseEvent) => e.stopPropagation();\n\nexport const HeaderResizer: React.ComponentType<{\n column: TypescriptColumn;\n}> = ({ column }) => {\n const {\n layoutHelpers: { setGridLayout },\n visibleColumns,\n tableProps: { onColumnResize, onColumnSizeChange },\n } = useContext(DataTableContext);\n\n const [isResizing, setIsResizing] = useState(false);\n const [nextWidth, setNextWidth] = useState(column.width ?? 150);\n const visibleColumnsCopy = useMemo(\n () =>\n visibleColumns.reduce((acc, col) => {\n if (col.columns) {\n return [...acc, ...col.columns];\n }\n return [...acc, { ...col }];\n }, [] as TypescriptColumn[]),\n [visibleColumns],\n );\n const realColumnIndex = useMemo(\n () => visibleColumnsCopy.findIndex((visibleColumn) => visibleColumn.id === column.id),\n [column.id, visibleColumnsCopy],\n );\n\n useEffect(() => {\n if (realColumnIndex > -1) {\n visibleColumnsCopy[realColumnIndex].width = nextWidth;\n setGridLayout(columnsToGrid(visibleColumnsCopy, ColsLayoutStyle.Fixed));\n }\n }, [realColumnIndex, column.id, nextWidth, setGridLayout, visibleColumnsCopy]);\n\n const ref = useRef<HTMLDivElement>(null);\n\n const onResizeStart = useCallback(() => {\n setIsResizing(true);\n }, []);\n\n const onResizeHandler = useCallback(\n (e: MouseEvent | TouchEvent) => {\n const delta = ('clientX' in e ? e.clientX : e.touches[0].clientX) - (ref.current?.getBoundingClientRect().x ?? 0); // delta in pixels\n\n if (realColumnIndex > -1) {\n const widthWithDelta = narrow(\n nextWidth + delta,\n visibleColumnsCopy[realColumnIndex].minWidth,\n visibleColumnsCopy[realColumnIndex].maxWidth,\n );\n setNextWidth(widthWithDelta);\n }\n // To prevent text selection\n e.preventDefault();\n e.stopPropagation();\n },\n [realColumnIndex, nextWidth, visibleColumnsCopy],\n );\n\n const onResizeEnd = useCallback(() => {\n setGridLayout(columnsToGrid(visibleColumns, ColsLayoutStyle.Fixed));\n setIsResizing(false);\n onColumnResize?.(column.id, nextWidth);\n onColumnSizeChange(visibleColumnsCopy, column.id, nextWidth);\n }, [setGridLayout, visibleColumns, onColumnResize, column.id, nextWidth, onColumnSizeChange, visibleColumnsCopy]);\n\n useEffect(() => {\n const debouncedResizeHandler = onResizeHandler;\n const debouncedResizeEnd = onResizeEnd;\n const addEvents = () => {\n document.addEventListener('mousemove', debouncedResizeHandler);\n document.addEventListener('touchmove', debouncedResizeHandler);\n document.addEventListener('mouseup', debouncedResizeEnd);\n document.addEventListener('touchend', debouncedResizeEnd);\n };\n const removeEvents = () => {\n document.removeEventListener('mousemove', debouncedResizeHandler);\n document.removeEventListener('touchmove', debouncedResizeHandler);\n document.removeEventListener('mouseup', debouncedResizeEnd);\n document.removeEventListener('touchend', debouncedResizeEnd);\n };\n\n if (isResizing) addEvents();\n else removeEvents();\n\n // just in case the component is unmounted\n return removeEvents;\n }, [isResizing, onResizeHandler, onResizeEnd]);\n\n return (\n <StyledResizer\n ref={ref}\n role=\"separator\"\n draggable={false}\n isResizing={isResizing}\n onMouseDown={onResizeStart}\n onTouchStart={onResizeStart}\n onMouseUp={onResizeEnd}\n onTouchEnd={onResizeEnd}\n onClick={stopPropagation}\n />\n );\n};\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "import React, { useEffect } from 'react';\nimport { StyledResizer } from '../../styled.js';\nimport type { DSDataTableT } from '../../react-desc-prop-types.js';\nimport { useHeaderResizer } from './useHeaderResizer.js';\n\nconst stopPropagation = (e: React.MouseEvent) => e.stopPropagation();\n\nexport const HeaderResizer: React.ComponentType<{\n column: DSDataTableT.InternalColumn;\n innerRef: React.MutableRefObject<HTMLInputElement | null>;\n isReachable: boolean;\n}> = ({ column, innerRef, isReachable }) => {\n const { isResizing, onResizeStart, onResizeEnd, onResizeHandler, handleKeyboardResize } = useHeaderResizer({\n columnId: column.id,\n innerRef,\n });\n\n // This setups the event listeners for the resize (only for mouse)\n // It reacts to the isResizing state change\n useEffect(() => {\n const addEvents = () => {\n document.addEventListener('mousemove', onResizeHandler);\n document.addEventListener('touchmove', onResizeHandler);\n document.addEventListener('mouseup', onResizeEnd);\n document.addEventListener('touchend', onResizeEnd);\n };\n const removeEvents = () => {\n document.removeEventListener('mousemove', onResizeHandler);\n document.removeEventListener('touchmove', onResizeHandler);\n document.removeEventListener('mouseup', onResizeEnd);\n document.removeEventListener('touchend', onResizeEnd);\n };\n\n if (isResizing) addEvents();\n else removeEvents();\n\n // just in case the component is unmounted\n return removeEvents;\n }, [isResizing, onResizeHandler, onResizeEnd]);\n\n return (\n <StyledResizer\n type=\"range\"\n aria-label=\"Resize column\"\n tabIndex={isReachable ? 0 : -1}\n innerRef={innerRef}\n draggable={false}\n onMouseDown={onResizeStart}\n onTouchStart={onResizeStart}\n onMouseUp={onResizeEnd}\n onTouchEnd={onResizeEnd}\n onClick={stopPropagation}\n onKeyDown={handleKeyboardResize}\n />\n );\n};\n"],
5
+ "mappings": "AAAA,YAAY,WAAW;ACyCnB;AAzCJ,SAAgB,iBAAiB;AACjC,SAAS,qBAAqB;AAE9B,SAAS,wBAAwB;AAEjC,MAAM,kBAAkB,CAAC,MAAwB,EAAE,gBAAgB;AAE5D,MAAM,gBAIR,CAAC,EAAE,QAAQ,UAAU,YAAY,MAAM;AAC1C,QAAM,EAAE,YAAY,eAAe,aAAa,iBAAiB,qBAAqB,IAAI,iBAAiB;AAAA,IACzG,UAAU,OAAO;AAAA,IACjB;AAAA,EACF,CAAC;AAID,YAAU,MAAM;AACd,UAAM,YAAY,MAAM;AACtB,eAAS,iBAAiB,aAAa,eAAe;AACtD,eAAS,iBAAiB,aAAa,eAAe;AACtD,eAAS,iBAAiB,WAAW,WAAW;AAChD,eAAS,iBAAiB,YAAY,WAAW;AAAA,IACnD;AACA,UAAM,eAAe,MAAM;AACzB,eAAS,oBAAoB,aAAa,eAAe;AACzD,eAAS,oBAAoB,aAAa,eAAe;AACzD,eAAS,oBAAoB,WAAW,WAAW;AACnD,eAAS,oBAAoB,YAAY,WAAW;AAAA,IACtD;AAEA,QAAI;AAAY,gBAAU;AAAA;AACrB,mBAAa;AAGlB,WAAO;AAAA,EACT,GAAG,CAAC,YAAY,iBAAiB,WAAW,CAAC;AAE7C,SACE;AAAA,IAAC;AAAA;AAAA,MACC,MAAK;AAAA,MACL,cAAW;AAAA,MACX,UAAU,cAAc,IAAI;AAAA,MAC5B;AAAA,MACA,WAAW;AAAA,MACX,aAAa;AAAA,MACb,cAAc;AAAA,MACd,WAAW;AAAA,MACX,YAAY;AAAA,MACZ,SAAS;AAAA,MACT,WAAW;AAAA;AAAA,EACb;AAEJ;",
6
6
  "names": []
7
7
  }
@@ -9,11 +9,10 @@ import { SortableHeaderCell } from "../SortableHeaderCell.js";
9
9
  const HeadersComp = () => {
10
10
  const {
11
11
  tableProps: { isExpandable, colsLayoutStyle },
12
- layoutHelpers: { gridLayout, totalColumnsWidth },
13
12
  visibleColumns,
14
13
  columnHeaderRef
15
14
  } = useContext(DataTableContext);
16
- return /* @__PURE__ */ jsx(StyledHeadWrapper, { totalColumnsWidth, colsLayoutStyle, ref: columnHeaderRef, children: /* @__PURE__ */ jsx(SortableHeaderCell, { items: visibleColumns, children: /* @__PURE__ */ jsx(StyledHeadTr, { role: "row", cols: gridLayout, colsLayoutStyle, isExpandable, children: visibleColumns.map((h, index) => /* @__PURE__ */ jsx(HeaderCellGroupSortable, { header: h, isLast: index === visibleColumns.length - 1 }, h.id)) }) }) });
15
+ return /* @__PURE__ */ jsx(StyledHeadWrapper, { colsLayoutStyle, ref: columnHeaderRef, children: /* @__PURE__ */ jsx(SortableHeaderCell, { items: visibleColumns, children: /* @__PURE__ */ jsx(StyledHeadTr, { role: "row", colsLayoutStyle, isExpandable, children: visibleColumns.map((h, index) => /* @__PURE__ */ jsx(HeaderCellGroupSortable, { header: h, isLast: index === visibleColumns.length - 1 }, h.id)) }) }) });
17
16
  };
18
17
  const Headers = withConditionalDnDColumnContext(HeadersComp);
19
18
  export {
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../../../scripts/build/transpile/react-shim.js", "../../../../src/parts/Headers/index.tsx"],
4
- "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "import React, { useContext } from 'react';\nimport { StyledHeadWrapper, StyledHeadTr } from '../../styled.js';\nimport { DataTableContext } from '../../DataTableContext.js';\nimport { withConditionalDnDColumnContext } from '../HoC/withConditionalDnDColumnContext.js';\nimport { HeaderCellGroupSortable } from './HeaderCellGroup.js';\nimport { SortableHeaderCell } from '../SortableHeaderCell.js';\nimport type { TypescriptColumn } from '../../types/props.js';\n\nconst HeadersComp = (): JSX.Element => {\n const {\n tableProps: { isExpandable, colsLayoutStyle },\n layoutHelpers: { gridLayout, totalColumnsWidth },\n visibleColumns,\n columnHeaderRef,\n } = useContext(DataTableContext);\n\n return (\n <StyledHeadWrapper totalColumnsWidth={totalColumnsWidth} colsLayoutStyle={colsLayoutStyle} ref={columnHeaderRef}>\n <SortableHeaderCell items={visibleColumns}>\n <StyledHeadTr role=\"row\" cols={gridLayout} colsLayoutStyle={colsLayoutStyle} isExpandable={isExpandable}>\n {visibleColumns.map((h: TypescriptColumn, index) => (\n <HeaderCellGroupSortable header={h} key={h.id} isLast={index === visibleColumns.length - 1} />\n ))}\n </StyledHeadTr>\n </SortableHeaderCell>\n </StyledHeadWrapper>\n );\n};\n\nexport const Headers = withConditionalDnDColumnContext(HeadersComp);\n"],
5
- "mappings": "AAAA,YAAY,WAAW;ACqBX;AArBZ,SAAgB,kBAAkB;AAClC,SAAS,mBAAmB,oBAAoB;AAChD,SAAS,wBAAwB;AACjC,SAAS,uCAAuC;AAChD,SAAS,+BAA+B;AACxC,SAAS,0BAA0B;AAGnC,MAAM,cAAc,MAAmB;AACrC,QAAM;AAAA,IACJ,YAAY,EAAE,cAAc,gBAAgB;AAAA,IAC5C,eAAe,EAAE,YAAY,kBAAkB;AAAA,IAC/C;AAAA,IACA;AAAA,EACF,IAAI,WAAW,gBAAgB;AAE/B,SACE,oBAAC,qBAAkB,mBAAsC,iBAAkC,KAAK,iBAC9F,8BAAC,sBAAmB,OAAO,gBACzB,8BAAC,gBAAa,MAAK,OAAM,MAAM,YAAY,iBAAkC,cAC1E,yBAAe,IAAI,CAAC,GAAqB,UACxC,oBAAC,2BAAwB,QAAQ,GAAc,QAAQ,UAAU,eAAe,SAAS,KAAhD,EAAE,EAAiD,CAC7F,GACH,GACF,GACF;AAEJ;AAEO,MAAM,UAAU,gCAAgC,WAAW;",
4
+ "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "import React, { useContext } from 'react';\nimport { StyledHeadWrapper, StyledHeadTr } from '../../styled.js';\nimport { DataTableContext } from '../../DataTableContext.js';\nimport { withConditionalDnDColumnContext } from '../HoC/withConditionalDnDColumnContext.js';\nimport { HeaderCellGroupSortable } from './HeaderCellGroup.js';\nimport { SortableHeaderCell } from '../SortableHeaderCell.js';\n\nconst HeadersComp = (): JSX.Element => {\n const {\n tableProps: { isExpandable, colsLayoutStyle },\n visibleColumns,\n columnHeaderRef,\n } = useContext(DataTableContext);\n\n return (\n <StyledHeadWrapper colsLayoutStyle={colsLayoutStyle} ref={columnHeaderRef}>\n <SortableHeaderCell items={visibleColumns}>\n <StyledHeadTr role=\"row\" colsLayoutStyle={colsLayoutStyle} isExpandable={isExpandable}>\n {visibleColumns.map((h, index) => (\n <HeaderCellGroupSortable header={h} key={h.id} isLast={index === visibleColumns.length - 1} />\n ))}\n </StyledHeadTr>\n </SortableHeaderCell>\n </StyledHeadWrapper>\n );\n};\n\nexport const Headers = withConditionalDnDColumnContext(HeadersComp);\n"],
5
+ "mappings": "AAAA,YAAY,WAAW;ACmBX;AAnBZ,SAAgB,kBAAkB;AAClC,SAAS,mBAAmB,oBAAoB;AAChD,SAAS,wBAAwB;AACjC,SAAS,uCAAuC;AAChD,SAAS,+BAA+B;AACxC,SAAS,0BAA0B;AAEnC,MAAM,cAAc,MAAmB;AACrC,QAAM;AAAA,IACJ,YAAY,EAAE,cAAc,gBAAgB;AAAA,IAC5C;AAAA,IACA;AAAA,EACF,IAAI,WAAW,gBAAgB;AAE/B,SACE,oBAAC,qBAAkB,iBAAkC,KAAK,iBACxD,8BAAC,sBAAmB,OAAO,gBACzB,8BAAC,gBAAa,MAAK,OAAM,iBAAkC,cACxD,yBAAe,IAAI,CAAC,GAAG,UACtB,oBAAC,2BAAwB,QAAQ,GAAc,QAAQ,UAAU,eAAe,SAAS,KAAhD,EAAE,EAAiD,CAC7F,GACH,GACF,GACF;AAEJ;AAEO,MAAM,UAAU,gCAAgC,WAAW;",
6
6
  "names": []
7
7
  }
@@ -2,7 +2,7 @@ import * as React from "react";
2
2
  import { useContext, useMemo } from "react";
3
3
  import { DataTableContext } from "../../DataTableContext.js";
4
4
  import { SortableItemContext } from "../HoC/SortableItemContext.js";
5
- const useHeaderCellConfig = ({ column, isDragOverlay }) => {
5
+ const useHeaderCellConfig = ({ column, isDragOverlay = false }) => {
6
6
  const {
7
7
  tableProps: { dragAndDropColumns },
8
8
  reduxHeaders
@@ -11,7 +11,7 @@ const useHeaderCellConfig = ({ column, isDragOverlay }) => {
11
11
  const reduxHeader = useMemo(() => reduxHeaders[column.id], [reduxHeaders, column]);
12
12
  const hasFilter = !!(column.filter || column.Filter);
13
13
  const hasDnD = dragAndDropColumns && !column.disableDnD;
14
- const hasSortingCaret = column.canSort && typeof column.isSortedDesc === "boolean";
14
+ const hasSortingCaret = Boolean(column.canSort) && typeof column.isSortedDesc === "boolean";
15
15
  const hasRightIcons = !isDragOverlay && (hasSortingCaret || hasFilter);
16
16
  const isDragging = draggableProps && draggableProps.isDragging;
17
17
  const shouldShowDnD = hasDnD && (reduxHeader?.showDnDHandle && draggableProps && !draggableProps.active || draggableProps && draggableProps.isDragging || isDragOverlay);
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../../../scripts/build/transpile/react-shim.js", "../../../../src/parts/Headers/useHeaderCellConfig.tsx"],
4
- "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "/* eslint-disable complexity */\nimport { useContext, useMemo } from 'react';\nimport { DataTableContext } from '../../DataTableContext.js';\nimport { SortableItemContext } from '../HoC/SortableItemContext.js';\nimport type { InternalTypescriptColumn } from '../../types/props.js';\n\ntype UseHeaderCellConfigType = (args: { column: InternalTypescriptColumn; isDragOverlay: boolean }) => {\n hasFilter: boolean;\n hasDnD: boolean;\n hasSortingCaret: boolean;\n hasRightIcons: boolean;\n isDragging: boolean;\n shouldShowDnD: boolean;\n hCols: string[];\n};\n\nexport const useHeaderCellConfig: UseHeaderCellConfigType = ({ column, isDragOverlay }) => {\n const {\n tableProps: { dragAndDropColumns },\n reduxHeaders,\n } = useContext(DataTableContext);\n\n const { draggableProps } = useContext(SortableItemContext);\n\n const reduxHeader = useMemo(() => reduxHeaders[column.id], [reduxHeaders, column]);\n\n const hasFilter = !!(column.filter || column.Filter);\n\n const hasDnD = dragAndDropColumns && !column.disableDnD;\n\n const hasSortingCaret = column.canSort && typeof column.isSortedDesc === 'boolean';\n\n const hasRightIcons = !isDragOverlay && (hasSortingCaret || hasFilter);\n\n const isDragging = draggableProps && draggableProps.isDragging;\n\n const shouldShowDnD =\n hasDnD &&\n ((reduxHeader?.showDnDHandle && draggableProps && !draggableProps.active) ||\n (draggableProps && draggableProps.isDragging) ||\n isDragOverlay);\n\n // Column definition\n const hCols = ['auto'];\n if (hasRightIcons) hCols.push('min-content');\n if (shouldShowDnD) hCols.unshift('min-content');\n\n return {\n hasFilter,\n hasDnD,\n hasSortingCaret,\n hasRightIcons,\n isDragging,\n hCols,\n shouldShowDnD,\n };\n};\n"],
5
- "mappings": "AAAA,YAAY,WAAW;ACCvB,SAAS,YAAY,eAAe;AACpC,SAAS,wBAAwB;AACjC,SAAS,2BAA2B;AAa7B,MAAM,sBAA+C,CAAC,EAAE,QAAQ,cAAc,MAAM;AACzF,QAAM;AAAA,IACJ,YAAY,EAAE,mBAAmB;AAAA,IACjC;AAAA,EACF,IAAI,WAAW,gBAAgB;AAE/B,QAAM,EAAE,eAAe,IAAI,WAAW,mBAAmB;AAEzD,QAAM,cAAc,QAAQ,MAAM,aAAa,OAAO,EAAE,GAAG,CAAC,cAAc,MAAM,CAAC;AAEjF,QAAM,YAAY,CAAC,EAAE,OAAO,UAAU,OAAO;AAE7C,QAAM,SAAS,sBAAsB,CAAC,OAAO;AAE7C,QAAM,kBAAkB,OAAO,WAAW,OAAO,OAAO,iBAAiB;AAEzE,QAAM,gBAAgB,CAAC,kBAAkB,mBAAmB;AAE5D,QAAM,aAAa,kBAAkB,eAAe;AAEpD,QAAM,gBACJ,WACE,aAAa,iBAAiB,kBAAkB,CAAC,eAAe,UAC/D,kBAAkB,eAAe,cAClC;AAGJ,QAAM,QAAQ,CAAC,MAAM;AACrB,MAAI;AAAe,UAAM,KAAK,aAAa;AAC3C,MAAI;AAAe,UAAM,QAAQ,aAAa;AAE9C,SAAO;AAAA,IACL;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF;AACF;",
4
+ "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "/* eslint-disable complexity */\nimport { useContext, useMemo } from 'react';\nimport { DataTableContext } from '../../DataTableContext.js';\nimport { SortableItemContext } from '../HoC/SortableItemContext.js';\nimport type { DSDataTableT } from '../../react-desc-prop-types.js';\n\ntype UseHeaderCellConfigType = (args: { column: DSDataTableT.InternalColumn; isDragOverlay?: boolean }) => {\n hasFilter: boolean;\n hasDnD: boolean;\n hasSortingCaret: boolean;\n hasRightIcons: boolean;\n isDragging: boolean;\n shouldShowDnD: boolean;\n hCols: string[];\n};\n\nexport const useHeaderCellConfig: UseHeaderCellConfigType = ({ column, isDragOverlay = false }) => {\n const {\n tableProps: { dragAndDropColumns },\n reduxHeaders,\n } = useContext(DataTableContext);\n\n const { draggableProps } = useContext(SortableItemContext);\n\n const reduxHeader = useMemo(() => reduxHeaders[column.id], [reduxHeaders, column]);\n\n const hasFilter = !!(column.filter || column.Filter);\n\n const hasDnD = dragAndDropColumns && !column.disableDnD;\n\n const hasSortingCaret = Boolean(column.canSort) && typeof column.isSortedDesc === 'boolean';\n\n const hasRightIcons = !isDragOverlay && (hasSortingCaret || hasFilter);\n\n const isDragging = draggableProps && draggableProps.isDragging;\n\n const shouldShowDnD =\n hasDnD &&\n ((reduxHeader?.showDnDHandle && draggableProps && !draggableProps.active) ||\n (draggableProps && draggableProps.isDragging) ||\n isDragOverlay);\n\n // Column definition\n const hCols = ['auto'];\n if (hasRightIcons) hCols.push('min-content');\n if (shouldShowDnD) hCols.unshift('min-content');\n\n return {\n hasFilter,\n hasDnD,\n hasSortingCaret,\n hasRightIcons,\n isDragging,\n hCols,\n shouldShowDnD,\n };\n};\n"],
5
+ "mappings": "AAAA,YAAY,WAAW;ACCvB,SAAS,YAAY,eAAe;AACpC,SAAS,wBAAwB;AACjC,SAAS,2BAA2B;AAa7B,MAAM,sBAA+C,CAAC,EAAE,QAAQ,gBAAgB,MAAM,MAAM;AACjG,QAAM;AAAA,IACJ,YAAY,EAAE,mBAAmB;AAAA,IACjC;AAAA,EACF,IAAI,WAAW,gBAAgB;AAE/B,QAAM,EAAE,eAAe,IAAI,WAAW,mBAAmB;AAEzD,QAAM,cAAc,QAAQ,MAAM,aAAa,OAAO,EAAE,GAAG,CAAC,cAAc,MAAM,CAAC;AAEjF,QAAM,YAAY,CAAC,EAAE,OAAO,UAAU,OAAO;AAE7C,QAAM,SAAS,sBAAsB,CAAC,OAAO;AAE7C,QAAM,kBAAkB,QAAQ,OAAO,OAAO,KAAK,OAAO,OAAO,iBAAiB;AAElF,QAAM,gBAAgB,CAAC,kBAAkB,mBAAmB;AAE5D,QAAM,aAAa,kBAAkB,eAAe;AAEpD,QAAM,gBACJ,WACE,aAAa,iBAAiB,kBAAkB,CAAC,eAAe,UAC/D,kBAAkB,eAAe,cAClC;AAGJ,QAAM,QAAQ,CAAC,MAAM;AACrB,MAAI;AAAe,UAAM,KAAK,aAAa;AAC3C,MAAI;AAAe,UAAM,QAAQ,aAAa;AAE9C,SAAO;AAAA,IACL;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF;AACF;",
6
6
  "names": []
7
7
  }
@@ -28,7 +28,8 @@ const useHeaderCellHandlers = ({
28
28
  column,
29
29
  hasDnD,
30
30
  dragHandleRef,
31
- filterIconRef
31
+ filterIconRef,
32
+ resizeHandlerRef
32
33
  }) => {
33
34
  const {
34
35
  tableProps: { onColumnSortChange, onColumnSort },
@@ -82,6 +83,8 @@ const useHeaderCellHandlers = ({
82
83
  dragHandleRef.current.focus();
83
84
  else if (filterIconRef.current)
84
85
  filterIconRef.current.focus();
86
+ else if (resizeHandlerRef.current)
87
+ resizeHandlerRef.current.focus();
85
88
  });
86
89
  }
87
90
  },
@@ -96,7 +99,8 @@ const useHeaderCellHandlers = ({
96
99
  hasFilter,
97
100
  hasDnD,
98
101
  dragHandleRef,
99
- filterIconRef
102
+ filterIconRef,
103
+ resizeHandlerRef
100
104
  ]
101
105
  );
102
106
  const onFocus = useCallback(
@@ -113,9 +117,11 @@ const useHeaderCellHandlers = ({
113
117
  return;
114
118
  if (e.relatedTarget === filterIconRef.current)
115
119
  return;
120
+ if (e.relatedTarget === resizeHandlerRef.current)
121
+ return;
116
122
  patchHeader(column.id, buildNextHeader(reduxHeader, false, hasFilter, hasDnD));
117
123
  },
118
- [dragHandleRef, filterIconRef, patchHeader, column.id, reduxHeader, hasFilter, hasDnD]
124
+ [dragHandleRef, filterIconRef, resizeHandlerRef, patchHeader, column.id, reduxHeader, hasFilter, hasDnD]
119
125
  );
120
126
  return { onMouseEnter, onMouseLeave, onClick, onKeyDown, onBlur, onFocus };
121
127
  };
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../../../../scripts/build/transpile/react-shim.js", "../../../../src/parts/Headers/useHeaderCellHandlers.tsx"],
4
- "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "/* eslint-disable max-params */\nimport { useCallback, useContext, useMemo } from 'react';\nimport { DataTableContext } from '../../DataTableContext.js';\nimport type { InternalTypescriptColumn, ReduxHeader } from '../../types/props.js';\n\ntype UseHeaderCellHandlersType = (args: {\n hasFilter: boolean;\n column: InternalTypescriptColumn;\n hasDnD: boolean;\n dragHandleRef: React.MutableRefObject<HTMLDivElement | null>;\n filterIconRef: React.MutableRefObject<HTMLButtonElement | null>;\n}) => {\n onMouseEnter: React.MouseEventHandler;\n onMouseLeave: React.MouseEventHandler;\n onClick: React.MouseEventHandler;\n onKeyDown: React.KeyboardEventHandler;\n onFocus: React.FocusEventHandler;\n onBlur: React.FocusEventHandler;\n};\n\nconst buildNextHeader = (\n reduxHeader: ReduxHeader,\n value: boolean,\n hasFilter: boolean,\n hasDnD: boolean,\n withTabStops = false,\n) => ({\n hideFilterMenu: true, // Do this to overwrite it if it exists\n ...reduxHeader,\n hideFilterButton: !(hasFilter && value),\n showDnDHandle: hasDnD && value,\n withTabStops,\n});\n\nconst getNextSortedVisibleColumns = (\n visibleColumns: InternalTypescriptColumn<HTMLElement>[],\n columnId: string,\n isSortedDesc: boolean,\n) => {\n const doit = (columns: InternalTypescriptColumn<HTMLElement>[]) =>\n columns.map((col) => {\n const newCol = { ...col };\n delete newCol.isSortedDesc;\n if (col.id === columnId) {\n newCol.isSortedDesc = isSortedDesc;\n }\n if (newCol.columns) {\n newCol.columns = doit(newCol.columns);\n }\n return newCol;\n });\n return doit(visibleColumns);\n};\n\nexport const useHeaderCellHandlers: UseHeaderCellHandlersType = ({\n hasFilter,\n column,\n hasDnD,\n dragHandleRef,\n filterIconRef,\n}) => {\n const {\n tableProps: { onColumnSortChange, onColumnSort },\n patchHeader,\n reduxHeaders,\n visibleColumns,\n } = useContext(DataTableContext);\n\n const reduxHeader = useMemo(() => reduxHeaders[column.id], [reduxHeaders, column]);\n\n const headerRef = column.ref;\n\n const onMouseEnter: React.MouseEventHandler = useCallback(() => {\n patchHeader(column.id, buildNextHeader(reduxHeader, true, hasFilter, hasDnD));\n }, [column.id, hasDnD, hasFilter, patchHeader, reduxHeader]);\n\n const onMouseLeave: React.MouseEventHandler = useCallback(() => {\n if (!headerRef?.current?.contains(document.activeElement)) {\n patchHeader(column.id, buildNextHeader(reduxHeader, false, hasFilter, hasDnD));\n }\n }, [column.id, hasDnD, hasFilter, headerRef, patchHeader, reduxHeader]);\n\n const onClick: React.MouseEventHandler = useCallback(() => {\n if (column.canSort) {\n onColumnSortChange?.({\n column: column.id,\n direction: column.isSortedDesc ? 'ASC' : 'DESC',\n });\n onColumnSort(\n getNextSortedVisibleColumns(visibleColumns, column.id, !column.isSortedDesc),\n column.id,\n column.isSortedDesc ? 'ASC' : 'DESC',\n );\n }\n }, [column.canSort, column.id, column.isSortedDesc, onColumnSort, onColumnSortChange, visibleColumns]);\n\n const onKeyDown: React.KeyboardEventHandler = useCallback(\n (e) => {\n if (e.code === 'ArrowDown' && column.canSort) {\n e.preventDefault();\n onColumnSortChange?.({\n column: column.id,\n direction: 'DESC',\n });\n onColumnSort(getNextSortedVisibleColumns(visibleColumns, column.id, true), column.id, 'DESC');\n } else if (e.code === 'ArrowUp' && column.canSort) {\n e.preventDefault();\n onColumnSortChange?.({\n column: column.id,\n direction: 'ASC',\n });\n onColumnSort(getNextSortedVisibleColumns(visibleColumns, column.id, false), column.id, 'ASC');\n } else if (['Enter', 'Space'].includes(e.code)) {\n patchHeader(column.id, buildNextHeader(reduxHeader, true, hasFilter, hasDnD, true));\n // Elements don't not yet exist\n setTimeout(() => {\n if (dragHandleRef.current) dragHandleRef.current.focus();\n else if (filterIconRef.current) filterIconRef.current.focus();\n });\n }\n },\n [\n column.canSort,\n column.id,\n onColumnSortChange,\n onColumnSort,\n visibleColumns,\n patchHeader,\n reduxHeader,\n hasFilter,\n hasDnD,\n dragHandleRef,\n filterIconRef,\n ],\n );\n\n const onFocus: React.FocusEventHandler = useCallback(\n (e) => {\n // Don't do anything if focus wasn't placed in the element (bubling issues)\n if (e.target === headerRef?.current) {\n patchHeader(column.id, buildNextHeader(reduxHeader, true, hasFilter, hasDnD));\n }\n },\n [column.id, hasDnD, hasFilter, headerRef, patchHeader, reduxHeader],\n );\n\n const onBlur: React.FocusEventHandler = useCallback(\n (e) => {\n // Don't do anything if blur was caused by going to a child\n if (e.relatedTarget === dragHandleRef.current) return;\n if (e.relatedTarget === filterIconRef.current) return;\n patchHeader(column.id, buildNextHeader(reduxHeader, false, hasFilter, hasDnD));\n },\n [dragHandleRef, filterIconRef, patchHeader, column.id, reduxHeader, hasFilter, hasDnD],\n );\n\n return { onMouseEnter, onMouseLeave, onClick, onKeyDown, onBlur, onFocus };\n};\n"],
5
- "mappings": "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",
4
+ "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "/* eslint-disable max-params */\nimport { useCallback, useContext, useMemo } from 'react';\nimport { DataTableContext } from '../../DataTableContext.js';\nimport type { DSDataTableT } from '../../react-desc-prop-types.js';\n\ntype UseHeaderCellHandlersType = (args: {\n hasFilter: boolean;\n column: DSDataTableT.InternalColumn;\n hasDnD: boolean;\n dragHandleRef: React.MutableRefObject<HTMLDivElement | null>;\n filterIconRef: React.MutableRefObject<HTMLButtonElement | null>;\n resizeHandlerRef: React.MutableRefObject<HTMLInputElement | null>;\n}) => {\n onMouseEnter: React.MouseEventHandler;\n onMouseLeave: React.MouseEventHandler;\n onClick: React.MouseEventHandler;\n onKeyDown: React.KeyboardEventHandler;\n onFocus: React.FocusEventHandler;\n onBlur: React.FocusEventHandler;\n};\n\nconst buildNextHeader = (\n reduxHeader: DSDataTableT.ReduxHeader,\n value: boolean,\n hasFilter: boolean,\n hasDnD: boolean,\n withTabStops = false,\n) => ({\n hideFilterMenu: true, // Do this to overwrite it if it exists\n ...reduxHeader,\n hideFilterButton: !(hasFilter && value),\n showDnDHandle: hasDnD && value,\n withTabStops,\n});\n\nconst getNextSortedVisibleColumns = (\n visibleColumns: DSDataTableT.InternalColumn<HTMLElement>[],\n columnId: string,\n isSortedDesc: boolean,\n) => {\n const doit = (columns: DSDataTableT.InternalColumn<HTMLElement>[]) =>\n columns.map((col) => {\n const newCol = { ...col };\n delete newCol.isSortedDesc;\n if (col.id === columnId) {\n newCol.isSortedDesc = isSortedDesc;\n }\n if (newCol.columns) {\n newCol.columns = doit(newCol.columns);\n }\n return newCol;\n });\n return doit(visibleColumns);\n};\n\nexport const useHeaderCellHandlers: UseHeaderCellHandlersType = ({\n hasFilter,\n column,\n hasDnD,\n dragHandleRef,\n filterIconRef,\n resizeHandlerRef,\n}) => {\n const {\n tableProps: { onColumnSortChange, onColumnSort },\n patchHeader,\n reduxHeaders,\n visibleColumns,\n } = useContext(DataTableContext);\n\n const reduxHeader = useMemo(() => reduxHeaders[column.id], [reduxHeaders, column]);\n\n const headerRef = column.ref;\n\n const onMouseEnter: React.MouseEventHandler = useCallback(() => {\n patchHeader(column.id, buildNextHeader(reduxHeader, true, hasFilter, hasDnD));\n }, [column.id, hasDnD, hasFilter, patchHeader, reduxHeader]);\n\n const onMouseLeave: React.MouseEventHandler = useCallback(() => {\n if (!headerRef?.current?.contains(document.activeElement)) {\n patchHeader(column.id, buildNextHeader(reduxHeader, false, hasFilter, hasDnD));\n }\n }, [column.id, hasDnD, hasFilter, headerRef, patchHeader, reduxHeader]);\n\n const onClick: React.MouseEventHandler = useCallback(() => {\n if (column.canSort) {\n onColumnSortChange?.({\n column: column.id,\n direction: column.isSortedDesc ? 'ASC' : 'DESC',\n });\n onColumnSort(\n getNextSortedVisibleColumns(visibleColumns, column.id, !column.isSortedDesc),\n column.id,\n column.isSortedDesc ? 'ASC' : 'DESC',\n );\n }\n }, [column.canSort, column.id, column.isSortedDesc, onColumnSort, onColumnSortChange, visibleColumns]);\n\n const onKeyDown: React.KeyboardEventHandler = useCallback(\n (e) => {\n if (e.code === 'ArrowDown' && column.canSort) {\n e.preventDefault();\n onColumnSortChange?.({\n column: column.id,\n direction: 'DESC',\n });\n onColumnSort(getNextSortedVisibleColumns(visibleColumns, column.id, true), column.id, 'DESC');\n } else if (e.code === 'ArrowUp' && column.canSort) {\n e.preventDefault();\n onColumnSortChange?.({\n column: column.id,\n direction: 'ASC',\n });\n onColumnSort(getNextSortedVisibleColumns(visibleColumns, column.id, false), column.id, 'ASC');\n } else if (['Enter', 'Space'].includes(e.code)) {\n patchHeader(column.id, buildNextHeader(reduxHeader, true, hasFilter, hasDnD, true));\n // Elements don't not yet exist\n setTimeout(() => {\n if (dragHandleRef.current) dragHandleRef.current.focus();\n else if (filterIconRef.current) filterIconRef.current.focus();\n else if (resizeHandlerRef.current) resizeHandlerRef.current.focus();\n });\n }\n },\n [\n column.canSort,\n column.id,\n onColumnSortChange,\n onColumnSort,\n visibleColumns,\n patchHeader,\n reduxHeader,\n hasFilter,\n hasDnD,\n dragHandleRef,\n filterIconRef,\n resizeHandlerRef,\n ],\n );\n\n const onFocus: React.FocusEventHandler = useCallback(\n (e) => {\n // Don't do anything if focus wasn't placed in the element (bubling issues)\n if (e.target === headerRef?.current) {\n patchHeader(column.id, buildNextHeader(reduxHeader, true, hasFilter, hasDnD));\n }\n },\n [column.id, hasDnD, hasFilter, headerRef, patchHeader, reduxHeader],\n );\n\n const onBlur: React.FocusEventHandler = useCallback(\n (e) => {\n // Don't do anything if blur was caused by going to a child\n if (e.relatedTarget === dragHandleRef.current) return;\n if (e.relatedTarget === filterIconRef.current) return;\n if (e.relatedTarget === resizeHandlerRef.current) return;\n patchHeader(column.id, buildNextHeader(reduxHeader, false, hasFilter, hasDnD));\n },\n [dragHandleRef, filterIconRef, resizeHandlerRef, patchHeader, column.id, reduxHeader, hasFilter, hasDnD],\n );\n\n return { onMouseEnter, onMouseLeave, onClick, onKeyDown, onBlur, onFocus };\n};\n"],
5
+ "mappings": "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",
6
6
  "names": []
7
7
  }