@cloud-ru/uikit-product-mobile-layout 0.20.7

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 (264) hide show
  1. package/CHANGELOG.md +1762 -0
  2. package/LICENSE +201 -0
  3. package/README.md +8 -0
  4. package/dist/cjs/components/AdaptiveLayout/AdaptiveLayout.d.ts +23 -0
  5. package/dist/cjs/components/AdaptiveLayout/AdaptiveLayout.js +68 -0
  6. package/dist/cjs/components/AdaptiveLayout/index.d.ts +1 -0
  7. package/dist/cjs/components/AdaptiveLayout/index.js +17 -0
  8. package/dist/cjs/components/MobileBlockBasic/MobileBlockBasic.d.ts +3 -0
  9. package/dist/cjs/components/MobileBlockBasic/MobileBlockBasic.js +13 -0
  10. package/dist/cjs/components/MobileBlockBasic/index.d.ts +1 -0
  11. package/dist/cjs/components/MobileBlockBasic/index.js +17 -0
  12. package/dist/cjs/components/MobileBlockBasic/styles.module.css +3 -0
  13. package/dist/cjs/components/MobileCardBanner/MobileCardBanner.d.ts +14 -0
  14. package/dist/cjs/components/MobileCardBanner/MobileCardBanner.js +31 -0
  15. package/dist/cjs/components/MobileCardBanner/index.d.ts +1 -0
  16. package/dist/cjs/components/MobileCardBanner/index.js +17 -0
  17. package/dist/cjs/components/MobileCardBanner/styles.module.css +52 -0
  18. package/dist/cjs/components/MobileEmptyBlock/MobileEmptyBlock.d.ts +17 -0
  19. package/dist/cjs/components/MobileEmptyBlock/MobileEmptyBlock.js +29 -0
  20. package/dist/cjs/components/MobileEmptyBlock/components/Footer/Footer.d.ts +14 -0
  21. package/dist/cjs/components/MobileEmptyBlock/components/Footer/Footer.js +16 -0
  22. package/dist/cjs/components/MobileEmptyBlock/components/Footer/hooks.d.ts +6 -0
  23. package/dist/cjs/components/MobileEmptyBlock/components/Footer/hooks.js +13 -0
  24. package/dist/cjs/components/MobileEmptyBlock/components/Footer/index.d.ts +1 -0
  25. package/dist/cjs/components/MobileEmptyBlock/components/Footer/index.js +17 -0
  26. package/dist/cjs/components/MobileEmptyBlock/components/Footer/styles.module.css +7 -0
  27. package/dist/cjs/components/MobileEmptyBlock/components/index.d.ts +1 -0
  28. package/dist/cjs/components/MobileEmptyBlock/components/index.js +17 -0
  29. package/dist/cjs/components/MobileEmptyBlock/index.d.ts +1 -0
  30. package/dist/cjs/components/MobileEmptyBlock/index.js +17 -0
  31. package/dist/cjs/components/MobileEmptyBlock/styles.module.css +61 -0
  32. package/dist/cjs/components/MobilePageCatalog/MobilePageCatalog.d.ts +9 -0
  33. package/dist/cjs/components/MobilePageCatalog/MobilePageCatalog.js +26 -0
  34. package/dist/cjs/components/MobilePageCatalog/index.d.ts +1 -0
  35. package/dist/cjs/components/MobilePageCatalog/index.js +17 -0
  36. package/dist/cjs/components/MobilePageCatalog/styles.module.css +15 -0
  37. package/dist/cjs/components/MobilePageForm/MobilePageForm.d.ts +17 -0
  38. package/dist/cjs/components/MobilePageForm/MobilePageForm.js +72 -0
  39. package/dist/cjs/components/MobilePageForm/hooks.d.ts +6 -0
  40. package/dist/cjs/components/MobilePageForm/hooks.js +13 -0
  41. package/dist/cjs/components/MobilePageForm/index.d.ts +1 -0
  42. package/dist/cjs/components/MobilePageForm/index.js +17 -0
  43. package/dist/cjs/components/MobilePageForm/styles.module.css +86 -0
  44. package/dist/cjs/components/MobilePageServices/MobilePageServices.d.ts +10 -0
  45. package/dist/cjs/components/MobilePageServices/MobilePageServices.js +26 -0
  46. package/dist/cjs/components/MobilePageServices/index.d.ts +1 -0
  47. package/dist/cjs/components/MobilePageServices/index.js +17 -0
  48. package/dist/cjs/components/MobilePageServices/styles.module.css +25 -0
  49. package/dist/cjs/components/index.d.ts +7 -0
  50. package/dist/cjs/components/index.js +23 -0
  51. package/dist/cjs/helperComponents/Actions/ActionView.d.ts +10 -0
  52. package/dist/cjs/helperComponents/Actions/ActionView.js +58 -0
  53. package/dist/cjs/helperComponents/Actions/DesktopActions.d.ts +2 -0
  54. package/dist/cjs/helperComponents/Actions/DesktopActions.js +19 -0
  55. package/dist/cjs/helperComponents/Actions/MobileActions.d.ts +2 -0
  56. package/dist/cjs/helperComponents/Actions/MobileActions.js +107 -0
  57. package/dist/cjs/helperComponents/Actions/constants.d.ts +11 -0
  58. package/dist/cjs/helperComponents/Actions/constants.js +14 -0
  59. package/dist/cjs/helperComponents/Actions/helpers.d.ts +2 -0
  60. package/dist/cjs/helperComponents/Actions/helpers.js +6 -0
  61. package/dist/cjs/helperComponents/Actions/index.d.ts +3 -0
  62. package/dist/cjs/helperComponents/Actions/index.js +19 -0
  63. package/dist/cjs/helperComponents/Actions/styles.module.css +35 -0
  64. package/dist/cjs/helperComponents/Actions/types.d.ts +38 -0
  65. package/dist/cjs/helperComponents/Actions/types.js +2 -0
  66. package/dist/cjs/helperComponents/ButtonDropdown/ButtonDropdown.d.ts +8 -0
  67. package/dist/cjs/helperComponents/ButtonDropdown/ButtonDropdown.js +13 -0
  68. package/dist/cjs/helperComponents/ButtonDropdown/index.d.ts +1 -0
  69. package/dist/cjs/helperComponents/ButtonDropdown/index.js +17 -0
  70. package/dist/cjs/helperComponents/ButtonDroplist/ButtonDroplist.d.ts +12 -0
  71. package/dist/cjs/helperComponents/ButtonDroplist/ButtonDroplist.js +21 -0
  72. package/dist/cjs/helperComponents/ButtonDroplist/index.d.ts +1 -0
  73. package/dist/cjs/helperComponents/ButtonDroplist/index.js +17 -0
  74. package/dist/cjs/helperComponents/ButtonKebab/ButtonKebab.d.ts +8 -0
  75. package/dist/cjs/helperComponents/ButtonKebab/ButtonKebab.js +15 -0
  76. package/dist/cjs/helperComponents/ButtonKebab/index.d.ts +1 -0
  77. package/dist/cjs/helperComponents/ButtonKebab/index.js +17 -0
  78. package/dist/cjs/helperComponents/Headline/Headline.d.ts +9 -0
  79. package/dist/cjs/helperComponents/Headline/Headline.js +11 -0
  80. package/dist/cjs/helperComponents/Headline/index.d.ts +1 -0
  81. package/dist/cjs/helperComponents/Headline/index.js +17 -0
  82. package/dist/cjs/helperComponents/Headline/styles.module.css +51 -0
  83. package/dist/cjs/helperComponents/SidebarSelect/SidebarSelect.d.ts +13 -0
  84. package/dist/cjs/helperComponents/SidebarSelect/SidebarSelect.js +51 -0
  85. package/dist/cjs/helperComponents/SidebarSelect/hooks/index.d.ts +3 -0
  86. package/dist/cjs/helperComponents/SidebarSelect/hooks/index.js +9 -0
  87. package/dist/cjs/helperComponents/SidebarSelect/hooks/useItemsContent.d.ts +3 -0
  88. package/dist/cjs/helperComponents/SidebarSelect/hooks/useItemsContent.js +59 -0
  89. package/dist/cjs/helperComponents/SidebarSelect/hooks/useSearchFilter.d.ts +7 -0
  90. package/dist/cjs/helperComponents/SidebarSelect/hooks/useSearchFilter.js +42 -0
  91. package/dist/cjs/helperComponents/SidebarSelect/hooks/useSelectedItem.d.ts +7 -0
  92. package/dist/cjs/helperComponents/SidebarSelect/hooks/useSelectedItem.js +24 -0
  93. package/dist/cjs/helperComponents/SidebarSelect/index.d.ts +1 -0
  94. package/dist/cjs/helperComponents/SidebarSelect/index.js +17 -0
  95. package/dist/cjs/helperComponents/SidebarSelect/styles.module.css +19 -0
  96. package/dist/cjs/helperComponents/SidebarSelect/types.d.ts +1 -0
  97. package/dist/cjs/helperComponents/SidebarSelect/types.js +2 -0
  98. package/dist/cjs/helperComponents/index.d.ts +3 -0
  99. package/dist/cjs/helperComponents/index.js +19 -0
  100. package/dist/cjs/helpers/index.d.ts +1 -0
  101. package/dist/cjs/helpers/index.js +17 -0
  102. package/dist/cjs/helpers/useGetButtonLabel.d.ts +2 -0
  103. package/dist/cjs/helpers/useGetButtonLabel.js +10 -0
  104. package/dist/cjs/index.d.ts +1 -0
  105. package/dist/cjs/index.js +17 -0
  106. package/dist/esm/components/AdaptiveLayout/AdaptiveLayout.d.ts +23 -0
  107. package/dist/esm/components/AdaptiveLayout/AdaptiveLayout.js +60 -0
  108. package/dist/esm/components/AdaptiveLayout/index.d.ts +1 -0
  109. package/dist/esm/components/AdaptiveLayout/index.js +1 -0
  110. package/dist/esm/components/MobileBlockBasic/MobileBlockBasic.d.ts +3 -0
  111. package/dist/esm/components/MobileBlockBasic/MobileBlockBasic.js +7 -0
  112. package/dist/esm/components/MobileBlockBasic/index.d.ts +1 -0
  113. package/dist/esm/components/MobileBlockBasic/index.js +1 -0
  114. package/dist/esm/components/MobileBlockBasic/styles.module.css +3 -0
  115. package/dist/esm/components/MobileCardBanner/MobileCardBanner.d.ts +14 -0
  116. package/dist/esm/components/MobileCardBanner/MobileCardBanner.js +25 -0
  117. package/dist/esm/components/MobileCardBanner/index.d.ts +1 -0
  118. package/dist/esm/components/MobileCardBanner/index.js +1 -0
  119. package/dist/esm/components/MobileCardBanner/styles.module.css +52 -0
  120. package/dist/esm/components/MobileEmptyBlock/MobileEmptyBlock.d.ts +17 -0
  121. package/dist/esm/components/MobileEmptyBlock/MobileEmptyBlock.js +23 -0
  122. package/dist/esm/components/MobileEmptyBlock/components/Footer/Footer.d.ts +14 -0
  123. package/dist/esm/components/MobileEmptyBlock/components/Footer/Footer.js +10 -0
  124. package/dist/esm/components/MobileEmptyBlock/components/Footer/hooks.d.ts +6 -0
  125. package/dist/esm/components/MobileEmptyBlock/components/Footer/hooks.js +10 -0
  126. package/dist/esm/components/MobileEmptyBlock/components/Footer/index.d.ts +1 -0
  127. package/dist/esm/components/MobileEmptyBlock/components/Footer/index.js +1 -0
  128. package/dist/esm/components/MobileEmptyBlock/components/Footer/styles.module.css +7 -0
  129. package/dist/esm/components/MobileEmptyBlock/components/index.d.ts +1 -0
  130. package/dist/esm/components/MobileEmptyBlock/components/index.js +1 -0
  131. package/dist/esm/components/MobileEmptyBlock/index.d.ts +1 -0
  132. package/dist/esm/components/MobileEmptyBlock/index.js +1 -0
  133. package/dist/esm/components/MobileEmptyBlock/styles.module.css +61 -0
  134. package/dist/esm/components/MobilePageCatalog/MobilePageCatalog.d.ts +9 -0
  135. package/dist/esm/components/MobilePageCatalog/MobilePageCatalog.js +20 -0
  136. package/dist/esm/components/MobilePageCatalog/index.d.ts +1 -0
  137. package/dist/esm/components/MobilePageCatalog/index.js +1 -0
  138. package/dist/esm/components/MobilePageCatalog/styles.module.css +15 -0
  139. package/dist/esm/components/MobilePageForm/MobilePageForm.d.ts +17 -0
  140. package/dist/esm/components/MobilePageForm/MobilePageForm.js +65 -0
  141. package/dist/esm/components/MobilePageForm/hooks.d.ts +6 -0
  142. package/dist/esm/components/MobilePageForm/hooks.js +10 -0
  143. package/dist/esm/components/MobilePageForm/index.d.ts +1 -0
  144. package/dist/esm/components/MobilePageForm/index.js +1 -0
  145. package/dist/esm/components/MobilePageForm/styles.module.css +86 -0
  146. package/dist/esm/components/MobilePageServices/MobilePageServices.d.ts +10 -0
  147. package/dist/esm/components/MobilePageServices/MobilePageServices.js +20 -0
  148. package/dist/esm/components/MobilePageServices/index.d.ts +1 -0
  149. package/dist/esm/components/MobilePageServices/index.js +1 -0
  150. package/dist/esm/components/MobilePageServices/styles.module.css +25 -0
  151. package/dist/esm/components/index.d.ts +7 -0
  152. package/dist/esm/components/index.js +7 -0
  153. package/dist/esm/helperComponents/Actions/ActionView.d.ts +10 -0
  154. package/dist/esm/helperComponents/Actions/ActionView.js +55 -0
  155. package/dist/esm/helperComponents/Actions/DesktopActions.d.ts +2 -0
  156. package/dist/esm/helperComponents/Actions/DesktopActions.js +13 -0
  157. package/dist/esm/helperComponents/Actions/MobileActions.d.ts +2 -0
  158. package/dist/esm/helperComponents/Actions/MobileActions.js +101 -0
  159. package/dist/esm/helperComponents/Actions/constants.d.ts +11 -0
  160. package/dist/esm/helperComponents/Actions/constants.js +11 -0
  161. package/dist/esm/helperComponents/Actions/helpers.d.ts +2 -0
  162. package/dist/esm/helperComponents/Actions/helpers.js +3 -0
  163. package/dist/esm/helperComponents/Actions/index.d.ts +3 -0
  164. package/dist/esm/helperComponents/Actions/index.js +3 -0
  165. package/dist/esm/helperComponents/Actions/styles.module.css +35 -0
  166. package/dist/esm/helperComponents/Actions/types.d.ts +38 -0
  167. package/dist/esm/helperComponents/Actions/types.js +1 -0
  168. package/dist/esm/helperComponents/ButtonDropdown/ButtonDropdown.d.ts +8 -0
  169. package/dist/esm/helperComponents/ButtonDropdown/ButtonDropdown.js +10 -0
  170. package/dist/esm/helperComponents/ButtonDropdown/index.d.ts +1 -0
  171. package/dist/esm/helperComponents/ButtonDropdown/index.js +1 -0
  172. package/dist/esm/helperComponents/ButtonDroplist/ButtonDroplist.d.ts +12 -0
  173. package/dist/esm/helperComponents/ButtonDroplist/ButtonDroplist.js +18 -0
  174. package/dist/esm/helperComponents/ButtonDroplist/index.d.ts +1 -0
  175. package/dist/esm/helperComponents/ButtonDroplist/index.js +1 -0
  176. package/dist/esm/helperComponents/ButtonKebab/ButtonKebab.d.ts +8 -0
  177. package/dist/esm/helperComponents/ButtonKebab/ButtonKebab.js +12 -0
  178. package/dist/esm/helperComponents/ButtonKebab/index.d.ts +1 -0
  179. package/dist/esm/helperComponents/ButtonKebab/index.js +1 -0
  180. package/dist/esm/helperComponents/Headline/Headline.d.ts +9 -0
  181. package/dist/esm/helperComponents/Headline/Headline.js +5 -0
  182. package/dist/esm/helperComponents/Headline/index.d.ts +1 -0
  183. package/dist/esm/helperComponents/Headline/index.js +1 -0
  184. package/dist/esm/helperComponents/Headline/styles.module.css +51 -0
  185. package/dist/esm/helperComponents/SidebarSelect/SidebarSelect.d.ts +13 -0
  186. package/dist/esm/helperComponents/SidebarSelect/SidebarSelect.js +45 -0
  187. package/dist/esm/helperComponents/SidebarSelect/hooks/index.d.ts +3 -0
  188. package/dist/esm/helperComponents/SidebarSelect/hooks/index.js +3 -0
  189. package/dist/esm/helperComponents/SidebarSelect/hooks/useItemsContent.d.ts +3 -0
  190. package/dist/esm/helperComponents/SidebarSelect/hooks/useItemsContent.js +56 -0
  191. package/dist/esm/helperComponents/SidebarSelect/hooks/useSearchFilter.d.ts +7 -0
  192. package/dist/esm/helperComponents/SidebarSelect/hooks/useSearchFilter.js +38 -0
  193. package/dist/esm/helperComponents/SidebarSelect/hooks/useSelectedItem.d.ts +7 -0
  194. package/dist/esm/helperComponents/SidebarSelect/hooks/useSelectedItem.js +21 -0
  195. package/dist/esm/helperComponents/SidebarSelect/index.d.ts +1 -0
  196. package/dist/esm/helperComponents/SidebarSelect/index.js +1 -0
  197. package/dist/esm/helperComponents/SidebarSelect/styles.module.css +19 -0
  198. package/dist/esm/helperComponents/SidebarSelect/types.d.ts +1 -0
  199. package/dist/esm/helperComponents/SidebarSelect/types.js +1 -0
  200. package/dist/esm/helperComponents/index.d.ts +3 -0
  201. package/dist/esm/helperComponents/index.js +3 -0
  202. package/dist/esm/helpers/index.d.ts +1 -0
  203. package/dist/esm/helpers/index.js +1 -0
  204. package/dist/esm/helpers/useGetButtonLabel.d.ts +2 -0
  205. package/dist/esm/helpers/useGetButtonLabel.js +7 -0
  206. package/dist/esm/index.d.ts +1 -0
  207. package/dist/esm/index.js +1 -0
  208. package/package.json +61 -0
  209. package/src/components/AdaptiveLayout/AdaptiveLayout.tsx +88 -0
  210. package/src/components/AdaptiveLayout/index.ts +1 -0
  211. package/src/components/MobileBlockBasic/MobileBlockBasic.tsx +11 -0
  212. package/src/components/MobileBlockBasic/index.ts +1 -0
  213. package/src/components/MobileBlockBasic/styles.module.scss +5 -0
  214. package/src/components/MobileCardBanner/MobileCardBanner.tsx +75 -0
  215. package/src/components/MobileCardBanner/index.ts +1 -0
  216. package/src/components/MobileCardBanner/styles.module.scss +48 -0
  217. package/src/components/MobileEmptyBlock/MobileEmptyBlock.tsx +64 -0
  218. package/src/components/MobileEmptyBlock/components/Footer/Footer.tsx +29 -0
  219. package/src/components/MobileEmptyBlock/components/Footer/hooks.tsx +25 -0
  220. package/src/components/MobileEmptyBlock/components/Footer/index.ts +1 -0
  221. package/src/components/MobileEmptyBlock/components/Footer/styles.module.scss +11 -0
  222. package/src/components/MobileEmptyBlock/components/index.ts +1 -0
  223. package/src/components/MobileEmptyBlock/index.ts +1 -0
  224. package/src/components/MobileEmptyBlock/styles.module.scss +75 -0
  225. package/src/components/MobilePageCatalog/MobilePageCatalog.tsx +36 -0
  226. package/src/components/MobilePageCatalog/index.ts +1 -0
  227. package/src/components/MobilePageCatalog/styles.module.scss +17 -0
  228. package/src/components/MobilePageForm/MobilePageForm.tsx +153 -0
  229. package/src/components/MobilePageForm/hooks.tsx +23 -0
  230. package/src/components/MobilePageForm/index.ts +1 -0
  231. package/src/components/MobilePageForm/styles.module.scss +98 -0
  232. package/src/components/MobilePageServices/MobilePageServices.tsx +50 -0
  233. package/src/components/MobilePageServices/index.ts +1 -0
  234. package/src/components/MobilePageServices/styles.module.scss +27 -0
  235. package/src/components/index.ts +7 -0
  236. package/src/helperComponents/Actions/ActionView.tsx +81 -0
  237. package/src/helperComponents/Actions/DesktopActions.tsx +25 -0
  238. package/src/helperComponents/Actions/MobileActions.tsx +196 -0
  239. package/src/helperComponents/Actions/constants.ts +11 -0
  240. package/src/helperComponents/Actions/helpers.ts +5 -0
  241. package/src/helperComponents/Actions/index.ts +3 -0
  242. package/src/helperComponents/Actions/styles.module.scss +42 -0
  243. package/src/helperComponents/Actions/types.ts +39 -0
  244. package/src/helperComponents/ButtonDropdown/ButtonDropdown.tsx +22 -0
  245. package/src/helperComponents/ButtonDropdown/index.ts +1 -0
  246. package/src/helperComponents/ButtonDroplist/ButtonDroplist.tsx +46 -0
  247. package/src/helperComponents/ButtonDroplist/index.ts +1 -0
  248. package/src/helperComponents/ButtonKebab/ButtonKebab.tsx +31 -0
  249. package/src/helperComponents/ButtonKebab/index.ts +1 -0
  250. package/src/helperComponents/Headline/Headline.tsx +29 -0
  251. package/src/helperComponents/Headline/index.ts +1 -0
  252. package/src/helperComponents/Headline/styles.module.scss +49 -0
  253. package/src/helperComponents/SidebarSelect/SidebarSelect.tsx +78 -0
  254. package/src/helperComponents/SidebarSelect/hooks/index.ts +3 -0
  255. package/src/helperComponents/SidebarSelect/hooks/useItemsContent.tsx +89 -0
  256. package/src/helperComponents/SidebarSelect/hooks/useSearchFilter.tsx +53 -0
  257. package/src/helperComponents/SidebarSelect/hooks/useSelectedItem.tsx +35 -0
  258. package/src/helperComponents/SidebarSelect/index.ts +1 -0
  259. package/src/helperComponents/SidebarSelect/styles.module.scss +17 -0
  260. package/src/helperComponents/SidebarSelect/types.ts +1 -0
  261. package/src/helperComponents/index.ts +3 -0
  262. package/src/helpers/index.ts +1 -0
  263. package/src/helpers/useGetButtonLabel.ts +10 -0
  264. package/src/index.ts +1 -0
@@ -0,0 +1,61 @@
1
+ div.emptyBlock{
2
+ background-color:var(--sys-neutral-background1-level, #fdfdfd);
3
+ border-radius:calc(var(--dimension-1m, 8px) + var(--dimension-050m, 4px));
4
+ padding:var(--dimension-4m, 32px) var(--dimension-2m, 16px);
5
+ display:flex;
6
+ align-items:center;
7
+ justify-content:center;
8
+ flex-grow:1;
9
+ }
10
+
11
+ .contentLayout{
12
+ display:flex;
13
+ flex-direction:column;
14
+ }
15
+
16
+ .textWrap{
17
+ display:flex;
18
+ flex-direction:column;
19
+ word-wrap:break-all;
20
+ max-width:100%;
21
+ }
22
+
23
+ .footer{
24
+ position:relative;
25
+ box-sizing:border-box;
26
+ width:100%;
27
+ }
28
+
29
+ .title{
30
+ color:var(--sys-neutral-text-main, #41424e);
31
+ }
32
+
33
+ .description{
34
+ color:var(--sys-neutral-text-support, #6d707f);
35
+ }
36
+
37
+ .infoBlock{
38
+ display:flex;
39
+ box-sizing:border-box;
40
+ flex-direction:column;
41
+ align-items:center;
42
+ width:100%;
43
+ gap:var(--space-info-block-m-container-gap, 16px);
44
+ }
45
+ .infoBlock .footer{
46
+ text-align:center;
47
+ }
48
+ .infoBlock .description,
49
+ .infoBlock .title{
50
+ text-align:center;
51
+ }
52
+ .infoBlock .contentLayout{
53
+ gap:var(--space-info-block-m-container-content-layout-gap, 24px);
54
+ align-items:center;
55
+ width:100%;
56
+ }
57
+ .infoBlock .textWrap{
58
+ gap:var(--space-info-block-m-container-content-layout-text-wrap-gap, 8px);
59
+ align-items:center;
60
+ width:100%;
61
+ }
@@ -0,0 +1,9 @@
1
+ import { PropsWithChildren } from 'react';
2
+ import { WithSupportProps } from '@sbercloud/uikit-product-utils';
3
+ import { ActionsProps, HeadlineProps } from '../../helperComponents';
4
+ export type MobilePageCatalogProps = WithSupportProps<PropsWithChildren<Pick<HeadlineProps, 'title'> & {
5
+ className?: string;
6
+ actions?: ActionsProps['items'];
7
+ maxVisibleActionsItems?: ActionsProps['maxVisibleItems'];
8
+ }>>;
9
+ export declare function MobilePageCatalog({ children, title, actions, maxVisibleActionsItems, className, ...rest }: MobilePageCatalogProps): import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,20 @@
1
+ var __rest = (this && this.__rest) || function (s, e) {
2
+ var t = {};
3
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
4
+ t[p] = s[p];
5
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
6
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
8
+ t[p[i]] = s[p[i]];
9
+ }
10
+ return t;
11
+ };
12
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
13
+ import cn from 'classnames';
14
+ import { extractSupportProps } from '@sbercloud/uikit-product-utils';
15
+ import { Headline, MobileActions } from '../../helperComponents';
16
+ import styles from './styles.module.css';
17
+ export function MobilePageCatalog(_a) {
18
+ var { children, title, actions = [], maxVisibleActionsItems, className } = _a, rest = __rest(_a, ["children", "title", "actions", "maxVisibleActionsItems", "className"]);
19
+ return (_jsxs("div", Object.assign({ className: cn(styles.catalog, className) }, extractSupportProps(rest), { children: [_jsx(Headline, { title: title }), actions.length > 0 && _jsx(MobileActions, { items: actions, maxVisibleItems: maxVisibleActionsItems }), _jsx("div", { className: styles.content, children: children })] })));
20
+ }
@@ -0,0 +1 @@
1
+ export * from './MobilePageCatalog';
@@ -0,0 +1 @@
1
+ export * from './MobilePageCatalog';
@@ -0,0 +1,15 @@
1
+ .catalog{
2
+ display:flex;
3
+ flex-direction:column;
4
+ gap:var(--dimension-3m, 24px);
5
+ padding:var(--dimension-3m, 24px);
6
+ margin:0 auto;
7
+ box-sizing:border-box;
8
+ width:100%;
9
+ }
10
+
11
+ .content{
12
+ display:flex;
13
+ flex-direction:column;
14
+ flex-grow:1;
15
+ }
@@ -0,0 +1,17 @@
1
+ import { PageFormProps } from '@sbercloud/uikit-product-page-layout';
2
+ import { ValueOf } from '@snack-uikit/utils';
3
+ export declare const BUTTON_PRIMARY_VARIANT: {
4
+ readonly Continue: "continue";
5
+ readonly Create: "create";
6
+ readonly Save: "save";
7
+ readonly Rent: "rent";
8
+ readonly Send: "send";
9
+ };
10
+ export declare const BUTTON_SECONDARY_VARIANT: {
11
+ readonly Cancel: "cancel";
12
+ readonly Back: "back";
13
+ };
14
+ export type ButtonPrimaryVariant = ValueOf<typeof BUTTON_PRIMARY_VARIANT>;
15
+ export type ButtonSecondaryVariant = ValueOf<typeof BUTTON_SECONDARY_VARIANT>;
16
+ export type MobilePageFormProps = PageFormProps;
17
+ export declare function MobilePageForm({ children, title, subHeader, className, footer, stepper, priceSummary, sideBlock, ...rest }: PageFormProps): import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,65 @@
1
+ var __rest = (this && this.__rest) || function (s, e) {
2
+ var t = {};
3
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
4
+ t[p] = s[p];
5
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
6
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
8
+ t[p[i]] = s[p[i]];
9
+ }
10
+ return t;
11
+ };
12
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
13
+ import cn from 'classnames';
14
+ import { useState } from 'react';
15
+ import { ChevronRightSVG, KebabSVG } from '@sbercloud/uikit-product-icons';
16
+ import { MobileDropdown, MobileDroplist } from '@sbercloud/uikit-product-mobile-dropdown';
17
+ import { MobileModalCustom } from '@sbercloud/uikit-product-mobile-modal';
18
+ import { ButtonFilled, ButtonFunction, ButtonOutline, ButtonSimple } from '@snack-uikit/button';
19
+ import { Typography } from '@snack-uikit/typography';
20
+ import { extractSupportProps } from '@snack-uikit/utils';
21
+ import { Headline } from '../../helperComponents';
22
+ import { useGetButtonLabel } from '../../helpers';
23
+ import { useButtonWithTooltip } from './hooks';
24
+ import styles from './styles.module.css';
25
+ export const BUTTON_PRIMARY_VARIANT = {
26
+ Continue: 'continue',
27
+ Create: 'create',
28
+ Save: 'save',
29
+ Rent: 'rent',
30
+ Send: 'send',
31
+ };
32
+ export const BUTTON_SECONDARY_VARIANT = {
33
+ Cancel: 'cancel',
34
+ Back: 'back',
35
+ };
36
+ export function MobilePageForm(_a) {
37
+ var _b, _c;
38
+ var { children, title, subHeader, className, footer, stepper, priceSummary, sideBlock } = _a, rest = __rest(_a, ["children", "title", "subHeader", "className", "footer", "stepper", "priceSummary", "sideBlock"]);
39
+ const PrimaryButton = useButtonWithTooltip({ Button: ButtonFilled, tooltip: footer === null || footer === void 0 ? void 0 : footer.buttonPrimary.tooltip });
40
+ const SecondaryButton = useButtonWithTooltip({ Button: ButtonOutline, tooltip: (_b = footer === null || footer === void 0 ? void 0 : footer.buttonSecondary) === null || _b === void 0 ? void 0 : _b.tooltip });
41
+ const AdditionalButton = useButtonWithTooltip({ Button: ButtonSimple, tooltip: (_c = footer === null || footer === void 0 ? void 0 : footer.buttonAdditional) === null || _c === void 0 ? void 0 : _c.tooltip });
42
+ const [openPriceSummary, setOpenPriceSummary] = useState(false);
43
+ const [openMore, setOpenMore] = useState(false);
44
+ const [openMoreContentIndex, setOpenMoreContentIndex] = useState(undefined);
45
+ const getButtonLabel = useGetButtonLabel();
46
+ return (_jsxs("div", Object.assign({ className: cn(styles.container, className) }, extractSupportProps(rest), { children: [_jsx(Headline, { title: title, subHeader: subHeader, moreActions: sideBlock ? (_jsx(MobileDroplist
47
+ // eslint-disable-next-line @typescript-eslint/ban-ts-comment
48
+ // @ts-ignore
49
+ , {
50
+ // eslint-disable-next-line @typescript-eslint/ban-ts-comment
51
+ // @ts-ignore
52
+ size: 'l', open: openMore, onOpenChange: setOpenMore, items: sideBlock.map(({ label }, idx) => ({
53
+ id: idx,
54
+ content: {
55
+ option: label,
56
+ },
57
+ onClick: () => {
58
+ (setOpenMoreContentIndex(idx), setOpenMore(false));
59
+ },
60
+ })), children: _jsx(ButtonFunction, { icon: _jsx(KebabSVG, {}), size: 'm' }) })) : undefined }), sideBlock && (_jsx(MobileModalCustom, { open: openMoreContentIndex !== undefined, onClose: () => setOpenMoreContentIndex(undefined), children: _jsx(MobileModalCustom.Body, { content: sideBlock === null || sideBlock === void 0 ? void 0 : sideBlock[openMoreContentIndex !== null && openMoreContentIndex !== void 0 ? openMoreContentIndex : 0].content }) })), stepper && _jsx("div", { className: styles.stepper, children: stepper }), _jsx("div", { className: styles.body, children: children }), (priceSummary || footer) && (_jsxs("div", { className: styles.footer, children: [priceSummary && (_jsxs("div", { className: styles.priceSummary, children: [_jsx(Typography.SansBodyM, { className: styles.priceSummaryText, children: "\u041E\u0446\u0435\u043D\u043A\u0430 \u0431\u044E\u0434\u0436\u0435\u0442\u0430" }), _jsx(MobileDropdown, { open: openPriceSummary, onOpenChange: setOpenPriceSummary, content: _jsx("div", { className: styles.modalContent, children: priceSummary.content }), children: _jsxs("div", { className: styles.priceSummaryRight, children: [_jsx(Typography.SansLabelL, { className: styles.priceSummaryTotal, children: priceSummary.total }), priceSummary.content && _jsx(ButtonFunction, { size: 'm', icon: _jsx(ChevronRightSVG, {}) })] }) })] })), footer && (_jsxs("div", { className: styles.actions, "data-column": (footer.buttonAdditional && footer.buttonSecondary) || undefined, children: [footer.buttonAdditional && _jsx(AdditionalButton, Object.assign({}, footer.buttonAdditional, { size: 'm', fullWidth: true })), footer.buttonSecondary && (_jsx(SecondaryButton, Object.assign({}, footer.buttonSecondary, { size: 'm', fullWidth: true, appearance: 'neutral', label: footer.buttonSecondary.variant === 'custom'
61
+ ? footer.buttonSecondary.label
62
+ : getButtonLabel(footer.buttonSecondary.variant) }))), _jsx(PrimaryButton, Object.assign({}, footer.buttonPrimary, { size: 'm', fullWidth: true, label: footer.buttonPrimary.variant === 'custom'
63
+ ? footer.buttonPrimary.label
64
+ : getButtonLabel(footer.buttonPrimary.variant) }))] }))] }))] })));
65
+ }
@@ -0,0 +1,6 @@
1
+ import { ForwardRefExoticComponent } from 'react';
2
+ import { MobileTooltipProps } from '@sbercloud/uikit-product-mobile-tooltip';
3
+ export declare function useButtonWithTooltip<T extends Record<string, unknown>>({ Button, tooltip, }: {
4
+ tooltip?: MobileTooltipProps;
5
+ Button: ForwardRefExoticComponent<T>;
6
+ }): ForwardRefExoticComponent<T> | ((props: T) => import("react/jsx-runtime").JSX.Element);
@@ -0,0 +1,10 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { MobileTooltip } from '@sbercloud/uikit-product-mobile-tooltip';
3
+ export function useButtonWithTooltip({ Button, tooltip, }) {
4
+ if (tooltip) {
5
+ return function ButtonWithTooltip(props) {
6
+ return (_jsx(MobileTooltip, Object.assign({}, tooltip, { children: _jsx(Button, Object.assign({}, props)) })));
7
+ };
8
+ }
9
+ return Button;
10
+ }
@@ -0,0 +1 @@
1
+ export * from './MobilePageForm';
@@ -0,0 +1 @@
1
+ export * from './MobilePageForm';
@@ -0,0 +1,86 @@
1
+ .container{
2
+ background-color:var(--sys-neutral-background1-level, #fdfdfd);
3
+ width:100%;
4
+ min-height:100%;
5
+ flex-grow:1;
6
+ display:flex;
7
+ flex-direction:column;
8
+ gap:var(--dimension-2m, 16px);
9
+ padding:var(--dimension-2m, 16px);
10
+ box-sizing:border-box;
11
+ position:relative;
12
+ z-index:0;
13
+ }
14
+
15
+ .body{
16
+ font-family:var(--sans-body-m-font-family, SB Sans Interface);
17
+ font-weight:var(--sans-body-m-font-weight, Regular);
18
+ line-height:var(--sans-body-m-line-height, 20px);
19
+ font-size:var(--sans-body-m-font-size, 14px);
20
+ letter-spacing:var(--sans-body-m-letter-spacing, 0.1px);
21
+ paragraph-spacing:var(--sans-body-m-paragraph-spacing, 7.7px);
22
+ color:var(--sys-neutral-text-main, #41424e);
23
+ background-color:var(--sys-neutral-background1-level, #fdfdfd);
24
+ flex:1;
25
+ }
26
+
27
+ .footer{
28
+ position:sticky;
29
+ bottom:0;
30
+ z-index:1;
31
+ display:flex;
32
+ flex-direction:column;
33
+ gap:var(--dimension-1m, 8px);
34
+ border-top:solid 1px var(--sys-neutral-decor-default, #dde0ea);
35
+ box-sizing:border-box;
36
+ background-color:var(--sys-neutral-background1-level, #fdfdfd);
37
+ padding:var(--dimension-1m, 8px) var(--dimension-2m, 16px) var(--dimension-2m, 16px);
38
+ margin:calc(0px - var(--dimension-1m, 8px)) calc(0px - var(--dimension-2m, 16px)) calc(0px - var(--dimension-2m, 16px));
39
+ }
40
+ .footer .actions{
41
+ display:flex;
42
+ flex-direction:row;
43
+ gap:var(--dimension-1m, 8px);
44
+ }
45
+ .footer .actions[data-column]{
46
+ flex-direction:column;
47
+ }
48
+
49
+ .mainActions{
50
+ display:flex;
51
+ align-items:center;
52
+ margin-left:auto;
53
+ }
54
+
55
+ .priceSummary{
56
+ display:flex;
57
+ justify-content:space-between;
58
+ min-height:40px;
59
+ align-items:center;
60
+ gap:4px;
61
+ }
62
+
63
+ .priceSummaryText{
64
+ color:var(--sys-neutral-text-support, #6d707f);
65
+ }
66
+
67
+ .priceSummaryRight{
68
+ display:flex;
69
+ align-items:center;
70
+ cursor:pointer;
71
+ }
72
+
73
+ .stepper{
74
+ position:sticky;
75
+ top:0;
76
+ z-index:1;
77
+ background-color:var(--sys-neutral-background1-level, #fdfdfd);
78
+ padding:0 var(--dimension-2m, 16px) var(--dimension-1m, 8px);
79
+ margin:0 calc(0px - var(--dimension-2m, 16px)) calc(0px - var(--dimension-1m, 8px));
80
+ border-bottom:solid 1px var(--sys-neutral-decor-default, #dde0ea);
81
+ box-sizing:border-box;
82
+ }
83
+
84
+ .modalContent{
85
+ padding:0 var(--dimension-2m, 16px);
86
+ }
@@ -0,0 +1,10 @@
1
+ import { PropsWithChildren } from 'react';
2
+ import { WithSupportProps } from '@sbercloud/uikit-product-utils';
3
+ import { ActionsProps, HeadlineProps, SidebarSelectProps } from '../../helperComponents';
4
+ export type MobilePageServicesProps = WithSupportProps<PropsWithChildren<Pick<HeadlineProps, 'title' | 'beforeHeadline' | 'subHeader' | 'afterHeadline'> & {
5
+ className?: string;
6
+ sidebar?: SidebarSelectProps;
7
+ actions?: ActionsProps['items'];
8
+ maxVisibleActionsItems?: ActionsProps['maxVisibleItems'];
9
+ }>>;
10
+ export declare function MobilePageServices({ children, title, actions, className, sidebar, afterHeadline, subHeader, beforeHeadline, maxVisibleActionsItems, ...rest }: MobilePageServicesProps): import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,20 @@
1
+ var __rest = (this && this.__rest) || function (s, e) {
2
+ var t = {};
3
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
4
+ t[p] = s[p];
5
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
6
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
8
+ t[p[i]] = s[p[i]];
9
+ }
10
+ return t;
11
+ };
12
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
13
+ import cn from 'classnames';
14
+ import { extractSupportProps } from '@sbercloud/uikit-product-utils';
15
+ import { Headline, MobileActions, SidebarSelect, } from '../../helperComponents';
16
+ import styles from './styles.module.css';
17
+ export function MobilePageServices(_a) {
18
+ var { children, title, actions = [], className, sidebar, afterHeadline, subHeader, beforeHeadline, maxVisibleActionsItems } = _a, rest = __rest(_a, ["children", "title", "actions", "className", "sidebar", "afterHeadline", "subHeader", "beforeHeadline", "maxVisibleActionsItems"]);
19
+ return (_jsxs("div", Object.assign({ className: cn(styles.wrapper, className) }, extractSupportProps(rest), { children: [_jsx(Headline, { title: title, beforeHeadline: beforeHeadline, afterHeadline: afterHeadline, subHeader: subHeader }), sidebar && _jsx(SidebarSelect, Object.assign({}, sidebar)), actions.length > 0 && _jsx(MobileActions, { items: actions, maxVisibleItems: maxVisibleActionsItems }), _jsx("div", { className: styles.childWrapper, children: children })] })));
20
+ }
@@ -0,0 +1 @@
1
+ export * from './MobilePageServices';
@@ -0,0 +1 @@
1
+ export * from './MobilePageServices';
@@ -0,0 +1,25 @@
1
+ .wrapper{
2
+ display:flex;
3
+ flex-direction:column;
4
+ width:100%;
5
+ min-height:100%;
6
+ box-sizing:border-box;
7
+ padding:var(--dimension-2m, 16px);
8
+ gap:var(--dimension-2m, 16px);
9
+ }
10
+
11
+ .childWrapper{
12
+ flex-shrink:1;
13
+ flex-grow:1;
14
+ display:flex;
15
+ flex-direction:column;
16
+ box-sizing:border-box;
17
+ }
18
+
19
+ .actions{
20
+ display:flex;
21
+ gap:8px;
22
+ flex-shrink:0;
23
+ width:100%;
24
+ justify-content:stretch;
25
+ }
@@ -0,0 +1,7 @@
1
+ export * from './AdaptiveLayout';
2
+ export * from './MobileBlockBasic';
3
+ export * from './MobileCardBanner';
4
+ export * from './MobilePageForm';
5
+ export * from './MobilePageServices';
6
+ export * from './MobileEmptyBlock';
7
+ export * from './MobilePageCatalog';
@@ -0,0 +1,7 @@
1
+ export * from './AdaptiveLayout';
2
+ export * from './MobileBlockBasic';
3
+ export * from './MobileCardBanner';
4
+ export * from './MobilePageForm';
5
+ export * from './MobilePageServices';
6
+ export * from './MobileEmptyBlock';
7
+ export * from './MobilePageCatalog';
@@ -0,0 +1,10 @@
1
+ import { ReactNode } from 'react';
2
+ import { WithLayoutType } from '@sbercloud/uikit-product-utils';
3
+ import { Action } from './types';
4
+ export declare function ActionView({ variant, tooltip, hidden, layoutType, commonProps, ...buttonProps }: WithLayoutType<Action & {
5
+ commonProps: {
6
+ className?: string;
7
+ size?: 's' | 'm' | 'l';
8
+ fullWidth?: boolean;
9
+ };
10
+ }>): string | number | boolean | Iterable<ReactNode> | import("react/jsx-runtime").JSX.Element | null | undefined;
@@ -0,0 +1,55 @@
1
+ var __rest = (this && this.__rest) || function (s, e) {
2
+ var t = {};
3
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
4
+ t[p] = s[p];
5
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
6
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
7
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
8
+ t[p[i]] = s[p[i]];
9
+ }
10
+ return t;
11
+ };
12
+ import { jsx as _jsx } from "react/jsx-runtime";
13
+ import { AdaptiveTooltip } from '@sbercloud/uikit-product-mobile-tooltip';
14
+ import { QuotaDropdown } from '@sbercloud/uikit-product-quota';
15
+ import { ButtonFilled, ButtonFunction, ButtonOutline, ButtonSimple, ButtonTonal, } from '@snack-uikit/button';
16
+ import { ButtonDropdown } from '../ButtonDropdown';
17
+ import { ButtonDroplist } from '../ButtonDroplist';
18
+ import { ButtonKebab } from '../ButtonKebab';
19
+ import { BUTTON_TYPE } from './constants';
20
+ export function ActionView(_a) {
21
+ var { variant, tooltip, hidden = false, layoutType, commonProps } = _a, buttonProps = __rest(_a, ["variant", "tooltip", "hidden", "layoutType", "commonProps"]);
22
+ if (hidden) {
23
+ return null;
24
+ }
25
+ const addTooltip = (component) => tooltip ? (_jsx(AdaptiveTooltip, Object.assign({ layoutType: layoutType }, tooltip, { children: component }))) : (component);
26
+ switch (variant) {
27
+ case BUTTON_TYPE.Filled:
28
+ return addTooltip(_jsx(ButtonFilled, Object.assign({}, buttonProps, commonProps)));
29
+ case BUTTON_TYPE.Outline:
30
+ return addTooltip(_jsx(ButtonOutline, Object.assign({}, buttonProps, commonProps)));
31
+ case BUTTON_TYPE.Tonal:
32
+ return addTooltip(_jsx(ButtonTonal, Object.assign({}, buttonProps, commonProps)));
33
+ case BUTTON_TYPE.Function:
34
+ return addTooltip(_jsx(ButtonFunction, Object.assign({}, buttonProps, commonProps)));
35
+ case BUTTON_TYPE.Simple:
36
+ return addTooltip(_jsx(ButtonSimple, Object.assign({}, buttonProps, commonProps)));
37
+ case BUTTON_TYPE.Dropdown: {
38
+ const { button, dropdown } = buttonProps;
39
+ return addTooltip(_jsx(ButtonDropdown, { button: Object.assign(Object.assign({}, button), commonProps), dropdown: dropdown, layoutType: layoutType }));
40
+ }
41
+ case BUTTON_TYPE.Kebab: {
42
+ const { button, list } = buttonProps;
43
+ return addTooltip(_jsx(ButtonKebab, { button: Object.assign(Object.assign({}, button), commonProps), list: list, layoutType: layoutType }));
44
+ }
45
+ case BUTTON_TYPE.Droplist: {
46
+ const { button, list } = buttonProps;
47
+ return addTooltip(_jsx(ButtonDroplist, { button: Object.assign(Object.assign({}, button), commonProps), list: list, layoutType: layoutType }));
48
+ }
49
+ case BUTTON_TYPE.Quota: {
50
+ return addTooltip(_jsx(QuotaDropdown, Object.assign({}, buttonProps, commonProps, { layoutType: layoutType })));
51
+ }
52
+ default:
53
+ return null;
54
+ }
55
+ }
@@ -0,0 +1,2 @@
1
+ import { ActionsProps } from './types';
2
+ export declare function DesktopActions({ items }: Pick<ActionsProps, 'items'>): import("react/jsx-runtime").JSX.Element | null;
@@ -0,0 +1,13 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { createElement as _createElement } from "react";
3
+ import { ActionView } from './ActionView';
4
+ import { hasVisibleActions } from './helpers';
5
+ import styles from './styles.module.css';
6
+ export function DesktopActions({ items }) {
7
+ if (!hasVisibleActions(items)) {
8
+ return null;
9
+ }
10
+ return (_jsx("div", { className: styles.desktopActionsWrapper, children: items.map((action, index) => (_createElement(ActionView, Object.assign({}, action, { key: index, layoutType: 'desktop', commonProps: {
11
+ className: styles.button,
12
+ } })))) }));
13
+ }
@@ -0,0 +1,2 @@
1
+ import { ActionsProps } from './types';
2
+ export declare function MobileActions({ items, maxVisibleItems }: ActionsProps): import("react/jsx-runtime").JSX.Element | null;
@@ -0,0 +1,101 @@
1
+ import { createElement as _createElement } from "react";
2
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import { Children, isValidElement, useRef, useState } from 'react';
4
+ import { ChevronDownSVG, KebabSVG } from '@sbercloud/uikit-product-icons';
5
+ import { useLocale } from '@sbercloud/uikit-product-locale';
6
+ import { AdaptiveDropdown, MobileDroplist } from '@sbercloud/uikit-product-mobile-dropdown';
7
+ import { MobileTooltip } from '@sbercloud/uikit-product-mobile-tooltip';
8
+ import { checkExceeded, QuotaDropdownContent } from '@sbercloud/uikit-product-quota';
9
+ import { ButtonOutline } from '@snack-uikit/button';
10
+ import { Counter } from '@snack-uikit/counter';
11
+ import { useDynamicList } from '@snack-uikit/utils';
12
+ import { ActionView } from './ActionView';
13
+ import { BUTTON_TYPE } from './constants';
14
+ import { hasVisibleActions } from './helpers';
15
+ import styles from './styles.module.css';
16
+ export function MobileActions({ items, maxVisibleItems }) {
17
+ const containerRef = useRef(null);
18
+ const [isOpen, setIsOpen] = useState(false);
19
+ const { visibleItems, hiddenItems } = useDynamicList({ parentContainerRef: containerRef, items, maxVisibleItems });
20
+ const { t: tQuota } = useLocale('Quota');
21
+ if (!hasVisibleActions(items)) {
22
+ return null;
23
+ }
24
+ const hiddenItemsWithKebab = hiddenItems.concat(visibleItems.filter(item => item.variant === 'kebab'));
25
+ const visibleItemsWithoutKebab = visibleItems.filter(item => item.variant !== 'kebab');
26
+ return (_jsxs("div", { className: styles.mobileActionsWrapper, ref: containerRef, children: [hiddenItemsWithKebab.length > 0 && (_jsx(MobileDroplist, { open: isOpen, onOpenChange: setIsOpen, items: hiddenItemsWithKebab.reduce((acc, action) => {
27
+ var _a, _b;
28
+ switch (action.variant) {
29
+ case BUTTON_TYPE.Tonal:
30
+ case BUTTON_TYPE.Simple:
31
+ case BUTTON_TYPE.Outline:
32
+ case BUTTON_TYPE.Function:
33
+ case BUTTON_TYPE.Filled: {
34
+ acc.push(Object.assign(Object.assign({}, action), { content: { option: (_a = action.label) !== null && _a !== void 0 ? _a : '' }, onClick: event => {
35
+ var _a;
36
+ setIsOpen(false);
37
+ (_a = action.onClick) === null || _a === void 0 ? void 0 : _a.call(action, event);
38
+ }, beforeContent: action === null || action === void 0 ? void 0 : action.icon, itemWrapRender: action.tooltip
39
+ ? item => {
40
+ var _a, _b;
41
+ return (_jsx(MobileTooltip, Object.assign({ tip: (_b = (_a = action.tooltip) === null || _a === void 0 ? void 0 : _a.tip) !== null && _b !== void 0 ? _b : '' }, action.tooltip, { children: item })));
42
+ }
43
+ : undefined }));
44
+ break;
45
+ }
46
+ case BUTTON_TYPE.Quota: {
47
+ const quotaExceededCount = Children.toArray(action.children).reduce((count, child) => {
48
+ var _a, _b, _c, _d, _e, _f;
49
+ return isValidElement(child) &&
50
+ !((_a = child === null || child === void 0 ? void 0 : child.props) === null || _a === void 0 ? void 0 : _a.loading) &&
51
+ !((_b = child === null || child === void 0 ? void 0 : child.props) === null || _b === void 0 ? void 0 : _b.unlimited) &&
52
+ checkExceeded(((_d = (_c = child === null || child === void 0 ? void 0 : child.props) === null || _c === void 0 ? void 0 : _c.limit) !== null && _d !== void 0 ? _d : 0) - ((_f = (_e = child === null || child === void 0 ? void 0 : child.props) === null || _e === void 0 ? void 0 : _e.created) !== null && _f !== void 0 ? _f : 0))
53
+ ? count + 1
54
+ : count;
55
+ }, 0);
56
+ const isQuotaExceededCountVisible = !action.dataError && quotaExceededCount > 0;
57
+ acc.push(Object.assign(Object.assign({}, action), { type: 'group', divider: acc.length > 0, items: [
58
+ Object.assign(Object.assign({}, action), { content: {
59
+ option: tQuota('quotas'),
60
+ }, afterContent: (_jsxs(_Fragment, { children: [isQuotaExceededCountVisible && (_jsx(Counter, { value: quotaExceededCount, appearance: 'red', size: 'm' })), _jsx(ChevronDownSVG, {})] })), itemWrapRender: item => {
61
+ const content = (_jsx(AdaptiveDropdown, { content: _jsx(QuotaDropdownContent, Object.assign({}, action)), layoutType: 'mobile', children: item }));
62
+ return action.tooltip ? (_jsx(MobileTooltip, Object.assign({}, action.tooltip, { children: content }))) : (content);
63
+ } }),
64
+ ] }));
65
+ break;
66
+ }
67
+ case BUTTON_TYPE.Droplist:
68
+ case BUTTON_TYPE.Kebab: {
69
+ const needDivider = Boolean(action.variant === 'droplist' && (action === null || action === void 0 ? void 0 : action.button.label)) || acc.length > 0;
70
+ acc.push(Object.assign(Object.assign({}, action), { type: 'group', label: action.variant === 'droplist' ? action === null || action === void 0 ? void 0 : action.button.label : undefined, divider: needDivider, items: action.list.items.map(item => (Object.assign(Object.assign({}, item), { onClick: event => {
71
+ var _a;
72
+ setIsOpen(false);
73
+ // eslint-disable-next-line @typescript-eslint/ban-ts-comment
74
+ // @ts-expect-error
75
+ (_a = item.onClick) === null || _a === void 0 ? void 0 : _a.call(item, event);
76
+ } }))) }));
77
+ break;
78
+ }
79
+ case BUTTON_TYPE.Dropdown: {
80
+ acc.push(Object.assign(Object.assign({}, action), { type: 'group', divider: acc.length > 0, items: [
81
+ Object.assign(Object.assign({}, action.button), { content: { option: (_b = action.button.label) !== null && _b !== void 0 ? _b : '' }, onClick: event => {
82
+ var _a, _b;
83
+ (_b = (_a = action.button).onClick) === null || _b === void 0 ? void 0 : _b.call(_a, event);
84
+ }, afterContent: _jsx(ChevronDownSVG, {}), itemWrapRender: item => {
85
+ const content = (_jsx(AdaptiveDropdown, Object.assign({}, action.dropdown, { layoutType: 'mobile', children: item })));
86
+ return action.tooltip ? (_jsx(MobileTooltip, Object.assign({}, action.tooltip, { children: content }))) : (content);
87
+ } }),
88
+ ] }));
89
+ break;
90
+ }
91
+ default: {
92
+ break;
93
+ }
94
+ }
95
+ return acc;
96
+ }, []), children: _jsx(ButtonOutline, { appearance: 'neutral', icon: _jsx(KebabSVG, {}), size: 'm' }) })), visibleItemsWithoutKebab.map((action, index) => (_createElement(ActionView, Object.assign({}, action, { key: index, layoutType: 'mobile', commonProps: {
97
+ className: styles.button,
98
+ size: 'm',
99
+ fullWidth: true,
100
+ } }))))] }));
101
+ }
@@ -0,0 +1,11 @@
1
+ export declare const BUTTON_TYPE: {
2
+ readonly Filled: "filled";
3
+ readonly Outline: "outline";
4
+ readonly Tonal: "tonal";
5
+ readonly Function: "function";
6
+ readonly Simple: "simple";
7
+ readonly Dropdown: "dropdown";
8
+ readonly Droplist: "droplist";
9
+ readonly Quota: "quota";
10
+ readonly Kebab: "kebab";
11
+ };
@@ -0,0 +1,11 @@
1
+ export const BUTTON_TYPE = {
2
+ Filled: 'filled',
3
+ Outline: 'outline',
4
+ Tonal: 'tonal',
5
+ Function: 'function',
6
+ Simple: 'simple',
7
+ Dropdown: 'dropdown',
8
+ Droplist: 'droplist',
9
+ Quota: 'quota',
10
+ Kebab: 'kebab',
11
+ };
@@ -0,0 +1,2 @@
1
+ import { Action } from './types';
2
+ export declare function hasVisibleActions(actions: Action[]): boolean;
@@ -0,0 +1,3 @@
1
+ export function hasVisibleActions(actions) {
2
+ return actions.some(action => !action.hidden);
3
+ }
@@ -0,0 +1,3 @@
1
+ export * from './DesktopActions';
2
+ export * from './MobileActions';
3
+ export * from './types';
@@ -0,0 +1,3 @@
1
+ export * from './DesktopActions';
2
+ export * from './MobileActions';
3
+ export * from './types';