@elliemae/ds-pagination 3.57.0-next.34 → 3.57.0-next.35

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 (385) hide show
  1. package/dist/cjs/{Pagination.js → DSPagination.js} +8 -8
  2. package/dist/cjs/DSPagination.js.map +7 -0
  3. package/dist/cjs/config/usePagination.js +51 -0
  4. package/dist/cjs/config/usePagination.js.map +7 -0
  5. package/dist/cjs/{PaginationDataTestID.js → config/useValidateProps.js} +9 -13
  6. package/dist/cjs/config/useValidateProps.js.map +7 -0
  7. package/dist/cjs/{DSPaginationDefinitions.js → constants/index.js} +22 -19
  8. package/dist/cjs/constants/index.js.map +7 -0
  9. package/dist/cjs/index.js +29 -18
  10. package/dist/cjs/index.js.map +3 -3
  11. package/dist/cjs/parts/{DSPageNextButton.js → DSPageNextButton/DSPageNextButton.js} +46 -18
  12. package/dist/cjs/parts/DSPageNextButton/DSPageNextButton.js.map +7 -0
  13. package/dist/cjs/parts/DSPageNextButton/config/usePageNextButton.js +55 -0
  14. package/dist/cjs/parts/DSPageNextButton/config/usePageNextButton.js.map +7 -0
  15. package/dist/cjs/parts/DSPageNextButton/config/useValidateProps.js +40 -0
  16. package/dist/cjs/parts/DSPageNextButton/config/useValidateProps.js.map +7 -0
  17. package/dist/cjs/parts/DSPageNextButton/constants/index.js +48 -0
  18. package/dist/cjs/parts/DSPageNextButton/constants/index.js.map +7 -0
  19. package/dist/cjs/parts/DSPageNextButton/index.js +41 -0
  20. package/dist/cjs/parts/DSPageNextButton/index.js.map +7 -0
  21. package/dist/cjs/parts/DSPageNextButton/react-desc-prop-types.js +51 -0
  22. package/dist/cjs/parts/DSPageNextButton/react-desc-prop-types.js.map +7 -0
  23. package/dist/cjs/parts/DSPageNextButton/typescript-testing/slot-props.js +32 -0
  24. package/dist/cjs/parts/DSPageNextButton/typescript-testing/slot-props.js.map +7 -0
  25. package/dist/cjs/{typescript-testing/typescript-page-next-button-valid.js → parts/DSPageNextButton/typescript-testing/typescript-testing.js} +1 -1
  26. package/dist/cjs/parts/DSPageNextButton/typescript-testing/typescript-testing.js.map +7 -0
  27. package/dist/cjs/parts/{DSPagePrevButton.js → DSPagePrevButton/DSPagePrevButton.js} +46 -18
  28. package/dist/cjs/parts/DSPagePrevButton/DSPagePrevButton.js.map +7 -0
  29. package/dist/cjs/parts/DSPagePrevButton/config/usePagePrevButton.js +55 -0
  30. package/dist/cjs/parts/DSPagePrevButton/config/usePagePrevButton.js.map +7 -0
  31. package/dist/cjs/parts/DSPagePrevButton/config/useValidateProps.js +40 -0
  32. package/dist/cjs/parts/DSPagePrevButton/config/useValidateProps.js.map +7 -0
  33. package/dist/cjs/parts/DSPagePrevButton/constants/index.js +48 -0
  34. package/dist/cjs/parts/DSPagePrevButton/constants/index.js.map +7 -0
  35. package/dist/cjs/parts/DSPagePrevButton/index.js +41 -0
  36. package/dist/cjs/parts/DSPagePrevButton/index.js.map +7 -0
  37. package/dist/cjs/parts/DSPagePrevButton/react-desc-prop-types.js +51 -0
  38. package/dist/cjs/parts/DSPagePrevButton/react-desc-prop-types.js.map +7 -0
  39. package/dist/cjs/parts/DSPagePrevButton/typescript-testing/slot-props.js +32 -0
  40. package/dist/cjs/parts/DSPagePrevButton/typescript-testing/slot-props.js.map +7 -0
  41. package/dist/cjs/{typescript-testing/typescript-page-prev-button-valid.js → parts/DSPagePrevButton/typescript-testing/typescript-testing.js} +1 -1
  42. package/dist/cjs/parts/DSPagePrevButton/typescript-testing/typescript-testing.js.map +7 -0
  43. package/dist/cjs/parts/{DSPaginationContainer.js → DSPaginationContainer/DSPaginationContainer.js} +26 -12
  44. package/dist/cjs/parts/DSPaginationContainer/DSPaginationContainer.js.map +7 -0
  45. package/dist/cjs/parts/DSPaginationContainer/config/usePaginationContainer.js +60 -0
  46. package/dist/cjs/parts/DSPaginationContainer/config/usePaginationContainer.js.map +7 -0
  47. package/dist/cjs/parts/DSPaginationContainer/config/useValidateProps.js +40 -0
  48. package/dist/cjs/parts/DSPaginationContainer/config/useValidateProps.js.map +7 -0
  49. package/dist/cjs/parts/DSPaginationContainer/constants/index.js +50 -0
  50. package/dist/cjs/parts/DSPaginationContainer/constants/index.js.map +7 -0
  51. package/dist/cjs/parts/DSPaginationContainer/index.js +41 -0
  52. package/dist/cjs/parts/DSPaginationContainer/index.js.map +7 -0
  53. package/dist/cjs/parts/DSPaginationContainer/react-desc-prop-types.js +48 -0
  54. package/dist/cjs/parts/DSPaginationContainer/react-desc-prop-types.js.map +7 -0
  55. package/dist/cjs/parts/DSPaginationContainer/typescript-testing/slot-props.js +34 -0
  56. package/dist/cjs/parts/DSPaginationContainer/typescript-testing/slot-props.js.map +7 -0
  57. package/dist/cjs/parts/DSPaginationSeparator/DSPaginationSeparator.js +68 -0
  58. package/dist/cjs/parts/DSPaginationSeparator/DSPaginationSeparator.js.map +7 -0
  59. package/dist/cjs/parts/DSPaginationSeparator/config/usePaginationSeparator.js +60 -0
  60. package/dist/cjs/parts/DSPaginationSeparator/config/usePaginationSeparator.js.map +7 -0
  61. package/dist/cjs/parts/DSPaginationSeparator/config/useValidateProps.js +40 -0
  62. package/dist/cjs/parts/DSPaginationSeparator/config/useValidateProps.js.map +7 -0
  63. package/dist/cjs/parts/DSPaginationSeparator/constants/index.js +45 -0
  64. package/dist/cjs/parts/DSPaginationSeparator/constants/index.js.map +7 -0
  65. package/dist/cjs/parts/DSPaginationSeparator/index.js +41 -0
  66. package/dist/cjs/parts/DSPaginationSeparator/index.js.map +7 -0
  67. package/dist/cjs/parts/DSPaginationSeparator/react-desc-prop-types.js +46 -0
  68. package/dist/cjs/parts/DSPaginationSeparator/react-desc-prop-types.js.map +7 -0
  69. package/dist/cjs/parts/DSPaginator/DSPaginator.js +143 -0
  70. package/dist/cjs/parts/DSPaginator/DSPaginator.js.map +7 -0
  71. package/dist/cjs/parts/DSPaginator/{createPaginatorHeader.js → config/createPaginatorHeader.js} +7 -3
  72. package/dist/cjs/parts/DSPaginator/config/createPaginatorHeader.js.map +7 -0
  73. package/dist/cjs/parts/DSPaginator/{getOptions.js.map → config/getOptions.js.map} +1 -1
  74. package/dist/cjs/parts/DSPaginator/{useOnElementOnResize.js.map → config/useOnElementOnResize.js.map} +1 -1
  75. package/dist/cjs/parts/DSPaginator/{usePaginationSearch.js.map → config/usePaginationSearch.js.map} +1 -1
  76. package/dist/cjs/parts/DSPaginator/{usePaginator.js → config/usePaginator.js} +46 -21
  77. package/dist/cjs/parts/DSPaginator/config/usePaginator.js.map +7 -0
  78. package/dist/cjs/parts/DSPaginator/config/useValidateProps.js +40 -0
  79. package/dist/cjs/parts/DSPaginator/config/useValidateProps.js.map +7 -0
  80. package/dist/cjs/parts/DSPaginator/constants/index.js +45 -0
  81. package/dist/cjs/parts/DSPaginator/constants/index.js.map +7 -0
  82. package/dist/cjs/parts/DSPaginator/index.js +7 -112
  83. package/dist/cjs/parts/DSPaginator/index.js.map +3 -3
  84. package/dist/cjs/parts/DSPaginator/react-desc-prop-types.js +59 -0
  85. package/dist/cjs/parts/DSPaginator/react-desc-prop-types.js.map +7 -0
  86. package/dist/cjs/{styled.js → parts/DSPaginator/styled.js} +9 -41
  87. package/dist/cjs/parts/DSPaginator/styled.js.map +7 -0
  88. package/dist/cjs/parts/DSPaginator/typescript-testing/slot-props.js +32 -0
  89. package/dist/cjs/parts/DSPaginator/typescript-testing/slot-props.js.map +7 -0
  90. package/dist/cjs/{typescript-testing/typescript-paginator-valid.js → parts/DSPaginator/typescript-testing/typescript-testing.js} +1 -1
  91. package/dist/cjs/parts/DSPaginator/typescript-testing/typescript-testing.js.map +7 -0
  92. package/dist/cjs/parts/DSPerPageSelector/DSPerPageSelector.js +109 -0
  93. package/dist/cjs/parts/DSPerPageSelector/DSPerPageSelector.js.map +7 -0
  94. package/dist/cjs/parts/DSPerPageSelector/{getOptions.js.map → config/getOptions.js.map} +1 -1
  95. package/dist/cjs/parts/DSPerPageSelector/{usePerPageSelector.js → config/usePerPageSelector.js} +29 -19
  96. package/dist/cjs/parts/DSPerPageSelector/config/usePerPageSelector.js.map +7 -0
  97. package/dist/cjs/parts/DSPerPageSelector/config/useValidateProps.js +40 -0
  98. package/dist/cjs/parts/DSPerPageSelector/config/useValidateProps.js.map +7 -0
  99. package/dist/cjs/parts/DSPerPageSelector/constants/index.js +50 -0
  100. package/dist/cjs/parts/DSPerPageSelector/constants/index.js.map +7 -0
  101. package/dist/cjs/parts/DSPerPageSelector/index.js +7 -70
  102. package/dist/cjs/parts/DSPerPageSelector/index.js.map +3 -3
  103. package/dist/cjs/parts/DSPerPageSelector/react-desc-prop-types.js +58 -0
  104. package/dist/cjs/parts/DSPerPageSelector/react-desc-prop-types.js.map +7 -0
  105. package/dist/cjs/parts/DSPerPageSelector/styled.js +90 -0
  106. package/dist/cjs/parts/DSPerPageSelector/styled.js.map +7 -0
  107. package/dist/cjs/parts/DSPerPageSelector/typescript-testing/slots-props.js +32 -0
  108. package/dist/cjs/parts/DSPerPageSelector/typescript-testing/slots-props.js.map +7 -0
  109. package/dist/cjs/{typescript-testing/typescript-per-page-selector-valid.js → parts/DSPerPageSelector/typescript-testing/typescript-testing.js} +1 -1
  110. package/dist/cjs/parts/DSPerPageSelector/typescript-testing/typescript-testing.js.map +7 -0
  111. package/dist/cjs/parts/PaginationContent.js +7 -9
  112. package/dist/cjs/parts/PaginationContent.js.map +2 -2
  113. package/dist/cjs/parts/index.js +25 -4
  114. package/dist/cjs/parts/index.js.map +2 -2
  115. package/dist/cjs/react-desc-prop-types.js +1 -86
  116. package/dist/cjs/react-desc-prop-types.js.map +2 -2
  117. package/dist/esm/{Pagination.js → DSPagination.js} +6 -6
  118. package/dist/esm/DSPagination.js.map +7 -0
  119. package/dist/esm/config/usePagination.js +21 -0
  120. package/dist/esm/config/usePagination.js.map +7 -0
  121. package/dist/esm/config/useValidateProps.js +10 -0
  122. package/dist/esm/config/useValidateProps.js.map +7 -0
  123. package/dist/esm/constants/index.js +27 -0
  124. package/dist/esm/constants/index.js.map +7 -0
  125. package/dist/esm/index.js +45 -13
  126. package/dist/esm/index.js.map +3 -3
  127. package/dist/esm/parts/DSPageNextButton/DSPageNextButton.js +74 -0
  128. package/dist/esm/parts/DSPageNextButton/DSPageNextButton.js.map +7 -0
  129. package/dist/esm/parts/DSPageNextButton/config/usePageNextButton.js +30 -0
  130. package/dist/esm/parts/DSPageNextButton/config/usePageNextButton.js.map +7 -0
  131. package/dist/esm/parts/DSPageNextButton/config/useValidateProps.js +10 -0
  132. package/dist/esm/parts/DSPageNextButton/config/useValidateProps.js.map +7 -0
  133. package/dist/esm/parts/DSPageNextButton/constants/index.js +18 -0
  134. package/dist/esm/parts/DSPageNextButton/constants/index.js.map +7 -0
  135. package/dist/esm/parts/DSPageNextButton/index.js +11 -0
  136. package/dist/esm/parts/DSPageNextButton/index.js.map +7 -0
  137. package/dist/esm/parts/DSPageNextButton/react-desc-prop-types.js +26 -0
  138. package/dist/esm/parts/DSPageNextButton/react-desc-prop-types.js.map +7 -0
  139. package/dist/esm/parts/DSPageNextButton/typescript-testing/slot-props.js +9 -0
  140. package/dist/esm/parts/DSPageNextButton/typescript-testing/slot-props.js.map +7 -0
  141. package/dist/esm/{typescript-testing/typescript-page-next-button-valid.js → parts/DSPageNextButton/typescript-testing/typescript-testing.js} +1 -1
  142. package/dist/esm/parts/DSPageNextButton/typescript-testing/typescript-testing.js.map +7 -0
  143. package/dist/esm/parts/DSPagePrevButton/DSPagePrevButton.js +74 -0
  144. package/dist/esm/parts/DSPagePrevButton/DSPagePrevButton.js.map +7 -0
  145. package/dist/esm/parts/DSPagePrevButton/config/usePagePrevButton.js +30 -0
  146. package/dist/esm/parts/DSPagePrevButton/config/usePagePrevButton.js.map +7 -0
  147. package/dist/esm/parts/DSPagePrevButton/config/useValidateProps.js +10 -0
  148. package/dist/esm/parts/DSPagePrevButton/config/useValidateProps.js.map +7 -0
  149. package/dist/esm/parts/DSPagePrevButton/constants/index.js +18 -0
  150. package/dist/esm/parts/DSPagePrevButton/constants/index.js.map +7 -0
  151. package/dist/esm/parts/DSPagePrevButton/index.js +11 -0
  152. package/dist/esm/parts/DSPagePrevButton/index.js.map +7 -0
  153. package/dist/esm/parts/DSPagePrevButton/react-desc-prop-types.js +26 -0
  154. package/dist/esm/parts/DSPagePrevButton/react-desc-prop-types.js.map +7 -0
  155. package/dist/esm/parts/DSPagePrevButton/typescript-testing/slot-props.js +9 -0
  156. package/dist/esm/parts/DSPagePrevButton/typescript-testing/slot-props.js.map +7 -0
  157. package/dist/esm/{typescript-testing/typescript-page-prev-button-valid.js → parts/DSPagePrevButton/typescript-testing/typescript-testing.js} +1 -1
  158. package/dist/esm/parts/DSPagePrevButton/typescript-testing/typescript-testing.js.map +7 -0
  159. package/dist/esm/parts/DSPaginationContainer/DSPaginationContainer.js +50 -0
  160. package/dist/esm/parts/DSPaginationContainer/DSPaginationContainer.js.map +7 -0
  161. package/dist/esm/parts/DSPaginationContainer/config/usePaginationContainer.js +38 -0
  162. package/dist/esm/parts/DSPaginationContainer/config/usePaginationContainer.js.map +7 -0
  163. package/dist/esm/parts/DSPaginationContainer/config/useValidateProps.js +10 -0
  164. package/dist/esm/parts/DSPaginationContainer/config/useValidateProps.js.map +7 -0
  165. package/dist/esm/parts/DSPaginationContainer/constants/index.js +20 -0
  166. package/dist/esm/parts/DSPaginationContainer/constants/index.js.map +7 -0
  167. package/dist/esm/parts/DSPaginationContainer/index.js +15 -0
  168. package/dist/esm/parts/DSPaginationContainer/index.js.map +7 -0
  169. package/dist/esm/parts/DSPaginationContainer/react-desc-prop-types.js +18 -0
  170. package/dist/esm/parts/DSPaginationContainer/react-desc-prop-types.js.map +7 -0
  171. package/dist/esm/parts/DSPaginationContainer/typescript-testing/slot-props.js +11 -0
  172. package/dist/esm/parts/DSPaginationContainer/typescript-testing/slot-props.js.map +7 -0
  173. package/dist/esm/parts/DSPaginationSeparator/DSPaginationSeparator.js +43 -0
  174. package/dist/esm/parts/DSPaginationSeparator/DSPaginationSeparator.js.map +7 -0
  175. package/dist/esm/parts/DSPaginationSeparator/config/usePaginationSeparator.js +38 -0
  176. package/dist/esm/parts/DSPaginationSeparator/config/usePaginationSeparator.js.map +7 -0
  177. package/dist/esm/parts/DSPaginationSeparator/config/useValidateProps.js +10 -0
  178. package/dist/esm/parts/DSPaginationSeparator/config/useValidateProps.js.map +7 -0
  179. package/dist/esm/parts/DSPaginationSeparator/constants/index.js +15 -0
  180. package/dist/esm/parts/DSPaginationSeparator/constants/index.js.map +7 -0
  181. package/dist/esm/parts/DSPaginationSeparator/index.js +15 -0
  182. package/dist/esm/parts/DSPaginationSeparator/index.js.map +7 -0
  183. package/dist/esm/parts/DSPaginationSeparator/react-desc-prop-types.js +16 -0
  184. package/dist/esm/parts/DSPaginationSeparator/react-desc-prop-types.js.map +7 -0
  185. package/dist/esm/parts/DSPaginator/DSPaginator.js +113 -0
  186. package/dist/esm/parts/DSPaginator/DSPaginator.js.map +7 -0
  187. package/dist/esm/parts/DSPaginator/{createPaginatorHeader.js → config/createPaginatorHeader.js} +7 -3
  188. package/dist/esm/parts/DSPaginator/config/createPaginatorHeader.js.map +7 -0
  189. package/dist/esm/parts/DSPaginator/{getOptions.js.map → config/getOptions.js.map} +1 -1
  190. package/dist/esm/parts/DSPaginator/{useOnElementOnResize.js.map → config/useOnElementOnResize.js.map} +1 -1
  191. package/dist/esm/parts/DSPaginator/{usePaginationSearch.js.map → config/usePaginationSearch.js.map} +1 -1
  192. package/dist/esm/parts/DSPaginator/{usePaginator.js → config/usePaginator.js} +52 -22
  193. package/dist/esm/parts/DSPaginator/config/usePaginator.js.map +7 -0
  194. package/dist/esm/parts/DSPaginator/config/useValidateProps.js +10 -0
  195. package/dist/esm/parts/DSPaginator/config/useValidateProps.js.map +7 -0
  196. package/dist/esm/parts/DSPaginator/constants/index.js +15 -0
  197. package/dist/esm/parts/DSPaginator/constants/index.js.map +7 -0
  198. package/dist/esm/parts/DSPaginator/index.js +6 -111
  199. package/dist/esm/parts/DSPaginator/index.js.map +3 -3
  200. package/dist/esm/parts/DSPaginator/react-desc-prop-types.js +34 -0
  201. package/dist/esm/parts/DSPaginator/react-desc-prop-types.js.map +7 -0
  202. package/dist/esm/parts/DSPaginator/styled.js +60 -0
  203. package/dist/esm/parts/DSPaginator/styled.js.map +7 -0
  204. package/dist/esm/parts/DSPaginator/typescript-testing/slot-props.js +9 -0
  205. package/dist/esm/parts/DSPaginator/typescript-testing/slot-props.js.map +7 -0
  206. package/dist/esm/{typescript-testing/typescript-paginator-valid.js → parts/DSPaginator/typescript-testing/typescript-testing.js} +1 -1
  207. package/dist/esm/parts/DSPaginator/typescript-testing/typescript-testing.js.map +7 -0
  208. package/dist/esm/parts/DSPerPageSelector/DSPerPageSelector.js +79 -0
  209. package/dist/esm/parts/DSPerPageSelector/DSPerPageSelector.js.map +7 -0
  210. package/dist/esm/parts/DSPerPageSelector/{getOptions.js.map → config/getOptions.js.map} +1 -1
  211. package/dist/esm/parts/DSPerPageSelector/config/usePerPageSelector.js +55 -0
  212. package/dist/esm/parts/DSPerPageSelector/config/usePerPageSelector.js.map +7 -0
  213. package/dist/esm/parts/DSPerPageSelector/config/useValidateProps.js +10 -0
  214. package/dist/esm/parts/DSPerPageSelector/config/useValidateProps.js.map +7 -0
  215. package/dist/esm/parts/DSPerPageSelector/constants/index.js +20 -0
  216. package/dist/esm/parts/DSPerPageSelector/constants/index.js.map +7 -0
  217. package/dist/esm/parts/DSPerPageSelector/index.js +6 -69
  218. package/dist/esm/parts/DSPerPageSelector/index.js.map +3 -3
  219. package/dist/esm/parts/DSPerPageSelector/react-desc-prop-types.js +33 -0
  220. package/dist/esm/parts/DSPerPageSelector/react-desc-prop-types.js.map +7 -0
  221. package/dist/esm/parts/DSPerPageSelector/styled.js +60 -0
  222. package/dist/esm/parts/DSPerPageSelector/styled.js.map +7 -0
  223. package/dist/esm/parts/DSPerPageSelector/typescript-testing/slots-props.js +9 -0
  224. package/dist/esm/parts/DSPerPageSelector/typescript-testing/slots-props.js.map +7 -0
  225. package/dist/esm/{typescript-testing/typescript-per-page-selector-valid.js → parts/DSPerPageSelector/typescript-testing/typescript-testing.js} +1 -1
  226. package/dist/esm/parts/DSPerPageSelector/typescript-testing/typescript-testing.js.map +7 -0
  227. package/dist/esm/parts/PaginationContent.js +7 -9
  228. package/dist/esm/parts/PaginationContent.js.map +2 -2
  229. package/dist/esm/parts/index.js +63 -6
  230. package/dist/esm/parts/index.js.map +2 -2
  231. package/dist/esm/react-desc-prop-types.js +1 -86
  232. package/dist/esm/react-desc-prop-types.js.map +2 -2
  233. package/dist/types/config/usePagination.d.ts +5 -0
  234. package/dist/types/config/useValidateProps.d.ts +3 -0
  235. package/dist/types/constants/index.d.ts +29 -0
  236. package/dist/types/index.d.ts +3 -7
  237. package/dist/types/parts/DSPageNextButton/DSPageNextButton.d.ts +5 -0
  238. package/dist/types/parts/DSPageNextButton/config/usePageNextButton.d.ts +377 -0
  239. package/dist/types/parts/DSPageNextButton/config/useValidateProps.d.ts +3 -0
  240. package/dist/types/parts/DSPageNextButton/constants/index.d.ts +9 -0
  241. package/dist/types/parts/DSPageNextButton/index.d.ts +3 -0
  242. package/dist/types/parts/DSPageNextButton/react-desc-prop-types.d.ts +23 -0
  243. package/dist/types/parts/DSPageNextButton/tests/DSPageNextButton.get-owner-props.test.d.ts +1 -0
  244. package/dist/types/parts/DSPageNextButton/tests/DSPageNextButton.keyboard.test.d.ts +1 -0
  245. package/dist/types/parts/DSPageNextButton/tests/utils/NextButtonTestRender.d.ts +2 -0
  246. package/dist/types/parts/DSPageNextButton/typescript-testing/slot-props.d.ts +1 -0
  247. package/dist/types/parts/DSPageNextButton/typescript-testing/typescript-testing.d.ts +1 -0
  248. package/dist/types/parts/DSPagePrevButton/DSPagePrevButton.d.ts +5 -0
  249. package/dist/types/parts/DSPagePrevButton/config/usePagePrevButton.d.ts +377 -0
  250. package/dist/types/parts/DSPagePrevButton/config/useValidateProps.d.ts +3 -0
  251. package/dist/types/parts/DSPagePrevButton/constants/index.d.ts +9 -0
  252. package/dist/types/parts/DSPagePrevButton/index.d.ts +3 -0
  253. package/dist/types/parts/DSPagePrevButton/react-desc-prop-types.d.ts +23 -0
  254. package/dist/types/parts/DSPagePrevButton/tests/DSPagePrevButton.a11y.test.d.ts +1 -0
  255. package/dist/types/parts/DSPagePrevButton/tests/DSPagePrevButton.callbacks.test.d.ts +1 -0
  256. package/dist/types/parts/DSPagePrevButton/tests/DSPagePrevButton.data-testid.test.d.ts +1 -0
  257. package/dist/types/parts/DSPagePrevButton/tests/DSPagePrevButton.export.test.d.ts +1 -0
  258. package/dist/types/parts/DSPagePrevButton/tests/DSPagePrevButton.get-owner-props.test.d.ts +1 -0
  259. package/dist/types/parts/DSPagePrevButton/tests/DSPagePrevButton.keyboard.test.d.ts +1 -0
  260. package/dist/types/parts/DSPagePrevButton/tests/utils/PrevButtonTestRender.d.ts +1 -0
  261. package/dist/types/parts/DSPagePrevButton/typescript-testing/slot-props.d.ts +1 -0
  262. package/dist/types/parts/DSPagePrevButton/typescript-testing/typescript-testing.d.ts +1 -0
  263. package/dist/types/parts/DSPaginationContainer/DSPaginationContainer.d.ts +5 -0
  264. package/dist/types/parts/DSPaginationContainer/config/usePaginationContainer.d.ts +377 -0
  265. package/dist/types/parts/DSPaginationContainer/config/useValidateProps.d.ts +3 -0
  266. package/dist/types/parts/DSPaginationContainer/constants/index.d.ts +11 -0
  267. package/dist/types/parts/DSPaginationContainer/index.d.ts +3 -0
  268. package/dist/types/parts/DSPaginationContainer/react-desc-prop-types.d.ts +22 -0
  269. package/dist/types/parts/DSPaginationContainer/tests/DSPaginationContainer.data-testid.test.d.ts +1 -0
  270. package/dist/types/parts/DSPaginationContainer/tests/DSPaginationContainer.exports.test.d.ts +1 -0
  271. package/dist/types/parts/DSPaginationContainer/tests/DSPaginationContainer.get-owner-props.test.d.ts +1 -0
  272. package/dist/types/parts/DSPaginationContainer/tests/utils/PaginationContainerRender.d.ts +1 -0
  273. package/dist/types/parts/DSPaginationContainer/typescript-testing/slot-props.d.ts +1 -0
  274. package/dist/types/parts/DSPaginationSeparator/DSPaginationSeparator.d.ts +7 -0
  275. package/dist/types/parts/DSPaginationSeparator/config/usePaginationSeparator.d.ts +377 -0
  276. package/dist/types/parts/DSPaginationSeparator/config/useValidateProps.d.ts +3 -0
  277. package/dist/types/parts/DSPaginationSeparator/constants/index.d.ts +9 -0
  278. package/dist/types/parts/DSPaginationSeparator/index.d.ts +3 -0
  279. package/dist/types/parts/DSPaginationSeparator/react-desc-prop-types.d.ts +18 -0
  280. package/dist/types/parts/DSPaginationSeparator/tests/DSPaginationSeparator.data-testid.test.d.ts +1 -0
  281. package/dist/types/parts/DSPaginationSeparator/tests/DSPaginationSeparator.exports.test.d.ts +1 -0
  282. package/dist/types/parts/DSPaginationSeparator/tests/DSPaginationSeparator.get-owner-props.test.d.ts +1 -0
  283. package/dist/types/parts/DSPaginationSeparator/tests/utils/DSPaginationSeparatorTestRender.d.ts +1 -0
  284. package/dist/types/parts/DSPaginator/DSPaginator.d.ts +5 -0
  285. package/dist/types/parts/DSPaginator/{createPaginatorHeader.d.ts → config/createPaginatorHeader.d.ts} +2 -1
  286. package/dist/types/parts/DSPaginator/config/usePaginator.d.ts +386 -0
  287. package/dist/types/parts/DSPaginator/config/useValidateProps.d.ts +3 -0
  288. package/dist/types/parts/DSPaginator/constants/index.d.ts +9 -0
  289. package/dist/types/parts/DSPaginator/index.d.ts +3 -4
  290. package/dist/types/parts/DSPaginator/react-desc-prop-types.d.ts +27 -0
  291. package/dist/types/parts/DSPaginator/styled.d.ts +2 -0
  292. package/dist/types/parts/DSPaginator/tests/DSPaginator.a11y.test.d.ts +1 -0
  293. package/dist/types/parts/DSPaginator/tests/DSPaginator.data-testid.test.d.ts +1 -0
  294. package/dist/types/parts/DSPaginator/tests/DSPaginator.exports.test.d.ts +1 -0
  295. package/dist/types/parts/DSPaginator/tests/DSPaginator.get-owner-props.test.d.ts +1 -0
  296. package/dist/types/parts/DSPaginator/tests/DSPaginator.keyboard.test.d.ts +1 -0
  297. package/dist/types/parts/DSPaginator/tests/utils/DSPaginatorTestRender.d.ts +1 -0
  298. package/dist/types/parts/DSPaginator/typescript-testing/slot-props.d.ts +1 -0
  299. package/dist/types/parts/DSPaginator/typescript-testing/typescript-testing.d.ts +1 -0
  300. package/dist/types/parts/DSPerPageSelector/DSPerPageSelector.d.ts +5 -0
  301. package/dist/types/parts/DSPerPageSelector/config/usePerPageSelector.d.ts +383 -0
  302. package/dist/types/parts/DSPerPageSelector/config/useValidateProps.d.ts +3 -0
  303. package/dist/types/parts/DSPerPageSelector/constants/index.d.ts +13 -0
  304. package/dist/types/parts/DSPerPageSelector/index.d.ts +3 -4
  305. package/dist/types/parts/DSPerPageSelector/react-desc-prop-types.d.ts +28 -0
  306. package/dist/types/parts/DSPerPageSelector/styled.d.ts +2 -0
  307. package/dist/types/parts/DSPerPageSelector/tests/DSPerPageSelector.a11y.test.d.ts +1 -0
  308. package/dist/types/parts/DSPerPageSelector/tests/DSPerPageSelector.data-testid.test.d.ts +1 -0
  309. package/dist/types/parts/DSPerPageSelector/tests/DSPerPageSelector.exports.test.d.ts +1 -0
  310. package/dist/types/parts/DSPerPageSelector/tests/DSPerPageSelector.get-owner-props.test.d.ts +1 -0
  311. package/dist/types/parts/DSPerPageSelector/tests/DSPerPageSelector.keyboard.test.d.ts +1 -0
  312. package/dist/types/parts/DSPerPageSelector/tests/utils/PerPageSelectorTestRender.d.ts +1 -0
  313. package/dist/types/parts/DSPerPageSelector/typescript-testing/slots-props.d.ts +1 -0
  314. package/dist/types/parts/DSPerPageSelector/typescript-testing/typescript-testing.d.ts +1 -0
  315. package/dist/types/parts/index.d.ts +6 -5
  316. package/dist/types/react-desc-prop-types.d.ts +9 -540
  317. package/dist/types/tests/DSPagination.data-testid.test.d.ts +1 -0
  318. package/dist/types/tests/DSPagination.exports.test.d.ts +1 -0
  319. package/dist/types/tests/DSPagination.get-owner-props.test.d.ts +1 -0
  320. package/package.json +15 -12
  321. package/dist/cjs/DSPaginationDefinitions.js.map +0 -7
  322. package/dist/cjs/Pagination.js.map +0 -7
  323. package/dist/cjs/PaginationDataTestID.js.map +0 -7
  324. package/dist/cjs/parts/DSPageNextButton.js.map +0 -7
  325. package/dist/cjs/parts/DSPagePrevButton.js.map +0 -7
  326. package/dist/cjs/parts/DSPaginationContainer.js.map +0 -7
  327. package/dist/cjs/parts/DSPaginator/createPaginatorHeader.js.map +0 -7
  328. package/dist/cjs/parts/DSPaginator/usePaginator.js.map +0 -7
  329. package/dist/cjs/parts/DSPerPageSelector/usePerPageSelector.js.map +0 -7
  330. package/dist/cjs/props.js +0 -85
  331. package/dist/cjs/props.js.map +0 -7
  332. package/dist/cjs/styled.js.map +0 -7
  333. package/dist/cjs/typescript-testing/typescript-page-next-button-valid.js.map +0 -7
  334. package/dist/cjs/typescript-testing/typescript-page-prev-button-valid.js.map +0 -7
  335. package/dist/cjs/typescript-testing/typescript-paginator-valid.js.map +0 -7
  336. package/dist/cjs/typescript-testing/typescript-per-page-selector-valid.js.map +0 -7
  337. package/dist/esm/DSPaginationDefinitions.js +0 -24
  338. package/dist/esm/DSPaginationDefinitions.js.map +0 -7
  339. package/dist/esm/Pagination.js.map +0 -7
  340. package/dist/esm/PaginationDataTestID.js +0 -14
  341. package/dist/esm/PaginationDataTestID.js.map +0 -7
  342. package/dist/esm/parts/DSPageNextButton.js +0 -47
  343. package/dist/esm/parts/DSPageNextButton.js.map +0 -7
  344. package/dist/esm/parts/DSPagePrevButton.js +0 -47
  345. package/dist/esm/parts/DSPagePrevButton.js.map +0 -7
  346. package/dist/esm/parts/DSPaginationContainer.js +0 -31
  347. package/dist/esm/parts/DSPaginationContainer.js.map +0 -7
  348. package/dist/esm/parts/DSPaginator/createPaginatorHeader.js.map +0 -7
  349. package/dist/esm/parts/DSPaginator/usePaginator.js.map +0 -7
  350. package/dist/esm/parts/DSPerPageSelector/usePerPageSelector.js +0 -40
  351. package/dist/esm/parts/DSPerPageSelector/usePerPageSelector.js.map +0 -7
  352. package/dist/esm/props.js +0 -55
  353. package/dist/esm/props.js.map +0 -7
  354. package/dist/esm/styled.js +0 -92
  355. package/dist/esm/styled.js.map +0 -7
  356. package/dist/esm/typescript-testing/typescript-page-next-button-valid.js.map +0 -7
  357. package/dist/esm/typescript-testing/typescript-page-prev-button-valid.js.map +0 -7
  358. package/dist/esm/typescript-testing/typescript-paginator-valid.js.map +0 -7
  359. package/dist/esm/typescript-testing/typescript-per-page-selector-valid.js.map +0 -7
  360. package/dist/types/DSPaginationDefinitions.d.ts +0 -12
  361. package/dist/types/PaginationDataTestID.d.ts +0 -9
  362. package/dist/types/parts/DSPageNextButton.d.ts +0 -4
  363. package/dist/types/parts/DSPagePrevButton.d.ts +0 -4
  364. package/dist/types/parts/DSPaginationContainer.d.ts +0 -4
  365. package/dist/types/parts/DSPaginator/usePaginator.d.ts +0 -381
  366. package/dist/types/parts/DSPerPageSelector/usePerPageSelector.d.ts +0 -377
  367. package/dist/types/props.d.ts +0 -20
  368. package/dist/types/styled.d.ts +0 -7
  369. /package/dist/cjs/parts/DSPaginator/{getOptions.js → config/getOptions.js} +0 -0
  370. /package/dist/cjs/parts/DSPaginator/{useOnElementOnResize.js → config/useOnElementOnResize.js} +0 -0
  371. /package/dist/cjs/parts/DSPaginator/{usePaginationSearch.js → config/usePaginationSearch.js} +0 -0
  372. /package/dist/cjs/parts/DSPerPageSelector/{getOptions.js → config/getOptions.js} +0 -0
  373. /package/dist/esm/parts/DSPaginator/{getOptions.js → config/getOptions.js} +0 -0
  374. /package/dist/esm/parts/DSPaginator/{useOnElementOnResize.js → config/useOnElementOnResize.js} +0 -0
  375. /package/dist/esm/parts/DSPaginator/{usePaginationSearch.js → config/usePaginationSearch.js} +0 -0
  376. /package/dist/esm/parts/DSPerPageSelector/{getOptions.js → config/getOptions.js} +0 -0
  377. /package/dist/types/{Pagination.d.ts → DSPagination.d.ts} +0 -0
  378. /package/dist/types/{typescript-testing/typescript-page-next-button-valid.d.ts → parts/DSPageNextButton/tests/DSPageNextButton.a11y.test.d.ts} +0 -0
  379. /package/dist/types/{typescript-testing/typescript-page-prev-button-valid.d.ts → parts/DSPageNextButton/tests/DSPageNextButton.callbacks.test.d.ts} +0 -0
  380. /package/dist/types/{typescript-testing/typescript-paginator-valid.d.ts → parts/DSPageNextButton/tests/DSPageNextButton.data-testid.test.d.ts} +0 -0
  381. /package/dist/types/{typescript-testing/typescript-per-page-selector-valid.d.ts → parts/DSPageNextButton/tests/DSPageNextButton.export.test.d.ts} +0 -0
  382. /package/dist/types/parts/DSPaginator/{getOptions.d.ts → config/getOptions.d.ts} +0 -0
  383. /package/dist/types/parts/DSPaginator/{useOnElementOnResize.d.ts → config/useOnElementOnResize.d.ts} +0 -0
  384. /package/dist/types/parts/DSPaginator/{usePaginationSearch.d.ts → config/usePaginationSearch.d.ts} +0 -0
  385. /package/dist/types/parts/DSPerPageSelector/{getOptions.d.ts → config/getOptions.d.ts} +0 -0
@@ -1,116 +1,11 @@
1
1
  import * as React from "react";
2
- import { Fragment, jsx, jsxs } from "react/jsx-runtime";
3
- import { useMemo } from "react";
4
- import { ChevronDown } from "@elliemae/ds-icons";
5
- import { describe, useMemoMergePropsWithDefault, useValidateTypescriptPropTypes } from "@elliemae/ds-props-helpers";
6
- import { Grid } from "@elliemae/ds-grid";
7
- import { DSDropdownMenuV2 } from "@elliemae/ds-dropdownmenu-v2";
8
- import { DSTypography } from "@elliemae/ds-typography";
9
- import { DSCircularIndeterminateIndicator } from "@elliemae/ds-circular-progress-indicator";
10
- import { InvisibleDiv, PaginationDropdownButton, DSPaginationSeparator } from "../../styled.js";
11
- import { paginatorDefaultProps, DSPaginatorPropTypesSchema } from "../../react-desc-prop-types.js";
12
- import { PaginatorName } from "../../DSPaginationDefinitions.js";
13
- import { usePaginator } from "./usePaginator.js";
14
- import { createPaginatorHeader } from "./createPaginatorHeader.js";
15
- import { PAGINATION_DATA_TESTID } from "../../PaginationDataTestID.js";
16
- const DSPaginator = (props) => {
17
- const propsWithDefault = useMemoMergePropsWithDefault(
18
- props,
19
- paginatorDefaultProps
20
- );
21
- useValidateTypescriptPropTypes(propsWithDefault, DSPaginatorPropTypesSchema, PaginatorName);
22
- const { pageIndex, pageCount, isLoadingPageCount, onPageChange, pageDetails, pageDetailsTitle } = propsWithDefault;
23
- const {
24
- btnRef,
25
- btnWidth,
26
- pageInfoWidth,
27
- options,
28
- isOpened,
29
- setIsOpened,
30
- detailWidth,
31
- globalAttributes,
32
- xstyledAttributes,
33
- actionRef,
34
- onKeyDown
35
- } = usePaginator(propsWithDefault);
36
- const Header = useMemo(
37
- () => createPaginatorHeader({ pageDetailsTitle, pageInfoWidth }),
38
- [pageDetailsTitle, pageInfoWidth]
39
- );
40
- const buttonOnClick = useMemo(() => {
41
- if (globalAttributes.onClick) return globalAttributes.onClick;
42
- return () => setIsOpened((prev) => !prev);
43
- }, [globalAttributes.onClick, setIsOpened]);
44
- return /* @__PURE__ */ jsxs(
45
- DSDropdownMenuV2,
46
- {
47
- isOpened,
48
- options,
49
- selectedOptions: { [pageIndex.toString()]: true },
50
- onOptionClick: (_, clickedOption) => {
51
- onPageChange(clickedOption.value);
52
- setIsOpened(false);
53
- btnRef.current?.focus();
54
- },
55
- onClickOutside: () => {
56
- setIsOpened(false);
57
- btnRef.current?.focus();
58
- },
59
- customOffset: [-23, 2],
60
- startPlacementPreference: "top-start",
61
- actionRef,
62
- onKeyDown,
63
- minWidth: pageDetails.length !== 0 ? btnWidth + 23 : pageCount.toString().length * 6 + 90,
64
- maxHeight: 300,
65
- HeaderComp: Header,
66
- children: [
67
- /* @__PURE__ */ jsx(
68
- PaginationDropdownButton,
69
- {
70
- buttonType: "raw",
71
- disabled: isLoadingPageCount,
72
- innerRef: btnRef,
73
- "aria-pressed": isOpened,
74
- "aria-label": `Page ${pageIndex} out of ${pageCount}, ${pageDetails.length !== 0 ? pageDetails[pageIndex - 1] : "\b\b"}. Press to change the current page`,
75
- "data-testid": PAGINATION_DATA_TESTID.PAGINATOR,
76
- ...globalAttributes,
77
- ...xstyledAttributes,
78
- onClick: buttonOnClick,
79
- children: /* @__PURE__ */ jsxs(Grid, { gutter: "xxxs", alignItems: "center", style: { gridAutoFlow: "column" }, children: [
80
- /* @__PURE__ */ jsx(DSTypography, { fontSize: "18px", variant: "b1", as: "span", fontWeight: "semibold", textAlign: "start", children: pageIndex }),
81
- "/ ",
82
- pageCount,
83
- isLoadingPageCount && /* @__PURE__ */ jsx(DSCircularIndeterminateIndicator, { ml: "xxxs", mr: "xxxs", size: "xs" }),
84
- pageDetails.length !== 0 && /* @__PURE__ */ jsxs(Fragment, { children: [
85
- /* @__PURE__ */ jsx(DSPaginationSeparator, { height: "12px", ml: "12px", mr: "xxxs" }),
86
- /* @__PURE__ */ jsx(
87
- DSTypography,
88
- {
89
- fontSize: "13px",
90
- w: detailWidth,
91
- mr: "xxs",
92
- variant: "b1",
93
- as: "span",
94
- fontWeight: "semibold",
95
- textAlign: "start",
96
- children: pageDetails[pageIndex - 1]
97
- }
98
- )
99
- ] }),
100
- /* @__PURE__ */ jsx(ChevronDown, { ml: "xxxs", color: ["brand-primary", "700"] })
101
- ] })
102
- }
103
- ),
104
- /* @__PURE__ */ jsx(Grid, { style: { position: "relative" }, children: pageDetails.map((pageDetail) => /* @__PURE__ */ jsx(InvisibleDiv, { "data-testid": "ds-pagination-invisible-detail-for-width-calc", children: /* @__PURE__ */ jsx(DSTypography, { fontSize: "13px", mr: "xxs", variant: "b1", as: "span", fontWeight: "semibold", textAlign: "start", children: pageDetail }) }, pageDetail)) })
105
- ]
106
- }
107
- );
108
- };
109
- DSPaginator.displayName = PaginatorName;
110
- const DSPaginatorWithSchema = describe(DSPaginator).description("Per Page Selector");
111
- DSPaginatorWithSchema.propTypes = DSPaginatorPropTypesSchema;
2
+ import { DSPaginator, DSPaginatorWithSchema } from "./DSPaginator.js";
3
+ import { DSPaginatorName, PAGINATOR_DATA_TESTID, PAGINATOR_SLOTS } from "./constants/index.js";
112
4
  export {
113
5
  DSPaginator,
114
- DSPaginatorWithSchema
6
+ DSPaginatorName,
7
+ DSPaginatorWithSchema,
8
+ PAGINATOR_DATA_TESTID,
9
+ PAGINATOR_SLOTS
115
10
  };
116
11
  //# sourceMappingURL=index.js.map
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
- "sources": ["../../../../../../../scripts/build/transpile/react-shim.js", "../../../../src/parts/DSPaginator/index.tsx"],
4
- "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "/* eslint-disable react/prop-types */\nimport React, { useMemo } from 'react';\nimport type { DSButtonT } from '@elliemae/ds-button-v2';\nimport { ChevronDown } from '@elliemae/ds-icons';\nimport { describe, useMemoMergePropsWithDefault, useValidateTypescriptPropTypes } from '@elliemae/ds-props-helpers';\nimport { Grid } from '@elliemae/ds-grid';\nimport { DSDropdownMenuV2 } from '@elliemae/ds-dropdownmenu-v2';\nimport { DSTypography } from '@elliemae/ds-typography';\nimport { DSCircularIndeterminateIndicator } from '@elliemae/ds-circular-progress-indicator';\nimport type { DSDropdownMenuT } from '@elliemae/ds-dropdownmenu-v2';\nimport { InvisibleDiv, PaginationDropdownButton, DSPaginationSeparator } from '../../styled.js';\nimport { paginatorDefaultProps, DSPaginatorPropTypesSchema } from '../../react-desc-prop-types.js';\nimport { PaginatorName } from '../../DSPaginationDefinitions.js';\nimport { usePaginator } from './usePaginator.js';\nimport { createPaginatorHeader } from './createPaginatorHeader.js';\nimport { PAGINATION_DATA_TESTID } from '../../PaginationDataTestID.js';\nimport type { DSPaginationT } from '../../react-desc-prop-types.js';\n\nexport const DSPaginator: React.ComponentType<DSPaginationT.PaginatorProps> = (props) => {\n const propsWithDefault = useMemoMergePropsWithDefault<DSPaginationT.PaginatorInternalProps>(\n props,\n paginatorDefaultProps,\n );\n useValidateTypescriptPropTypes(propsWithDefault, DSPaginatorPropTypesSchema, PaginatorName);\n\n const { pageIndex, pageCount, isLoadingPageCount, onPageChange, pageDetails, pageDetailsTitle } = propsWithDefault;\n\n const {\n btnRef,\n btnWidth,\n pageInfoWidth,\n options,\n isOpened,\n setIsOpened,\n detailWidth,\n globalAttributes,\n xstyledAttributes,\n actionRef,\n onKeyDown,\n } = usePaginator(propsWithDefault);\n\n const Header = useMemo(\n () => createPaginatorHeader({ pageDetailsTitle, pageInfoWidth }),\n [pageDetailsTitle, pageInfoWidth],\n );\n\n const buttonOnClick: DSButtonT.Props['onClick'] = useMemo(() => {\n if (globalAttributes.onClick) return globalAttributes.onClick as DSButtonT.Props['onClick'];\n return () => setIsOpened((prev) => !prev);\n }, [globalAttributes.onClick, setIsOpened]);\n\n return (\n <DSDropdownMenuV2\n isOpened={isOpened}\n options={options}\n selectedOptions={{ [pageIndex.toString()]: true }}\n onOptionClick={(_, clickedOption) => {\n onPageChange((clickedOption as DSDropdownMenuT.ItemSingleOptions).value as number);\n setIsOpened(false);\n btnRef.current?.focus();\n }}\n onClickOutside={() => {\n setIsOpened(false);\n btnRef.current?.focus();\n }}\n customOffset={[-23, 2]}\n startPlacementPreference=\"top-start\"\n actionRef={actionRef}\n onKeyDown={onKeyDown}\n minWidth={pageDetails.length !== 0 ? btnWidth + 23 : pageCount.toString().length * 6 + 90}\n maxHeight={300}\n HeaderComp={Header}\n >\n <PaginationDropdownButton\n buttonType=\"raw\"\n disabled={isLoadingPageCount}\n innerRef={btnRef}\n aria-pressed={isOpened}\n aria-label={`Page ${pageIndex} out of ${pageCount}, ${\n pageDetails.length !== 0 ? pageDetails[pageIndex - 1] : '\\b\\b'\n }. Press to change the current page`}\n data-testid={PAGINATION_DATA_TESTID.PAGINATOR}\n {...globalAttributes}\n {...xstyledAttributes}\n onClick={buttonOnClick}\n >\n <Grid gutter=\"xxxs\" alignItems=\"center\" style={{ gridAutoFlow: 'column' }}>\n <DSTypography fontSize=\"18px\" variant=\"b1\" as=\"span\" fontWeight=\"semibold\" textAlign=\"start\">\n {pageIndex}\n </DSTypography>\n / {pageCount}\n {isLoadingPageCount && <DSCircularIndeterminateIndicator ml=\"xxxs\" mr=\"xxxs\" size=\"xs\" />}\n {pageDetails.length !== 0 && (\n <>\n <DSPaginationSeparator height=\"12px\" ml=\"12px\" mr=\"xxxs\" />\n <DSTypography\n fontSize=\"13px\"\n w={detailWidth}\n mr=\"xxs\"\n variant=\"b1\"\n as=\"span\"\n fontWeight=\"semibold\"\n textAlign=\"start\"\n >\n {pageDetails[pageIndex - 1]}\n </DSTypography>\n </>\n )}\n <ChevronDown ml=\"xxxs\" color={['brand-primary', '700']} />\n </Grid>\n </PaginationDropdownButton>\n {/* We calculate the length of the longest detail here (this is as per specs) */}\n <Grid style={{ position: 'relative' }}>\n {pageDetails.map((pageDetail) => (\n <InvisibleDiv data-testid=\"ds-pagination-invisible-detail-for-width-calc\" key={pageDetail}>\n <DSTypography fontSize=\"13px\" mr=\"xxs\" variant=\"b1\" as=\"span\" fontWeight=\"semibold\" textAlign=\"start\">\n {pageDetail}\n </DSTypography>\n </InvisibleDiv>\n ))}\n </Grid>\n </DSDropdownMenuV2>\n );\n};\n\nDSPaginator.displayName = PaginatorName;\nexport const DSPaginatorWithSchema = describe(DSPaginator).description('Per Page Selector');\nDSPaginatorWithSchema.propTypes = DSPaginatorPropTypesSchema;\n"],
5
- "mappings": "AAAA,YAAY,WAAW;ACuFb,SAME,UANF,KAME,YANF;AAtFV,SAAgB,eAAe;AAE/B,SAAS,mBAAmB;AAC5B,SAAS,UAAU,8BAA8B,sCAAsC;AACvF,SAAS,YAAY;AACrB,SAAS,wBAAwB;AACjC,SAAS,oBAAoB;AAC7B,SAAS,wCAAwC;AAEjD,SAAS,cAAc,0BAA0B,6BAA6B;AAC9E,SAAS,uBAAuB,kCAAkC;AAClE,SAAS,qBAAqB;AAC9B,SAAS,oBAAoB;AAC7B,SAAS,6BAA6B;AACtC,SAAS,8BAA8B;AAGhC,MAAM,cAAiE,CAAC,UAAU;AACvF,QAAM,mBAAmB;AAAA,IACvB;AAAA,IACA;AAAA,EACF;AACA,iCAA+B,kBAAkB,4BAA4B,aAAa;AAE1F,QAAM,EAAE,WAAW,WAAW,oBAAoB,cAAc,aAAa,iBAAiB,IAAI;AAElG,QAAM;AAAA,IACJ;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF,IAAI,aAAa,gBAAgB;AAEjC,QAAM,SAAS;AAAA,IACb,MAAM,sBAAsB,EAAE,kBAAkB,cAAc,CAAC;AAAA,IAC/D,CAAC,kBAAkB,aAAa;AAAA,EAClC;AAEA,QAAM,gBAA4C,QAAQ,MAAM;AAC9D,QAAI,iBAAiB,QAAS,QAAO,iBAAiB;AACtD,WAAO,MAAM,YAAY,CAAC,SAAS,CAAC,IAAI;AAAA,EAC1C,GAAG,CAAC,iBAAiB,SAAS,WAAW,CAAC;AAE1C,SACE;AAAA,IAAC;AAAA;AAAA,MACC;AAAA,MACA;AAAA,MACA,iBAAiB,EAAE,CAAC,UAAU,SAAS,CAAC,GAAG,KAAK;AAAA,MAChD,eAAe,CAAC,GAAG,kBAAkB;AACnC,qBAAc,cAAoD,KAAe;AACjF,oBAAY,KAAK;AACjB,eAAO,SAAS,MAAM;AAAA,MACxB;AAAA,MACA,gBAAgB,MAAM;AACpB,oBAAY,KAAK;AACjB,eAAO,SAAS,MAAM;AAAA,MACxB;AAAA,MACA,cAAc,CAAC,KAAK,CAAC;AAAA,MACrB,0BAAyB;AAAA,MACzB;AAAA,MACA;AAAA,MACA,UAAU,YAAY,WAAW,IAAI,WAAW,KAAK,UAAU,SAAS,EAAE,SAAS,IAAI;AAAA,MACvF,WAAW;AAAA,MACX,YAAY;AAAA,MAEZ;AAAA;AAAA,UAAC;AAAA;AAAA,YACC,YAAW;AAAA,YACX,UAAU;AAAA,YACV,UAAU;AAAA,YACV,gBAAc;AAAA,YACd,cAAY,QAAQ,SAAS,WAAW,SAAS,KAC/C,YAAY,WAAW,IAAI,YAAY,YAAY,CAAC,IAAI,MAC1D;AAAA,YACA,eAAa,uBAAuB;AAAA,YACnC,GAAG;AAAA,YACH,GAAG;AAAA,YACJ,SAAS;AAAA,YAET,+BAAC,QAAK,QAAO,QAAO,YAAW,UAAS,OAAO,EAAE,cAAc,SAAS,GACtE;AAAA,kCAAC,gBAAa,UAAS,QAAO,SAAQ,MAAK,IAAG,QAAO,YAAW,YAAW,WAAU,SAClF,qBACH;AAAA,cAAe;AAAA,cACZ;AAAA,cACF,sBAAsB,oBAAC,oCAAiC,IAAG,QAAO,IAAG,QAAO,MAAK,MAAK;AAAA,cACtF,YAAY,WAAW,KACtB,iCACE;AAAA,oCAAC,yBAAsB,QAAO,QAAO,IAAG,QAAO,IAAG,QAAO;AAAA,gBACzD;AAAA,kBAAC;AAAA;AAAA,oBACC,UAAS;AAAA,oBACT,GAAG;AAAA,oBACH,IAAG;AAAA,oBACH,SAAQ;AAAA,oBACR,IAAG;AAAA,oBACH,YAAW;AAAA,oBACX,WAAU;AAAA,oBAET,sBAAY,YAAY,CAAC;AAAA;AAAA,gBAC5B;AAAA,iBACF;AAAA,cAEF,oBAAC,eAAY,IAAG,QAAO,OAAO,CAAC,iBAAiB,KAAK,GAAG;AAAA,eAC1D;AAAA;AAAA,QACF;AAAA,QAEA,oBAAC,QAAK,OAAO,EAAE,UAAU,WAAW,GACjC,sBAAY,IAAI,CAAC,eAChB,oBAAC,gBAAa,eAAY,iDACxB,8BAAC,gBAAa,UAAS,QAAO,IAAG,OAAM,SAAQ,MAAK,IAAG,QAAO,YAAW,YAAW,WAAU,SAC3F,sBACH,KAH6E,UAI/E,CACD,GACH;AAAA;AAAA;AAAA,EACF;AAEJ;AAEA,YAAY,cAAc;AACnB,MAAM,wBAAwB,SAAS,WAAW,EAAE,YAAY,mBAAmB;AAC1F,sBAAsB,YAAY;",
3
+ "sources": ["../../../../../../../scripts/build/transpile/react-shim.js", "../../../../src/parts/DSPaginator/index.ts"],
4
+ "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "export { DSPaginator, DSPaginatorWithSchema } from './DSPaginator.js';\nexport { DSPaginatorName, PAGINATOR_DATA_TESTID, PAGINATOR_SLOTS } from './constants/index.js';\nexport type { DSPaginatorT } from './react-desc-prop-types.js';\n"],
5
+ "mappings": "AAAA,YAAY,WAAW;ACAvB,SAAS,aAAa,6BAA6B;AACnD,SAAS,iBAAiB,uBAAuB,uBAAuB;",
6
6
  "names": []
7
7
  }
@@ -0,0 +1,34 @@
1
+ import * as React from "react";
2
+ import {
3
+ PropTypes,
4
+ getPropsPerSlotPropTypes,
5
+ globalAttributesPropTypes,
6
+ xstyledPropTypes
7
+ } from "@elliemae/ds-props-helpers";
8
+ import { DSPaginationName, PAGINATOR_SLOTS } from "./constants/index.js";
9
+ const defaultProps = {
10
+ pageCount: 0,
11
+ isLoadingPageCount: false,
12
+ pageIndex: 1,
13
+ onPageChange: () => null,
14
+ pageDetails: [],
15
+ pageDetailsTitle: ""
16
+ };
17
+ const DSPaginatorPropTypes = {
18
+ ...getPropsPerSlotPropTypes(DSPaginationName, PAGINATOR_SLOTS),
19
+ ...globalAttributesPropTypes,
20
+ ...xstyledPropTypes,
21
+ pageIndex: PropTypes.number.description("Index of the current page, starting from 1").defaultValue(1),
22
+ pageCount: PropTypes.oneOfType([PropTypes.string, PropTypes.number]).description("How many pages are there"),
23
+ onPageChange: PropTypes.func.description("Function invoked when the page changes").defaultValue(() => null),
24
+ isLoadingPageCount: PropTypes.bool.description("Whether the page count is loading or not").defaultValue(false),
25
+ pageDetails: PropTypes.arrayOf(PropTypes.string).description("Details to provide for each page").defaultValue([]),
26
+ pageDetailsTitle: PropTypes.string.description("The title of the details (usually a column of your dataset)").defaultValue("")
27
+ };
28
+ const DSPaginatorPropTypesSchema = DSPaginatorPropTypes;
29
+ export {
30
+ DSPaginatorPropTypes,
31
+ DSPaginatorPropTypesSchema,
32
+ defaultProps
33
+ };
34
+ //# sourceMappingURL=react-desc-prop-types.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../../../scripts/build/transpile/react-shim.js", "../../../../src/parts/DSPaginator/react-desc-prop-types.ts"],
4
+ "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "/* eslint-disable @typescript-eslint/no-empty-interface */\n\nimport type { DSPropTypesSchema, GlobalAttributesT, ValidationMap, XstyledProps } from '@elliemae/ds-props-helpers';\nimport {\n PropTypes,\n getPropsPerSlotPropTypes,\n globalAttributesPropTypes,\n xstyledPropTypes,\n} from '@elliemae/ds-props-helpers';\nimport { type TypescriptHelpersT } from '@elliemae/ds-typescript-helpers';\nimport { DSPaginationName, PAGINATOR_SLOTS } from './constants/index.js';\n\nexport declare namespace DSPaginatorT {\n export type SlotFunctionArguments = {\n dsPaginationPaginator: () => object;\n };\n export interface RequiredProps {}\n\n export interface DefaultProps {\n pageCount: number | string;\n isLoadingPageCount: boolean;\n pageIndex: number;\n onPageChange: (page: number) => void;\n pageDetails: string[] | readonly string[];\n pageDetailsTitle: string;\n }\n\n export interface OptionalProps\n extends TypescriptHelpersT.PropsForGlobalOnSlots<typeof DSPaginationName, typeof PAGINATOR_SLOTS> {}\n export interface Props\n extends Partial<DefaultProps>,\n OptionalProps,\n Omit<GlobalAttributesT<HTMLElement>, keyof DefaultProps | keyof XstyledProps>,\n XstyledProps,\n RequiredProps {}\n\n export interface InternalProps\n extends DefaultProps,\n OptionalProps,\n Omit<GlobalAttributesT<HTMLElement>, keyof DefaultProps | keyof XstyledProps>,\n XstyledProps,\n RequiredProps {}\n}\n\nexport const defaultProps: DSPaginatorT.DefaultProps = {\n pageCount: 0,\n isLoadingPageCount: false,\n pageIndex: 1,\n onPageChange: () => null,\n pageDetails: [],\n pageDetailsTitle: '',\n};\n\nexport const DSPaginatorPropTypes: DSPropTypesSchema<DSPaginatorT.Props> = {\n ...getPropsPerSlotPropTypes(DSPaginationName, PAGINATOR_SLOTS),\n ...globalAttributesPropTypes,\n ...xstyledPropTypes,\n pageIndex: PropTypes.number.description('Index of the current page, starting from 1').defaultValue(1),\n pageCount: PropTypes.oneOfType([PropTypes.string, PropTypes.number]).description('How many pages are there'),\n onPageChange: PropTypes.func.description('Function invoked when the page changes').defaultValue(() => null),\n isLoadingPageCount: PropTypes.bool.description('Whether the page count is loading or not').defaultValue(false),\n pageDetails: PropTypes.arrayOf(PropTypes.string).description('Details to provide for each page').defaultValue([]),\n pageDetailsTitle: PropTypes.string\n .description('The title of the details (usually a column of your dataset)')\n .defaultValue(''),\n};\n\nexport const DSPaginatorPropTypesSchema = DSPaginatorPropTypes as unknown as ValidationMap<DSPaginatorT.Props>;\n"],
5
+ "mappings": "AAAA,YAAY,WAAW;ACGvB;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AAEP,SAAS,kBAAkB,uBAAuB;AAkC3C,MAAM,eAA0C;AAAA,EACrD,WAAW;AAAA,EACX,oBAAoB;AAAA,EACpB,WAAW;AAAA,EACX,cAAc,MAAM;AAAA,EACpB,aAAa,CAAC;AAAA,EACd,kBAAkB;AACpB;AAEO,MAAM,uBAA8D;AAAA,EACzE,GAAG,yBAAyB,kBAAkB,eAAe;AAAA,EAC7D,GAAG;AAAA,EACH,GAAG;AAAA,EACH,WAAW,UAAU,OAAO,YAAY,4CAA4C,EAAE,aAAa,CAAC;AAAA,EACpG,WAAW,UAAU,UAAU,CAAC,UAAU,QAAQ,UAAU,MAAM,CAAC,EAAE,YAAY,0BAA0B;AAAA,EAC3G,cAAc,UAAU,KAAK,YAAY,wCAAwC,EAAE,aAAa,MAAM,IAAI;AAAA,EAC1G,oBAAoB,UAAU,KAAK,YAAY,0CAA0C,EAAE,aAAa,KAAK;AAAA,EAC7G,aAAa,UAAU,QAAQ,UAAU,MAAM,EAAE,YAAY,kCAAkC,EAAE,aAAa,CAAC,CAAC;AAAA,EAChH,kBAAkB,UAAU,OACzB,YAAY,6DAA6D,EACzE,aAAa,EAAE;AACpB;AAEO,MAAM,6BAA6B;",
6
+ "names": []
7
+ }
@@ -0,0 +1,60 @@
1
+ import * as React from "react";
2
+ import { DSButtonV3 } from "@elliemae/ds-button-v2";
3
+ import { css, styled } from "@elliemae/ds-system";
4
+ import { DSPaginationName, PAGINATOR_SLOTS } from "./constants/index.js";
5
+ const styledFocusCss = css`
6
+ &:after {
7
+ display: block;
8
+ content: ' ';
9
+ position: absolute;
10
+ top: 0;
11
+ left: 0;
12
+ right: 0;
13
+ bottom: 0;
14
+ border: 2px solid ${({ theme }) => theme.colors.brand[700]};
15
+ pointer-events: none;
16
+ z-index: 7;
17
+ }
18
+ `;
19
+ const InvisibleDiv = styled.div`
20
+ opacity: 0;
21
+ white-space: nowrap;
22
+ overflow: hidden;
23
+ text-overflow: ellipsis;
24
+ position: absolute;
25
+ `;
26
+ const paginationDropdownButtonCommonStyles = css`
27
+ height: 42px;
28
+ display: grid;
29
+ grid-auto-flow: column;
30
+ justify-content: center;
31
+ align-items: center;
32
+ position: relative;
33
+ padding-left: 16px;
34
+ padding-right: 16px;
35
+ grid-gap: 8px;
36
+ font-size: 13px;
37
+ color: neutral-700;
38
+ cursor: pointer;
39
+ border-radius: 0;
40
+ font-weight: ${(props) => props.theme.fontWeights.regular};
41
+ :focus {
42
+ ${styledFocusCss}
43
+ }
44
+ &[aria-disabled='true'] {
45
+ cursor: not-allowed;
46
+ }
47
+ white-space: nowrap;
48
+ `;
49
+ const PaginationDropdownButtonPaginator = styled(DSButtonV3, {
50
+ name: DSPaginationName,
51
+ slot: PAGINATOR_SLOTS.PAGINATOR,
52
+ preserveLegacyDataTestId: true
53
+ })`
54
+ ${paginationDropdownButtonCommonStyles}
55
+ `;
56
+ export {
57
+ InvisibleDiv,
58
+ PaginationDropdownButtonPaginator
59
+ };
60
+ //# sourceMappingURL=styled.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../../../scripts/build/transpile/react-shim.js", "../../../../src/parts/DSPaginator/styled.tsx"],
4
+ "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "import { DSButtonV3 } from '@elliemae/ds-button-v2';\n\nimport { css, styled } from '@elliemae/ds-system';\nimport type {} from '@xstyled/system';\nimport { DSPaginationName, PAGINATOR_SLOTS } from './constants/index.js';\n\nconst styledFocusCss = css`\n &:after {\n display: block;\n content: ' ';\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n border: 2px solid ${({ theme }) => theme.colors.brand[700]};\n pointer-events: none;\n z-index: 7;\n }\n`;\n\nexport const InvisibleDiv = styled.div`\n opacity: 0;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n position: absolute;\n`;\n\nconst paginationDropdownButtonCommonStyles = css`\n height: 42px;\n display: grid;\n grid-auto-flow: column;\n justify-content: center;\n align-items: center;\n position: relative;\n padding-left: 16px;\n padding-right: 16px;\n grid-gap: 8px;\n font-size: 13px;\n color: neutral-700;\n cursor: pointer;\n border-radius: 0;\n font-weight: ${(props) => props.theme.fontWeights.regular};\n :focus {\n ${styledFocusCss}\n }\n &[aria-disabled='true'] {\n cursor: not-allowed;\n }\n white-space: nowrap;\n`;\nexport const PaginationDropdownButtonPaginator = styled(DSButtonV3, {\n name: DSPaginationName,\n slot: PAGINATOR_SLOTS.PAGINATOR,\n preserveLegacyDataTestId: true,\n})`\n ${paginationDropdownButtonCommonStyles}\n`;\n"],
5
+ "mappings": "AAAA,YAAY,WAAW;ACAvB,SAAS,kBAAkB;AAE3B,SAAS,KAAK,cAAc;AAE5B,SAAS,kBAAkB,uBAAuB;AAElD,MAAM,iBAAiB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,wBASC,CAAC,EAAE,MAAM,MAAM,MAAM,OAAO,MAAM,GAAG,CAAC;AAAA;AAAA;AAAA;AAAA;AAMvD,MAAM,eAAe,OAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAQnC,MAAM,uCAAuC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,iBAc5B,CAAC,UAAU,MAAM,MAAM,YAAY,OAAO;AAAA;AAAA,MAErD,cAAc;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAOb,MAAM,oCAAoC,OAAO,YAAY;AAAA,EAClE,MAAM;AAAA,EACN,MAAM,gBAAgB;AAAA,EACtB,0BAA0B;AAC5B,CAAC;AAAA,IACG,oCAAoC;AAAA;",
6
+ "names": []
7
+ }
@@ -0,0 +1,9 @@
1
+ import * as React from "react";
2
+ const SlotPropsAsObj = {
3
+ dsPaginationPaginator: { "aria-label": "just a typescript test" }
4
+ };
5
+ const SlotPropsAsFunctions = {
6
+ dsPaginationPaginator: () => ({ "aria-label": "just a typescript test" })
7
+ };
8
+ const EnsureAllSlotsExistInSlotFunctionArguments = SlotPropsAsFunctions;
9
+ //# sourceMappingURL=slot-props.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../../../../scripts/build/transpile/react-shim.js", "../../../../../src/parts/DSPaginator/typescript-testing/slot-props.ts"],
4
+ "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "/* eslint-disable @typescript-eslint/no-unused-vars, no-unused-vars */\n\nimport type { TypescriptHelpersT } from '@elliemae/ds-typescript-helpers';\nimport type { DSPaginationName, PAGINATOR_SLOTS } from '../constants/index.js';\nimport type { DSPaginatorT } from '../react-desc-prop-types.js';\n\nconst SlotPropsAsObj: Partial<DSPaginatorT.Props> = {\n dsPaginationPaginator: { 'aria-label': 'just a typescript test' },\n};\nconst SlotPropsAsFunctions: DSPaginatorT.SlotFunctionArguments = {\n dsPaginationPaginator: () => ({ 'aria-label': 'just a typescript test' }),\n};\nconst EnsureAllSlotsExistInSlotFunctionArguments: Required<\n TypescriptHelpersT.PropsForSlots<typeof DSPaginationName, typeof PAGINATOR_SLOTS>\n> = SlotPropsAsFunctions;\n"],
5
+ "mappings": "AAAA,YAAY,WAAW;ACMvB,MAAM,iBAA8C;AAAA,EAClD,uBAAuB,EAAE,cAAc,yBAAyB;AAClE;AACA,MAAM,uBAA2D;AAAA,EAC/D,uBAAuB,OAAO,EAAE,cAAc,yBAAyB;AACzE;AACA,MAAM,6CAEF;",
6
+ "names": []
7
+ }
@@ -76,4 +76,4 @@ const ExampleUsageComponent = () => /* @__PURE__ */ jsxs(Fragment, { children: [
76
76
  }
77
77
  )
78
78
  ] });
79
- //# sourceMappingURL=typescript-paginator-valid.js.map
79
+ //# sourceMappingURL=typescript-testing.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../../../../scripts/build/transpile/react-shim.js", "../../../../../src/parts/DSPaginator/typescript-testing/typescript-testing.tsx"],
4
+ "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "/* eslint-disable @typescript-eslint/no-unused-vars, no-unused-vars */\nimport { DSPaginator } from '../index.js';\nimport type { DSPaginatorT } from '../index.js';\n\n// test we expose the namespace and the namespace follows our deliverable conventions\ntype ComponentPropsForApp = DSPaginatorT.Props;\ntype ComponentPropsInternals = DSPaginatorT.InternalProps;\ntype ComponentPropsDefaultProps = DSPaginatorT.DefaultProps;\ntype ComponentPropsOptionalProps = DSPaginatorT.OptionalProps;\ntype ComponentPropsRequiredProps = DSPaginatorT.RequiredProps;\n\nconst testRequiredProps: ComponentPropsRequiredProps = {};\n\nconst testOptionalProps: ComponentPropsOptionalProps = {};\n\n// difference Props and InternalProps is that InternalProps has all the default props filled in\n// Props allows for partial defaults\nconst testPartialDefaults: Partial<ComponentPropsDefaultProps> = {\n pageCount: 0,\n isLoadingPageCount: false,\n onPageChange: () => null,\n};\n\nconst testProps: ComponentPropsForApp = {\n ...testRequiredProps,\n ...testOptionalProps,\n ...testPartialDefaults,\n};\n\nconst testPropsAsSyntax = {\n ...testRequiredProps,\n ...testOptionalProps,\n ...testPartialDefaults,\n} as ComponentPropsForApp;\n\n// InternalProps requires all defaults to be filled in\nconst testCompleteDefaults: Required<ComponentPropsDefaultProps> = {\n pageCount: 0,\n isLoadingPageCount: false,\n pageIndex: 1,\n onPageChange: () => null,\n pageDetails: [],\n pageDetailsTitle: '',\n};\n\nconst testInternalProps: ComponentPropsInternals = {\n ...testRequiredProps,\n ...testOptionalProps,\n ...testCompleteDefaults,\n};\n\nconst testInternalPropsAsSyntax = {\n ...testRequiredProps,\n ...testOptionalProps,\n ...testCompleteDefaults,\n} as ComponentPropsInternals;\n\n// using the explicit type definition, if there is an error, it will be marked on the key that is wrong\nconst testExplicitDefinition: ComponentPropsForApp = {\n pageCount: 0,\n isLoadingPageCount: false,\n pageIndex: 1,\n onPageChange: () => null,\n pageDetails: [],\n pageDetailsTitle: '',\n};\n\n// using the \"as\" syntax, if there is an error, it will be marking the whole object as wrong because it is not compatible with the type\nconst testInferedTypeCompatibility = {\n pageCount: 0,\n isLoadingPageCount: false,\n pageIndex: 1,\n onPageChange: () => null,\n pageDetails: [],\n pageDetailsTitle: '',\n} as ComponentPropsForApp;\n\nconst testDefinitionAsConst = {\n pageCount: 0,\n isLoadingPageCount: false,\n pageIndex: 1,\n onPageChange: () => null,\n pageDetails: [],\n pageDetailsTitle: '',\n} as const;\n\nconst ExampleUsageComponent = () => (\n <>\n {/* works with explicitly casted props, all syntaxes */}\n <DSPaginator {...testExplicitDefinition} />\n <DSPaginator {...testInferedTypeCompatibility} />\n <DSPaginator {...testDefinitionAsConst} />\n {/* works with inline values */}\n <DSPaginator\n pageCount={0}\n isLoadingPageCount={false}\n pageIndex={1}\n onPageChange={() => null}\n pageDetails={[]}\n pageDetailsTitle=\"\"\n />\n </>\n);\n"],
5
+ "mappings": "AAAA,YAAY,WAAW;ACuFrB,mBAEE,KAFF;AAtFF,SAAS,mBAAmB;AAU5B,MAAM,oBAAiD,CAAC;AAExD,MAAM,oBAAiD,CAAC;AAIxD,MAAM,sBAA2D;AAAA,EAC/D,WAAW;AAAA,EACX,oBAAoB;AAAA,EACpB,cAAc,MAAM;AACtB;AAEA,MAAM,YAAkC;AAAA,EACtC,GAAG;AAAA,EACH,GAAG;AAAA,EACH,GAAG;AACL;AAEA,MAAM,oBAAoB;AAAA,EACxB,GAAG;AAAA,EACH,GAAG;AAAA,EACH,GAAG;AACL;AAGA,MAAM,uBAA6D;AAAA,EACjE,WAAW;AAAA,EACX,oBAAoB;AAAA,EACpB,WAAW;AAAA,EACX,cAAc,MAAM;AAAA,EACpB,aAAa,CAAC;AAAA,EACd,kBAAkB;AACpB;AAEA,MAAM,oBAA6C;AAAA,EACjD,GAAG;AAAA,EACH,GAAG;AAAA,EACH,GAAG;AACL;AAEA,MAAM,4BAA4B;AAAA,EAChC,GAAG;AAAA,EACH,GAAG;AAAA,EACH,GAAG;AACL;AAGA,MAAM,yBAA+C;AAAA,EACnD,WAAW;AAAA,EACX,oBAAoB;AAAA,EACpB,WAAW;AAAA,EACX,cAAc,MAAM;AAAA,EACpB,aAAa,CAAC;AAAA,EACd,kBAAkB;AACpB;AAGA,MAAM,+BAA+B;AAAA,EACnC,WAAW;AAAA,EACX,oBAAoB;AAAA,EACpB,WAAW;AAAA,EACX,cAAc,MAAM;AAAA,EACpB,aAAa,CAAC;AAAA,EACd,kBAAkB;AACpB;AAEA,MAAM,wBAAwB;AAAA,EAC5B,WAAW;AAAA,EACX,oBAAoB;AAAA,EACpB,WAAW;AAAA,EACX,cAAc,MAAM;AAAA,EACpB,aAAa,CAAC;AAAA,EACd,kBAAkB;AACpB;AAEA,MAAM,wBAAwB,MAC5B,iCAEE;AAAA,sBAAC,eAAa,GAAG,wBAAwB;AAAA,EACzC,oBAAC,eAAa,GAAG,8BAA8B;AAAA,EAC/C,oBAAC,eAAa,GAAG,uBAAuB;AAAA,EAExC;AAAA,IAAC;AAAA;AAAA,MACC,WAAW;AAAA,MACX,oBAAoB;AAAA,MACpB,WAAW;AAAA,MACX,cAAc,MAAM;AAAA,MACpB,aAAa,CAAC;AAAA,MACd,kBAAiB;AAAA;AAAA,EACnB;AAAA,GACF;",
6
+ "names": []
7
+ }
@@ -0,0 +1,79 @@
1
+ import * as React from "react";
2
+ import { Fragment, jsx, jsxs } from "react/jsx-runtime";
3
+ import { useMemo } from "react";
4
+ import { DSDropdownMenuV2 } from "@elliemae/ds-dropdownmenu-v2";
5
+ import { ChevronDown } from "@elliemae/ds-icons";
6
+ import { describe } from "@elliemae/ds-props-helpers";
7
+ import { usePerPageSelector } from "./config/usePerPageSelector.js";
8
+ import { DSPerPageSelectorName, PER_PAGE_SELECTOR_DATA_TESTID } from "./constants/index.js";
9
+ import { DSPerPageSelectorPropTypesSchema } from "./react-desc-prop-types.js";
10
+ import { PaginationDropdownButtonPerPageSelector } from "./styled.js";
11
+ const Header = () => /* @__PURE__ */ jsx(Fragment, { children: "Per Page" });
12
+ const DSPerPageSelector = (props) => {
13
+ const {
14
+ propsWithDefault: { pageSize, onPageSizeChange },
15
+ xstyledProps,
16
+ globalAttributes,
17
+ ownerPropsConfig,
18
+ actionRef,
19
+ btnRef,
20
+ width,
21
+ isOpened,
22
+ options,
23
+ setIsOpened
24
+ } = usePerPageSelector(props);
25
+ const buttonOnClick = useMemo(() => {
26
+ if (globalAttributes.onClick) return globalAttributes.onClick;
27
+ return () => setIsOpened((prev) => !prev);
28
+ }, [globalAttributes.onClick, setIsOpened]);
29
+ return /* @__PURE__ */ jsx(
30
+ DSDropdownMenuV2,
31
+ {
32
+ isOpened,
33
+ options,
34
+ selectedOptions: { [pageSize.toString()]: true },
35
+ onOptionClick: (_, clickedOption) => {
36
+ onPageSizeChange(clickedOption.value);
37
+ setIsOpened(false);
38
+ btnRef.current?.focus();
39
+ },
40
+ onClickOutside: () => {
41
+ setIsOpened(false);
42
+ btnRef.current?.focus();
43
+ },
44
+ customOffset: [-23, 2],
45
+ startPlacementPreference: "top-start",
46
+ actionRef,
47
+ minWidth: width,
48
+ maxHeight: 300,
49
+ HeaderComp: Header,
50
+ children: /* @__PURE__ */ jsxs(
51
+ PaginationDropdownButtonPerPageSelector,
52
+ {
53
+ buttonType: "raw",
54
+ innerRef: btnRef,
55
+ "aria-pressed": isOpened,
56
+ "aria-label": `${pageSize} rows per page. Press to select rows per page`,
57
+ "data-testid": PER_PAGE_SELECTOR_DATA_TESTID.PER_PAGE_SELECTOR,
58
+ ...globalAttributes,
59
+ ...xstyledProps,
60
+ ...ownerPropsConfig,
61
+ onClick: buttonOnClick,
62
+ children: [
63
+ pageSize,
64
+ " / page",
65
+ /* @__PURE__ */ jsx(ChevronDown, { color: ["brand-primary", "700"] })
66
+ ]
67
+ }
68
+ )
69
+ }
70
+ );
71
+ };
72
+ DSPerPageSelector.displayName = DSPerPageSelectorName;
73
+ const DSPerPageSelectorWithSchema = describe(DSPerPageSelector);
74
+ DSPerPageSelectorWithSchema.propTypes = DSPerPageSelectorPropTypesSchema;
75
+ export {
76
+ DSPerPageSelector,
77
+ DSPerPageSelectorWithSchema
78
+ };
79
+ //# sourceMappingURL=DSPerPageSelector.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../../../scripts/build/transpile/react-shim.js", "../../../../src/parts/DSPerPageSelector/DSPerPageSelector.tsx"],
4
+ "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "import React, { useMemo } from 'react';\nimport type { DSButtonT } from '@elliemae/ds-button-v2';\nimport { DSDropdownMenuV2, type DSDropdownMenuT } from '@elliemae/ds-dropdownmenu-v2';\nimport { ChevronDown } from '@elliemae/ds-icons';\nimport { describe } from '@elliemae/ds-props-helpers';\nimport { usePerPageSelector } from './config/usePerPageSelector.js';\nimport { DSPerPageSelectorName, PER_PAGE_SELECTOR_DATA_TESTID } from './constants/index.js';\nimport { DSPerPageSelectorPropTypesSchema, type DSPerPageSelectorT } from './react-desc-prop-types.js';\nimport { PaginationDropdownButtonPerPageSelector } from './styled.js';\n\nconst Header = () => <>Per Page</>;\n\nconst DSPerPageSelector: React.ComponentType<DSPerPageSelectorT.Props> = (props) => {\n const {\n propsWithDefault: { pageSize, onPageSizeChange },\n xstyledProps,\n globalAttributes,\n ownerPropsConfig,\n actionRef,\n btnRef,\n width,\n isOpened,\n options,\n setIsOpened,\n } = usePerPageSelector(props);\n const buttonOnClick: DSButtonT.Props['onClick'] = useMemo(() => {\n if (globalAttributes.onClick) return globalAttributes.onClick as DSButtonT.Props['onClick'];\n return () => setIsOpened((prev) => !prev);\n }, [globalAttributes.onClick, setIsOpened]);\n return (\n <DSDropdownMenuV2\n isOpened={isOpened}\n options={options}\n selectedOptions={{ [pageSize.toString()]: true }}\n onOptionClick={(_, clickedOption) => {\n onPageSizeChange((clickedOption as DSDropdownMenuT.ItemSingleOptions).value as number);\n setIsOpened(false);\n btnRef.current?.focus();\n }}\n onClickOutside={() => {\n setIsOpened(false);\n btnRef.current?.focus();\n }}\n customOffset={[-23, 2]}\n startPlacementPreference=\"top-start\"\n actionRef={actionRef}\n minWidth={width}\n maxHeight={300}\n HeaderComp={Header}\n >\n <PaginationDropdownButtonPerPageSelector\n buttonType=\"raw\"\n innerRef={btnRef}\n aria-pressed={isOpened}\n aria-label={`${pageSize} rows per page. Press to select rows per page`}\n data-testid={PER_PAGE_SELECTOR_DATA_TESTID.PER_PAGE_SELECTOR}\n {...globalAttributes}\n {...xstyledProps}\n {...ownerPropsConfig}\n onClick={buttonOnClick}\n >\n {pageSize} / page\n <ChevronDown color={['brand-primary', '700']} />\n </PaginationDropdownButtonPerPageSelector>\n </DSDropdownMenuV2>\n );\n};\n\nDSPerPageSelector.displayName = DSPerPageSelectorName;\nconst DSPerPageSelectorWithSchema = describe(DSPerPageSelector);\nDSPerPageSelectorWithSchema.propTypes = DSPerPageSelectorPropTypesSchema;\n\nexport { DSPerPageSelector, DSPerPageSelectorWithSchema };\n"],
5
+ "mappings": "AAAA,YAAY,WAAW;ACUF,wBAwCf,YAxCe;AAVrB,SAAgB,eAAe;AAE/B,SAAS,wBAA8C;AACvD,SAAS,mBAAmB;AAC5B,SAAS,gBAAgB;AACzB,SAAS,0BAA0B;AACnC,SAAS,uBAAuB,qCAAqC;AACrE,SAAS,wCAAiE;AAC1E,SAAS,+CAA+C;AAExD,MAAM,SAAS,MAAM,gCAAE,sBAAQ;AAE/B,MAAM,oBAAmE,CAAC,UAAU;AAClF,QAAM;AAAA,IACJ,kBAAkB,EAAE,UAAU,iBAAiB;AAAA,IAC/C;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF,IAAI,mBAAmB,KAAK;AAC5B,QAAM,gBAA4C,QAAQ,MAAM;AAC9D,QAAI,iBAAiB,QAAS,QAAO,iBAAiB;AACtD,WAAO,MAAM,YAAY,CAAC,SAAS,CAAC,IAAI;AAAA,EAC1C,GAAG,CAAC,iBAAiB,SAAS,WAAW,CAAC;AAC1C,SACE;AAAA,IAAC;AAAA;AAAA,MACC;AAAA,MACA;AAAA,MACA,iBAAiB,EAAE,CAAC,SAAS,SAAS,CAAC,GAAG,KAAK;AAAA,MAC/C,eAAe,CAAC,GAAG,kBAAkB;AACnC,yBAAkB,cAAoD,KAAe;AACrF,oBAAY,KAAK;AACjB,eAAO,SAAS,MAAM;AAAA,MACxB;AAAA,MACA,gBAAgB,MAAM;AACpB,oBAAY,KAAK;AACjB,eAAO,SAAS,MAAM;AAAA,MACxB;AAAA,MACA,cAAc,CAAC,KAAK,CAAC;AAAA,MACrB,0BAAyB;AAAA,MACzB;AAAA,MACA,UAAU;AAAA,MACV,WAAW;AAAA,MACX,YAAY;AAAA,MAEZ;AAAA,QAAC;AAAA;AAAA,UACC,YAAW;AAAA,UACX,UAAU;AAAA,UACV,gBAAc;AAAA,UACd,cAAY,GAAG,QAAQ;AAAA,UACvB,eAAa,8BAA8B;AAAA,UAC1C,GAAG;AAAA,UACH,GAAG;AAAA,UACH,GAAG;AAAA,UACJ,SAAS;AAAA,UAER;AAAA;AAAA,YAAS;AAAA,YACV,oBAAC,eAAY,OAAO,CAAC,iBAAiB,KAAK,GAAG;AAAA;AAAA;AAAA,MAChD;AAAA;AAAA,EACF;AAEJ;AAEA,kBAAkB,cAAc;AAChC,MAAM,8BAA8B,SAAS,iBAAiB;AAC9D,4BAA4B,YAAY;",
6
+ "names": []
7
+ }
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "version": 3,
3
- "sources": ["../../../../../../../scripts/build/transpile/react-shim.js", "../../../../src/parts/DSPerPageSelector/getOptions.ts"],
3
+ "sources": ["../../../../../../../../scripts/build/transpile/react-shim.js", "../../../../../src/parts/DSPerPageSelector/config/getOptions.ts"],
4
4
  "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "import { range } from 'lodash-es';\nimport type { DSDropdownMenuT } from '@elliemae/ds-dropdownmenu-v2';\n\nexport const generateOption = (\n value: number | DSDropdownMenuT.ItemSingleOptions,\n): DSDropdownMenuT.ItemSingleOptions => {\n if (typeof value === 'object') {\n return value;\n }\n return {\n dsId: value.toString(),\n value,\n label: value.toString(),\n type: 'single',\n } as const;\n};\n\nexport const getOptions = (step: number, min: number, max: number) => {\n const options = range(min, max + step, step).map(generateOption);\n return min === 0 ? options.slice(1, options.length) : options;\n};\n"],
5
5
  "mappings": "AAAA,YAAY,WAAW;ACAvB,SAAS,aAAa;AAGf,MAAM,iBAAiB,CAC5B,UACsC;AACtC,MAAI,OAAO,UAAU,UAAU;AAC7B,WAAO;AAAA,EACT;AACA,SAAO;AAAA,IACL,MAAM,MAAM,SAAS;AAAA,IACrB;AAAA,IACA,OAAO,MAAM,SAAS;AAAA,IACtB,MAAM;AAAA,EACR;AACF;AAEO,MAAM,aAAa,CAAC,MAAc,KAAa,QAAgB;AACpE,QAAM,UAAU,MAAM,KAAK,MAAM,MAAM,IAAI,EAAE,IAAI,cAAc;AAC/D,SAAO,QAAQ,IAAI,QAAQ,MAAM,GAAG,QAAQ,MAAM,IAAI;AACxD;",
6
6
  "names": []
@@ -0,0 +1,55 @@
1
+ import * as React from "react";
2
+ import {
3
+ useGetGlobalAttributes,
4
+ useGetXstyledProps,
5
+ useMemoMergePropsWithDefault,
6
+ useOwnerProps
7
+ } from "@elliemae/ds-props-helpers";
8
+ import React2, { useEffect, useMemo, useRef, useState } from "react";
9
+ import { DSPerPageSelectorPropTypesSchema, defaultProps } from "../react-desc-prop-types.js";
10
+ import { useValidateProps } from "./useValidateProps.js";
11
+ import { generateOption, getOptions } from "./getOptions.js";
12
+ const usePerPageSelector = (propsFromUser) => {
13
+ const propsWithDefault = useMemoMergePropsWithDefault(propsFromUser, defaultProps);
14
+ useValidateProps(propsWithDefault, DSPerPageSelectorPropTypesSchema);
15
+ const xstyledProps = useGetXstyledProps(propsWithDefault);
16
+ const globalAttributes = useGetGlobalAttributes(propsWithDefault);
17
+ const ownerPropsConfig = useOwnerProps(propsWithDefault);
18
+ const { pageSize, perPageOptions, perPageStep, minPerPage, maxPerPage } = propsWithDefault;
19
+ const [isOpened, setIsOpened] = useState(false);
20
+ const options = useMemo(() => {
21
+ if (perPageOptions) return perPageOptions.map(generateOption);
22
+ return getOptions(perPageStep, minPerPage, maxPerPage);
23
+ }, [maxPerPage, minPerPage, perPageOptions, perPageStep]);
24
+ const actionRef = useRef({});
25
+ const btnRef = useRef(null);
26
+ const width = useMemo(() => {
27
+ const maxLength = options.reduce((acc, cur) => Math.max(acc, ("label" in cur ? cur.label : "").length), 0);
28
+ return maxLength * 6 + 90;
29
+ }, [options]);
30
+ useEffect(() => {
31
+ if (isOpened) {
32
+ actionRef.current.setActiveDescendant(pageSize.toString());
33
+ actionRef.current.scrollOptionIntoView(pageSize.toString());
34
+ }
35
+ }, [isOpened]);
36
+ return React2.useMemo(
37
+ () => ({
38
+ propsWithDefault,
39
+ xstyledProps,
40
+ globalAttributes,
41
+ ownerPropsConfig,
42
+ actionRef,
43
+ btnRef,
44
+ width,
45
+ isOpened,
46
+ options,
47
+ setIsOpened
48
+ }),
49
+ [propsWithDefault, xstyledProps, globalAttributes, ownerPropsConfig, width, isOpened, options]
50
+ );
51
+ };
52
+ export {
53
+ usePerPageSelector
54
+ };
55
+ //# sourceMappingURL=usePerPageSelector.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../../../../scripts/build/transpile/react-shim.js", "../../../../../src/parts/DSPerPageSelector/config/usePerPageSelector.ts"],
4
+ "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "import type { DSButtonV3T } from '@elliemae/ds-button-v2';\nimport {\n useGetGlobalAttributes,\n useGetXstyledProps,\n useMemoMergePropsWithDefault,\n useOwnerProps,\n} from '@elliemae/ds-props-helpers';\nimport React, { useEffect, useMemo, useRef, useState } from 'react';\n\nimport { type DSPerPageSelectorT, DSPerPageSelectorPropTypesSchema, defaultProps } from '../react-desc-prop-types.js';\nimport { useValidateProps } from './useValidateProps.js';\nimport { generateOption, getOptions } from './getOptions.js';\n\nexport const usePerPageSelector = (propsFromUser: DSPerPageSelectorT.Props) => {\n // =============================================================================\n // MERGE WITH DEFAULT AND VALIDATE PROPS\n // =============================================================================\n const propsWithDefault = useMemoMergePropsWithDefault<DSPerPageSelectorT.InternalProps>(propsFromUser, defaultProps);\n useValidateProps(propsWithDefault, DSPerPageSelectorPropTypesSchema);\n // =============================================================================\n // XSTYLED PROPS\n // =============================================================================\n const xstyledProps = useGetXstyledProps(propsWithDefault);\n // =============================================================================\n // GLOBAL ATTRIBUTES\n // =============================================================================\n const globalAttributes = useGetGlobalAttributes<\n DSPerPageSelectorT.InternalProps,\n HTMLButtonElement,\n DSButtonV3T.Props\n >(propsWithDefault);\n // =============================================================================\n // OWNER PROPS\n // =============================================================================\n const ownerPropsConfig = useOwnerProps(propsWithDefault);\n // AD HOC PER COMPONENT LOGIC\n // =============================================================================\n // custom code goes here, this is an example\n // const instanceUid = React.useMemo(() => `ds-per-page-selector-${uid(5)}`, []);\n\n const { pageSize, perPageOptions, perPageStep, minPerPage, maxPerPage } = propsWithDefault;\n const [isOpened, setIsOpened] = useState(false);\n const options = useMemo(() => {\n if (perPageOptions) return perPageOptions.map(generateOption);\n return getOptions(perPageStep, minPerPage, maxPerPage);\n }, [maxPerPage, minPerPage, perPageOptions, perPageStep]);\n\n const actionRef = useRef<Record<string, (dsId: string) => void>>({});\n const btnRef = useRef<HTMLButtonElement>(null);\n const width = useMemo(() => {\n const maxLength = options.reduce((acc, cur) => Math.max(acc, ('label' in cur ? cur.label : '').length), 0);\n return maxLength * 6 + 90;\n }, [options]);\n\n useEffect(() => {\n if (isOpened) {\n actionRef.current.setActiveDescendant(pageSize.toString());\n actionRef.current.scrollOptionIntoView(pageSize.toString());\n }\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [isOpened]);\n\n // =============================================================================\n // HELPERS HOOKS CONFIGS\n // =============================================================================\n // const eventHandlers = useEventHandlers({ propsWithDefault, instanceUid }); // <-- complex logic should be made atomics this way\n\n return React.useMemo(\n () => ({\n propsWithDefault,\n xstyledProps,\n globalAttributes,\n ownerPropsConfig,\n actionRef,\n btnRef,\n width,\n isOpened,\n options,\n setIsOpened,\n }),\n [propsWithDefault, xstyledProps, globalAttributes, ownerPropsConfig, width, isOpened, options],\n );\n};\n"],
5
+ "mappings": "AAAA,YAAY,WAAW;ACCvB;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,OAAOA,UAAS,WAAW,SAAS,QAAQ,gBAAgB;AAE5D,SAAkC,kCAAkC,oBAAoB;AACxF,SAAS,wBAAwB;AACjC,SAAS,gBAAgB,kBAAkB;AAEpC,MAAM,qBAAqB,CAAC,kBAA4C;AAI7E,QAAM,mBAAmB,6BAA+D,eAAe,YAAY;AACnH,mBAAiB,kBAAkB,gCAAgC;AAInE,QAAM,eAAe,mBAAmB,gBAAgB;AAIxD,QAAM,mBAAmB,uBAIvB,gBAAgB;AAIlB,QAAM,mBAAmB,cAAc,gBAAgB;AAMvD,QAAM,EAAE,UAAU,gBAAgB,aAAa,YAAY,WAAW,IAAI;AAC1E,QAAM,CAAC,UAAU,WAAW,IAAI,SAAS,KAAK;AAC9C,QAAM,UAAU,QAAQ,MAAM;AAC5B,QAAI,eAAgB,QAAO,eAAe,IAAI,cAAc;AAC5D,WAAO,WAAW,aAAa,YAAY,UAAU;AAAA,EACvD,GAAG,CAAC,YAAY,YAAY,gBAAgB,WAAW,CAAC;AAExD,QAAM,YAAY,OAA+C,CAAC,CAAC;AACnE,QAAM,SAAS,OAA0B,IAAI;AAC7C,QAAM,QAAQ,QAAQ,MAAM;AAC1B,UAAM,YAAY,QAAQ,OAAO,CAAC,KAAK,QAAQ,KAAK,IAAI,MAAM,WAAW,MAAM,IAAI,QAAQ,IAAI,MAAM,GAAG,CAAC;AACzG,WAAO,YAAY,IAAI;AAAA,EACzB,GAAG,CAAC,OAAO,CAAC;AAEZ,YAAU,MAAM;AACd,QAAI,UAAU;AACZ,gBAAU,QAAQ,oBAAoB,SAAS,SAAS,CAAC;AACzD,gBAAU,QAAQ,qBAAqB,SAAS,SAAS,CAAC;AAAA,IAC5D;AAAA,EAEF,GAAG,CAAC,QAAQ,CAAC;AAOb,SAAOA,OAAM;AAAA,IACX,OAAO;AAAA,MACL;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IACF;AAAA,IACA,CAAC,kBAAkB,cAAc,kBAAkB,kBAAkB,OAAO,UAAU,OAAO;AAAA,EAC/F;AACF;",
6
+ "names": ["React"]
7
+ }
@@ -0,0 +1,10 @@
1
+ import * as React from "react";
2
+ import { useValidateTypescriptPropTypes } from "@elliemae/ds-props-helpers";
3
+ import { DSPerPageSelectorName } from "../constants/index.js";
4
+ const useValidateProps = (props, propTypes) => {
5
+ useValidateTypescriptPropTypes(props, propTypes, DSPerPageSelectorName);
6
+ };
7
+ export {
8
+ useValidateProps
9
+ };
10
+ //# sourceMappingURL=useValidateProps.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../../../../scripts/build/transpile/react-shim.js", "../../../../../src/parts/DSPerPageSelector/config/useValidateProps.ts"],
4
+ "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "import { useValidateTypescriptPropTypes } from '@elliemae/ds-props-helpers';\nimport type { ValidationMap } from '@elliemae/ds-props-helpers';\nimport { type DSPerPageSelectorT } from '../react-desc-prop-types.js';\nimport { DSPerPageSelectorName } from '../constants/index.js';\n\nexport const useValidateProps = (\n props: DSPerPageSelectorT.InternalProps,\n propTypes: ValidationMap<DSPerPageSelectorT.Props>,\n): void => {\n // we validate the \"required if\" via 'isRequiredIf from our custom PropTypes\n useValidateTypescriptPropTypes(props, propTypes, DSPerPageSelectorName);\n};\n"],
5
+ "mappings": "AAAA,YAAY,WAAW;ACAvB,SAAS,sCAAsC;AAG/C,SAAS,6BAA6B;AAE/B,MAAM,mBAAmB,CAC9B,OACA,cACS;AAET,iCAA+B,OAAO,WAAW,qBAAqB;AACxE;",
6
+ "names": []
7
+ }
@@ -0,0 +1,20 @@
1
+ import * as React from "react";
2
+ import { slotObjectToDataTestIds } from "@elliemae/ds-system";
3
+ import { DSPaginationName } from "../../../constants/index.js";
4
+ const DSPerPageSelectorName = "DSPerPageSelector";
5
+ const EXAMPLE_CONSTANTS = {
6
+ HELLO: "WORLD",
7
+ FOO: "BAR"
8
+ };
9
+ const PER_PAGE_SELECTOR_SLOTS = {
10
+ PER_PAGE_SELECTOR: "per-page-selector"
11
+ };
12
+ const PER_PAGE_SELECTOR_DATA_TESTID = slotObjectToDataTestIds(DSPaginationName, PER_PAGE_SELECTOR_SLOTS);
13
+ export {
14
+ DSPaginationName,
15
+ DSPerPageSelectorName,
16
+ EXAMPLE_CONSTANTS,
17
+ PER_PAGE_SELECTOR_DATA_TESTID,
18
+ PER_PAGE_SELECTOR_SLOTS
19
+ };
20
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../../../../scripts/build/transpile/react-shim.js", "../../../../../src/parts/DSPerPageSelector/constants/index.ts"],
4
+ "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "import { slotObjectToDataTestIds } from '@elliemae/ds-system';\nimport { DSPaginationName } from '../../../constants/index.js';\nexport { DSPaginationName };\n\n// This should be used only for displayName, and useValidateProps.\n// For slots definition, use parent component name\nexport const DSPerPageSelectorName = 'DSPerPageSelector';\n\nexport const EXAMPLE_CONSTANTS = {\n HELLO: 'WORLD',\n FOO: 'BAR',\n} as const;\n\n// we are naming this with the ${component_name}_slots convention to namespace & avoid errors on duplicate exports variables in aggregators\nexport const PER_PAGE_SELECTOR_SLOTS = {\n PER_PAGE_SELECTOR: 'per-page-selector',\n} as const;\n\n// we are naming this with the ${component_name}_data_testid convention to namespace & avoid errors on duplicate exports variables in aggregators\nexport const PER_PAGE_SELECTOR_DATA_TESTID = slotObjectToDataTestIds(DSPaginationName, PER_PAGE_SELECTOR_SLOTS);\n"],
5
+ "mappings": "AAAA,YAAY,WAAW;ACAvB,SAAS,+BAA+B;AACxC,SAAS,wBAAwB;AAK1B,MAAM,wBAAwB;AAE9B,MAAM,oBAAoB;AAAA,EAC/B,OAAO;AAAA,EACP,KAAK;AACP;AAGO,MAAM,0BAA0B;AAAA,EACrC,mBAAmB;AACrB;AAGO,MAAM,gCAAgC,wBAAwB,kBAAkB,uBAAuB;",
6
+ "names": []
7
+ }