@k-int/stripes-kint-components 5.29.1 → 5.31.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (392) hide show
  1. package/CHANGELOG.md +21 -0
  2. package/es/__mocks__/@folio/stripes/components.js +3 -7
  3. package/es/__mocks__/@folio/stripes/core.js +4 -6
  4. package/es/__mocks__/@folio/stripes/smart-components.js +4 -6
  5. package/es/__mocks__/react-query.js +4 -6
  6. package/es/__mocks__/react-router-dom.js +6 -6
  7. package/es/index.js +8 -0
  8. package/es/lib/ActionList/ActionList.js +26 -33
  9. package/es/lib/ActionList/ActionListFieldArray.js +103 -119
  10. package/es/lib/ButtonTypedown/ButtonTypedown.js +58 -0
  11. package/es/lib/ButtonTypedown/index.js +13 -0
  12. package/es/lib/ComboButton/ComboButton.js +42 -47
  13. package/es/lib/CustomProperties/Config/CustomPropertiesLookup.js +11 -17
  14. package/es/lib/CustomProperties/Config/CustomPropertiesSettings.js +42 -46
  15. package/es/lib/CustomProperties/Config/CustomPropertyForm.js +58 -58
  16. package/es/lib/CustomProperties/Config/CustomPropertyForm.test.js +4 -8
  17. package/es/lib/CustomProperties/Config/CustomPropertyView.js +32 -33
  18. package/es/lib/CustomProperties/Config/CustomPropertyView.test.js +1 -1
  19. package/es/lib/CustomProperties/Edit/CustomPropertiesEdit.js +1 -1
  20. package/es/lib/CustomProperties/Edit/CustomPropertiesEditCtx.js +3 -3
  21. package/es/lib/CustomProperties/Edit/CustomPropertiesListField.js +29 -35
  22. package/es/lib/CustomProperties/Edit/CustomPropertyField.js +61 -59
  23. package/es/lib/CustomProperties/Edit/CustomPropertyField.test.js +20 -20
  24. package/es/lib/CustomProperties/Edit/CustomPropertyFormCard.js +2 -2
  25. package/es/lib/CustomProperties/Edit/CustomPropertyFormCard.test.js +1 -1
  26. package/es/lib/CustomProperties/Edit/testResources.js +11 -12
  27. package/es/lib/CustomProperties/Filter/CustomPropertiesFilter.js +22 -33
  28. package/es/lib/CustomProperties/Filter/CustomPropertiesFilterField.js +23 -35
  29. package/es/lib/CustomProperties/Filter/CustomPropertiesFilterField.test.js +1 -1
  30. package/es/lib/CustomProperties/Filter/CustomPropertiesFilterFieldArray.js +6 -6
  31. package/es/lib/CustomProperties/Filter/CustomPropertiesFilterForm.js +3 -6
  32. package/es/lib/CustomProperties/Filter/CustomPropertiesFilterForm.test.js +4 -8
  33. package/es/lib/CustomProperties/Filter/CustomPropertiesRule.js +14 -17
  34. package/es/lib/CustomProperties/Filter/testResources.js +1 -2
  35. package/es/lib/CustomProperties/Filter/useParseActiveFilterStrings.js +1 -2
  36. package/es/lib/CustomProperties/View/CustomPropertiesView.js +1 -1
  37. package/es/lib/CustomProperties/View/CustomPropertiesViewCtx.js +18 -26
  38. package/es/lib/CustomProperties/View/CustomPropertiesViewCtx.test.js +3 -6
  39. package/es/lib/CustomProperties/View/CustomPropertyCard.js +7 -11
  40. package/es/lib/CycleButton/CycleButton.js +9 -17
  41. package/es/lib/FormModal/FormModal.js +24 -32
  42. package/es/lib/FormattedKintMessage/FormattedKintMessage.js +23 -30
  43. package/es/lib/IconSelect/IconSelect.js +22 -32
  44. package/es/lib/NoResultsMessage/NoResultsMessage.js +4 -5
  45. package/es/lib/NumberField/NumberField.js +17 -25
  46. package/es/lib/NumberField/NumberField.test.js +6 -7
  47. package/es/lib/QueryTypedown/QueryTypedown.js +8 -15
  48. package/es/lib/RefdataButtons/RefdataButtons.js +6 -9
  49. package/es/lib/ResponsiveButtonGroup/ResponsiveButtonGroup.js +48 -60
  50. package/es/lib/ResponsiveButtonGroup/useResponsiveButtonGroupSizing.js +5 -6
  51. package/es/lib/RichSelect/RichSelect.js +31 -36
  52. package/es/lib/RichSelect/useSelectedOption.js +1 -2
  53. package/es/lib/SASQLookupComponent/SASQLookupComponent.js +91 -94
  54. package/es/lib/SASQLookupComponent/TableBody/TableBody.js +42 -52
  55. package/es/lib/SASQRoute/SASQRoute.js +25 -29
  56. package/es/lib/SASQViewComponent/SASQViewComponent.js +68 -76
  57. package/es/lib/SearchField/SearchField.js +7 -13
  58. package/es/lib/SearchKeyControl/SearchKeyControl.js +8 -13
  59. package/es/lib/SearchKeyControl/SearchKeyControl.test.js +2 -6
  60. package/es/lib/Settings/EditableRefdataCategoryList/EditableRefdataCategoryList.js +30 -46
  61. package/es/lib/Settings/EditableRefdataList/EditableRefdataList.js +33 -43
  62. package/es/lib/Settings/EditableSettingsList/EditableSettingsListFieldArray/EditableSettingsListFieldArray.js +7 -11
  63. package/es/lib/Settings/EditableSettingsList/SettingField/EditSettingValue/EditSettingValue.js +13 -20
  64. package/es/lib/Settings/EditableSettingsList/SettingField/RenderSettingValue/RenderSettingValue.js +10 -12
  65. package/es/lib/Settings/EditableSettingsList/SettingField/SettingField.js +10 -15
  66. package/es/lib/Settings/EditableSettingsList/SettingField/SettingField.test.js +3 -3
  67. package/es/lib/Settings/RefdataCategoriesSettings/RefdataCategoriesSettings.js +19 -26
  68. package/es/lib/Settings/SettingPage/SettingPagePane/SettingPagePane.js +2 -2
  69. package/es/lib/Settings/SettingsFormContainer/SettingsFormContainer.js +30 -35
  70. package/es/lib/Settings/StaticSettingsField/StaticSettingsField.js +5 -8
  71. package/es/lib/Settings/StaticSettingsField/StaticSettingsFieldComponent/StaticSettingsFieldComponent.js +18 -22
  72. package/es/lib/Settings/hooks/staticSettingsPages/useSettingCallout/useSettingCallout.js +2 -2
  73. package/es/lib/Settings/hooks/staticSettingsPages/useSettingsSectionInitalValues/useSettingsSectionInitalValues.js +1 -1
  74. package/es/lib/Settings/hooks/staticSettingsPages/useStaticSettingsSection.js +3 -7
  75. package/es/lib/Settings/hooks/useAppSettings/useAppSettings.js +7 -11
  76. package/es/lib/Settings/hooks/useSettingSection/useSettingSection.js +16 -22
  77. package/es/lib/Settings/hooks/useSettings/useSettings.js +60 -60
  78. package/es/lib/Tags/Tags.js +5 -8
  79. package/es/lib/Tags/hooks/useTags.js +1 -1
  80. package/es/lib/Tags/hooks/useTagsEnabled.js +34 -4
  81. package/es/lib/Tags/tagsConfig.js +1 -1
  82. package/es/lib/Typedown/Typedown.js +103 -69
  83. package/es/lib/constants/endpoints.js +7 -2
  84. package/es/lib/hooks/__mocks__/index.js +3 -7
  85. package/es/lib/hooks/intlHooks/useIntlKeyStore/useIntlKeyStore.js +20 -26
  86. package/es/lib/hooks/intlHooks/useKintIntl/useKintIntl.js +24 -34
  87. package/es/lib/hooks/typedownHooks/useTypedown.js +104 -81
  88. package/es/lib/hooks/typedownHooks/useTypedownToggle.js +2 -2
  89. package/es/lib/hooks/useActionListRef.js +1 -1
  90. package/es/lib/hooks/useActiveElement.js +1 -1
  91. package/es/lib/hooks/useCustomProperties.js +6 -10
  92. package/es/lib/hooks/useHelperApp.js +13 -16
  93. package/es/lib/hooks/useKiwtFieldArray.js +7 -8
  94. package/es/lib/hooks/useKiwtSASQuery.js +15 -19
  95. package/es/lib/hooks/useLocalPageStore.js +7 -10
  96. package/es/lib/hooks/useModConfigEntries.js +2 -2
  97. package/es/lib/hooks/useMutateCustomProperties/useMutateCustomProperties.js +10 -17
  98. package/es/lib/hooks/useMutateGeneric/useMutateGeneric.js +2 -2
  99. package/es/lib/hooks/useMutateModConfigEntry.js +2 -2
  100. package/es/lib/hooks/useMutateRefdataCategory/useMutateRefdataCategory.js +15 -21
  101. package/es/lib/hooks/useMutateRefdataValue/useMutateRefdataValue.js +16 -23
  102. package/es/lib/hooks/usePrevNextPagination.js +17 -19
  103. package/es/lib/hooks/useQIndex.js +11 -14
  104. package/es/lib/hooks/useRefdata.js +3 -3
  105. package/es/lib/hooks/useStandaloneSASQQueryParameter/useStandaloneSASQQueryParameter.js +9 -13
  106. package/es/lib/hooks/useTemplates.js +4 -4
  107. package/es/lib/utils/buildUrl.js +2 -3
  108. package/es/lib/utils/filterParsers/deparseKiwtQueryFilters.js +5 -5
  109. package/es/lib/utils/filterParsers/parseKiwtQueryFilters.js +2 -2
  110. package/es/lib/utils/filterParsers/parseKiwtQueryGroups.js +4 -5
  111. package/es/lib/utils/filterParsers/parseKiwtQueryString.js +1 -1
  112. package/es/lib/utils/generateKiwtQueryParams/generateKiwtQueryParams.js +94 -107
  113. package/es/lib/utils/groupCustomPropertiesByCtx.js +5 -9
  114. package/es/lib/utils/matchString.js +5 -7
  115. package/es/lib/utils/parseErrorResponse.js +3 -7
  116. package/es/lib/utils/selectorSafe.js +2 -3
  117. package/es/lib/utils/sortByLabel.js +2 -3
  118. package/es/lib/validators/validators.js +6 -9
  119. package/package.json +1 -1
  120. package/src/artifacts/coverage-jest/ActionList/ActionList.js.html +1 -1
  121. package/src/artifacts/coverage-jest/ActionList/ActionListFieldArray.js.html +1 -1
  122. package/src/artifacts/coverage-jest/ActionList/index.html +1 -1
  123. package/src/artifacts/coverage-jest/ActionList/index.js.html +1 -1
  124. package/src/artifacts/coverage-jest/ButtonTypedown/ButtonTypedown.js.html +241 -0
  125. package/src/artifacts/coverage-jest/ButtonTypedown/index.html +131 -0
  126. package/src/artifacts/coverage-jest/ButtonTypedown/index.js.html +88 -0
  127. package/src/artifacts/coverage-jest/ComboButton/ComboButton.js.html +1 -1
  128. package/src/artifacts/coverage-jest/ComboButton/index.html +1 -1
  129. package/src/artifacts/coverage-jest/ComboButton/index.js.html +1 -1
  130. package/src/artifacts/coverage-jest/CustomProperties/Config/CustomPropertiesLookup.js.html +1 -1
  131. package/src/artifacts/coverage-jest/CustomProperties/Config/CustomPropertiesSettings.js.html +1 -1
  132. package/src/artifacts/coverage-jest/CustomProperties/Config/CustomPropertyForm.js.html +1 -1
  133. package/src/artifacts/coverage-jest/CustomProperties/Config/CustomPropertyView.js.html +1 -1
  134. package/src/artifacts/coverage-jest/CustomProperties/Config/index.html +1 -1
  135. package/src/artifacts/coverage-jest/CustomProperties/Config/index.js.html +1 -1
  136. package/src/artifacts/coverage-jest/CustomProperties/Edit/CustomPropertiesEdit.js.html +1 -1
  137. package/src/artifacts/coverage-jest/CustomProperties/Edit/CustomPropertiesEditCtx.js.html +1 -1
  138. package/src/artifacts/coverage-jest/CustomProperties/Edit/CustomPropertiesListField.js.html +1 -1
  139. package/src/artifacts/coverage-jest/CustomProperties/Edit/CustomPropertyField.js.html +1 -1
  140. package/src/artifacts/coverage-jest/CustomProperties/Edit/CustomPropertyFormCard.js.html +1 -1
  141. package/src/artifacts/coverage-jest/CustomProperties/Edit/index.html +1 -1
  142. package/src/artifacts/coverage-jest/CustomProperties/Edit/index.js.html +1 -1
  143. package/src/artifacts/coverage-jest/CustomProperties/Edit/testResources.js.html +1 -1
  144. package/src/artifacts/coverage-jest/CustomProperties/Filter/CustomPropertiesFilter.js.html +1 -1
  145. package/src/artifacts/coverage-jest/CustomProperties/Filter/CustomPropertiesFilterField.js.html +1 -1
  146. package/src/artifacts/coverage-jest/CustomProperties/Filter/CustomPropertiesFilterFieldArray.js.html +1 -1
  147. package/src/artifacts/coverage-jest/CustomProperties/Filter/CustomPropertiesFilterForm.js.html +1 -1
  148. package/src/artifacts/coverage-jest/CustomProperties/Filter/CustomPropertiesRule.js.html +1 -1
  149. package/src/artifacts/coverage-jest/CustomProperties/Filter/index.html +1 -1
  150. package/src/artifacts/coverage-jest/CustomProperties/Filter/index.js.html +1 -1
  151. package/src/artifacts/coverage-jest/CustomProperties/Filter/testResources.js.html +1 -1
  152. package/src/artifacts/coverage-jest/CustomProperties/Filter/useOperators.js.html +1 -1
  153. package/src/artifacts/coverage-jest/CustomProperties/Filter/useParseActiveFilterStrings.js.html +1 -1
  154. package/src/artifacts/coverage-jest/CustomProperties/Filter/useValueProps.js.html +1 -1
  155. package/src/artifacts/coverage-jest/CustomProperties/View/CustomPropertiesView.js.html +1 -1
  156. package/src/artifacts/coverage-jest/CustomProperties/View/CustomPropertiesViewCtx.js.html +1 -1
  157. package/src/artifacts/coverage-jest/CustomProperties/View/CustomPropertyCard.js.html +1 -1
  158. package/src/artifacts/coverage-jest/CustomProperties/View/index.html +1 -1
  159. package/src/artifacts/coverage-jest/CustomProperties/View/index.js.html +1 -1
  160. package/src/artifacts/coverage-jest/CustomProperties/View/testResources.js.html +1 -1
  161. package/src/artifacts/coverage-jest/CustomProperties/index.html +1 -1
  162. package/src/artifacts/coverage-jest/CustomProperties/index.js.html +1 -1
  163. package/src/artifacts/coverage-jest/CycleButton/CycleButton.js.html +1 -1
  164. package/src/artifacts/coverage-jest/CycleButton/index.html +1 -1
  165. package/src/artifacts/coverage-jest/CycleButton/index.js.html +1 -1
  166. package/src/artifacts/coverage-jest/FieldLabel/FieldLabel.js.html +1 -1
  167. package/src/artifacts/coverage-jest/FieldLabel/index.html +1 -1
  168. package/src/artifacts/coverage-jest/FieldLabel/index.js.html +1 -1
  169. package/src/artifacts/coverage-jest/FormModal/FormModal.js.html +1 -1
  170. package/src/artifacts/coverage-jest/FormModal/index.html +1 -1
  171. package/src/artifacts/coverage-jest/FormModal/index.js.html +1 -1
  172. package/src/artifacts/coverage-jest/FormattedKintMessage/FormattedKintMessage.js.html +1 -1
  173. package/src/artifacts/coverage-jest/FormattedKintMessage/index.html +1 -1
  174. package/src/artifacts/coverage-jest/FormattedKintMessage/index.js.html +1 -1
  175. package/src/artifacts/coverage-jest/IconSelect/IconSelect.js.html +1 -1
  176. package/src/artifacts/coverage-jest/IconSelect/index.html +1 -1
  177. package/src/artifacts/coverage-jest/IconSelect/index.js.html +1 -1
  178. package/src/artifacts/coverage-jest/NoResultsMessage/NoResultsMessage.js.html +1 -1
  179. package/src/artifacts/coverage-jest/NoResultsMessage/index.html +1 -1
  180. package/src/artifacts/coverage-jest/NoResultsMessage/index.js.html +1 -1
  181. package/src/artifacts/coverage-jest/NumberField/NumberField.js.html +1 -1
  182. package/src/artifacts/coverage-jest/NumberField/index.html +1 -1
  183. package/src/artifacts/coverage-jest/NumberField/index.js.html +1 -1
  184. package/src/artifacts/coverage-jest/QueryTypedown/QueryTypedown.js.html +1 -1
  185. package/src/artifacts/coverage-jest/QueryTypedown/index.html +1 -1
  186. package/src/artifacts/coverage-jest/QueryTypedown/index.js.html +1 -1
  187. package/src/artifacts/coverage-jest/RefdataButtons/RefdataButtons.js.html +1 -1
  188. package/src/artifacts/coverage-jest/RefdataButtons/index.html +1 -1
  189. package/src/artifacts/coverage-jest/RefdataButtons/index.js.html +1 -1
  190. package/src/artifacts/coverage-jest/ResponsiveButtonGroup/ResponsiveButtonGroup.js.html +1 -1
  191. package/src/artifacts/coverage-jest/ResponsiveButtonGroup/index.html +1 -1
  192. package/src/artifacts/coverage-jest/ResponsiveButtonGroup/index.js.html +1 -1
  193. package/src/artifacts/coverage-jest/ResponsiveButtonGroup/useResponsiveButtonGroupSizing.js.html +1 -1
  194. package/src/artifacts/coverage-jest/RichSelect/RichSelect.js.html +1 -1
  195. package/src/artifacts/coverage-jest/RichSelect/index.html +1 -1
  196. package/src/artifacts/coverage-jest/RichSelect/index.js.html +1 -1
  197. package/src/artifacts/coverage-jest/RichSelect/useSelectedOption.js.html +1 -1
  198. package/src/artifacts/coverage-jest/SASQLookupComponent/SASQLookupComponent.js.html +1 -1
  199. package/src/artifacts/coverage-jest/SASQLookupComponent/TableBody/TableBody.js.html +1 -1
  200. package/src/artifacts/coverage-jest/SASQLookupComponent/TableBody/index.html +1 -1
  201. package/src/artifacts/coverage-jest/SASQLookupComponent/TableBody/index.js.html +1 -1
  202. package/src/artifacts/coverage-jest/SASQLookupComponent/index.html +1 -1
  203. package/src/artifacts/coverage-jest/SASQLookupComponent/index.js.html +1 -1
  204. package/src/artifacts/coverage-jest/SASQRoute/SASQRoute.js.html +1 -1
  205. package/src/artifacts/coverage-jest/SASQRoute/index.html +1 -1
  206. package/src/artifacts/coverage-jest/SASQRoute/index.js.html +1 -1
  207. package/src/artifacts/coverage-jest/SASQViewComponent/SASQViewComponent.js.html +1 -1
  208. package/src/artifacts/coverage-jest/SASQViewComponent/index.html +1 -1
  209. package/src/artifacts/coverage-jest/SASQViewComponent/index.js.html +1 -1
  210. package/src/artifacts/coverage-jest/SearchField/SearchField.js.html +1 -1
  211. package/src/artifacts/coverage-jest/SearchField/index.html +1 -1
  212. package/src/artifacts/coverage-jest/SearchField/index.js.html +1 -1
  213. package/src/artifacts/coverage-jest/SearchKeyControl/SearchKeyControl.js.html +1 -1
  214. package/src/artifacts/coverage-jest/SearchKeyControl/index.html +1 -1
  215. package/src/artifacts/coverage-jest/SearchKeyControl/index.js.html +1 -1
  216. package/src/artifacts/coverage-jest/Settings/EditableRefdataCategoryList/EditableRefdataCategoryList.js.html +1 -1
  217. package/src/artifacts/coverage-jest/Settings/EditableRefdataCategoryList/index.html +1 -1
  218. package/src/artifacts/coverage-jest/Settings/EditableRefdataCategoryList/index.js.html +1 -1
  219. package/src/artifacts/coverage-jest/Settings/EditableRefdataList/EditableRefdataList.js.html +1 -1
  220. package/src/artifacts/coverage-jest/Settings/EditableRefdataList/index.html +1 -1
  221. package/src/artifacts/coverage-jest/Settings/EditableRefdataList/index.js.html +1 -1
  222. package/src/artifacts/coverage-jest/Settings/EditableSettingsList/EditableSettingsList.js.html +1 -1
  223. package/src/artifacts/coverage-jest/Settings/EditableSettingsList/EditableSettingsListFieldArray/EditableSettingsListFieldArray.js.html +1 -1
  224. package/src/artifacts/coverage-jest/Settings/EditableSettingsList/EditableSettingsListFieldArray/index.html +1 -1
  225. package/src/artifacts/coverage-jest/Settings/EditableSettingsList/EditableSettingsListFieldArray/index.js.html +1 -1
  226. package/src/artifacts/coverage-jest/Settings/EditableSettingsList/SettingField/EditSettingValue/EditSettingValue.js.html +1 -1
  227. package/src/artifacts/coverage-jest/Settings/EditableSettingsList/SettingField/EditSettingValue/index.html +1 -1
  228. package/src/artifacts/coverage-jest/Settings/EditableSettingsList/SettingField/EditSettingValue/index.js.html +1 -1
  229. package/src/artifacts/coverage-jest/Settings/EditableSettingsList/SettingField/RenderSettingValue/RenderSettingValue.js.html +1 -1
  230. package/src/artifacts/coverage-jest/Settings/EditableSettingsList/SettingField/RenderSettingValue/index.html +1 -1
  231. package/src/artifacts/coverage-jest/Settings/EditableSettingsList/SettingField/RenderSettingValue/index.js.html +1 -1
  232. package/src/artifacts/coverage-jest/Settings/EditableSettingsList/SettingField/SettingField.js.html +1 -1
  233. package/src/artifacts/coverage-jest/Settings/EditableSettingsList/SettingField/index.html +1 -1
  234. package/src/artifacts/coverage-jest/Settings/EditableSettingsList/SettingField/index.js.html +1 -1
  235. package/src/artifacts/coverage-jest/Settings/EditableSettingsList/index.html +1 -1
  236. package/src/artifacts/coverage-jest/Settings/EditableSettingsList/index.js.html +1 -1
  237. package/src/artifacts/coverage-jest/Settings/RefdataCategoriesSettings/RefdataCategoriesSettings.js.html +1 -1
  238. package/src/artifacts/coverage-jest/Settings/RefdataCategoriesSettings/index.html +1 -1
  239. package/src/artifacts/coverage-jest/Settings/RefdataCategoriesSettings/index.js.html +1 -1
  240. package/src/artifacts/coverage-jest/Settings/SettingPage/SettingPage.js.html +1 -1
  241. package/src/artifacts/coverage-jest/Settings/SettingPage/SettingPagePane/SettingPagePane.js.html +1 -1
  242. package/src/artifacts/coverage-jest/Settings/SettingPage/SettingPagePane/index.html +1 -1
  243. package/src/artifacts/coverage-jest/Settings/SettingPage/SettingPagePane/index.js.html +1 -1
  244. package/src/artifacts/coverage-jest/Settings/SettingPage/index.html +1 -1
  245. package/src/artifacts/coverage-jest/Settings/SettingPage/index.js.html +1 -1
  246. package/src/artifacts/coverage-jest/Settings/SettingsFormContainer/SettingsFormContainer.js.html +1 -1
  247. package/src/artifacts/coverage-jest/Settings/SettingsFormContainer/index.html +1 -1
  248. package/src/artifacts/coverage-jest/Settings/SettingsFormContainer/index.js.html +1 -1
  249. package/src/artifacts/coverage-jest/Settings/StaticSettingsField/StaticSettingsField.js.html +1 -1
  250. package/src/artifacts/coverage-jest/Settings/StaticSettingsField/StaticSettingsFieldComponent/StaticSettingsFieldComponent.js.html +1 -1
  251. package/src/artifacts/coverage-jest/Settings/StaticSettingsField/StaticSettingsFieldComponent/index.html +1 -1
  252. package/src/artifacts/coverage-jest/Settings/StaticSettingsField/StaticSettingsFieldComponent/index.js.html +1 -1
  253. package/src/artifacts/coverage-jest/Settings/StaticSettingsField/index.html +1 -1
  254. package/src/artifacts/coverage-jest/Settings/StaticSettingsField/index.js.html +1 -1
  255. package/src/artifacts/coverage-jest/Settings/constants/index.html +1 -1
  256. package/src/artifacts/coverage-jest/Settings/constants/index.js.html +1 -1
  257. package/src/artifacts/coverage-jest/Settings/constants/queryKeys.js.html +1 -1
  258. package/src/artifacts/coverage-jest/Settings/contexts/SettingsContext.js.html +1 -1
  259. package/src/artifacts/coverage-jest/Settings/contexts/index.html +1 -1
  260. package/src/artifacts/coverage-jest/Settings/contexts/index.js.html +1 -1
  261. package/src/artifacts/coverage-jest/Settings/hooks/index.html +1 -1
  262. package/src/artifacts/coverage-jest/Settings/hooks/index.js.html +1 -1
  263. package/src/artifacts/coverage-jest/Settings/hooks/staticSettingsPages/index.html +1 -1
  264. package/src/artifacts/coverage-jest/Settings/hooks/staticSettingsPages/index.js.html +1 -1
  265. package/src/artifacts/coverage-jest/Settings/hooks/staticSettingsPages/useSettingCallout/index.html +1 -1
  266. package/src/artifacts/coverage-jest/Settings/hooks/staticSettingsPages/useSettingCallout/index.js.html +1 -1
  267. package/src/artifacts/coverage-jest/Settings/hooks/staticSettingsPages/useSettingCallout/useSettingCallout.js.html +1 -1
  268. package/src/artifacts/coverage-jest/Settings/hooks/staticSettingsPages/useSettingsSectionInitalValues/index.html +1 -1
  269. package/src/artifacts/coverage-jest/Settings/hooks/staticSettingsPages/useSettingsSectionInitalValues/index.js.html +1 -1
  270. package/src/artifacts/coverage-jest/Settings/hooks/staticSettingsPages/useSettingsSectionInitalValues/useSettingsSectionInitalValues.js.html +1 -1
  271. package/src/artifacts/coverage-jest/Settings/hooks/staticSettingsPages/useStaticSettingsSection.js.html +1 -1
  272. package/src/artifacts/coverage-jest/Settings/hooks/useAppSettings/index.html +1 -1
  273. package/src/artifacts/coverage-jest/Settings/hooks/useAppSettings/index.js.html +1 -1
  274. package/src/artifacts/coverage-jest/Settings/hooks/useAppSettings/useAppSettings.js.html +1 -1
  275. package/src/artifacts/coverage-jest/Settings/hooks/useSettingSection/index.html +1 -1
  276. package/src/artifacts/coverage-jest/Settings/hooks/useSettingSection/index.js.html +1 -1
  277. package/src/artifacts/coverage-jest/Settings/hooks/useSettingSection/useSettingSection.js.html +1 -1
  278. package/src/artifacts/coverage-jest/Settings/hooks/useSettings/index.html +1 -1
  279. package/src/artifacts/coverage-jest/Settings/hooks/useSettings/index.js.html +1 -1
  280. package/src/artifacts/coverage-jest/Settings/hooks/useSettings/useSettings.js.html +1 -1
  281. package/src/artifacts/coverage-jest/Settings/index.html +1 -1
  282. package/src/artifacts/coverage-jest/Settings/index.js.html +1 -1
  283. package/src/artifacts/coverage-jest/Tags/Tags.js.html +1 -1
  284. package/src/artifacts/coverage-jest/Tags/hooks/index.html +15 -15
  285. package/src/artifacts/coverage-jest/Tags/hooks/index.js.html +1 -1
  286. package/src/artifacts/coverage-jest/Tags/hooks/useTags.js.html +1 -1
  287. package/src/artifacts/coverage-jest/Tags/hooks/useTagsEnabled.js.html +150 -12
  288. package/src/artifacts/coverage-jest/Tags/index.html +1 -1
  289. package/src/artifacts/coverage-jest/Tags/index.js.html +1 -1
  290. package/src/artifacts/coverage-jest/Tags/tagsConfig.js.html +1 -1
  291. package/src/artifacts/coverage-jest/Typedown/Typedown.js.html +219 -60
  292. package/src/artifacts/coverage-jest/Typedown/index.html +15 -15
  293. package/src/artifacts/coverage-jest/Typedown/index.js.html +1 -1
  294. package/src/artifacts/coverage-jest/cobertura-coverage.xml +220 -110
  295. package/src/artifacts/coverage-jest/constants/comparators.js.html +1 -1
  296. package/src/artifacts/coverage-jest/constants/customProperties.js.html +1 -1
  297. package/src/artifacts/coverage-jest/constants/endpoints.js.html +23 -5
  298. package/src/artifacts/coverage-jest/constants/eventCodes.js.html +1 -1
  299. package/src/artifacts/coverage-jest/constants/index.html +5 -5
  300. package/src/artifacts/coverage-jest/constants/pagination.js.html +1 -1
  301. package/src/artifacts/coverage-jest/hooks/index.html +1 -1
  302. package/src/artifacts/coverage-jest/hooks/index.js.html +1 -1
  303. package/src/artifacts/coverage-jest/hooks/intlHooks/index.html +1 -1
  304. package/src/artifacts/coverage-jest/hooks/intlHooks/index.js.html +1 -1
  305. package/src/artifacts/coverage-jest/hooks/intlHooks/useIntlKey/index.html +1 -1
  306. package/src/artifacts/coverage-jest/hooks/intlHooks/useIntlKey/index.js.html +1 -1
  307. package/src/artifacts/coverage-jest/hooks/intlHooks/useIntlKey/useIntlKey.js.html +1 -1
  308. package/src/artifacts/coverage-jest/hooks/intlHooks/useIntlKeyStore/index.html +1 -1
  309. package/src/artifacts/coverage-jest/hooks/intlHooks/useIntlKeyStore/index.js.html +1 -1
  310. package/src/artifacts/coverage-jest/hooks/intlHooks/useIntlKeyStore/useIntlKeyStore.js.html +1 -1
  311. package/src/artifacts/coverage-jest/hooks/intlHooks/useKintIntl/index.html +1 -1
  312. package/src/artifacts/coverage-jest/hooks/intlHooks/useKintIntl/index.js.html +1 -1
  313. package/src/artifacts/coverage-jest/hooks/intlHooks/useKintIntl/useKintIntl.js.html +1 -1
  314. package/src/artifacts/coverage-jest/hooks/typedownHooks/index.html +14 -14
  315. package/src/artifacts/coverage-jest/hooks/typedownHooks/index.js.html +1 -1
  316. package/src/artifacts/coverage-jest/hooks/typedownHooks/useTypedown.js.html +170 -116
  317. package/src/artifacts/coverage-jest/hooks/typedownHooks/useTypedownData.js.html +1 -1
  318. package/src/artifacts/coverage-jest/hooks/typedownHooks/useTypedownToggle.js.html +1 -1
  319. package/src/artifacts/coverage-jest/hooks/useActionListRef.js.html +1 -1
  320. package/src/artifacts/coverage-jest/hooks/useActiveElement.js.html +1 -1
  321. package/src/artifacts/coverage-jest/hooks/useCustomProperties.js.html +1 -1
  322. package/src/artifacts/coverage-jest/hooks/useHelperApp.js.html +1 -1
  323. package/src/artifacts/coverage-jest/hooks/useInvalidateRefdata/index.html +1 -1
  324. package/src/artifacts/coverage-jest/hooks/useInvalidateRefdata/index.js.html +1 -1
  325. package/src/artifacts/coverage-jest/hooks/useInvalidateRefdata/useInvalidateRefdata.js.html +1 -1
  326. package/src/artifacts/coverage-jest/hooks/useKiwtFieldArray.js.html +1 -1
  327. package/src/artifacts/coverage-jest/hooks/useKiwtSASQuery.js.html +1 -1
  328. package/src/artifacts/coverage-jest/hooks/useLocalPageStore.js.html +1 -1
  329. package/src/artifacts/coverage-jest/hooks/useLocalStorageState.js.html +1 -1
  330. package/src/artifacts/coverage-jest/hooks/useModConfigEntries.js.html +1 -1
  331. package/src/artifacts/coverage-jest/hooks/useMutateCustomProperties/index.html +1 -1
  332. package/src/artifacts/coverage-jest/hooks/useMutateCustomProperties/index.js.html +1 -1
  333. package/src/artifacts/coverage-jest/hooks/useMutateCustomProperties/useMutateCustomProperties.js.html +1 -1
  334. package/src/artifacts/coverage-jest/hooks/useMutateGeneric/index.html +1 -1
  335. package/src/artifacts/coverage-jest/hooks/useMutateGeneric/index.js.html +1 -1
  336. package/src/artifacts/coverage-jest/hooks/useMutateGeneric/useMutateGeneric.js.html +1 -1
  337. package/src/artifacts/coverage-jest/hooks/useMutateModConfigEntry.js.html +1 -1
  338. package/src/artifacts/coverage-jest/hooks/useMutateRefdataCategory/index.html +1 -1
  339. package/src/artifacts/coverage-jest/hooks/useMutateRefdataCategory/index.js.html +1 -1
  340. package/src/artifacts/coverage-jest/hooks/useMutateRefdataCategory/useMutateRefdataCategory.js.html +1 -1
  341. package/src/artifacts/coverage-jest/hooks/useMutateRefdataValue/index.html +1 -1
  342. package/src/artifacts/coverage-jest/hooks/useMutateRefdataValue/index.js.html +1 -1
  343. package/src/artifacts/coverage-jest/hooks/useMutateRefdataValue/useMutateRefdataValue.js.html +1 -1
  344. package/src/artifacts/coverage-jest/hooks/usePrevNextPagination.js.html +1 -1
  345. package/src/artifacts/coverage-jest/hooks/useQIndex.js.html +1 -1
  346. package/src/artifacts/coverage-jest/hooks/useRefdata.js.html +1 -1
  347. package/src/artifacts/coverage-jest/hooks/useSASQQueryMeta.js.html +1 -1
  348. package/src/artifacts/coverage-jest/hooks/useStandaloneSASQQueryParameter/index.html +1 -1
  349. package/src/artifacts/coverage-jest/hooks/useStandaloneSASQQueryParameter/index.js.html +1 -1
  350. package/src/artifacts/coverage-jest/hooks/useStandaloneSASQQueryParameter/useStandaloneSASQQueryParameter.js.html +1 -1
  351. package/src/artifacts/coverage-jest/hooks/useTemplates.js.html +1 -1
  352. package/src/artifacts/coverage-jest/index.html +50 -35
  353. package/src/artifacts/coverage-jest/utils/buildUrl.js.html +1 -1
  354. package/src/artifacts/coverage-jest/utils/filterParsers/deparseKiwtQueryFilters.js.html +1 -1
  355. package/src/artifacts/coverage-jest/utils/filterParsers/index.html +1 -1
  356. package/src/artifacts/coverage-jest/utils/filterParsers/index.js.html +1 -1
  357. package/src/artifacts/coverage-jest/utils/filterParsers/parseKiwtQueryFilters.js.html +1 -1
  358. package/src/artifacts/coverage-jest/utils/filterParsers/parseKiwtQueryGroups.js.html +1 -1
  359. package/src/artifacts/coverage-jest/utils/filterParsers/parseKiwtQueryString.js.html +1 -1
  360. package/src/artifacts/coverage-jest/utils/generateKiwtQuery.js.html +1 -1
  361. package/src/artifacts/coverage-jest/utils/generateKiwtQueryParams/generateKiwtQueryParams.js.html +1 -1
  362. package/src/artifacts/coverage-jest/utils/generateKiwtQueryParams/index.html +1 -1
  363. package/src/artifacts/coverage-jest/utils/generateKiwtQueryParams/index.js.html +1 -1
  364. package/src/artifacts/coverage-jest/utils/groupCustomPropertiesByCtx.js.html +1 -1
  365. package/src/artifacts/coverage-jest/utils/highlightString.js.html +1 -1
  366. package/src/artifacts/coverage-jest/utils/index.html +1 -1
  367. package/src/artifacts/coverage-jest/utils/index.js.html +1 -1
  368. package/src/artifacts/coverage-jest/utils/matchString.js.html +1 -1
  369. package/src/artifacts/coverage-jest/utils/modConfigEntriesQueryKey.js.html +1 -1
  370. package/src/artifacts/coverage-jest/utils/parseErrorResponse.js.html +1 -1
  371. package/src/artifacts/coverage-jest/utils/parseModConfigEntry.js.html +1 -1
  372. package/src/artifacts/coverage-jest/utils/refdataOptions.js.html +1 -1
  373. package/src/artifacts/coverage-jest/utils/refdataQueryKey/index.html +1 -1
  374. package/src/artifacts/coverage-jest/utils/refdataQueryKey/index.js.html +1 -1
  375. package/src/artifacts/coverage-jest/utils/refdataQueryKey/refdataQueryKey.js.html +1 -1
  376. package/src/artifacts/coverage-jest/utils/selectorSafe.js.html +1 -1
  377. package/src/artifacts/coverage-jest/utils/sortByLabel.js.html +1 -1
  378. package/src/artifacts/coverage-jest/utils/toCamelCase.js.html +1 -1
  379. package/src/artifacts/coverage-jest/utils/typedownQueryKey.js.html +1 -1
  380. package/src/artifacts/coverage-jest/validators/index.html +1 -1
  381. package/src/artifacts/coverage-jest/validators/index.js.html +1 -1
  382. package/src/artifacts/coverage-jest/validators/validators.js.html +1 -1
  383. package/src/index.js +4 -0
  384. package/src/lib/ButtonTypedown/ButtonTypedown.js +52 -0
  385. package/src/lib/ButtonTypedown/README.md +53 -0
  386. package/src/lib/ButtonTypedown/index.js +1 -0
  387. package/src/lib/Tags/hooks/useTagsEnabled.js +51 -5
  388. package/src/lib/Typedown/README.md +24 -21
  389. package/src/lib/Typedown/Typedown.js +101 -48
  390. package/src/lib/constants/endpoints.js +7 -1
  391. package/src/lib/hooks/typedownHooks/useTypedown.js +105 -87
  392. package/styles/TypeDown.css +4 -0
@@ -1,4 +1,4 @@
1
- import { useEffect, useRef, useState } from 'react';
1
+ import { useCallback, useEffect, useRef, useState } from 'react';
2
2
  import { useResizeDetector } from 'react-resize-detector';
3
3
 
4
4
  import {
@@ -14,106 +14,124 @@ import {
14
14
  UP_ARROW
15
15
  } from '../../constants/eventCodes';
16
16
 
17
- import selectorSafe from '../../utils/selectorSafe';
18
-
19
17
  import useTypedownToggle from './useTypedownToggle';
20
18
 
21
19
  const useTypedown = (
22
20
  name,
23
21
  { timeout = 800 } = {}
24
22
  ) => {
25
- // SEARCHFIELD COMPONENT
26
- const searchFieldComponent = document.getElementById(`typedown-searchField-${selectorSafe(name)}`);
23
+ // SET UP STATE HOLDING DOM ELEMENTS
24
+ const [list, setListElement] = useState();
25
+ const [trigger, setTriggerElement] = useState();
26
+ const [footer, setFooterElement] = useState();
27
+ const [header, setHeaderElement] = useState();
27
28
 
28
29
  // SET UP REFS
29
- const listRef = useRef();
30
30
  const triggerRef = useRef();
31
31
  const overlayRef = useRef();
32
- const footerRef = useRef();
33
-
34
- const footer = document.getElementById(`typedown-footer-${selectorSafe(name)}`);
35
- // Add an event listener to the footer, so that we can control tab behaviour between footer elements
36
-
37
- if (footer && footer.getAttribute('hasListener') !== 'true') {
38
- footer.addEventListener('keydown', e => {
39
- // We want special behaviour on tab
40
- if (e.code === TAB) {
41
- // Prevent the default behaviour
42
- e.preventDefault();
43
- const focusFunc = e.shiftKey ? getPreviousFocusable : getNextFocusable;
44
- const elem = focusFunc(footerRef.current, true, true, false, true);
45
-
46
- if (elem) {
47
- // Focus on next focusable element
48
- elem.focus();
49
- } else if (e.shiftKey) {
50
- // We are at the beginning of the list, refocus on search bar
51
- searchFieldComponent.focus();
52
- } else {
53
- // We are at the end of the list, move onto next focusable element in page
54
- getNextFocusable(searchFieldComponent, false).focus();
55
- }
56
- }
57
- });
32
+ const listRef = useCallback(node => setListElement(node), []);
33
+ const triggerComponentRef = useCallback(node => setTriggerElement(node), []);
34
+ const footerRef = useCallback(node => setFooterElement(node), []);
35
+ const headerRef = useCallback(node => setHeaderElement(node), []);
58
36
 
59
- footer.setAttribute('hasListener', 'true');
60
- }
61
-
62
- // SET UP HANDLERS
63
- const searchFieldKeyDownHandler = e => {
64
- if (e.code === UP_ARROW) {
65
- const elem = getLastFocusable(listRef.current, true, true);
66
- if (elem) {
67
- elem.focus();
68
- }
69
- }
70
-
71
- if (e.code === DOWN_ARROW) {
72
- const elem = getFirstFocusable(listRef.current, true, true);
73
- if (elem) {
74
- elem.focus();
37
+ useEffect(() => {
38
+ const configs = [
39
+ // --- HEADER CONFIG ---
40
+ {
41
+ element: header,
42
+ allowTabThroughContents: true,
43
+ previousElement: trigger,
44
+ nextElement: (footer && getFirstFocusable(footer)) ?? getNextFocusable(trigger, false),
45
+ downElement: list && getFirstFocusable(list),
46
+ upElement: list && getLastFocusable(list),
47
+ },
48
+ // --- FOOTER CONFIG ---
49
+ {
50
+ element: footer,
51
+ allowTabThroughContents: true,
52
+ previousElement: (header && getLastFocusable(header)) ?? trigger,
53
+ nextElement: getNextFocusable(trigger, false),
54
+ downElement: list && getFirstFocusable(list),
55
+ upElement: list && getLastFocusable(list),
56
+ },
57
+ // --- LIST/CONTAINER CONFIG ---
58
+ {
59
+ element: list,
60
+ allowUpDownThroughContents: true,
61
+ previousElement: (header && getLastFocusable(header)) ?? trigger,
62
+ nextElement: (footer && getFirstFocusable(footer)) ?? getNextFocusable(trigger, false)
63
+ },
64
+ // --- TRIGGER CONFIG ---
65
+ {
66
+ element: trigger,
67
+ nextElement: (header && getFirstFocusable(header)) ?? (footer && getFirstFocusable(footer)) ?? getNextFocusable(trigger, false),
68
+ previousElement: getPreviousFocusable(trigger, false),
69
+ downElement: list && getFirstFocusable(list),
70
+ upElement: list && getLastFocusable(list),
75
71
  }
76
- }
72
+ ].filter(c => c.element); // Filter out configs where the element (e.g., header) is null
73
+
74
+ const cleanups = [];
75
+ const setupListener = (config) => {
76
+ const handler = (e) => {
77
+ if (e.code === TAB) {
78
+ e.preventDefault();
79
+ if (config.allowTabThroughContents) {
80
+ const focusFunc = e.shiftKey ? getPreviousFocusable : getNextFocusable;
81
+ const elem = focusFunc(config.element, true, true, false, true);
82
+
83
+ if (elem) {
84
+ // Focus on next focusable element
85
+ elem.focus();
86
+ } else if (e.shiftKey) {
87
+ // We are at the beginning of the list moving backwards, focus on the previous element
88
+ config.previousElement.focus();
89
+ } else {
90
+ // We are at the end of the list, move onto next focusable element in page
91
+ config.nextElement.focus();
92
+ }
93
+ } else if (e.shiftKey) {
94
+ config.previousElement.focus();
95
+ } else {
96
+ config.nextElement.focus();
97
+ }
98
+ } else if (e.code === DOWN_ARROW || e.code === UP_ARROW) {
99
+ e.preventDefault();
100
+ // Prevent the default behaviour
101
+ e.preventDefault();
102
+
103
+ if (config.allowUpDownThroughContents) {
104
+ const focusFunc = e.code === UP_ARROW ? getPreviousFocusable : getNextFocusable;
105
+ const elem = focusFunc(config.element, true, true, true, true); // Allow looping through elements
106
+ if (elem) {
107
+ elem.focus();
108
+ }
109
+ } else if (e.code === UP_ARROW) {
110
+ config.upElement.focus();
111
+ } else {
112
+ config.downElement.focus();
113
+ }
114
+ }
115
+ };
77
116
 
78
- // Tab key (But not while shifting)
79
- if (e.code === TAB && !e.shiftKey) {
80
- e.preventDefault();
81
- // If we have focusable elements in the footer, then focus on them, else unfocus searchbar
82
- const elem = getNextFocusable(footerRef.current, true, true, true, true);
83
- if (elem) {
84
- elem.focus();
85
- } else {
86
- getNextFocusable(searchFieldComponent, false).focus();
87
- }
88
- }
89
- };
117
+ // Add event listener and add the removal of said event listener to the cleanup function
118
+ config.element.addEventListener('keydown', handler);
119
+ cleanups.push(() => config.element.removeEventListener('keydown', handler));
120
+ };
90
121
 
91
- const listKeyDownHandler = e => {
92
- if (e.code === DOWN_ARROW) {
93
- const elem = getNextFocusable(listRef.current, true, true);
94
- elem.focus();
95
- }
122
+ // Setup the event listener for each config entry
123
+ configs.forEach(setupListener);
96
124
 
97
- if (e.code === UP_ARROW) {
98
- const elem = getPreviousFocusable(listRef.current, true, true);
99
- elem.focus();
100
- }
125
+ // Cleanup any event listeners
126
+ return () => {
127
+ cleanups.forEach(cleanup => cleanup());
128
+ };
101
129
 
102
- if (e.code === TAB) {
103
- e.preventDefault();
104
- let elem;
105
- if (!e.shiftKey && !footerRef.current) {
106
- elem = getNextFocusable(searchFieldComponent, false);
107
- } else if (!e.shiftKey) {
108
- elem = getNextFocusable(footerRef.current, true, true, true, true);
109
- } else {
110
- elem = searchFieldComponent;
111
- }
112
- elem.focus();
113
- }
114
- };
130
+ // Re-add the listener ANY time any of the elements changes (this is why we're using callback refs)
131
+ }, [header, trigger, footer, list]);
115
132
 
116
- const handleNextFocus = () => getNextFocusable(searchFieldComponent, false).focus();
133
+ // TODO is this still necessary?
134
+ const handleNextFocus = () => getNextFocusable(trigger, false).focus();
117
135
 
118
136
  // SET UP VARIABLES
119
137
  const { open } = useTypedownToggle(name);
@@ -139,13 +157,13 @@ const useTypedown = (
139
157
  refs: {
140
158
  listRef,
141
159
  triggerRef,
160
+ triggerComponentRef,
142
161
  overlayRef,
143
- footerRef
162
+ footerRef,
163
+ headerRef
144
164
  },
145
165
  handlers: {
146
166
  handleNextFocus,
147
- listKeyDownHandler,
148
- searchFieldKeyDownHandler
149
167
  },
150
168
  variables: {
151
169
  open: useOpen ? open : false,
@@ -121,3 +121,7 @@ div[class^="overlay"][x-out-of-boundaries=""] > div[class^="dropdownMenu"] > div
121
121
  .footer {
122
122
  padding: var(--gutter-static-one-third) var(--gutter-static-two-thirds)
123
123
  }
124
+
125
+ .header {
126
+ padding: var(--gutter-static-one-third) var(--gutter-static-two-thirds)
127
+ }