@gravity-ui/navigation 5.0.0-beta.3 → 6.0.0-beta.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 (374) hide show
  1. package/build/cjs/assets/icons/control-menu-button.svg.js +41 -0
  2. package/build/cjs/assets/icons/control-menu-button.svg.js.map +1 -0
  3. package/build/cjs/components/AsideHeader/AsideHeader.css +1 -1
  4. package/build/cjs/components/AsideHeader/AsideHeader.js +1 -1
  5. package/build/cjs/components/AsideHeader/AsideHeader.js.map +1 -1
  6. package/build/cjs/components/AsideHeader/AsideHeader.module.scss.js +1 -1
  7. package/build/cjs/components/AsideHeader/AsideHeaderContext.d.ts +1 -12
  8. package/build/cjs/components/AsideHeader/AsideHeaderContext.js +5 -4
  9. package/build/cjs/components/AsideHeader/AsideHeaderContext.js.map +1 -1
  10. package/build/cjs/components/AsideHeader/components/AllPagesPanel/AllPagesListItem/AllPagesListItem.css +1 -0
  11. package/build/cjs/components/AsideHeader/components/AllPagesPanel/AllPagesListItem/AllPagesListItem.d.ts +12 -0
  12. package/build/cjs/components/AsideHeader/components/AllPagesPanel/AllPagesListItem/AllPagesListItem.js +44 -0
  13. package/build/cjs/components/AsideHeader/components/AllPagesPanel/AllPagesListItem/AllPagesListItem.js.map +1 -0
  14. package/build/cjs/components/AsideHeader/components/AllPagesPanel/AllPagesListItem/AllPagesListItem.module.scss.js +8 -0
  15. package/build/cjs/components/AsideHeader/components/AllPagesPanel/AllPagesListItem/AllPagesListItem.module.scss.js.map +1 -0
  16. package/build/cjs/components/AsideHeader/components/AllPagesPanel/AllPagesListItem/index.d.ts +1 -0
  17. package/build/cjs/components/AsideHeader/components/AllPagesPanel/AllPagesPanel.css +1 -1
  18. package/build/cjs/components/AsideHeader/components/AllPagesPanel/AllPagesPanel.js +48 -98
  19. package/build/cjs/components/AsideHeader/components/AllPagesPanel/AllPagesPanel.js.map +1 -1
  20. package/build/cjs/components/AsideHeader/components/AllPagesPanel/AllPagesPanel.module.scss.js +1 -1
  21. package/build/cjs/components/AsideHeader/components/AllPagesPanel/constants.d.ts +0 -1
  22. package/build/cjs/components/AsideHeader/components/AllPagesPanel/constants.js +0 -2
  23. package/build/cjs/components/AsideHeader/components/AllPagesPanel/constants.js.map +1 -1
  24. package/build/cjs/components/AsideHeader/components/AllPagesPanel/i18n/en.json.js +1 -0
  25. package/build/cjs/components/AsideHeader/components/AllPagesPanel/i18n/en.json.js.map +1 -1
  26. package/build/cjs/components/AsideHeader/components/AllPagesPanel/i18n/index.d.ts +4 -4
  27. package/build/cjs/components/AsideHeader/components/AllPagesPanel/i18n/ru.json.js +1 -0
  28. package/build/cjs/components/AsideHeader/components/AllPagesPanel/i18n/ru.json.js.map +1 -1
  29. package/build/cjs/components/AsideHeader/components/AllPagesPanel/index.d.ts +1 -0
  30. package/build/cjs/components/AsideHeader/components/AllPagesPanel/useGroupedMenuItems.d.ts +4 -3
  31. package/build/cjs/components/AsideHeader/components/AllPagesPanel/useGroupedMenuItems.js +15 -62
  32. package/build/cjs/components/AsideHeader/components/AllPagesPanel/useGroupedMenuItems.js.map +1 -1
  33. package/build/cjs/components/AsideHeader/components/AllPagesPanel/useVisibleMenuItems.d.ts +2 -0
  34. package/build/cjs/components/AsideHeader/components/AllPagesPanel/useVisibleMenuItems.js +29 -0
  35. package/build/cjs/components/AsideHeader/components/AllPagesPanel/useVisibleMenuItems.js.map +1 -0
  36. package/build/cjs/components/AsideHeader/components/CollapseButton/CollapseButton.css +1 -1
  37. package/build/cjs/components/AsideHeader/components/CollapseButton/CollapseButton.js +6 -11
  38. package/build/cjs/components/AsideHeader/components/CollapseButton/CollapseButton.js.map +1 -1
  39. package/build/cjs/components/AsideHeader/components/CollapseButton/CollapseButton.module.scss.js +1 -1
  40. package/build/cjs/components/AsideHeader/components/CompositeBar/CompositeBar.css +1 -1
  41. package/build/cjs/components/AsideHeader/components/CompositeBar/CompositeBar.d.ts +4 -26
  42. package/build/cjs/components/AsideHeader/components/CompositeBar/CompositeBar.js +39 -177
  43. package/build/cjs/components/AsideHeader/components/CompositeBar/CompositeBar.js.map +1 -1
  44. package/build/cjs/components/AsideHeader/components/CompositeBar/CompositeBar.module.scss.js +1 -1
  45. package/build/cjs/components/AsideHeader/components/CompositeBar/Item/Item.css +1 -1
  46. package/build/cjs/components/AsideHeader/components/CompositeBar/Item/Item.d.ts +1 -12
  47. package/build/cjs/components/AsideHeader/components/CompositeBar/Item/Item.js +52 -39
  48. package/build/cjs/components/AsideHeader/components/CompositeBar/Item/Item.js.map +1 -1
  49. package/build/cjs/components/AsideHeader/components/CompositeBar/Item/Item.module.scss.js +1 -1
  50. package/build/cjs/components/AsideHeader/components/CompositeBar/Item/Item.types.d.ts +20 -0
  51. package/build/cjs/components/AsideHeader/components/CompositeBar/Item/ItemPopup.d.ts +18 -0
  52. package/build/cjs/components/AsideHeader/components/CompositeBar/Item/ItemPopup.js +32 -0
  53. package/build/cjs/components/AsideHeader/components/CompositeBar/Item/ItemPopup.js.map +1 -0
  54. package/build/cjs/components/AsideHeader/components/CompositeBar/Item/renderItemTitle.d.ts +3 -0
  55. package/build/cjs/components/AsideHeader/components/CompositeBar/Item/renderItemTitle.js +19 -0
  56. package/build/cjs/components/AsideHeader/components/CompositeBar/Item/renderItemTitle.js.map +1 -0
  57. package/build/cjs/components/AsideHeader/components/CompositeBar/grouping.d.ts +11 -0
  58. package/build/cjs/components/AsideHeader/components/CompositeBar/grouping.js +68 -0
  59. package/build/cjs/components/AsideHeader/components/CompositeBar/grouping.js.map +1 -0
  60. package/build/cjs/components/AsideHeader/components/CompositeBar/utils.d.ts +10 -2
  61. package/build/cjs/components/AsideHeader/components/CompositeBar/utils.js +90 -9
  62. package/build/cjs/components/AsideHeader/components/CompositeBar/utils.js.map +1 -1
  63. package/build/cjs/components/AsideHeader/components/FirstPanel.js +20 -25
  64. package/build/cjs/components/AsideHeader/components/FirstPanel.js.map +1 -1
  65. package/build/cjs/components/AsideHeader/components/FooterItem/FooterItem.css +1 -1
  66. package/build/cjs/components/AsideHeader/components/Header.js +3 -9
  67. package/build/cjs/components/AsideHeader/components/Header.js.map +1 -1
  68. package/build/cjs/components/AsideHeader/components/PageLayout/AsideFallback.css +2 -0
  69. package/build/cjs/components/AsideHeader/components/PageLayout/AsideFallback.js +1 -0
  70. package/build/cjs/components/AsideHeader/components/PageLayout/PageLayout.css +2 -0
  71. package/build/cjs/components/AsideHeader/components/PageLayout/PageLayout.d.ts +1 -2
  72. package/build/cjs/components/AsideHeader/components/PageLayout/PageLayout.js +7 -16
  73. package/build/cjs/components/AsideHeader/components/PageLayout/PageLayout.js.map +1 -1
  74. package/build/cjs/components/AsideHeader/components/PageLayout/PageLayoutAside.css +2 -0
  75. package/build/cjs/components/AsideHeader/components/PageLayout/PageLayoutAside.js +3 -6
  76. package/build/cjs/components/AsideHeader/components/PageLayout/PageLayoutAside.js.map +1 -1
  77. package/build/cjs/components/AsideHeader/components/Panels.d.ts +1 -1
  78. package/build/cjs/components/AsideHeader/components/Panels.js +6 -17
  79. package/build/cjs/components/AsideHeader/components/Panels.js.map +1 -1
  80. package/build/cjs/components/AsideHeader/index.d.ts +1 -0
  81. package/build/cjs/components/AsideHeader/types.d.ts +3 -18
  82. package/build/cjs/components/AsideHeader/types.js.map +1 -1
  83. package/build/cjs/components/AsideHeader/useAsideHeaderInnerContextValue.d.ts +0 -4
  84. package/build/cjs/components/AsideHeader/useAsideHeaderInnerContextValue.js +8 -21
  85. package/build/cjs/components/AsideHeader/useAsideHeaderInnerContextValue.js.map +1 -1
  86. package/build/cjs/components/HotkeysPanel/HotkeysPanel.d.ts +7 -3
  87. package/build/cjs/components/HotkeysPanel/HotkeysPanel.js +15 -7
  88. package/build/cjs/components/HotkeysPanel/HotkeysPanel.js.map +1 -1
  89. package/build/cjs/components/Logo/Logo.css +1 -1
  90. package/build/cjs/components/Logo/Logo.js +2 -12
  91. package/build/cjs/components/Logo/Logo.js.map +1 -1
  92. package/build/cjs/components/Logo/Logo.module.scss.js +1 -1
  93. package/build/cjs/components/MobileHeader/BurgerMenu/BurgerCompositeBar/BurgerCompositeBar.css +1 -1
  94. package/build/cjs/components/MobileHeader/BurgerMenu/BurgerCompositeBar/BurgerCompositeBar.module.scss.js +1 -1
  95. package/build/cjs/components/MobileHeader/MobileHeader.d.ts +3 -7
  96. package/build/cjs/components/MobileHeader/MobileHeader.js +18 -14
  97. package/build/cjs/components/MobileHeader/MobileHeader.js.map +1 -1
  98. package/build/cjs/components/MobileHeader/OverlapPanel/OverlapPanel.d.ts +2 -2
  99. package/build/cjs/components/MobileHeader/OverlapPanel/OverlapPanel.js +2 -2
  100. package/build/cjs/components/MobileHeader/OverlapPanel/OverlapPanel.js.map +1 -1
  101. package/build/cjs/components/MobileHeader/types.d.ts +1 -1
  102. package/build/cjs/components/Settings/Settings.css +1 -1
  103. package/build/cjs/components/Settings/SettingsMenu/SettingsMenu.css +1 -1
  104. package/build/cjs/components/Settings/SettingsMenu/SettingsMenu.js +5 -1
  105. package/build/cjs/components/Settings/SettingsMenu/SettingsMenu.js.map +1 -1
  106. package/build/cjs/components/Settings/SettingsMenu/SettingsMenu.module.scss.js +1 -1
  107. package/build/cjs/components/constants.d.ts +3 -4
  108. package/build/cjs/components/constants.js +4 -6
  109. package/build/cjs/components/constants.js.map +1 -1
  110. package/build/cjs/components/types.d.ts +15 -6
  111. package/build/esm/assets/icons/control-menu-button.svg.js +18 -0
  112. package/build/esm/assets/icons/control-menu-button.svg.js.map +1 -0
  113. package/build/esm/components/AsideHeader/AsideHeader.css +1 -1
  114. package/build/esm/components/AsideHeader/AsideHeader.js +1 -1
  115. package/build/esm/components/AsideHeader/AsideHeader.js.map +1 -1
  116. package/build/esm/components/AsideHeader/AsideHeader.module.scss.js +1 -1
  117. package/build/esm/components/AsideHeader/AsideHeaderContext.d.ts +1 -12
  118. package/build/esm/components/AsideHeader/AsideHeaderContext.js +5 -5
  119. package/build/esm/components/AsideHeader/AsideHeaderContext.js.map +1 -1
  120. package/build/esm/components/AsideHeader/components/AllPagesPanel/AllPagesListItem/AllPagesListItem.css +1 -0
  121. package/build/esm/components/AsideHeader/components/AllPagesPanel/AllPagesListItem/AllPagesListItem.d.ts +12 -0
  122. package/build/esm/components/AsideHeader/components/AllPagesPanel/AllPagesListItem/AllPagesListItem.js +42 -0
  123. package/build/esm/components/AsideHeader/components/AllPagesPanel/AllPagesListItem/AllPagesListItem.js.map +1 -0
  124. package/build/esm/components/AsideHeader/components/AllPagesPanel/AllPagesListItem/AllPagesListItem.module.scss.js +4 -0
  125. package/build/esm/components/AsideHeader/components/AllPagesPanel/AllPagesListItem/AllPagesListItem.module.scss.js.map +1 -0
  126. package/build/esm/components/AsideHeader/components/AllPagesPanel/AllPagesListItem/index.d.ts +1 -0
  127. package/build/esm/components/AsideHeader/components/AllPagesPanel/AllPagesPanel.css +1 -1
  128. package/build/esm/components/AsideHeader/components/AllPagesPanel/AllPagesPanel.js +49 -99
  129. package/build/esm/components/AsideHeader/components/AllPagesPanel/AllPagesPanel.js.map +1 -1
  130. package/build/esm/components/AsideHeader/components/AllPagesPanel/AllPagesPanel.module.scss.js +1 -1
  131. package/build/esm/components/AsideHeader/components/AllPagesPanel/constants.d.ts +0 -1
  132. package/build/esm/components/AsideHeader/components/AllPagesPanel/constants.js +1 -2
  133. package/build/esm/components/AsideHeader/components/AllPagesPanel/constants.js.map +1 -1
  134. package/build/esm/components/AsideHeader/components/AllPagesPanel/i18n/en.json.js +1 -0
  135. package/build/esm/components/AsideHeader/components/AllPagesPanel/i18n/en.json.js.map +1 -1
  136. package/build/esm/components/AsideHeader/components/AllPagesPanel/i18n/index.d.ts +4 -4
  137. package/build/esm/components/AsideHeader/components/AllPagesPanel/i18n/ru.json.js +1 -0
  138. package/build/esm/components/AsideHeader/components/AllPagesPanel/i18n/ru.json.js.map +1 -1
  139. package/build/esm/components/AsideHeader/components/AllPagesPanel/index.d.ts +1 -0
  140. package/build/esm/components/AsideHeader/components/AllPagesPanel/useGroupedMenuItems.d.ts +4 -3
  141. package/build/esm/components/AsideHeader/components/AllPagesPanel/useGroupedMenuItems.js +15 -62
  142. package/build/esm/components/AsideHeader/components/AllPagesPanel/useGroupedMenuItems.js.map +1 -1
  143. package/build/esm/components/AsideHeader/components/AllPagesPanel/useVisibleMenuItems.d.ts +2 -0
  144. package/build/esm/components/AsideHeader/components/AllPagesPanel/useVisibleMenuItems.js +27 -0
  145. package/build/esm/components/AsideHeader/components/AllPagesPanel/useVisibleMenuItems.js.map +1 -0
  146. package/build/esm/components/AsideHeader/components/CollapseButton/CollapseButton.css +1 -1
  147. package/build/esm/components/AsideHeader/components/CollapseButton/CollapseButton.js +8 -13
  148. package/build/esm/components/AsideHeader/components/CollapseButton/CollapseButton.js.map +1 -1
  149. package/build/esm/components/AsideHeader/components/CollapseButton/CollapseButton.module.scss.js +1 -1
  150. package/build/esm/components/AsideHeader/components/CompositeBar/CompositeBar.css +1 -1
  151. package/build/esm/components/AsideHeader/components/CompositeBar/CompositeBar.d.ts +4 -26
  152. package/build/esm/components/AsideHeader/components/CompositeBar/CompositeBar.js +41 -178
  153. package/build/esm/components/AsideHeader/components/CompositeBar/CompositeBar.js.map +1 -1
  154. package/build/esm/components/AsideHeader/components/CompositeBar/CompositeBar.module.scss.js +1 -1
  155. package/build/esm/components/AsideHeader/components/CompositeBar/Item/Item.css +1 -1
  156. package/build/esm/components/AsideHeader/components/CompositeBar/Item/Item.d.ts +1 -12
  157. package/build/esm/components/AsideHeader/components/CompositeBar/Item/Item.js +55 -42
  158. package/build/esm/components/AsideHeader/components/CompositeBar/Item/Item.js.map +1 -1
  159. package/build/esm/components/AsideHeader/components/CompositeBar/Item/Item.module.scss.js +1 -1
  160. package/build/esm/components/AsideHeader/components/CompositeBar/Item/Item.types.d.ts +20 -0
  161. package/build/esm/components/AsideHeader/components/CompositeBar/Item/ItemPopup.d.ts +18 -0
  162. package/build/esm/components/AsideHeader/components/CompositeBar/Item/ItemPopup.js +30 -0
  163. package/build/esm/components/AsideHeader/components/CompositeBar/Item/ItemPopup.js.map +1 -0
  164. package/build/esm/components/AsideHeader/components/CompositeBar/Item/renderItemTitle.d.ts +3 -0
  165. package/build/esm/components/AsideHeader/components/CompositeBar/Item/renderItemTitle.js +17 -0
  166. package/build/esm/components/AsideHeader/components/CompositeBar/Item/renderItemTitle.js.map +1 -0
  167. package/build/esm/components/AsideHeader/components/CompositeBar/grouping.d.ts +11 -0
  168. package/build/esm/components/AsideHeader/components/CompositeBar/grouping.js +65 -0
  169. package/build/esm/components/AsideHeader/components/CompositeBar/grouping.js.map +1 -0
  170. package/build/esm/components/AsideHeader/components/CompositeBar/utils.d.ts +10 -2
  171. package/build/esm/components/AsideHeader/components/CompositeBar/utils.js +87 -11
  172. package/build/esm/components/AsideHeader/components/CompositeBar/utils.js.map +1 -1
  173. package/build/esm/components/AsideHeader/components/FirstPanel.js +20 -25
  174. package/build/esm/components/AsideHeader/components/FirstPanel.js.map +1 -1
  175. package/build/esm/components/AsideHeader/components/FooterItem/FooterItem.css +1 -1
  176. package/build/esm/components/AsideHeader/components/Header.js +3 -9
  177. package/build/esm/components/AsideHeader/components/Header.js.map +1 -1
  178. package/build/esm/components/AsideHeader/components/PageLayout/AsideFallback.css +2 -0
  179. package/build/esm/components/AsideHeader/components/PageLayout/AsideFallback.js +1 -0
  180. package/build/esm/components/AsideHeader/components/PageLayout/PageLayout.css +2 -0
  181. package/build/esm/components/AsideHeader/components/PageLayout/PageLayout.d.ts +1 -2
  182. package/build/esm/components/AsideHeader/components/PageLayout/PageLayout.js +8 -17
  183. package/build/esm/components/AsideHeader/components/PageLayout/PageLayout.js.map +1 -1
  184. package/build/esm/components/AsideHeader/components/PageLayout/PageLayoutAside.css +2 -0
  185. package/build/esm/components/AsideHeader/components/PageLayout/PageLayoutAside.js +3 -6
  186. package/build/esm/components/AsideHeader/components/PageLayout/PageLayoutAside.js.map +1 -1
  187. package/build/esm/components/AsideHeader/components/Panels.d.ts +1 -1
  188. package/build/esm/components/AsideHeader/components/Panels.js +7 -18
  189. package/build/esm/components/AsideHeader/components/Panels.js.map +1 -1
  190. package/build/esm/components/AsideHeader/index.d.ts +1 -0
  191. package/build/esm/components/AsideHeader/types.d.ts +3 -18
  192. package/build/esm/components/AsideHeader/types.js.map +1 -1
  193. package/build/esm/components/AsideHeader/useAsideHeaderInnerContextValue.d.ts +0 -4
  194. package/build/esm/components/AsideHeader/useAsideHeaderInnerContextValue.js +8 -21
  195. package/build/esm/components/AsideHeader/useAsideHeaderInnerContextValue.js.map +1 -1
  196. package/build/esm/components/HotkeysPanel/HotkeysPanel.d.ts +7 -3
  197. package/build/esm/components/HotkeysPanel/HotkeysPanel.js +15 -7
  198. package/build/esm/components/HotkeysPanel/HotkeysPanel.js.map +1 -1
  199. package/build/esm/components/Logo/Logo.css +1 -1
  200. package/build/esm/components/Logo/Logo.js +2 -12
  201. package/build/esm/components/Logo/Logo.js.map +1 -1
  202. package/build/esm/components/Logo/Logo.module.scss.js +1 -1
  203. package/build/esm/components/MobileHeader/BurgerMenu/BurgerCompositeBar/BurgerCompositeBar.css +1 -1
  204. package/build/esm/components/MobileHeader/BurgerMenu/BurgerCompositeBar/BurgerCompositeBar.module.scss.js +1 -1
  205. package/build/esm/components/MobileHeader/MobileHeader.d.ts +3 -7
  206. package/build/esm/components/MobileHeader/MobileHeader.js +18 -14
  207. package/build/esm/components/MobileHeader/MobileHeader.js.map +1 -1
  208. package/build/esm/components/MobileHeader/OverlapPanel/OverlapPanel.d.ts +2 -2
  209. package/build/esm/components/MobileHeader/OverlapPanel/OverlapPanel.js +2 -2
  210. package/build/esm/components/MobileHeader/OverlapPanel/OverlapPanel.js.map +1 -1
  211. package/build/esm/components/MobileHeader/types.d.ts +1 -1
  212. package/build/esm/components/Settings/Settings.css +1 -1
  213. package/build/esm/components/Settings/SettingsMenu/SettingsMenu.css +1 -1
  214. package/build/esm/components/Settings/SettingsMenu/SettingsMenu.js +5 -1
  215. package/build/esm/components/Settings/SettingsMenu/SettingsMenu.js.map +1 -1
  216. package/build/esm/components/Settings/SettingsMenu/SettingsMenu.module.scss.js +1 -1
  217. package/build/esm/components/constants.d.ts +3 -4
  218. package/build/esm/components/constants.js +4 -5
  219. package/build/esm/components/constants.js.map +1 -1
  220. package/build/esm/components/types.d.ts +15 -6
  221. package/codemods/transforms/unifyInterfaces.ts +0 -1
  222. package/package.json +5 -4
  223. package/build/cjs/components/ActionBar/__stories__/ActionBar.stories.d.ts +0 -20
  224. package/build/cjs/components/ActionBar/__stories__/ActionBarShowcase.d.ts +0 -2
  225. package/build/cjs/components/ActionBar/__stories__/ActionBarSingleSection.d.ts +0 -2
  226. package/build/cjs/components/ActionBar/__stories__/ActionBarStretchGroupShowcase.d.ts +0 -2
  227. package/build/cjs/components/ActionBar/__tests__/helpersPlaywright.d.ts +0 -5
  228. package/build/cjs/components/AsideHeader/__stories__/AsideHeader.stories.d.ts +0 -23
  229. package/build/cjs/components/AsideHeader/__stories__/AsideHeaderShowcase.d.ts +0 -13
  230. package/build/cjs/components/AsideHeader/__stories__/getAsideHeaderWrapper.d.ts +0 -3
  231. package/build/cjs/components/AsideHeader/__stories__/moc.d.ts +0 -17
  232. package/build/cjs/components/AsideHeader/__tests__/helpersPlaywright.d.ts +0 -2
  233. package/build/cjs/components/AsideHeader/components/AllPagesPanel/utils/buildExpandedFromFlatList.d.ts +0 -3
  234. package/build/cjs/components/AsideHeader/components/AllPagesPanel/utils/buildExpandedFromFlatList.js +0 -17
  235. package/build/cjs/components/AsideHeader/components/AllPagesPanel/utils/buildExpandedFromFlatList.js.map +0 -1
  236. package/build/cjs/components/AsideHeader/components/AllPagesPanel/utils/getIsMenuItem.d.ts +0 -2
  237. package/build/cjs/components/AsideHeader/components/AllPagesPanel/utils/getIsMenuItem.js +0 -13
  238. package/build/cjs/components/AsideHeader/components/AllPagesPanel/utils/getIsMenuItem.js.map +0 -1
  239. package/build/cjs/components/AsideHeader/components/AllPagesPanel/utils/getRealIndexInGroup.d.ts +0 -2
  240. package/build/cjs/components/AsideHeader/components/AllPagesPanel/utils/getRealIndexInGroup.js +0 -22
  241. package/build/cjs/components/AsideHeader/components/AllPagesPanel/utils/getRealIndexInGroup.js.map +0 -1
  242. package/build/cjs/components/AsideHeader/components/AllPagesPanel/utils/sortMenuItems.d.ts +0 -2
  243. package/build/cjs/components/AsideHeader/components/AllPagesPanel/utils/sortMenuItems.js +0 -16
  244. package/build/cjs/components/AsideHeader/components/AllPagesPanel/utils/sortMenuItems.js.map +0 -1
  245. package/build/cjs/components/AsideHeader/components/AllPagesPanel/utils/sortMenuItemsWithDividers.d.ts +0 -3
  246. package/build/cjs/components/AsideHeader/components/AllPagesPanel/utils/sortMenuItemsWithDividers.js +0 -44
  247. package/build/cjs/components/AsideHeader/components/AllPagesPanel/utils/sortMenuItemsWithDividers.js.map +0 -1
  248. package/build/cjs/components/AsideHeader/components/CompositeBar/MultipleTooltip/MultipleTooltip.css +0 -9
  249. package/build/cjs/components/AsideHeader/components/CompositeBar/MultipleTooltip/MultipleTooltip.d.ts +0 -9
  250. package/build/cjs/components/AsideHeader/components/CompositeBar/MultipleTooltip/MultipleTooltip.js +0 -34
  251. package/build/cjs/components/AsideHeader/components/CompositeBar/MultipleTooltip/MultipleTooltip.js.map +0 -1
  252. package/build/cjs/components/AsideHeader/components/CompositeBar/MultipleTooltip/MultipleTooltip.module.scss.js +0 -8
  253. package/build/cjs/components/AsideHeader/components/CompositeBar/MultipleTooltip/MultipleTooltip.module.scss.js.map +0 -1
  254. package/build/cjs/components/AsideHeader/components/CompositeBar/MultipleTooltip/MultipleTooltipContext.d.ts +0 -24
  255. package/build/cjs/components/AsideHeader/components/CompositeBar/MultipleTooltip/MultipleTooltipContext.js +0 -29
  256. package/build/cjs/components/AsideHeader/components/CompositeBar/MultipleTooltip/MultipleTooltipContext.js.map +0 -1
  257. package/build/cjs/components/AsideHeader/components/CompositeBar/MultipleTooltip/index.d.ts +0 -2
  258. package/build/cjs/components/AsideHeader/components/FooterItem/__stories__/FooterItem.stories.d.ts +0 -6
  259. package/build/cjs/components/AsideHeader/components/FooterItem/__tests__/helpersPlaywright.d.ts +0 -2
  260. package/build/cjs/components/AsideHeader/hooks/useDelayedToggle.d.ts +0 -6
  261. package/build/cjs/components/AsideHeader/hooks/useDelayedToggle.js +0 -57
  262. package/build/cjs/components/AsideHeader/hooks/useDelayedToggle.js.map +0 -1
  263. package/build/cjs/components/AsideHeader/hooks/useIsExpanded.d.ts +0 -7
  264. package/build/cjs/components/AsideHeader/hooks/useIsExpanded.js +0 -44
  265. package/build/cjs/components/AsideHeader/hooks/useIsExpanded.js.map +0 -1
  266. package/build/cjs/components/AsideHeader/utils/getGroupHeight.d.ts +0 -2
  267. package/build/cjs/components/AsideHeader/utils/getGroupHeight.js +0 -16
  268. package/build/cjs/components/AsideHeader/utils/getGroupHeight.js.map +0 -1
  269. package/build/cjs/components/Footer/desktop/__stories__/Footer.stories.d.ts +0 -8
  270. package/build/cjs/components/Footer/desktop/__stories__/FooterShowcase.d.ts +0 -4
  271. package/build/cjs/components/Footer/desktop/__stories__/moc.d.ts +0 -3
  272. package/build/cjs/components/Footer/desktop/__tests__/helpersPlaywright.d.ts +0 -2
  273. package/build/cjs/components/Footer/mobile/__stories__/MobileFooter.stories.d.ts +0 -8
  274. package/build/cjs/components/Footer/mobile/__stories__/MobileFooterShowcase.d.ts +0 -4
  275. package/build/cjs/components/Footer/mobile/__stories__/moc.d.ts +0 -3
  276. package/build/cjs/components/Footer/mobile/__tests__/helpersPlaywright.d.ts +0 -2
  277. package/build/cjs/components/HotkeysPanel/__stories__/HotkeysPanel.stories.d.ts +0 -5
  278. package/build/cjs/components/HotkeysPanel/__stories__/HotkeysPanelShowcase.d.ts +0 -6
  279. package/build/cjs/components/HotkeysPanel/__stories__/moc.d.ts +0 -2
  280. package/build/cjs/components/HotkeysPanel/__tests__/helpersPlaywright.d.ts +0 -2
  281. package/build/cjs/components/Logo/__stories__/Logo.stories.d.ts +0 -7
  282. package/build/cjs/components/Logo/__tests__/helpersPlaywright.d.ts +0 -2
  283. package/build/cjs/components/MobileHeader/BurgerMenu/__stories__/BurgerMenu.stories.d.ts +0 -6
  284. package/build/cjs/components/MobileHeader/BurgerMenu/__stories__/moc.d.ts +0 -2
  285. package/build/cjs/components/MobileHeader/BurgerMenu/__tests__/helpersPlaywright.d.ts +0 -2
  286. package/build/cjs/components/MobileHeader/OverlapPanel/__stories__/OverlapPanel.stories.d.ts +0 -6
  287. package/build/cjs/components/MobileHeader/OverlapPanel/__stories__/moc.d.ts +0 -2
  288. package/build/cjs/components/MobileHeader/OverlapPanel/__tests__/helpersPlaywright.d.ts +0 -2
  289. package/build/cjs/components/MobileHeader/__stories__/MobileHeader.stories.d.ts +0 -4
  290. package/build/cjs/components/MobileHeader/__stories__/MobileHeaderShowcase.d.ts +0 -3
  291. package/build/cjs/components/MobileHeader/__stories__/moc.d.ts +0 -1
  292. package/build/cjs/components/MobileHeader/__tests__/helpersPlaywright.d.ts +0 -2
  293. package/build/cjs/components/MobileLogo/__stories__/MobileLogo.stories.d.ts +0 -6
  294. package/build/cjs/components/MobileLogo/__tests__/helpersPlaywright.d.ts +0 -2
  295. package/build/cjs/components/Settings/__stories__/Settings.stories.d.ts +0 -5
  296. package/build/cjs/components/Settings/__stories__/SettingsDemo.d.ts +0 -14
  297. package/build/cjs/components/Settings/__stories__/SettingsMobileDemo.d.ts +0 -8
  298. package/build/cjs/components/Settings/__tests__/helpersPlaywright.d.ts +0 -2
  299. package/build/esm/components/ActionBar/__stories__/ActionBar.stories.d.ts +0 -20
  300. package/build/esm/components/ActionBar/__stories__/ActionBarShowcase.d.ts +0 -2
  301. package/build/esm/components/ActionBar/__stories__/ActionBarSingleSection.d.ts +0 -2
  302. package/build/esm/components/ActionBar/__stories__/ActionBarStretchGroupShowcase.d.ts +0 -2
  303. package/build/esm/components/ActionBar/__tests__/helpersPlaywright.d.ts +0 -5
  304. package/build/esm/components/AsideHeader/__stories__/AsideHeader.stories.d.ts +0 -23
  305. package/build/esm/components/AsideHeader/__stories__/AsideHeaderShowcase.d.ts +0 -13
  306. package/build/esm/components/AsideHeader/__stories__/getAsideHeaderWrapper.d.ts +0 -3
  307. package/build/esm/components/AsideHeader/__stories__/moc.d.ts +0 -17
  308. package/build/esm/components/AsideHeader/__tests__/helpersPlaywright.d.ts +0 -2
  309. package/build/esm/components/AsideHeader/components/AllPagesPanel/utils/buildExpandedFromFlatList.d.ts +0 -3
  310. package/build/esm/components/AsideHeader/components/AllPagesPanel/utils/buildExpandedFromFlatList.js +0 -15
  311. package/build/esm/components/AsideHeader/components/AllPagesPanel/utils/buildExpandedFromFlatList.js.map +0 -1
  312. package/build/esm/components/AsideHeader/components/AllPagesPanel/utils/getIsMenuItem.d.ts +0 -2
  313. package/build/esm/components/AsideHeader/components/AllPagesPanel/utils/getIsMenuItem.js +0 -11
  314. package/build/esm/components/AsideHeader/components/AllPagesPanel/utils/getIsMenuItem.js.map +0 -1
  315. package/build/esm/components/AsideHeader/components/AllPagesPanel/utils/getRealIndexInGroup.d.ts +0 -2
  316. package/build/esm/components/AsideHeader/components/AllPagesPanel/utils/getRealIndexInGroup.js +0 -20
  317. package/build/esm/components/AsideHeader/components/AllPagesPanel/utils/getRealIndexInGroup.js.map +0 -1
  318. package/build/esm/components/AsideHeader/components/AllPagesPanel/utils/sortMenuItems.d.ts +0 -2
  319. package/build/esm/components/AsideHeader/components/AllPagesPanel/utils/sortMenuItems.js +0 -14
  320. package/build/esm/components/AsideHeader/components/AllPagesPanel/utils/sortMenuItems.js.map +0 -1
  321. package/build/esm/components/AsideHeader/components/AllPagesPanel/utils/sortMenuItemsWithDividers.d.ts +0 -3
  322. package/build/esm/components/AsideHeader/components/AllPagesPanel/utils/sortMenuItemsWithDividers.js +0 -42
  323. package/build/esm/components/AsideHeader/components/AllPagesPanel/utils/sortMenuItemsWithDividers.js.map +0 -1
  324. package/build/esm/components/AsideHeader/components/CompositeBar/MultipleTooltip/MultipleTooltip.css +0 -9
  325. package/build/esm/components/AsideHeader/components/CompositeBar/MultipleTooltip/MultipleTooltip.d.ts +0 -9
  326. package/build/esm/components/AsideHeader/components/CompositeBar/MultipleTooltip/MultipleTooltip.js +0 -32
  327. package/build/esm/components/AsideHeader/components/CompositeBar/MultipleTooltip/MultipleTooltip.js.map +0 -1
  328. package/build/esm/components/AsideHeader/components/CompositeBar/MultipleTooltip/MultipleTooltip.module.scss.js +0 -4
  329. package/build/esm/components/AsideHeader/components/CompositeBar/MultipleTooltip/MultipleTooltip.module.scss.js.map +0 -1
  330. package/build/esm/components/AsideHeader/components/CompositeBar/MultipleTooltip/MultipleTooltipContext.d.ts +0 -24
  331. package/build/esm/components/AsideHeader/components/CompositeBar/MultipleTooltip/MultipleTooltipContext.js +0 -26
  332. package/build/esm/components/AsideHeader/components/CompositeBar/MultipleTooltip/MultipleTooltipContext.js.map +0 -1
  333. package/build/esm/components/AsideHeader/components/CompositeBar/MultipleTooltip/index.d.ts +0 -2
  334. package/build/esm/components/AsideHeader/components/FooterItem/__stories__/FooterItem.stories.d.ts +0 -6
  335. package/build/esm/components/AsideHeader/components/FooterItem/__tests__/helpersPlaywright.d.ts +0 -2
  336. package/build/esm/components/AsideHeader/hooks/useDelayedToggle.d.ts +0 -6
  337. package/build/esm/components/AsideHeader/hooks/useDelayedToggle.js +0 -55
  338. package/build/esm/components/AsideHeader/hooks/useDelayedToggle.js.map +0 -1
  339. package/build/esm/components/AsideHeader/hooks/useIsExpanded.d.ts +0 -7
  340. package/build/esm/components/AsideHeader/hooks/useIsExpanded.js +0 -42
  341. package/build/esm/components/AsideHeader/hooks/useIsExpanded.js.map +0 -1
  342. package/build/esm/components/AsideHeader/utils/getGroupHeight.d.ts +0 -2
  343. package/build/esm/components/AsideHeader/utils/getGroupHeight.js +0 -14
  344. package/build/esm/components/AsideHeader/utils/getGroupHeight.js.map +0 -1
  345. package/build/esm/components/Footer/desktop/__stories__/Footer.stories.d.ts +0 -8
  346. package/build/esm/components/Footer/desktop/__stories__/FooterShowcase.d.ts +0 -4
  347. package/build/esm/components/Footer/desktop/__stories__/moc.d.ts +0 -3
  348. package/build/esm/components/Footer/desktop/__tests__/helpersPlaywright.d.ts +0 -2
  349. package/build/esm/components/Footer/mobile/__stories__/MobileFooter.stories.d.ts +0 -8
  350. package/build/esm/components/Footer/mobile/__stories__/MobileFooterShowcase.d.ts +0 -4
  351. package/build/esm/components/Footer/mobile/__stories__/moc.d.ts +0 -3
  352. package/build/esm/components/Footer/mobile/__tests__/helpersPlaywright.d.ts +0 -2
  353. package/build/esm/components/HotkeysPanel/__stories__/HotkeysPanel.stories.d.ts +0 -5
  354. package/build/esm/components/HotkeysPanel/__stories__/HotkeysPanelShowcase.d.ts +0 -6
  355. package/build/esm/components/HotkeysPanel/__stories__/moc.d.ts +0 -2
  356. package/build/esm/components/HotkeysPanel/__tests__/helpersPlaywright.d.ts +0 -2
  357. package/build/esm/components/Logo/__stories__/Logo.stories.d.ts +0 -7
  358. package/build/esm/components/Logo/__tests__/helpersPlaywright.d.ts +0 -2
  359. package/build/esm/components/MobileHeader/BurgerMenu/__stories__/BurgerMenu.stories.d.ts +0 -6
  360. package/build/esm/components/MobileHeader/BurgerMenu/__stories__/moc.d.ts +0 -2
  361. package/build/esm/components/MobileHeader/BurgerMenu/__tests__/helpersPlaywright.d.ts +0 -2
  362. package/build/esm/components/MobileHeader/OverlapPanel/__stories__/OverlapPanel.stories.d.ts +0 -6
  363. package/build/esm/components/MobileHeader/OverlapPanel/__stories__/moc.d.ts +0 -2
  364. package/build/esm/components/MobileHeader/OverlapPanel/__tests__/helpersPlaywright.d.ts +0 -2
  365. package/build/esm/components/MobileHeader/__stories__/MobileHeader.stories.d.ts +0 -4
  366. package/build/esm/components/MobileHeader/__stories__/MobileHeaderShowcase.d.ts +0 -3
  367. package/build/esm/components/MobileHeader/__stories__/moc.d.ts +0 -1
  368. package/build/esm/components/MobileHeader/__tests__/helpersPlaywright.d.ts +0 -2
  369. package/build/esm/components/MobileLogo/__stories__/MobileLogo.stories.d.ts +0 -6
  370. package/build/esm/components/MobileLogo/__tests__/helpersPlaywright.d.ts +0 -2
  371. package/build/esm/components/Settings/__stories__/Settings.stories.d.ts +0 -5
  372. package/build/esm/components/Settings/__stories__/SettingsDemo.d.ts +0 -14
  373. package/build/esm/components/Settings/__stories__/SettingsMobileDemo.d.ts +0 -8
  374. package/build/esm/components/Settings/__tests__/helpersPlaywright.d.ts +0 -2
@@ -1 +1 @@
1
- {"version":3,"file":"OverlapPanel.js","sources":["../../../../../../src/components/MobileHeader/OverlapPanel/OverlapPanel.tsx"],"sourcesContent":["import React from 'react';\n\nimport {ArrowLeft as CloseIcon} from '@gravity-ui/icons';\nimport {Button, Drawer, Icon, IconProps, Text} from '@gravity-ui/uikit';\n\nimport {createBlock} from '../../utils/cn';\nimport {MOBILE_HEADER_ICON_SIZE} from '../constants';\nimport i18n from '../i18n';\n\nimport styles from './OverlapPanel.module.scss';\n\nconst b = createBlock('mobile-overlap-panel', styles);\n\ninterface OverlapPanelActionProps {\n icon: IconProps['data'];\n className?: string;\n onClick: (event: React.MouseEvent<HTMLElement, MouseEvent>) => void;\n title: string;\n}\n\nexport interface OverlapPanelProps {\n className?: string;\n title?: string;\n onClose: () => void;\n action?: OverlapPanelActionProps;\n renderContent: () => React.ReactNode;\n closeTitle?: string;\n visible: boolean;\n topOffset?: number | string;\n}\n\nexport const OverlapPanel = ({\n title,\n renderContent,\n className,\n onClose,\n action,\n closeTitle = i18n('overlap_button_close'),\n visible,\n topOffset,\n}: OverlapPanelProps) => {\n const topOffsetValue = typeof topOffset === 'number' ? `${topOffset}px` : topOffset;\n\n const drawerStyle = React.useMemo(\n () => ({top: `calc(${topOffsetValue} + var(--gn-top-alert-height, 0px))`}),\n [topOffsetValue],\n );\n\n return (\n <Drawer\n className={b('', {action: Boolean(action)}, className)}\n open={visible}\n onOpenChange={(open) => !open && onClose()}\n style={drawerStyle}\n contentClassName={b('drawer-item')}\n >\n <div className={b('header')}>\n <Button\n size=\"l\"\n view=\"flat\"\n className={b('close')}\n onClick={onClose}\n aria-label={closeTitle}\n >\n <Icon className={b('icon')} data={CloseIcon} size={MOBILE_HEADER_ICON_SIZE} />\n </Button>\n <Text\n whiteSpace=\"nowrap\"\n ellipsis\n variant={'subheader-2'}\n className={b('title')}\n as={title ? ('h2' as const) : undefined}\n >\n {title}\n </Text>\n {action && (\n <Button\n size=\"l\"\n type=\"button\"\n view=\"flat\"\n onClick={action.onClick}\n className={b('action')}\n aria-label={action.title}\n >\n <Icon data={action.icon} size={MOBILE_HEADER_ICON_SIZE} />\n </Button>\n )}\n </div>\n <div className={b('content')}>{renderContent()}</div>\n </Drawer>\n );\n};\n"],"names":["React","CloseIcon"],"mappings":";;;;;;;;AAWA,MAAM,CAAC,GAAG,WAAW,CAAC,sBAAsB,EAAE,MAAM,CAAC;AAoB9C,MAAM,YAAY,GAAG,CAAC,EACzB,KAAK,EACL,aAAa,EACb,SAAS,EACT,OAAO,EACP,MAAM,EACN,UAAU,GAAG,IAAI,CAAC,sBAAsB,CAAC,EACzC,OAAO,EACP,SAAS,GACO,KAAI;AACpB,IAAA,MAAM,cAAc,GAAG,OAAO,SAAS,KAAK,QAAQ,GAAG,CAAA,EAAG,SAAS,CAAI,EAAA,CAAA,GAAG,SAAS;IAEnF,MAAM,WAAW,GAAGA,cAAK,CAAC,OAAO,CAC7B,OAAO,EAAC,GAAG,EAAE,CAAA,KAAA,EAAQ,cAAc,CAAA,mCAAA,CAAqC,EAAC,CAAC,EAC1E,CAAC,cAAc,CAAC,CACnB;IAED,QACIA,6BAAC,MAAM,EAAA,EACH,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE,EAAC,MAAM,EAAE,OAAO,CAAC,MAAM,CAAC,EAAC,EAAE,SAAS,CAAC,EACtD,IAAI,EAAE,OAAO,EACb,YAAY,EAAE,CAAC,IAAI,KAAK,CAAC,IAAI,IAAI,OAAO,EAAE,EAC1C,KAAK,EAAE,WAAW,EAClB,gBAAgB,EAAE,CAAC,CAAC,aAAa,CAAC,EAAA;AAElC,QAAAA,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA,EAAK,SAAS,EAAE,CAAC,CAAC,QAAQ,CAAC,EAAA;YACvBA,cAAC,CAAA,aAAA,CAAA,MAAM,IACH,IAAI,EAAC,GAAG,EACR,IAAI,EAAC,MAAM,EACX,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,EACrB,OAAO,EAAE,OAAO,EAAA,YAAA,EACJ,UAAU,EAAA;AAEtB,gBAAAA,cAAA,CAAA,aAAA,CAAC,IAAI,EAAC,EAAA,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,EAAE,IAAI,EAAEC,SAAS,EAAE,IAAI,EAAE,uBAAuB,GAAI,CACzE;AACT,YAAAD,cAAA,CAAA,aAAA,CAAC,IAAI,EAAA,EACD,UAAU,EAAC,QAAQ,EACnB,QAAQ,EACR,IAAA,EAAA,OAAO,EAAE,aAAa,EACtB,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,EACrB,EAAE,EAAE,KAAK,GAAI,IAAc,GAAG,SAAS,EAAA,EAEtC,KAAK,CACH;AACN,YAAA,MAAM,KACHA,cAAC,CAAA,aAAA,CAAA,MAAM,IACH,IAAI,EAAC,GAAG,EACR,IAAI,EAAC,QAAQ,EACb,IAAI,EAAC,MAAM,EACX,OAAO,EAAE,MAAM,CAAC,OAAO,EACvB,SAAS,EAAE,CAAC,CAAC,QAAQ,CAAC,EACV,YAAA,EAAA,MAAM,CAAC,KAAK,EAAA;AAExB,gBAAAA,cAAA,CAAA,aAAA,CAAC,IAAI,EAAA,EAAC,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,IAAI,EAAE,uBAAuB,EAAI,CAAA,CACrD,CACZ,CACC;AACN,QAAAA,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA,EAAK,SAAS,EAAE,CAAC,CAAC,SAAS,CAAC,EAAG,EAAA,aAAa,EAAE,CAAO,CAChD;AAEjB;;;;"}
1
+ {"version":3,"file":"OverlapPanel.js","sources":["../../../../../../src/components/MobileHeader/OverlapPanel/OverlapPanel.tsx"],"sourcesContent":["import React from 'react';\n\nimport {ArrowLeft as CloseIcon} from '@gravity-ui/icons';\nimport {Button, Drawer, Icon, IconProps, Text} from '@gravity-ui/uikit';\n\nimport {createBlock} from '../../utils/cn';\nimport {MOBILE_HEADER_ICON_SIZE} from '../constants';\nimport i18n from '../i18n';\n\nimport styles from './OverlapPanel.module.scss';\n\nconst b = createBlock('mobile-overlap-panel', styles);\n\ninterface OverlapPanelActionProps {\n icon: IconProps['data'];\n className?: string;\n onClick: (event: React.MouseEvent<HTMLElement, MouseEvent>) => void;\n title: string;\n}\n\nexport interface OverlapPanelProps {\n className?: string;\n title?: string;\n onClose: () => void;\n action?: OverlapPanelActionProps;\n renderContent: () => React.ReactNode;\n closeTitle?: string;\n open: boolean;\n topOffset?: number | string;\n}\n\nexport const OverlapPanel = ({\n title,\n renderContent,\n className,\n onClose,\n action,\n closeTitle = i18n('overlap_button_close'),\n open,\n topOffset,\n}: OverlapPanelProps) => {\n const topOffsetValue = typeof topOffset === 'number' ? `${topOffset}px` : topOffset;\n\n const drawerStyle = React.useMemo(\n () => ({top: `calc(${topOffsetValue} + var(--gn-top-alert-height, 0px))`}),\n [topOffsetValue],\n );\n\n return (\n <Drawer\n className={b('', {action: Boolean(action)}, className)}\n open={open}\n onOpenChange={(open) => !open && onClose()}\n style={drawerStyle}\n contentClassName={b('drawer-item')}\n >\n <div className={b('header')}>\n <Button\n size=\"l\"\n view=\"flat\"\n className={b('close')}\n onClick={onClose}\n aria-label={closeTitle}\n >\n <Icon className={b('icon')} data={CloseIcon} size={MOBILE_HEADER_ICON_SIZE} />\n </Button>\n <Text\n whiteSpace=\"nowrap\"\n ellipsis\n variant={'subheader-2'}\n className={b('title')}\n as={title ? ('h2' as const) : undefined}\n >\n {title}\n </Text>\n {action && (\n <Button\n size=\"l\"\n type=\"button\"\n view=\"flat\"\n onClick={action.onClick}\n className={b('action')}\n aria-label={action.title}\n >\n <Icon data={action.icon} size={MOBILE_HEADER_ICON_SIZE} />\n </Button>\n )}\n </div>\n <div className={b('content')}>{renderContent()}</div>\n </Drawer>\n );\n};\n"],"names":["React","CloseIcon"],"mappings":";;;;;;;;AAWA,MAAM,CAAC,GAAG,WAAW,CAAC,sBAAsB,EAAE,MAAM,CAAC;AAoB9C,MAAM,YAAY,GAAG,CAAC,EACzB,KAAK,EACL,aAAa,EACb,SAAS,EACT,OAAO,EACP,MAAM,EACN,UAAU,GAAG,IAAI,CAAC,sBAAsB,CAAC,EACzC,IAAI,EACJ,SAAS,GACO,KAAI;AACpB,IAAA,MAAM,cAAc,GAAG,OAAO,SAAS,KAAK,QAAQ,GAAG,CAAA,EAAG,SAAS,CAAI,EAAA,CAAA,GAAG,SAAS;IAEnF,MAAM,WAAW,GAAGA,cAAK,CAAC,OAAO,CAC7B,OAAO,EAAC,GAAG,EAAE,CAAA,KAAA,EAAQ,cAAc,CAAA,mCAAA,CAAqC,EAAC,CAAC,EAC1E,CAAC,cAAc,CAAC,CACnB;IAED,QACIA,6BAAC,MAAM,EAAA,EACH,SAAS,EAAE,CAAC,CAAC,EAAE,EAAE,EAAC,MAAM,EAAE,OAAO,CAAC,MAAM,CAAC,EAAC,EAAE,SAAS,CAAC,EACtD,IAAI,EAAE,IAAI,EACV,YAAY,EAAE,CAAC,IAAI,KAAK,CAAC,IAAI,IAAI,OAAO,EAAE,EAC1C,KAAK,EAAE,WAAW,EAClB,gBAAgB,EAAE,CAAC,CAAC,aAAa,CAAC,EAAA;AAElC,QAAAA,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA,EAAK,SAAS,EAAE,CAAC,CAAC,QAAQ,CAAC,EAAA;YACvBA,cAAC,CAAA,aAAA,CAAA,MAAM,IACH,IAAI,EAAC,GAAG,EACR,IAAI,EAAC,MAAM,EACX,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,EACrB,OAAO,EAAE,OAAO,EAAA,YAAA,EACJ,UAAU,EAAA;AAEtB,gBAAAA,cAAA,CAAA,aAAA,CAAC,IAAI,EAAC,EAAA,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,EAAE,IAAI,EAAEC,SAAS,EAAE,IAAI,EAAE,uBAAuB,GAAI,CACzE;AACT,YAAAD,cAAA,CAAA,aAAA,CAAC,IAAI,EAAA,EACD,UAAU,EAAC,QAAQ,EACnB,QAAQ,EACR,IAAA,EAAA,OAAO,EAAE,aAAa,EACtB,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,EACrB,EAAE,EAAE,KAAK,GAAI,IAAc,GAAG,SAAS,EAAA,EAEtC,KAAK,CACH;AACN,YAAA,MAAM,KACHA,cAAC,CAAA,aAAA,CAAA,MAAM,IACH,IAAI,EAAC,GAAG,EACR,IAAI,EAAC,QAAQ,EACb,IAAI,EAAC,MAAM,EACX,OAAO,EAAE,MAAM,CAAC,OAAO,EACvB,SAAS,EAAE,CAAC,CAAC,QAAQ,CAAC,EACV,YAAA,EAAA,MAAM,CAAC,KAAK,EAAA;AAExB,gBAAAA,cAAA,CAAA,aAAA,CAAC,IAAI,EAAA,EAAC,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,IAAI,EAAE,uBAAuB,EAAI,CAAA,CACrD,CACZ,CACC;AACN,QAAAA,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA,EAAK,SAAS,EAAE,CAAC,CAAC,SAAS,CAAC,EAAG,EAAA,aAAa,EAAE,CAAO,CAChD;AAEjB;;;;"}
@@ -10,7 +10,7 @@ export interface ModalItem {
10
10
  onClose?: () => void;
11
11
  }
12
12
  type MobileMenuItemType = 'regular' | 'divider';
13
- export interface MobileMenuItem extends Omit<MenuItem, 'tooltipText' | 'rightAdornment' | 'itemWrapper' | 'onItemClick' | 'href'> {
13
+ export interface MobileMenuItem extends Omit<MenuItem, 'tooltipText' | 'pinned' | 'rightAdornment' | 'afterMoreButton' | 'itemWrapper' | 'onItemClick' | 'href'> {
14
14
  type?: MobileMenuItemType;
15
15
  closeMenuOnClick?: boolean;
16
16
  link?: string;
@@ -1 +1 @@
1
- .Settings-module__gn-settings___RP-Ow{display:grid;grid-template-columns:216px 1fr;height:100%;width:834px}.Settings-module__gn-settings_view_mobile___4DAjN{display:block;height:calc(80vh - 56px);overflow-x:hidden;width:auto}@supports (height:90dvh){.Settings-module__gn-settings_view_mobile___4DAjN{height:calc(90dvh - 56px)}}.Settings-module__gn-settings_view_mobile___4DAjN.Settings-module__gn-settings_loading___PpULI{text-align:center}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__loader___68JGV{margin-top:20px}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__search___2xBLH{margin:4px 0 16px;padding:0 20px}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__page___pbx2Y{overflow-y:visible}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__tabs___-Z5T9 .Settings-module__g-tabs__item___tsOZs:first-child{margin-left:20px}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__tabs___-Z5T9 .Settings-module__g-tabs__item___tsOZs:last-child{margin-right:20px}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__section-heading___gPmIo{font-family:var(--g-text-subheader-font-family);font-size:var(--g-text-subheader-3-font-size);font-weight:var(--g-text-subheader-font-weight);line-height:var(--g-text-subheader-3-line-height)}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__section-subheader___fl8WB{color:var(--g-color-text-secondary)}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__section-heading___gPmIo+.Settings-module__gn-settings-subheader___WAPMz{margin-top:8px}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__section-item___2NG92{margin-top:0}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__section-heading___gPmIo+.Settings-module__gn-settings__section-item___2NG92, .Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__section-subheader___fl8WB+.Settings-module__gn-settings__section-item___2NG92{margin-top:30px}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__section-item___2NG92+.Settings-module__gn-settings__section-item___2NG92{margin-top:22px}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__item___rCuSR:not(.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__item_mode_row___k5s8p){gap:8px;grid-template-columns:1fr}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__item-heading___1zCRl{font-family:var(--g-text-body-font-family);font-size:var(--g-text-body-2-font-size);font-weight:var(--g-text-body-font-weight);line-height:var(--g-text-body-2-line-height)}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__item-description___8rQUz{font-family:var(--g-text-body-font-family);font-size:var(--g-text-body-1-font-size);font-weight:var(--g-text-body-font-weight);line-height:var(--g-text-body-1-line-height)}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__item_mode_row___k5s8p{grid-template-columns:1fr auto}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__item_mode_row___k5s8p .Settings-module__gn-settings__item-heading___1zCRl{padding-right:20px}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__item-content___1InnS{width:100%}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__not-found___eIxBf{color:var(--g-color-text-hint);font-family:var(--g-text-body-font-family);font-size:var(--g-text-body-2-font-size);font-weight:var(--g-text-body-font-weight);justify-items:start;line-height:var(--g-text-body-2-line-height);margin:20px 0 0 20px}.Settings-module__gn-settings_loading___PpULI{grid-template-columns:auto}.Settings-module__gn-settings__loader___68JGV{place-self:center}.Settings-module__gn-settings__not-found___eIxBf{display:grid;height:100%;place-items:center}.Settings-module__gn-settings__menu___3XZde{border-right:1px solid var(--g-color-line-generic)}.Settings-module__gn-settings__heading___mLHq2{font-family:var(--g-text-subheader-font-family);font-size:var(--g-text-subheader-2-font-size);font-weight:var(--g-text-subheader-font-weight);line-height:var(--g-text-subheader-2-line-height);margin:20px 20px 0}.Settings-module__gn-settings__search___2xBLH{margin:0 20px 16px}.Settings-module__gn-settings__page___pbx2Y{overflow-y:auto}.Settings-module__gn-settings__content___tQ2hC{padding:20px}.Settings-module__gn-settings__section-right-adornment_hidden___wn9-S{opacity:0;transition:opacity .2s}.Settings-module__gn-settings__section-heading___gPmIo:hover .Settings-module__gn-settings__section-right-adornment_hidden___wn9-S{opacity:1}.Settings-module__gn-settings__section-heading___gPmIo{font-family:var(--g-text-subheader-font-family);font-size:var(--g-text-subheader-2-font-size);font-weight:var(--g-text-subheader-font-weight);line-height:var(--g-text-subheader-2-line-height);margin:0}.Settings-module__gn-settings__section-item___2NG92{margin-top:24px}.Settings-module__gn-settings__section___c6u3X+.Settings-module__gn-settings__section___c6u3X{margin-top:32px}.Settings-module__gn-settings__section___c6u3X:only-child .Settings-module__gn-settings__section-item___2NG92:first-of-type{margin-top:0}.Settings-module__gn-settings__section___c6u3X:only-child .Settings-module__gn-settings__section-heading___gPmIo{display:none}.Settings-module__gn-settings__item___rCuSR{display:grid;grid-template-columns:216px 1fr;justify-items:start}.Settings-module__gn-settings__item_title_hide___w1l3N{grid-template-columns:1fr;justify-items:normal}.Settings-module__gn-settings__item_align_top___sPweP{align-items:start}.Settings-module__gn-settings__item_align_center___GdjES{align-items:center}.Settings-module__gn-settings__item-title_badge___pTkg2{position:relative}.Settings-module__gn-settings__item-title_badge___pTkg2:after{background-color:var(--g-color-text-danger);border-radius:50%;content:"";display:block;height:6px;position:absolute;right:-8px;top:1px;width:6px}.Settings-module__gn-settings__item-description___8rQUz{color:var(--g-color-text-secondary);display:block;font-family:var(--g-text-caption-font-family);font-size:var(--g-text-caption-2-font-size);font-weight:var(--g-text-caption-font-weight);line-height:var(--g-text-caption-2-line-height);margin-top:2px;padding-right:20px}.Settings-module__gn-settings__item-right-adornment_hidden___9zgNP{opacity:0;transition:opacity .2s}.Settings-module__gn-settings__item___rCuSR:hover .Settings-module__gn-settings__item-right-adornment_hidden___9zgNP{opacity:1}.Settings-module__gn-settings__item_selected___e4r3Y, .Settings-module__gn-settings__section_selected___YOdnN{background:var(--g-color-base-selection);border-radius:8px;margin-left:-8px;padding:8px}.Settings-module__gn-settings__found___PDgmI{background:var(--g-color-base-selection);font-weight:var(--g-text-accent-font-weight)}
1
+ .Settings-module__gn-settings___RP-Ow{display:grid;grid-template-columns:216px 1fr;height:100%;width:834px}.Settings-module__gn-settings_view_mobile___4DAjN{display:block;height:calc(80vh - 56px);overflow-x:hidden;width:auto}@supports (height:90dvh){.Settings-module__gn-settings_view_mobile___4DAjN{height:calc(90dvh - 56px)}}.Settings-module__gn-settings_view_mobile___4DAjN.Settings-module__gn-settings_loading___PpULI{text-align:center}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__loader___68JGV{margin-top:20px}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__search___2xBLH{margin:4px 0 16px;padding:0 20px}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__page___pbx2Y{overflow-y:visible}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__tabs___-Z5T9 .Settings-module__g-tabs__item___tsOZs:first-child{margin-left:20px}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__tabs___-Z5T9 .Settings-module__g-tabs__item___tsOZs:last-child{margin-right:20px}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__section-heading___gPmIo{font-family:var(--g-text-subheader-font-family);font-size:var(--g-text-subheader-3-font-size);font-weight:var(--g-text-subheader-font-weight);line-height:var(--g-text-subheader-3-line-height)}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__section-subheader___fl8WB{color:var(--g-color-text-secondary)}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__section-heading___gPmIo+.Settings-module__gn-settings-subheader___WAPMz{margin-top:8px}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__section-item___2NG92{margin-top:0}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__section-heading___gPmIo+.Settings-module__gn-settings__section-item___2NG92, .Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__section-subheader___fl8WB+.Settings-module__gn-settings__section-item___2NG92{margin-top:30px}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__section-item___2NG92+.Settings-module__gn-settings__section-item___2NG92{margin-top:22px}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__item___rCuSR:not(.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__item_mode_row___k5s8p){gap:8px;grid-template-columns:1fr}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__item-heading___1zCRl{font-family:var(--g-text-body-font-family);font-size:var(--g-text-body-2-font-size);font-weight:var(--g-text-body-font-weight);line-height:var(--g-text-body-2-line-height)}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__item-description___8rQUz{font-family:var(--g-text-body-font-family);font-size:var(--g-text-body-1-font-size);font-weight:var(--g-text-body-font-weight);line-height:var(--g-text-body-1-line-height)}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__item_mode_row___k5s8p{grid-template-columns:1fr auto}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__item_mode_row___k5s8p .Settings-module__gn-settings__item-heading___1zCRl{padding-right:20px}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__item-content___1InnS{width:100%}.Settings-module__gn-settings_view_mobile___4DAjN .Settings-module__gn-settings__not-found___eIxBf{color:var(--g-color-text-hint);font-family:var(--g-text-body-font-family);font-size:var(--g-text-body-2-font-size);font-weight:var(--g-text-body-font-weight);justify-items:start;line-height:var(--g-text-body-2-line-height);margin:20px 0 0 20px}.Settings-module__gn-settings_loading___PpULI{grid-template-columns:auto}.Settings-module__gn-settings__loader___68JGV{place-self:center}.Settings-module__gn-settings__not-found___eIxBf{display:grid;height:100%;place-items:center}.Settings-module__gn-settings__menu___3XZde{border-right:1px solid var(--g-color-line-generic);display:flex;flex-direction:column;min-height:0}.Settings-module__gn-settings__heading___mLHq2{font-family:var(--g-text-subheader-font-family);font-size:var(--g-text-subheader-2-font-size);font-weight:var(--g-text-subheader-font-weight);line-height:var(--g-text-subheader-2-line-height);margin:20px 20px 0}.Settings-module__gn-settings__search___2xBLH{margin:0 20px 16px}.Settings-module__gn-settings__page___pbx2Y{overflow-y:auto}.Settings-module__gn-settings__content___tQ2hC{padding:20px}.Settings-module__gn-settings__section-right-adornment_hidden___wn9-S{opacity:0;transition:opacity .2s}.Settings-module__gn-settings__section-heading___gPmIo:hover .Settings-module__gn-settings__section-right-adornment_hidden___wn9-S{opacity:1}.Settings-module__gn-settings__section-heading___gPmIo{font-family:var(--g-text-subheader-font-family);font-size:var(--g-text-subheader-2-font-size);font-weight:var(--g-text-subheader-font-weight);line-height:var(--g-text-subheader-2-line-height);margin:0}.Settings-module__gn-settings__section-item___2NG92{margin-top:24px}.Settings-module__gn-settings__section___c6u3X+.Settings-module__gn-settings__section___c6u3X{margin-top:32px}.Settings-module__gn-settings__section___c6u3X:only-child .Settings-module__gn-settings__section-item___2NG92:first-of-type{margin-top:0}.Settings-module__gn-settings__section___c6u3X:only-child .Settings-module__gn-settings__section-heading___gPmIo{display:none}.Settings-module__gn-settings__item___rCuSR{display:grid;grid-template-columns:216px 1fr;justify-items:start}.Settings-module__gn-settings__item_title_hide___w1l3N{grid-template-columns:1fr;justify-items:normal}.Settings-module__gn-settings__item_align_top___sPweP{align-items:start}.Settings-module__gn-settings__item_align_center___GdjES{align-items:center}.Settings-module__gn-settings__item-title_badge___pTkg2{position:relative}.Settings-module__gn-settings__item-title_badge___pTkg2:after{background-color:var(--g-color-text-danger);border-radius:50%;content:"";display:block;height:6px;position:absolute;right:-8px;top:1px;width:6px}.Settings-module__gn-settings__item-description___8rQUz{color:var(--g-color-text-secondary);display:block;font-family:var(--g-text-caption-font-family);font-size:var(--g-text-caption-2-font-size);font-weight:var(--g-text-caption-font-weight);line-height:var(--g-text-caption-2-line-height);margin-top:2px;padding-right:20px}.Settings-module__gn-settings__item-right-adornment_hidden___9zgNP{opacity:0;transition:opacity .2s}.Settings-module__gn-settings__item___rCuSR:hover .Settings-module__gn-settings__item-right-adornment_hidden___9zgNP{opacity:1}.Settings-module__gn-settings__item_selected___e4r3Y, .Settings-module__gn-settings__section_selected___YOdnN{background:var(--g-color-base-selection);border-radius:8px;margin-left:-8px;padding:8px}.Settings-module__gn-settings__found___PDgmI{background:var(--g-color-base-selection);font-weight:var(--g-text-accent-font-weight)}
@@ -1 +1 @@
1
- .SettingsMenu-module__gn-settings-menu__group-heading___b3rMA{display:inline-block;font-weight:var(--g-text-accent-font-weight);line-height:18px;margin-bottom:12px;padding:0 20px}.SettingsMenu-module__gn-settings-menu__group___zBrCj+.SettingsMenu-module__gn-settings-menu__group___zBrCj{margin-top:24px}.SettingsMenu-module__gn-settings-menu__item___QGz0Y+.SettingsMenu-module__gn-settings-menu__group___zBrCj{margin-top:8px}.SettingsMenu-module__gn-settings-menu__item___QGz0Y{align-items:center;color:var(--g-color-text-primary);cursor:pointer;display:flex;height:40px;padding:0 20px}.SettingsMenu-module__gn-settings-menu__item-icon___B-h-X{color:var(--g-color-text-misc);margin-right:5px}.SettingsMenu-module__gn-settings-menu__item___QGz0Y:hover, .SettingsMenu-module__gn-settings-menu__item_focused___pKQBC{background:var(--g-color-base-simple-hover)}.SettingsMenu-module__gn-settings-menu__item_selected___Og2Jr{background:var(--g-color-base-selection)}.SettingsMenu-module__gn-settings-menu__item_selected___Og2Jr.SettingsMenu-module__gn-settings-menu__item_focused___pKQBC, .SettingsMenu-module__gn-settings-menu__item_selected___Og2Jr:hover{background:var(--g-color-base-selection-hover)}.SettingsMenu-module__gn-settings-menu__item_disabled___xv9E8{color:var(--g-color-text-secondary);cursor:auto}.SettingsMenu-module__gn-settings-menu__item_disabled___xv9E8:hover{background:none}.SettingsMenu-module__gn-settings-menu__item_disabled___xv9E8 .SettingsMenu-module__gn-settings-menu__item-icon___B-h-X{color:var(--g-color-base-misc-heavy)}.SettingsMenu-module__gn-settings-menu__item_badge___I-O-X{position:relative}.SettingsMenu-module__gn-settings-menu__item_badge___I-O-X:after{background-color:var(--g-color-text-danger);border-radius:50%;content:"";display:block;height:6px;position:absolute;right:9px;top:calc(50% - 3px);width:6px}
1
+ .SettingsMenu-module__gn-settings-menu___ChFyc{overflow-y:auto}.SettingsMenu-module__gn-settings-menu_scrolled___QYbnX{box-shadow:inset 0 5px 5px -5px rgba(0,0,0,.15)}.SettingsMenu-module__gn-settings-menu__group-heading___b3rMA{display:inline-block;font-weight:var(--g-text-accent-font-weight);line-height:18px;margin-bottom:12px;padding:0 20px}.SettingsMenu-module__gn-settings-menu__group___zBrCj+.SettingsMenu-module__gn-settings-menu__group___zBrCj{margin-top:24px}.SettingsMenu-module__gn-settings-menu__item___QGz0Y+.SettingsMenu-module__gn-settings-menu__group___zBrCj{margin-top:8px}.SettingsMenu-module__gn-settings-menu__item___QGz0Y{align-items:center;color:var(--g-color-text-primary);cursor:pointer;display:flex;height:40px;padding:0 20px}.SettingsMenu-module__gn-settings-menu__item-icon___B-h-X{color:var(--g-color-text-misc);margin-right:5px}.SettingsMenu-module__gn-settings-menu__item___QGz0Y:hover, .SettingsMenu-module__gn-settings-menu__item_focused___pKQBC{background:var(--g-color-base-simple-hover)}.SettingsMenu-module__gn-settings-menu__item_selected___Og2Jr{background:var(--g-color-base-selection)}.SettingsMenu-module__gn-settings-menu__item_selected___Og2Jr.SettingsMenu-module__gn-settings-menu__item_focused___pKQBC, .SettingsMenu-module__gn-settings-menu__item_selected___Og2Jr:hover{background:var(--g-color-base-selection-hover)}.SettingsMenu-module__gn-settings-menu__item_disabled___xv9E8{color:var(--g-color-text-secondary);cursor:auto}.SettingsMenu-module__gn-settings-menu__item_disabled___xv9E8:hover{background:none}.SettingsMenu-module__gn-settings-menu__item_disabled___xv9E8 .SettingsMenu-module__gn-settings-menu__item-icon___B-h-X{color:var(--g-color-base-misc-heavy)}.SettingsMenu-module__gn-settings-menu__item_badge___I-O-X{position:relative}.SettingsMenu-module__gn-settings-menu__item_badge___I-O-X:after{background-color:var(--g-color-text-danger);border-radius:50%;content:"";display:block;height:6px;position:absolute;right:9px;top:calc(50% - 3px);width:6px}
@@ -10,9 +10,13 @@ const SettingsMenu = React__default.forwardRef(
10
10
  // eslint-disable-next-line prefer-arrow-callback
11
11
  function SettingsMenu({ items, onChange, activeItemId }, ref) {
12
12
  const [focusItemId, setFocusId] = React__default.useState();
13
+ const [scrolled, setScrolled] = React__default.useState(false);
13
14
  const containerRef = React__default.useRef(null);
14
15
  const handleChange = useStableCallback(onChange);
15
16
  const getFocused = useCurrent(focusItemId);
17
+ const handleScroll = React__default.useCallback((event) => {
18
+ setScrolled(event.currentTarget.scrollTop > 0);
19
+ }, []);
16
20
  React__default.useImperativeHandle(ref, () => ({
17
21
  handleKeyDown(event) {
18
22
  if (!containerRef.current) {
@@ -37,7 +41,7 @@ function SettingsMenu({ items, onChange, activeItemId }, ref) {
37
41
  setFocusId(undefined);
38
42
  },
39
43
  }), [getFocused, handleChange]);
40
- return (React__default.createElement("div", { ref: containerRef, className: b() }, items.map((firstLevelItem) => {
44
+ return (React__default.createElement("div", { ref: containerRef, className: b({ scrolled }), onScroll: handleScroll }, items.map((firstLevelItem) => {
41
45
  if ('groupTitle' in firstLevelItem) {
42
46
  return (React__default.createElement("div", { key: firstLevelItem.groupTitle, className: b('group') },
43
47
  React__default.createElement("span", { className: b('group-heading') }, firstLevelItem.groupTitle),
@@ -1 +1 @@
1
- {"version":3,"file":"SettingsMenu.js","sources":["../../../../../../src/components/Settings/SettingsMenu/SettingsMenu.tsx"],"sourcesContent":["import React from 'react';\n\nimport {Icon} from '@gravity-ui/uikit';\n\nimport {createBlock} from '../../utils/cn';\nimport {useCurrent, useStableCallback} from '../helpers';\nimport {Item, SettingsMenuProps} from '../types';\n\nimport styles from './SettingsMenu.module.scss';\n\nconst b = createBlock('settings-menu', styles);\n\nexport interface SettingsMenuInstance {\n handleKeyDown(event: React.KeyboardEvent): boolean;\n clearFocus(): void;\n}\n\nexport const SettingsMenu = React.forwardRef<SettingsMenuInstance, SettingsMenuProps>(\n // eslint-disable-next-line prefer-arrow-callback\n function SettingsMenu({items, onChange, activeItemId}, ref) {\n const [focusItemId, setFocusId] = React.useState<string>();\n const containerRef = React.useRef<HTMLDivElement>(null);\n const handleChange = useStableCallback(onChange);\n const getFocused = useCurrent(focusItemId);\n\n React.useImperativeHandle(\n ref,\n () => ({\n handleKeyDown(event) {\n if (!containerRef.current) {\n return false;\n }\n const focused = getFocused();\n if (focused && event.key === 'Enter') {\n handleChange(focused);\n return true;\n } else if (event.key === 'ArrowDown') {\n setFocusId(focusNext(containerRef.current, focused, 1));\n return true;\n } else if (event.key === 'ArrowUp') {\n setFocusId(focusNext(containerRef.current, focused, -1));\n return true;\n }\n return false;\n },\n clearFocus() {\n setFocusId(undefined);\n },\n }),\n [getFocused, handleChange],\n );\n\n return (\n <div ref={containerRef} className={b()}>\n {items.map((firstLevelItem) => {\n if ('groupTitle' in firstLevelItem) {\n return (\n <div key={firstLevelItem.groupTitle} className={b('group')}>\n <span className={b('group-heading')}>\n {firstLevelItem.groupTitle}\n </span>\n {firstLevelItem.items.map((item) => {\n return renderMenuItem(\n item,\n onChange,\n activeItemId,\n focusItemId,\n );\n })}\n </div>\n );\n }\n return renderMenuItem(firstLevelItem, onChange, activeItemId, focusItemId);\n })}\n </div>\n );\n },\n);\n\nfunction renderMenuItem(\n item: Item,\n onChange: (id: string) => void,\n activeItemId: string | undefined,\n focusItemId: string | undefined,\n) {\n return (\n <span\n key={item.title}\n className={b('item', {\n selected: activeItemId === item.id,\n disabled: item.disabled,\n focused: focusItemId === item.id,\n badge: item.withBadge,\n })}\n onClick={() => {\n if (!item.disabled) {\n onChange(item.id);\n }\n }}\n data-id={item.id}\n >\n {item.icon ? <Icon size={16} {...item.icon} className={b('item-icon')} /> : undefined}\n <span>{item.title}</span>\n </span>\n );\n}\n\nfunction focusNext(container: HTMLElement, focused: string | undefined, direction: number) {\n const elements = container.querySelectorAll(`.${b('item')}:not(.${b('item')}_disabled)`);\n if (elements.length === 0) {\n return undefined;\n }\n\n let currentIndex = direction > 0 ? -1 : 0;\n if (focused) {\n currentIndex = Array.prototype.findIndex.call(\n elements,\n (element) => element.getAttribute('data-id') === focused,\n );\n }\n\n currentIndex = (elements.length + currentIndex + direction) % elements.length;\n return elements[currentIndex].getAttribute('data-id') ?? undefined;\n}\n"],"names":["React"],"mappings":"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"}
1
+ {"version":3,"file":"SettingsMenu.js","sources":["../../../../../../src/components/Settings/SettingsMenu/SettingsMenu.tsx"],"sourcesContent":["import React from 'react';\n\nimport {Icon} from '@gravity-ui/uikit';\n\nimport {createBlock} from '../../utils/cn';\nimport {useCurrent, useStableCallback} from '../helpers';\nimport {Item, SettingsMenuProps} from '../types';\n\nimport styles from './SettingsMenu.module.scss';\n\nconst b = createBlock('settings-menu', styles);\n\nexport interface SettingsMenuInstance {\n handleKeyDown(event: React.KeyboardEvent): boolean;\n clearFocus(): void;\n}\n\nexport const SettingsMenu = React.forwardRef<SettingsMenuInstance, SettingsMenuProps>(\n // eslint-disable-next-line prefer-arrow-callback\n function SettingsMenu({items, onChange, activeItemId}, ref) {\n const [focusItemId, setFocusId] = React.useState<string>();\n const [scrolled, setScrolled] = React.useState(false);\n const containerRef = React.useRef<HTMLDivElement>(null);\n const handleChange = useStableCallback(onChange);\n const getFocused = useCurrent(focusItemId);\n\n const handleScroll = React.useCallback((event: React.UIEvent<HTMLDivElement>) => {\n setScrolled(event.currentTarget.scrollTop > 0);\n }, []);\n\n React.useImperativeHandle(\n ref,\n () => ({\n handleKeyDown(event) {\n if (!containerRef.current) {\n return false;\n }\n const focused = getFocused();\n if (focused && event.key === 'Enter') {\n handleChange(focused);\n return true;\n } else if (event.key === 'ArrowDown') {\n setFocusId(focusNext(containerRef.current, focused, 1));\n return true;\n } else if (event.key === 'ArrowUp') {\n setFocusId(focusNext(containerRef.current, focused, -1));\n return true;\n }\n return false;\n },\n clearFocus() {\n setFocusId(undefined);\n },\n }),\n [getFocused, handleChange],\n );\n\n return (\n <div ref={containerRef} className={b({scrolled})} onScroll={handleScroll}>\n {items.map((firstLevelItem) => {\n if ('groupTitle' in firstLevelItem) {\n return (\n <div key={firstLevelItem.groupTitle} className={b('group')}>\n <span className={b('group-heading')}>\n {firstLevelItem.groupTitle}\n </span>\n {firstLevelItem.items.map((item) => {\n return renderMenuItem(\n item,\n onChange,\n activeItemId,\n focusItemId,\n );\n })}\n </div>\n );\n }\n return renderMenuItem(firstLevelItem, onChange, activeItemId, focusItemId);\n })}\n </div>\n );\n },\n);\n\nfunction renderMenuItem(\n item: Item,\n onChange: (id: string) => void,\n activeItemId: string | undefined,\n focusItemId: string | undefined,\n) {\n return (\n <span\n key={item.title}\n className={b('item', {\n selected: activeItemId === item.id,\n disabled: item.disabled,\n focused: focusItemId === item.id,\n badge: item.withBadge,\n })}\n onClick={() => {\n if (!item.disabled) {\n onChange(item.id);\n }\n }}\n data-id={item.id}\n >\n {item.icon ? <Icon size={16} {...item.icon} className={b('item-icon')} /> : undefined}\n <span>{item.title}</span>\n </span>\n );\n}\n\nfunction focusNext(container: HTMLElement, focused: string | undefined, direction: number) {\n const elements = container.querySelectorAll(`.${b('item')}:not(.${b('item')}_disabled)`);\n if (elements.length === 0) {\n return undefined;\n }\n\n let currentIndex = direction > 0 ? -1 : 0;\n if (focused) {\n currentIndex = Array.prototype.findIndex.call(\n elements,\n (element) => element.getAttribute('data-id') === focused,\n );\n }\n\n currentIndex = (elements.length + currentIndex + direction) % elements.length;\n return elements[currentIndex].getAttribute('data-id') ?? undefined;\n}\n"],"names":["React"],"mappings":";;;;;;AAUA,MAAM,CAAC,GAAG,WAAW,CAAC,eAAe,EAAE,MAAM,CAAC;AAOjC,MAAA,YAAY,GAAGA,cAAK,CAAC,UAAU;AACxC;AACA,SAAS,YAAY,CAAC,EAAC,KAAK,EAAE,QAAQ,EAAE,YAAY,EAAC,EAAE,GAAG,EAAA;IACtD,MAAM,CAAC,WAAW,EAAE,UAAU,CAAC,GAAGA,cAAK,CAAC,QAAQ,EAAU;AAC1D,IAAA,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAGA,cAAK,CAAC,QAAQ,CAAC,KAAK,CAAC;IACrD,MAAM,YAAY,GAAGA,cAAK,CAAC,MAAM,CAAiB,IAAI,CAAC;AACvD,IAAA,MAAM,YAAY,GAAG,iBAAiB,CAAC,QAAQ,CAAC;AAChD,IAAA,MAAM,UAAU,GAAG,UAAU,CAAC,WAAW,CAAC;IAE1C,MAAM,YAAY,GAAGA,cAAK,CAAC,WAAW,CAAC,CAAC,KAAoC,KAAI;QAC5E,WAAW,CAAC,KAAK,CAAC,aAAa,CAAC,SAAS,GAAG,CAAC,CAAC;KACjD,EAAE,EAAE,CAAC;IAENA,cAAK,CAAC,mBAAmB,CACrB,GAAG,EACH,OAAO;AACH,QAAA,aAAa,CAAC,KAAK,EAAA;AACf,YAAA,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE;AACvB,gBAAA,OAAO,KAAK;;AAEhB,YAAA,MAAM,OAAO,GAAG,UAAU,EAAE;YAC5B,IAAI,OAAO,IAAI,KAAK,CAAC,GAAG,KAAK,OAAO,EAAE;gBAClC,YAAY,CAAC,OAAO,CAAC;AACrB,gBAAA,OAAO,IAAI;;AACR,iBAAA,IAAI,KAAK,CAAC,GAAG,KAAK,WAAW,EAAE;AAClC,gBAAA,UAAU,CAAC,SAAS,CAAC,YAAY,CAAC,OAAO,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC;AACvD,gBAAA,OAAO,IAAI;;AACR,iBAAA,IAAI,KAAK,CAAC,GAAG,KAAK,SAAS,EAAE;AAChC,gBAAA,UAAU,CAAC,SAAS,CAAC,YAAY,CAAC,OAAO,EAAE,OAAO,EAAE,EAAE,CAAC,CAAC;AACxD,gBAAA,OAAO,IAAI;;AAEf,YAAA,OAAO,KAAK;SACf;QACD,UAAU,GAAA;YACN,UAAU,CAAC,SAAS,CAAC;SACxB;AACJ,KAAA,CAAC,EACF,CAAC,UAAU,EAAE,YAAY,CAAC,CAC7B;IAED,QACIA,cAAK,CAAA,aAAA,CAAA,KAAA,EAAA,EAAA,GAAG,EAAE,YAAY,EAAE,SAAS,EAAE,CAAC,CAAC,EAAC,QAAQ,EAAC,CAAC,EAAE,QAAQ,EAAE,YAAY,EACnE,EAAA,KAAK,CAAC,GAAG,CAAC,CAAC,cAAc,KAAI;AAC1B,QAAA,IAAI,YAAY,IAAI,cAAc,EAAE;AAChC,YAAA,QACIA,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA,EAAK,GAAG,EAAE,cAAc,CAAC,UAAU,EAAE,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,EAAA;gBACtDA,cAAM,CAAA,aAAA,CAAA,MAAA,EAAA,EAAA,SAAS,EAAE,CAAC,CAAC,eAAe,CAAC,EAC9B,EAAA,cAAc,CAAC,UAAU,CACvB;gBACN,cAAc,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,KAAI;oBAC/B,OAAO,cAAc,CACjB,IAAI,EACJ,QAAQ,EACR,YAAY,EACZ,WAAW,CACd;iBACJ,CAAC,CACA;;QAGd,OAAO,cAAc,CAAC,cAAc,EAAE,QAAQ,EAAE,YAAY,EAAE,WAAW,CAAC;KAC7E,CAAC,CACA;AAEd,CAAC;AAGL,SAAS,cAAc,CACnB,IAAU,EACV,QAA8B,EAC9B,YAAgC,EAChC,WAA+B,EAAA;AAE/B,IAAA,QACIA,cAAA,CAAA,aAAA,CAAA,MAAA,EAAA,EACI,GAAG,EAAE,IAAI,CAAC,KAAK,EACf,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE;AACjB,YAAA,QAAQ,EAAE,YAAY,KAAK,IAAI,CAAC,EAAE;YAClC,QAAQ,EAAE,IAAI,CAAC,QAAQ;AACvB,YAAA,OAAO,EAAE,WAAW,KAAK,IAAI,CAAC,EAAE;YAChC,KAAK,EAAE,IAAI,CAAC,SAAS;AACxB,SAAA,CAAC,EACF,OAAO,EAAE,MAAK;AACV,YAAA,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;AAChB,gBAAA,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;;SAExB,EAAA,SAAA,EACQ,IAAI,CAAC,EAAE,EAAA;QAEf,IAAI,CAAC,IAAI,GAAGA,cAAC,CAAA,aAAA,CAAA,IAAI,EAAC,MAAA,CAAA,MAAA,CAAA,EAAA,IAAI,EAAE,EAAE,EAAM,EAAA,IAAI,CAAC,IAAI,EAAA,EAAE,SAAS,EAAE,CAAC,CAAC,WAAW,CAAC,EAAI,CAAA,CAAA,GAAG,SAAS;AACrF,QAAAA,cAAA,CAAA,aAAA,CAAA,MAAA,EAAA,IAAA,EAAO,IAAI,CAAC,KAAK,CAAQ,CACtB;AAEf;AAEA,SAAS,SAAS,CAAC,SAAsB,EAAE,OAA2B,EAAE,SAAiB,EAAA;;AACrF,IAAA,MAAM,QAAQ,GAAG,SAAS,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,CAAA,UAAA,CAAY,CAAC;AACxF,IAAA,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE;AACvB,QAAA,OAAO,SAAS;;AAGpB,IAAA,IAAI,YAAY,GAAG,SAAS,GAAG,CAAC,GAAG,EAAE,GAAG,CAAC;IACzC,IAAI,OAAO,EAAE;QACT,YAAY,GAAG,KAAK,CAAC,SAAS,CAAC,SAAS,CAAC,IAAI,CACzC,QAAQ,EACR,CAAC,OAAO,KAAK,OAAO,CAAC,YAAY,CAAC,SAAS,CAAC,KAAK,OAAO,CAC3D;;AAGL,IAAA,YAAY,GAAG,CAAC,QAAQ,CAAC,MAAM,GAAG,YAAY,GAAG,SAAS,IAAI,QAAQ,CAAC,MAAM;AAC7E,IAAA,OAAO,CAAA,EAAA,GAAA,QAAQ,CAAC,YAAY,CAAC,CAAC,YAAY,CAAC,SAAS,CAAC,MAAI,IAAA,IAAA,EAAA,KAAA,SAAA,GAAA,EAAA,GAAA,SAAS;AACtE;;;;"}
@@ -1,4 +1,4 @@
1
- var styles = {"gn-settings-menu__group-heading":"SettingsMenu-module__gn-settings-menu__group-heading___b3rMA","gnSettingsMenuGroupHeading":"SettingsMenu-module__gn-settings-menu__group-heading___b3rMA","gn-settings-menu__group":"SettingsMenu-module__gn-settings-menu__group___zBrCj","gnSettingsMenuGroup":"SettingsMenu-module__gn-settings-menu__group___zBrCj","gn-settings-menu__item":"SettingsMenu-module__gn-settings-menu__item___QGz0Y","gnSettingsMenuItem":"SettingsMenu-module__gn-settings-menu__item___QGz0Y","gn-settings-menu__item-icon":"SettingsMenu-module__gn-settings-menu__item-icon___B-h-X","gnSettingsMenuItemIcon":"SettingsMenu-module__gn-settings-menu__item-icon___B-h-X","gn-settings-menu__item_focused":"SettingsMenu-module__gn-settings-menu__item_focused___pKQBC","gnSettingsMenuItemFocused":"SettingsMenu-module__gn-settings-menu__item_focused___pKQBC","gn-settings-menu__item_selected":"SettingsMenu-module__gn-settings-menu__item_selected___Og2Jr","gnSettingsMenuItemSelected":"SettingsMenu-module__gn-settings-menu__item_selected___Og2Jr","gn-settings-menu__item_disabled":"SettingsMenu-module__gn-settings-menu__item_disabled___xv9E8","gnSettingsMenuItemDisabled":"SettingsMenu-module__gn-settings-menu__item_disabled___xv9E8","gn-settings-menu__item_badge":"SettingsMenu-module__gn-settings-menu__item_badge___I-O-X","gnSettingsMenuItemBadge":"SettingsMenu-module__gn-settings-menu__item_badge___I-O-X"};
1
+ var styles = {"gn-settings-menu":"SettingsMenu-module__gn-settings-menu___ChFyc","gnSettingsMenu":"SettingsMenu-module__gn-settings-menu___ChFyc","gn-settings-menu_scrolled":"SettingsMenu-module__gn-settings-menu_scrolled___QYbnX","gnSettingsMenuScrolled":"SettingsMenu-module__gn-settings-menu_scrolled___QYbnX","gn-settings-menu__group-heading":"SettingsMenu-module__gn-settings-menu__group-heading___b3rMA","gnSettingsMenuGroupHeading":"SettingsMenu-module__gn-settings-menu__group-heading___b3rMA","gn-settings-menu__group":"SettingsMenu-module__gn-settings-menu__group___zBrCj","gnSettingsMenuGroup":"SettingsMenu-module__gn-settings-menu__group___zBrCj","gn-settings-menu__item":"SettingsMenu-module__gn-settings-menu__item___QGz0Y","gnSettingsMenuItem":"SettingsMenu-module__gn-settings-menu__item___QGz0Y","gn-settings-menu__item-icon":"SettingsMenu-module__gn-settings-menu__item-icon___B-h-X","gnSettingsMenuItemIcon":"SettingsMenu-module__gn-settings-menu__item-icon___B-h-X","gn-settings-menu__item_focused":"SettingsMenu-module__gn-settings-menu__item_focused___pKQBC","gnSettingsMenuItemFocused":"SettingsMenu-module__gn-settings-menu__item_focused___pKQBC","gn-settings-menu__item_selected":"SettingsMenu-module__gn-settings-menu__item_selected___Og2Jr","gnSettingsMenuItemSelected":"SettingsMenu-module__gn-settings-menu__item_selected___Og2Jr","gn-settings-menu__item_disabled":"SettingsMenu-module__gn-settings-menu__item_disabled___xv9E8","gnSettingsMenuItemDisabled":"SettingsMenu-module__gn-settings-menu__item_disabled___xv9E8","gn-settings-menu__item_badge":"SettingsMenu-module__gn-settings-menu__item_badge___I-O-X","gnSettingsMenuItemBadge":"SettingsMenu-module__gn-settings-menu__item_badge___I-O-X"};
2
2
 
3
3
  export { styles as default };
4
4
  //# sourceMappingURL=SettingsMenu.module.scss.js.map
@@ -1,7 +1,6 @@
1
- export declare const ASIDE_HEADER_ICON_SIZE = 16;
1
+ export declare const ASIDE_HEADER_ICON_SIZE = 18;
2
2
  export declare const ASIDE_HEADER_COMPACT_WIDTH = 56;
3
3
  export declare const ASIDE_HEADER_EXPANDED_WIDTH = 236;
4
- export declare const ITEM_HEIGHT = 36;
4
+ export declare const ITEM_HEIGHT = 40;
5
+ export declare const POPUP_REGULAR_ITEM_HEIGHT = 32;
5
6
  export declare const HEADER_DIVIDER_HEIGHT = 29;
6
- export declare const ASIDE_HEADER_EXPAND_TRANSITION_DELAY = 150;
7
- export declare const ASIDE_HEADER_EXPAND_DELAY = 250;
@@ -1,10 +1,9 @@
1
- const ASIDE_HEADER_ICON_SIZE = 16;
1
+ const ASIDE_HEADER_ICON_SIZE = 18;
2
2
  const ASIDE_HEADER_COMPACT_WIDTH = 56;
3
3
  const ASIDE_HEADER_EXPANDED_WIDTH = 236;
4
- const ITEM_HEIGHT = 36;
4
+ const ITEM_HEIGHT = 40;
5
+ const POPUP_REGULAR_ITEM_HEIGHT = 32;
5
6
  const HEADER_DIVIDER_HEIGHT = 29;
6
- const ASIDE_HEADER_EXPAND_TRANSITION_DELAY = 150;
7
- const ASIDE_HEADER_EXPAND_DELAY = 250;
8
7
 
9
- export { ASIDE_HEADER_COMPACT_WIDTH, ASIDE_HEADER_EXPANDED_WIDTH, ASIDE_HEADER_EXPAND_DELAY, ASIDE_HEADER_EXPAND_TRANSITION_DELAY, ASIDE_HEADER_ICON_SIZE, HEADER_DIVIDER_HEIGHT, ITEM_HEIGHT };
8
+ export { ASIDE_HEADER_COMPACT_WIDTH, ASIDE_HEADER_EXPANDED_WIDTH, ASIDE_HEADER_ICON_SIZE, HEADER_DIVIDER_HEIGHT, ITEM_HEIGHT, POPUP_REGULAR_ITEM_HEIGHT };
10
9
  //# sourceMappingURL=constants.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"constants.js","sources":["../../../../src/components/constants.ts"],"sourcesContent":["export const ASIDE_HEADER_ICON_SIZE = 16;\nexport const ASIDE_HEADER_COMPACT_WIDTH = 56;\nexport const ASIDE_HEADER_EXPANDED_WIDTH = 236;\nexport const ITEM_HEIGHT = 36;\nexport const HEADER_DIVIDER_HEIGHT = 29;\nexport const ASIDE_HEADER_EXPAND_TRANSITION_DELAY = 150;\nexport const ASIDE_HEADER_EXPAND_DELAY = 250;\n"],"names":[],"mappings":"AAAO,MAAM,sBAAsB,GAAG;AAC/B,MAAM,0BAA0B,GAAG;AACnC,MAAM,2BAA2B,GAAG;AACpC,MAAM,WAAW,GAAG;AACpB,MAAM,qBAAqB,GAAG;AAC9B,MAAM,oCAAoC,GAAG;AAC7C,MAAM,yBAAyB,GAAG;;;;"}
1
+ {"version":3,"file":"constants.js","sources":["../../../../src/components/constants.ts"],"sourcesContent":["export const ASIDE_HEADER_ICON_SIZE = 18;\nexport const ASIDE_HEADER_COMPACT_WIDTH = 56;\nexport const ASIDE_HEADER_EXPANDED_WIDTH = 236;\nexport const ITEM_HEIGHT = 40;\nexport const POPUP_REGULAR_ITEM_HEIGHT = 32;\nexport const HEADER_DIVIDER_HEIGHT = 29;\n"],"names":[],"mappings":"AAAO,MAAM,sBAAsB,GAAG;AAC/B,MAAM,0BAA0B,GAAG;AACnC,MAAM,2BAA2B,GAAG;AACpC,MAAM,WAAW,GAAG;AACpB,MAAM,yBAAyB,GAAG;AAClC,MAAM,qBAAqB,GAAG;;;;"}
@@ -15,6 +15,7 @@ export interface MenuItem extends QAProps {
15
15
  iconQa?: string;
16
16
  href?: string;
17
17
  current?: boolean;
18
+ pinned?: boolean;
18
19
  onItemClick?: (item: MenuItem, collapsed: boolean, event: React.MouseEvent<HTMLElement, MouseEvent>) => void;
19
20
  onItemClickCapture?: (event: React.SyntheticEvent) => void;
20
21
  itemWrapper?: (p: MakeItemParams, makeItem: (p: MakeItemParams) => React.ReactNode, opts: {
@@ -26,10 +27,19 @@ export interface MenuItem extends QAProps {
26
27
  preventUserRemoving?: boolean;
27
28
  rightAdornment?: React.ReactNode;
28
29
  type?: MenuItemType;
30
+ afterMoreButton?: boolean;
31
+ /**
32
+ * Order number. Used to determine the display order in the side menu
33
+ */
34
+ order?: number;
29
35
  /**
30
36
  * Visibility flag in the side menu
31
37
  */
32
38
  hidden?: boolean;
39
+ /**
40
+ * The category to which the menu item belongs. Need for grouping in the display/editing mode of all pages
41
+ */
42
+ category?: string;
33
43
  /**
34
44
  * The group ID to which the menu item belongs. Used for grouping menu items
35
45
  */
@@ -42,12 +52,11 @@ export interface MenuGroup {
42
52
  icon?: IconProps['data'];
43
53
  /** Hide the group from display */
44
54
  hidden?: boolean;
45
- /** Allow collapsing the group via UI */
46
- collapsible?: boolean;
47
- /** Initial collapsed state when collapsible is true */
48
- collapsedByDefault?: boolean;
49
- /** Current collapsed state */
50
- collapsed: boolean;
55
+ /**
56
+ * Optional title shown only in the compact popup that lists group children.
57
+ * Does not affect the group title displayed anywhere else.
58
+ */
59
+ popupTitle?: string;
51
60
  }
52
61
  export interface LogoProps {
53
62
  text: (() => React.ReactNode) | string;
@@ -129,7 +129,6 @@ function updateImports(root: Collection, j: JSCodeshift): boolean {
129
129
  });
130
130
 
131
131
  if (hasBeenModified) {
132
- // eslint-disable-next-line no-param-reassign
133
132
  path.node.specifiers = newSpecifiers;
134
133
  hasChanges = true;
135
134
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@gravity-ui/navigation",
3
- "version": "5.0.0-beta.3",
3
+ "version": "6.0.0-beta.0",
4
4
  "description": "Gravity UI Navigation components",
5
5
  "license": "MIT",
6
6
  "repository": {
@@ -52,7 +52,6 @@
52
52
  "dependencies": {
53
53
  "commander": "^11.0.0",
54
54
  "jscodeshift": "^0.15.0",
55
- "react-transition-group": "^4.4.5",
56
55
  "tslib": "^2.8.1"
57
56
  },
58
57
  "devDependencies": {
@@ -70,7 +69,7 @@
70
69
  "@gravity-ui/prettier-config": "^1.0.0",
71
70
  "@gravity-ui/stylelint-config": "^4.0.1",
72
71
  "@gravity-ui/tsconfig": "^1.0.0",
73
- "@gravity-ui/uikit": "^7.28.0",
72
+ "@gravity-ui/uikit": "^7.31.0",
74
73
  "@jest/globals": "^30.0.5",
75
74
  "@playwright/experimental-ct-react": "^1.49.1",
76
75
  "@playwright/test": "^1.49.1",
@@ -89,11 +88,12 @@
89
88
  "@storybook/test-runner": "^0.17.0",
90
89
  "@storybook/theming": "^8.5.0",
91
90
  "@svgr/rollup": "^8.1.0",
91
+ "@testing-library/react": "^16.3.2",
92
92
  "@types/jest": "^28.1.0",
93
93
  "@types/jscodeshift": "^0.12.0",
94
94
  "@types/lodash": "^4.17.14",
95
95
  "@types/react": "^18.3.18",
96
- "@types/react-transition-group": "^4.4.12",
96
+ "@types/react-virtualized-auto-sizer": "^1.0.4",
97
97
  "@vitejs/plugin-react": "^4.3.4",
98
98
  "axe-playwright": "^2.0.3",
99
99
  "babel-jest": "^28.0.0",
@@ -104,6 +104,7 @@
104
104
  "eslint-plugin-testing-library": "^6.5.0",
105
105
  "husky": "^9.1.7",
106
106
  "jest": "^28.0.0",
107
+ "jest-environment-jsdom": "^30.3.0",
107
108
  "knip": "^5.66.4",
108
109
  "nano-staged": "^0.6.0",
109
110
  "npm-run-all": "^4.0.0",
@@ -1,20 +0,0 @@
1
- import React from 'react';
2
- import type { Meta } from '@storybook/react';
3
- import { ActionBar } from '../ActionBar';
4
- declare const _default: Meta<typeof ActionBar>;
5
- export default _default;
6
- export declare const Showcase: import("@storybook/csf").AnnotatedStoryFn<import("@storybook/react").ReactRenderer, import("@gravity-ui/uikit").DOMProps & import("@gravity-ui/uikit").QAProps & {
7
- 'aria-label'?: string;
8
- } & {
9
- children?: React.ReactNode | undefined;
10
- }>;
11
- export declare const SingleSection: import("@storybook/csf").AnnotatedStoryFn<import("@storybook/react").ReactRenderer, import("@gravity-ui/uikit").DOMProps & import("@gravity-ui/uikit").QAProps & {
12
- 'aria-label'?: string;
13
- } & {
14
- children?: React.ReactNode | undefined;
15
- }>;
16
- export declare const StretchGroup: import("@storybook/csf").AnnotatedStoryFn<import("@storybook/react").ReactRenderer, import("@gravity-ui/uikit").DOMProps & import("@gravity-ui/uikit").QAProps & {
17
- 'aria-label'?: string;
18
- } & {
19
- children?: React.ReactNode | undefined;
20
- }>;
@@ -1,2 +0,0 @@
1
- import React from 'react';
2
- export declare function ActionBarShowcase(): React.JSX.Element;
@@ -1,2 +0,0 @@
1
- import React from 'react';
2
- export declare function ActionBarSingleSection(): React.JSX.Element;
@@ -1,2 +0,0 @@
1
- import React from 'react';
2
- export declare function ActionBarStretchGroupShowcase(): React.JSX.Element;
@@ -1,5 +0,0 @@
1
- import * as DefaultActionBarStories from '../__stories__/ActionBar.stories';
2
- declare const stories: Omit<import("@storybook/core/types").StoriesWithPartialProps<import("@storybook/react").ReactRenderer, typeof DefaultActionBarStories>, keyof import("@storybook/core/types").Store_CSFExports>;
3
- type ActionBarStoriesType = typeof stories;
4
- export declare const ActionBarStories: ActionBarStoriesType;
5
- export {};
@@ -1,23 +0,0 @@
1
- import React from 'react';
2
- import type { Meta } from '@storybook/react';
3
- import { AsideHeaderShowcaseProps } from './AsideHeaderShowcase';
4
- declare const _default: Meta;
5
- export default _default;
6
- export declare const Showcase: import("@storybook/csf").AnnotatedStoryFn<import("@storybook/react").ReactRenderer, import("@storybook/csf").Args>;
7
- export declare const Compact: import("@storybook/csf").AnnotatedStoryFn<import("@storybook/react").ReactRenderer, import("@storybook/csf").Args>;
8
- export declare const MultipleTooltip: import("@storybook/csf").AnnotatedStoryFn<import("@storybook/react").ReactRenderer, import("@storybook/csf").Args>;
9
- export declare const CustomTheme: import("@storybook/csf").AnnotatedStoryFn<import("@storybook/react").ReactRenderer, import("@storybook/csf").Args>;
10
- export declare const CustomBackground: import("@storybook/csf").AnnotatedStoryFn<import("@storybook/react").ReactRenderer, import("@storybook/csf").Args>;
11
- export declare const AdvancedUsage: import("@storybook/csf").AnnotatedStoryFn<import("@storybook/react").ReactRenderer, import("@storybook/csf").Args>;
12
- export declare const HeaderAlert: import("@storybook/csf").AnnotatedStoryFn<import("@storybook/react").ReactRenderer, AsideHeaderShowcaseProps>;
13
- export declare const HeaderAlertCentered: import("@storybook/csf").AnnotatedStoryFn<import("@storybook/react").ReactRenderer, AsideHeaderShowcaseProps>;
14
- export declare const HeaderAlertCustom: import("@storybook/csf").AnnotatedStoryFn<import("@storybook/react").ReactRenderer, AsideHeaderShowcaseProps>;
15
- export declare const Fallback: import("@storybook/csf").AnnotatedStoryFn<import("@storybook/react").ReactRenderer, {
16
- headerDecoration: boolean;
17
- subheaderItemsCount: number;
18
- }>;
19
- /** @type {StoryFn} */
20
- export declare function LineClamp(): React.JSX.Element;
21
- export declare const CollapseButtonWrapper: import("@storybook/csf").AnnotatedStoryFn<import("@storybook/react").ReactRenderer, import("@storybook/csf").Args>;
22
- export declare const ManyItems: import("@storybook/csf").AnnotatedStoryFn<import("@storybook/react").ReactRenderer, import("@storybook/csf").Args>;
23
- export declare const GroupedMenuCollapsible: import("@storybook/csf").AnnotatedStoryFn<import("@storybook/react").ReactRenderer, import("@storybook/csf").Args>;
@@ -1,13 +0,0 @@
1
- import React from 'react';
2
- import { TopAlertProps } from '../../types';
3
- import './AsideHeaderShowcase.scss';
4
- export interface AsideHeaderShowcaseProps {
5
- multipleTooltip?: boolean;
6
- initialCompact?: boolean;
7
- topAlert?: TopAlertProps;
8
- customBackground?: React.ReactNode;
9
- customBackgroundClassName?: string;
10
- headerDecoration?: boolean;
11
- hideCollapseButton?: boolean;
12
- }
13
- export declare const AsideHeaderShowcase: React.FC<AsideHeaderShowcaseProps>;
@@ -1,3 +0,0 @@
1
- import React, { FC } from 'react';
2
- import { AsideHeaderProps } from '../types';
3
- export declare function getAsideHeaderWrapper(props?: AsideHeaderProps): (Story: FC) => React.JSX.Element;
@@ -1,17 +0,0 @@
1
- import { AsideHeaderContextType } from '../AsideHeaderContext';
2
- import { AsideHeaderProps } from '../types';
3
- export declare const EMPTY_CONTEXT_VALUE: AsideHeaderContextType;
4
- export declare const menuItemsShowcase: AsideHeaderProps['menuItems'];
5
- export declare const text = "\nDid you attend? He sang by grove ripe -\nThe bard of love, the singer of his mourning.\nWhen fields were silent by the early morning,\nTo sad and simple sounds of a pipe\nDid you attend?\n\nDid you behold in dark of forest leaf\nThe bard of love, the singer of his sadness?\nThe trace of tears, the smile, the utter paleness,\nThe quiet look, full of eternal grief,\nDid you behold?\n\nThen did you sigh when hearing how cries\nThe bard of love, the singer of his dole?\nWhen in the woods you saw the young man, sole,\nAnd met the look of his extinguished eyes,\nThen did you sigh?\n";
6
- export declare const DEFAULT_LOGO: {
7
- text: string;
8
- icon: import("node_modules/@gravity-ui/uikit/build/esm/components/Icon/types").SVGIconData;
9
- href: string;
10
- onClick: () => void;
11
- 'aria-label': string;
12
- };
13
- export declare const menuItemsClamped: import("..").AsideHeaderItem[];
14
- export declare const generateManyMenuItems: (count?: number) => AsideHeaderProps["menuItems"];
15
- export declare const menuItemsMany: import("..").AsideHeaderItem[] | undefined;
16
- export declare const menuItemsWithGroups: AsideHeaderProps['menuItems'];
17
- export declare const menuGroupsWithIcons: AsideHeaderProps['menuGroups'];
@@ -1,2 +0,0 @@
1
- import * as DefaultAsideHeaderStories from '../__stories__/AsideHeader.stories';
2
- export declare const AsideHeaderStories: Omit<import("@storybook/core/types").StoriesWithPartialProps<import("@storybook/react").ReactRenderer, typeof DefaultAsideHeaderStories>, keyof import("@storybook/core/types").Store_CSFExports>;
@@ -1,3 +0,0 @@
1
- import { MenuItem } from '../../../../types';
2
- import { MenuItemsWithGroups } from '../../../types';
3
- export declare function buildExpandedFromFlatList(flatList: MenuItemsWithGroups[]): MenuItem[];
@@ -1,17 +0,0 @@
1
- 'use strict';
2
-
3
- function buildExpandedFromFlatList(flatList) {
4
- const expanded = [];
5
- flatList.forEach((item) => {
6
- if ('items' in item && item.items && item.items.length > 0) {
7
- expanded.push(...item.items);
8
- }
9
- else {
10
- expanded.push(item);
11
- }
12
- });
13
- return expanded;
14
- }
15
-
16
- exports.buildExpandedFromFlatList = buildExpandedFromFlatList;
17
- //# sourceMappingURL=buildExpandedFromFlatList.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"buildExpandedFromFlatList.js","sources":["../../../../../../../../src/components/AsideHeader/components/AllPagesPanel/utils/buildExpandedFromFlatList.ts"],"sourcesContent":["import {MenuItem} from '../../../../types';\nimport {MenuItemsWithGroups} from '../../../types';\n\nexport function buildExpandedFromFlatList(flatList: MenuItemsWithGroups[]): MenuItem[] {\n const expanded: MenuItem[] = [];\n\n flatList.forEach((item) => {\n if ('items' in item && item.items && item.items.length > 0) {\n expanded.push(...item.items);\n } else {\n expanded.push(item);\n }\n });\n\n return expanded;\n}\n"],"names":[],"mappings":";;AAGM,SAAU,yBAAyB,CAAC,QAA+B,EAAA;IACrE,MAAM,QAAQ,GAAe,EAAE;AAE/B,IAAA,QAAQ,CAAC,OAAO,CAAC,CAAC,IAAI,KAAI;AACtB,QAAA,IAAI,OAAO,IAAI,IAAI,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;YACxD,QAAQ,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC;;aACzB;AACH,YAAA,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC;;AAE3B,KAAC,CAAC;AAEF,IAAA,OAAO,QAAQ;AACnB;;;;"}
@@ -1,2 +0,0 @@
1
- import { MenuItemsWithGroups } from 'src/components/AsideHeader/types';
2
- export declare function getIsMenuItem(item: MenuItemsWithGroups): boolean;
@@ -1,13 +0,0 @@
1
- 'use strict';
2
-
3
- var constants = require('../constants.js');
4
-
5
- function getIsMenuItem(item) {
6
- const isDivider = item.type === 'divider';
7
- const isAction = item.type === 'action';
8
- const isAllPages = item.id === constants.ALL_PAGES_ID;
9
- return !isDivider && !isAction && !isAllPages;
10
- }
11
-
12
- exports.getIsMenuItem = getIsMenuItem;
13
- //# sourceMappingURL=getIsMenuItem.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"getIsMenuItem.js","sources":["../../../../../../../../src/components/AsideHeader/components/AllPagesPanel/utils/getIsMenuItem.ts"],"sourcesContent":["import {MenuItemsWithGroups} from 'src/components/AsideHeader/types';\n\nimport {ALL_PAGES_ID} from '../constants';\n\nexport function getIsMenuItem(item: MenuItemsWithGroups): boolean {\n const isDivider = item.type === 'divider';\n const isAction = item.type === 'action';\n const isAllPages = item.id === ALL_PAGES_ID;\n\n return !isDivider && !isAction && !isAllPages;\n}\n"],"names":["ALL_PAGES_ID"],"mappings":";;;;AAIM,SAAU,aAAa,CAAC,IAAyB,EAAA;AACnD,IAAA,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,KAAK,SAAS;AACzC,IAAA,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,KAAK,QAAQ;AACvC,IAAA,MAAM,UAAU,GAAG,IAAI,CAAC,EAAE,KAAKA,sBAAY;IAE3C,OAAO,CAAC,SAAS,IAAI,CAAC,QAAQ,IAAI,CAAC,UAAU;AACjD;;;;"}
@@ -1,2 +0,0 @@
1
- import { MenuItemsWithGroups } from '../../../types';
2
- export declare function getRealIndexInGroup(groupIndex: number, itemIndexInGroup: number, flatList: MenuItemsWithGroups[]): number;
@@ -1,22 +0,0 @@
1
- 'use strict';
2
-
3
- function getRealIndexInExpandedMenu(flatListIndex, flatList) {
4
- let realIndex = 0;
5
- for (let i = 0; i < flatListIndex; i++) {
6
- const item = flatList[i];
7
- if ('items' in item && item.items && item.items.length > 0) {
8
- realIndex += item.items.length;
9
- }
10
- else {
11
- realIndex += 1;
12
- }
13
- }
14
- return realIndex;
15
- }
16
- function getRealIndexInGroup(groupIndex, itemIndexInGroup, flatList) {
17
- const groupStartIndex = getRealIndexInExpandedMenu(groupIndex, flatList);
18
- return groupStartIndex + itemIndexInGroup;
19
- }
20
-
21
- exports.getRealIndexInGroup = getRealIndexInGroup;
22
- //# sourceMappingURL=getRealIndexInGroup.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"getRealIndexInGroup.js","sources":["../../../../../../../../src/components/AsideHeader/components/AllPagesPanel/utils/getRealIndexInGroup.ts"],"sourcesContent":["import {MenuItemsWithGroups} from '../../../types';\n\nfunction getRealIndexInExpandedMenu(\n flatListIndex: number,\n flatList: MenuItemsWithGroups[],\n): number {\n let realIndex = 0;\n\n for (let i = 0; i < flatListIndex; i++) {\n const item = flatList[i];\n\n if ('items' in item && item.items && item.items.length > 0) {\n realIndex += item.items.length;\n } else {\n realIndex += 1;\n }\n }\n\n return realIndex;\n}\n\nexport function getRealIndexInGroup(\n groupIndex: number,\n itemIndexInGroup: number,\n flatList: MenuItemsWithGroups[],\n): number {\n const groupStartIndex = getRealIndexInExpandedMenu(groupIndex, flatList);\n\n return groupStartIndex + itemIndexInGroup;\n}\n"],"names":[],"mappings":";;AAEA,SAAS,0BAA0B,CAC/B,aAAqB,EACrB,QAA+B,EAAA;IAE/B,IAAI,SAAS,GAAG,CAAC;AAEjB,IAAA,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,aAAa,EAAE,CAAC,EAAE,EAAE;AACpC,QAAA,MAAM,IAAI,GAAG,QAAQ,CAAC,CAAC,CAAC;AAExB,QAAA,IAAI,OAAO,IAAI,IAAI,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;AACxD,YAAA,SAAS,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM;;aAC3B;YACH,SAAS,IAAI,CAAC;;;AAItB,IAAA,OAAO,SAAS;AACpB;SAEgB,mBAAmB,CAC/B,UAAkB,EAClB,gBAAwB,EACxB,QAA+B,EAAA;IAE/B,MAAM,eAAe,GAAG,0BAA0B,CAAC,UAAU,EAAE,QAAQ,CAAC;IAExE,OAAO,eAAe,GAAG,gBAAgB;AAC7C;;;;"}
@@ -1,2 +0,0 @@
1
- import { MenuItemsWithGroups } from '../../../types';
2
- export declare function sortMenuItems(oldIndex: number, newIndex: number, items: MenuItemsWithGroups[]): import("../../../..").MenuItem[];
@@ -1,16 +0,0 @@
1
- 'use strict';
2
-
3
- var buildExpandedFromFlatList = require('./buildExpandedFromFlatList.js');
4
-
5
- function sortMenuItems(oldIndex, newIndex, items) {
6
- if (items[oldIndex] === undefined || items[newIndex] === undefined) {
7
- return buildExpandedFromFlatList.buildExpandedFromFlatList(items);
8
- }
9
- const sortedItems = [...items];
10
- const [movedElement] = sortedItems.splice(oldIndex, 1);
11
- sortedItems.splice(newIndex, 0, movedElement);
12
- return buildExpandedFromFlatList.buildExpandedFromFlatList(sortedItems);
13
- }
14
-
15
- exports.sortMenuItems = sortMenuItems;
16
- //# sourceMappingURL=sortMenuItems.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"sortMenuItems.js","sources":["../../../../../../../../src/components/AsideHeader/components/AllPagesPanel/utils/sortMenuItems.ts"],"sourcesContent":["import {MenuItemsWithGroups} from '../../../types';\n\nimport {buildExpandedFromFlatList} from './buildExpandedFromFlatList';\n\nexport function sortMenuItems(oldIndex: number, newIndex: number, items: MenuItemsWithGroups[]) {\n if (items[oldIndex] === undefined || items[newIndex] === undefined) {\n return buildExpandedFromFlatList(items);\n }\n\n const sortedItems = [...items];\n\n const [movedElement] = sortedItems.splice(oldIndex, 1);\n\n sortedItems.splice(newIndex, 0, movedElement);\n\n return buildExpandedFromFlatList(sortedItems);\n}\n"],"names":["buildExpandedFromFlatList"],"mappings":";;;;SAIgB,aAAa,CAAC,QAAgB,EAAE,QAAgB,EAAE,KAA4B,EAAA;AAC1F,IAAA,IAAI,KAAK,CAAC,QAAQ,CAAC,KAAK,SAAS,IAAI,KAAK,CAAC,QAAQ,CAAC,KAAK,SAAS,EAAE;AAChE,QAAA,OAAOA,mDAAyB,CAAC,KAAK,CAAC;;AAG3C,IAAA,MAAM,WAAW,GAAG,CAAC,GAAG,KAAK,CAAC;AAE9B,IAAA,MAAM,CAAC,YAAY,CAAC,GAAG,WAAW,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC;IAEtD,WAAW,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,EAAE,YAAY,CAAC;AAE7C,IAAA,OAAOA,mDAAyB,CAAC,WAAW,CAAC;AACjD;;;;"}
@@ -1,3 +0,0 @@
1
- import { MenuItemsWithGroups } from '../../../types';
2
- /** Sorts menu items while preserving divider positions at their original locations. */
3
- export declare function sortMenuItemsWithDividers(oldIndex: number, newIndex: number, currentFlatList: MenuItemsWithGroups[]): MenuItemsWithGroups[];
@@ -1,44 +0,0 @@
1
- 'use strict';
2
-
3
- var getIsMenuItem = require('./getIsMenuItem.js');
4
-
5
- /** Sorts menu items while preserving divider positions at their original locations. */
6
- function sortMenuItemsWithDividers(oldIndex, newIndex, currentFlatList) {
7
- // Single pass: collect dividers and items
8
- const dividerPositions = [];
9
- const itemsWithoutDividers = [];
10
- currentFlatList.forEach((item, index) => {
11
- if (item.type === 'divider') {
12
- dividerPositions.push({ index, item });
13
- }
14
- else if (getIsMenuItem.getIsMenuItem(item)) {
15
- itemsWithoutDividers.push(item);
16
- }
17
- });
18
- if (itemsWithoutDividers[oldIndex] === undefined ||
19
- itemsWithoutDividers[newIndex] === undefined) {
20
- return currentFlatList;
21
- }
22
- const sortedItemsWithoutDividers = [...itemsWithoutDividers];
23
- const [movedElement] = sortedItemsWithoutDividers.splice(oldIndex, 1);
24
- sortedItemsWithoutDividers.splice(newIndex, 0, movedElement);
25
- // Insert dividers back at their original positions in currentFlatList
26
- const result = [];
27
- const dividerMap = new Map(dividerPositions.map((d) => [d.index, d.item]));
28
- let sortedIndex = 0;
29
- for (let originalIndex = 0; originalIndex < currentFlatList.length; originalIndex++) {
30
- const dividerItem = dividerMap.get(originalIndex);
31
- if (dividerItem) {
32
- // Insert divider at its original position
33
- result.push(dividerItem);
34
- }
35
- else if (sortedIndex < sortedItemsWithoutDividers.length) {
36
- // Insert item from sorted array (without dividers)
37
- result.push(sortedItemsWithoutDividers[sortedIndex++]);
38
- }
39
- }
40
- return result;
41
- }
42
-
43
- exports.sortMenuItemsWithDividers = sortMenuItemsWithDividers;
44
- //# sourceMappingURL=sortMenuItemsWithDividers.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"sortMenuItemsWithDividers.js","sources":["../../../../../../../../src/components/AsideHeader/components/AllPagesPanel/utils/sortMenuItemsWithDividers.ts"],"sourcesContent":["import {MenuItemsWithGroups} from '../../../types';\n\nimport {getIsMenuItem} from './getIsMenuItem';\n\n/** Sorts menu items while preserving divider positions at their original locations. */\nexport function sortMenuItemsWithDividers(\n oldIndex: number,\n newIndex: number,\n currentFlatList: MenuItemsWithGroups[],\n): MenuItemsWithGroups[] {\n // Single pass: collect dividers and items\n const dividerPositions: Array<{index: number; item: MenuItemsWithGroups}> = [];\n const itemsWithoutDividers: MenuItemsWithGroups[] = [];\n\n currentFlatList.forEach((item, index) => {\n if (item.type === 'divider') {\n dividerPositions.push({index, item});\n } else if (getIsMenuItem(item)) {\n itemsWithoutDividers.push(item);\n }\n });\n\n if (\n itemsWithoutDividers[oldIndex] === undefined ||\n itemsWithoutDividers[newIndex] === undefined\n ) {\n return currentFlatList;\n }\n\n const sortedItemsWithoutDividers = [...itemsWithoutDividers];\n const [movedElement] = sortedItemsWithoutDividers.splice(oldIndex, 1);\n sortedItemsWithoutDividers.splice(newIndex, 0, movedElement);\n\n // Insert dividers back at their original positions in currentFlatList\n const result: MenuItemsWithGroups[] = [];\n const dividerMap = new Map(dividerPositions.map((d) => [d.index, d.item]));\n let sortedIndex = 0;\n\n for (let originalIndex = 0; originalIndex < currentFlatList.length; originalIndex++) {\n const dividerItem = dividerMap.get(originalIndex);\n\n if (dividerItem) {\n // Insert divider at its original position\n result.push(dividerItem);\n } else if (sortedIndex < sortedItemsWithoutDividers.length) {\n // Insert item from sorted array (without dividers)\n result.push(sortedItemsWithoutDividers[sortedIndex++]);\n }\n }\n\n return result;\n}\n"],"names":["getIsMenuItem"],"mappings":";;;;AAIA;SACgB,yBAAyB,CACrC,QAAgB,EAChB,QAAgB,EAChB,eAAsC,EAAA;;IAGtC,MAAM,gBAAgB,GAAsD,EAAE;IAC9E,MAAM,oBAAoB,GAA0B,EAAE;IAEtD,eAAe,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,KAAK,KAAI;AACpC,QAAA,IAAI,IAAI,CAAC,IAAI,KAAK,SAAS,EAAE;YACzB,gBAAgB,CAAC,IAAI,CAAC,EAAC,KAAK,EAAE,IAAI,EAAC,CAAC;;AACjC,aAAA,IAAIA,2BAAa,CAAC,IAAI,CAAC,EAAE;AAC5B,YAAA,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC;;AAEvC,KAAC,CAAC;AAEF,IAAA,IACI,oBAAoB,CAAC,QAAQ,CAAC,KAAK,SAAS;AAC5C,QAAA,oBAAoB,CAAC,QAAQ,CAAC,KAAK,SAAS,EAC9C;AACE,QAAA,OAAO,eAAe;;AAG1B,IAAA,MAAM,0BAA0B,GAAG,CAAC,GAAG,oBAAoB,CAAC;AAC5D,IAAA,MAAM,CAAC,YAAY,CAAC,GAAG,0BAA0B,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC;IACrE,0BAA0B,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,EAAE,YAAY,CAAC;;IAG5D,MAAM,MAAM,GAA0B,EAAE;IACxC,MAAM,UAAU,GAAG,IAAI,GAAG,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;IAC1E,IAAI,WAAW,GAAG,CAAC;AAEnB,IAAA,KAAK,IAAI,aAAa,GAAG,CAAC,EAAE,aAAa,GAAG,eAAe,CAAC,MAAM,EAAE,aAAa,EAAE,EAAE;QACjF,MAAM,WAAW,GAAG,UAAU,CAAC,GAAG,CAAC,aAAa,CAAC;QAEjD,IAAI,WAAW,EAAE;;AAEb,YAAA,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC;;AACrB,aAAA,IAAI,WAAW,GAAG,0BAA0B,CAAC,MAAM,EAAE;;YAExD,MAAM,CAAC,IAAI,CAAC,0BAA0B,CAAC,WAAW,EAAE,CAAC,CAAC;;;AAI9D,IAAA,OAAO,MAAM;AACjB;;;;"}