@databiosphere/findable-ui 22.0.0 → 24.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (343) hide show
  1. package/.release-please-manifest.json +1 -1
  2. package/.storybook/preview.js +4 -37
  3. package/CHANGELOG.md +53 -0
  4. package/jest.config.js +1 -0
  5. package/lib/common/selectors.d.ts +6 -2
  6. package/lib/common/selectors.js +7 -2
  7. package/lib/components/DataDictionary/components/Entities/constants.d.ts +1 -0
  8. package/lib/components/DataDictionary/components/Entities/constants.js +2 -1
  9. package/lib/components/DataDictionary/components/Entities/entities.d.ts +1 -1
  10. package/lib/components/DataDictionary/components/Entities/entities.js +2 -2
  11. package/lib/components/DataDictionary/components/Entities/types.d.ts +2 -0
  12. package/lib/components/DataDictionary/components/Entity/entity.d.ts +1 -1
  13. package/lib/components/DataDictionary/components/Entity/entity.js +9 -4
  14. package/lib/components/DataDictionary/components/Entity/entity.styles.d.ts +2 -0
  15. package/lib/components/DataDictionary/components/Entity/entity.styles.js +10 -0
  16. package/lib/components/DataDictionary/components/Entity/types.d.ts +2 -0
  17. package/lib/components/DataDictionary/components/Layout/components/EntitiesLayout/entitiesLayout.d.ts +2 -0
  18. package/lib/components/DataDictionary/components/Layout/components/EntitiesLayout/entitiesLayout.js +5 -0
  19. package/lib/components/DataDictionary/components/Layout/components/EntitiesLayout/entitiesLayout.styles.d.ts +5 -0
  20. package/lib/components/DataDictionary/components/Layout/components/EntitiesLayout/entitiesLayout.styles.js +19 -0
  21. package/lib/components/DataDictionary/components/Layout/components/EntitiesLayout/types.d.ts +5 -0
  22. package/lib/components/DataDictionary/components/Layout/components/EntitiesLayout/types.js +1 -0
  23. package/lib/components/DataDictionary/components/Layout/components/OutlineLayout/outlineLayout.d.ts +2 -0
  24. package/lib/components/DataDictionary/components/Layout/components/OutlineLayout/outlineLayout.js +6 -0
  25. package/lib/components/DataDictionary/components/Layout/components/OutlineLayout/outlineLayout.styles.d.ts +9 -0
  26. package/lib/components/DataDictionary/components/Layout/components/OutlineLayout/outlineLayout.styles.js +26 -0
  27. package/lib/components/DataDictionary/components/Layout/components/OutlineLayout/types.d.ts +5 -0
  28. package/lib/components/DataDictionary/components/Layout/components/OutlineLayout/types.js +1 -0
  29. package/lib/components/DataDictionary/components/Layout/components/TitleLayout/titleLayout.d.ts +2 -0
  30. package/lib/components/DataDictionary/components/Layout/components/TitleLayout/titleLayout.js +5 -0
  31. package/lib/components/DataDictionary/components/Layout/components/TitleLayout/titleLayout.styles.d.ts +5 -0
  32. package/lib/components/DataDictionary/components/Layout/components/TitleLayout/titleLayout.styles.js +16 -0
  33. package/lib/components/DataDictionary/components/Layout/components/TitleLayout/types.d.ts +5 -0
  34. package/lib/components/DataDictionary/components/Layout/components/TitleLayout/types.js +1 -0
  35. package/lib/components/DataDictionary/components/Layout/constants.d.ts +5 -0
  36. package/lib/components/DataDictionary/components/Layout/constants.js +5 -0
  37. package/lib/components/DataDictionary/components/Outline/components/ContentsTab/constants.d.ts +2 -0
  38. package/lib/components/DataDictionary/components/Outline/components/ContentsTab/constants.js +5 -0
  39. package/lib/components/DataDictionary/components/Outline/components/ContentsTab/contentsTab.d.ts +1 -0
  40. package/lib/components/DataDictionary/components/Outline/components/ContentsTab/contentsTab.js +6 -0
  41. package/lib/components/DataDictionary/components/Outline/components/ContentsTab/contentsTab.styles.d.ts +3 -0
  42. package/lib/components/DataDictionary/components/Outline/components/ContentsTab/contentsTab.styles.js +7 -0
  43. package/lib/components/DataDictionary/components/Outline/outline.d.ts +2 -0
  44. package/lib/components/DataDictionary/components/Outline/outline.js +6 -0
  45. package/lib/components/DataDictionary/components/Outline/outline.styles.d.ts +3 -0
  46. package/lib/components/DataDictionary/components/Outline/outline.styles.js +19 -0
  47. package/lib/components/DataDictionary/components/Outline/types.d.ts +5 -0
  48. package/lib/components/DataDictionary/components/Outline/types.js +1 -0
  49. package/lib/components/DataDictionary/components/Outline/utils.d.ts +8 -0
  50. package/lib/components/DataDictionary/components/Outline/utils.js +15 -0
  51. package/lib/components/DataDictionary/components/Table/components/BasicCell/basicCell.js +2 -2
  52. package/lib/components/DataDictionary/components/Title/title.d.ts +2 -0
  53. package/lib/components/DataDictionary/components/Title/title.js +3 -0
  54. package/lib/components/DataDictionary/components/Title/title.styles.d.ts +3 -0
  55. package/lib/components/DataDictionary/components/Title/title.styles.js +17 -0
  56. package/lib/components/DataDictionary/dataDictionary.d.ts +2 -2
  57. package/lib/components/DataDictionary/dataDictionary.js +17 -3
  58. package/lib/components/DataDictionary/dataDictionary.styles.d.ts +5 -1
  59. package/lib/components/DataDictionary/dataDictionary.styles.js +16 -3
  60. package/lib/components/DataDictionary/hooks/UseDataDictionary/hook.js +2 -1
  61. package/lib/components/DataDictionary/hooks/UseLayoutSpacing/hook.d.ts +2 -0
  62. package/lib/components/DataDictionary/hooks/UseLayoutSpacing/hook.js +10 -0
  63. package/lib/components/DataDictionary/hooks/UseLayoutSpacing/types.d.ts +7 -0
  64. package/lib/components/DataDictionary/hooks/UseLayoutSpacing/types.js +1 -0
  65. package/lib/components/DataDictionary/types.d.ts +9 -0
  66. package/lib/components/DataDictionary/types.js +1 -0
  67. package/lib/components/Error/error.js +3 -3
  68. package/lib/components/Export/components/ExportForm/exportForm.styles.d.ts +2 -2
  69. package/lib/components/Filter/components/FilterLabel/filterLabel.styles.d.ts +1 -1
  70. package/lib/components/Filter/components/SearchAllFilters/searchAllFilters.js +3 -3
  71. package/lib/components/Index/index.js +3 -4
  72. package/lib/components/Layout/components/ContentLayout/contentLayout.js +7 -7
  73. package/lib/components/Layout/components/Footer/footer.js +4 -1
  74. package/lib/components/Layout/components/Footer/footer.styles.js +1 -0
  75. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/authenticationMenu.styles.d.ts +1 -1
  76. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/Button/button.styles.d.ts +1 -1
  77. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Search/components/Button/button.styles.d.ts +1 -1
  78. package/lib/components/Layout/components/Header/header.js +4 -3
  79. package/lib/components/Layout/components/Main/main.js +3 -4
  80. package/lib/components/Layout/components/Outline/components/ContentsTab/contentsTab.d.ts +1 -5
  81. package/lib/components/Layout/components/Outline/components/ContentsTab/contentsTab.js +5 -3
  82. package/lib/components/Layout/components/Outline/components/ContentsTab/contentsTab.styles.d.ts +1 -1
  83. package/lib/components/Layout/components/Outline/components/ContentsTab/contentsTab.styles.js +2 -2
  84. package/lib/components/Layout/components/Outline/components/ContentsTab/types.d.ts +5 -0
  85. package/lib/components/Layout/components/Outline/components/ContentsTab/types.js +1 -0
  86. package/lib/components/Layout/components/Outline/hooks/UseHash/hook.d.ts +11 -0
  87. package/lib/components/Layout/components/Outline/hooks/UseHash/hook.js +16 -0
  88. package/lib/components/Layout/components/Outline/hooks/UseHash/types.d.ts +3 -0
  89. package/lib/components/Layout/components/Outline/hooks/UseHash/types.js +1 -0
  90. package/lib/components/Layout/components/Outline/hooks/UseTabs/constants.d.ts +2 -0
  91. package/lib/components/Layout/components/Outline/hooks/UseTabs/hook.d.ts +3 -0
  92. package/lib/components/Layout/components/Outline/hooks/UseTabs/hook.js +24 -0
  93. package/lib/components/Layout/components/Outline/hooks/UseTabs/utils.d.ts +9 -0
  94. package/lib/components/Layout/components/Outline/hooks/UseTabs/utils.js +13 -0
  95. package/lib/components/Layout/components/Outline/outline.d.ts +2 -13
  96. package/lib/components/Layout/components/Outline/outline.js +8 -32
  97. package/lib/components/Layout/components/Outline/outline.styles.d.ts +3 -3
  98. package/lib/components/Layout/components/Outline/outline.styles.js +2 -2
  99. package/lib/components/Layout/components/Outline/types.d.ts +14 -0
  100. package/lib/components/Layout/components/Outline/types.js +1 -0
  101. package/lib/components/Layout/components/Sidebar/components/SidebarPositioner/sidebarPositioner.js +4 -4
  102. package/lib/components/Loading/loading.stories.d.ts +3 -31
  103. package/lib/components/Login/components/Button/button.styles.d.ts +1 -1
  104. package/lib/components/Login/components/Section/components/Warning/warning.js +2 -3
  105. package/lib/components/Stepper/components/Step/components/StepContent/stepContent.d.ts +3 -0
  106. package/lib/components/Stepper/components/Step/components/StepContent/stepContent.js +7 -0
  107. package/lib/components/Stepper/components/Step/components/StepContent/stepContent.styles.d.ts +3 -0
  108. package/lib/components/Stepper/components/Step/components/StepContent/stepContent.styles.js +17 -0
  109. package/lib/components/Stepper/components/Step/components/StepIcon/components/CompletedIcon/completedIcon.d.ts +2 -0
  110. package/lib/components/Stepper/components/Step/components/StepIcon/components/CompletedIcon/completedIcon.js +8 -0
  111. package/lib/components/Stepper/components/Step/components/StepIcon/components/CompletedIcon/completedIcon.styles.d.ts +5 -0
  112. package/lib/components/Stepper/components/Step/components/StepIcon/components/CompletedIcon/completedIcon.styles.js +15 -0
  113. package/lib/components/Stepper/components/Step/components/StepIcon/components/CompletedIcon/contants.d.ts +2 -0
  114. package/lib/components/Stepper/components/Step/components/StepIcon/components/CompletedIcon/contants.js +4 -0
  115. package/lib/components/Stepper/components/Step/components/StepIcon/constants.d.ts +1 -0
  116. package/lib/components/Stepper/components/Step/components/StepIcon/constants.js +1 -0
  117. package/lib/components/Stepper/components/Step/components/StepIcon/stepIcon.d.ts +3 -0
  118. package/lib/components/Stepper/components/Step/components/StepIcon/stepIcon.js +6 -0
  119. package/lib/components/Stepper/components/Step/components/StepIcon/stepIcon.styles.d.ts +3 -0
  120. package/lib/components/Stepper/components/Step/components/StepIcon/stepIcon.styles.js +27 -0
  121. package/lib/components/Stepper/components/Step/components/StepIcon/stories/stepIcon.stories.d.ts +9 -0
  122. package/lib/components/Stepper/components/Step/components/StepIcon/stories/stepIcon.stories.js +38 -0
  123. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/components/Icon/constants.d.ts +3 -0
  124. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/components/Icon/constants.js +11 -0
  125. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/components/Icon/icon.d.ts +2 -0
  126. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/components/Icon/icon.js +9 -0
  127. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/components/Icon/stories/contants.d.ts +3 -0
  128. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/components/Icon/stories/contants.js +3 -0
  129. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/components/Icon/stories/icon.stories.d.ts +6 -0
  130. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/components/Icon/stories/icon.stories.js +20 -0
  131. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/components/Icon/types.d.ts +7 -0
  132. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/components/Icon/types.js +1 -0
  133. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/constants.d.ts +2 -0
  134. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/constants.js +6 -0
  135. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/label.d.ts +2 -0
  136. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/label.js +6 -0
  137. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/label.styles.d.ts +5 -0
  138. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/label.styles.js +7 -0
  139. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/stories/label.stories.d.ts +7 -0
  140. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/stories/label.stories.js +21 -0
  141. package/lib/components/Stepper/components/Step/components/StepLabel/components/Optional/constants.d.ts +2 -0
  142. package/lib/components/Stepper/components/Step/components/StepLabel/components/Optional/constants.js +5 -0
  143. package/lib/components/Stepper/components/Step/components/StepLabel/components/Optional/optional.d.ts +2 -0
  144. package/lib/components/Stepper/components/Step/components/StepLabel/components/Optional/optional.js +6 -0
  145. package/lib/components/Stepper/components/Step/components/StepLabel/constants.d.ts +2 -0
  146. package/lib/components/Stepper/components/Step/components/StepLabel/constants.js +8 -0
  147. package/lib/components/Stepper/components/Step/components/StepLabel/stepLabel.d.ts +2 -0
  148. package/lib/components/Stepper/components/Step/components/StepLabel/stepLabel.js +6 -0
  149. package/lib/components/Stepper/components/Step/components/StepLabel/stepLabel.styles.d.ts +3 -0
  150. package/lib/components/Stepper/components/Step/components/StepLabel/stepLabel.styles.js +12 -0
  151. package/lib/components/Stepper/components/Step/components/StepLabel/stories/contants.d.ts +4 -0
  152. package/lib/components/Stepper/components/Step/components/StepLabel/stories/contants.js +15 -0
  153. package/lib/components/Stepper/components/Step/components/StepLabel/stories/stepLabel.stories.d.ts +8 -0
  154. package/lib/components/Stepper/components/Step/components/StepLabel/stories/stepLabel.stories.js +37 -0
  155. package/lib/components/Stepper/components/Step/constants.d.ts +2 -0
  156. package/lib/components/Stepper/components/Step/constants.js +4 -0
  157. package/lib/components/Stepper/components/Step/step.d.ts +3 -0
  158. package/lib/components/Stepper/components/Step/step.js +6 -0
  159. package/lib/components/Stepper/components/Step/step.styles.d.ts +5 -0
  160. package/lib/components/Stepper/components/Step/step.styles.js +31 -0
  161. package/lib/components/Stepper/components/Step/stories/contants.d.ts +4 -0
  162. package/lib/components/Stepper/components/Step/stories/contants.js +14 -0
  163. package/lib/components/Stepper/components/Step/stories/step.stories.d.ts +8 -0
  164. package/lib/components/Stepper/components/Step/stories/step.stories.js +62 -0
  165. package/lib/components/Table/components/TableCell/components/RowPositionCell/constants.js +2 -2
  166. package/lib/components/common/AnchorLink/anchorLink.d.ts +6 -0
  167. package/lib/components/common/Form/components/Input/input.styles.d.ts +1 -1
  168. package/lib/components/common/Form/components/Select/select.js +2 -1
  169. package/lib/components/common/Form/components/Select/select.styles.d.ts +1 -1
  170. package/lib/components/common/Input/input.styles.d.ts +1 -1
  171. package/lib/components/common/KeyValuePairs/components/KeyElType/keyElType.d.ts +2 -5
  172. package/lib/components/common/KeyValuePairs/components/KeyElType/keyElType.js +6 -2
  173. package/lib/components/common/KeyValuePairs/components/ValueElType/valueElType.d.ts +2 -5
  174. package/lib/components/common/KeyValuePairs/components/ValueElType/valueElType.js +6 -2
  175. package/lib/components/common/LoginDialog/constants.js +4 -4
  176. package/lib/providers/layoutDimensions/constants.d.ts +2 -0
  177. package/lib/providers/layoutDimensions/constants.js +4 -0
  178. package/lib/providers/layoutDimensions/context.d.ts +2 -0
  179. package/lib/providers/layoutDimensions/context.js +7 -0
  180. package/lib/providers/layoutDimensions/hook.d.ts +2 -0
  181. package/lib/providers/layoutDimensions/hook.js +5 -0
  182. package/lib/providers/layoutDimensions/provider.d.ts +2 -0
  183. package/lib/providers/layoutDimensions/provider.js +14 -0
  184. package/lib/providers/layoutDimensions/types.d.ts +14 -0
  185. package/lib/providers/layoutDimensions/types.js +1 -0
  186. package/lib/storybook/controls/constants.d.ts +4 -0
  187. package/lib/storybook/controls/constants.js +6 -0
  188. package/lib/storybook/controls/types.d.ts +4 -0
  189. package/lib/storybook/controls/types.js +5 -0
  190. package/lib/storybook/controls/utils.d.ts +9 -0
  191. package/lib/storybook/controls/utils.js +10 -0
  192. package/lib/storybook/decorators.d.ts +2 -0
  193. package/lib/storybook/decorators.js +11 -0
  194. package/lib/storybook/loremIpsum.d.ts +4 -0
  195. package/lib/storybook/loremIpsum.js +4 -0
  196. package/lib/storybook/parameters.d.ts +2 -0
  197. package/lib/storybook/parameters.js +12 -0
  198. package/lib/styles/common/mui/stepper.d.ts +7 -0
  199. package/lib/styles/common/mui/stepper.js +7 -0
  200. package/lib/styles/common/mui/svgIcon.d.ts +9 -0
  201. package/lib/styles/common/mui/svgIcon.js +26 -0
  202. package/lib/styles/common/mui/tab.d.ts +7 -0
  203. package/lib/styles/common/mui/tab.js +9 -0
  204. package/lib/styles/common/mui/tabs.d.ts +9 -0
  205. package/lib/styles/common/mui/tabs.js +11 -0
  206. package/lib/styles/common/mui/typography.d.ts +8 -2
  207. package/lib/styles/common/mui/typography.js +9 -2
  208. package/lib/tests/mui/constants.d.ts +4 -0
  209. package/lib/tests/mui/constants.js +4 -0
  210. package/lib/theme/common/components.js +0 -4
  211. package/lib/theme/common/typography.d.ts +5 -1
  212. package/lib/theme/common/typography.js +10 -1
  213. package/lib/theme/theme.js +1 -0
  214. package/lib/utils/tests.d.ts +12 -0
  215. package/lib/utils/tests.js +20 -0
  216. package/package.json +1 -1
  217. package/src/common/selectors.ts +6 -3
  218. package/src/components/DataDictionary/components/Entities/constants.ts +3 -1
  219. package/src/components/DataDictionary/components/Entities/entities.tsx +2 -2
  220. package/src/components/DataDictionary/components/Entities/types.ts +2 -0
  221. package/src/components/DataDictionary/components/Entity/entity.styles.ts +12 -0
  222. package/src/components/DataDictionary/components/Entity/entity.tsx +17 -7
  223. package/src/components/DataDictionary/components/Entity/types.ts +2 -0
  224. package/src/components/DataDictionary/components/Layout/components/EntitiesLayout/entitiesLayout.styles.ts +22 -0
  225. package/src/components/DataDictionary/components/Layout/components/EntitiesLayout/entitiesLayout.tsx +10 -0
  226. package/src/components/DataDictionary/components/Layout/components/EntitiesLayout/types.ts +6 -0
  227. package/src/components/DataDictionary/components/Layout/components/OutlineLayout/outlineLayout.styles.ts +31 -0
  228. package/src/components/DataDictionary/components/Layout/components/OutlineLayout/outlineLayout.tsx +14 -0
  229. package/src/components/DataDictionary/components/Layout/components/OutlineLayout/types.ts +6 -0
  230. package/src/components/DataDictionary/components/Layout/components/TitleLayout/titleLayout.styles.ts +18 -0
  231. package/src/components/DataDictionary/components/Layout/components/TitleLayout/titleLayout.tsx +10 -0
  232. package/src/components/DataDictionary/components/Layout/components/TitleLayout/types.ts +6 -0
  233. package/src/components/DataDictionary/components/Layout/constants.ts +5 -0
  234. package/src/components/DataDictionary/components/Outline/components/ContentsTab/constants.ts +7 -0
  235. package/src/components/DataDictionary/components/Outline/components/ContentsTab/contentsTab.styles.ts +8 -0
  236. package/src/components/DataDictionary/components/Outline/components/ContentsTab/contentsTab.tsx +7 -0
  237. package/src/components/DataDictionary/components/Outline/outline.styles.ts +24 -0
  238. package/src/components/DataDictionary/components/Outline/outline.tsx +11 -0
  239. package/src/components/DataDictionary/components/Outline/types.ts +6 -0
  240. package/src/components/DataDictionary/components/Outline/utils.ts +18 -0
  241. package/src/components/DataDictionary/components/Table/components/BasicCell/basicCell.tsx +6 -2
  242. package/src/components/DataDictionary/components/Title/title.styles.ts +18 -0
  243. package/src/components/DataDictionary/components/Title/title.tsx +8 -0
  244. package/src/components/DataDictionary/dataDictionary.styles.ts +17 -3
  245. package/src/components/DataDictionary/dataDictionary.tsx +26 -4
  246. package/src/components/DataDictionary/hooks/UseDataDictionary/hook.ts +2 -1
  247. package/src/components/DataDictionary/hooks/UseLayoutSpacing/hook.ts +12 -0
  248. package/src/components/DataDictionary/hooks/UseLayoutSpacing/types.ts +8 -0
  249. package/src/components/DataDictionary/types.ts +10 -0
  250. package/src/components/Error/error.tsx +3 -5
  251. package/src/components/Filter/components/SearchAllFilters/searchAllFilters.tsx +3 -3
  252. package/src/components/Index/index.tsx +3 -4
  253. package/src/components/Layout/components/ContentLayout/contentLayout.tsx +7 -9
  254. package/src/components/Layout/components/Footer/footer.styles.ts +1 -0
  255. package/src/components/Layout/components/Footer/footer.tsx +5 -0
  256. package/src/components/Layout/components/Header/header.tsx +9 -3
  257. package/src/components/Layout/components/Main/main.tsx +3 -4
  258. package/src/components/Layout/components/Outline/components/ContentsTab/contentsTab.styles.ts +2 -2
  259. package/src/components/Layout/components/Outline/components/ContentsTab/contentsTab.tsx +8 -11
  260. package/src/components/Layout/components/Outline/components/ContentsTab/types.ts +8 -0
  261. package/src/components/Layout/components/Outline/hooks/UseHash/hook.ts +17 -0
  262. package/src/components/Layout/components/Outline/hooks/UseHash/types.ts +3 -0
  263. package/src/components/Layout/components/Outline/hooks/UseTabs/constants.ts +3 -0
  264. package/src/components/Layout/components/Outline/hooks/UseTabs/hook.ts +32 -0
  265. package/src/components/Layout/components/Outline/hooks/UseTabs/utils.ts +18 -0
  266. package/src/components/Layout/components/Outline/outline.styles.ts +2 -2
  267. package/src/components/Layout/components/Outline/outline.tsx +22 -59
  268. package/src/components/Layout/components/Outline/types.ts +16 -0
  269. package/src/components/Layout/components/Sidebar/components/SidebarPositioner/sidebarPositioner.tsx +7 -6
  270. package/src/components/Loading/loading.stories.tsx +2 -2
  271. package/src/components/Login/components/Section/components/Warning/warning.tsx +3 -4
  272. package/src/components/Stepper/components/Step/components/StepContent/stepContent.styles.ts +18 -0
  273. package/src/components/Stepper/components/Step/components/StepContent/stepContent.tsx +16 -0
  274. package/src/components/Stepper/components/Step/components/StepIcon/components/CompletedIcon/completedIcon.styles.ts +19 -0
  275. package/src/components/Stepper/components/Step/components/StepIcon/components/CompletedIcon/completedIcon.tsx +20 -0
  276. package/src/components/Stepper/components/Step/components/StepIcon/components/CompletedIcon/contants.ts +6 -0
  277. package/src/components/Stepper/components/Step/components/StepIcon/constants.ts +1 -0
  278. package/src/components/Stepper/components/Step/components/StepIcon/stepIcon.styles.ts +32 -0
  279. package/src/components/Stepper/components/Step/components/StepIcon/stepIcon.tsx +21 -0
  280. package/src/components/Stepper/components/Step/components/StepIcon/stories/stepIcon.stories.tsx +52 -0
  281. package/src/components/Stepper/components/Step/components/StepLabel/components/Label/components/Icon/constants.ts +14 -0
  282. package/src/components/Stepper/components/Step/components/StepLabel/components/Label/components/Icon/icon.tsx +13 -0
  283. package/src/components/Stepper/components/Step/components/StepLabel/components/Label/components/Icon/stories/contants.ts +6 -0
  284. package/src/components/Stepper/components/Step/components/StepLabel/components/Label/components/Icon/stories/icon.stories.tsx +30 -0
  285. package/src/components/Stepper/components/Step/components/StepLabel/components/Label/components/Icon/types.ts +8 -0
  286. package/src/components/Stepper/components/Step/components/StepLabel/components/Label/constants.ts +8 -0
  287. package/src/components/Stepper/components/Step/components/StepLabel/components/Label/label.styles.ts +8 -0
  288. package/src/components/Stepper/components/Step/components/StepLabel/components/Label/label.tsx +10 -0
  289. package/src/components/Stepper/components/Step/components/StepLabel/components/Label/stories/label.stories.tsx +31 -0
  290. package/src/components/Stepper/components/Step/components/StepLabel/components/Optional/constants.ts +7 -0
  291. package/src/components/Stepper/components/Step/components/StepLabel/components/Optional/optional.tsx +9 -0
  292. package/src/components/Stepper/components/Step/components/StepLabel/constants.ts +10 -0
  293. package/src/components/Stepper/components/Step/components/StepLabel/stepLabel.styles.ts +13 -0
  294. package/src/components/Stepper/components/Step/components/StepLabel/stepLabel.tsx +10 -0
  295. package/src/components/Stepper/components/Step/components/StepLabel/stories/contants.ts +19 -0
  296. package/src/components/Stepper/components/Step/components/StepLabel/stories/stepLabel.stories.tsx +48 -0
  297. package/src/components/Stepper/components/Step/constants.ts +6 -0
  298. package/src/components/Stepper/components/Step/step.styles.ts +33 -0
  299. package/src/components/Stepper/components/Step/step.tsx +12 -0
  300. package/src/components/Stepper/components/Step/stories/contants.ts +18 -0
  301. package/src/components/Stepper/components/Step/stories/step.stories.tsx +87 -0
  302. package/src/components/Table/components/TableCell/components/RowPositionCell/constants.ts +2 -2
  303. package/src/components/common/AnchorLink/anchorLink.tsx +7 -0
  304. package/src/components/common/Form/components/Select/select.tsx +8 -1
  305. package/src/components/common/KeyValuePairs/components/KeyElType/keyElType.tsx +14 -9
  306. package/src/components/common/KeyValuePairs/components/ValueElType/valueElType.tsx +8 -9
  307. package/src/components/common/LoginDialog/constants.ts +4 -4
  308. package/src/providers/layoutDimensions/constants.ts +6 -0
  309. package/src/providers/layoutDimensions/context.tsx +10 -0
  310. package/src/providers/layoutDimensions/hook.ts +7 -0
  311. package/src/providers/layoutDimensions/provider.tsx +29 -0
  312. package/src/providers/layoutDimensions/types.ts +17 -0
  313. package/src/storybook/controls/constants.ts +12 -0
  314. package/src/storybook/controls/types.ts +4 -0
  315. package/src/storybook/controls/utils.ts +18 -0
  316. package/src/storybook/decorators.tsx +17 -0
  317. package/src/storybook/loremIpsum.ts +5 -0
  318. package/src/storybook/parameters.ts +14 -0
  319. package/src/styles/common/mui/stepper.ts +14 -0
  320. package/src/styles/common/mui/svgIcon.ts +35 -0
  321. package/src/styles/common/mui/tab.ts +16 -0
  322. package/src/styles/common/mui/tabs.ts +20 -0
  323. package/src/styles/common/mui/typography.ts +15 -2
  324. package/src/tests/mui/constants.ts +4 -0
  325. package/src/theme/common/components.ts +0 -4
  326. package/src/theme/common/typography.ts +11 -0
  327. package/src/theme/theme.ts +1 -0
  328. package/src/utils/tests.ts +20 -0
  329. package/tests/setup.ts +6 -0
  330. package/tests/stepIcon.test.tsx +42 -0
  331. package/types/data-explorer-ui.d.ts +3 -0
  332. package/lib/components/Layout/components/Header/hooks/useMeasureHeader.d.ts +0 -5
  333. package/lib/components/Layout/components/Header/hooks/useMeasureHeader.js +0 -19
  334. package/lib/components/Layout/components/Outline/common/constants.d.ts +0 -2
  335. package/lib/hooks/useLayoutState.d.ts +0 -6
  336. package/lib/hooks/useLayoutState.js +0 -9
  337. package/lib/providers/layoutState.d.ts +0 -40
  338. package/lib/providers/layoutState.js +0 -47
  339. package/src/components/Layout/components/Header/hooks/useMeasureHeader.ts +0 -28
  340. package/src/components/Layout/components/Outline/common/constants.ts +0 -3
  341. package/src/hooks/useLayoutState.ts +0 -13
  342. package/src/providers/layoutState.tsx +0 -94
  343. /package/lib/components/Layout/components/Outline/{common → hooks/UseTabs}/constants.js +0 -0
@@ -1,7 +1,20 @@
1
- import { styled } from "@mui/material";
1
+ import { css } from "@emotion/react";
2
+ import styled from "@emotion/styled";
3
+ import { mediaTabletDown } from "../../styles/common/mixins/breakpoints";
4
+ export const grid = css `
5
+ column-gap: 24px;
6
+ display: grid;
7
+ grid-template-columns: 242px 1fr;
8
+ `;
2
9
  export const View = styled("div") `
10
+ ${grid};
3
11
  flex: 1;
4
12
  margin: 0 auto;
5
- max-width: calc(100vw - 48px);
6
- padding: 24px 0;
13
+ max-width: min(calc(100vw - 48px), 1392px);
14
+ position: relative;
15
+
16
+ ${mediaTabletDown} {
17
+ grid-template-columns: 1fr;
18
+ max-width: calc(100vw - 32px);
19
+ }
7
20
  `;
@@ -1,5 +1,6 @@
1
+ import { useMemo } from "react";
1
2
  import { useConfig } from "../../../../hooks/useConfig";
2
3
  export const useDataDictionary = () => {
3
4
  const { config: { dataDictionary: { classes = [] } = {} }, } = useConfig();
4
- return { classes };
5
+ return useMemo(() => ({ classes }), [classes]);
5
6
  };
@@ -0,0 +1,2 @@
1
+ import { UseLayoutSpacing } from "./types";
2
+ export declare const useLayoutSpacing: () => UseLayoutSpacing;
@@ -0,0 +1,10 @@
1
+ import { useLayoutDimensions } from "../../../../providers/layoutDimensions/hook";
2
+ export const useLayoutSpacing = () => {
3
+ const { dimensions } = useLayoutDimensions();
4
+ return {
5
+ spacing: {
6
+ bottom: dimensions.footer.height,
7
+ top: dimensions.header.height,
8
+ },
9
+ };
10
+ };
@@ -0,0 +1,7 @@
1
+ export interface LayoutSpacing {
2
+ bottom: number;
3
+ top: number;
4
+ }
5
+ export interface UseLayoutSpacing {
6
+ spacing: LayoutSpacing;
7
+ }
@@ -0,0 +1,9 @@
1
+ import { ElementType } from "react";
2
+ import { BaseComponentProps } from "../types";
3
+ export interface DataDictionaryProps extends BaseComponentProps {
4
+ EntitiesLayout?: ElementType;
5
+ Outline?: ElementType;
6
+ OutlineLayout?: ElementType;
7
+ Title?: ElementType;
8
+ TitleLayout?: ElementType;
9
+ }
@@ -0,0 +1 @@
1
+ export {};
@@ -2,8 +2,8 @@ import { Divider, Typography } from "@mui/material";
2
2
  import Link from "next/link";
3
3
  import React from "react";
4
4
  import { useExploreState } from "../../hooks/useExploreState";
5
- import { useLayoutState } from "../../hooks/useLayoutState";
6
5
  import { ExploreActionKind } from "../../providers/exploreState";
6
+ import { useLayoutDimensions } from "../../providers/layoutDimensions/hook";
7
7
  import { ButtonPrimary } from "../common/Button/components/ButtonPrimary/buttonPrimary";
8
8
  import { AlertIcon } from "../common/CustomIcon/components/AlertIcon/alertIcon";
9
9
  import { Grid } from "../common/Grid/grid";
@@ -17,7 +17,7 @@ const ErrorMessage = ({ detail, title, }) => (React.createElement(Content, null,
17
17
  React.createElement(ErrorCode, null, detail))));
18
18
  export const Error = ({ errorMessage, onReset, requestUrlMessage, rootPath, }) => {
19
19
  const { exploreDispatch } = useExploreState();
20
- const { layoutState: { headerHeight }, } = useLayoutState();
20
+ const { dimensions } = useLayoutDimensions();
21
21
  const handleToHomePageClicked = () => {
22
22
  onReset?.();
23
23
  exploreDispatch({
@@ -25,7 +25,7 @@ export const Error = ({ errorMessage, onReset, requestUrlMessage, rootPath, }) =
25
25
  type: ExploreActionKind.ResetState,
26
26
  });
27
27
  };
28
- return (React.createElement(ErrorLayout, { offset: headerHeight },
28
+ return (React.createElement(ErrorLayout, { offset: dimensions.header.height },
29
29
  React.createElement(CustomError, null,
30
30
  React.createElement(ErrorSection, null,
31
31
  React.createElement(StatusIcon, { priority: PRIORITY.HIGH, StatusIcon: AlertIcon }),
@@ -2,12 +2,12 @@ import { ThemeProps } from "../../../../theme/theme";
2
2
  export declare const margin: ({ theme }: ThemeProps) => import("@emotion/react").SerializedStyles;
3
3
  export declare const FormControl: import("@emotion/styled").StyledComponent<import("@mui/material").FormControlOwnProps & import("@mui/material/OverridableComponent").CommonProps & Omit<Omit<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "ref"> & {
4
4
  ref?: ((instance: HTMLDivElement | null) => void | import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES[keyof import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES]) | import("react").RefObject<HTMLDivElement> | null | undefined;
5
- }, "style" | "className" | "classes" | "color" | "children" | "margin" | "sx" | "variant" | "error" | "disabled" | "required" | "size" | "fullWidth" | "hiddenLabel" | "focused"> & {
5
+ }, "style" | "className" | "classes" | "color" | "children" | "margin" | "sx" | "variant" | "error" | "disabled" | "required" | "size" | "focused" | "fullWidth" | "hiddenLabel"> & {
6
6
  theme?: import("@emotion/react").Theme;
7
7
  }, {}, {}>;
8
8
  export declare const TableFormControl: import("@emotion/styled").StyledComponent<import("@mui/material").FormControlOwnProps & import("@mui/material/OverridableComponent").CommonProps & Omit<Omit<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "ref"> & {
9
9
  ref?: ((instance: HTMLDivElement | null) => void | import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES[keyof import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES]) | import("react").RefObject<HTMLDivElement> | null | undefined;
10
- }, "style" | "className" | "classes" | "color" | "children" | "margin" | "sx" | "variant" | "error" | "disabled" | "required" | "size" | "fullWidth" | "hiddenLabel" | "focused"> & {
10
+ }, "style" | "className" | "classes" | "color" | "children" | "margin" | "sx" | "variant" | "error" | "disabled" | "required" | "size" | "focused" | "fullWidth" | "hiddenLabel"> & {
11
11
  theme?: import("@emotion/react").Theme;
12
12
  }, {}, {}>;
13
13
  export declare const GridPaper: import("@emotion/styled").StyledComponent<{
@@ -3,7 +3,7 @@ interface Props {
3
3
  }
4
4
  export declare const FilterLabel: import("@emotion/styled").StyledComponent<import("@mui/material").ButtonOwnProps & Omit<import("@mui/material").ButtonBaseOwnProps, "classes"> & import("@mui/material/OverridableComponent").CommonProps & Omit<Omit<import("react").DetailedHTMLProps<import("react").ButtonHTMLAttributes<HTMLButtonElement>, HTMLButtonElement>, "ref"> & {
5
5
  ref?: ((instance: HTMLButtonElement | null) => void | import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES[keyof import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES]) | import("react").RefObject<HTMLButtonElement> | null | undefined;
6
- }, "style" | "className" | "classes" | "tabIndex" | "color" | "children" | "sx" | "variant" | "disabled" | "href" | "action" | "size" | "centerRipple" | "disableRipple" | "disableTouchRipple" | "focusRipple" | "focusVisibleClassName" | "LinkComponent" | "onFocusVisible" | "TouchRippleProps" | "touchRippleRef" | "fullWidth" | "disableElevation" | "disableFocusRipple" | "endIcon" | "startIcon"> & {
6
+ }, "style" | "className" | "classes" | "tabIndex" | "color" | "children" | "sx" | "variant" | "disabled" | "href" | "action" | "size" | "centerRipple" | "disableRipple" | "disableTouchRipple" | "focusRipple" | "focusVisibleClassName" | "LinkComponent" | "onFocusVisible" | "TouchRippleProps" | "touchRippleRef" | "disableElevation" | "disableFocusRipple" | "endIcon" | "fullWidth" | "startIcon"> & {
7
7
  theme?: import("@emotion/react").Theme;
8
8
  } & Props, {}, {}>;
9
9
  export {};
@@ -1,5 +1,5 @@
1
1
  import React, { createContext, useContext, useEffect, useRef, useState, } from "react";
2
- import { BODY, SIDEBAR_POSITIONER } from "../../../../common/selectors";
2
+ import { SELECTOR } from "../../../../common/selectors";
3
3
  import { BREAKPOINT_FN_NAME, useBreakpointHelper, } from "../../../../hooks/useBreakpointHelper";
4
4
  import { DESKTOP_SM } from "../../../../theme/common/breakpoints";
5
5
  import { SearchCloseButton } from "../SearchAllFiltersSearch/components/SearchCloseButton/searchCloseButton";
@@ -35,8 +35,8 @@ export const SearchAllFilters = ({ categoryViews, drawerOpen = false, onFilter,
35
35
  const handleBackgroundScroll = (overflowStyle) => {
36
36
  if (desktopSmUp) {
37
37
  setElementsOverflowStyle([
38
- document.querySelector(BODY),
39
- document.getElementById(SIDEBAR_POSITIONER),
38
+ document.querySelector(SELECTOR.BODY),
39
+ document.getElementById(SELECTOR.SIDEBAR_POSITIONER),
40
40
  ], overflowStyle);
41
41
  }
42
42
  };
@@ -1,11 +1,10 @@
1
1
  import React from "react";
2
- import { useLayoutState } from "../../hooks/useLayoutState";
2
+ import { useLayoutDimensions } from "../../providers/layoutDimensions/hook";
3
3
  import { Hero } from "./components/Hero/hero";
4
4
  import { Index as IndexLayout } from "./index.styles";
5
5
  export const Index = ({ className, List, ListHero, SideBarButton, SubTitleHero, Summaries, Tabs, title, }) => {
6
- const { layoutState } = useLayoutState();
7
- const { headerHeight } = layoutState;
8
- return (React.createElement(IndexLayout, { className: className, marginTop: headerHeight },
6
+ const { dimensions } = useLayoutDimensions();
7
+ return (React.createElement(IndexLayout, { className: className, marginTop: dimensions.header.height },
9
8
  React.createElement(Hero, { SideBarButton: SideBarButton, Summaries: Summaries, title: title }),
10
9
  SubTitleHero,
11
10
  Tabs,
@@ -1,18 +1,18 @@
1
1
  import { useRouter } from "next/router";
2
2
  import React from "react";
3
- import { useLayoutState } from "../../../../hooks/useLayoutState";
3
+ import { useLayoutDimensions } from "../../../../providers/layoutDimensions/hook";
4
4
  import { Content, ContentGrid, ContentLayout as Layout, Navigation, NavigationGrid, Outline, OutlineGrid, Positioner, } from "./contentLayout.styles";
5
5
  export const ContentLayout = ({ className, content, layoutStyle, navigation, outline, }) => {
6
6
  const { asPath } = useRouter();
7
- const { layoutState: { headerHeight }, } = useLayoutState();
7
+ const { dimensions } = useLayoutDimensions();
8
8
  return (React.createElement(Layout, { className: className, hasNavigation: Boolean(navigation), panelColor: layoutStyle?.content },
9
- navigation && (React.createElement(NavigationGrid, { headerHeight: headerHeight, panelColor: layoutStyle?.navigation },
10
- React.createElement(Positioner, { headerHeight: headerHeight },
9
+ navigation && (React.createElement(NavigationGrid, { headerHeight: dimensions.header.height, panelColor: layoutStyle?.navigation },
10
+ React.createElement(Positioner, { headerHeight: dimensions.header.height },
11
11
  React.createElement(Navigation, null, navigation)))),
12
- React.createElement(ContentGrid, { headerHeight: headerHeight, panelColor: layoutStyle?.content },
12
+ React.createElement(ContentGrid, { headerHeight: dimensions.header.height, panelColor: layoutStyle?.content },
13
13
  React.createElement(Content, null, content)),
14
- outline && (React.createElement(OutlineGrid, { key: getOutlineKey(asPath), headerHeight: headerHeight, panelColor: layoutStyle?.outline },
15
- React.createElement(Positioner, { headerHeight: headerHeight },
14
+ outline && (React.createElement(OutlineGrid, { key: getOutlineKey(asPath), headerHeight: dimensions.header.height, panelColor: layoutStyle?.outline },
15
+ React.createElement(Positioner, { headerHeight: dimensions.header.height },
16
16
  React.createElement(Outline, null, outline))))));
17
17
  };
18
18
  /**
@@ -1,11 +1,14 @@
1
1
  import { Toolbar } from "@mui/material";
2
2
  import React from "react";
3
+ import { SELECTOR } from "../../../../common/selectors";
4
+ import { useLayoutDimensions } from "../../../../providers/layoutDimensions/hook";
3
5
  import { ANCHOR_TARGET } from "../../../Links/common/entities";
4
6
  import { isNodeBoolean } from "../../../utils";
5
7
  import { VersionInfo } from "./components/VersionInfo/versionInfo";
6
8
  import { AppBar, Link, Links, Socials } from "./footer.styles";
7
9
  export const Footer = ({ Branding, className, navLinks, socials, versionInfo, }) => {
8
- return (React.createElement(AppBar, { className: className, color: "inherit", component: "footer", variant: "footer" },
10
+ const { footerRef } = useLayoutDimensions();
11
+ return (React.createElement(AppBar, { className: className, color: "inherit", component: "footer", id: SELECTOR.FOOTER, ref: footerRef, variant: "footer" },
9
12
  React.createElement(Toolbar, { variant: "dense" },
10
13
  Branding,
11
14
  (navLinks || socials || versionInfo) && (React.createElement(Links, null,
@@ -7,6 +7,7 @@ import { Socials as DXSocials } from "../../../common/Socials/socials";
7
7
  import { Link as DXLink } from "../../../Links/components/Link/link";
8
8
  export const AppBar = styled(MAppBar) `
9
9
  padding: 16px 0;
10
+ z-index: 1; /* required for outline or navigation overflow */
10
11
 
11
12
  .MuiToolbar-root {
12
13
  align-items: flex-start;
@@ -18,6 +18,6 @@ export declare const UserNames: import("@emotion/styled").StyledComponent<import
18
18
  }, {}, {}>;
19
19
  export declare const StyledAvatar: import("@emotion/styled").StyledComponent<import("@mui/material").AvatarOwnProps & import("@mui/material").AvatarSlotsAndSlotProps & import("@mui/material/OverridableComponent").CommonProps & Omit<Omit<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "ref"> & {
20
20
  ref?: ((instance: HTMLDivElement | null) => void | import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES[keyof import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES]) | import("react").RefObject<HTMLDivElement> | null | undefined;
21
- }, "style" | "className" | "classes" | "children" | "sx" | "variant" | "alt" | "src" | "sizes" | "srcSet" | "slotProps" | "slots" | "imgProps"> & {
21
+ }, "style" | "className" | "classes" | "children" | "sx" | "variant" | "alt" | "src" | "sizes" | "srcSet" | "slots" | "slotProps" | "imgProps"> & {
22
22
  theme?: import("@emotion/react").Theme;
23
23
  }, {}, {}>;
@@ -1,5 +1,5 @@
1
1
  export declare const StyledButton: import("@emotion/styled").StyledComponent<import("@mui/material").ButtonOwnProps & Omit<import("@mui/material").ButtonBaseOwnProps, "classes"> & import("@mui/material/OverridableComponent").CommonProps & Omit<Omit<import("react").DetailedHTMLProps<import("react").ButtonHTMLAttributes<HTMLButtonElement>, HTMLButtonElement>, "ref"> & {
2
2
  ref?: ((instance: HTMLButtonElement | null) => void | import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES[keyof import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES]) | import("react").RefObject<HTMLButtonElement> | null | undefined;
3
- }, "style" | "className" | "classes" | "tabIndex" | "color" | "children" | "sx" | "variant" | "disabled" | "href" | "action" | "size" | "centerRipple" | "disableRipple" | "disableTouchRipple" | "focusRipple" | "focusVisibleClassName" | "LinkComponent" | "onFocusVisible" | "TouchRippleProps" | "touchRippleRef" | "fullWidth" | "disableElevation" | "disableFocusRipple" | "endIcon" | "startIcon"> & {
3
+ }, "style" | "className" | "classes" | "tabIndex" | "color" | "children" | "sx" | "variant" | "disabled" | "href" | "action" | "size" | "centerRipple" | "disableRipple" | "disableTouchRipple" | "focusRipple" | "focusVisibleClassName" | "LinkComponent" | "onFocusVisible" | "TouchRippleProps" | "touchRippleRef" | "disableElevation" | "disableFocusRipple" | "endIcon" | "fullWidth" | "startIcon"> & {
4
4
  theme?: import("@emotion/react").Theme;
5
5
  }, {}, {}>;
@@ -1,5 +1,5 @@
1
1
  export declare const StyledButton: import("@emotion/styled").StyledComponent<import("@mui/material").ButtonOwnProps & Omit<import("@mui/material").ButtonBaseOwnProps, "classes"> & import("@mui/material/OverridableComponent").CommonProps & Omit<Omit<import("react").DetailedHTMLProps<import("react").ButtonHTMLAttributes<HTMLButtonElement>, HTMLButtonElement>, "ref"> & {
2
2
  ref?: ((instance: HTMLButtonElement | null) => void | import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES[keyof import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES]) | import("react").RefObject<HTMLButtonElement> | null | undefined;
3
- }, "style" | "className" | "classes" | "tabIndex" | "color" | "children" | "sx" | "variant" | "disabled" | "href" | "action" | "size" | "centerRipple" | "disableRipple" | "disableTouchRipple" | "focusRipple" | "focusVisibleClassName" | "LinkComponent" | "onFocusVisible" | "TouchRippleProps" | "touchRippleRef" | "fullWidth" | "disableElevation" | "disableFocusRipple" | "endIcon" | "startIcon"> & {
3
+ }, "style" | "className" | "classes" | "tabIndex" | "color" | "children" | "sx" | "variant" | "disabled" | "href" | "action" | "size" | "centerRipple" | "disableRipple" | "disableTouchRipple" | "focusRipple" | "focusVisibleClassName" | "LinkComponent" | "onFocusVisible" | "TouchRippleProps" | "touchRippleRef" | "disableElevation" | "disableFocusRipple" | "endIcon" | "fullWidth" | "startIcon"> & {
4
4
  theme?: import("@emotion/react").Theme;
5
5
  }, {}, {}>;
@@ -1,6 +1,8 @@
1
1
  import { Fade, Toolbar } from "@mui/material";
2
2
  import { usePathname } from "next/navigation";
3
3
  import React from "react";
4
+ import { SELECTOR } from "../../../../common/selectors";
5
+ import { useLayoutDimensions } from "../../../../providers/layoutDimensions/hook";
4
6
  import { APP_BAR_PROPS, FADE_TRANSITION_PROPS, TOOLBAR_PROPS, } from "./common/constants";
5
7
  import { Announcements } from "./components/Announcements/announcements";
6
8
  import { Actions } from "./components/Content/components/Actions/actions";
@@ -15,12 +17,11 @@ import { Socials } from "./components/Content/components/Socials/socials.styles"
15
17
  import { AppBar, Center, Left, Right } from "./header.styles";
16
18
  import { useHeaderNavigation } from "./hooks/useHeaderNavigation";
17
19
  import { useHeaderVisibility } from "./hooks/useHeaderVisibility";
18
- import { useMeasureHeader } from "./hooks/useMeasureHeader";
19
20
  import { useMenu } from "./hooks/useMenu";
20
21
  export const Header = ({ ...headerProps }) => {
21
22
  const { navigation } = useHeaderNavigation(headerProps);
22
23
  const { isIn } = useHeaderVisibility({ ...headerProps, navigation });
23
- const { headerRef } = useMeasureHeader();
24
+ const { headerRef } = useLayoutDimensions();
24
25
  const { onClose, onOpen, open } = useMenu();
25
26
  const pathname = usePathname() ?? "";
26
27
  const { actions, announcements, authenticationEnabled, className, logo, searchEnabled, searchURL, slogan, socialMedia, } = headerProps;
@@ -29,7 +30,7 @@ export const Header = ({ ...headerProps }) => {
29
30
  headerProps: { ...headerProps, navigation },
30
31
  pathname,
31
32
  };
32
- return (React.createElement(AppBar, { ...APP_BAR_PROPS, ref: headerRef, className: className },
33
+ return (React.createElement(AppBar, { ...APP_BAR_PROPS, className: className, id: SELECTOR.HEADER, ref: headerRef },
33
34
  React.createElement(Announcements, { announcements: announcements }),
34
35
  React.createElement(Toolbar, { ...TOOLBAR_PROPS },
35
36
  React.createElement(Fade, { ...FADE_TRANSITION_PROPS, in: isIn.isLeftGroupIn },
@@ -1,8 +1,7 @@
1
1
  import React from "react";
2
- import { useLayoutState } from "../../../../hooks/useLayoutState";
2
+ import { useLayoutDimensions } from "../../../../providers/layoutDimensions/hook";
3
3
  import { MainWithOffset } from "./main.styles";
4
4
  export const Main = ({ children, className }) => {
5
- const { layoutState } = useLayoutState();
6
- const { headerHeight } = layoutState;
7
- return (React.createElement(MainWithOffset, { className: className, offset: headerHeight }, children));
5
+ const { dimensions } = useLayoutDimensions();
6
+ return (React.createElement(MainWithOffset, { className: className, offset: dimensions.header.height }, children));
8
7
  };
@@ -1,6 +1,2 @@
1
- import { TabProps as MTabProps } from "@mui/material";
2
- export interface ContentsTabProps extends Omit<MTabProps, "value"> {
3
- className?: string;
4
- value: string;
5
- }
1
+ import { ContentsTabProps } from "./types";
6
2
  export declare const ContentsTab: ({ className, value, ...props }: ContentsTabProps) => JSX.Element;
@@ -1,6 +1,8 @@
1
1
  import React from "react";
2
+ import { FONT_SIZE } from "../../../../../../styles/common/mui/icon";
3
+ import { TAB_PROPS } from "../../../../../../styles/common/mui/tab";
2
4
  import { Segment } from "../../../../../common/CustomIcon/components/Segment/segment";
3
- import { Tab } from "./contentsTab.styles";
4
- export const ContentsTab = ({ className, value, ...props /* Spread props to allow for Mui Tab specific prop overrides. */ }) => {
5
- return (React.createElement(Tab, { className: className, label: "Contents", icon: React.createElement(Segment, { fontSize: "small" }), iconPosition: "start", value: value, ...props }));
5
+ import { StyledTab } from "./contentsTab.styles";
6
+ export const ContentsTab = ({ className, value, ...props /* MuiTabProps. */ }) => {
7
+ return (React.createElement(StyledTab, { className: className, label: "Contents", icon: React.createElement(Segment, { fontSize: FONT_SIZE.SMALL }), iconPosition: TAB_PROPS.ICON_POSITION.START, value: value, ...props }));
6
8
  };
@@ -1,4 +1,4 @@
1
- export declare const Tab: import("@emotion/styled").StyledComponent<import("@mui/material").TabOwnProps & Omit<import("@mui/material").ButtonBaseOwnProps, "classes"> & import("@mui/material/OverridableComponent").CommonProps & Omit<Omit<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "ref"> & {
1
+ export declare const StyledTab: import("@emotion/styled").StyledComponent<import("@mui/material").TabOwnProps & Omit<import("@mui/material").ButtonBaseOwnProps, "classes"> & import("@mui/material/OverridableComponent").CommonProps & Omit<Omit<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "ref"> & {
2
2
  ref?: ((instance: HTMLDivElement | null) => void | import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES[keyof import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES]) | import("react").RefObject<HTMLDivElement> | null | undefined;
3
3
  }, "label" | "style" | "className" | "classes" | "tabIndex" | "children" | "sx" | "disabled" | "value" | "action" | "icon" | "centerRipple" | "disableRipple" | "disableTouchRipple" | "focusRipple" | "focusVisibleClassName" | "LinkComponent" | "onFocusVisible" | "TouchRippleProps" | "touchRippleRef" | "disableFocusRipple" | "wrapped" | "iconPosition"> & {
4
4
  theme?: import("@emotion/react").Theme;
@@ -1,9 +1,9 @@
1
1
  import styled from "@emotion/styled";
2
- import { Tab as MTab } from "@mui/material";
2
+ import { Tab } from "@mui/material";
3
3
  import { inkLight } from "../../../../../../styles/common/mixins/colors";
4
4
  import { textUppercase500 } from "../../../../../../styles/common/mixins/fonts";
5
5
  import { tab } from "../../outline.styles";
6
- export const Tab = styled(MTab) `
6
+ export const StyledTab = styled(Tab) `
7
7
  ${tab};
8
8
 
9
9
  && {
@@ -0,0 +1,5 @@
1
+ import { TabProps } from "@mui/material";
2
+ import { BaseComponentProps } from "../../../../../types";
3
+ export interface ContentsTabProps extends BaseComponentProps, Omit<TabProps, "value"> {
4
+ value: string;
5
+ }
@@ -0,0 +1,11 @@
1
+ import { UseHash } from "./types";
2
+ /**
3
+ * Hook to get the current URL hash without the leading '#' character.
4
+ *
5
+ * @description
6
+ * Extracts the hash from window.location.hash and removes the leading '#'.
7
+ * Returns empty string when running in SSR environment.
8
+ *
9
+ * @returns Object containing the hash without leading '#', or empty string if SSR.
10
+ */
11
+ export declare function useHash(): UseHash;
@@ -0,0 +1,16 @@
1
+ import { isSSR } from "../../../../../../utils/ssr";
2
+ /**
3
+ * Hook to get the current URL hash without the leading '#' character.
4
+ *
5
+ * @description
6
+ * Extracts the hash from window.location.hash and removes the leading '#'.
7
+ * Returns empty string when running in SSR environment.
8
+ *
9
+ * @returns Object containing the hash without leading '#', or empty string if SSR.
10
+ */
11
+ export function useHash() {
12
+ if (isSSR())
13
+ return { hash: "" };
14
+ const { hash } = window.location;
15
+ return { hash: hash.replace(/^#/, "") };
16
+ }
@@ -0,0 +1,3 @@
1
+ export interface UseHash {
2
+ hash: string;
3
+ }
@@ -0,0 +1,2 @@
1
+ import { TabProps } from "@mui/material";
2
+ export declare const DEFAULT_TAB_VALUE: TabProps["value"];
@@ -0,0 +1,3 @@
1
+ import { TabsProps } from "@mui/material";
2
+ import { OutlineItem } from "../../types";
3
+ export declare function useTabs(outline: OutlineItem[]): Pick<TabsProps, "indicatorColor" | "onChange" | "orientation" | "value">;
@@ -0,0 +1,24 @@
1
+ import Router from "next/router";
2
+ import { useCallback, useEffect, useState } from "react";
3
+ import { TABS_PROPS } from "../../../../../../styles/common/mui/tabs";
4
+ import { useHash } from "../UseHash/hook";
5
+ import { DEFAULT_TAB_VALUE } from "./constants";
6
+ import { getNextValue } from "./utils";
7
+ export function useTabs(outline) {
8
+ const [value, setValue] = useState(DEFAULT_TAB_VALUE);
9
+ const { hash } = useHash();
10
+ const onChange = useCallback((_event, hash) => {
11
+ Router.push({ hash });
12
+ }, []);
13
+ useEffect(() => {
14
+ setValue(getNextValue(hash, outline));
15
+ }, [hash, outline]);
16
+ return {
17
+ indicatorColor: value
18
+ ? TABS_PROPS.INDICATOR_COLOR.PRIMARY
19
+ : TABS_PROPS.INDICATOR_COLOR.TRANSPARENT,
20
+ onChange,
21
+ orientation: TABS_PROPS.ORIENTATION.VERTICAL,
22
+ value,
23
+ };
24
+ }
@@ -0,0 +1,9 @@
1
+ import { TabsProps } from "@mui/material";
2
+ import { OutlineItem } from "../../types";
3
+ /**
4
+ * Returns the tab value for navigation.
5
+ * @param hash - The current hash from the URL.
6
+ * @param outlineItems - Outline items.
7
+ * @returns The item's hash if found and enabled, otherwise returns the default tab value.
8
+ */
9
+ export declare function getNextValue(hash: string, outlineItems: OutlineItem[]): TabsProps["value"];
@@ -0,0 +1,13 @@
1
+ import { DEFAULT_TAB_VALUE } from "./constants";
2
+ /**
3
+ * Returns the tab value for navigation.
4
+ * @param hash - The current hash from the URL.
5
+ * @param outlineItems - Outline items.
6
+ * @returns The item's hash if found and enabled, otherwise returns the default tab value.
7
+ */
8
+ export function getNextValue(hash, outlineItems) {
9
+ const item = outlineItems.find((item) => item.hash === hash);
10
+ if (!item || item.disabled)
11
+ return DEFAULT_TAB_VALUE;
12
+ return item.hash;
13
+ }
@@ -1,13 +1,2 @@
1
- import { ElementType } from "react";
2
- import { ContentsTabProps } from "./components/ContentsTab/contentsTab";
3
- export interface OutlineItem {
4
- depth: number;
5
- hash: string;
6
- value: string;
7
- }
8
- export interface OutlineProps {
9
- className?: string;
10
- Contents: ElementType<ContentsTabProps>;
11
- outline: OutlineItem[];
12
- }
13
- export declare const Outline: ({ className, Contents, outline, ...props }: OutlineProps) => JSX.Element;
1
+ import { OutlineProps } from "./types";
2
+ export declare const Outline: ({ className, Contents, outline, ...props }: OutlineProps) => JSX.Element | null;
@@ -1,34 +1,10 @@
1
- import { useRouter } from "next/router";
2
- import React, { useEffect, useState } from "react";
3
- import { DEFAULT_TAB_VALUE } from "./common/constants";
4
- import { Tab, Tabs } from "./outline.styles";
5
- export const Outline = ({ className, Contents, outline, ...props /* Spread props to allow for Mui Tabs specific prop overrides. */ }) => {
6
- const { asPath, push } = useRouter();
7
- const [activeTab, setActiveTab] = useState("");
8
- // Callback fired when selected tab value changes.
9
- const handleChange = (_event, tabValue) => {
10
- push(`#${tabValue}`);
11
- };
12
- // Update active tab when path changes.
13
- useEffect(() => {
14
- setActiveTab(getActiveTab(outline, asPath));
15
- }, [asPath, outline]);
16
- return (React.createElement(Tabs, { className: className, indicatorColor: activeTab ? "primary" : "transparent", onChange: handleChange, orientation: "vertical", value: activeTab, ...props },
1
+ import React from "react";
2
+ import { DEFAULT_TAB_VALUE } from "./hooks/UseTabs/constants";
3
+ import { useTabs } from "./hooks/UseTabs/hook";
4
+ import { StyledTab, StyledTabs } from "./outline.styles";
5
+ export const Outline = ({ className, Contents, outline, ...props /* MuiTabsProps */ }) => {
6
+ const { indicatorColor, onChange, orientation, value } = useTabs(outline);
7
+ return (React.createElement(StyledTabs, { className: className, indicatorColor: indicatorColor, onChange: onChange, orientation: orientation, value: value, ...props },
17
8
  React.createElement(Contents, { value: DEFAULT_TAB_VALUE }),
18
- outline.map(({ depth, hash, value }) => (React.createElement(Tab, { key: hash, depth: depth, label: value, value: hash })))));
9
+ outline.map(({ depth, disabled, hash, value }) => (React.createElement(StyledTab, { depth: depth, disabled: disabled, key: hash, label: value, value: hash })))));
19
10
  };
20
- /**
21
- * Initializes active tab.
22
- * @param outline - Outline items.
23
- * @param asPath - Current path.
24
- * @returns active tab.
25
- */
26
- function getActiveTab(outline, asPath) {
27
- if (asPath.includes("#")) {
28
- const hashLink = asPath.split("#")[1];
29
- if (outline.some(({ hash }) => hash === hashLink)) {
30
- return hashLink;
31
- }
32
- }
33
- return DEFAULT_TAB_VALUE;
34
- }
@@ -3,12 +3,12 @@ interface Props extends TabProps {
3
3
  depth: number;
4
4
  }
5
5
  export declare const tab: import("@emotion/react").SerializedStyles;
6
- export declare const Tabs: import("@emotion/styled").StyledComponent<import("@mui/material").TabsOwnProps & import("@mui/material/OverridableComponent").CommonProps & Omit<Omit<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "ref"> & {
6
+ export declare const StyledTabs: import("@emotion/styled").StyledComponent<import("@mui/material").TabsOwnProps & import("@mui/material/OverridableComponent").CommonProps & Omit<Omit<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "ref"> & {
7
7
  ref?: ((instance: HTMLDivElement | null) => void | import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES[keyof import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES]) | import("react").RefObject<HTMLDivElement> | null | undefined;
8
- }, "style" | "className" | "classes" | "aria-label" | "aria-labelledby" | "children" | "onChange" | "sx" | "variant" | "orientation" | "value" | "action" | "slotProps" | "slots" | "allowScrollButtonsMobile" | "centered" | "indicatorColor" | "ScrollButtonComponent" | "scrollButtons" | "selectionFollowsFocus" | "TabIndicatorProps" | "TabScrollButtonProps" | "textColor" | "visibleScrollbar"> & {
8
+ }, "style" | "className" | "classes" | "aria-label" | "aria-labelledby" | "children" | "onChange" | "sx" | "variant" | "orientation" | "value" | "action" | "slots" | "slotProps" | "allowScrollButtonsMobile" | "centered" | "indicatorColor" | "ScrollButtonComponent" | "scrollButtons" | "selectionFollowsFocus" | "TabIndicatorProps" | "TabScrollButtonProps" | "textColor" | "visibleScrollbar"> & {
9
9
  theme?: import("@emotion/react").Theme;
10
10
  }, {}, {}>;
11
- export declare const Tab: import("@emotion/styled").StyledComponent<import("@mui/material").TabOwnProps & Omit<import("@mui/material").ButtonBaseOwnProps, "classes"> & import("@mui/material/OverridableComponent").CommonProps & Omit<Omit<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "ref"> & {
11
+ export declare const StyledTab: import("@emotion/styled").StyledComponent<import("@mui/material").TabOwnProps & Omit<import("@mui/material").ButtonBaseOwnProps, "classes"> & import("@mui/material/OverridableComponent").CommonProps & Omit<Omit<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "ref"> & {
12
12
  ref?: ((instance: HTMLDivElement | null) => void | import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES[keyof import("react").DO_NOT_USE_OR_YOU_WILL_BE_FIRED_CALLBACK_REF_RETURN_VALUES]) | import("react").RefObject<HTMLDivElement> | null | undefined;
13
13
  }, "label" | "style" | "className" | "classes" | "tabIndex" | "children" | "sx" | "disabled" | "value" | "action" | "icon" | "centerRipple" | "disableRipple" | "disableTouchRipple" | "focusRipple" | "focusVisibleClassName" | "LinkComponent" | "onFocusVisible" | "TouchRippleProps" | "touchRippleRef" | "disableFocusRipple" | "wrapped" | "iconPosition"> & {
14
14
  theme?: import("@emotion/react").Theme;
@@ -15,7 +15,7 @@ export const tab = css `
15
15
  text-decoration: none;
16
16
  }
17
17
  `;
18
- export const Tabs = styled(MTabs) `
18
+ export const StyledTabs = styled(MTabs) `
19
19
  align-self: flex-start;
20
20
  box-shadow: inset 1px 0 ${smokeMain};
21
21
  margin: 0;
@@ -36,7 +36,7 @@ export const Tabs = styled(MTabs) `
36
36
  width: 3px;
37
37
  }
38
38
  `;
39
- export const Tab = styled(MTab, {
39
+ export const StyledTab = styled(MTab, {
40
40
  shouldForwardProp: (prop) => prop !== "depth",
41
41
  }) `
42
42
  ${tab};
@@ -0,0 +1,14 @@
1
+ import { TabsProps } from "@mui/material";
2
+ import { ElementType } from "react";
3
+ import { BaseComponentProps } from "../../../types";
4
+ import { ContentsTabProps } from "./components/ContentsTab/types";
5
+ export interface OutlineItem {
6
+ depth: number;
7
+ disabled?: boolean;
8
+ hash: string;
9
+ value: string;
10
+ }
11
+ export interface OutlineProps extends BaseComponentProps, TabsProps {
12
+ Contents: ElementType<ContentsTabProps>;
13
+ outline: OutlineItem[];
14
+ }
@@ -0,0 +1 @@
1
+ export {};
@@ -1,8 +1,8 @@
1
1
  import React from "react";
2
- import { SIDEBAR_POSITIONER } from "../../../../../../common/selectors";
3
- import { useLayoutState } from "../../../../../../hooks/useLayoutState";
2
+ import { SELECTOR } from "../../../../../../common/selectors";
3
+ import { useLayoutDimensions } from "../../../../../../providers/layoutDimensions/hook";
4
4
  import { SidebarPositioner as Positioner } from "./sidebarPositioner.styles";
5
5
  export const SidebarPositioner = ({ children, }) => {
6
- const { layoutState: { headerHeight }, } = useLayoutState();
7
- return (React.createElement(Positioner, { headerHeight: headerHeight, id: SIDEBAR_POSITIONER }, children));
6
+ const { dimensions } = useLayoutDimensions();
7
+ return (React.createElement(Positioner, { headerHeight: dimensions.header.height, id: SELECTOR.SIDEBAR_POSITIONER }, children));
8
8
  };