@diplodoc/components 3.0.0-alpha-1

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 (614) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +67 -0
  3. package/assets/icons/link.svg +3 -0
  4. package/assets/icons/pdf.svg +6 -0
  5. package/build/cjs/components/BookmarkButton/BookmarkButton.css +12 -0
  6. package/build/cjs/components/BookmarkButton/BookmarkButton.css.map +7 -0
  7. package/build/cjs/components/BookmarkButton/BookmarkButton.d.ts +8 -0
  8. package/build/cjs/components/BookmarkButton/BookmarkButton.js +56 -0
  9. package/build/cjs/components/BookmarkButton/BookmarkButton.js.map +7 -0
  10. package/build/cjs/components/BookmarkButton/index.d.ts +1 -0
  11. package/build/cjs/components/BookmarkButton/index.js +21 -0
  12. package/build/cjs/components/BookmarkButton/index.js.map +7 -0
  13. package/build/cjs/components/Breadcrumbs/Breadcrumbs.css +35 -0
  14. package/build/cjs/components/Breadcrumbs/Breadcrumbs.css.map +7 -0
  15. package/build/cjs/components/Breadcrumbs/Breadcrumbs.d.ts +8 -0
  16. package/build/cjs/components/Breadcrumbs/Breadcrumbs.js +58 -0
  17. package/build/cjs/components/Breadcrumbs/Breadcrumbs.js.map +7 -0
  18. package/build/cjs/components/Breadcrumbs/index.d.ts +1 -0
  19. package/build/cjs/components/Breadcrumbs/index.js +21 -0
  20. package/build/cjs/components/Breadcrumbs/index.js.map +7 -0
  21. package/build/cjs/components/ContributorAvatars/Avatars/Avatar.d.ts +10 -0
  22. package/build/cjs/components/ContributorAvatars/Avatars/Avatar.js +89 -0
  23. package/build/cjs/components/ContributorAvatars/Avatars/Avatar.js.map +7 -0
  24. package/build/cjs/components/ContributorAvatars/Avatars/AvatarWithDescription.d.ts +9 -0
  25. package/build/cjs/components/ContributorAvatars/Avatars/AvatarWithDescription.js +63 -0
  26. package/build/cjs/components/ContributorAvatars/Avatars/AvatarWithDescription.js.map +7 -0
  27. package/build/cjs/components/ContributorAvatars/Avatars/Details.d.ts +10 -0
  28. package/build/cjs/components/ContributorAvatars/Avatars/Details.js +77 -0
  29. package/build/cjs/components/ContributorAvatars/Avatars/Details.js.map +7 -0
  30. package/build/cjs/components/ContributorAvatars/Avatars/HiddenAvatars.d.ts +10 -0
  31. package/build/cjs/components/ContributorAvatars/Avatars/HiddenAvatars.js +70 -0
  32. package/build/cjs/components/ContributorAvatars/Avatars/HiddenAvatars.js.map +7 -0
  33. package/build/cjs/components/ContributorAvatars/ContributorAvatars.css +135 -0
  34. package/build/cjs/components/ContributorAvatars/ContributorAvatars.css.map +7 -0
  35. package/build/cjs/components/ContributorAvatars/ContributorAvatars.d.ts +10 -0
  36. package/build/cjs/components/ContributorAvatars/ContributorAvatars.js +84 -0
  37. package/build/cjs/components/ContributorAvatars/ContributorAvatars.js.map +7 -0
  38. package/build/cjs/components/ContributorAvatars/index.d.ts +2 -0
  39. package/build/cjs/components/ContributorAvatars/index.js +39 -0
  40. package/build/cjs/components/ContributorAvatars/index.js.map +7 -0
  41. package/build/cjs/components/ContributorAvatars/models.d.ts +16 -0
  42. package/build/cjs/components/ContributorAvatars/models.js +31 -0
  43. package/build/cjs/components/ContributorAvatars/models.js.map +7 -0
  44. package/build/cjs/components/ContributorAvatars/utils.d.ts +3 -0
  45. package/build/cjs/components/ContributorAvatars/utils.js +39 -0
  46. package/build/cjs/components/ContributorAvatars/utils.js.map +7 -0
  47. package/build/cjs/components/Contributors/Contributors.css +12 -0
  48. package/build/cjs/components/Contributors/Contributors.css.map +7 -0
  49. package/build/cjs/components/Contributors/Contributors.d.ts +11 -0
  50. package/build/cjs/components/Contributors/Contributors.js +48 -0
  51. package/build/cjs/components/Contributors/Contributors.js.map +7 -0
  52. package/build/cjs/components/Contributors/index.d.ts +2 -0
  53. package/build/cjs/components/Control/Control.css +15 -0
  54. package/build/cjs/components/Control/Control.css.map +7 -0
  55. package/build/cjs/components/Control/Control.d.ts +20 -0
  56. package/build/cjs/components/Control/Control.js +95 -0
  57. package/build/cjs/components/Control/Control.js.map +7 -0
  58. package/build/cjs/components/Control/index.d.ts +2 -0
  59. package/build/cjs/components/Control/index.js +39 -0
  60. package/build/cjs/components/Control/index.js.map +7 -0
  61. package/build/cjs/components/Controls/Controls.css +50 -0
  62. package/build/cjs/components/Controls/Controls.css.map +7 -0
  63. package/build/cjs/components/Controls/Controls.d.ts +32 -0
  64. package/build/cjs/components/Controls/Controls.js +169 -0
  65. package/build/cjs/components/Controls/Controls.js.map +7 -0
  66. package/build/cjs/components/Controls/ControlsLayout.d.ts +12 -0
  67. package/build/cjs/components/Controls/ControlsLayout.js +68 -0
  68. package/build/cjs/components/Controls/ControlsLayout.js.map +7 -0
  69. package/build/cjs/components/Controls/index.d.ts +4 -0
  70. package/build/cjs/components/Controls/index.js +42 -0
  71. package/build/cjs/components/Controls/index.js.map +7 -0
  72. package/build/cjs/components/Controls/single-controls/DividerControl/DividerControl.css +21 -0
  73. package/build/cjs/components/Controls/single-controls/DividerControl/DividerControl.css.map +7 -0
  74. package/build/cjs/components/Controls/single-controls/DividerControl/DividerControl.d.ts +7 -0
  75. package/build/cjs/components/Controls/single-controls/DividerControl/DividerControl.js +46 -0
  76. package/build/cjs/components/Controls/single-controls/DividerControl/DividerControl.js.map +7 -0
  77. package/build/cjs/components/Controls/single-controls/EditControl.d.ts +9 -0
  78. package/build/cjs/components/Controls/single-controls/EditControl.js +73 -0
  79. package/build/cjs/components/Controls/single-controls/EditControl.js.map +7 -0
  80. package/build/cjs/components/Controls/single-controls/FullScreenControl.d.ts +7 -0
  81. package/build/cjs/components/Controls/single-controls/FullScreenControl.js +82 -0
  82. package/build/cjs/components/Controls/single-controls/FullScreenControl.js.map +7 -0
  83. package/build/cjs/components/Controls/single-controls/LangControl.d.ts +10 -0
  84. package/build/cjs/components/Controls/single-controls/LangControl.js +122 -0
  85. package/build/cjs/components/Controls/single-controls/LangControl.js.map +7 -0
  86. package/build/cjs/components/Controls/single-controls/PdfControl.d.ts +6 -0
  87. package/build/cjs/components/Controls/single-controls/PdfControl.js +60 -0
  88. package/build/cjs/components/Controls/single-controls/PdfControl.js.map +7 -0
  89. package/build/cjs/components/Controls/single-controls/SettingsControl/SettingsControl.css +49 -0
  90. package/build/cjs/components/Controls/single-controls/SettingsControl/SettingsControl.css.map +7 -0
  91. package/build/cjs/components/Controls/single-controls/SettingsControl/SettingsControl.d.ts +17 -0
  92. package/build/cjs/components/Controls/single-controls/SettingsControl/SettingsControl.js +198 -0
  93. package/build/cjs/components/Controls/single-controls/SettingsControl/SettingsControl.js.map +7 -0
  94. package/build/cjs/components/Controls/single-controls/SinglePageControl.d.ts +7 -0
  95. package/build/cjs/components/Controls/single-controls/SinglePageControl.js +67 -0
  96. package/build/cjs/components/Controls/single-controls/SinglePageControl.js.map +7 -0
  97. package/build/cjs/components/Controls/single-controls/index.d.ts +7 -0
  98. package/build/cjs/components/Controls/single-controls/index.js +49 -0
  99. package/build/cjs/components/Controls/single-controls/index.js.map +7 -0
  100. package/build/cjs/components/Controls/single-controls/utils.d.ts +2 -0
  101. package/build/cjs/components/Controls/single-controls/utils.js +30 -0
  102. package/build/cjs/components/Controls/single-controls/utils.js.map +7 -0
  103. package/build/cjs/components/DocLayout/DocLayout.css +102 -0
  104. package/build/cjs/components/DocLayout/DocLayout.css.map +7 -0
  105. package/build/cjs/components/DocLayout/DocLayout.d.ts +34 -0
  106. package/build/cjs/components/DocLayout/DocLayout.js +117 -0
  107. package/build/cjs/components/DocLayout/DocLayout.js.map +7 -0
  108. package/build/cjs/components/DocLayout/index.d.ts +1 -0
  109. package/build/cjs/components/DocLayout/index.js +21 -0
  110. package/build/cjs/components/DocLayout/index.js.map +7 -0
  111. package/build/cjs/components/DocLeadingPage/DocLeadingPage.css +93 -0
  112. package/build/cjs/components/DocLeadingPage/DocLeadingPage.css.map +7 -0
  113. package/build/cjs/components/DocLeadingPage/DocLeadingPage.d.ts +22 -0
  114. package/build/cjs/components/DocLeadingPage/DocLeadingPage.js +109 -0
  115. package/build/cjs/components/DocLeadingPage/DocLeadingPage.js.map +7 -0
  116. package/build/cjs/components/DocLeadingPage/index.d.ts +1 -0
  117. package/build/cjs/components/DocLeadingPage/index.js +21 -0
  118. package/build/cjs/components/DocLeadingPage/index.js.map +7 -0
  119. package/build/cjs/components/DocPage/DocPage.css +231 -0
  120. package/build/cjs/components/DocPage/DocPage.css.map +7 -0
  121. package/build/cjs/components/DocPage/DocPage.d.ts +41 -0
  122. package/build/cjs/components/DocPage/DocPage.js +460 -0
  123. package/build/cjs/components/DocPage/DocPage.js.map +7 -0
  124. package/build/cjs/components/DocPage/index.d.ts +2 -0
  125. package/build/cjs/components/DocPage/index.js +39 -0
  126. package/build/cjs/components/DocPage/index.js.map +7 -0
  127. package/build/cjs/components/DocPageTitle/DocPageTitle.css +10 -0
  128. package/build/cjs/components/DocPageTitle/DocPageTitle.css.map +7 -0
  129. package/build/cjs/components/DocPageTitle/DocPageTitle.d.ts +7 -0
  130. package/build/cjs/components/DocPageTitle/DocPageTitle.js +50 -0
  131. package/build/cjs/components/DocPageTitle/DocPageTitle.js.map +7 -0
  132. package/build/cjs/components/DocPageTitle/index.d.ts +1 -0
  133. package/build/cjs/components/DocPageTitle/index.js +21 -0
  134. package/build/cjs/components/DocPageTitle/index.js.map +7 -0
  135. package/build/cjs/components/ErrorBoundary/ErrorBoundary.d.ts +12 -0
  136. package/build/cjs/components/ErrorBoundary/ErrorBoundary.js +56 -0
  137. package/build/cjs/components/ErrorBoundary/ErrorBoundary.js.map +7 -0
  138. package/build/cjs/components/ErrorBoundary/index.d.ts +2 -0
  139. package/build/cjs/components/ErrorBoundary/index.js +39 -0
  140. package/build/cjs/components/ErrorBoundary/index.js.map +7 -0
  141. package/build/cjs/components/ErrorPage/ErrorPage.css +65 -0
  142. package/build/cjs/components/ErrorPage/ErrorPage.css.map +7 -0
  143. package/build/cjs/components/ErrorPage/ErrorPage.d.ts +10 -0
  144. package/build/cjs/components/ErrorPage/ErrorPage.js +83 -0
  145. package/build/cjs/components/ErrorPage/ErrorPage.js.map +7 -0
  146. package/build/cjs/components/ErrorPage/index.d.ts +2 -0
  147. package/build/cjs/components/ErrorPage/index.js +39 -0
  148. package/build/cjs/components/ErrorPage/index.js.map +7 -0
  149. package/build/cjs/components/Feedback/Feedback.css +109 -0
  150. package/build/cjs/components/Feedback/Feedback.css.map +7 -0
  151. package/build/cjs/components/Feedback/Feedback.d.ts +15 -0
  152. package/build/cjs/components/Feedback/Feedback.js +163 -0
  153. package/build/cjs/components/Feedback/Feedback.js.map +7 -0
  154. package/build/cjs/components/Feedback/controls/DislikeControl.d.ts +11 -0
  155. package/build/cjs/components/Feedback/controls/DislikeControl.js +69 -0
  156. package/build/cjs/components/Feedback/controls/DislikeControl.js.map +7 -0
  157. package/build/cjs/components/Feedback/controls/DislikeVariantsPopup.d.ts +18 -0
  158. package/build/cjs/components/Feedback/controls/DislikeVariantsPopup.js +150 -0
  159. package/build/cjs/components/Feedback/controls/DislikeVariantsPopup.js.map +7 -0
  160. package/build/cjs/components/Feedback/controls/LikeControl.d.ts +13 -0
  161. package/build/cjs/components/Feedback/controls/LikeControl.js +81 -0
  162. package/build/cjs/components/Feedback/controls/LikeControl.js.map +7 -0
  163. package/build/cjs/components/Feedback/controls/SuccessPopup.d.ts +10 -0
  164. package/build/cjs/components/Feedback/controls/SuccessPopup.js +67 -0
  165. package/build/cjs/components/Feedback/controls/SuccessPopup.js.map +7 -0
  166. package/build/cjs/components/Feedback/index.d.ts +2 -0
  167. package/build/cjs/components/Feedback/index.js +39 -0
  168. package/build/cjs/components/Feedback/index.js.map +7 -0
  169. package/build/cjs/components/HTML/HTML.d.ts +7 -0
  170. package/build/cjs/components/HTML/HTML.js +46 -0
  171. package/build/cjs/components/HTML/HTML.js.map +7 -0
  172. package/build/cjs/components/HTML/index.d.ts +1 -0
  173. package/build/cjs/components/HTML/index.js +21 -0
  174. package/build/cjs/components/HTML/index.js.map +7 -0
  175. package/build/cjs/components/Link.d.ts +6 -0
  176. package/build/cjs/components/Link.js +41 -0
  177. package/build/cjs/components/Link.js.map +7 -0
  178. package/build/cjs/components/Mark/Mark.css +22 -0
  179. package/build/cjs/components/Mark/Mark.css.map +7 -0
  180. package/build/cjs/components/Mark/Mark.d.ts +10 -0
  181. package/build/cjs/components/Mark/Mark.js +43 -0
  182. package/build/cjs/components/Mark/Mark.js.map +7 -0
  183. package/build/cjs/components/Mark/index.d.ts +1 -0
  184. package/build/cjs/components/Mark/index.js +21 -0
  185. package/build/cjs/components/Mark/index.js.map +7 -0
  186. package/build/cjs/components/MiniToc/MiniToc.css +44 -0
  187. package/build/cjs/components/MiniToc/MiniToc.css.map +7 -0
  188. package/build/cjs/components/MiniToc/MiniToc.d.ts +15 -0
  189. package/build/cjs/components/MiniToc/MiniToc.js +71 -0
  190. package/build/cjs/components/MiniToc/MiniToc.js.map +7 -0
  191. package/build/cjs/components/MiniToc/index.d.ts +2 -0
  192. package/build/cjs/components/MiniToc/index.js +39 -0
  193. package/build/cjs/components/MiniToc/index.js.map +7 -0
  194. package/build/cjs/components/OutsideClick/OutsideClick.d.ts +12 -0
  195. package/build/cjs/components/OutsideClick/OutsideClick.js +56 -0
  196. package/build/cjs/components/OutsideClick/OutsideClick.js.map +7 -0
  197. package/build/cjs/components/OutsideClick/index.d.ts +2 -0
  198. package/build/cjs/components/OutsideClick/index.js +39 -0
  199. package/build/cjs/components/OutsideClick/index.js.map +7 -0
  200. package/build/cjs/components/Paginator/Paginator.css +45 -0
  201. package/build/cjs/components/Paginator/Paginator.css.map +7 -0
  202. package/build/cjs/components/Paginator/Paginator.d.ts +22 -0
  203. package/build/cjs/components/Paginator/Paginator.js +132 -0
  204. package/build/cjs/components/Paginator/Paginator.js.map +7 -0
  205. package/build/cjs/components/Paginator/index.d.ts +2 -0
  206. package/build/cjs/components/Paginator/index.js +39 -0
  207. package/build/cjs/components/Paginator/index.js.map +7 -0
  208. package/build/cjs/components/Scrollspy/Scrollspy.d.ts +48 -0
  209. package/build/cjs/components/Scrollspy/Scrollspy.js +259 -0
  210. package/build/cjs/components/Scrollspy/Scrollspy.js.map +7 -0
  211. package/build/cjs/components/Scrollspy/index.d.ts +1 -0
  212. package/build/cjs/components/Scrollspy/index.js +21 -0
  213. package/build/cjs/components/Scrollspy/index.js.map +7 -0
  214. package/build/cjs/components/SearchBar/SearchBar.css +59 -0
  215. package/build/cjs/components/SearchBar/SearchBar.css.map +7 -0
  216. package/build/cjs/components/SearchBar/SearchBar.d.ts +12 -0
  217. package/build/cjs/components/SearchBar/SearchBar.js +88 -0
  218. package/build/cjs/components/SearchBar/SearchBar.js.map +7 -0
  219. package/build/cjs/components/SearchBar/constants.d.ts +7 -0
  220. package/build/cjs/components/SearchBar/constants.js +39 -0
  221. package/build/cjs/components/SearchBar/constants.js.map +7 -0
  222. package/build/cjs/components/SearchBar/hooks.d.ts +55 -0
  223. package/build/cjs/components/SearchBar/hooks.js +292 -0
  224. package/build/cjs/components/SearchBar/hooks.js.map +7 -0
  225. package/build/cjs/components/SearchBar/index.d.ts +4 -0
  226. package/build/cjs/components/SearchBar/index.js +42 -0
  227. package/build/cjs/components/SearchBar/index.js.map +7 -0
  228. package/build/cjs/components/SearchBar/utils.d.ts +26 -0
  229. package/build/cjs/components/SearchBar/utils.js +108 -0
  230. package/build/cjs/components/SearchBar/utils.js.map +7 -0
  231. package/build/cjs/components/SearchBar/withHighlightedSearchWords.d.ts +16 -0
  232. package/build/cjs/components/SearchBar/withHighlightedSearchWords.js +123 -0
  233. package/build/cjs/components/SearchBar/withHighlightedSearchWords.js.map +7 -0
  234. package/build/cjs/components/SearchItem/SearchItem.css +88 -0
  235. package/build/cjs/components/SearchItem/SearchItem.css.map +7 -0
  236. package/build/cjs/components/SearchItem/SearchItem.d.ts +19 -0
  237. package/build/cjs/components/SearchItem/SearchItem.js +91 -0
  238. package/build/cjs/components/SearchItem/SearchItem.js.map +7 -0
  239. package/build/cjs/components/SearchItem/index.d.ts +2 -0
  240. package/build/cjs/components/SearchItem/index.js +39 -0
  241. package/build/cjs/components/SearchItem/index.js.map +7 -0
  242. package/build/cjs/components/SearchPage/SearchPage.css +43 -0
  243. package/build/cjs/components/SearchPage/SearchPage.css.map +7 -0
  244. package/build/cjs/components/SearchPage/SearchPage.d.ts +20 -0
  245. package/build/cjs/components/SearchPage/SearchPage.js +165 -0
  246. package/build/cjs/components/SearchPage/SearchPage.js.map +7 -0
  247. package/build/cjs/components/SearchPage/index.d.ts +2 -0
  248. package/build/cjs/components/SearchPage/index.js +39 -0
  249. package/build/cjs/components/SearchPage/index.js.map +7 -0
  250. package/build/cjs/components/StageLabel/StageLabel.d.ts +8 -0
  251. package/build/cjs/components/StageLabel/StageLabel.js +50 -0
  252. package/build/cjs/components/StageLabel/StageLabel.js.map +7 -0
  253. package/build/cjs/components/StageLabel/index.d.ts +1 -0
  254. package/build/cjs/components/StageLabel/index.js +21 -0
  255. package/build/cjs/components/StageLabel/index.js.map +7 -0
  256. package/build/cjs/components/Subscribe/Subscribe.css +98 -0
  257. package/build/cjs/components/Subscribe/Subscribe.css.map +7 -0
  258. package/build/cjs/components/Subscribe/Subscribe.d.ts +13 -0
  259. package/build/cjs/components/Subscribe/Subscribe.js +136 -0
  260. package/build/cjs/components/Subscribe/Subscribe.js.map +7 -0
  261. package/build/cjs/components/Subscribe/SubscribeSuccessPopup/SubscribeSuccessPopup.d.ts +8 -0
  262. package/build/cjs/components/Subscribe/SubscribeSuccessPopup/SubscribeSuccessPopup.js +61 -0
  263. package/build/cjs/components/Subscribe/SubscribeSuccessPopup/SubscribeSuccessPopup.js.map +7 -0
  264. package/build/cjs/components/Subscribe/SubscribeSuccessPopup/index.d.ts +1 -0
  265. package/build/cjs/components/Subscribe/SubscribeSuccessPopup/index.js +37 -0
  266. package/build/cjs/components/Subscribe/SubscribeSuccessPopup/index.js.map +7 -0
  267. package/build/cjs/components/Subscribe/SubscribeVariantsPopup/SubscribeVariantsPopup.d.ts +11 -0
  268. package/build/cjs/components/Subscribe/SubscribeVariantsPopup/SubscribeVariantsPopup.js +126 -0
  269. package/build/cjs/components/Subscribe/SubscribeVariantsPopup/SubscribeVariantsPopup.js.map +7 -0
  270. package/build/cjs/components/Subscribe/SubscribeVariantsPopup/index.d.ts +1 -0
  271. package/build/cjs/components/Subscribe/SubscribeVariantsPopup/index.js +37 -0
  272. package/build/cjs/components/Subscribe/SubscribeVariantsPopup/index.js.map +7 -0
  273. package/build/cjs/components/Subscribe/index.d.ts +2 -0
  274. package/build/cjs/components/Subscribe/index.js +39 -0
  275. package/build/cjs/components/Subscribe/index.js.map +7 -0
  276. package/build/cjs/components/Subscribe/utils.d.ts +3 -0
  277. package/build/cjs/components/Subscribe/utils.js +34 -0
  278. package/build/cjs/components/Subscribe/utils.js.map +7 -0
  279. package/build/cjs/components/Text/Text.d.ts +7 -0
  280. package/build/cjs/components/Text/Text.js +54 -0
  281. package/build/cjs/components/Text/Text.js.map +7 -0
  282. package/build/cjs/components/Text/index.d.ts +1 -0
  283. package/build/cjs/components/Text/index.js +21 -0
  284. package/build/cjs/components/Text/index.js.map +7 -0
  285. package/build/cjs/components/TextInput/TextInput.d.ts +0 -0
  286. package/build/cjs/components/Toc/Toc.css +102 -0
  287. package/build/cjs/components/Toc/Toc.css.map +7 -0
  288. package/build/cjs/components/Toc/Toc.d.ts +58 -0
  289. package/build/cjs/components/Toc/Toc.js +275 -0
  290. package/build/cjs/components/Toc/Toc.js.map +7 -0
  291. package/build/cjs/components/Toc/TocItemRegistry.d.ts +16 -0
  292. package/build/cjs/components/Toc/TocItemRegistry.js +81 -0
  293. package/build/cjs/components/Toc/TocItemRegistry.js.map +7 -0
  294. package/build/cjs/components/Toc/index.d.ts +2 -0
  295. package/build/cjs/components/Toc/index.js +39 -0
  296. package/build/cjs/components/Toc/index.js.map +7 -0
  297. package/build/cjs/components/TocItem/TocItem.css +39 -0
  298. package/build/cjs/components/TocItem/TocItem.css.map +7 -0
  299. package/build/cjs/components/TocItem/TocItem.d.ts +20 -0
  300. package/build/cjs/components/TocItem/TocItem.js +105 -0
  301. package/build/cjs/components/TocItem/TocItem.js.map +7 -0
  302. package/build/cjs/components/TocItem/index.d.ts +2 -0
  303. package/build/cjs/components/TocItem/index.js +39 -0
  304. package/build/cjs/components/TocItem/index.js.map +7 -0
  305. package/build/cjs/components/TocNavPanel/TocNavPanel.css +64 -0
  306. package/build/cjs/components/TocNavPanel/TocNavPanel.css.map +7 -0
  307. package/build/cjs/components/TocNavPanel/TocNavPanel.d.ts +10 -0
  308. package/build/cjs/components/TocNavPanel/TocNavPanel.js +94 -0
  309. package/build/cjs/components/TocNavPanel/TocNavPanel.js.map +7 -0
  310. package/build/cjs/components/TocNavPanel/index.d.ts +2 -0
  311. package/build/cjs/components/TocNavPanel/index.js +39 -0
  312. package/build/cjs/components/TocNavPanel/index.js.map +7 -0
  313. package/build/cjs/components/ToggleArrow/ToggleArrow.css +24 -0
  314. package/build/cjs/components/ToggleArrow/ToggleArrow.css.map +7 -0
  315. package/build/cjs/components/ToggleArrow/ToggleArrow.d.ts +11 -0
  316. package/build/cjs/components/ToggleArrow/ToggleArrow.js +49 -0
  317. package/build/cjs/components/ToggleArrow/ToggleArrow.js.map +7 -0
  318. package/build/cjs/components/ToggleArrow/index.d.ts +1 -0
  319. package/build/cjs/components/ToggleArrow/index.js +21 -0
  320. package/build/cjs/components/ToggleArrow/index.js.map +7 -0
  321. package/build/cjs/config/i18n.d.ts +7 -0
  322. package/build/cjs/config/i18n.js +68 -0
  323. package/build/cjs/config/i18n.js.map +7 -0
  324. package/build/cjs/config/index.d.ts +6 -0
  325. package/build/cjs/config/index.js +51 -0
  326. package/build/cjs/config/index.js.map +7 -0
  327. package/build/cjs/constants.d.ts +19 -0
  328. package/build/cjs/constants.js +46 -0
  329. package/build/cjs/constants.js.map +7 -0
  330. package/build/cjs/hooks/index.d.ts +4 -0
  331. package/build/cjs/hooks/index.js +24 -0
  332. package/build/cjs/hooks/index.js.map +7 -0
  333. package/build/cjs/hooks/usePopper.d.ts +33 -0
  334. package/build/cjs/hooks/usePopper.js +93 -0
  335. package/build/cjs/hooks/usePopper.js.map +7 -0
  336. package/build/cjs/hooks/usePopupState.d.ts +8 -0
  337. package/build/cjs/hooks/usePopupState.js +62 -0
  338. package/build/cjs/hooks/usePopupState.js.map +7 -0
  339. package/build/cjs/hooks/useTimer.d.ts +1 -0
  340. package/build/cjs/hooks/useTimer.js +44 -0
  341. package/build/cjs/hooks/useTimer.js.map +7 -0
  342. package/build/cjs/hooks/useTranslation.d.ts +2 -0
  343. package/build/cjs/hooks/useTranslation.js +32 -0
  344. package/build/cjs/hooks/useTranslation.js.map +7 -0
  345. package/build/cjs/i18n/en.js +124 -0
  346. package/build/cjs/i18n/en.js.map +7 -0
  347. package/build/cjs/i18n/ru.js +124 -0
  348. package/build/cjs/i18n/ru.js.map +7 -0
  349. package/build/cjs/index.d.ts +28 -0
  350. package/build/cjs/index.js +48 -0
  351. package/build/cjs/index.js.map +7 -0
  352. package/build/cjs/models/index.d.ts +139 -0
  353. package/build/cjs/models/index.js +69 -0
  354. package/build/cjs/models/index.js.map +7 -0
  355. package/build/cjs/utils/index.d.ts +14 -0
  356. package/build/cjs/utils/index.js +109 -0
  357. package/build/cjs/utils/index.js.map +7 -0
  358. package/build/esm/components/BookmarkButton/BookmarkButton.css +12 -0
  359. package/build/esm/components/BookmarkButton/BookmarkButton.css.map +7 -0
  360. package/build/esm/components/BookmarkButton/BookmarkButton.js +25 -0
  361. package/build/esm/components/BookmarkButton/BookmarkButton.js.map +7 -0
  362. package/build/esm/components/BookmarkButton/index.js +3 -0
  363. package/build/esm/components/BookmarkButton/index.js.map +7 -0
  364. package/build/esm/components/Breadcrumbs/Breadcrumbs.css +35 -0
  365. package/build/esm/components/Breadcrumbs/Breadcrumbs.css.map +7 -0
  366. package/build/esm/components/Breadcrumbs/Breadcrumbs.js +27 -0
  367. package/build/esm/components/Breadcrumbs/Breadcrumbs.js.map +7 -0
  368. package/build/esm/components/Breadcrumbs/index.js +3 -0
  369. package/build/esm/components/Breadcrumbs/index.js.map +7 -0
  370. package/build/esm/components/ContributorAvatars/Avatars/Avatar.js +58 -0
  371. package/build/esm/components/ContributorAvatars/Avatars/Avatar.js.map +7 -0
  372. package/build/esm/components/ContributorAvatars/Avatars/AvatarWithDescription.js +32 -0
  373. package/build/esm/components/ContributorAvatars/Avatars/AvatarWithDescription.js.map +7 -0
  374. package/build/esm/components/ContributorAvatars/Avatars/Details.js +46 -0
  375. package/build/esm/components/ContributorAvatars/Avatars/Details.js.map +7 -0
  376. package/build/esm/components/ContributorAvatars/Avatars/HiddenAvatars.js +39 -0
  377. package/build/esm/components/ContributorAvatars/Avatars/HiddenAvatars.js.map +7 -0
  378. package/build/esm/components/ContributorAvatars/ContributorAvatars.css +135 -0
  379. package/build/esm/components/ContributorAvatars/ContributorAvatars.css.map +7 -0
  380. package/build/esm/components/ContributorAvatars/ContributorAvatars.js +53 -0
  381. package/build/esm/components/ContributorAvatars/ContributorAvatars.js.map +7 -0
  382. package/build/esm/components/ContributorAvatars/index.js +7 -0
  383. package/build/esm/components/ContributorAvatars/index.js.map +7 -0
  384. package/build/esm/components/ContributorAvatars/models.js +10 -0
  385. package/build/esm/components/ContributorAvatars/models.js.map +7 -0
  386. package/build/esm/components/ContributorAvatars/utils.js +18 -0
  387. package/build/esm/components/ContributorAvatars/utils.js.map +7 -0
  388. package/build/esm/components/Contributors/Contributors.css +12 -0
  389. package/build/esm/components/Contributors/Contributors.css.map +7 -0
  390. package/build/esm/components/Contributors/Contributors.js +17 -0
  391. package/build/esm/components/Contributors/Contributors.js.map +7 -0
  392. package/build/esm/components/Control/Control.css +15 -0
  393. package/build/esm/components/Control/Control.css.map +7 -0
  394. package/build/esm/components/Control/Control.js +64 -0
  395. package/build/esm/components/Control/Control.js.map +7 -0
  396. package/build/esm/components/Control/index.js +7 -0
  397. package/build/esm/components/Control/index.js.map +7 -0
  398. package/build/esm/components/Controls/Controls.css +50 -0
  399. package/build/esm/components/Controls/Controls.css.map +7 -0
  400. package/build/esm/components/Controls/Controls.js +146 -0
  401. package/build/esm/components/Controls/Controls.js.map +7 -0
  402. package/build/esm/components/Controls/ControlsLayout.js +37 -0
  403. package/build/esm/components/Controls/ControlsLayout.js.map +7 -0
  404. package/build/esm/components/Controls/index.js +10 -0
  405. package/build/esm/components/Controls/index.js.map +7 -0
  406. package/build/esm/components/Controls/single-controls/DividerControl/DividerControl.css +21 -0
  407. package/build/esm/components/Controls/single-controls/DividerControl/DividerControl.css.map +7 -0
  408. package/build/esm/components/Controls/single-controls/DividerControl/DividerControl.js +15 -0
  409. package/build/esm/components/Controls/single-controls/DividerControl/DividerControl.js.map +7 -0
  410. package/build/esm/components/Controls/single-controls/EditControl.js +42 -0
  411. package/build/esm/components/Controls/single-controls/EditControl.js.map +7 -0
  412. package/build/esm/components/Controls/single-controls/FullScreenControl.js +51 -0
  413. package/build/esm/components/Controls/single-controls/FullScreenControl.js.map +7 -0
  414. package/build/esm/components/Controls/single-controls/LangControl.js +91 -0
  415. package/build/esm/components/Controls/single-controls/LangControl.js.map +7 -0
  416. package/build/esm/components/Controls/single-controls/PdfControl.js +29 -0
  417. package/build/esm/components/Controls/single-controls/PdfControl.js.map +7 -0
  418. package/build/esm/components/Controls/single-controls/SettingsControl/SettingsControl.css +49 -0
  419. package/build/esm/components/Controls/single-controls/SettingsControl/SettingsControl.css.map +7 -0
  420. package/build/esm/components/Controls/single-controls/SettingsControl/SettingsControl.js +167 -0
  421. package/build/esm/components/Controls/single-controls/SettingsControl/SettingsControl.js.map +7 -0
  422. package/build/esm/components/Controls/single-controls/SinglePageControl.js +36 -0
  423. package/build/esm/components/Controls/single-controls/SinglePageControl.js.map +7 -0
  424. package/build/esm/components/Controls/single-controls/index.js +18 -0
  425. package/build/esm/components/Controls/single-controls/index.js.map +7 -0
  426. package/build/esm/components/Controls/single-controls/utils.js +9 -0
  427. package/build/esm/components/Controls/single-controls/utils.js.map +7 -0
  428. package/build/esm/components/DocLayout/DocLayout.css +102 -0
  429. package/build/esm/components/DocLayout/DocLayout.css.map +7 -0
  430. package/build/esm/components/DocLayout/DocLayout.js +86 -0
  431. package/build/esm/components/DocLayout/DocLayout.js.map +7 -0
  432. package/build/esm/components/DocLayout/index.js +3 -0
  433. package/build/esm/components/DocLayout/index.js.map +7 -0
  434. package/build/esm/components/DocLeadingPage/DocLeadingPage.css +93 -0
  435. package/build/esm/components/DocLeadingPage/DocLeadingPage.css.map +7 -0
  436. package/build/esm/components/DocLeadingPage/DocLeadingPage.js +78 -0
  437. package/build/esm/components/DocLeadingPage/DocLeadingPage.js.map +7 -0
  438. package/build/esm/components/DocLeadingPage/index.js +3 -0
  439. package/build/esm/components/DocLeadingPage/index.js.map +7 -0
  440. package/build/esm/components/DocPage/DocPage.css +231 -0
  441. package/build/esm/components/DocPage/DocPage.css.map +7 -0
  442. package/build/esm/components/DocPage/DocPage.js +436 -0
  443. package/build/esm/components/DocPage/DocPage.js.map +7 -0
  444. package/build/esm/components/DocPage/index.js +7 -0
  445. package/build/esm/components/DocPage/index.js.map +7 -0
  446. package/build/esm/components/DocPageTitle/DocPageTitle.css +10 -0
  447. package/build/esm/components/DocPageTitle/DocPageTitle.css.map +7 -0
  448. package/build/esm/components/DocPageTitle/DocPageTitle.js +19 -0
  449. package/build/esm/components/DocPageTitle/DocPageTitle.js.map +7 -0
  450. package/build/esm/components/DocPageTitle/index.js +3 -0
  451. package/build/esm/components/DocPageTitle/index.js.map +7 -0
  452. package/build/esm/components/ErrorBoundary/ErrorBoundary.js +25 -0
  453. package/build/esm/components/ErrorBoundary/ErrorBoundary.js.map +7 -0
  454. package/build/esm/components/ErrorBoundary/index.js +7 -0
  455. package/build/esm/components/ErrorBoundary/index.js.map +7 -0
  456. package/build/esm/components/ErrorPage/ErrorPage.css +65 -0
  457. package/build/esm/components/ErrorPage/ErrorPage.css.map +7 -0
  458. package/build/esm/components/ErrorPage/ErrorPage.js +52 -0
  459. package/build/esm/components/ErrorPage/ErrorPage.js.map +7 -0
  460. package/build/esm/components/ErrorPage/index.js +7 -0
  461. package/build/esm/components/ErrorPage/index.js.map +7 -0
  462. package/build/esm/components/Feedback/Feedback.css +109 -0
  463. package/build/esm/components/Feedback/Feedback.css.map +7 -0
  464. package/build/esm/components/Feedback/Feedback.js +132 -0
  465. package/build/esm/components/Feedback/Feedback.js.map +7 -0
  466. package/build/esm/components/Feedback/controls/DislikeControl.js +38 -0
  467. package/build/esm/components/Feedback/controls/DislikeControl.js.map +7 -0
  468. package/build/esm/components/Feedback/controls/DislikeVariantsPopup.js +128 -0
  469. package/build/esm/components/Feedback/controls/DislikeVariantsPopup.js.map +7 -0
  470. package/build/esm/components/Feedback/controls/LikeControl.js +50 -0
  471. package/build/esm/components/Feedback/controls/LikeControl.js.map +7 -0
  472. package/build/esm/components/Feedback/controls/SuccessPopup.js +36 -0
  473. package/build/esm/components/Feedback/controls/SuccessPopup.js.map +7 -0
  474. package/build/esm/components/Feedback/index.js +7 -0
  475. package/build/esm/components/Feedback/index.js.map +7 -0
  476. package/build/esm/components/HTML/HTML.js +15 -0
  477. package/build/esm/components/HTML/HTML.js.map +7 -0
  478. package/build/esm/components/HTML/index.js +3 -0
  479. package/build/esm/components/HTML/index.js.map +7 -0
  480. package/build/esm/components/Link.js +10 -0
  481. package/build/esm/components/Link.js.map +7 -0
  482. package/build/esm/components/Mark/Mark.css +22 -0
  483. package/build/esm/components/Mark/Mark.css.map +7 -0
  484. package/build/esm/components/Mark/Mark.js +12 -0
  485. package/build/esm/components/Mark/Mark.js.map +7 -0
  486. package/build/esm/components/Mark/index.js +3 -0
  487. package/build/esm/components/Mark/index.js.map +7 -0
  488. package/build/esm/components/MiniToc/MiniToc.css +44 -0
  489. package/build/esm/components/MiniToc/MiniToc.css.map +7 -0
  490. package/build/esm/components/MiniToc/MiniToc.js +40 -0
  491. package/build/esm/components/MiniToc/MiniToc.js.map +7 -0
  492. package/build/esm/components/MiniToc/index.js +7 -0
  493. package/build/esm/components/MiniToc/index.js.map +7 -0
  494. package/build/esm/components/OutsideClick/OutsideClick.js +25 -0
  495. package/build/esm/components/OutsideClick/OutsideClick.js.map +7 -0
  496. package/build/esm/components/OutsideClick/index.js +7 -0
  497. package/build/esm/components/OutsideClick/index.js.map +7 -0
  498. package/build/esm/components/Paginator/Paginator.css +45 -0
  499. package/build/esm/components/Paginator/Paginator.css.map +7 -0
  500. package/build/esm/components/Paginator/Paginator.js +101 -0
  501. package/build/esm/components/Paginator/Paginator.js.map +7 -0
  502. package/build/esm/components/Paginator/index.js +7 -0
  503. package/build/esm/components/Paginator/index.js.map +7 -0
  504. package/build/esm/components/Scrollspy/Scrollspy.js +228 -0
  505. package/build/esm/components/Scrollspy/Scrollspy.js.map +7 -0
  506. package/build/esm/components/Scrollspy/index.js +3 -0
  507. package/build/esm/components/Scrollspy/index.js.map +7 -0
  508. package/build/esm/components/SearchBar/SearchBar.css +59 -0
  509. package/build/esm/components/SearchBar/SearchBar.css.map +7 -0
  510. package/build/esm/components/SearchBar/SearchBar.js +57 -0
  511. package/build/esm/components/SearchBar/SearchBar.js.map +7 -0
  512. package/build/esm/components/SearchBar/constants.js +18 -0
  513. package/build/esm/components/SearchBar/constants.js.map +7 -0
  514. package/build/esm/components/SearchBar/hooks.js +271 -0
  515. package/build/esm/components/SearchBar/hooks.js.map +7 -0
  516. package/build/esm/components/SearchBar/index.js +10 -0
  517. package/build/esm/components/SearchBar/index.js.map +7 -0
  518. package/build/esm/components/SearchBar/utils.js +77 -0
  519. package/build/esm/components/SearchBar/utils.js.map +7 -0
  520. package/build/esm/components/SearchBar/withHighlightedSearchWords.js +97 -0
  521. package/build/esm/components/SearchBar/withHighlightedSearchWords.js.map +7 -0
  522. package/build/esm/components/SearchItem/SearchItem.css +88 -0
  523. package/build/esm/components/SearchItem/SearchItem.css.map +7 -0
  524. package/build/esm/components/SearchItem/SearchItem.js +60 -0
  525. package/build/esm/components/SearchItem/SearchItem.js.map +7 -0
  526. package/build/esm/components/SearchItem/index.js +7 -0
  527. package/build/esm/components/SearchItem/index.js.map +7 -0
  528. package/build/esm/components/SearchPage/SearchPage.css +43 -0
  529. package/build/esm/components/SearchPage/SearchPage.css.map +7 -0
  530. package/build/esm/components/SearchPage/SearchPage.js +134 -0
  531. package/build/esm/components/SearchPage/SearchPage.js.map +7 -0
  532. package/build/esm/components/SearchPage/index.js +7 -0
  533. package/build/esm/components/SearchPage/index.js.map +7 -0
  534. package/build/esm/components/StageLabel/StageLabel.js +19 -0
  535. package/build/esm/components/StageLabel/StageLabel.js.map +7 -0
  536. package/build/esm/components/StageLabel/index.js +3 -0
  537. package/build/esm/components/StageLabel/index.js.map +7 -0
  538. package/build/esm/components/Subscribe/Subscribe.css +98 -0
  539. package/build/esm/components/Subscribe/Subscribe.css.map +7 -0
  540. package/build/esm/components/Subscribe/Subscribe.js +105 -0
  541. package/build/esm/components/Subscribe/Subscribe.js.map +7 -0
  542. package/build/esm/components/Subscribe/SubscribeSuccessPopup/SubscribeSuccessPopup.js +30 -0
  543. package/build/esm/components/Subscribe/SubscribeSuccessPopup/SubscribeSuccessPopup.js.map +7 -0
  544. package/build/esm/components/Subscribe/SubscribeSuccessPopup/index.js +6 -0
  545. package/build/esm/components/Subscribe/SubscribeSuccessPopup/index.js.map +7 -0
  546. package/build/esm/components/Subscribe/SubscribeVariantsPopup/SubscribeVariantsPopup.js +95 -0
  547. package/build/esm/components/Subscribe/SubscribeVariantsPopup/SubscribeVariantsPopup.js.map +7 -0
  548. package/build/esm/components/Subscribe/SubscribeVariantsPopup/index.js +6 -0
  549. package/build/esm/components/Subscribe/SubscribeVariantsPopup/index.js.map +7 -0
  550. package/build/esm/components/Subscribe/index.js +7 -0
  551. package/build/esm/components/Subscribe/index.js.map +7 -0
  552. package/build/esm/components/Subscribe/utils.js +13 -0
  553. package/build/esm/components/Subscribe/utils.js.map +7 -0
  554. package/build/esm/components/Text/Text.js +23 -0
  555. package/build/esm/components/Text/Text.js.map +7 -0
  556. package/build/esm/components/Text/index.js +3 -0
  557. package/build/esm/components/Text/index.js.map +7 -0
  558. package/build/esm/components/Toc/Toc.css +102 -0
  559. package/build/esm/components/Toc/Toc.css.map +7 -0
  560. package/build/esm/components/Toc/Toc.js +244 -0
  561. package/build/esm/components/Toc/Toc.js.map +7 -0
  562. package/build/esm/components/Toc/TocItemRegistry.js +60 -0
  563. package/build/esm/components/Toc/TocItemRegistry.js.map +7 -0
  564. package/build/esm/components/Toc/index.js +7 -0
  565. package/build/esm/components/Toc/index.js.map +7 -0
  566. package/build/esm/components/TocItem/TocItem.css +39 -0
  567. package/build/esm/components/TocItem/TocItem.css.map +7 -0
  568. package/build/esm/components/TocItem/TocItem.js +74 -0
  569. package/build/esm/components/TocItem/TocItem.js.map +7 -0
  570. package/build/esm/components/TocItem/index.js +7 -0
  571. package/build/esm/components/TocItem/index.js.map +7 -0
  572. package/build/esm/components/TocNavPanel/TocNavPanel.css +64 -0
  573. package/build/esm/components/TocNavPanel/TocNavPanel.css.map +7 -0
  574. package/build/esm/components/TocNavPanel/TocNavPanel.js +63 -0
  575. package/build/esm/components/TocNavPanel/TocNavPanel.js.map +7 -0
  576. package/build/esm/components/TocNavPanel/index.js +7 -0
  577. package/build/esm/components/TocNavPanel/index.js.map +7 -0
  578. package/build/esm/components/ToggleArrow/ToggleArrow.css +24 -0
  579. package/build/esm/components/ToggleArrow/ToggleArrow.css.map +7 -0
  580. package/build/esm/components/ToggleArrow/ToggleArrow.js +18 -0
  581. package/build/esm/components/ToggleArrow/ToggleArrow.js.map +7 -0
  582. package/build/esm/components/ToggleArrow/index.js +3 -0
  583. package/build/esm/components/ToggleArrow/index.js.map +7 -0
  584. package/build/esm/config/i18n.js +37 -0
  585. package/build/esm/config/i18n.js.map +7 -0
  586. package/build/esm/config/index.js +30 -0
  587. package/build/esm/config/index.js.map +7 -0
  588. package/build/esm/constants.js +25 -0
  589. package/build/esm/constants.js.map +7 -0
  590. package/build/esm/hooks/index.js +6 -0
  591. package/build/esm/hooks/index.js.map +7 -0
  592. package/build/esm/hooks/usePopper.js +62 -0
  593. package/build/esm/hooks/usePopper.js.map +7 -0
  594. package/build/esm/hooks/usePopupState.js +41 -0
  595. package/build/esm/hooks/usePopupState.js.map +7 -0
  596. package/build/esm/hooks/useTimer.js +23 -0
  597. package/build/esm/hooks/useTimer.js.map +7 -0
  598. package/build/esm/hooks/useTranslation.js +11 -0
  599. package/build/esm/hooks/useTranslation.js.map +7 -0
  600. package/build/esm/i18n/en.js +137 -0
  601. package/build/esm/i18n/en.js.map +7 -0
  602. package/build/esm/i18n/ru.js +137 -0
  603. package/build/esm/i18n/ru.js.map +7 -0
  604. package/build/esm/index.js +30 -0
  605. package/build/esm/index.js.map +7 -0
  606. package/build/esm/models/index.js +48 -0
  607. package/build/esm/models/index.js.map +7 -0
  608. package/build/esm/utils/index.js +88 -0
  609. package/build/esm/utils/index.js.map +7 -0
  610. package/build/index.css +197 -0
  611. package/build/index.css.map +7 -0
  612. package/build/themes/common/index.css +1170 -0
  613. package/build/themes/common/index.css.map +7 -0
  614. package/package.json +145 -0
@@ -0,0 +1,45 @@
1
+ /* src/components/Paginator/Paginator.scss */
2
+ .Paginator {
3
+ margin: 0;
4
+ padding: 0;
5
+ list-style: none;
6
+ display: flex;
7
+ align-items: center;
8
+ }
9
+ .Paginator__item {
10
+ display: inline-flex;
11
+ align-items: center;
12
+ justify-content: center;
13
+ min-width: 28px;
14
+ min-height: 28px;
15
+ margin: 4px;
16
+ color: var(--g-color-text-primary);
17
+ font-size: var(--g-text-body-1-font-size);
18
+ line-height: var(--g-text-body-1-line-height);
19
+ }
20
+ .Paginator__item_type_prev {
21
+ margin-left: -6px;
22
+ }
23
+ .Paginator__item_type_prev .Paginator__icon {
24
+ transform: rotate(180deg);
25
+ }
26
+ .Paginator__item_type_dots {
27
+ min-width: 0;
28
+ color: var(--g-color-text-secondary);
29
+ }
30
+ .Paginator__item_type_page {
31
+ cursor: pointer;
32
+ border-radius: 14px;
33
+ }
34
+ .Paginator__item_type_page:hover {
35
+ background: var(--g-color-base-simple-hover);
36
+ }
37
+ .Paginator__item_type_page.Paginator__item_active {
38
+ color: var(--g-color-text-light-primary);
39
+ background: var(--g-color-base-brand);
40
+ cursor: default;
41
+ }
42
+ .Paginator__item_type_next {
43
+ margin-right: -6px;
44
+ }
45
+ /*# sourceMappingURL=Paginator.css.map */
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../src/components/Paginator/Users/3y3k0/doctools/docs-components/src/components/Paginator/Paginator.scss", "../../../../src/components/Paginator/Users/3y3k0/doctools/docs-components/src/styles/mixins.scss", "../../../../src/components/Paginator/%3Cinput%20css%20pk6c7-%3E"],
4
+ "sourcesContent": ["@import '../../styles/variables';\n@import '../../styles/mixins';\n\n.Paginator {\n $block: &;\n\n @include reset-list-style();\n\n display: flex;\n align-items: center;\n\n &__item {\n $item: &;\n\n display: inline-flex;\n align-items: center;\n justify-content: center;\n\n min-width: 28px;\n min-height: 28px;\n margin: 4px;\n\n color: var(--g-color-text-primary);\n @include text-size(body-1);\n\n &_type {\n &_prev {\n margin-left: -6px;\n\n #{$block}__icon {\n transform: rotate(180deg);\n }\n }\n\n &_dots {\n min-width: 0;\n color: var(--g-color-text-secondary);\n }\n\n &_page {\n cursor: pointer;\n border-radius: 14px;\n\n &:hover {\n background: var(--g-color-base-simple-hover);\n }\n\n &#{$item}_active {\n color: var(--g-color-text-light-primary);\n background: var(--g-color-base-brand);\n cursor: default;\n }\n }\n\n &_next {\n margin-right: -6px;\n }\n }\n }\n}\n", "@import './variables';\n\n@mixin text-size($name) {\n font-size: var(--g-text-#{$name}-font-size);\n line-height: var(--g-text-#{$name}-line-height);\n}\n\n@mixin reset-list-style() {\n margin: 0;\n padding: 0;\n list-style: none;\n}\n\n@mixin fixAnchorPosition($offset: 0px) {\n padding-top: calc(var(--dc-header-height, #{$headerHeight}));\n margin-top: calc(#{$offset} - var(--dc-header-height, #{$headerHeight}));\n}\n\n@mixin reset-link-style() {\n color: inherit;\n text-decoration: none;\n}\n\n@mixin islands-focus() {\n outline: none;\n\n .utilityfocus &:focus {\n outline: 2px solid #ffdb4d;\n }\n}\n\n@mixin link() {\n @include islands-focus();\n\n color: var(--g-color-text-link);\n text-decoration: none;\n cursor: pointer;\n\n &:hover,\n &:active {\n color: var(--g-color-text-link-hover);\n }\n}\n\n@mixin heading1() {\n @include text-size(display-3);\n font-weight: 500;\n\n @media (max-width: map-get($screenBreakpoints, 'md') - 1) {\n @include text-size(display-2);\n }\n}\n\n@mixin heading2() {\n @include text-size(display-1);\n font-weight: 500;\n}\n\n@mixin heading3() {\n @include text-size(header-2);\n font-weight: 500;\n}\n\n@mixin heading4() {\n @include text-size(header-1);\n font-weight: 500;\n}\n\n@mixin heading5() {\n @include text-size(body-3);\n font-weight: 500;\n}\n\n@mixin heading6() {\n @include text-size(body-3);\n font-weight: 400;\n}\n\n@mixin contributors-text() {\n font-size: 13px;\n font-weight: 400;\n margin-right: 5px;\n align-self: center;\n}\n\n@mixin text-body-1() {\n font-size: var(--g-text-body-1-font-size);\n line-height: var(--g-text-body-1-line-height);\n font-weight: var(--g-text-body-font-weight);\n}\n\n@mixin desktop-only() {\n @media (max-width: map-get($screenBreakpoints, 'md') - 1) {\n display: none;\n }\n}\n\n@mixin desktop-tablet-only() {\n @media (max-width: map-get($screenBreakpoints, 'sm') - 1) {\n display: none;\n }\n}\n\n@mixin mobile-tablet-only() {\n @media (min-width: map-get($screenBreakpoints, 'md')) {\n display: none;\n }\n}\n\n@mixin mobile-only() {\n @media (min-width: map-get($screenBreakpoints, 'sm')) {\n display: none;\n }\n}\n", ".Paginator {\n margin: 0;\n padding: 0;\n list-style: none;\n display: flex;\n align-items: center;\n}\n.Paginator__item {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n min-width: 28px;\n min-height: 28px;\n margin: 4px;\n color: var(--g-color-text-primary);\n font-size: var(--g-text-body-1-font-size);\n line-height: var(--g-text-body-1-line-height);\n}\n.Paginator__item_type_prev {\n margin-left: -6px;\n}\n.Paginator__item_type_prev .Paginator__icon {\n transform: rotate(180deg);\n}\n.Paginator__item_type_dots {\n min-width: 0;\n color: var(--g-color-text-secondary);\n}\n.Paginator__item_type_page {\n cursor: pointer;\n border-radius: 14px;\n}\n.Paginator__item_type_page:hover {\n background: var(--g-color-base-simple-hover);\n}\n.Paginator__item_type_page.Paginator__item_active {\n color: var(--g-color-text-light-primary);\n background: var(--g-color-base-brand);\n cursor: default;\n}\n.Paginator__item_type_next {\n margin-right: -6px;\n}\n/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VSb290IjoiL1VzZXJzLzN5M2swL2RvY3Rvb2xzL2RvY3MtY29tcG9uZW50cy9zcmMvY29tcG9uZW50cy9QYWdpbmF0b3IiLCJzb3VyY2VzIjpbIlBhZ2luYXRvci5zY3NzIiwiLi4vLi4vc3R5bGVzL21peGlucy5zY3NzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUdBO0VDS0k7RUFDQTtFQUNBO0VERkE7RUFDQTs7QUFFQTtFQUdJO0VBQ0E7RUFDQTtFQUVBO0VBQ0E7RUFDQTtFQUVBO0VDbkJKO0VBQ0E7O0FEc0JRO0VBQ0k7O0FBRUE7RUFDSTs7QUFJUjtFQUNJO0VBQ0E7O0FBR0o7RUFDSTtFQUNBOztBQUVBO0VBQ0k7O0FBR0o7RUFDSTtFQUNBO0VBQ0E7O0FBSVI7RUFDSSIsInNvdXJjZXNDb250ZW50IjpbIkBpbXBvcnQgJy4uLy4uL3N0eWxlcy92YXJpYWJsZXMnO1xuQGltcG9ydCAnLi4vLi4vc3R5bGVzL21peGlucyc7XG5cbi5QYWdpbmF0b3Ige1xuICAgICRibG9jazogJjtcblxuICAgIEBpbmNsdWRlIHJlc2V0LWxpc3Qtc3R5bGUoKTtcblxuICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcblxuICAgICZfX2l0ZW0ge1xuICAgICAgICAkaXRlbTogJjtcblxuICAgICAgICBkaXNwbGF5OiBpbmxpbmUtZmxleDtcbiAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgICAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG5cbiAgICAgICAgbWluLXdpZHRoOiAyOHB4O1xuICAgICAgICBtaW4taGVpZ2h0OiAyOHB4O1xuICAgICAgICBtYXJnaW46IDRweDtcblxuICAgICAgICBjb2xvcjogdmFyKC0tZy1jb2xvci10ZXh0LXByaW1hcnkpO1xuICAgICAgICBAaW5jbHVkZSB0ZXh0LXNpemUoYm9keS0xKTtcblxuICAgICAgICAmX3R5cGUge1xuICAgICAgICAgICAgJl9wcmV2IHtcbiAgICAgICAgICAgICAgICBtYXJnaW4tbGVmdDogLTZweDtcblxuICAgICAgICAgICAgICAgICN7JGJsb2NrfV9faWNvbiB7XG4gICAgICAgICAgICAgICAgICAgIHRyYW5zZm9ybTogcm90YXRlKDE4MGRlZyk7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICAmX2RvdHMge1xuICAgICAgICAgICAgICAgIG1pbi13aWR0aDogMDtcbiAgICAgICAgICAgICAgICBjb2xvcjogdmFyKC0tZy1jb2xvci10ZXh0LXNlY29uZGFyeSk7XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICZfcGFnZSB7XG4gICAgICAgICAgICAgICAgY3Vyc29yOiBwb2ludGVyO1xuICAgICAgICAgICAgICAgIGJvcmRlci1yYWRpdXM6IDE0cHg7XG5cbiAgICAgICAgICAgICAgICAmOmhvdmVyIHtcbiAgICAgICAgICAgICAgICAgICAgYmFja2dyb3VuZDogdmFyKC0tZy1jb2xvci1iYXNlLXNpbXBsZS1ob3Zlcik7XG4gICAgICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICAgICAgJiN7JGl0ZW19X2FjdGl2ZSB7XG4gICAgICAgICAgICAgICAgICAgIGNvbG9yOiB2YXIoLS1nLWNvbG9yLXRleHQtbGlnaHQtcHJpbWFyeSk7XG4gICAgICAgICAgICAgICAgICAgIGJhY2tncm91bmQ6IHZhcigtLWctY29sb3ItYmFzZS1icmFuZCk7XG4gICAgICAgICAgICAgICAgICAgIGN1cnNvcjogZGVmYXVsdDtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICZfbmV4dCB7XG4gICAgICAgICAgICAgICAgbWFyZ2luLXJpZ2h0OiAtNnB4O1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgfVxufVxuIiwiQGltcG9ydCAnLi92YXJpYWJsZXMnO1xuXG5AbWl4aW4gdGV4dC1zaXplKCRuYW1lKSB7XG4gICAgZm9udC1zaXplOiB2YXIoLS1nLXRleHQtI3skbmFtZX0tZm9udC1zaXplKTtcbiAgICBsaW5lLWhlaWdodDogdmFyKC0tZy10ZXh0LSN7JG5hbWV9LWxpbmUtaGVpZ2h0KTtcbn1cblxuQG1peGluIHJlc2V0LWxpc3Qtc3R5bGUoKSB7XG4gICAgbWFyZ2luOiAwO1xuICAgIHBhZGRpbmc6IDA7XG4gICAgbGlzdC1zdHlsZTogbm9uZTtcbn1cblxuQG1peGluIGZpeEFuY2hvclBvc2l0aW9uKCRvZmZzZXQ6IDBweCkge1xuICAgIHBhZGRpbmctdG9wOiBjYWxjKHZhcigtLWRjLWhlYWRlci1oZWlnaHQsICN7JGhlYWRlckhlaWdodH0pKTtcbiAgICBtYXJnaW4tdG9wOiBjYWxjKCN7JG9mZnNldH0gLSB2YXIoLS1kYy1oZWFkZXItaGVpZ2h0LCAjeyRoZWFkZXJIZWlnaHR9KSk7XG59XG5cbkBtaXhpbiByZXNldC1saW5rLXN0eWxlKCkge1xuICAgIGNvbG9yOiBpbmhlcml0O1xuICAgIHRleHQtZGVjb3JhdGlvbjogbm9uZTtcbn1cblxuQG1peGluIGlzbGFuZHMtZm9jdXMoKSB7XG4gICAgb3V0bGluZTogbm9uZTtcblxuICAgIC51dGlsaXR5Zm9jdXMgJjpmb2N1cyB7XG4gICAgICAgIG91dGxpbmU6IDJweCBzb2xpZCAjZmZkYjRkO1xuICAgIH1cbn1cblxuQG1peGluIGxpbmsoKSB7XG4gICAgQGluY2x1ZGUgaXNsYW5kcy1mb2N1cygpO1xuXG4gICAgY29sb3I6IHZhcigtLWctY29sb3ItdGV4dC1saW5rKTtcbiAgICB0ZXh0LWRlY29yYXRpb246IG5vbmU7XG4gICAgY3Vyc29yOiBwb2ludGVyO1xuXG4gICAgJjpob3ZlcixcbiAgICAmOmFjdGl2ZSB7XG4gICAgICAgIGNvbG9yOiB2YXIoLS1nLWNvbG9yLXRleHQtbGluay1ob3Zlcik7XG4gICAgfVxufVxuXG5AbWl4aW4gaGVhZGluZzEoKSB7XG4gICAgQGluY2x1ZGUgdGV4dC1zaXplKGRpc3BsYXktMyk7XG4gICAgZm9udC13ZWlnaHQ6IDUwMDtcblxuICAgIEBtZWRpYSAobWF4LXdpZHRoOiBtYXAtZ2V0KCRzY3JlZW5CcmVha3BvaW50cywgJ21kJykgLSAxKSB7XG4gICAgICAgIEBpbmNsdWRlIHRleHQtc2l6ZShkaXNwbGF5LTIpO1xuICAgIH1cbn1cblxuQG1peGluIGhlYWRpbmcyKCkge1xuICAgIEBpbmNsdWRlIHRleHQtc2l6ZShkaXNwbGF5LTEpO1xuICAgIGZvbnQtd2VpZ2h0OiA1MDA7XG59XG5cbkBtaXhpbiBoZWFkaW5nMygpIHtcbiAgICBAaW5jbHVkZSB0ZXh0LXNpemUoaGVhZGVyLTIpO1xuICAgIGZvbnQtd2VpZ2h0OiA1MDA7XG59XG5cbkBtaXhpbiBoZWFkaW5nNCgpIHtcbiAgICBAaW5jbHVkZSB0ZXh0LXNpemUoaGVhZGVyLTEpO1xuICAgIGZvbnQtd2VpZ2h0OiA1MDA7XG59XG5cbkBtaXhpbiBoZWFkaW5nNSgpIHtcbiAgICBAaW5jbHVkZSB0ZXh0LXNpemUoYm9keS0zKTtcbiAgICBmb250LXdlaWdodDogNTAwO1xufVxuXG5AbWl4aW4gaGVhZGluZzYoKSB7XG4gICAgQGluY2x1ZGUgdGV4dC1zaXplKGJvZHktMyk7XG4gICAgZm9udC13ZWlnaHQ6IDQwMDtcbn1cblxuQG1peGluIGNvbnRyaWJ1dG9ycy10ZXh0KCkge1xuICAgIGZvbnQtc2l6ZTogMTNweDtcbiAgICBmb250LXdlaWdodDogNDAwO1xuICAgIG1hcmdpbi1yaWdodDogNXB4O1xuICAgIGFsaWduLXNlbGY6IGNlbnRlcjtcbn1cblxuQG1peGluIHRleHQtYm9keS0xKCkge1xuICAgIGZvbnQtc2l6ZTogdmFyKC0tZy10ZXh0LWJvZHktMS1mb250LXNpemUpO1xuICAgIGxpbmUtaGVpZ2h0OiB2YXIoLS1nLXRleHQtYm9keS0xLWxpbmUtaGVpZ2h0KTtcbiAgICBmb250LXdlaWdodDogdmFyKC0tZy10ZXh0LWJvZHktZm9udC13ZWlnaHQpO1xufVxuXG5AbWl4aW4gZGVza3RvcC1vbmx5KCkge1xuICAgIEBtZWRpYSAobWF4LXdpZHRoOiBtYXAtZ2V0KCRzY3JlZW5CcmVha3BvaW50cywgJ21kJykgLSAxKSB7XG4gICAgICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgfVxufVxuXG5AbWl4aW4gZGVza3RvcC10YWJsZXQtb25seSgpIHtcbiAgICBAbWVkaWEgKG1heC13aWR0aDogbWFwLWdldCgkc2NyZWVuQnJlYWtwb2ludHMsICdzbScpIC0gMSkge1xuICAgICAgICBkaXNwbGF5OiBub25lO1xuICAgIH1cbn1cblxuQG1peGluIG1vYmlsZS10YWJsZXQtb25seSgpIHtcbiAgICBAbWVkaWEgKG1pbi13aWR0aDogbWFwLWdldCgkc2NyZWVuQnJlYWtwb2ludHMsICdtZCcpKSB7XG4gICAgICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgfVxufVxuXG5AbWl4aW4gbW9iaWxlLW9ubHkoKSB7XG4gICAgQG1lZGlhIChtaW4td2lkdGg6IG1hcC1nZXQoJHNjcmVlbkJyZWFrcG9pbnRzLCAnc20nKSkge1xuICAgICAgICBkaXNwbGF5OiBub25lO1xuICAgIH1cbn1cbiJdfQ== */"],
5
+ "mappings": ";AAGA,CAAA;ACKI,UAAA;AACA,WAAA;AACA,cAAA;ADFA,WAAA;AACA,eAAA;AEHJ;AFKI,CAAA;AAGI,WAAA;AACA,eAAA;AACA,mBAAA;AAEA,aAAA;AACA,cAAA;AACA,UAAA;AAEA,SAAA,IAAA;ACnBJ,aAAA,IAAA;AACA,eAAA,IAAA;ACaJ;AFSY,CAAA;AACI,eAAA;AEPhB;AFSgB,CAHJ,0BAGI,CAAA;AACI,aAAA,OAAA;AEPpB;AFWY,CAAA;AACI,aAAA;AACA,SAAA,IAAA;AEThB;AFYY,CAAA;AACI,UAAA;AACA,iBAAA;AEVhB;AFYgB,CAJJ,yBAII;AACI,cAAA,IAAA;AEVpB;AFagB,CARJ,yBAQI,CAAA;AACI,SAAA,IAAA;AACA,cAAA,IAAA;AACA,UAAA;AEXpB;AFeY,CAAA;AACI,gBAAA;AEbhB;",
6
+ "names": []
7
+ }
@@ -0,0 +1,101 @@
1
+ // src/components/Paginator/Paginator.tsx
2
+ import React from "react";
3
+ import { Button, Icon } from "@gravity-ui/uikit";
4
+ import block from "bem-cn-lite";
5
+ import ArrowRightIcon from "@gravity-ui/icons/svgs/arrow-right.svg";
6
+ import "./Paginator.css";
7
+ var b = block("Paginator");
8
+ var MOBILE_VISIBLE_PAGES = 1;
9
+ var DESKTOP_VISIBLE_PAGES = 3;
10
+ var MAX_VISIBLE_PAGES = 6;
11
+ var Paginator = ({
12
+ page = 1,
13
+ itemsPerPage = 10,
14
+ totalItems,
15
+ maxPages = Infinity,
16
+ className,
17
+ isMobile = false,
18
+ onPageChange
19
+ }) => {
20
+ const getPagesCount = () => {
21
+ const totalPages = Math.ceil(totalItems / itemsPerPage);
22
+ return Math.min(totalPages, maxPages);
23
+ };
24
+ const pagesCount = getPagesCount();
25
+ if (pagesCount <= 1) {
26
+ return null;
27
+ }
28
+ const renderPaginatorItem = ({ key, mods, content, onClick }) => {
29
+ return /* @__PURE__ */ React.createElement(
30
+ "li",
31
+ {
32
+ key: `page_${key}`,
33
+ className: b("item", mods),
34
+ onClick: onClick && onClick.bind(void 0, key)
35
+ },
36
+ content
37
+ );
38
+ };
39
+ const handlePageChange = (newPage) => {
40
+ if (onPageChange) {
41
+ onPageChange(newPage);
42
+ }
43
+ };
44
+ const handleArrowClick = (type) => {
45
+ let newPage = page;
46
+ if (type === "prev" && page > 1) {
47
+ newPage = page - 1;
48
+ } else if (type === "next" && page < pagesCount) {
49
+ newPage = page + 1;
50
+ }
51
+ if (newPage !== page) {
52
+ handlePageChange(newPage);
53
+ }
54
+ };
55
+ const handlePageClick = (index) => {
56
+ if (index !== page) {
57
+ handlePageChange(index);
58
+ }
59
+ };
60
+ const getPageConfigs = () => {
61
+ const visiblePages = isMobile ? MOBILE_VISIBLE_PAGES : DESKTOP_VISIBLE_PAGES;
62
+ const pages2 = [];
63
+ for (let i = 1; i <= pagesCount; i++) {
64
+ if (pagesCount <= MAX_VISIBLE_PAGES || i <= visiblePages || i > pagesCount - visiblePages || i >= page - 1 && i <= page + 1) {
65
+ pages2.push({
66
+ key: i,
67
+ mods: { type: "page", active: page === i },
68
+ onClick: handlePageClick,
69
+ content: i
70
+ });
71
+ } else if (pages2.length > 0 && pages2[pages2.length - 1].key !== "dots") {
72
+ pages2.push({
73
+ key: "dots",
74
+ mods: { type: "dots" },
75
+ content: "..."
76
+ });
77
+ }
78
+ }
79
+ return pages2;
80
+ };
81
+ const arrowButton = (disable) => /* @__PURE__ */ React.createElement(Button, { className: b("icon"), size: "s", view: "flat", disabled: disable }, /* @__PURE__ */ React.createElement(Icon, { data: ArrowRightIcon, size: 16 }));
82
+ const pages = getPageConfigs();
83
+ pages.unshift({
84
+ key: "prev" /* Prev */,
85
+ mods: { type: "prev" },
86
+ onClick: handleArrowClick,
87
+ content: arrowButton(page === 1)
88
+ });
89
+ pages.push({
90
+ key: "next" /* Next */,
91
+ mods: { type: "next" },
92
+ onClick: handleArrowClick,
93
+ content: arrowButton(page === pagesCount)
94
+ });
95
+ return /* @__PURE__ */ React.createElement("ul", { className: b(null, className) }, pages.map(renderPaginatorItem));
96
+ };
97
+ var Paginator_default = Paginator;
98
+ export {
99
+ Paginator_default as default
100
+ };
101
+ //# sourceMappingURL=Paginator.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../src/components/Paginator/Paginator.tsx"],
4
+ "sourcesContent": ["import React, {ReactNode} from 'react';\n\nimport {Button, Icon} from '@gravity-ui/uikit';\nimport block from 'bem-cn-lite';\n\nimport ArrowRightIcon from '@gravity-ui/icons/svgs/arrow-right.svg';\n\nimport './Paginator.scss';\n\nconst b = block('Paginator');\n\nconst MOBILE_VISIBLE_PAGES = 1;\nconst DESKTOP_VISIBLE_PAGES = 3;\nconst MAX_VISIBLE_PAGES = 6;\n\nexport interface PaginatorDefaultProps {\n page: number;\n maxPages?: number;\n onPageChange: (page: number) => void;\n}\n\nexport interface PaginatorExtraProps {\n className?: string;\n isMobile?: boolean;\n}\n\nexport interface Test {\n aaa: never;\n}\n\nexport interface TotalCountItems {\n totalItems: number;\n itemsPerPage?: number;\n}\n\nexport type PaginatorProps = PaginatorDefaultProps & TotalCountItems;\n\nexport type PaginatorInnerProps = PaginatorExtraProps & PaginatorProps;\n\ninterface Modifications {\n [name: string]: string | boolean | undefined;\n}\n\ninterface PaginatorItemProps<T> {\n key: T;\n mods: Modifications;\n content: ReactNode;\n onClick?: (key: T) => void;\n}\n\nenum ArrowType {\n Prev = 'prev',\n Next = 'next',\n}\n\nconst Paginator = ({\n page = 1,\n itemsPerPage = 10,\n totalItems,\n maxPages = Infinity,\n className,\n isMobile = false,\n onPageChange,\n}: PaginatorInnerProps) => {\n const getPagesCount = () => {\n const totalPages = Math.ceil(totalItems / itemsPerPage);\n\n return Math.min(totalPages, maxPages);\n };\n\n const pagesCount = getPagesCount();\n\n if (pagesCount <= 1) {\n return null;\n }\n\n const renderPaginatorItem = <T,>({key, mods, content, onClick}: PaginatorItemProps<T>) => {\n return (\n <li\n key={`page_${key}`}\n className={b('item', mods)}\n onClick={onClick && onClick.bind(this, key)}\n >\n {content}\n </li>\n );\n };\n\n const handlePageChange = (newPage: number) => {\n if (onPageChange) {\n onPageChange(newPage);\n }\n };\n\n const handleArrowClick = (type: string) => {\n let newPage = page;\n if (type === 'prev' && page > 1) {\n newPage = page - 1;\n } else if (type === 'next' && page < pagesCount) {\n newPage = page + 1;\n }\n if (newPage !== page) {\n handlePageChange(newPage);\n }\n };\n\n const handlePageClick = (index: number) => {\n if (index !== page) {\n handlePageChange(index);\n }\n };\n\n const getPageConfigs = () => {\n const visiblePages = isMobile ? MOBILE_VISIBLE_PAGES : DESKTOP_VISIBLE_PAGES;\n\n const pages = [];\n\n for (let i = 1; i <= pagesCount; i++) {\n if (\n pagesCount <= MAX_VISIBLE_PAGES ||\n i <= visiblePages ||\n i > pagesCount - visiblePages ||\n (i >= page - 1 && i <= page + 1)\n ) {\n pages.push({\n key: i,\n mods: {type: 'page', active: page === i},\n onClick: handlePageClick,\n content: i,\n });\n } else if (pages.length > 0 && pages[pages.length - 1].key !== 'dots') {\n pages.push({\n key: 'dots',\n mods: {type: 'dots'},\n content: '...',\n });\n }\n }\n\n return pages;\n };\n\n const arrowButton = (disable: boolean) => (\n <Button className={b('icon')} size=\"s\" view={'flat'} disabled={disable}>\n <Icon data={ArrowRightIcon} size={16} />\n </Button>\n );\n\n const pages = getPageConfigs() as PaginatorItemProps<string>[];\n\n pages.unshift({\n key: ArrowType.Prev,\n mods: {type: 'prev'},\n onClick: handleArrowClick,\n content: arrowButton(page === 1),\n });\n\n pages.push({\n key: ArrowType.Next,\n mods: {type: 'next'},\n onClick: handleArrowClick,\n content: arrowButton(page === pagesCount),\n });\n\n return <ul className={b(null, className)}>{pages.map(renderPaginatorItem)}</ul>;\n};\n\nexport default Paginator;\n"],
5
+ "mappings": "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",
6
+ "names": ["pages"]
7
+ }
@@ -0,0 +1,7 @@
1
+ // src/components/Paginator/index.ts
2
+ import { default as default2 } from "./Paginator";
3
+ export * from "./Paginator";
4
+ export {
5
+ default2 as Paginator
6
+ };
7
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../src/components/Paginator/index.ts"],
4
+ "sourcesContent": ["export {default as Paginator} from './Paginator';\nexport * from './Paginator';\n"],
5
+ "mappings": ";AAAA,SAAmB,WAAXA,gBAA2B;AACnC,cAAc;",
6
+ "names": ["default"]
7
+ }
@@ -0,0 +1,228 @@
1
+ // src/components/Scrollspy/Scrollspy.tsx
2
+ import React from "react";
3
+ import { debounce, isEqual } from "lodash";
4
+ import scrollIntoView from "scroll-into-view-if-needed";
5
+ var Scrollspy = class extends React.Component {
6
+ static defaultProps = {
7
+ currentClassName: "Scrollspy",
8
+ sectionOffset: 20,
9
+ headerHeight: 0
10
+ };
11
+ containerRef = React.createRef();
12
+ itemRefs = this.props.items.map(() => React.createRef());
13
+ scrollByClick;
14
+ firstItemIndexInView;
15
+ lastItemIndexInView;
16
+ constructor(props) {
17
+ super(props);
18
+ this.state = {
19
+ targetItems: [],
20
+ inViewState: []
21
+ };
22
+ this.scrollByClick = false;
23
+ this.firstItemIndexInView = -1;
24
+ this.lastItemIndexInView = -1;
25
+ }
26
+ componentDidMount() {
27
+ this.initItems();
28
+ window.addEventListener("scroll", this.handleScroll);
29
+ const containerEl = this.containerRef.current;
30
+ if (containerEl) {
31
+ containerEl.addEventListener("scroll", this.updateScrollValues);
32
+ }
33
+ }
34
+ componentDidUpdate(prevProps, prevState) {
35
+ const { items, router } = this.props;
36
+ const { inViewState } = this.state;
37
+ if (!isEqual(inViewState, prevState.inViewState)) {
38
+ this.scrollToListItem();
39
+ }
40
+ if (!isEqual(items, prevProps.items) || prevProps.router.pathname !== router.pathname) {
41
+ this.initItems();
42
+ }
43
+ if (router.hash !== prevProps.router.hash) {
44
+ this.pauseScrollHandler();
45
+ this.saveActiveItems(router.hash);
46
+ }
47
+ }
48
+ componentWillUnmount() {
49
+ window.removeEventListener("scroll", this.handleScroll);
50
+ const containerEl = this.containerRef.current;
51
+ if (containerEl) {
52
+ containerEl.removeEventListener("scroll", this.updateScrollValues);
53
+ }
54
+ }
55
+ render() {
56
+ const { children, currentClassName, className } = this.props;
57
+ const { inViewState } = this.state;
58
+ const items = children.map((child, index) => {
59
+ if (!child) {
60
+ return null;
61
+ }
62
+ const ChildTag = child.type;
63
+ let childClassNames = child.props.className;
64
+ if (inViewState[index] && currentClassName.length > 0) {
65
+ childClassNames += ` ${currentClassName}`;
66
+ this.syncScroll(index);
67
+ }
68
+ return /* @__PURE__ */ React.createElement(
69
+ ChildTag,
70
+ {
71
+ key: child.key,
72
+ className: childClassNames,
73
+ onClick: this.handleSectionClick,
74
+ ref: this.itemRefs[index]
75
+ },
76
+ child.props.children
77
+ );
78
+ });
79
+ return /* @__PURE__ */ React.createElement("ul", { className, ref: this.containerRef }, items);
80
+ }
81
+ updateFirstItemIndexInView(maxItemsInView) {
82
+ this.firstItemIndexInView = Math.max(this.lastItemIndexInView - (maxItemsInView - 1), 0);
83
+ }
84
+ getContainerValues(containerEl) {
85
+ const { children } = this.props;
86
+ const childHeight = Math.round(containerEl.scrollHeight / children.length);
87
+ const maxItemsInView = Math.round(containerEl.clientHeight / childHeight);
88
+ return { childHeight, maxItemsInView };
89
+ }
90
+ updateScrollValues = () => {
91
+ const containerEl = this.containerRef.current;
92
+ if (!containerEl) {
93
+ return;
94
+ }
95
+ const { childHeight, maxItemsInView } = this.getContainerValues(containerEl);
96
+ this.lastItemIndexInView = Math.round(containerEl.scrollTop / childHeight) + maxItemsInView - 1;
97
+ this.updateFirstItemIndexInView(maxItemsInView);
98
+ };
99
+ syncScroll(index) {
100
+ const { children } = this.props;
101
+ const containerEl = this.containerRef.current;
102
+ if (!containerEl) {
103
+ return;
104
+ }
105
+ const { childHeight, maxItemsInView } = this.getContainerValues(containerEl);
106
+ if (this.lastItemIndexInView === -1) {
107
+ this.lastItemIndexInView = maxItemsInView - 1;
108
+ }
109
+ this.updateFirstItemIndexInView(maxItemsInView);
110
+ let itemInView = false;
111
+ if (index >= this.lastItemIndexInView) {
112
+ this.lastItemIndexInView = Math.min(index + 1, children.length - 1);
113
+ } else if (index <= this.firstItemIndexInView) {
114
+ this.lastItemIndexInView = Math.max(index + maxItemsInView - 2, maxItemsInView - 1);
115
+ } else {
116
+ itemInView = true;
117
+ }
118
+ this.updateFirstItemIndexInView(maxItemsInView);
119
+ const endIsNear = index + maxItemsInView / 2 > children.length;
120
+ if (itemInView) {
121
+ return;
122
+ } else if (endIsNear) {
123
+ containerEl.scrollTop = containerEl.scrollHeight;
124
+ } else {
125
+ containerEl.scrollTop = childHeight * this.firstItemIndexInView;
126
+ }
127
+ }
128
+ scrollToListItem = () => {
129
+ if (!this.props.scrollToListItem) {
130
+ return;
131
+ }
132
+ let itemIndex = this.state.inViewState.findIndex((isActive) => isActive);
133
+ if (itemIndex < 0) {
134
+ itemIndex = 0;
135
+ }
136
+ const ref = this.itemRefs[itemIndex] && this.itemRefs[itemIndex].current;
137
+ if (ref) {
138
+ scrollIntoView(ref, {
139
+ scrollMode: "if-needed",
140
+ block: "nearest",
141
+ inline: "nearest",
142
+ behavior: "smooth"
143
+ });
144
+ }
145
+ };
146
+ initItems() {
147
+ const { items } = this.props;
148
+ const targetItems = items.map((item) => document.getElementById(item.slice(1))).filter(Boolean);
149
+ this.setState({ targetItems }, this.initSections);
150
+ this.scrollToListItem();
151
+ }
152
+ initSections = () => {
153
+ this.saveActiveItems();
154
+ };
155
+ saveActiveItems(hash) {
156
+ const visibleItems = this.getViewState(hash);
157
+ this.setState({ inViewState: visibleItems });
158
+ }
159
+ getViewState(hash) {
160
+ const { targetItems, inViewState } = this.state;
161
+ const { headerHeight } = this.props;
162
+ const currentOffset = window.pageYOffset;
163
+ const visibleItemOffset = [];
164
+ let isOneActive = false;
165
+ const pureHash = hash && hash.startsWith("#") ? hash.substring(1) : hash;
166
+ targetItems.forEach((item, index) => {
167
+ if (!item) {
168
+ return;
169
+ }
170
+ const offsetTop = item.getBoundingClientRect().top;
171
+ const isVisibleItem = offsetTop < headerHeight + 1;
172
+ if (pureHash) {
173
+ if (pureHash === item.getAttribute("id")) {
174
+ visibleItemOffset.push(true);
175
+ isOneActive = true;
176
+ } else {
177
+ visibleItemOffset.push(false);
178
+ }
179
+ } else if (isVisibleItem) {
180
+ if (visibleItemOffset[index - 1]) {
181
+ visibleItemOffset[index - 1] = false;
182
+ }
183
+ visibleItemOffset.push(true);
184
+ isOneActive = true;
185
+ } else {
186
+ visibleItemOffset.push(false);
187
+ }
188
+ });
189
+ if (targetItems && targetItems.length && !isOneActive) {
190
+ if (currentOffset < targetItems[0].getBoundingClientRect().top) {
191
+ visibleItemOffset[0] = true;
192
+ isOneActive = true;
193
+ }
194
+ }
195
+ return isOneActive ? visibleItemOffset : inViewState;
196
+ }
197
+ handleScroll = () => {
198
+ if (this.scrollByClick) {
199
+ window.removeEventListener("scroll", this.handleScrollDebounced);
200
+ window.addEventListener("scroll", this.handleScroll);
201
+ this.scrollByClick = false;
202
+ }
203
+ this.saveActiveItems();
204
+ };
205
+ // eslint-disable-next-line @typescript-eslint/member-ordering, react/sort-comp
206
+ handleScrollDebounced = debounce(this.handleScroll, 100);
207
+ pauseScrollHandler() {
208
+ this.scrollByClick = true;
209
+ window.removeEventListener("scroll", this.handleScroll);
210
+ window.addEventListener("scroll", this.handleScrollDebounced);
211
+ }
212
+ handleSectionClick = (event) => {
213
+ const { onSectionClick } = this.props;
214
+ const { target } = event;
215
+ if (target && target.tagName === "A") {
216
+ event.stopPropagation();
217
+ this.pauseScrollHandler();
218
+ this.saveActiveItems(target.hash);
219
+ if (onSectionClick) {
220
+ onSectionClick(event);
221
+ }
222
+ }
223
+ };
224
+ };
225
+ export {
226
+ Scrollspy
227
+ };
228
+ //# sourceMappingURL=Scrollspy.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../src/components/Scrollspy/Scrollspy.tsx"],
4
+ "sourcesContent": ["import React, {ReactElement} from 'react';\n\nimport {debounce, isEqual} from 'lodash';\nimport scrollIntoView from 'scroll-into-view-if-needed';\n\nimport {Router} from '../../models';\nimport {InnerProps} from '../../utils';\n\ninterface ScrollspyDefaultProps {\n currentClassName: string;\n sectionOffset: number;\n headerHeight: number;\n}\n\nexport interface ScrollspyProps extends Partial<ScrollspyDefaultProps> {\n items: string[];\n children: ReactElement[];\n router: Router;\n onSectionClick?: (event: MouseEvent) => void;\n className?: string;\n scrollToListItem?: boolean;\n}\n\ninterface ScrollspyState {\n targetItems: HTMLElement[];\n inViewState: boolean[];\n}\n\ntype ScrollspyInnerProps = InnerProps<ScrollspyProps, ScrollspyDefaultProps>;\n\nexport class Scrollspy extends React.Component<ScrollspyInnerProps, ScrollspyState> {\n static defaultProps: ScrollspyDefaultProps = {\n currentClassName: 'Scrollspy',\n sectionOffset: 20,\n headerHeight: 0,\n };\n\n containerRef = React.createRef<HTMLUListElement>();\n itemRefs = this.props.items.map(() => React.createRef<HTMLDivElement>());\n\n scrollByClick: boolean;\n firstItemIndexInView: number;\n lastItemIndexInView: number;\n\n constructor(props: ScrollspyInnerProps) {\n super(props);\n\n this.state = {\n targetItems: [],\n inViewState: [],\n };\n\n this.scrollByClick = false;\n this.firstItemIndexInView = -1;\n this.lastItemIndexInView = -1;\n }\n\n componentDidMount() {\n this.initItems();\n window.addEventListener('scroll', this.handleScroll);\n\n const containerEl = this.containerRef.current;\n if (containerEl) {\n containerEl.addEventListener('scroll', this.updateScrollValues);\n }\n }\n\n componentDidUpdate(prevProps: Readonly<ScrollspyProps>, prevState: Readonly<ScrollspyState>) {\n const {items, router} = this.props;\n const {inViewState} = this.state;\n\n if (!isEqual(inViewState, prevState.inViewState)) {\n this.scrollToListItem();\n }\n\n if (!isEqual(items, prevProps.items) || prevProps.router.pathname !== router.pathname) {\n this.initItems();\n }\n\n if (router.hash !== prevProps.router.hash) {\n this.pauseScrollHandler();\n this.saveActiveItems(router.hash);\n }\n }\n\n componentWillUnmount() {\n window.removeEventListener('scroll', this.handleScroll);\n\n const containerEl = this.containerRef.current;\n if (containerEl) {\n containerEl.removeEventListener('scroll', this.updateScrollValues);\n }\n }\n\n render() {\n const {children, currentClassName, className} = this.props;\n const {inViewState} = this.state;\n\n const items = children.map((child, index) => {\n if (!child) {\n return null;\n }\n\n const ChildTag = child.type;\n let childClassNames = child.props.className;\n\n if (inViewState[index] && currentClassName.length > 0) {\n childClassNames += ` ${currentClassName}`;\n\n this.syncScroll(index);\n }\n\n return (\n <ChildTag\n key={child.key}\n className={childClassNames}\n onClick={this.handleSectionClick}\n ref={this.itemRefs[index]}\n >\n {child.props.children}\n </ChildTag>\n );\n });\n\n return (\n <ul className={className} ref={this.containerRef}>\n {items}\n </ul>\n );\n }\n\n private updateFirstItemIndexInView(maxItemsInView: number) {\n this.firstItemIndexInView = Math.max(this.lastItemIndexInView - (maxItemsInView - 1), 0);\n }\n\n private getContainerValues(containerEl: HTMLUListElement) {\n const {children} = this.props;\n\n /* Average values */\n const childHeight = Math.round(containerEl.scrollHeight / children.length);\n const maxItemsInView = Math.round(containerEl.clientHeight / childHeight);\n\n return {childHeight, maxItemsInView};\n }\n\n private updateScrollValues = () => {\n const containerEl = this.containerRef.current;\n\n if (!containerEl) {\n return;\n }\n\n const {childHeight, maxItemsInView} = this.getContainerValues(containerEl);\n this.lastItemIndexInView =\n Math.round(containerEl.scrollTop / childHeight) + maxItemsInView - 1;\n\n this.updateFirstItemIndexInView(maxItemsInView);\n };\n\n private syncScroll(index: number) {\n const {children} = this.props;\n const containerEl = this.containerRef.current;\n\n if (!containerEl) {\n return;\n }\n\n const {childHeight, maxItemsInView} = this.getContainerValues(containerEl);\n\n if (this.lastItemIndexInView === -1) {\n this.lastItemIndexInView = maxItemsInView - 1;\n }\n\n this.updateFirstItemIndexInView(maxItemsInView);\n\n let itemInView = false;\n if (index >= this.lastItemIndexInView) {\n this.lastItemIndexInView = Math.min(index + 1, children.length - 1);\n } else if (index <= this.firstItemIndexInView) {\n this.lastItemIndexInView = Math.max(index + maxItemsInView - 2, maxItemsInView - 1);\n } else {\n itemInView = true;\n }\n\n this.updateFirstItemIndexInView(maxItemsInView);\n\n const endIsNear = index + maxItemsInView / 2 > children.length;\n if (itemInView) {\n return;\n } else if (endIsNear) {\n containerEl.scrollTop = containerEl.scrollHeight;\n } else {\n containerEl.scrollTop = childHeight * this.firstItemIndexInView;\n }\n }\n\n private scrollToListItem = () => {\n if (!this.props.scrollToListItem) {\n return;\n }\n\n let itemIndex = this.state.inViewState.findIndex((isActive) => isActive);\n\n if (itemIndex < 0) {\n itemIndex = 0;\n }\n\n const ref = this.itemRefs[itemIndex] && this.itemRefs[itemIndex].current;\n\n if (ref) {\n scrollIntoView(ref, {\n scrollMode: 'if-needed',\n block: 'nearest',\n inline: 'nearest',\n behavior: 'smooth',\n });\n }\n };\n\n private initItems() {\n const {items} = this.props;\n const targetItems = items\n .map((item) => document.getElementById(item.slice(1)))\n .filter(Boolean) as HTMLElement[];\n\n this.setState({targetItems}, this.initSections);\n this.scrollToListItem();\n }\n\n private initSections = () => {\n this.saveActiveItems();\n };\n\n private saveActiveItems(hash?: string) {\n const visibleItems = this.getViewState(hash);\n\n this.setState({inViewState: visibleItems});\n }\n\n private getViewState(hash?: string) {\n const {targetItems, inViewState} = this.state;\n const {headerHeight} = this.props;\n const currentOffset = window.pageYOffset;\n const visibleItemOffset: boolean[] = [];\n let isOneActive = false;\n\n const pureHash = hash && hash.startsWith('#') ? hash.substring(1) : hash;\n\n targetItems.forEach((item, index) => {\n if (!item) {\n return;\n }\n\n const offsetTop = item.getBoundingClientRect().top;\n const isVisibleItem = offsetTop < headerHeight + 1;\n\n if (pureHash) {\n if (pureHash === item.getAttribute('id')) {\n visibleItemOffset.push(true);\n isOneActive = true;\n } else {\n visibleItemOffset.push(false);\n }\n } else if (isVisibleItem) {\n if (visibleItemOffset[index - 1]) {\n visibleItemOffset[index - 1] = false;\n }\n\n visibleItemOffset.push(true);\n isOneActive = true;\n } else {\n visibleItemOffset.push(false);\n }\n });\n\n if (targetItems && targetItems.length && !isOneActive) {\n if (currentOffset < targetItems[0].getBoundingClientRect().top) {\n visibleItemOffset[0] = true;\n isOneActive = true;\n }\n }\n\n return isOneActive ? visibleItemOffset : inViewState;\n }\n\n private handleScroll = () => {\n if (this.scrollByClick) {\n // the end of smooth auto-scroll\n window.removeEventListener('scroll', this.handleScrollDebounced);\n window.addEventListener('scroll', this.handleScroll);\n this.scrollByClick = false;\n }\n this.saveActiveItems();\n };\n\n // eslint-disable-next-line @typescript-eslint/member-ordering, react/sort-comp\n private handleScrollDebounced = debounce(this.handleScroll, 100);\n\n private pauseScrollHandler() {\n // wait for the end of smooth auto-scroll\n this.scrollByClick = true;\n window.removeEventListener('scroll', this.handleScroll);\n window.addEventListener('scroll', this.handleScrollDebounced);\n }\n\n private handleSectionClick = (event: MouseEvent) => {\n const {onSectionClick} = this.props;\n const {target} = event;\n\n if (target && (target as HTMLElement).tagName === 'A') {\n event.stopPropagation();\n this.pauseScrollHandler();\n this.saveActiveItems((target as HTMLAnchorElement).hash);\n\n if (onSectionClick) {\n onSectionClick(event);\n }\n }\n };\n}\n"],
5
+ "mappings": "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",
6
+ "names": []
7
+ }
@@ -0,0 +1,3 @@
1
+ // src/components/Scrollspy/index.ts
2
+ export * from "./Scrollspy";
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../src/components/Scrollspy/index.ts"],
4
+ "sourcesContent": ["export * from './Scrollspy';\n"],
5
+ "mappings": ";AAAA,cAAc;",
6
+ "names": []
7
+ }
@@ -0,0 +1,59 @@
1
+ /* src/components/SearchBar/SearchBar.scss */
2
+ .dc-search-bar {
3
+ width: 100%;
4
+ height: 100%;
5
+ border-radius: 5px;
6
+ box-sizing: border-box;
7
+ box-shadow: 0px 3px 10px var(--g-color-base-generic-accent);
8
+ padding: 11px;
9
+ display: flex;
10
+ align-items: center;
11
+ justify-content: space-between;
12
+ font-size: var(--g-text-body-short-font-size);
13
+ line-height: var(--g-text-body-short-line-height);
14
+ }
15
+ .dc-search-bar__search-query-label {
16
+ color: var(--g-color-text-secondary);
17
+ white-space: nowrap;
18
+ text-overflow: ellipsis;
19
+ overflow: hidden;
20
+ }
21
+ @media (max-width: 770px) {
22
+ .dc-search-bar__search-query-label {
23
+ display: none;
24
+ }
25
+ }
26
+ .dc-search-bar__search-query {
27
+ max-width: 400px;
28
+ white-space: nowrap;
29
+ text-overflow: ellipsis;
30
+ overflow: hidden;
31
+ }
32
+ @media (max-width: 770px) {
33
+ .dc-search-bar__search-query {
34
+ display: none;
35
+ }
36
+ }
37
+ .dc-search-bar__left {
38
+ width: 90%;
39
+ display: flex;
40
+ align-items: center;
41
+ }
42
+ .dc-search-bar__navigation {
43
+ display: flex;
44
+ align-items: center;
45
+ margin-right: 11px;
46
+ }
47
+ .dc-search-bar__next-arrow {
48
+ transform: rotate(-180deg);
49
+ }
50
+ .dc-search-bar__counter {
51
+ margin: 0 4px;
52
+ }
53
+ .dc-search-highlighted {
54
+ background: var(--dc-text-highlight);
55
+ }
56
+ .dc-search-highlighted_selected {
57
+ background: var(--dc-text-highlight-selected);
58
+ }
59
+ /*# sourceMappingURL=SearchBar.css.map */
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../src/components/SearchBar/Users/3y3k0/doctools/docs-components/src/components/SearchBar/SearchBar.scss", "../../../../src/components/SearchBar/%3Cinput%20css%20YSUvwV%3E"],
4
+ "sourcesContent": ["@import '../../styles/variables';\n@import '../../styles/mixins';\n\n.dc-search-bar {\n width: 100%;\n height: 100%;\n border-radius: 5px;\n box-sizing: border-box;\n box-shadow: 0px 3px 10px var(--g-color-base-generic-accent);\n padding: 11px;\n display: flex;\n align-items: center;\n justify-content: space-between;\n\n font-size: var(--g-text-body-short-font-size);\n line-height: var(--g-text-body-short-line-height);\n\n &__search-query-label {\n color: var(--g-color-text-secondary);\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden;\n\n @media (max-width: map-get($screenBreakpoints, 'md') + 1) {\n display: none;\n }\n }\n\n &__search-query {\n max-width: 400px;\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden;\n\n @media (max-width: map-get($screenBreakpoints, 'md') + 1) {\n display: none;\n }\n }\n\n &__left {\n width: 90%;\n display: flex;\n align-items: center;\n }\n\n &__navigation {\n display: flex;\n align-items: center;\n margin-right: 11px;\n }\n\n &__next-arrow {\n transform: rotate(-180deg);\n }\n\n &__counter {\n margin: 0 4px;\n }\n}\n\n$hl-class: '.dc-search-highlighted';\n\n#{$hl-class} {\n background: var(--dc-text-highlight);\n\n &_selected {\n background: var(--dc-text-highlight-selected);\n }\n}\n", ".dc-search-bar {\n width: 100%;\n height: 100%;\n border-radius: 5px;\n box-sizing: border-box;\n box-shadow: 0px 3px 10px var(--g-color-base-generic-accent);\n padding: 11px;\n display: flex;\n align-items: center;\n justify-content: space-between;\n font-size: var(--g-text-body-short-font-size);\n line-height: var(--g-text-body-short-line-height);\n}\n.dc-search-bar__search-query-label {\n color: var(--g-color-text-secondary);\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden;\n}\n@media (max-width: 770px) {\n .dc-search-bar__search-query-label {\n display: none;\n }\n}\n.dc-search-bar__search-query {\n max-width: 400px;\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden;\n}\n@media (max-width: 770px) {\n .dc-search-bar__search-query {\n display: none;\n }\n}\n.dc-search-bar__left {\n width: 90%;\n display: flex;\n align-items: center;\n}\n.dc-search-bar__navigation {\n display: flex;\n align-items: center;\n margin-right: 11px;\n}\n.dc-search-bar__next-arrow {\n transform: rotate(-180deg);\n}\n.dc-search-bar__counter {\n margin: 0 4px;\n}\n\n.dc-search-highlighted {\n background: var(--dc-text-highlight);\n}\n.dc-search-highlighted_selected {\n background: var(--dc-text-highlight-selected);\n}\n/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VSb290IjoiL1VzZXJzLzN5M2swL2RvY3Rvb2xzL2RvY3MtY29tcG9uZW50cy9zcmMvY29tcG9uZW50cy9TZWFyY2hCYXIiLCJzb3VyY2VzIjpbIlNlYXJjaEJhci5zY3NzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUdBO0VBQ0k7RUFDQTtFQUNBO0VBQ0E7RUFDQTtFQUNBO0VBQ0E7RUFDQTtFQUNBO0VBRUE7RUFDQTs7QUFFQTtFQUNJO0VBQ0E7RUFDQTtFQUNBOztBQUVBO0VBTko7SUFPUTs7O0FBSVI7RUFDSTtFQUNBO0VBQ0E7RUFDQTs7QUFFQTtFQU5KO0lBT1E7OztBQUlSO0VBQ0k7RUFDQTtFQUNBOztBQUdKO0VBQ0k7RUFDQTtFQUNBOztBQUdKO0VBQ0k7O0FBR0o7RUFDSTs7O0FBTVI7RUFDSTs7QUFFQTtFQUNJIiwic291cmNlc0NvbnRlbnQiOlsiQGltcG9ydCAnLi4vLi4vc3R5bGVzL3ZhcmlhYmxlcyc7XG5AaW1wb3J0ICcuLi8uLi9zdHlsZXMvbWl4aW5zJztcblxuLmRjLXNlYXJjaC1iYXIge1xuICAgIHdpZHRoOiAxMDAlO1xuICAgIGhlaWdodDogMTAwJTtcbiAgICBib3JkZXItcmFkaXVzOiA1cHg7XG4gICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgICBib3gtc2hhZG93OiAwcHggM3B4IDEwcHggdmFyKC0tZy1jb2xvci1iYXNlLWdlbmVyaWMtYWNjZW50KTtcbiAgICBwYWRkaW5nOiAxMXB4O1xuICAgIGRpc3BsYXk6IGZsZXg7XG4gICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG5cbiAgICBmb250LXNpemU6IHZhcigtLWctdGV4dC1ib2R5LXNob3J0LWZvbnQtc2l6ZSk7XG4gICAgbGluZS1oZWlnaHQ6IHZhcigtLWctdGV4dC1ib2R5LXNob3J0LWxpbmUtaGVpZ2h0KTtcblxuICAgICZfX3NlYXJjaC1xdWVyeS1sYWJlbCB7XG4gICAgICAgIGNvbG9yOiB2YXIoLS1nLWNvbG9yLXRleHQtc2Vjb25kYXJ5KTtcbiAgICAgICAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbiAgICAgICAgdGV4dC1vdmVyZmxvdzogZWxsaXBzaXM7XG4gICAgICAgIG92ZXJmbG93OiBoaWRkZW47XG5cbiAgICAgICAgQG1lZGlhIChtYXgtd2lkdGg6IG1hcC1nZXQoJHNjcmVlbkJyZWFrcG9pbnRzLCAnbWQnKSArIDEpIHtcbiAgICAgICAgICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICAmX19zZWFyY2gtcXVlcnkge1xuICAgICAgICBtYXgtd2lkdGg6IDQwMHB4O1xuICAgICAgICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICAgICAgICB0ZXh0LW92ZXJmbG93OiBlbGxpcHNpcztcbiAgICAgICAgb3ZlcmZsb3c6IGhpZGRlbjtcblxuICAgICAgICBAbWVkaWEgKG1heC13aWR0aDogbWFwLWdldCgkc2NyZWVuQnJlYWtwb2ludHMsICdtZCcpICsgMSkge1xuICAgICAgICAgICAgZGlzcGxheTogbm9uZTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgICZfX2xlZnQge1xuICAgICAgICB3aWR0aDogOTAlO1xuICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgIH1cblxuICAgICZfX25hdmlnYXRpb24ge1xuICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgICBtYXJnaW4tcmlnaHQ6IDExcHg7XG4gICAgfVxuXG4gICAgJl9fbmV4dC1hcnJvdyB7XG4gICAgICAgIHRyYW5zZm9ybTogcm90YXRlKC0xODBkZWcpO1xuICAgIH1cblxuICAgICZfX2NvdW50ZXIge1xuICAgICAgICBtYXJnaW46IDAgNHB4O1xuICAgIH1cbn1cblxuJGhsLWNsYXNzOiAnLmRjLXNlYXJjaC1oaWdobGlnaHRlZCc7XG5cbiN7JGhsLWNsYXNzfSB7XG4gICAgYmFja2dyb3VuZDogdmFyKC0tZGMtdGV4dC1oaWdobGlnaHQpO1xuXG4gICAgJl9zZWxlY3RlZCB7XG4gICAgICAgIGJhY2tncm91bmQ6IHZhcigtLWRjLXRleHQtaGlnaGxpZ2h0LXNlbGVjdGVkKTtcbiAgICB9XG59XG4iXX0= */"],
5
+ "mappings": ";AAGA,CAAA;AACI,SAAA;AACA,UAAA;AACA,iBAAA;AACA,cAAA;AACA,cAAA,IAAA,IAAA,KAAA,IAAA;AACA,WAAA;AACA,WAAA;AACA,eAAA;AACA,mBAAA;AAEA,aAAA,IAAA;AACA,eAAA,IAAA;ACHJ;ADKI,CAAA;AACI,SAAA,IAAA;AACA,eAAA;AACA,iBAAA;AACA,YAAA;ACHR;ADKQ,OAAA,CAAA,SAAA,EAAA;AANJ,GAAA;AAOQ,aAAA;ACFV;AACF;ADKI,CAAA;AACI,aAAA;AACA,eAAA;AACA,iBAAA;AACA,YAAA;ACHR;ADKQ,OAAA,CAAA,SAAA,EAAA;AANJ,GAAA;AAOQ,aAAA;ACFV;AACF;ADKI,CAAA;AACI,SAAA;AACA,WAAA;AACA,eAAA;ACHR;ADMI,CAAA;AACI,WAAA;AACA,eAAA;AACA,gBAAA;ACJR;ADOI,CAAA;AACI,aAAA,OAAA;ACLR;ADQI,CAAA;AACI,UAAA,EAAA;ACNR;ADYA,CAAA;AACI,cAAA,IAAA;ACTJ;ADWI,CAAA;AACI,cAAA,IAAA;ACTR;",
6
+ "names": []
7
+ }
@@ -0,0 +1,57 @@
1
+ // src/components/SearchBar/SearchBar.tsx
2
+ import React, { memo } from "react";
3
+ import { Icon } from "@gravity-ui/uikit";
4
+ import block from "bem-cn-lite";
5
+ import { useHotkeys } from "react-hotkeys-hook";
6
+ import { useTranslation } from "../../hooks";
7
+ import { Control } from "../Control";
8
+ import ArrowLeftIcon from "@gravity-ui/icons/svgs/chevron-left.svg";
9
+ import CloseIcon from "@gravity-ui/icons/svgs/xmark.svg";
10
+ import "./SearchBar.css";
11
+ var b = block("dc-search-bar");
12
+ var noop = () => {
13
+ };
14
+ var SearchBar = memo((props) => {
15
+ const { t } = useTranslation("search-bar");
16
+ const {
17
+ searchQuery,
18
+ searchCurrentIndex,
19
+ searchCountResults,
20
+ onClickPrevSearch = noop,
21
+ onClickNextSearch = noop,
22
+ onCloseSearchBar = noop
23
+ } = props;
24
+ const hotkeysOptions = { filterPreventDefault: true };
25
+ const hotkeysPrev = "\u21E7+enter";
26
+ const hotkeysNext = "enter";
27
+ useHotkeys(hotkeysPrev, onClickPrevSearch, hotkeysOptions, [onClickPrevSearch]);
28
+ useHotkeys(hotkeysNext, onClickNextSearch, hotkeysOptions, [onClickNextSearch]);
29
+ return /* @__PURE__ */ React.createElement("div", { className: b() }, /* @__PURE__ */ React.createElement("div", { className: b("left") }, /* @__PURE__ */ React.createElement("div", { className: b("navigation") }, /* @__PURE__ */ React.createElement(
30
+ Control,
31
+ {
32
+ onClick: onClickPrevSearch,
33
+ tooltipText: `${t("prev")} (${hotkeysPrev})`,
34
+ icon: (args) => /* @__PURE__ */ React.createElement(Icon, { data: ArrowLeftIcon, ...args })
35
+ }
36
+ ), /* @__PURE__ */ React.createElement("span", { className: b("counter") }, searchCurrentIndex, "/", searchCountResults), /* @__PURE__ */ React.createElement(
37
+ Control,
38
+ {
39
+ onClick: onClickNextSearch,
40
+ tooltipText: `${t("next")} (${hotkeysNext})`,
41
+ icon: (args) => /* @__PURE__ */ React.createElement(Icon, { data: ArrowLeftIcon, className: b("next-arrow"), ...args })
42
+ }
43
+ )), /* @__PURE__ */ React.createElement("span", { className: b("search-query-label") }, t("search-query-label"), ":\xA0"), /* @__PURE__ */ React.createElement("span", { className: b("search-query") }, searchQuery)), /* @__PURE__ */ React.createElement("div", { className: b("right") }, /* @__PURE__ */ React.createElement(
44
+ Control,
45
+ {
46
+ onClick: onCloseSearchBar,
47
+ tooltipText: t("close"),
48
+ icon: () => /* @__PURE__ */ React.createElement(Icon, { data: CloseIcon, size: 16 })
49
+ }
50
+ )));
51
+ });
52
+ SearchBar.displayName = "DCSearchBar";
53
+ var SearchBar_default = SearchBar;
54
+ export {
55
+ SearchBar_default as default
56
+ };
57
+ //# sourceMappingURL=SearchBar.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../src/components/SearchBar/SearchBar.tsx"],
4
+ "sourcesContent": ["import React, {memo} from 'react';\n\nimport {Icon} from '@gravity-ui/uikit';\nimport block from 'bem-cn-lite';\nimport {useHotkeys} from 'react-hotkeys-hook';\n\nimport {useTranslation} from '../../hooks';\nimport {Control} from '../Control';\n\nimport ArrowLeftIcon from '@gravity-ui/icons/svgs/chevron-left.svg';\nimport CloseIcon from '@gravity-ui/icons/svgs/xmark.svg';\n\nimport './SearchBar.scss';\n\nconst b = block('dc-search-bar');\n\nexport interface SearchBarProps {\n searchQuery?: string;\n onClickPrevSearch?: () => void;\n onClickNextSearch?: () => void;\n onCloseSearchBar?: () => void;\n searchCurrentIndex?: number;\n searchCountResults?: number;\n}\n\nconst noop = () => {};\n\nconst SearchBar = memo<SearchBarProps>((props) => {\n const {t} = useTranslation('search-bar');\n const {\n searchQuery,\n searchCurrentIndex,\n searchCountResults,\n onClickPrevSearch = noop,\n onClickNextSearch = noop,\n onCloseSearchBar = noop,\n } = props;\n\n const hotkeysOptions = {filterPreventDefault: true};\n const hotkeysPrev = '\u21E7+enter';\n const hotkeysNext = 'enter';\n useHotkeys(hotkeysPrev, onClickPrevSearch, hotkeysOptions, [onClickPrevSearch]);\n useHotkeys(hotkeysNext, onClickNextSearch, hotkeysOptions, [onClickNextSearch]);\n\n return (\n <div className={b()}>\n <div className={b('left')}>\n <div className={b('navigation')}>\n <Control\n onClick={onClickPrevSearch}\n tooltipText={`${t('prev')} (${hotkeysPrev})`}\n icon={(args) => <Icon data={ArrowLeftIcon} {...args} />}\n />\n <span className={b('counter')}>\n {searchCurrentIndex}/{searchCountResults}\n </span>\n <Control\n onClick={onClickNextSearch}\n tooltipText={`${t('next')} (${hotkeysNext})`}\n icon={(args) => (\n <Icon data={ArrowLeftIcon} className={b('next-arrow')} {...args} />\n )}\n />\n </div>\n <span className={b('search-query-label')}>\n {t<string>('search-query-label')}:&nbsp;\n </span>\n <span className={b('search-query')}>{searchQuery}</span>\n </div>\n <div className={b('right')}>\n <Control\n onClick={onCloseSearchBar}\n tooltipText={t('close')}\n icon={() => <Icon data={CloseIcon} size={16} />}\n />\n </div>\n </div>\n );\n});\n\nSearchBar.displayName = 'DCSearchBar';\n\nexport default SearchBar;\n"],
5
+ "mappings": ";AAAA,OAAO,SAAQ,YAAW;AAE1B,SAAQ,YAAW;AACnB,OAAO,WAAW;AAClB,SAAQ,kBAAiB;AAEzB,SAAQ,sBAAqB;AAC7B,SAAQ,eAAc;AAEtB,OAAO,mBAAmB;AAC1B,OAAO,eAAe;AAEtB,OAAO;AAEP,IAAM,IAAI,MAAM,eAAe;AAW/B,IAAM,OAAO,MAAM;AAAC;AAEpB,IAAM,YAAY,KAAqB,CAAC,UAAU;AAC9C,QAAM,EAAC,EAAC,IAAI,eAAe,YAAY;AACvC,QAAM;AAAA,IACF;AAAA,IACA;AAAA,IACA;AAAA,IACA,oBAAoB;AAAA,IACpB,oBAAoB;AAAA,IACpB,mBAAmB;AAAA,EACvB,IAAI;AAEJ,QAAM,iBAAiB,EAAC,sBAAsB,KAAI;AAClD,QAAM,cAAc;AACpB,QAAM,cAAc;AACpB,aAAW,aAAa,mBAAmB,gBAAgB,CAAC,iBAAiB,CAAC;AAC9E,aAAW,aAAa,mBAAmB,gBAAgB,CAAC,iBAAiB,CAAC;AAE9E,SACI,oCAAC,SAAI,WAAW,EAAE,KACd,oCAAC,SAAI,WAAW,EAAE,MAAM,KACpB,oCAAC,SAAI,WAAW,EAAE,YAAY,KAC1B;AAAA,IAAC;AAAA;AAAA,MACG,SAAS;AAAA,MACT,aAAa,GAAG,EAAE,MAAM,CAAC,KAAK,WAAW;AAAA,MACzC,MAAM,CAAC,SAAS,oCAAC,QAAK,MAAM,eAAgB,GAAG,MAAM;AAAA;AAAA,EACzD,GACA,oCAAC,UAAK,WAAW,EAAE,SAAS,KACvB,oBAAmB,KAAE,kBAC1B,GACA;AAAA,IAAC;AAAA;AAAA,MACG,SAAS;AAAA,MACT,aAAa,GAAG,EAAE,MAAM,CAAC,KAAK,WAAW;AAAA,MACzC,MAAM,CAAC,SACH,oCAAC,QAAK,MAAM,eAAe,WAAW,EAAE,YAAY,GAAI,GAAG,MAAM;AAAA;AAAA,EAEzE,CACJ,GACA,oCAAC,UAAK,WAAW,EAAE,oBAAoB,KAClC,EAAU,oBAAoB,GAAE,OACrC,GACA,oCAAC,UAAK,WAAW,EAAE,cAAc,KAAI,WAAY,CACrD,GACA,oCAAC,SAAI,WAAW,EAAE,OAAO,KACrB;AAAA,IAAC;AAAA;AAAA,MACG,SAAS;AAAA,MACT,aAAa,EAAE,OAAO;AAAA,MACtB,MAAM,MAAM,oCAAC,QAAK,MAAM,WAAW,MAAM,IAAI;AAAA;AAAA,EACjD,CACJ,CACJ;AAER,CAAC;AAED,UAAU,cAAc;AAExB,IAAO,oBAAQ;",
6
+ "names": []
7
+ }