@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
@@ -10,3 +10,15 @@ export declare function getAnchorEl(id: string): HTMLAnchorElement;
10
10
  * @returns HTML button element.
11
11
  */
12
12
  export declare function getButtonById(id: string): HTMLButtonElement;
13
+ /**
14
+ * Returns class names of the given element.
15
+ * @param element - Element.
16
+ * @returns element class names.
17
+ */
18
+ export declare function getClassNames(element?: Element | null): string | null;
19
+ /**
20
+ * Returns tag name of the given element.
21
+ * @param element - Element.
22
+ * @returns element tag name.
23
+ */
24
+ export declare function getTagName(element?: Element | null): string | null;
@@ -15,3 +15,23 @@ export function getAnchorEl(id) {
15
15
  export function getButtonById(id) {
16
16
  return screen.getByTestId(id);
17
17
  }
18
+ /**
19
+ * Returns class names of the given element.
20
+ * @param element - Element.
21
+ * @returns element class names.
22
+ */
23
+ export function getClassNames(element) {
24
+ if (!element)
25
+ return null;
26
+ return element.getAttribute("class");
27
+ }
28
+ /**
29
+ * Returns tag name of the given element.
30
+ * @param element - Element.
31
+ * @returns element tag name.
32
+ */
33
+ export function getTagName(element) {
34
+ if (!element)
35
+ return null;
36
+ return element.tagName.toLowerCase();
37
+ }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@databiosphere/findable-ui",
3
- "version": "22.0.0",
3
+ "version": "24.0.0",
4
4
  "description": "",
5
5
  "scripts": {
6
6
  "test": "node --experimental-vm-modules node_modules/jest/bin/jest.js",
@@ -1,3 +1,6 @@
1
- export const BODY = "body";
2
-
3
- export const SIDEBAR_POSITIONER = "sidebar-positioner";
1
+ export enum SELECTOR {
2
+ BODY = "body",
3
+ FOOTER = "footer",
4
+ HEADER = "header",
5
+ SIDEBAR_POSITIONER = "sidebar-positioner",
6
+ }
@@ -1,8 +1,10 @@
1
1
  import { Grid2Props } from "@mui/material";
2
2
 
3
+ export const ENTITIES_ROW_GAP = 8;
4
+
3
5
  export const GRID2_PROPS: Grid2Props = {
4
6
  container: true,
5
7
  direction: "column",
6
8
  flexWrap: "nowrap",
7
- rowGap: 8,
9
+ rowGap: ENTITIES_ROW_GAP,
8
10
  };
@@ -4,11 +4,11 @@ import { Entity } from "../Entity/entity";
4
4
  import { GRID2_PROPS } from "./constants";
5
5
  import { ClassesProps } from "./types";
6
6
 
7
- export const Entities = ({ classes }: ClassesProps): JSX.Element => {
7
+ export const Entities = ({ classes, spacing }: ClassesProps): JSX.Element => {
8
8
  return (
9
9
  <Grid2 {...GRID2_PROPS}>
10
10
  {classes.map((classData) => (
11
- <Entity key={classData.key} class={classData} />
11
+ <Entity key={classData.key} class={classData} spacing={spacing} />
12
12
  ))}
13
13
  </Grid2>
14
14
  );
@@ -1,5 +1,7 @@
1
1
  import { Class } from "../../../../common/entities";
2
+ import { LayoutSpacing } from "../../hooks/UseLayoutSpacing/types";
2
3
 
3
4
  export interface ClassesProps {
4
5
  classes: Class[];
6
+ spacing?: LayoutSpacing;
5
7
  }
@@ -0,0 +1,12 @@
1
+ import styled from "@emotion/styled";
2
+ import { Typography } from "@mui/material";
3
+ import { LayoutSpacing } from "../../hooks/UseLayoutSpacing/types";
4
+ import { ENTITIES_ROW_GAP } from "../Entities/constants";
5
+
6
+ export const StyledTypography = styled(Typography)<Partial<LayoutSpacing>>`
7
+ scroll-margin-top: ${({ top = 0 }) => top + ENTITIES_ROW_GAP}px;
8
+
9
+ &:hover a {
10
+ opacity: 1;
11
+ }
12
+ ` as typeof Typography;
@@ -1,23 +1,33 @@
1
1
  import { Grid2, Typography } from "@mui/material";
2
2
  import React from "react";
3
- import { COLOR, VARIANT } from "../../../../styles/common/mui/typography";
3
+ import { TYPOGRAPHY_PROPS } from "../../../../styles/common/mui/typography";
4
+ import { AnchorLink } from "../../../common/AnchorLink/anchorLink";
4
5
  import { useTable } from "../Table/hook";
5
6
  import { Table } from "../Table/table";
6
7
  import { GRID2_PROPS } from "./constants";
8
+ import { StyledTypography } from "./entity.styles";
7
9
  import { EntityProps } from "./types";
8
10
 
9
- export const Entity = ({ class: classData }: EntityProps): JSX.Element => {
11
+ export const Entity = ({
12
+ class: classData,
13
+ spacing,
14
+ }: EntityProps): JSX.Element => {
10
15
  const table = useTable(classData.attributes);
11
16
  return (
12
17
  <Grid2 {...GRID2_PROPS} rowGap={4}>
13
18
  <Grid2 {...GRID2_PROPS} rowGap={1}>
14
- <Typography component="h3" variant={VARIANT.TEXT_HEADING_SMALL}>
15
- {classData.label}
16
- </Typography>
19
+ <StyledTypography
20
+ component="h3"
21
+ id={classData.key}
22
+ variant={TYPOGRAPHY_PROPS.VARIANT.TEXT_HEADING_SMALL}
23
+ {...spacing}
24
+ >
25
+ {classData.label} <AnchorLink anchorLink={classData.key} />
26
+ </StyledTypography>
17
27
  <Typography
18
- color={COLOR.INK_LIGHT}
28
+ color={TYPOGRAPHY_PROPS.COLOR.INK_LIGHT}
19
29
  component="div"
20
- variant={VARIANT.TEXT_BODY_400_2_LINES}
30
+ variant={TYPOGRAPHY_PROPS.VARIANT.TEXT_BODY_400_2_LINES}
21
31
  >
22
32
  {classData.description}
23
33
  </Typography>
@@ -1,5 +1,7 @@
1
1
  import { Class } from "../../../../common/entities";
2
+ import { LayoutSpacing } from "../../hooks/UseLayoutSpacing/types";
2
3
 
3
4
  export interface EntityProps {
4
5
  class: Class;
6
+ spacing?: LayoutSpacing;
5
7
  }
@@ -0,0 +1,22 @@
1
+ import styled from "@emotion/styled";
2
+ import { mediaTabletDown } from "../../../../../../styles/common/mixins/breakpoints";
3
+ import { LayoutSpacing } from "../../../../hooks/UseLayoutSpacing/types";
4
+ import { LAYOUT_SPACING } from "../../constants";
5
+
6
+ const PB = LAYOUT_SPACING.CONTENT_PADDING_BOTTOM; /* bottom padding */
7
+ const PT = LAYOUT_SPACING.CONTENT_PADDING_TOP; /* top padding */
8
+ const TITLE_HEIGHT = LAYOUT_SPACING.TITLE_HEIGHT; /* title height */
9
+
10
+ export const Layout = styled("div")<LayoutSpacing>`
11
+ grid-column: 2;
12
+ grid-row: 1;
13
+ padding-bottom: ${PB}px;
14
+ padding-top: ${({ top }) => top + TITLE_HEIGHT + PT}px;
15
+ z-index: 1; /* not required, but helpful in that the entities are always on top */
16
+
17
+ ${mediaTabletDown} {
18
+ grid-column: 1;
19
+ grid-row: auto;
20
+ padding-top: ${PT}px;
21
+ }
22
+ `;
@@ -0,0 +1,10 @@
1
+ import React from "react";
2
+ import { Layout } from "./entitiesLayout.styles";
3
+ import { EntitiesLayoutProps } from "./types";
4
+
5
+ export const EntitiesLayout = ({
6
+ children,
7
+ ...props
8
+ }: EntitiesLayoutProps): JSX.Element => {
9
+ return <Layout {...props}>{children}</Layout>;
10
+ };
@@ -0,0 +1,6 @@
1
+ import { ReactNode } from "react";
2
+ import { LayoutSpacing } from "../../../../hooks/UseLayoutSpacing/types";
3
+
4
+ export interface EntitiesLayoutProps extends LayoutSpacing {
5
+ children: ReactNode;
6
+ }
@@ -0,0 +1,31 @@
1
+ import styled from "@emotion/styled";
2
+ import { mediaTabletDown } from "../../../../../../styles/common/mixins/breakpoints";
3
+ import { LayoutSpacing } from "../../../../hooks/UseLayoutSpacing/types";
4
+ import { LAYOUT_SPACING } from "../../constants";
5
+
6
+ const PB = LAYOUT_SPACING.CONTENT_PADDING_BOTTOM; /* bottom padding */
7
+ const PT = LAYOUT_SPACING.CONTENT_PADDING_TOP; /* top padding */
8
+ const TITLE_HEIGHT = LAYOUT_SPACING.TITLE_HEIGHT; /* title height */
9
+
10
+ export const Layout = styled("div")<LayoutSpacing>`
11
+ grid-column: 1;
12
+ grid-row: 1;
13
+ margin-bottom: ${({ bottom }) =>
14
+ -bottom}px; /* required; prevents sticky element from scrolling when footer scrolls into viewport */
15
+ max-height: 100vh;
16
+ overflow: hidden;
17
+ padding-bottom: ${({ bottom }) => bottom}px; /* footer height */
18
+ padding-top: ${({ top }) => top + TITLE_HEIGHT + PT}px;
19
+ position: sticky;
20
+ top: 0;
21
+
22
+ ${mediaTabletDown} {
23
+ display: none;
24
+ }
25
+ `;
26
+
27
+ export const LayoutScroller = styled("div")`
28
+ height: 100%;
29
+ overflow: auto;
30
+ padding-bottom: ${PB}px;
31
+ `;
@@ -0,0 +1,14 @@
1
+ import React from "react";
2
+ import { Layout, LayoutScroller } from "./outlineLayout.styles";
3
+ import { OutlineLayoutProps } from "./types";
4
+
5
+ export const OutlineLayout = ({
6
+ children,
7
+ ...props
8
+ }: OutlineLayoutProps): JSX.Element => {
9
+ return (
10
+ <Layout {...props}>
11
+ <LayoutScroller>{children}</LayoutScroller>
12
+ </Layout>
13
+ );
14
+ };
@@ -0,0 +1,6 @@
1
+ import { ReactNode } from "react";
2
+ import { LayoutSpacing } from "../../../../hooks/UseLayoutSpacing/types";
3
+
4
+ export interface OutlineLayoutProps extends LayoutSpacing {
5
+ children: ReactNode;
6
+ }
@@ -0,0 +1,18 @@
1
+ import styled from "@emotion/styled";
2
+ import { mediaTabletDown } from "../../../../../../styles/common/mixins/breakpoints";
3
+ import { LayoutSpacing } from "../../../../hooks/UseLayoutSpacing/types";
4
+
5
+ export const Layout = styled("div")<LayoutSpacing>`
6
+ grid-column: 1 / -1;
7
+ grid-row: 1;
8
+ height: fit-content;
9
+ padding-top: ${({ top }) => top}px; /* header height */
10
+ position: sticky;
11
+ top: 0;
12
+
13
+ ${mediaTabletDown} {
14
+ grid-column: 1;
15
+ grid-row: auto;
16
+ position: relative;
17
+ }
18
+ `;
@@ -0,0 +1,10 @@
1
+ import React from "react";
2
+ import { Layout } from "./titleLayout.styles";
3
+ import { TitleLayoutProps } from "./types";
4
+
5
+ export const TitleLayout = ({
6
+ children,
7
+ ...props
8
+ }: TitleLayoutProps): JSX.Element => {
9
+ return <Layout {...props}>{children}</Layout>;
10
+ };
@@ -0,0 +1,6 @@
1
+ import { ReactNode } from "react";
2
+ import { LayoutSpacing } from "../../../../hooks/UseLayoutSpacing/types";
3
+
4
+ export interface TitleLayoutProps extends LayoutSpacing {
5
+ children: ReactNode;
6
+ }
@@ -0,0 +1,5 @@
1
+ export const LAYOUT_SPACING = {
2
+ CONTENT_PADDING_BOTTOM: 24,
3
+ CONTENT_PADDING_TOP: 16,
4
+ TITLE_HEIGHT: 74,
5
+ };
@@ -0,0 +1,7 @@
1
+ import { ContentsTabProps } from "../../../../../Layout/components/Outline/components/ContentsTab/types";
2
+
3
+ export const TAB_PROPS: ContentsTabProps = {
4
+ icon: undefined,
5
+ label: "Entity Type",
6
+ value: "",
7
+ };
@@ -0,0 +1,8 @@
1
+ import styled from "@emotion/styled";
2
+ import { ContentsTab } from "../../../../../Layout/components/Outline/components/ContentsTab/contentsTab";
3
+
4
+ export const StyledContentsTab = styled(ContentsTab)`
5
+ & {
6
+ padding: 8px 24px;
7
+ }
8
+ `;
@@ -0,0 +1,7 @@
1
+ import React from "react";
2
+ import { TAB_PROPS } from "./constants";
3
+ import { StyledContentsTab } from "./contentsTab.styles";
4
+
5
+ export const ContentsTab = (): JSX.Element => {
6
+ return <StyledContentsTab {...TAB_PROPS} />;
7
+ };
@@ -0,0 +1,24 @@
1
+ import styled from "@emotion/styled";
2
+ import {
3
+ inkLight,
4
+ inkMain,
5
+ smokeDark,
6
+ } from "../../../../styles/common/mixins/colors";
7
+ import { Outline } from "../../../Layout/components/Outline/outline";
8
+
9
+ export const StyledOutline = styled(Outline)`
10
+ &.MuiTabs-root {
11
+ .MuiTab-root {
12
+ color: ${inkLight};
13
+
14
+ &.Mui-selected {
15
+ color: ${inkMain};
16
+ }
17
+
18
+ &.Mui-disabled {
19
+ color: ${smokeDark};
20
+ opacity: 1;
21
+ }
22
+ }
23
+ }
24
+ `;
@@ -0,0 +1,11 @@
1
+ import React from "react";
2
+ import { ContentsTab } from "./components/ContentsTab/contentsTab";
3
+ import { StyledOutline } from "./outline.styles";
4
+ import { OutlineProps } from "./types";
5
+
6
+ export const Outline = ({
7
+ outline,
8
+ ...props /* MuiTabsProps */
9
+ }: OutlineProps): JSX.Element => {
10
+ return <StyledOutline Contents={ContentsTab} outline={outline} {...props} />;
11
+ };
@@ -0,0 +1,6 @@
1
+ import { TabsProps } from "@mui/material";
2
+ import { OutlineItem } from "../../../Layout/components/Outline/types";
3
+
4
+ export interface OutlineProps extends TabsProps {
5
+ outline: OutlineItem[];
6
+ }
@@ -0,0 +1,18 @@
1
+ import { Class } from "../../../../common/entities";
2
+ import { OutlineItem } from "../../../Layout/components/Outline/types";
3
+
4
+ /**
5
+ * Returns outline items from classes.
6
+ * @param classes - Class entities.
7
+ * @returns Outline items.
8
+ */
9
+ export function buildClassesOutline(classes: Class[]): OutlineItem[] {
10
+ return classes.map(({ key, name }) => {
11
+ return {
12
+ depth: 2,
13
+ disabled: false,
14
+ hash: key,
15
+ value: name,
16
+ };
17
+ });
18
+ }
@@ -1,8 +1,12 @@
1
1
  import { Typography } from "@mui/material";
2
2
  import React from "react";
3
- import { VARIANT } from "../../../../../../styles/common/mui/typography";
3
+ import { TYPOGRAPHY_PROPS } from "../../../../../../styles/common/mui/typography";
4
4
  import { BasicCellProps } from "./types";
5
5
 
6
6
  export const BasicCell = ({ getValue }: BasicCellProps): JSX.Element => {
7
- return <Typography variant={VARIANT.INHERIT}>{getValue()}</Typography>;
7
+ return (
8
+ <Typography variant={TYPOGRAPHY_PROPS.VARIANT.INHERIT}>
9
+ {getValue()}
10
+ </Typography>
11
+ );
8
12
  };
@@ -0,0 +1,18 @@
1
+ import styled from "@emotion/styled";
2
+ import { mediaTabletDown } from "../../../../styles/common/mixins/breakpoints";
3
+ import { Title } from "../../../common/Title/title";
4
+
5
+ export const StyledTitle = styled(Title)`
6
+ & {
7
+ font-size: 34px;
8
+ grid-column: 1 / -1;
9
+ letter-spacing: normal;
10
+ line-height: 42px;
11
+ margin: 24px 0 8px;
12
+
13
+ ${mediaTabletDown} {
14
+ font-size: 26px;
15
+ line-height: 34px;
16
+ }
17
+ }
18
+ `;
@@ -0,0 +1,8 @@
1
+ import React from "react";
2
+ import { TitleProps } from "../../../common/Title/title";
3
+ import { StyledTitle } from "./title.styles";
4
+
5
+ export const Title = ({
6
+ title = "Data Dictionary",
7
+ ...props
8
+ }: TitleProps): JSX.Element => <StyledTitle title={title} {...props} />;
@@ -1,8 +1,22 @@
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
+
5
+ export const grid = css`
6
+ column-gap: 24px;
7
+ display: grid;
8
+ grid-template-columns: 242px 1fr;
9
+ `;
2
10
 
3
11
  export const View = styled("div")`
12
+ ${grid};
4
13
  flex: 1;
5
14
  margin: 0 auto;
6
- max-width: calc(100vw - 48px);
7
- padding: 24px 0;
15
+ max-width: min(calc(100vw - 48px), 1392px);
16
+ position: relative;
17
+
18
+ ${mediaTabletDown} {
19
+ grid-template-columns: 1fr;
20
+ max-width: calc(100vw - 32px);
21
+ }
8
22
  `;
@@ -1,16 +1,38 @@
1
- import React from "react";
2
- import { BaseComponentProps } from "../types";
1
+ import React, { useMemo } from "react";
3
2
  import { Entities } from "./components/Entities/entities";
3
+ import { EntitiesLayout as DefaultEntitiesLayout } from "./components/Layout/components/EntitiesLayout/entitiesLayout";
4
+ import { OutlineLayout as DefaultOutlineLayout } from "./components/Layout/components/OutlineLayout/outlineLayout";
5
+ import { TitleLayout as DefaultTitleLayout } from "./components/Layout/components/TitleLayout/titleLayout";
6
+ import { Outline as DefaultOutline } from "./components/Outline/outline";
7
+ import { buildClassesOutline } from "./components/Outline/utils";
8
+ import { Title as DefaultTitle } from "./components/Title/title";
4
9
  import { View } from "./dataDictionary.styles";
5
10
  import { useDataDictionary } from "./hooks/UseDataDictionary/hook";
11
+ import { useLayoutSpacing } from "./hooks/UseLayoutSpacing/hook";
12
+ import { DataDictionaryProps } from "./types";
6
13
 
7
14
  export const DataDictionary = ({
8
15
  className,
9
- }: BaseComponentProps): JSX.Element => {
16
+ EntitiesLayout = DefaultEntitiesLayout,
17
+ Outline = DefaultOutline,
18
+ OutlineLayout = DefaultOutlineLayout,
19
+ Title = DefaultTitle,
20
+ TitleLayout = DefaultTitleLayout,
21
+ }: DataDictionaryProps): JSX.Element => {
10
22
  const { classes } = useDataDictionary();
23
+ const { spacing } = useLayoutSpacing();
24
+ const outline = useMemo(() => buildClassesOutline(classes), [classes]);
11
25
  return (
12
26
  <View className={className}>
13
- <Entities classes={classes} />
27
+ <TitleLayout {...spacing}>
28
+ <Title />
29
+ </TitleLayout>
30
+ <OutlineLayout {...spacing}>
31
+ <Outline outline={outline} />
32
+ </OutlineLayout>
33
+ <EntitiesLayout {...spacing}>
34
+ <Entities classes={classes} spacing={spacing} />
35
+ </EntitiesLayout>
14
36
  </View>
15
37
  );
16
38
  };
@@ -1,3 +1,4 @@
1
+ import { useMemo } from "react";
1
2
  import { useConfig } from "../../../../hooks/useConfig";
2
3
  import { UseDataDictionary } from "./types";
3
4
 
@@ -5,5 +6,5 @@ export const useDataDictionary = (): UseDataDictionary => {
5
6
  const {
6
7
  config: { dataDictionary: { classes = [] } = {} },
7
8
  } = useConfig();
8
- return { classes };
9
+ return useMemo(() => ({ classes }), [classes]);
9
10
  };
@@ -0,0 +1,12 @@
1
+ import { useLayoutDimensions } from "../../../../providers/layoutDimensions/hook";
2
+ import { UseLayoutSpacing } from "./types";
3
+
4
+ export const useLayoutSpacing = (): UseLayoutSpacing => {
5
+ const { dimensions } = useLayoutDimensions();
6
+ return {
7
+ spacing: {
8
+ bottom: dimensions.footer.height,
9
+ top: dimensions.header.height,
10
+ },
11
+ };
12
+ };
@@ -0,0 +1,8 @@
1
+ export interface LayoutSpacing {
2
+ bottom: number;
3
+ top: number;
4
+ }
5
+
6
+ export interface UseLayoutSpacing {
7
+ spacing: LayoutSpacing;
8
+ }
@@ -0,0 +1,10 @@
1
+ import { ElementType } from "react";
2
+ import { BaseComponentProps } from "../types";
3
+
4
+ export interface DataDictionaryProps extends BaseComponentProps {
5
+ EntitiesLayout?: ElementType;
6
+ Outline?: ElementType;
7
+ OutlineLayout?: ElementType;
8
+ Title?: ElementType;
9
+ TitleLayout?: ElementType;
10
+ }
@@ -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";
@@ -54,9 +54,7 @@ export const Error = ({
54
54
  rootPath,
55
55
  }: ErrorProps): JSX.Element => {
56
56
  const { exploreDispatch } = useExploreState();
57
- const {
58
- layoutState: { headerHeight },
59
- } = useLayoutState();
57
+ const { dimensions } = useLayoutDimensions();
60
58
 
61
59
  const handleToHomePageClicked = (): void => {
62
60
  onReset?.();
@@ -67,7 +65,7 @@ export const Error = ({
67
65
  };
68
66
 
69
67
  return (
70
- <ErrorLayout offset={headerHeight}>
68
+ <ErrorLayout offset={dimensions.header.height}>
71
69
  <CustomError>
72
70
  <ErrorSection>
73
71
  <StatusIcon priority={PRIORITY.HIGH} StatusIcon={AlertIcon} />
@@ -11,7 +11,7 @@ import React, {
11
11
  useState,
12
12
  } from "react";
13
13
  import { SelectCategoryView } from "../../../../common/entities";
14
- import { BODY, SIDEBAR_POSITIONER } from "../../../../common/selectors";
14
+ import { SELECTOR } from "../../../../common/selectors";
15
15
  import {
16
16
  BREAKPOINT_FN_NAME,
17
17
  useBreakpointHelper,
@@ -89,8 +89,8 @@ export const SearchAllFilters = ({
89
89
  if (desktopSmUp) {
90
90
  setElementsOverflowStyle(
91
91
  [
92
- document.querySelector(BODY),
93
- document.getElementById(SIDEBAR_POSITIONER),
92
+ document.querySelector(SELECTOR.BODY),
93
+ document.getElementById(SELECTOR.SIDEBAR_POSITIONER),
94
94
  ],
95
95
  overflowStyle
96
96
  );
@@ -1,5 +1,5 @@
1
1
  import React, { ReactNode } from "react";
2
- import { useLayoutState } from "../../hooks/useLayoutState";
2
+ import { useLayoutDimensions } from "../../providers/layoutDimensions/hook";
3
3
  import { HeroTitle } from "../common/Title/title";
4
4
  import { Hero } from "./components/Hero/hero";
5
5
  import { Index as IndexLayout } from "./index.styles";
@@ -25,10 +25,9 @@ export const Index = ({
25
25
  Tabs,
26
26
  title,
27
27
  }: IndexProps): JSX.Element => {
28
- const { layoutState } = useLayoutState();
29
- const { headerHeight } = layoutState;
28
+ const { dimensions } = useLayoutDimensions();
30
29
  return (
31
- <IndexLayout className={className} marginTop={headerHeight}>
30
+ <IndexLayout className={className} marginTop={dimensions.header.height}>
32
31
  <Hero SideBarButton={SideBarButton} Summaries={Summaries} title={title} />
33
32
  {SubTitleHero}
34
33
  {Tabs}