@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,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../src/components/Controls/ControlsLayout.tsx"],
4
+ "sourcesContent": ["import React, {PropsWithChildren, createContext} from 'react';\n\nimport block from 'bem-cn-lite';\n\nimport {PopperPosition} from '../../hooks';\nimport {ControlSizes} from '../../models';\n\ntype ControlsLayoutProps = {\n isVerticalView?: boolean;\n controlClassName?: string;\n controlSize?: ControlSizes;\n popupPosition?: PopperPosition;\n};\n\nexport const ControlsLayoutContext = createContext<ControlsLayoutProps>({\n controlClassName: '',\n isVerticalView: false,\n controlSize: ControlSizes.M,\n popupPosition: PopperPosition.BOTTOM_END,\n});\n\nconst b = block('dc-controls');\n\nexport const ControlsLayout: React.FC<PropsWithChildren<ControlsLayoutProps>> = ({\n isVerticalView,\n controlClassName,\n controlSize,\n popupPosition,\n children,\n}) => {\n return (\n <ControlsLayoutContext.Provider\n value={{\n controlClassName: controlClassName || b('control'),\n isVerticalView: isVerticalView,\n controlSize: controlSize,\n popupPosition: popupPosition,\n }}\n >\n {children}\n </ControlsLayoutContext.Provider>\n );\n};\n"],
5
+ "mappings": ";AAAA,OAAO,SAA2B,qBAAoB;AAEtD,OAAO,WAAW;AAElB,SAAQ,sBAAqB;AAC7B,SAAQ,oBAAmB;AASpB,IAAM,wBAAwB,cAAmC;AAAA,EACpE,kBAAkB;AAAA,EAClB,gBAAgB;AAAA,EAChB,aAAa,aAAa;AAAA,EAC1B,eAAe,eAAe;AAClC,CAAC;AAED,IAAM,IAAI,MAAM,aAAa;AAEtB,IAAM,iBAAmE,CAAC;AAAA,EAC7E;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACJ,MAAM;AACF,SACI;AAAA,IAAC,sBAAsB;AAAA,IAAtB;AAAA,MACG,OAAO;AAAA,QACH,kBAAkB,oBAAoB,EAAE,SAAS;AAAA,QACjD;AAAA,QACA;AAAA,QACA;AAAA,MACJ;AAAA;AAAA,IAEC;AAAA,EACL;AAER;",
6
+ "names": []
7
+ }
@@ -0,0 +1,10 @@
1
+ // src/components/Controls/index.ts
2
+ export * from "./Controls";
3
+ import { default as default2 } from "./Controls";
4
+ export * from "./single-controls";
5
+ import { ControlsLayout } from "./ControlsLayout";
6
+ export {
7
+ default2 as Controls,
8
+ ControlsLayout
9
+ };
10
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../src/components/Controls/index.ts"],
4
+ "sourcesContent": ["export * from './Controls';\nexport {default as Controls} from './Controls';\nexport * from './single-controls';\nexport {ControlsLayout} from './ControlsLayout';\n"],
5
+ "mappings": ";AAAA,cAAc;AACd,SAAmB,WAAXA,gBAA0B;AAClC,cAAc;AACd,SAAQ,sBAAqB;",
6
+ "names": ["default"]
7
+ }
@@ -0,0 +1,21 @@
1
+ /* src/components/Controls/single-controls/DividerControl/DividerControl.scss */
2
+ .dc-divider-control {
3
+ background: var(--g-color-line-generic);
4
+ }
5
+ .dc-divider-control:first-child {
6
+ display: none;
7
+ }
8
+ .dc-divider-control:not(.dc-divider-control_vertical) {
9
+ width: 100%;
10
+ height: 1px;
11
+ }
12
+ .dc-divider-control_vertical {
13
+ width: 1px;
14
+ }
15
+ .dc-divider-control.dc-divider-control_vertical.dc-divider-control_size_m {
16
+ height: 16px;
17
+ }
18
+ .dc-divider-control.dc-divider-control_vertical.dc-divider-control_size_l {
19
+ height: 24px;
20
+ }
21
+ /*# sourceMappingURL=DividerControl.css.map */
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../../src/components/Controls/single-controls/DividerControl/Users/3y3k0/doctools/docs-components/src/components/Controls/single-controls/DividerControl/DividerControl.scss", "../../../../../../src/components/Controls/single-controls/DividerControl/%3Cinput%20css%200UtqKW%3E"],
4
+ "sourcesContent": [".dc-divider-control {\n background: var(--g-color-line-generic);\n\n &:first-child {\n display: none;\n }\n\n &:not(&_vertical) {\n width: 100%;\n height: 1px;\n }\n\n &_vertical {\n width: 1px;\n }\n\n &#{&}_vertical#{&}_size_m {\n height: 16px;\n }\n &#{&}_vertical#{&}_size_l {\n height: 24px;\n }\n}\n", ".dc-divider-control {\n background: var(--g-color-line-generic);\n}\n.dc-divider-control:first-child {\n display: none;\n}\n.dc-divider-control:not(.dc-divider-control_vertical) {\n width: 100%;\n height: 1px;\n}\n.dc-divider-control_vertical {\n width: 1px;\n}\n.dc-divider-control.dc-divider-control_vertical.dc-divider-control_size_m {\n height: 16px;\n}\n.dc-divider-control.dc-divider-control_vertical.dc-divider-control_size_l {\n height: 24px;\n}\n/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VSb290IjoiL1VzZXJzLzN5M2swL2RvY3Rvb2xzL2RvY3MtY29tcG9uZW50cy9zcmMvY29tcG9uZW50cy9Db250cm9scy9zaW5nbGUtY29udHJvbHMvRGl2aWRlckNvbnRyb2wiLCJzb3VyY2VzIjpbIkRpdmlkZXJDb250cm9sLnNjc3MiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7RUFDSTs7QUFFQTtFQUNJOztBQUdKO0VBQ0k7RUFDQTs7QUFHSjtFQUNJOztBQUdKO0VBQ0k7O0FBRUo7RUFDSSIsInNvdXJjZXNDb250ZW50IjpbIi5kYy1kaXZpZGVyLWNvbnRyb2wge1xuICAgIGJhY2tncm91bmQ6IHZhcigtLWctY29sb3ItbGluZS1nZW5lcmljKTtcblxuICAgICY6Zmlyc3QtY2hpbGQge1xuICAgICAgICBkaXNwbGF5OiBub25lO1xuICAgIH1cblxuICAgICY6bm90KCZfdmVydGljYWwpIHtcbiAgICAgICAgd2lkdGg6IDEwMCU7XG4gICAgICAgIGhlaWdodDogMXB4O1xuICAgIH1cblxuICAgICZfdmVydGljYWwge1xuICAgICAgICB3aWR0aDogMXB4O1xuICAgIH1cblxuICAgICYjeyZ9X3ZlcnRpY2FsI3smfV9zaXplX20ge1xuICAgICAgICBoZWlnaHQ6IDE2cHg7XG4gICAgfVxuICAgICYjeyZ9X3ZlcnRpY2FsI3smfV9zaXplX2wge1xuICAgICAgICBoZWlnaHQ6IDI0cHg7XG4gICAgfVxufVxuIl19 */"],
5
+ "mappings": ";AAAA,CAAA;AACI,cAAA,IAAA;ACCJ;ADCI,CAHJ,kBAGI;AACI,WAAA;ACCR;ADEI,CAPJ,kBAOI,KAAA,CAAA;AACI,SAAA;AACA,UAAA;ACAR;ADGI,CALA;AAMI,SAAA;ACDR;ADII,CAhBJ,kBAgBI,CATA,2BASA,CAAA;AACI,UAAA;ACFR;ADII,CAnBJ,kBAmBI,CAZA,2BAYA,CAAA;AACI,UAAA;ACFR;",
6
+ "names": []
7
+ }
@@ -0,0 +1,15 @@
1
+ // src/components/Controls/single-controls/DividerControl/DividerControl.tsx
2
+ import React, { useContext } from "react";
3
+ import cn from "bem-cn-lite";
4
+ import { ControlsLayoutContext } from "../../ControlsLayout";
5
+ import "./DividerControl.css";
6
+ var b = cn("dc-divider-control");
7
+ var DividerControl = ({ className }) => {
8
+ const { isVerticalView, controlSize } = useContext(ControlsLayoutContext);
9
+ return /* @__PURE__ */ React.createElement("div", { className: b({ size: controlSize, vertical: !isVerticalView }, className) });
10
+ };
11
+ var DividerControl_default = DividerControl;
12
+ export {
13
+ DividerControl_default as default
14
+ };
15
+ //# sourceMappingURL=DividerControl.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../../src/components/Controls/single-controls/DividerControl/DividerControl.tsx"],
4
+ "sourcesContent": ["import React, {useContext} from 'react';\n\nimport cn from 'bem-cn-lite';\n\nimport {ControlsLayoutContext} from '../../ControlsLayout';\n\nimport './DividerControl.scss';\n\nconst b = cn('dc-divider-control');\n\ninterface DividerControlProps {\n className?: string;\n}\n\nconst DividerControl: React.FC<DividerControlProps> = ({className}) => {\n const {isVerticalView, controlSize} = useContext(ControlsLayoutContext);\n\n return <div className={b({size: controlSize, vertical: !isVerticalView}, className)} />;\n};\n\nexport default DividerControl;\n"],
5
+ "mappings": ";AAAA,OAAO,SAAQ,kBAAiB;AAEhC,OAAO,QAAQ;AAEf,SAAQ,6BAA4B;AAEpC,OAAO;AAEP,IAAM,IAAI,GAAG,oBAAoB;AAMjC,IAAM,iBAAgD,CAAC,EAAC,UAAS,MAAM;AACnE,QAAM,EAAC,gBAAgB,YAAW,IAAI,WAAW,qBAAqB;AAEtE,SAAO,oCAAC,SAAI,WAAW,EAAE,EAAC,MAAM,aAAa,UAAU,CAAC,eAAc,GAAG,SAAS,GAAG;AACzF;AAEA,IAAO,yBAAQ;",
6
+ "names": []
7
+ }
@@ -0,0 +1,42 @@
1
+ // src/components/Controls/single-controls/EditControl.tsx
2
+ import React, { memo, useContext } from "react";
3
+ import { Button, Icon } from "@gravity-ui/uikit";
4
+ import block from "bem-cn-lite";
5
+ import { useTranslation } from "../../../hooks";
6
+ import { Control } from "../../Control";
7
+ import { ControlsLayoutContext } from "../ControlsLayout";
8
+ import EditIcon from "@gravity-ui/icons/svgs/pencil.svg";
9
+ var b = block("dc-controls");
10
+ var EditControl = memo(({ vcsUrl, vcsType = "github", view, className }) => {
11
+ const { t } = useTranslation("controls");
12
+ const { controlClassName, controlSize, isVerticalView, popupPosition } = useContext(ControlsLayoutContext);
13
+ if (view === "wide") {
14
+ return /* @__PURE__ */ React.createElement("a", { href: vcsUrl, target: "_blank", rel: "noreferrer noopener" }, /* @__PURE__ */ React.createElement(Button, { className: b("control", { view }, className), view: "raised" }, /* @__PURE__ */ React.createElement(Button.Icon, null, /* @__PURE__ */ React.createElement(Icon, { data: EditIcon, size: 14 })), /* @__PURE__ */ React.createElement("span", { className: b("edit-text") }, t("edit-text"))));
15
+ }
16
+ return /* @__PURE__ */ React.createElement(
17
+ "a",
18
+ {
19
+ href: vcsUrl,
20
+ target: "_blank",
21
+ rel: "noreferrer noopener",
22
+ className: b("control", className)
23
+ },
24
+ /* @__PURE__ */ React.createElement(
25
+ Control,
26
+ {
27
+ size: controlSize,
28
+ className: controlClassName,
29
+ isVerticalView,
30
+ tooltipText: t(`edit-text-${vcsType}`),
31
+ icon: EditIcon,
32
+ popupPosition
33
+ }
34
+ )
35
+ );
36
+ });
37
+ EditControl.displayName = "EditControl";
38
+ var EditControl_default = EditControl;
39
+ export {
40
+ EditControl_default as default
41
+ };
42
+ //# sourceMappingURL=EditControl.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/components/Controls/single-controls/EditControl.tsx"],
4
+ "sourcesContent": ["import React, {memo, useContext} from 'react';\n\nimport {Button, Icon} from '@gravity-ui/uikit';\nimport block from 'bem-cn-lite';\n\nimport {useTranslation} from '../../../hooks';\nimport {Control} from '../../Control';\nimport {ControlsLayoutContext} from '../ControlsLayout';\n\nimport EditIcon from '@gravity-ui/icons/svgs/pencil.svg';\n\ninterface EditControlProps {\n vcsUrl: string;\n vcsType?: string;\n view?: string;\n className?: string;\n}\n\nconst b = block('dc-controls');\n\nconst EditControl = memo<EditControlProps>(({vcsUrl, vcsType = 'github', view, className}) => {\n const {t} = useTranslation('controls');\n const {controlClassName, controlSize, isVerticalView, popupPosition} =\n useContext(ControlsLayoutContext);\n\n if (view === 'wide') {\n return (\n <a href={vcsUrl} target=\"_blank\" rel=\"noreferrer noopener\">\n <Button className={b('control', {view}, className)} view=\"raised\">\n <Button.Icon>\n <Icon data={EditIcon} size={14} />\n </Button.Icon>\n <span className={b('edit-text')}>{t<string>('edit-text')}</span>\n </Button>\n </a>\n );\n }\n\n return (\n <a\n href={vcsUrl}\n target=\"_blank\"\n rel=\"noreferrer noopener\"\n className={b('control', className)}\n >\n <Control\n size={controlSize}\n className={controlClassName}\n isVerticalView={isVerticalView}\n tooltipText={t(`edit-text-${vcsType}`)}\n icon={EditIcon}\n popupPosition={popupPosition}\n />\n </a>\n );\n});\n\nEditControl.displayName = 'EditControl';\n\nexport default EditControl;\n"],
5
+ "mappings": ";AAAA,OAAO,SAAQ,MAAM,kBAAiB;AAEtC,SAAQ,QAAQ,YAAW;AAC3B,OAAO,WAAW;AAElB,SAAQ,sBAAqB;AAC7B,SAAQ,eAAc;AACtB,SAAQ,6BAA4B;AAEpC,OAAO,cAAc;AASrB,IAAM,IAAI,MAAM,aAAa;AAE7B,IAAM,cAAc,KAAuB,CAAC,EAAC,QAAQ,UAAU,UAAU,MAAM,UAAS,MAAM;AAC1F,QAAM,EAAC,EAAC,IAAI,eAAe,UAAU;AACrC,QAAM,EAAC,kBAAkB,aAAa,gBAAgB,cAAa,IAC/D,WAAW,qBAAqB;AAEpC,MAAI,SAAS,QAAQ;AACjB,WACI,oCAAC,OAAE,MAAM,QAAQ,QAAO,UAAS,KAAI,yBACjC,oCAAC,UAAO,WAAW,EAAE,WAAW,EAAC,KAAI,GAAG,SAAS,GAAG,MAAK,YACrD,oCAAC,OAAO,MAAP,MACG,oCAAC,QAAK,MAAM,UAAU,MAAM,IAAI,CACpC,GACA,oCAAC,UAAK,WAAW,EAAE,WAAW,KAAI,EAAU,WAAW,CAAE,CAC7D,CACJ;AAAA,EAER;AAEA,SACI;AAAA,IAAC;AAAA;AAAA,MACG,MAAM;AAAA,MACN,QAAO;AAAA,MACP,KAAI;AAAA,MACJ,WAAW,EAAE,WAAW,SAAS;AAAA;AAAA,IAEjC;AAAA,MAAC;AAAA;AAAA,QACG,MAAM;AAAA,QACN,WAAW;AAAA,QACX;AAAA,QACA,aAAa,EAAE,aAAa,OAAO,EAAE;AAAA,QACrC,MAAM;AAAA,QACN;AAAA;AAAA,IACJ;AAAA,EACJ;AAER,CAAC;AAED,YAAY,cAAc;AAE1B,IAAO,sBAAQ;",
6
+ "names": []
7
+ }
@@ -0,0 +1,51 @@
1
+ // src/components/Controls/single-controls/FullScreenControl.tsx
2
+ import React, { memo, useCallback, useContext, useEffect } from "react";
3
+ import { Icon } from "@gravity-ui/uikit";
4
+ import { useTranslation } from "../../../hooks";
5
+ import { Control } from "../../Control";
6
+ import { ControlsLayoutContext } from "../ControlsLayout";
7
+ import FullScreenClickedIcon from "@gravity-ui/icons/svgs/square-dashed-circle.svg";
8
+ import FullScreenIcon from "@gravity-ui/icons/svgs/square-dashed.svg";
9
+ var FullScreenControl = memo((props) => {
10
+ const { t } = useTranslation("controls");
11
+ const { controlClassName, controlSize, isVerticalView, popupPosition } = useContext(ControlsLayoutContext);
12
+ const { value, onChange } = props;
13
+ const onClick = useCallback(() => {
14
+ if (onChange) {
15
+ onChange(!value);
16
+ }
17
+ }, [value, onChange]);
18
+ const onKeyDown = useCallback(
19
+ (event) => {
20
+ if (event.key === "Escape" && value) {
21
+ onClick();
22
+ }
23
+ },
24
+ [onClick, value]
25
+ );
26
+ useEffect(() => {
27
+ document.addEventListener("keydown", onKeyDown);
28
+ return () => {
29
+ document.removeEventListener("keydown", onKeyDown);
30
+ };
31
+ }, [onKeyDown]);
32
+ const activeMode = value ? "enabled" : "disabled";
33
+ return /* @__PURE__ */ React.createElement(
34
+ Control,
35
+ {
36
+ size: controlSize,
37
+ onClick,
38
+ className: controlClassName,
39
+ isVerticalView,
40
+ tooltipText: t(`full-screen-text-${activeMode}`),
41
+ icon: (args) => /* @__PURE__ */ React.createElement(Icon, { data: value ? FullScreenClickedIcon : FullScreenIcon, ...args }),
42
+ popupPosition
43
+ }
44
+ );
45
+ });
46
+ FullScreenControl.displayName = "FullScreenControl";
47
+ var FullScreenControl_default = FullScreenControl;
48
+ export {
49
+ FullScreenControl_default as default
50
+ };
51
+ //# sourceMappingURL=FullScreenControl.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/components/Controls/single-controls/FullScreenControl.tsx"],
4
+ "sourcesContent": ["import React, {memo, useCallback, useContext, useEffect} from 'react';\n\nimport {Icon} from '@gravity-ui/uikit';\n\nimport {useTranslation} from '../../../hooks';\nimport {Control} from '../../Control';\nimport {ControlsLayoutContext} from '../ControlsLayout';\n\nimport FullScreenClickedIcon from '@gravity-ui/icons/svgs/square-dashed-circle.svg';\nimport FullScreenIcon from '@gravity-ui/icons/svgs/square-dashed.svg';\n\ninterface ControlProps {\n value?: boolean;\n onChange?: (value: boolean) => void;\n}\n\nconst FullScreenControl = memo<ControlProps>((props) => {\n const {t} = useTranslation('controls');\n const {controlClassName, controlSize, isVerticalView, popupPosition} =\n useContext(ControlsLayoutContext);\n const {value, onChange} = props;\n\n const onClick = useCallback(() => {\n if (onChange) {\n onChange(!value);\n }\n }, [value, onChange]);\n\n const onKeyDown = useCallback(\n (event: KeyboardEvent | React.KeyboardEvent) => {\n if (event.key === 'Escape' && value) {\n onClick();\n }\n },\n [onClick, value],\n );\n\n useEffect(() => {\n document.addEventListener('keydown', onKeyDown);\n\n return () => {\n document.removeEventListener('keydown', onKeyDown);\n };\n }, [onKeyDown]);\n\n const activeMode = value ? 'enabled' : 'disabled';\n\n return (\n <Control\n size={controlSize}\n onClick={onClick}\n className={controlClassName}\n isVerticalView={isVerticalView}\n tooltipText={t(`full-screen-text-${activeMode}`)}\n icon={(args) => (\n <Icon data={value ? FullScreenClickedIcon : FullScreenIcon} {...args} />\n )}\n popupPosition={popupPosition}\n />\n );\n});\n\nFullScreenControl.displayName = 'FullScreenControl';\n\nexport default FullScreenControl;\n"],
5
+ "mappings": ";AAAA,OAAO,SAAQ,MAAM,aAAa,YAAY,iBAAgB;AAE9D,SAAQ,YAAW;AAEnB,SAAQ,sBAAqB;AAC7B,SAAQ,eAAc;AACtB,SAAQ,6BAA4B;AAEpC,OAAO,2BAA2B;AAClC,OAAO,oBAAoB;AAO3B,IAAM,oBAAoB,KAAmB,CAAC,UAAU;AACpD,QAAM,EAAC,EAAC,IAAI,eAAe,UAAU;AACrC,QAAM,EAAC,kBAAkB,aAAa,gBAAgB,cAAa,IAC/D,WAAW,qBAAqB;AACpC,QAAM,EAAC,OAAO,SAAQ,IAAI;AAE1B,QAAM,UAAU,YAAY,MAAM;AAC9B,QAAI,UAAU;AACV,eAAS,CAAC,KAAK;AAAA,IACnB;AAAA,EACJ,GAAG,CAAC,OAAO,QAAQ,CAAC;AAEpB,QAAM,YAAY;AAAA,IACd,CAAC,UAA+C;AAC5C,UAAI,MAAM,QAAQ,YAAY,OAAO;AACjC,gBAAQ;AAAA,MACZ;AAAA,IACJ;AAAA,IACA,CAAC,SAAS,KAAK;AAAA,EACnB;AAEA,YAAU,MAAM;AACZ,aAAS,iBAAiB,WAAW,SAAS;AAE9C,WAAO,MAAM;AACT,eAAS,oBAAoB,WAAW,SAAS;AAAA,IACrD;AAAA,EACJ,GAAG,CAAC,SAAS,CAAC;AAEd,QAAM,aAAa,QAAQ,YAAY;AAEvC,SACI;AAAA,IAAC;AAAA;AAAA,MACG,MAAM;AAAA,MACN;AAAA,MACA,WAAW;AAAA,MACX;AAAA,MACA,aAAa,EAAE,oBAAoB,UAAU,EAAE;AAAA,MAC/C,MAAM,CAAC,SACH,oCAAC,QAAK,MAAM,QAAQ,wBAAwB,gBAAiB,GAAG,MAAM;AAAA,MAE1E;AAAA;AAAA,EACJ;AAER,CAAC;AAED,kBAAkB,cAAc;AAEhC,IAAO,4BAAQ;",
6
+ "names": []
7
+ }
@@ -0,0 +1,91 @@
1
+ // src/components/Controls/single-controls/LangControl.tsx
2
+ import React, { useCallback, useContext, useMemo, useRef } from "react";
3
+ import { Icon, List, Popup } from "@gravity-ui/uikit";
4
+ import block from "bem-cn-lite";
5
+ import allLangs from "langs";
6
+ import { usePopupState, useTranslation } from "../../../hooks";
7
+ import { Lang } from "../../../models";
8
+ import { Control } from "../../Control";
9
+ import { ControlsLayoutContext } from "../ControlsLayout";
10
+ import { getPopupPosition } from "./utils";
11
+ import LangIcon from "@gravity-ui/icons/svgs/globe.svg";
12
+ import "../Controls.css";
13
+ var ICONS = {
14
+ en: "\u{1F1EC}\u{1F1E7}",
15
+ ru: "\u{1F1F7}\u{1F1FA}"
16
+ };
17
+ var DEFAULT_LANGS = ["en", "ru"];
18
+ var LEGACY_LANG_ITEMS = [
19
+ { value: Lang.En, text: "English", icon: "\u{1F1EC}\u{1F1E7}" },
20
+ { value: Lang.Ru, text: "\u0420\u0443\u0441\u0441\u043A\u0438\u0439", icon: "\u{1F1F7}\u{1F1FA}" }
21
+ ];
22
+ var b = block("dc-controls");
23
+ var LIST_ITEM_HEIGHT = 36;
24
+ var LangControl = (props) => {
25
+ const { t } = useTranslation("controls");
26
+ const { controlClassName, controlSize, isVerticalView, popupPosition } = useContext(ControlsLayoutContext);
27
+ const { lang, langs = DEFAULT_LANGS, onChangeLang } = props;
28
+ const controlRef = useRef(null);
29
+ const popupState = usePopupState();
30
+ const langItems = useMemo(() => {
31
+ const preparedLangs = langs.map((code) => {
32
+ const langData = allLangs.where("1", code);
33
+ return langData ? {
34
+ text: langData.name,
35
+ value: langData["1"],
36
+ icon: ICONS[code] || ""
37
+ } : void 0;
38
+ }).filter(Boolean);
39
+ return preparedLangs.length ? preparedLangs : LEGACY_LANG_ITEMS;
40
+ }, [langs]);
41
+ const renderItem = useCallback((item) => {
42
+ return /* @__PURE__ */ React.createElement("div", { className: b("lang-item") }, /* @__PURE__ */ React.createElement("div", { className: b("list-icon") }, item.icon), item.text);
43
+ }, []);
44
+ const onItemClick = useCallback(
45
+ (item) => {
46
+ onChangeLang(item.value);
47
+ },
48
+ [onChangeLang]
49
+ );
50
+ const itemsHeight = LIST_ITEM_HEIGHT * langItems.length;
51
+ const selectedItemIndex = langItems.findIndex(({ value }) => value === lang);
52
+ return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(
53
+ Control,
54
+ {
55
+ ref: controlRef,
56
+ size: controlSize,
57
+ onClick: popupState.open,
58
+ className: controlClassName,
59
+ isVerticalView,
60
+ tooltipText: t("lang-text"),
61
+ icon: (args) => /* @__PURE__ */ React.createElement(Icon, { data: LangIcon, ...args }),
62
+ popupPosition
63
+ }
64
+ ), popupState.visible && /* @__PURE__ */ React.createElement(
65
+ Popup,
66
+ {
67
+ anchorRef: controlRef,
68
+ open: true,
69
+ onOutsideClick: popupState.close,
70
+ placement: getPopupPosition(isVerticalView)
71
+ },
72
+ /* @__PURE__ */ React.createElement(
73
+ List,
74
+ {
75
+ filterable: false,
76
+ className: b("list", { langs: true }),
77
+ items: langItems,
78
+ onItemClick,
79
+ selectedItemIndex,
80
+ itemHeight: LIST_ITEM_HEIGHT,
81
+ itemsHeight,
82
+ renderItem
83
+ }
84
+ )
85
+ ));
86
+ };
87
+ var LangControl_default = LangControl;
88
+ export {
89
+ LangControl_default as default
90
+ };
91
+ //# sourceMappingURL=LangControl.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/components/Controls/single-controls/LangControl.tsx"],
4
+ "sourcesContent": ["import React, {useCallback, useContext, useMemo, useRef} from 'react';\n\nimport {Icon, List, Popup} from '@gravity-ui/uikit';\nimport block from 'bem-cn-lite';\nimport allLangs from 'langs';\n\nimport {usePopupState, useTranslation} from '../../../hooks';\nimport {Lang} from '../../../models';\nimport {Control} from '../../Control';\nimport {ControlsLayoutContext} from '../ControlsLayout';\n\nimport {getPopupPosition} from './utils';\n\nimport LangIcon from '@gravity-ui/icons/svgs/globe.svg';\n\nimport '../Controls.scss';\n\nconst ICONS: Record<string, string> = {\n en: '\uD83C\uDDEC\uD83C\uDDE7',\n ru: '\uD83C\uDDF7\uD83C\uDDFA',\n};\nconst DEFAULT_LANGS = ['en', 'ru'];\nconst LEGACY_LANG_ITEMS = [\n {value: Lang.En, text: 'English', icon: '\uD83C\uDDEC\uD83C\uDDE7'},\n {value: Lang.Ru, text: '\u0420\u0443\u0441\u0441\u043A\u0438\u0439', icon: '\uD83C\uDDF7\uD83C\uDDFA'},\n];\n\nconst b = block('dc-controls');\n\ninterface ControlProps {\n lang: Lang;\n langs?: string[];\n onChangeLang: (lang: Lang) => void;\n}\n\ninterface ListItem {\n value: string;\n text: string;\n icon?: string;\n}\n\nconst LIST_ITEM_HEIGHT = 36;\n\nconst LangControl = (props: ControlProps) => {\n const {t} = useTranslation('controls');\n const {controlClassName, controlSize, isVerticalView, popupPosition} =\n useContext(ControlsLayoutContext);\n const {lang, langs = DEFAULT_LANGS, onChangeLang} = props;\n\n const controlRef = useRef<HTMLButtonElement | null>(null);\n\n const popupState = usePopupState();\n const langItems = useMemo(() => {\n const preparedLangs = langs\n .map((code) => {\n const langData = allLangs.where('1', code);\n\n return langData\n ? {\n text: langData.name,\n value: langData['1'],\n icon: ICONS[code] || '',\n }\n : undefined;\n })\n .filter(Boolean) as ListItem[];\n\n return preparedLangs.length ? preparedLangs : LEGACY_LANG_ITEMS;\n }, [langs]);\n const renderItem = useCallback((item: ListItem) => {\n return (\n <div className={b('lang-item')}>\n <div className={b('list-icon')}>{item.icon}</div>\n {item.text}\n </div>\n );\n }, []);\n const onItemClick = useCallback(\n (item: ListItem) => {\n onChangeLang(item.value as Lang);\n },\n [onChangeLang],\n );\n\n const itemsHeight = LIST_ITEM_HEIGHT * langItems.length;\n const selectedItemIndex = langItems.findIndex(({value}) => value === lang);\n\n return (\n <React.Fragment>\n <Control\n ref={controlRef}\n size={controlSize}\n onClick={popupState.open}\n className={controlClassName}\n isVerticalView={isVerticalView}\n tooltipText={t('lang-text')}\n icon={(args) => <Icon data={LangIcon} {...args} />}\n popupPosition={popupPosition}\n />\n {popupState.visible && (\n <Popup\n anchorRef={controlRef}\n open={true}\n onOutsideClick={popupState.close}\n placement={getPopupPosition(isVerticalView)}\n >\n <List\n filterable={false}\n className={b('list', {langs: true})}\n items={langItems}\n onItemClick={onItemClick}\n selectedItemIndex={selectedItemIndex}\n itemHeight={LIST_ITEM_HEIGHT}\n itemsHeight={itemsHeight}\n renderItem={renderItem}\n />\n </Popup>\n )}\n </React.Fragment>\n );\n};\n\nexport default LangControl;\n"],
5
+ "mappings": ";AAAA,OAAO,SAAQ,aAAa,YAAY,SAAS,cAAa;AAE9D,SAAQ,MAAM,MAAM,aAAY;AAChC,OAAO,WAAW;AAClB,OAAO,cAAc;AAErB,SAAQ,eAAe,sBAAqB;AAC5C,SAAQ,YAAW;AACnB,SAAQ,eAAc;AACtB,SAAQ,6BAA4B;AAEpC,SAAQ,wBAAuB;AAE/B,OAAO,cAAc;AAErB,OAAO;AAEP,IAAM,QAAgC;AAAA,EAClC,IAAI;AAAA,EACJ,IAAI;AACR;AACA,IAAM,gBAAgB,CAAC,MAAM,IAAI;AACjC,IAAM,oBAAoB;AAAA,EACtB,EAAC,OAAO,KAAK,IAAI,MAAM,WAAW,MAAM,qBAAM;AAAA,EAC9C,EAAC,OAAO,KAAK,IAAI,MAAM,8CAAW,MAAM,qBAAM;AAClD;AAEA,IAAM,IAAI,MAAM,aAAa;AAc7B,IAAM,mBAAmB;AAEzB,IAAM,cAAc,CAAC,UAAwB;AACzC,QAAM,EAAC,EAAC,IAAI,eAAe,UAAU;AACrC,QAAM,EAAC,kBAAkB,aAAa,gBAAgB,cAAa,IAC/D,WAAW,qBAAqB;AACpC,QAAM,EAAC,MAAM,QAAQ,eAAe,aAAY,IAAI;AAEpD,QAAM,aAAa,OAAiC,IAAI;AAExD,QAAM,aAAa,cAAc;AACjC,QAAM,YAAY,QAAQ,MAAM;AAC5B,UAAM,gBAAgB,MACjB,IAAI,CAAC,SAAS;AACX,YAAM,WAAW,SAAS,MAAM,KAAK,IAAI;AAEzC,aAAO,WACD;AAAA,QACI,MAAM,SAAS;AAAA,QACf,OAAO,SAAS,GAAG;AAAA,QACnB,MAAM,MAAM,IAAI,KAAK;AAAA,MACzB,IACA;AAAA,IACV,CAAC,EACA,OAAO,OAAO;AAEnB,WAAO,cAAc,SAAS,gBAAgB;AAAA,EAClD,GAAG,CAAC,KAAK,CAAC;AACV,QAAM,aAAa,YAAY,CAAC,SAAmB;AAC/C,WACI,oCAAC,SAAI,WAAW,EAAE,WAAW,KACzB,oCAAC,SAAI,WAAW,EAAE,WAAW,KAAI,KAAK,IAAK,GAC1C,KAAK,IACV;AAAA,EAER,GAAG,CAAC,CAAC;AACL,QAAM,cAAc;AAAA,IAChB,CAAC,SAAmB;AAChB,mBAAa,KAAK,KAAa;AAAA,IACnC;AAAA,IACA,CAAC,YAAY;AAAA,EACjB;AAEA,QAAM,cAAc,mBAAmB,UAAU;AACjD,QAAM,oBAAoB,UAAU,UAAU,CAAC,EAAC,MAAK,MAAM,UAAU,IAAI;AAEzE,SACI,oCAAC,MAAM,UAAN,MACG;AAAA,IAAC;AAAA;AAAA,MACG,KAAK;AAAA,MACL,MAAM;AAAA,MACN,SAAS,WAAW;AAAA,MACpB,WAAW;AAAA,MACX;AAAA,MACA,aAAa,EAAE,WAAW;AAAA,MAC1B,MAAM,CAAC,SAAS,oCAAC,QAAK,MAAM,UAAW,GAAG,MAAM;AAAA,MAChD;AAAA;AAAA,EACJ,GACC,WAAW,WACR;AAAA,IAAC;AAAA;AAAA,MACG,WAAW;AAAA,MACX,MAAM;AAAA,MACN,gBAAgB,WAAW;AAAA,MAC3B,WAAW,iBAAiB,cAAc;AAAA;AAAA,IAE1C;AAAA,MAAC;AAAA;AAAA,QACG,YAAY;AAAA,QACZ,WAAW,EAAE,QAAQ,EAAC,OAAO,KAAI,CAAC;AAAA,QAClC,OAAO;AAAA,QACP;AAAA,QACA;AAAA,QACA,YAAY;AAAA,QACZ;AAAA,QACA;AAAA;AAAA,IACJ;AAAA,EACJ,CAER;AAER;AAEA,IAAO,sBAAQ;",
6
+ "names": []
7
+ }
@@ -0,0 +1,29 @@
1
+ // src/components/Controls/single-controls/PdfControl.tsx
2
+ import React, { memo, useContext } from "react";
3
+ import { Icon } from "@gravity-ui/uikit";
4
+ import { useTranslation } from "../../../hooks";
5
+ import { Control } from "../../Control";
6
+ import { ControlsLayoutContext } from "../ControlsLayout";
7
+ import PdfIcon from "../../../../../assets/icons/pdf.svg";
8
+ var PdfControl = memo((props) => {
9
+ const { t } = useTranslation("controls");
10
+ const { controlClassName, controlSize, isVerticalView, popupPosition } = useContext(ControlsLayoutContext);
11
+ const { pdfLink } = props;
12
+ return /* @__PURE__ */ React.createElement("a", { href: pdfLink, target: "_blank", rel: "noreferrer noopener" }, /* @__PURE__ */ React.createElement(
13
+ Control,
14
+ {
15
+ size: controlSize,
16
+ className: controlClassName,
17
+ isVerticalView,
18
+ tooltipText: t("pdf-text"),
19
+ icon: (args) => /* @__PURE__ */ React.createElement(Icon, { data: PdfIcon, ...args }),
20
+ popupPosition
21
+ }
22
+ ));
23
+ });
24
+ PdfControl.displayName = "PdfControl";
25
+ var PdfControl_default = PdfControl;
26
+ export {
27
+ PdfControl_default as default
28
+ };
29
+ //# sourceMappingURL=PdfControl.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../src/components/Controls/single-controls/PdfControl.tsx"],
4
+ "sourcesContent": ["import React, {memo, useContext} from 'react';\n\nimport {Icon} from '@gravity-ui/uikit';\n\nimport {useTranslation} from '../../../hooks';\nimport {Control} from '../../Control';\nimport {ControlsLayoutContext} from '../ControlsLayout';\n\nimport PdfIcon from '../../../../assets/icons/pdf.svg';\n\ninterface ControlProps {\n pdfLink: string;\n}\n\nconst PdfControl = memo<ControlProps>((props) => {\n const {t} = useTranslation('controls');\n const {controlClassName, controlSize, isVerticalView, popupPosition} =\n useContext(ControlsLayoutContext);\n const {pdfLink} = props;\n\n return (\n <a href={pdfLink} target=\"_blank\" rel=\"noreferrer noopener\">\n <Control\n size={controlSize}\n className={controlClassName}\n isVerticalView={isVerticalView}\n tooltipText={t('pdf-text')}\n icon={(args) => <Icon data={PdfIcon} {...args} />}\n popupPosition={popupPosition}\n />\n </a>\n );\n});\n\nPdfControl.displayName = 'PdfControl';\n\nexport default PdfControl;\n"],
5
+ "mappings": ";AAAA,OAAO,SAAQ,MAAM,kBAAiB;AAEtC,SAAQ,YAAW;AAEnB,SAAQ,sBAAqB;AAC7B,SAAQ,eAAc;AACtB,SAAQ,6BAA4B;AAEpC,OAAO,aAAa;AAMpB,IAAM,aAAa,KAAmB,CAAC,UAAU;AAC7C,QAAM,EAAC,EAAC,IAAI,eAAe,UAAU;AACrC,QAAM,EAAC,kBAAkB,aAAa,gBAAgB,cAAa,IAC/D,WAAW,qBAAqB;AACpC,QAAM,EAAC,QAAO,IAAI;AAElB,SACI,oCAAC,OAAE,MAAM,SAAS,QAAO,UAAS,KAAI,yBAClC;AAAA,IAAC;AAAA;AAAA,MACG,MAAM;AAAA,MACN,WAAW;AAAA,MACX;AAAA,MACA,aAAa,EAAE,UAAU;AAAA,MACzB,MAAM,CAAC,SAAS,oCAAC,QAAK,MAAM,SAAU,GAAG,MAAM;AAAA,MAC/C;AAAA;AAAA,EACJ,CACJ;AAER,CAAC;AAED,WAAW,cAAc;AAEzB,IAAO,qBAAQ;",
6
+ "names": []
7
+ }
@@ -0,0 +1,49 @@
1
+ /* src/components/Controls/single-controls/SettingsControl/SettingsControl.scss */
2
+ .dc-settings-control__text-size-control {
3
+ display: flex;
4
+ align-items: center;
5
+ }
6
+ .dc-settings-control__text-size-button_s {
7
+ font-size: var(--g-text-body-1-font-size);
8
+ line-height: var(--g-text-body-1-line-height);
9
+ }
10
+ .dc-settings-control__text-size-button_m {
11
+ font-size: var(--g-text-body-2-font-size);
12
+ line-height: var(--g-text-body-2-line-height);
13
+ }
14
+ .dc-settings-control__text-size-button_l {
15
+ font-size: var(--g-text-body-3-font-size);
16
+ line-height: var(--g-text-body-3-line-height);
17
+ }
18
+ .dc-settings-control__text-size-button-icon_active {
19
+ color: var(--g-color-base-brand);
20
+ }
21
+ .dc-settings-control__popup {
22
+ width: 230px;
23
+ font-size: var(--g-text-body-1-font-size);
24
+ line-height: var(--g-text-body-1-line-height);
25
+ }
26
+ .dc-settings-control__list {
27
+ padding: 4px 0;
28
+ width: 230px;
29
+ }
30
+ .dc-settings-control__list .yc-list__item_active {
31
+ background: transparent;
32
+ }
33
+ .dc-settings-control__list-icon {
34
+ margin-right: 8px;
35
+ }
36
+ .dc-settings-control__list-item {
37
+ display: flex;
38
+ padding: 12px;
39
+ width: 100%;
40
+ }
41
+ .dc-settings-control__list-item-description {
42
+ color: var(--g-color-text-secondary);
43
+ }
44
+ .dc-settings-control__list-item-control {
45
+ display: flex;
46
+ align-items: center;
47
+ margin-left: auto;
48
+ }
49
+ /*# sourceMappingURL=SettingsControl.css.map */
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../../../../src/components/Controls/single-controls/SettingsControl/Users/3y3k0/doctools/docs-components/src/components/Controls/single-controls/SettingsControl/SettingsControl.scss", "../../../../../../src/components/Controls/single-controls/SettingsControl/%3Cinput%20css%201300uk%3E", "../../../../../../src/components/Controls/single-controls/SettingsControl/Users/3y3k0/doctools/docs-components/src/styles/mixins.scss"],
4
+ "sourcesContent": ["@import '../../../../styles/mixins';\n\n.dc-settings-control {\n &__text-size-control {\n display: flex;\n align-items: center;\n }\n\n &__text-size-button {\n &_s {\n @include text-size(body-1);\n }\n &_m {\n @include text-size(body-2);\n }\n &_l {\n @include text-size(body-3);\n }\n }\n\n &__text-size-button-icon {\n &_active {\n color: var(--g-color-base-brand);\n }\n }\n\n &__popup {\n width: 230px;\n @include text-size(body-1);\n }\n\n &__list {\n padding: 4px 0;\n width: 230px;\n\n .yc-list__item_active {\n background: transparent;\n }\n }\n\n &__list-icon {\n margin-right: 8px;\n }\n\n &__list-item {\n display: flex;\n padding: 12px;\n width: 100%;\n }\n\n &__list-item-description {\n color: var(--g-color-text-secondary);\n }\n\n &__list-item-control {\n display: flex;\n align-items: center;\n margin-left: auto;\n }\n}\n", ".dc-settings-control__text-size-control {\n display: flex;\n align-items: center;\n}\n.dc-settings-control__text-size-button_s {\n font-size: var(--g-text-body-1-font-size);\n line-height: var(--g-text-body-1-line-height);\n}\n.dc-settings-control__text-size-button_m {\n font-size: var(--g-text-body-2-font-size);\n line-height: var(--g-text-body-2-line-height);\n}\n.dc-settings-control__text-size-button_l {\n font-size: var(--g-text-body-3-font-size);\n line-height: var(--g-text-body-3-line-height);\n}\n.dc-settings-control__text-size-button-icon_active {\n color: var(--g-color-base-brand);\n}\n.dc-settings-control__popup {\n width: 230px;\n font-size: var(--g-text-body-1-font-size);\n line-height: var(--g-text-body-1-line-height);\n}\n.dc-settings-control__list {\n padding: 4px 0;\n width: 230px;\n}\n.dc-settings-control__list .yc-list__item_active {\n background: transparent;\n}\n.dc-settings-control__list-icon {\n margin-right: 8px;\n}\n.dc-settings-control__list-item {\n display: flex;\n padding: 12px;\n width: 100%;\n}\n.dc-settings-control__list-item-description {\n color: var(--g-color-text-secondary);\n}\n.dc-settings-control__list-item-control {\n display: flex;\n align-items: center;\n margin-left: auto;\n}\n/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VSb290IjoiL1VzZXJzLzN5M2swL2RvY3Rvb2xzL2RvY3MtY29tcG9uZW50cy9zcmMvY29tcG9uZW50cy9Db250cm9scy9zaW5nbGUtY29udHJvbHMvU2V0dGluZ3NDb250cm9sIiwic291cmNlcyI6WyJTZXR0aW5nc0NvbnRyb2wuc2NzcyIsIi4uLy4uLy4uLy4uL3N0eWxlcy9taXhpbnMuc2NzcyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFHSTtFQUNJO0VBQ0E7O0FBSUE7RUNOSjtFQUNBOztBRFFJO0VDVEo7RUFDQTs7QURXSTtFQ1pKO0VBQ0E7O0FEaUJJO0VBQ0k7O0FBSVI7RUFDSTtFQ3hCSjtFQUNBOztBRDJCQTtFQUNJO0VBQ0E7O0FBRUE7RUFDSTs7QUFJUjtFQUNJOztBQUdKO0VBQ0k7RUFDQTtFQUNBOztBQUdKO0VBQ0k7O0FBR0o7RUFDSTtFQUNBO0VBQ0EiLCJzb3VyY2VzQ29udGVudCI6WyJAaW1wb3J0ICcuLi8uLi8uLi8uLi9zdHlsZXMvbWl4aW5zJztcblxuLmRjLXNldHRpbmdzLWNvbnRyb2wge1xuICAgICZfX3RleHQtc2l6ZS1jb250cm9sIHtcbiAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICB9XG5cbiAgICAmX190ZXh0LXNpemUtYnV0dG9uIHtcbiAgICAgICAgJl9zIHtcbiAgICAgICAgICAgIEBpbmNsdWRlIHRleHQtc2l6ZShib2R5LTEpO1xuICAgICAgICB9XG4gICAgICAgICZfbSB7XG4gICAgICAgICAgICBAaW5jbHVkZSB0ZXh0LXNpemUoYm9keS0yKTtcbiAgICAgICAgfVxuICAgICAgICAmX2wge1xuICAgICAgICAgICAgQGluY2x1ZGUgdGV4dC1zaXplKGJvZHktMyk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICAmX190ZXh0LXNpemUtYnV0dG9uLWljb24ge1xuICAgICAgICAmX2FjdGl2ZSB7XG4gICAgICAgICAgICBjb2xvcjogdmFyKC0tZy1jb2xvci1iYXNlLWJyYW5kKTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgICZfX3BvcHVwIHtcbiAgICAgICAgd2lkdGg6IDIzMHB4O1xuICAgICAgICBAaW5jbHVkZSB0ZXh0LXNpemUoYm9keS0xKTtcbiAgICB9XG5cbiAgICAmX19saXN0IHtcbiAgICAgICAgcGFkZGluZzogNHB4IDA7XG4gICAgICAgIHdpZHRoOiAyMzBweDtcblxuICAgICAgICAueWMtbGlzdF9faXRlbV9hY3RpdmUge1xuICAgICAgICAgICAgYmFja2dyb3VuZDogdHJhbnNwYXJlbnQ7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICAmX19saXN0LWljb24ge1xuICAgICAgICBtYXJnaW4tcmlnaHQ6IDhweDtcbiAgICB9XG5cbiAgICAmX19saXN0LWl0ZW0ge1xuICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICBwYWRkaW5nOiAxMnB4O1xuICAgICAgICB3aWR0aDogMTAwJTtcbiAgICB9XG5cbiAgICAmX19saXN0LWl0ZW0tZGVzY3JpcHRpb24ge1xuICAgICAgICBjb2xvcjogdmFyKC0tZy1jb2xvci10ZXh0LXNlY29uZGFyeSk7XG4gICAgfVxuXG4gICAgJl9fbGlzdC1pdGVtLWNvbnRyb2wge1xuICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xuICAgICAgICBtYXJnaW4tbGVmdDogYXV0bztcbiAgICB9XG59XG4iLCJAaW1wb3J0ICcuL3ZhcmlhYmxlcyc7XG5cbkBtaXhpbiB0ZXh0LXNpemUoJG5hbWUpIHtcbiAgICBmb250LXNpemU6IHZhcigtLWctdGV4dC0jeyRuYW1lfS1mb250LXNpemUpO1xuICAgIGxpbmUtaGVpZ2h0OiB2YXIoLS1nLXRleHQtI3skbmFtZX0tbGluZS1oZWlnaHQpO1xufVxuXG5AbWl4aW4gcmVzZXQtbGlzdC1zdHlsZSgpIHtcbiAgICBtYXJnaW46IDA7XG4gICAgcGFkZGluZzogMDtcbiAgICBsaXN0LXN0eWxlOiBub25lO1xufVxuXG5AbWl4aW4gZml4QW5jaG9yUG9zaXRpb24oJG9mZnNldDogMHB4KSB7XG4gICAgcGFkZGluZy10b3A6IGNhbGModmFyKC0tZGMtaGVhZGVyLWhlaWdodCwgI3skaGVhZGVySGVpZ2h0fSkpO1xuICAgIG1hcmdpbi10b3A6IGNhbGMoI3skb2Zmc2V0fSAtIHZhcigtLWRjLWhlYWRlci1oZWlnaHQsICN7JGhlYWRlckhlaWdodH0pKTtcbn1cblxuQG1peGluIHJlc2V0LWxpbmstc3R5bGUoKSB7XG4gICAgY29sb3I6IGluaGVyaXQ7XG4gICAgdGV4dC1kZWNvcmF0aW9uOiBub25lO1xufVxuXG5AbWl4aW4gaXNsYW5kcy1mb2N1cygpIHtcbiAgICBvdXRsaW5lOiBub25lO1xuXG4gICAgLnV0aWxpdHlmb2N1cyAmOmZvY3VzIHtcbiAgICAgICAgb3V0bGluZTogMnB4IHNvbGlkICNmZmRiNGQ7XG4gICAgfVxufVxuXG5AbWl4aW4gbGluaygpIHtcbiAgICBAaW5jbHVkZSBpc2xhbmRzLWZvY3VzKCk7XG5cbiAgICBjb2xvcjogdmFyKC0tZy1jb2xvci10ZXh0LWxpbmspO1xuICAgIHRleHQtZGVjb3JhdGlvbjogbm9uZTtcbiAgICBjdXJzb3I6IHBvaW50ZXI7XG5cbiAgICAmOmhvdmVyLFxuICAgICY6YWN0aXZlIHtcbiAgICAgICAgY29sb3I6IHZhcigtLWctY29sb3ItdGV4dC1saW5rLWhvdmVyKTtcbiAgICB9XG59XG5cbkBtaXhpbiBoZWFkaW5nMSgpIHtcbiAgICBAaW5jbHVkZSB0ZXh0LXNpemUoZGlzcGxheS0zKTtcbiAgICBmb250LXdlaWdodDogNTAwO1xuXG4gICAgQG1lZGlhIChtYXgtd2lkdGg6IG1hcC1nZXQoJHNjcmVlbkJyZWFrcG9pbnRzLCAnbWQnKSAtIDEpIHtcbiAgICAgICAgQGluY2x1ZGUgdGV4dC1zaXplKGRpc3BsYXktMik7XG4gICAgfVxufVxuXG5AbWl4aW4gaGVhZGluZzIoKSB7XG4gICAgQGluY2x1ZGUgdGV4dC1zaXplKGRpc3BsYXktMSk7XG4gICAgZm9udC13ZWlnaHQ6IDUwMDtcbn1cblxuQG1peGluIGhlYWRpbmczKCkge1xuICAgIEBpbmNsdWRlIHRleHQtc2l6ZShoZWFkZXItMik7XG4gICAgZm9udC13ZWlnaHQ6IDUwMDtcbn1cblxuQG1peGluIGhlYWRpbmc0KCkge1xuICAgIEBpbmNsdWRlIHRleHQtc2l6ZShoZWFkZXItMSk7XG4gICAgZm9udC13ZWlnaHQ6IDUwMDtcbn1cblxuQG1peGluIGhlYWRpbmc1KCkge1xuICAgIEBpbmNsdWRlIHRleHQtc2l6ZShib2R5LTMpO1xuICAgIGZvbnQtd2VpZ2h0OiA1MDA7XG59XG5cbkBtaXhpbiBoZWFkaW5nNigpIHtcbiAgICBAaW5jbHVkZSB0ZXh0LXNpemUoYm9keS0zKTtcbiAgICBmb250LXdlaWdodDogNDAwO1xufVxuXG5AbWl4aW4gY29udHJpYnV0b3JzLXRleHQoKSB7XG4gICAgZm9udC1zaXplOiAxM3B4O1xuICAgIGZvbnQtd2VpZ2h0OiA0MDA7XG4gICAgbWFyZ2luLXJpZ2h0OiA1cHg7XG4gICAgYWxpZ24tc2VsZjogY2VudGVyO1xufVxuXG5AbWl4aW4gdGV4dC1ib2R5LTEoKSB7XG4gICAgZm9udC1zaXplOiB2YXIoLS1nLXRleHQtYm9keS0xLWZvbnQtc2l6ZSk7XG4gICAgbGluZS1oZWlnaHQ6IHZhcigtLWctdGV4dC1ib2R5LTEtbGluZS1oZWlnaHQpO1xuICAgIGZvbnQtd2VpZ2h0OiB2YXIoLS1nLXRleHQtYm9keS1mb250LXdlaWdodCk7XG59XG5cbkBtaXhpbiBkZXNrdG9wLW9ubHkoKSB7XG4gICAgQG1lZGlhIChtYXgtd2lkdGg6IG1hcC1nZXQoJHNjcmVlbkJyZWFrcG9pbnRzLCAnbWQnKSAtIDEpIHtcbiAgICAgICAgZGlzcGxheTogbm9uZTtcbiAgICB9XG59XG5cbkBtaXhpbiBkZXNrdG9wLXRhYmxldC1vbmx5KCkge1xuICAgIEBtZWRpYSAobWF4LXdpZHRoOiBtYXAtZ2V0KCRzY3JlZW5CcmVha3BvaW50cywgJ3NtJykgLSAxKSB7XG4gICAgICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgfVxufVxuXG5AbWl4aW4gbW9iaWxlLXRhYmxldC1vbmx5KCkge1xuICAgIEBtZWRpYSAobWluLXdpZHRoOiBtYXAtZ2V0KCRzY3JlZW5CcmVha3BvaW50cywgJ21kJykpIHtcbiAgICAgICAgZGlzcGxheTogbm9uZTtcbiAgICB9XG59XG5cbkBtaXhpbiBtb2JpbGUtb25seSgpIHtcbiAgICBAbWVkaWEgKG1pbi13aWR0aDogbWFwLWdldCgkc2NyZWVuQnJlYWtwb2ludHMsICdzbScpKSB7XG4gICAgICAgIGRpc3BsYXk6IG5vbmU7XG4gICAgfVxufVxuIl19 */", "@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"],
5
+ "mappings": ";AAGI,CAAA;AACI,WAAA;AACA,eAAA;ACFR;ADMQ,CAAA;AENJ,aAAA,IAAA;AACA,eAAA,IAAA;ADGJ;ADKQ,CAAA;AETJ,aAAA,IAAA;AACA,eAAA,IAAA;ADOJ;ADIQ,CAAA;AEZJ,aAAA,IAAA;AACA,eAAA,IAAA;ADWJ;ADMQ,CAAA;AACI,SAAA,IAAA;ACJZ;ADQI,CAAA;AACI,SAAA;AExBJ,aAAA,IAAA;AACA,eAAA,IAAA;ADmBJ;ADQI,CAAA;AACI,WAAA,IAAA;AACA,SAAA;ACNR;ADQQ,CAJJ,0BAII,CAAA;AACI,cAAA;ACNZ;ADUI,CAAA;AACI,gBAAA;ACRR;ADWI,CAAA;AACI,WAAA;AACA,WAAA;AACA,SAAA;ACTR;ADYI,CAAA;AACI,SAAA,IAAA;ACVR;ADaI,CAAA;AACI,WAAA;AACA,eAAA;AACA,eAAA;ACXR;",
6
+ "names": []
7
+ }
@@ -0,0 +1,167 @@
1
+ // src/components/Controls/single-controls/SettingsControl/SettingsControl.tsx
2
+ import React, { useCallback, useContext, useRef, useState } from "react";
3
+ import { Button, Icon, List, Popup, Switch } from "@gravity-ui/uikit";
4
+ import cn from "bem-cn-lite";
5
+ import { useTranslation } from "../../../../hooks";
6
+ import { TextSizes, Theme } from "../../../../models";
7
+ import { Control } from "../../../Control";
8
+ import { ControlsLayoutContext } from "../../ControlsLayout";
9
+ import { getPopupPosition } from "../utils";
10
+ import SettingsIcon from "@gravity-ui/icons/svgs/gear.svg";
11
+ import "./SettingsControl.css";
12
+ var ITEM_HEIGHT = 48;
13
+ var b = cn("dc-settings-control");
14
+ var SettingsControl = (props) => {
15
+ const { t } = useTranslation("controls");
16
+ const { controlClassName, controlSize, isVerticalView, popupPosition } = useContext(ControlsLayoutContext);
17
+ const {
18
+ textSize,
19
+ theme,
20
+ wideFormat,
21
+ showMiniToc,
22
+ fullScreen,
23
+ singlePage,
24
+ onChangeTheme,
25
+ onChangeWideFormat,
26
+ onChangeShowMiniToc,
27
+ onChangeTextSize
28
+ } = props;
29
+ const controlRef = useRef(null);
30
+ const [isVisiblePopup, setIsVisiblePopup] = useState(false);
31
+ const showPopup = () => setIsVisiblePopup(true);
32
+ const hidePopup = () => setIsVisiblePopup(false);
33
+ const _onChangeTextSize = useCallback(
34
+ (textSizeKey) => () => {
35
+ if (onChangeTextSize) {
36
+ onChangeTextSize(textSizeKey);
37
+ }
38
+ },
39
+ [onChangeTextSize]
40
+ );
41
+ const _onChangeTheme = useCallback(() => {
42
+ if (onChangeTheme) {
43
+ onChangeTheme(theme === Theme.Dark ? Theme.Light : Theme.Dark);
44
+ }
45
+ }, [theme, onChangeTheme]);
46
+ const _onChangeWideFormat = useCallback(() => {
47
+ if (onChangeWideFormat) {
48
+ onChangeWideFormat(!wideFormat);
49
+ }
50
+ }, [wideFormat, onChangeWideFormat]);
51
+ const _onChangeShowMiniToc = useCallback(() => {
52
+ if (onChangeShowMiniToc) {
53
+ onChangeShowMiniToc(!showMiniToc);
54
+ }
55
+ }, [showMiniToc, onChangeShowMiniToc]);
56
+ const getSettingsItems = useCallback(() => {
57
+ const allTextSizes = Object.values(TextSizes);
58
+ const showMiniTocDisabled = fullScreen || singlePage;
59
+ return [
60
+ onChangeWideFormat ? {
61
+ text: t("label_wide_format"),
62
+ description: t(
63
+ `description_wide_format_${wideFormat ? "enabled" : "disabled"}`
64
+ ),
65
+ control: /* @__PURE__ */ React.createElement(Switch, { checked: wideFormat, onChange: _onChangeWideFormat })
66
+ } : null,
67
+ onChangeShowMiniToc ? {
68
+ text: t("label_show_mini_toc"),
69
+ description: t("description_show_mini_toc"),
70
+ control: /* @__PURE__ */ React.createElement(
71
+ Switch,
72
+ {
73
+ disabled: showMiniTocDisabled,
74
+ checked: showMiniToc,
75
+ onChange: _onChangeShowMiniToc
76
+ }
77
+ )
78
+ } : null,
79
+ onChangeTheme ? {
80
+ text: t("label_dark_theme"),
81
+ description: Theme.Light === theme ? t("description_disabled_dark_theme") : t("description_enabled_dark_theme"),
82
+ control: /* @__PURE__ */ React.createElement(Switch, { checked: theme === Theme.Dark, onChange: _onChangeTheme })
83
+ } : null,
84
+ onChangeTextSize ? {
85
+ text: t("label_text_size"),
86
+ description: t(`description_${textSize}_text_size`),
87
+ control: /* @__PURE__ */ React.createElement("div", { className: b("text-size-control") }, allTextSizes.map((textSizeKey) => /* @__PURE__ */ React.createElement(
88
+ Button,
89
+ {
90
+ key: textSizeKey,
91
+ className: b("text-size-button", {
92
+ [textSizeKey]: true
93
+ }),
94
+ view: "flat",
95
+ onClick: _onChangeTextSize(textSizeKey)
96
+ },
97
+ /* @__PURE__ */ React.createElement(
98
+ Button.Icon,
99
+ {
100
+ className: b("text-size-button-icon", {
101
+ active: textSize === textSizeKey
102
+ })
103
+ },
104
+ "A"
105
+ )
106
+ )))
107
+ } : null
108
+ ].filter(Boolean);
109
+ }, [
110
+ t,
111
+ textSize,
112
+ theme,
113
+ wideFormat,
114
+ showMiniToc,
115
+ fullScreen,
116
+ singlePage,
117
+ _onChangeTheme,
118
+ _onChangeWideFormat,
119
+ _onChangeShowMiniToc,
120
+ _onChangeTextSize,
121
+ onChangeWideFormat,
122
+ onChangeShowMiniToc,
123
+ onChangeTheme,
124
+ onChangeTextSize
125
+ ]);
126
+ const settingsItems = getSettingsItems();
127
+ return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(
128
+ Control,
129
+ {
130
+ ref: controlRef,
131
+ size: controlSize,
132
+ onClick: showPopup,
133
+ className: controlClassName,
134
+ isVerticalView,
135
+ tooltipText: t("settings-text"),
136
+ popupPosition,
137
+ icon: (args) => /* @__PURE__ */ React.createElement(Icon, { data: SettingsIcon, ...args })
138
+ }
139
+ ), /* @__PURE__ */ React.createElement(
140
+ Popup,
141
+ {
142
+ anchorRef: controlRef,
143
+ open: isVisiblePopup,
144
+ contentClassName: b("popup"),
145
+ onOutsideClick: hidePopup,
146
+ placement: getPopupPosition(isVerticalView)
147
+ },
148
+ /* @__PURE__ */ React.createElement(
149
+ List,
150
+ {
151
+ items: settingsItems,
152
+ className: b("list"),
153
+ itemHeight: ITEM_HEIGHT,
154
+ itemsHeight: ITEM_HEIGHT * settingsItems.length,
155
+ filterable: false,
156
+ renderItem: (item) => {
157
+ return /* @__PURE__ */ React.createElement("div", { className: b("list-item") }, /* @__PURE__ */ React.createElement("div", { className: b("list-item-content") }, /* @__PURE__ */ React.createElement("div", { className: b("list-item-text") }, item.text), /* @__PURE__ */ React.createElement("div", { className: b("list-item-description") }, item.description)), /* @__PURE__ */ React.createElement("div", { className: b("list-item-control") }, item.control));
158
+ }
159
+ }
160
+ )
161
+ ));
162
+ };
163
+ var SettingsControl_default = SettingsControl;
164
+ export {
165
+ SettingsControl_default as default
166
+ };
167
+ //# sourceMappingURL=SettingsControl.js.map