@databiosphere/findable-ui 23.0.0 → 25.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 (478) hide show
  1. package/.release-please-manifest.json +1 -1
  2. package/.storybook/preview.js +4 -37
  3. package/CHANGELOG.md +64 -0
  4. package/jest.config.js +1 -0
  5. package/lib/common/entities.d.ts +1 -0
  6. package/lib/components/DataDictionary/components/Entities/constants.d.ts +2 -2
  7. package/lib/components/DataDictionary/components/Entities/constants.js +1 -1
  8. package/lib/components/DataDictionary/components/Entities/entities.js +3 -3
  9. package/lib/components/DataDictionary/components/Entity/constants.d.ts +2 -2
  10. package/lib/components/DataDictionary/components/Entity/constants.js +1 -1
  11. package/lib/components/DataDictionary/components/Entity/entity.js +4 -4
  12. package/lib/components/Detail/components/Table/components/TableHead/tableHead.d.ts +8 -0
  13. package/lib/components/Detail/components/Table/components/TableHead/tableHead.js +36 -0
  14. package/lib/components/Export/components/ExportToTerra/components/TerraSetUpForm/components/NIHAccountExpiryWarning/nihAccountExpiryWarning.js +1 -1
  15. package/lib/components/Filter/components/FilterLabel/filterLabel.js +2 -2
  16. package/lib/components/Filter/components/FilterLabel/filterLabel.styles.d.ts +1 -1
  17. package/lib/components/Filter/components/SearchAllFiltersSearch/components/SearchCloseButton/searchCloseButton.js +2 -2
  18. package/lib/components/Index/components/EntitiesView/components/ChartView/chartView.d.ts +2 -0
  19. package/lib/components/Index/components/EntitiesView/components/ChartView/chartView.js +17 -0
  20. package/lib/components/Index/components/EntitiesView/components/ChartView/chartView.styles.d.ts +13 -0
  21. package/lib/components/Index/components/EntitiesView/components/ChartView/chartView.styles.js +12 -0
  22. package/lib/components/Index/components/EntitiesView/components/ChartView/components/Chart/barX/constants.d.ts +9 -0
  23. package/lib/components/Index/components/EntitiesView/components/ChartView/components/Chart/barX/constants.js +9 -0
  24. package/lib/components/Index/components/EntitiesView/components/ChartView/components/Chart/barX/plot.d.ts +3 -0
  25. package/lib/components/Index/components/EntitiesView/components/ChartView/components/Chart/barX/plot.js +86 -0
  26. package/lib/components/Index/components/EntitiesView/components/ChartView/components/Chart/barX/utils.d.ts +105 -0
  27. package/lib/components/Index/components/EntitiesView/components/ChartView/components/Chart/barX/utils.js +196 -0
  28. package/lib/components/Index/components/EntitiesView/components/ChartView/components/Chart/chart.d.ts +2 -0
  29. package/lib/components/Index/components/EntitiesView/components/ChartView/components/Chart/chart.js +7 -0
  30. package/lib/components/Index/components/EntitiesView/components/ChartView/components/Chart/chart.styles.d.ts +3 -0
  31. package/lib/components/Index/components/EntitiesView/components/ChartView/components/Chart/chart.styles.js +29 -0
  32. package/lib/components/Index/components/EntitiesView/components/ChartView/components/Chart/constants.d.ts +1 -0
  33. package/lib/components/Index/components/EntitiesView/components/ChartView/components/Chart/constants.js +1 -0
  34. package/lib/components/Index/components/EntitiesView/components/ChartView/components/Chart/stories/args.d.ts +4 -0
  35. package/lib/components/Index/components/EntitiesView/components/ChartView/components/Chart/stories/args.js +70 -0
  36. package/lib/components/Index/components/EntitiesView/components/ChartView/components/Chart/stories/chart.stories.d.ts +7 -0
  37. package/lib/components/Index/components/EntitiesView/components/ChartView/components/Chart/stories/chart.stories.js +19 -0
  38. package/lib/components/Index/components/EntitiesView/components/ChartView/components/Chart/types.d.ts +6 -0
  39. package/lib/components/Index/components/EntitiesView/components/ChartView/components/Chart/types.js +1 -0
  40. package/lib/components/Index/components/EntitiesView/components/ChartView/constants.d.ts +1 -0
  41. package/lib/components/Index/components/EntitiesView/components/ChartView/constants.js +1 -0
  42. package/lib/components/Index/components/EntitiesView/components/ChartView/hooks/UseChartView/types.d.ts +7 -0
  43. package/lib/components/Index/components/EntitiesView/components/ChartView/hooks/UseChartView/types.js +1 -0
  44. package/lib/components/Index/components/EntitiesView/components/ChartView/hooks/UseChartView/useChartView.d.ts +3 -0
  45. package/lib/components/Index/components/EntitiesView/components/ChartView/hooks/UseChartView/useChartView.js +11 -0
  46. package/lib/components/Index/components/EntitiesView/components/ChartView/stories/args.d.ts +3 -0
  47. package/lib/components/Index/components/EntitiesView/components/ChartView/stories/args.js +96 -0
  48. package/lib/components/Index/components/EntitiesView/components/ChartView/stories/chartView.stories.d.ts +6 -0
  49. package/lib/components/Index/components/EntitiesView/components/ChartView/stories/chartView.stories.js +16 -0
  50. package/lib/components/Index/components/EntitiesView/components/ChartView/types.d.ts +6 -0
  51. package/lib/components/Index/components/EntitiesView/components/ChartView/types.js +1 -0
  52. package/lib/components/Index/components/EntitiesView/components/ChartView/utils.d.ts +14 -0
  53. package/lib/components/Index/components/EntitiesView/components/ChartView/utils.js +21 -0
  54. package/lib/components/Index/components/EntitiesView/components/EntityList/entityList.d.ts +2 -0
  55. package/lib/components/Index/components/EntitiesView/components/EntityList/entityList.js +16 -0
  56. package/lib/components/Index/components/EntitiesView/components/EntityList/types.d.ts +3 -0
  57. package/lib/components/Index/components/EntitiesView/components/EntityList/types.js +1 -0
  58. package/lib/components/Index/components/EntitiesView/constants.d.ts +1 -0
  59. package/lib/components/Index/components/EntitiesView/constants.js +1 -0
  60. package/lib/components/Index/components/EntitiesView/entitiesView.d.ts +2 -0
  61. package/lib/components/Index/components/EntitiesView/entitiesView.js +14 -0
  62. package/lib/components/Index/components/EntitiesView/entitiesView.styles.d.ts +3 -0
  63. package/lib/components/Index/components/EntitiesView/entitiesView.styles.js +20 -0
  64. package/lib/components/Index/components/EntitiesView/hooks/UseEntitiesView/hook.d.ts +2 -0
  65. package/lib/components/Index/components/EntitiesView/hooks/UseEntitiesView/hook.js +14 -0
  66. package/lib/components/Index/components/EntitiesView/hooks/UseEntitiesView/types.d.ts +13 -0
  67. package/lib/components/Index/components/EntitiesView/hooks/UseEntitiesView/types.js +5 -0
  68. package/lib/components/Index/components/EntitiesView/stories/entitiesView.stories.d.ts +8 -0
  69. package/lib/components/Index/components/EntitiesView/stories/entitiesView.stories.js +50 -0
  70. package/lib/components/Index/components/EntitiesView/types.d.ts +8 -0
  71. package/lib/components/Index/components/EntitiesView/types.js +1 -0
  72. package/lib/components/Index/components/NTagCell/nTagCell.stories.d.ts +5 -16
  73. package/lib/components/Index/components/NTagCell/nTagCell.stories.js +8 -8
  74. package/lib/components/Index/components/TitleCell/titleCell.d.ts +6 -0
  75. package/lib/components/Index/components/TitleCell/titleCell.js +10 -0
  76. package/lib/components/Index/components/TitleCell/titleCell.styles.d.ts +3 -0
  77. package/lib/components/Index/components/TitleCell/titleCell.styles.js +6 -0
  78. package/lib/components/Index/index.d.ts +2 -13
  79. package/lib/components/Index/index.js +6 -2
  80. package/lib/components/Index/index.stories.js +3 -2
  81. package/lib/components/Index/types.d.ts +12 -0
  82. package/lib/components/Index/types.js +1 -0
  83. package/lib/components/Layout/components/BackPage/components/BackPageHero/backPageHero.d.ts +1 -1
  84. package/lib/components/Layout/components/BackPage/components/BackPageHero/backPageHero.js +5 -4
  85. package/lib/components/Layout/components/BackPage/components/BackPageHero/stories/backPageHero.stories.d.ts +6 -0
  86. package/lib/components/Layout/components/BackPage/components/BackPageHero/stories/backPageHero.stories.js +18 -0
  87. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/authentication.js +3 -3
  88. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/authenticationMenu.stories.d.ts +5 -0
  89. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/authenticationMenu.stories.js +29 -0
  90. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/AuthenticationMenu/authenticationMenu.styles.d.ts +2 -2
  91. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/Button/button.styles.d.ts +1 -1
  92. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/RequestAuthentication/requestAuthentication.d.ts +6 -0
  93. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/RequestAuthentication/requestAuthentication.js +13 -0
  94. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/RequestAuthentication/requestAuthentication.styles.d.ts +36 -0
  95. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/components/RequestAuthentication/requestAuthentication.styles.js +9 -0
  96. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Menu/components/Toolbar/toolbar.js +2 -2
  97. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Menu/menu.js +2 -2
  98. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Search/components/Button/button.styles.d.ts +1 -1
  99. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Search/components/SearchBar/searchBar.js +5 -3
  100. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Search/components/SearchBar/searchBar.styles.d.ts +5 -1
  101. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Search/components/SearchBar/searchBar.styles.js +4 -3
  102. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Search/components/SearchButton/searchButton.d.ts +5 -0
  103. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Search/components/SearchButton/searchButton.js +10 -0
  104. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Search/components/SearchButton/searchButton.styles.d.ts +36 -0
  105. package/lib/components/Layout/components/Header/components/Content/components/Actions/components/Search/components/SearchButton/searchButton.styles.js +9 -0
  106. package/lib/components/Layout/components/Header/components/Content/components/Navigation/components/NavigationDrawer/navigationDrawer.js +2 -2
  107. package/lib/components/Layout/components/Header/components/Content/components/Navigation/components/NavigationMenu/navigationMenu.js +2 -2
  108. package/lib/components/Layout/components/Header/hooks/useMeasureHeader.d.ts +5 -0
  109. package/lib/components/Layout/components/Header/hooks/useMeasureHeader.js +19 -0
  110. package/lib/components/Layout/components/Outline/common/constants.d.ts +2 -0
  111. package/lib/components/Layout/components/Outline/common/constants.js +1 -0
  112. package/lib/components/Layout/components/Outline/outline.styles.d.ts +1 -1
  113. package/lib/components/Layout/components/Sidebar/components/SidebarButton/sidebarButton.js +2 -2
  114. package/lib/components/Loading/loading.d.ts +2 -1
  115. package/lib/components/Loading/loading.js +2 -2
  116. package/lib/components/Loading/loading.stories.d.ts +3 -31
  117. package/lib/components/Login/components/Button/button.styles.d.ts +1 -1
  118. package/lib/components/Login/components/Section/components/Consent/consent.js +3 -3
  119. package/lib/components/Login/components/Section/components/Consent/consent.styles.d.ts +1 -1
  120. package/lib/components/Login/components/Section/components/Consent/consent.styles.js +2 -2
  121. package/lib/components/Login/components/Section/components/Consent/types.d.ts +2 -2
  122. package/lib/components/Login/login.stories.d.ts +6 -0
  123. package/lib/components/Login/login.stories.js +31 -0
  124. package/lib/components/NoResults/noResults.d.ts +1 -8
  125. package/lib/components/NoResults/noResults.js +9 -8
  126. package/lib/components/NoResults/noResults.styles.d.ts +2 -2
  127. package/lib/components/NoResults/noResults.styles.js +4 -2
  128. package/lib/components/NoResults/types.d.ts +8 -0
  129. package/lib/components/NoResults/types.js +1 -0
  130. package/lib/components/Plot/components/BarX/barX.d.ts +2 -0
  131. package/lib/components/Plot/components/BarX/barX.js +13 -0
  132. package/lib/components/Plot/components/BarX/types.d.ts +5 -0
  133. package/lib/components/Plot/components/BarX/types.js +1 -0
  134. package/lib/components/Stepper/components/Step/components/StepContent/stepContent.d.ts +3 -0
  135. package/lib/components/Stepper/components/Step/components/StepContent/stepContent.js +7 -0
  136. package/lib/components/Stepper/components/Step/components/StepContent/stepContent.styles.d.ts +3 -0
  137. package/lib/components/Stepper/components/Step/components/StepContent/stepContent.styles.js +17 -0
  138. package/lib/components/Stepper/components/Step/components/StepIcon/components/CompletedIcon/completedIcon.d.ts +2 -0
  139. package/lib/components/Stepper/components/Step/components/StepIcon/components/CompletedIcon/completedIcon.js +8 -0
  140. package/lib/components/Stepper/components/Step/components/StepIcon/components/CompletedIcon/completedIcon.styles.d.ts +5 -0
  141. package/lib/components/Stepper/components/Step/components/StepIcon/components/CompletedIcon/completedIcon.styles.js +15 -0
  142. package/lib/components/Stepper/components/Step/components/StepIcon/components/CompletedIcon/contants.d.ts +2 -0
  143. package/lib/components/Stepper/components/Step/components/StepIcon/components/CompletedIcon/contants.js +4 -0
  144. package/lib/components/Stepper/components/Step/components/StepIcon/constants.d.ts +1 -0
  145. package/lib/components/Stepper/components/Step/components/StepIcon/constants.js +1 -0
  146. package/lib/components/Stepper/components/Step/components/StepIcon/stepIcon.d.ts +3 -0
  147. package/lib/components/Stepper/components/Step/components/StepIcon/stepIcon.js +6 -0
  148. package/lib/components/Stepper/components/Step/components/StepIcon/stepIcon.styles.d.ts +3 -0
  149. package/lib/components/Stepper/components/Step/components/StepIcon/stepIcon.styles.js +27 -0
  150. package/lib/components/Stepper/components/Step/components/StepIcon/stories/stepIcon.stories.d.ts +9 -0
  151. package/lib/components/Stepper/components/Step/components/StepIcon/stories/stepIcon.stories.js +38 -0
  152. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/components/Icon/constants.d.ts +3 -0
  153. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/components/Icon/constants.js +11 -0
  154. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/components/Icon/icon.d.ts +2 -0
  155. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/components/Icon/icon.js +9 -0
  156. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/components/Icon/stories/contants.d.ts +3 -0
  157. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/components/Icon/stories/contants.js +3 -0
  158. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/components/Icon/stories/icon.stories.d.ts +6 -0
  159. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/components/Icon/stories/icon.stories.js +20 -0
  160. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/components/Icon/types.d.ts +7 -0
  161. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/components/Icon/types.js +1 -0
  162. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/constants.d.ts +2 -0
  163. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/constants.js +6 -0
  164. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/label.d.ts +2 -0
  165. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/label.js +6 -0
  166. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/label.styles.d.ts +5 -0
  167. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/label.styles.js +7 -0
  168. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/stories/label.stories.d.ts +7 -0
  169. package/lib/components/Stepper/components/Step/components/StepLabel/components/Label/stories/label.stories.js +21 -0
  170. package/lib/components/Stepper/components/Step/components/StepLabel/components/Optional/constants.d.ts +2 -0
  171. package/lib/components/Stepper/components/Step/components/StepLabel/components/Optional/constants.js +5 -0
  172. package/lib/components/Stepper/components/Step/components/StepLabel/components/Optional/optional.d.ts +2 -0
  173. package/lib/components/Stepper/components/Step/components/StepLabel/components/Optional/optional.js +6 -0
  174. package/lib/components/Stepper/components/Step/components/StepLabel/constants.d.ts +2 -0
  175. package/lib/components/Stepper/components/Step/components/StepLabel/constants.js +8 -0
  176. package/lib/components/Stepper/components/Step/components/StepLabel/stepLabel.d.ts +2 -0
  177. package/lib/components/Stepper/components/Step/components/StepLabel/stepLabel.js +6 -0
  178. package/lib/components/Stepper/components/Step/components/StepLabel/stepLabel.styles.d.ts +3 -0
  179. package/lib/components/Stepper/components/Step/components/StepLabel/stepLabel.styles.js +12 -0
  180. package/lib/components/Stepper/components/Step/components/StepLabel/stories/contants.d.ts +4 -0
  181. package/lib/components/Stepper/components/Step/components/StepLabel/stories/contants.js +15 -0
  182. package/lib/components/Stepper/components/Step/components/StepLabel/stories/stepLabel.stories.d.ts +8 -0
  183. package/lib/components/Stepper/components/Step/components/StepLabel/stories/stepLabel.stories.js +37 -0
  184. package/lib/components/Stepper/components/Step/constants.d.ts +2 -0
  185. package/lib/components/Stepper/components/Step/constants.js +4 -0
  186. package/lib/components/Stepper/components/Step/step.d.ts +3 -0
  187. package/lib/components/Stepper/components/Step/step.js +6 -0
  188. package/lib/components/Stepper/components/Step/step.styles.d.ts +5 -0
  189. package/lib/components/Stepper/components/Step/step.styles.js +31 -0
  190. package/lib/components/Stepper/components/Step/stories/contants.d.ts +4 -0
  191. package/lib/components/Stepper/components/Step/stories/contants.js +14 -0
  192. package/lib/components/Stepper/components/Step/stories/step.stories.d.ts +8 -0
  193. package/lib/components/Stepper/components/Step/stories/step.stories.js +62 -0
  194. package/lib/components/Support/components/SupportRequest/components/Dialog/dialog.js +2 -2
  195. package/lib/components/Table/components/CheckboxMenu/checkboxMenu.d.ts +16 -0
  196. package/lib/components/Table/components/CheckboxMenu/checkboxMenu.js +28 -0
  197. package/lib/components/Table/components/CheckboxMenu/checkboxMenu.stories.d.ts +5 -0
  198. package/lib/components/Table/components/CheckboxMenu/checkboxMenu.stories.js +46 -0
  199. package/lib/components/Table/components/CheckboxMenu/checkboxMenu.styles.d.ts +3 -0
  200. package/lib/components/Table/components/CheckboxMenu/checkboxMenu.styles.js +21 -0
  201. package/lib/components/Table/components/EntityViewToggle/entityViewToggle.d.ts +2 -0
  202. package/lib/components/Table/components/EntityViewToggle/entityViewToggle.js +37 -0
  203. package/lib/components/Table/components/Pagination/pagination.js +3 -4
  204. package/lib/components/Table/components/TableHead/tableHead.js +2 -2
  205. package/lib/components/Table/table.js +11 -11
  206. package/lib/components/TableCreator/common/constants.d.ts +6 -0
  207. package/lib/components/TableCreator/common/constants.js +19 -0
  208. package/lib/components/TableCreator/common/entities.d.ts +5 -0
  209. package/lib/components/TableCreator/common/entities.js +1 -0
  210. package/lib/components/TableCreator/tableCreator.js +1 -6
  211. package/lib/components/common/Alert/alert.stories.d.ts +6 -0
  212. package/lib/components/common/Alert/alert.stories.js +36 -0
  213. package/lib/components/common/Alert/components/AlertText/alertText.styles.d.ts +4 -0
  214. package/lib/components/common/Alert/components/AlertText/alertText.styles.js +19 -0
  215. package/lib/components/common/AnchorLink/anchorLink.js +2 -2
  216. package/lib/components/common/Banner/components/BannerPrimary/bannerPrimary.d.ts +7 -0
  217. package/lib/components/common/Banner/components/BannerPrimary/bannerPrimary.js +5 -0
  218. package/lib/components/common/Banner/components/BannerPrimary/bannerPrimary.styles.d.ts +3 -0
  219. package/lib/components/common/Banner/components/BannerPrimary/bannerPrimary.styles.js +19 -0
  220. package/lib/components/common/Banner/components/DismissibleBanner/dismissibleBanner.d.ts +10 -0
  221. package/lib/components/common/Banner/components/DismissibleBanner/dismissibleBanner.js +16 -0
  222. package/lib/components/common/Banner/components/SessionTimeout/sessionTimeout.styles.d.ts +3 -0
  223. package/lib/components/common/Banner/components/SessionTimeout/sessionTimeout.styles.js +21 -0
  224. package/lib/components/common/Breadcrumbs/breadcrumbs.js +2 -2
  225. package/lib/components/common/Breadcrumbs/typeGuard.d.ts +13 -0
  226. package/lib/components/common/Breadcrumbs/typeGuard.js +23 -0
  227. package/lib/components/common/Button/components/DropdownButton/dropdownButton.js +2 -2
  228. package/lib/components/common/Button/components/LoginButton/loginButton.d.ts +3 -0
  229. package/lib/components/common/Button/components/LoginButton/loginButton.js +6 -0
  230. package/lib/components/common/Button/components/LoginButton/loginButton.styles.d.ts +7 -0
  231. package/lib/components/common/Button/components/LoginButton/loginButton.styles.js +11 -0
  232. package/lib/components/common/Button/components/NavigationButton/navigationButton.js +2 -2
  233. package/lib/components/common/CopyToClipboard/copyToClipboard.js +2 -2
  234. package/lib/components/common/Dialog/components/DialogTitle/dialogTitle.js +2 -2
  235. package/lib/components/common/Drawer/components/DrawerTitle/drawerTitle.js +2 -2
  236. package/lib/components/common/Form/components/Select/components/DropDownIcon/dropDownIcon.d.ts +2 -3
  237. package/lib/components/common/Form/components/Select/components/DropDownIcon/dropDownIcon.js +3 -3
  238. package/lib/components/common/Form/components/UploadFile/uploadFile.js +2 -2
  239. package/lib/components/common/IconButton/components/LoadingIconButton/loadingIconButton.d.ts +5 -0
  240. package/lib/components/common/IconButton/components/LoadingIconButton/loadingIconButton.js +10 -0
  241. package/lib/components/common/IconButton/components/LoadingIconButton/loadingIconButton.stories.d.ts +3 -0
  242. package/lib/components/common/IconButton/components/LoadingIconButton/loadingIconButton.stories.js +9 -0
  243. package/lib/components/common/IconButton/iconButton.styles.d.ts +1 -1
  244. package/lib/components/common/KeyValuePairs/components/KeyElType/keyElType.d.ts +2 -5
  245. package/lib/components/common/KeyValuePairs/components/KeyElType/keyElType.js +6 -2
  246. package/lib/components/common/KeyValuePairs/components/ValueElType/valueElType.d.ts +2 -5
  247. package/lib/components/common/KeyValuePairs/components/ValueElType/valueElType.js +6 -2
  248. package/lib/components/common/LoginDialog/loginDialog.styles.js +1 -1
  249. package/lib/components/common/Paper/paper.d.ts +2 -1
  250. package/lib/components/common/Paper/paper.js +2 -2
  251. package/lib/components/common/Section/components/CollapsableSection/collapsableSection.js +2 -3
  252. package/lib/components/common/ToggleButtonGroup/hooks/UseToggleButtonGroup/hook.d.ts +2 -0
  253. package/lib/components/common/ToggleButtonGroup/hooks/UseToggleButtonGroup/hook.js +10 -0
  254. package/lib/components/types.d.ts +3 -0
  255. package/lib/config/entities.d.ts +2 -0
  256. package/lib/hooks/useAuthentication/common/constants.d.ts +4 -0
  257. package/lib/hooks/useAuthentication/common/constants.js +19 -0
  258. package/lib/hooks/useAuthentication/common/entities.d.ts +25 -0
  259. package/lib/hooks/useAuthentication/common/entities.js +11 -0
  260. package/lib/hooks/useAuthentication/common/utils.d.ts +15 -0
  261. package/lib/hooks/useAuthentication/common/utils.js +25 -0
  262. package/lib/hooks/useAuthentication/useAuthentication.d.ts +6 -0
  263. package/lib/hooks/useAuthentication/useAuthentication.js +9 -0
  264. package/lib/hooks/useAuthentication/useAuthenticationComplete.d.ts +6 -0
  265. package/lib/hooks/useAuthentication/useAuthenticationComplete.js +55 -0
  266. package/lib/hooks/useAuthentication/useAuthenticationForm.d.ts +20 -0
  267. package/lib/hooks/useAuthentication/useAuthenticationForm.js +88 -0
  268. package/lib/hooks/useAuthentication/useAuthenticationNIHExpiry.d.ts +18 -0
  269. package/lib/hooks/useAuthentication/useAuthenticationNIHExpiry.js +50 -0
  270. package/lib/hooks/useAuthentication/useAuthenticationStatus.d.ts +20 -0
  271. package/lib/hooks/useAuthentication/useAuthenticationStatus.js +32 -0
  272. package/lib/hooks/useAuthentication/useFetchGoogleProfile.d.ts +21 -0
  273. package/lib/hooks/useAuthentication/useFetchGoogleProfile.js +41 -0
  274. package/lib/hooks/useAuthentication/useFetchTerraNIHProfile.d.ts +18 -0
  275. package/lib/hooks/useAuthentication/useFetchTerraNIHProfile.js +62 -0
  276. package/lib/hooks/useAuthentication/useFetchTerraProfile.d.ts +24 -0
  277. package/lib/hooks/useAuthentication/useFetchTerraProfile.js +62 -0
  278. package/lib/hooks/useAuthentication/useFetchTerraTermsOfService.d.ts +15 -0
  279. package/lib/hooks/useAuthentication/useFetchTerraTermsOfService.js +62 -0
  280. package/lib/hooks/useAuthentication/useTokenClient.d.ts +11 -0
  281. package/lib/hooks/useAuthentication/useTokenClient.js +29 -0
  282. package/lib/hooks/useAuthenticationConfig.d.ts +6 -0
  283. package/lib/hooks/useAuthenticationConfig.js +14 -0
  284. package/lib/hooks/useCategoryConfigs.d.ts +6 -0
  285. package/lib/hooks/useCategoryConfigs.js +17 -0
  286. package/lib/hooks/useCategoryFilter.js +1 -0
  287. package/lib/hooks/useEntityListRelatedView.d.ts +15 -0
  288. package/lib/hooks/useEntityListRelatedView.js +62 -0
  289. package/lib/hooks/useFileManifest/common/buildFileManifestRequestURL.d.ts +15 -0
  290. package/lib/hooks/useFileManifest/common/buildFileManifestRequestURL.js +27 -0
  291. package/lib/hooks/useFileManifest/useFileManifestURL.d.ts +5 -0
  292. package/lib/hooks/useFileManifest/useFileManifestURL.js +11 -0
  293. package/lib/hooks/useFileManifest/useRequestFileManifest.d.ts +9 -0
  294. package/lib/hooks/useFileManifest/useRequestFileManifest.js +37 -0
  295. package/lib/hooks/useLayoutState.d.ts +6 -0
  296. package/lib/hooks/useLayoutState.js +9 -0
  297. package/lib/hooks/useMenu.d.ts +10 -0
  298. package/lib/hooks/useMenu.js +17 -0
  299. package/lib/hooks/useMenuWithPosition.d.ts +14 -0
  300. package/lib/hooks/useMenuWithPosition.js +33 -0
  301. package/lib/hooks/useResizeObserver.d.ts +2 -1
  302. package/lib/hooks/useResizeObserver.js +5 -2
  303. package/lib/hooks/useSessionTimeout.d.ts +11 -0
  304. package/lib/hooks/useSessionTimeout.js +28 -0
  305. package/lib/providers/authentication.d.ts +51 -0
  306. package/lib/providers/authentication.js +110 -0
  307. package/lib/providers/layoutState.d.ts +40 -0
  308. package/lib/providers/layoutState.js +47 -0
  309. package/lib/storybook/controls/constants.d.ts +4 -0
  310. package/lib/storybook/controls/constants.js +6 -0
  311. package/lib/storybook/controls/types.d.ts +4 -0
  312. package/lib/storybook/controls/types.js +5 -0
  313. package/lib/storybook/controls/utils.d.ts +9 -0
  314. package/lib/storybook/controls/utils.js +10 -0
  315. package/lib/storybook/decorators.d.ts +2 -0
  316. package/lib/storybook/decorators.js +11 -0
  317. package/lib/storybook/loremIpsum.d.ts +4 -0
  318. package/lib/storybook/loremIpsum.js +4 -0
  319. package/lib/storybook/parameters.d.ts +2 -0
  320. package/lib/storybook/parameters.js +12 -0
  321. package/lib/styles/common/mui/palette.d.ts +47 -0
  322. package/lib/styles/common/mui/palette.js +47 -0
  323. package/lib/styles/common/mui/stepper.d.ts +7 -0
  324. package/lib/styles/common/mui/stepper.js +7 -0
  325. package/lib/styles/common/mui/svgIcon.d.ts +9 -0
  326. package/lib/styles/common/mui/svgIcon.js +26 -0
  327. package/lib/styles/common/mui/typography.js +1 -0
  328. package/lib/tests/mui/constants.d.ts +4 -0
  329. package/lib/tests/mui/constants.js +4 -0
  330. package/lib/theme/common/typography.d.ts +6 -2
  331. package/lib/theme/common/typography.js +10 -1
  332. package/lib/theme/theme.js +2 -0
  333. package/lib/utils/tests.d.ts +12 -0
  334. package/lib/utils/tests.js +20 -0
  335. package/lib/views/ExploreView/exploreView.js +4 -24
  336. package/package.json +6 -4
  337. package/src/common/entities.ts +1 -0
  338. package/src/components/DataDictionary/components/Entities/constants.ts +2 -2
  339. package/src/components/DataDictionary/components/Entities/entities.tsx +4 -4
  340. package/src/components/DataDictionary/components/Entity/constants.ts +2 -2
  341. package/src/components/DataDictionary/components/Entity/entity.tsx +6 -6
  342. package/src/components/Export/components/ExportToTerra/components/TerraSetUpForm/components/NIHAccountExpiryWarning/nihAccountExpiryWarning.tsx +1 -1
  343. package/src/components/Filter/components/FilterLabel/filterLabel.tsx +2 -2
  344. package/src/components/Filter/components/SearchAllFiltersSearch/components/SearchCloseButton/searchCloseButton.tsx +2 -2
  345. package/src/components/Index/components/EntitiesView/components/ChartView/chartView.styles.ts +14 -0
  346. package/src/components/Index/components/EntitiesView/components/ChartView/chartView.tsx +38 -0
  347. package/src/components/Index/components/EntitiesView/components/ChartView/components/Chart/barX/constants.ts +13 -0
  348. package/src/components/Index/components/EntitiesView/components/ChartView/components/Chart/barX/plot.ts +104 -0
  349. package/src/components/Index/components/EntitiesView/components/ChartView/components/Chart/barX/utils.ts +229 -0
  350. package/src/components/Index/components/EntitiesView/components/ChartView/components/Chart/chart.styles.ts +30 -0
  351. package/src/components/Index/components/EntitiesView/components/ChartView/components/Chart/chart.tsx +16 -0
  352. package/src/components/Index/components/EntitiesView/components/ChartView/components/Chart/constants.ts +1 -0
  353. package/src/components/Index/components/EntitiesView/components/ChartView/components/Chart/stories/args.ts +74 -0
  354. package/src/components/Index/components/EntitiesView/components/ChartView/components/Chart/stories/chart.stories.tsx +29 -0
  355. package/src/components/Index/components/EntitiesView/components/ChartView/components/Chart/types.ts +9 -0
  356. package/src/components/Index/components/EntitiesView/components/ChartView/constants.ts +1 -0
  357. package/src/components/Index/components/EntitiesView/components/ChartView/hooks/UseChartView/types.ts +8 -0
  358. package/src/components/Index/components/EntitiesView/components/ChartView/hooks/UseChartView/useChartView.ts +29 -0
  359. package/src/components/Index/components/EntitiesView/components/ChartView/stories/args.ts +99 -0
  360. package/src/components/Index/components/EntitiesView/components/ChartView/stories/chartView.stories.tsx +25 -0
  361. package/src/components/Index/components/EntitiesView/components/ChartView/types.ts +7 -0
  362. package/src/components/Index/components/EntitiesView/components/ChartView/utils.ts +26 -0
  363. package/src/components/Index/components/EntitiesView/components/EntityList/entityList.tsx +29 -0
  364. package/src/components/Index/components/EntitiesView/components/EntityList/types.ts +3 -0
  365. package/src/components/Index/components/EntitiesView/constants.ts +1 -0
  366. package/src/components/Index/components/EntitiesView/entitiesView.styles.ts +21 -0
  367. package/src/components/Index/components/EntitiesView/entitiesView.tsx +30 -0
  368. package/src/components/Index/components/EntitiesView/hooks/UseEntitiesView/hook.ts +15 -0
  369. package/src/components/Index/components/EntitiesView/hooks/UseEntitiesView/types.ts +16 -0
  370. package/src/components/Index/components/EntitiesView/stories/entitiesView.stories.tsx +76 -0
  371. package/src/components/Index/components/EntitiesView/types.ts +9 -0
  372. package/src/components/Index/index.stories.tsx +3 -2
  373. package/src/components/Index/index.tsx +15 -15
  374. package/src/components/Index/types.ts +13 -0
  375. package/src/components/Layout/components/BackPage/components/BackPageHero/backPageHero.tsx +19 -14
  376. package/src/components/Layout/components/BackPage/components/BackPageHero/stories/backPageHero.stories.tsx +24 -0
  377. package/src/components/Layout/components/Header/components/Content/components/Actions/components/Authentication/authentication.tsx +3 -3
  378. package/src/components/Layout/components/Header/components/Content/components/Actions/components/Menu/components/Toolbar/toolbar.tsx +2 -2
  379. package/src/components/Layout/components/Header/components/Content/components/Actions/components/Menu/menu.tsx +2 -2
  380. package/src/components/Layout/components/Header/components/Content/components/Actions/components/Search/components/SearchBar/searchBar.styles.ts +8 -3
  381. package/src/components/Layout/components/Header/components/Content/components/Actions/components/Search/components/SearchBar/searchBar.tsx +5 -2
  382. package/src/components/Layout/components/Header/components/Content/components/Navigation/components/NavigationDrawer/navigationDrawer.tsx +2 -2
  383. package/src/components/Layout/components/Header/components/Content/components/Navigation/components/NavigationMenu/navigationMenu.tsx +2 -2
  384. package/src/components/Layout/components/Sidebar/components/SidebarButton/sidebarButton.tsx +2 -2
  385. package/src/components/Loading/loading.stories.tsx +2 -2
  386. package/src/components/Loading/loading.tsx +11 -3
  387. package/src/components/Login/components/Section/components/Consent/consent.styles.ts +2 -2
  388. package/src/components/Login/components/Section/components/Consent/consent.tsx +4 -4
  389. package/src/components/Login/components/Section/components/Consent/types.ts +2 -2
  390. package/src/components/NoResults/noResults.styles.ts +4 -2
  391. package/src/components/NoResults/noResults.tsx +16 -22
  392. package/src/components/NoResults/types.ts +13 -0
  393. package/src/components/Plot/components/BarX/barX.tsx +20 -0
  394. package/src/components/Plot/components/BarX/types.ts +6 -0
  395. package/src/components/Stepper/components/Step/components/StepContent/stepContent.styles.ts +18 -0
  396. package/src/components/Stepper/components/Step/components/StepContent/stepContent.tsx +16 -0
  397. package/src/components/Stepper/components/Step/components/StepIcon/components/CompletedIcon/completedIcon.styles.ts +19 -0
  398. package/src/components/Stepper/components/Step/components/StepIcon/components/CompletedIcon/completedIcon.tsx +20 -0
  399. package/src/components/Stepper/components/Step/components/StepIcon/components/CompletedIcon/contants.ts +6 -0
  400. package/src/components/Stepper/components/Step/components/StepIcon/constants.ts +1 -0
  401. package/src/components/Stepper/components/Step/components/StepIcon/stepIcon.styles.ts +32 -0
  402. package/src/components/Stepper/components/Step/components/StepIcon/stepIcon.tsx +21 -0
  403. package/src/components/Stepper/components/Step/components/StepIcon/stories/stepIcon.stories.tsx +52 -0
  404. package/src/components/Stepper/components/Step/components/StepLabel/components/Label/components/Icon/constants.ts +14 -0
  405. package/src/components/Stepper/components/Step/components/StepLabel/components/Label/components/Icon/icon.tsx +13 -0
  406. package/src/components/Stepper/components/Step/components/StepLabel/components/Label/components/Icon/stories/contants.ts +6 -0
  407. package/src/components/Stepper/components/Step/components/StepLabel/components/Label/components/Icon/stories/icon.stories.tsx +30 -0
  408. package/src/components/Stepper/components/Step/components/StepLabel/components/Label/components/Icon/types.ts +8 -0
  409. package/src/components/Stepper/components/Step/components/StepLabel/components/Label/constants.ts +8 -0
  410. package/src/components/Stepper/components/Step/components/StepLabel/components/Label/label.styles.ts +8 -0
  411. package/src/components/Stepper/components/Step/components/StepLabel/components/Label/label.tsx +10 -0
  412. package/src/components/Stepper/components/Step/components/StepLabel/components/Label/stories/label.stories.tsx +31 -0
  413. package/src/components/Stepper/components/Step/components/StepLabel/components/Optional/constants.ts +7 -0
  414. package/src/components/Stepper/components/Step/components/StepLabel/components/Optional/optional.tsx +9 -0
  415. package/src/components/Stepper/components/Step/components/StepLabel/constants.ts +10 -0
  416. package/src/components/Stepper/components/Step/components/StepLabel/stepLabel.styles.ts +13 -0
  417. package/src/components/Stepper/components/Step/components/StepLabel/stepLabel.tsx +10 -0
  418. package/src/components/Stepper/components/Step/components/StepLabel/stories/contants.ts +19 -0
  419. package/src/components/Stepper/components/Step/components/StepLabel/stories/stepLabel.stories.tsx +48 -0
  420. package/src/components/Stepper/components/Step/constants.ts +6 -0
  421. package/src/components/Stepper/components/Step/step.styles.ts +33 -0
  422. package/src/components/Stepper/components/Step/step.tsx +12 -0
  423. package/src/components/Stepper/components/Step/stories/contants.ts +18 -0
  424. package/src/components/Stepper/components/Step/stories/step.stories.tsx +87 -0
  425. package/src/components/Support/components/SupportRequest/components/Dialog/dialog.tsx +2 -2
  426. package/src/components/Table/components/Pagination/pagination.tsx +3 -4
  427. package/src/components/Table/components/TableHead/tableHead.tsx +2 -2
  428. package/src/components/Table/table.tsx +42 -38
  429. package/src/components/TableCreator/tableCreator.tsx +8 -18
  430. package/src/components/common/AnchorLink/anchorLink.tsx +2 -2
  431. package/src/components/common/Breadcrumbs/breadcrumbs.tsx +2 -2
  432. package/src/components/common/Breadcrumbs/typeGuard.ts +24 -0
  433. package/src/components/common/Button/components/DropdownButton/dropdownButton.tsx +2 -2
  434. package/src/components/common/Button/components/NavigationButton/navigationButton.tsx +2 -2
  435. package/src/components/common/CopyToClipboard/copyToClipboard.tsx +2 -2
  436. package/src/components/common/Dialog/components/DialogTitle/dialogTitle.tsx +2 -2
  437. package/src/components/common/Drawer/components/DrawerTitle/drawerTitle.tsx +2 -2
  438. package/src/components/common/Form/components/Select/components/DropDownIcon/dropDownIcon.tsx +5 -6
  439. package/src/components/common/Form/components/UploadFile/uploadFile.tsx +2 -2
  440. package/src/components/common/KeyValuePairs/components/KeyElType/keyElType.tsx +14 -9
  441. package/src/components/common/KeyValuePairs/components/ValueElType/valueElType.tsx +8 -9
  442. package/src/components/common/LoginDialog/loginDialog.styles.ts +1 -1
  443. package/src/components/common/Paper/paper.tsx +9 -3
  444. package/src/components/common/Section/components/CollapsableSection/collapsableSection.tsx +2 -3
  445. package/src/components/common/ToggleButtonGroup/hooks/UseToggleButtonGroup/hook.ts +17 -0
  446. package/src/components/types.ts +4 -0
  447. package/src/config/entities.ts +2 -0
  448. package/src/hooks/useCategoryFilter.ts +1 -0
  449. package/src/hooks/useResizeObserver.ts +5 -2
  450. package/src/storybook/controls/constants.ts +12 -0
  451. package/src/storybook/controls/types.ts +4 -0
  452. package/src/storybook/controls/utils.ts +18 -0
  453. package/src/storybook/decorators.tsx +17 -0
  454. package/src/storybook/loremIpsum.ts +5 -0
  455. package/src/storybook/parameters.ts +14 -0
  456. package/src/styles/common/mui/palette.ts +47 -0
  457. package/src/styles/common/mui/stepper.ts +14 -0
  458. package/src/styles/common/mui/svgIcon.ts +35 -0
  459. package/src/styles/common/mui/typography.ts +1 -0
  460. package/src/tests/mui/constants.ts +4 -0
  461. package/src/theme/common/typography.ts +12 -1
  462. package/src/theme/theme.ts +2 -0
  463. package/src/utils/tests.ts +20 -0
  464. package/src/views/ExploreView/exploreView.tsx +8 -42
  465. package/tests/chart.test.tsx +170 -0
  466. package/tests/chartView.test.tsx +36 -0
  467. package/tests/entitiesView.test.tsx +36 -0
  468. package/tests/setup.ts +19 -0
  469. package/tests/stepIcon.test.tsx +42 -0
  470. package/types/data-explorer-ui.d.ts +39 -80
  471. package/src/components/Index/components/Cell/cell.tsx +0 -22
  472. package/src/components/Index/components/NTag/components/Tooltip/tooltip.styles.ts +0 -11
  473. package/src/components/Index/components/NTag/components/Tooltip/tooltip.tsx +0 -90
  474. package/src/components/Index/components/NTag/nTag.tsx +0 -25
  475. package/src/components/Index/components/NTagCell/nTagCell.stories.tsx +0 -22
  476. package/src/components/Index/components/NTagCell/nTagCell.tsx +0 -74
  477. package/src/components/Layout/components/BackPage/components/BackPageHero/backPageHero.stories.tsx +0 -16
  478. package/src/components/TableCreator/tableCreator.styles.ts +0 -5
@@ -0,0 +1,229 @@
1
+ import {
2
+ ChannelValues,
3
+ Context,
4
+ Dimensions,
5
+ RenderFunction,
6
+ ScaleFunctions,
7
+ } from "@observablehq/plot";
8
+ import { SelectCategoryValueView } from "../../../../../../../../../common/entities";
9
+ import { PALETTE } from "../../../../../../../../../styles/common/mui/palette";
10
+ import { BAR_GAP, BAR_HEIGHT, TEXT_PADDING, TICKS } from "./constants";
11
+
12
+ /**
13
+ * Returns the text for the category value point.
14
+ * @param d - Data point.
15
+ * @returns Formatted text string.
16
+ */
17
+ export function getCategoryValueText(d: SelectCategoryValueView): string {
18
+ if (d.selected) return `${d.label} (selected)`;
19
+ return d.label;
20
+ }
21
+
22
+ /**
23
+ * Returns the fill color for the category value point.
24
+ * @param d - Data point.
25
+ * @param isCategorySelected - Flag indicating if any value is selected.
26
+ * @returns Fill color string.
27
+ */
28
+ export function getCategoryValueTextFill(
29
+ d: SelectCategoryValueView,
30
+ isCategorySelected: boolean
31
+ ): string {
32
+ if (d.selected) return PALETTE.INK_MAIN;
33
+ if (isCategorySelected) return PALETTE.INK_LIGHT;
34
+ return PALETTE.INK_MAIN;
35
+ }
36
+
37
+ /**
38
+ * Returns the color range value for "false" (unselected).
39
+ * @param isCategorySelected - Flag indicating if any value is selected.
40
+ * @returns Color range value.
41
+ */
42
+ export function getColorRangeValue(isCategorySelected: boolean): string {
43
+ return isCategorySelected ? PALETTE.SMOKE_LIGHT : "#C5E3FC";
44
+ }
45
+
46
+ /**
47
+ * Returns the fill color for the count point.
48
+ * @param d - Data point.
49
+ * @param isCategorySelected - Flag indicating if any value is selected.
50
+ * @returns Fill color string.
51
+ */
52
+ export function getCountTextFill(
53
+ d: SelectCategoryValueView,
54
+ isCategorySelected: boolean
55
+ ): string {
56
+ if (d.selected) return PALETTE.COMMON_WHITE;
57
+ if (isCategorySelected) return PALETTE.SMOKE_DARK;
58
+ return PALETTE.INK_MAIN;
59
+ }
60
+
61
+ /**
62
+ * Calculates the total SVG height required to render a horizontal bar chart (barX).
63
+ * The computed height includes:
64
+ * - Padding space equivalent to one bar above the first and below the last bar,
65
+ * - Vertical gaps between bars,
66
+ * - A fixed bottom margin.
67
+ * @param numberOfBars - Number of bars to display.
68
+ * @returns Height.
69
+ */
70
+ export function getPlotHeight(numberOfBars: number): number {
71
+ return (numberOfBars + 2) * BAR_HEIGHT + (numberOfBars - 1) * BAR_GAP + 32;
72
+ }
73
+
74
+ /**
75
+ * Rounds up a number to the next "nice" stop value for axis scaling.
76
+ * This function returns an upper bound based on the input value's
77
+ * order of magnitude. It calculates axis limits or tick maximums
78
+ * for consistent and readable chart scales.
79
+ * The function applies standard magnitude-based steps:
80
+ * - Rounds up to 2.5×, 5×, 7.5×, or 10× the base magnitude
81
+ * - Ensures minimum stop of 10
82
+ * @param n - Number.
83
+ * @returns A rounded "nice" stop value suitable for axis ticks.
84
+ */
85
+ export function getStop(n: number): number {
86
+ if (n <= 10) return 10;
87
+
88
+ // Calculate the magnitude e.g. 10, 100, 1000
89
+ const magnitude = Math.pow(10, Math.floor(Math.log10(n)));
90
+
91
+ for (const multiplier of [1, 2.5, 5, 7.5, 10]) {
92
+ if (n <= magnitude * multiplier) {
93
+ return magnitude * multiplier;
94
+ }
95
+ }
96
+
97
+ return magnitude * 10;
98
+ }
99
+
100
+ /**
101
+ * Returns the ticks for the x-axis.
102
+ * @param data - Data.
103
+ * @returns Ticks.
104
+ */
105
+ export function getTicks(data: SelectCategoryValueView[]): number[] {
106
+ const domain = getXDomain(data);
107
+ return getXRange(domain[0], domain[1]);
108
+ }
109
+
110
+ /**
111
+ * Returns the `x` domain.
112
+ * @param data - Data.
113
+ * @returns Domain.
114
+ */
115
+ export function getXDomain(data: SelectCategoryValueView[]): [number, number] {
116
+ const max = Math.max(...data.map((d) => d.count));
117
+ return [0, getStop(max)];
118
+ }
119
+
120
+ /**
121
+ * Generates an evenly spaced numeric range between a start and stop value.
122
+ * The range includes a fixed number of steps (6), where each value is spaced
123
+ * by a step size derived from the adjusted stop value via `getStop`.
124
+ * Used for grid lines along the x-axis.
125
+ * @param start - Start value.
126
+ * @param stop - Stop value.
127
+ * @returns Range.
128
+ */
129
+ export function getXRange(start: number, stop: number): number[] {
130
+ const ticks = [];
131
+ const steps = TICKS;
132
+ const step = getStop(stop) / (steps - 1);
133
+ for (let i = 0; i < steps; i++) {
134
+ ticks.push(start + i * step);
135
+ }
136
+ return ticks;
137
+ }
138
+
139
+ /**
140
+ * Calculates the inner padding ratio for a band scale's y-axis.
141
+ * This determines the proportional spacing between adjacent bars in a bar chart.
142
+ * @returns The inner padding value as a fraction (between 0 and 1).
143
+ */
144
+ export function getYPaddingInner(): number {
145
+ return BAR_GAP / (BAR_HEIGHT + BAR_GAP);
146
+ }
147
+
148
+ /**
149
+ * Calculates the outer padding ratio for a band scale's y-axis.
150
+ * This represents the proportional space above the first bar and below the last bar
151
+ * in a vertical layout. It ensures that the outer margins are visually balanced and
152
+ * match the bar height, so the chart breathes evenly at the top and bottom.
153
+ * @returns The outer padding value as a fraction (between 0 and 1).
154
+ */
155
+ export function getYPaddingOuter(): number {
156
+ return BAR_HEIGHT / (BAR_HEIGHT + BAR_GAP);
157
+ }
158
+
159
+ /**
160
+ * Checks if any value in the data array is selected.
161
+ * @param data - Data.
162
+ * @returns True if any value is selected, false otherwise.
163
+ */
164
+ export function isAnyValueSelected(data: SelectCategoryValueView[]): boolean {
165
+ return data.some(({ selected }) => selected);
166
+ }
167
+
168
+ /**
169
+ * Parses a transform `translate` string and returns the x and y coordinates.
170
+ * @param translate - The transform `translate` string.
171
+ * @returns A tuple of the x and y coordinates.
172
+ */
173
+ function parseTranslate(translate: string | null): [number, number] {
174
+ const match = translate?.match(/translate\(\s*([-\d.]+)[,\s]+([-\d.]+)\s*\)/);
175
+ let tx = 0;
176
+ let ty = 0;
177
+ if (match) {
178
+ tx = parseFloat(match[1]);
179
+ ty = parseFloat(match[2]);
180
+ }
181
+ return [tx, ty];
182
+ }
183
+
184
+ /**
185
+ * Renders text elements for count values, positioning them either inside or outside bars
186
+ * based on available space. If text doesn't fit inside a bar, it's repositioned outside
187
+ * with adjusted styling.
188
+ * @param index - The mark's (filtered and transformed) index.
189
+ * @param scales - The plot's scale functions.
190
+ * @param values - The mark's (possibly scaled and transformed) channel values.
191
+ * @param dimensions - The plot's dimensions.
192
+ * @param context - The plot's context.
193
+ * @param next - The next render function in the chain.
194
+ * @returns SVG element or null
195
+ */
196
+ export function renderText(
197
+ index: number[],
198
+ scales: ScaleFunctions,
199
+ values: ChannelValues,
200
+ dimensions: Dimensions,
201
+ context: Context,
202
+ next?: RenderFunction
203
+ ): SVGElement | null {
204
+ const g = next?.(index, scales, values, dimensions, context);
205
+ if (!g) return null;
206
+ requestAnimationFrame(() => {
207
+ const textEls = g.querySelectorAll("text");
208
+ for (const textEl of textEls) {
209
+ const ctm = textEl.getCTM();
210
+ const bBox = textEl.getBBox();
211
+ if (!ctm || !bBox) continue;
212
+ // If the text doesn't fit inside the bar, reposition it outside.
213
+ if (ctm.e - bBox.width - TEXT_PADDING < 0) {
214
+ const [tx, ty] = parseTranslate(textEl.getAttribute("transform"));
215
+ // Translate by the width of the bar plus padding on each side.
216
+ textEl.setAttribute(
217
+ "transform",
218
+ `translate(${tx + bBox.width + TEXT_PADDING * 2}, ${ty})`
219
+ );
220
+ // If the text fill is white, change it to ink.
221
+ const fill = textEl.getAttribute("fill");
222
+ if (fill === PALETTE.COMMON_WHITE) {
223
+ textEl.setAttribute("fill", PALETTE.INK_MAIN);
224
+ }
225
+ }
226
+ }
227
+ });
228
+ return g;
229
+ }
@@ -0,0 +1,30 @@
1
+ import styled from "@emotion/styled";
2
+ import { mediaTabletDown } from "../../../../../../../../styles/common/mixins/breakpoints";
3
+ import { textBodySmall400 } from "../../../../../../../../styles/common/mixins/fonts";
4
+ import { BarX } from "../../../../../../../Plot/components/BarX/barX";
5
+
6
+ export const StyledBarX = styled(BarX)`
7
+ ${textBodySmall400};
8
+
9
+ svg {
10
+ g.x-axis {
11
+ text {
12
+ &:nth-of-type(1) {
13
+ text-anchor: start;
14
+ }
15
+
16
+ &:nth-last-of-type(1) {
17
+ text-anchor: end;
18
+ }
19
+
20
+ ${mediaTabletDown} {
21
+ display: none;
22
+ &:nth-of-type(1),
23
+ &:nth-last-of-type(1) {
24
+ display: block;
25
+ }
26
+ }
27
+ }
28
+ }
29
+ }
30
+ `;
@@ -0,0 +1,16 @@
1
+ import React, { useMemo } from "react";
2
+ import { getPlotOptions } from "./barX/plot";
3
+ import { StyledBarX } from "./chart.styles";
4
+ import { ChartProps } from "./types";
5
+
6
+ export const Chart = ({
7
+ selectCategoryValueViews,
8
+ testId,
9
+ width,
10
+ }: ChartProps): JSX.Element => {
11
+ const options = useMemo(
12
+ () => getPlotOptions(selectCategoryValueViews, width),
13
+ [selectCategoryValueViews, width]
14
+ );
15
+ return <StyledBarX options={options} testId={testId} />;
16
+ };
@@ -0,0 +1,74 @@
1
+ import { ComponentProps } from "react";
2
+ import { Chart } from "../chart";
3
+
4
+ export const CHART_ARGS: ComponentProps<typeof Chart> = {
5
+ selectCategoryValueViews: [
6
+ {
7
+ count: 248890,
8
+ key: "female",
9
+ label: "female",
10
+ selected: false,
11
+ },
12
+ {
13
+ count: 204935,
14
+ key: "male",
15
+ label: "male",
16
+ selected: false,
17
+ },
18
+ {
19
+ count: 240,
20
+ key: "mixed",
21
+ label: "mixed",
22
+ selected: false,
23
+ },
24
+ {
25
+ count: 78715,
26
+ key: "unknown",
27
+ label: "unknown",
28
+ selected: false,
29
+ },
30
+ {
31
+ count: 1561,
32
+ key: null,
33
+ label: "Unspecified",
34
+ selected: false,
35
+ },
36
+ ],
37
+ width: 800,
38
+ };
39
+
40
+ export const SELECT_CHART_ARGS: ComponentProps<typeof Chart> = {
41
+ selectCategoryValueViews: [
42
+ {
43
+ count: 248890,
44
+ key: "female",
45
+ label: "female",
46
+ selected: false,
47
+ },
48
+ {
49
+ count: 204935,
50
+ key: "male",
51
+ label: "male",
52
+ selected: true,
53
+ },
54
+ {
55
+ count: 240,
56
+ key: "mixed",
57
+ label: "mixed",
58
+ selected: false,
59
+ },
60
+ {
61
+ count: 78715,
62
+ key: "unknown",
63
+ label: "unknown",
64
+ selected: false,
65
+ },
66
+ {
67
+ count: 1561,
68
+ key: null,
69
+ label: "Unspecified",
70
+ selected: true,
71
+ },
72
+ ],
73
+ width: 800,
74
+ };
@@ -0,0 +1,29 @@
1
+ import { Box } from "@mui/material";
2
+ import { Meta, StoryObj } from "@storybook/react";
3
+ import React from "react";
4
+ import { PALETTE } from "../../../../../../../../../styles/common/mui/palette";
5
+ import { Chart } from "../chart";
6
+ import { CHART_ARGS, SELECT_CHART_ARGS } from "./args";
7
+
8
+ const meta: Meta<typeof Chart> = {
9
+ args: CHART_ARGS,
10
+ component: Chart,
11
+ decorators: [
12
+ (Story, context): JSX.Element => (
13
+ <Box sx={{ backgroundColor: PALETTE.COMMON_WHITE, padding: 5 }}>
14
+ <Story {...context} />
15
+ </Box>
16
+ ),
17
+ ],
18
+ title: "Components/Entities/EntitiesView/ChartView/Chart",
19
+ };
20
+
21
+ export default meta;
22
+
23
+ type Story = StoryObj<typeof meta>;
24
+
25
+ export const Default: Story = {};
26
+
27
+ export const Selected: Story = {
28
+ args: SELECT_CHART_ARGS,
29
+ };
@@ -0,0 +1,9 @@
1
+ import { PlotOptions } from "@observablehq/plot";
2
+ import { SelectCategoryValueView } from "../../../../../../../../common/entities";
3
+ import { TestIdProps } from "../../../../../../../types";
4
+
5
+ export interface ChartProps
6
+ extends Required<Pick<PlotOptions, "width">>,
7
+ TestIdProps {
8
+ selectCategoryValueViews: SelectCategoryValueView[];
9
+ }
@@ -0,0 +1 @@
1
+ export const CHART_VIEW_TEST_ID = "chart-view";
@@ -0,0 +1,8 @@
1
+ import { RefObject } from "react";
2
+ import { SelectCategoryView } from "../../../../../../../../common/entities";
3
+
4
+ export interface UseChartView {
5
+ chartViewRef: RefObject<HTMLDivElement> | null;
6
+ selectCategoryViews: SelectCategoryView[];
7
+ width: number;
8
+ }
@@ -0,0 +1,29 @@
1
+ import { useMemo, useRef } from "react";
2
+ import {
3
+ getBorderBoxSize,
4
+ useResizeObserver,
5
+ } from "../../../../../../../../hooks/useResizeObserver";
6
+ import { CategoryFilter } from "../../../../../../../Filter/components/Filters/filters";
7
+ import { getSelectCategoryViews, getSVGWidth } from "../../utils";
8
+ import { UseChartView } from "./types";
9
+
10
+ export const useChartView = (
11
+ categoryFilters: CategoryFilter[]
12
+ ): UseChartView => {
13
+ const chartViewRef = useRef<HTMLDivElement>(null);
14
+ const selectCategoryViews = useMemo(
15
+ () => getSelectCategoryViews(categoryFilters),
16
+ [categoryFilters]
17
+ );
18
+ const shouldObserve = useMemo(
19
+ () => selectCategoryViews.length > 0,
20
+ [selectCategoryViews]
21
+ );
22
+ const chartViewRect = useResizeObserver(
23
+ chartViewRef,
24
+ getBorderBoxSize,
25
+ shouldObserve
26
+ );
27
+ const width = getSVGWidth(chartViewRect?.width);
28
+ return { chartViewRef, selectCategoryViews, width };
29
+ };
@@ -0,0 +1,99 @@
1
+ import { ComponentProps } from "react";
2
+ import { ChartView } from "../chartView";
3
+
4
+ export const CHART_VIEW_ARGS: ComponentProps<typeof ChartView> = {
5
+ categoryFilters: [
6
+ {
7
+ categoryViews: [
8
+ {
9
+ enableChartView: true,
10
+ key: "biological-sex",
11
+ label: "Biological Sex",
12
+ values: [
13
+ {
14
+ count: 248890,
15
+ key: "female",
16
+ label: "female",
17
+ selected: false,
18
+ },
19
+ {
20
+ count: 204935,
21
+ key: "male",
22
+ label: "male",
23
+ selected: false,
24
+ },
25
+ {
26
+ count: 240,
27
+ key: "mixed",
28
+ label: "mixed",
29
+ selected: false,
30
+ },
31
+ {
32
+ count: 78715,
33
+ key: "unknown",
34
+ label: "unknown",
35
+ selected: false,
36
+ },
37
+ {
38
+ count: 1561,
39
+ key: null,
40
+ label: "Unspecified",
41
+ selected: false,
42
+ },
43
+ ],
44
+ },
45
+ {
46
+ enableChartView: true,
47
+ key: "genusSpecies",
48
+ label: "Genus Species",
49
+ values: [
50
+ {
51
+ count: 824,
52
+ key: "canis lupus familiaris",
53
+ label: "canis lupus familiaris",
54
+ selected: false,
55
+ },
56
+ {
57
+ count: 243550,
58
+ key: "Homo sapiens",
59
+ label: "Homo sapiens",
60
+ selected: false,
61
+ },
62
+ {
63
+ count: 277513,
64
+ key: "Mus musculus",
65
+ label: "Mus musculus",
66
+ selected: true,
67
+ },
68
+ {
69
+ count: 1292,
70
+ key: null,
71
+ label: "Unspecified",
72
+ selected: false,
73
+ },
74
+ ],
75
+ },
76
+ {
77
+ enableChartView: false,
78
+ key: "pairedEnd",
79
+ label: "Paired End",
80
+ values: [
81
+ {
82
+ count: 148558,
83
+ key: "false",
84
+ label: "false",
85
+ selected: false,
86
+ },
87
+ {
88
+ count: 366376,
89
+ key: "true",
90
+ label: "true",
91
+ selected: false,
92
+ },
93
+ ],
94
+ },
95
+ ],
96
+ },
97
+ ],
98
+ loading: false,
99
+ };
@@ -0,0 +1,25 @@
1
+ import { Meta, StoryObj } from "@storybook/react";
2
+ import React from "react";
3
+ import { GridPaper } from "../../../../../../common/Paper/paper.styles";
4
+ import { ChartView } from "../chartView";
5
+ import { CHART_VIEW_ARGS } from "./args";
6
+
7
+ const meta: Meta<typeof ChartView> = {
8
+ args: CHART_VIEW_ARGS,
9
+ component: ChartView,
10
+ decorators: [
11
+ (Story, context): JSX.Element => (
12
+ <GridPaper>
13
+ <Story {...context} />
14
+ </GridPaper>
15
+ ),
16
+ ],
17
+ parameters: { layout: "fullscreen" },
18
+ title: "Components/Entities/EntitiesView/ChartView",
19
+ };
20
+
21
+ export default meta;
22
+
23
+ type Story = StoryObj<typeof meta>;
24
+
25
+ export const Default: Story = {};
@@ -0,0 +1,7 @@
1
+ import { CategoryFilter } from "../../../../../Filter/components/Filters/filters";
2
+ import { TestIdProps } from "../../../../../types";
3
+
4
+ export interface ChartViewProps extends TestIdProps {
5
+ categoryFilters: CategoryFilter[];
6
+ loading: boolean;
7
+ }
@@ -0,0 +1,26 @@
1
+ import { SelectCategoryView } from "../../../../../../common/entities";
2
+ import { CategoryFilter } from "../../../../../Filter/components/Filters/filters";
3
+
4
+ /**
5
+ * Returns the set of select category views that have chart view enabled.
6
+ * @param categoryFilters - Category filters.
7
+ * @returns Set of category views with chart view enabled.
8
+ */
9
+ export function getSelectCategoryViews(
10
+ categoryFilters: CategoryFilter[]
11
+ ): SelectCategoryView[] {
12
+ return categoryFilters
13
+ .flatMap(({ categoryViews }) => categoryViews)
14
+ .filter(({ enableChartView = true }) => enableChartView)
15
+ .filter(({ values }) => values.length > 0);
16
+ }
17
+
18
+ /**
19
+ * Returns the available SVG `width` from the container width.
20
+ * @param width - View width.
21
+ * @returns width.
22
+ */
23
+ export function getSVGWidth(width?: number): number {
24
+ if (!width) return 0;
25
+ return width - 40; // 20px padding on each side.
26
+ }
@@ -0,0 +1,29 @@
1
+ import React from "react";
2
+ import { useConfig } from "../../../../../../hooks/useConfig";
3
+ import { useExploreState } from "../../../../../../hooks/useExploreState";
4
+ import { TableCreator } from "../../../../../TableCreator/tableCreator";
5
+ import { EntityListProps } from "./types";
6
+
7
+ export const EntityList = ({
8
+ entityListType,
9
+ }: EntityListProps): JSX.Element | null => {
10
+ const { entityConfig } = useConfig();
11
+ const { exploreState } = useExploreState();
12
+ const { listItems, loading } = exploreState;
13
+ const { getId: getRowId, list, listView } = entityConfig;
14
+ const { columns: columnsConfig } = list;
15
+
16
+ // required currently for client-side fetching as the pre-rendered page
17
+ // loads with the previous tabs data on the first render after switching tabs. (or similar)
18
+ if (entityListType !== exploreState.tabValue) return null;
19
+
20
+ return (
21
+ <TableCreator
22
+ columns={columnsConfig}
23
+ getRowId={getRowId}
24
+ items={listItems ?? []}
25
+ listView={listView}
26
+ loading={loading}
27
+ />
28
+ );
29
+ };
@@ -0,0 +1,3 @@
1
+ export interface EntityListProps {
2
+ entityListType: string;
3
+ }
@@ -0,0 +1 @@
1
+ export const ENTITIES_VIEW_TEST_ID = "entities-view";
@@ -0,0 +1,21 @@
1
+ import styled from "@emotion/styled";
2
+ import { white } from "../../../../styles/common/mixins/colors";
3
+ import { FluidPaper } from "../../../common/Paper/paper.styles";
4
+
5
+ export const StyledFluidPaper = styled(FluidPaper)`
6
+ &.MuiPaper-root {
7
+ position: relative; /* required; positions table loading indicator */
8
+
9
+ .MuiToolbar-root {
10
+ background-color: ${white};
11
+ padding: 20px;
12
+
13
+ .MuiToggleButtonGroup-root {
14
+ .MuiToggleButton-root {
15
+ padding: 8px 16px;
16
+ text-transform: none;
17
+ }
18
+ }
19
+ }
20
+ }
21
+ `;