@salutejs/plasma-new-hope 0.174.0-canary.1452.11462555994.0 → 0.174.0-canary.1503.11466452273.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (274) hide show
  1. package/cjs/components/Notification/Notification.js +2 -2
  2. package/cjs/components/Notification/Notification.js.map +1 -1
  3. package/cjs/components/Notification/Notification.types.js.map +1 -1
  4. package/cjs/components/Notification/NotificationsPortal.js +4 -2
  5. package/cjs/components/Notification/NotificationsPortal.js.map +1 -1
  6. package/cjs/components/Notification/NotificationsProvider.js +3 -1
  7. package/cjs/components/Notification/NotificationsProvider.js.map +1 -1
  8. package/cjs/components/Slider/Slider.css +13 -15
  9. package/cjs/components/Slider/Slider.js +3 -11
  10. package/cjs/components/Slider/Slider.js.map +1 -1
  11. package/cjs/components/Slider/Slider.tokens.js +17 -23
  12. package/cjs/components/Slider/Slider.tokens.js.map +1 -1
  13. package/cjs/components/Slider/components/Double/Double.css +8 -8
  14. package/cjs/components/Slider/components/Double/Double.js +23 -58
  15. package/cjs/components/Slider/components/Double/Double.js.map +1 -1
  16. package/cjs/components/Slider/components/Single/Single.css +14 -14
  17. package/cjs/components/Slider/components/Single/Single.js +33 -64
  18. package/cjs/components/Slider/components/Single/Single.js.map +1 -1
  19. package/cjs/components/Slider/components/Single/Single.styles.js +4 -4
  20. package/cjs/components/Slider/components/Single/Single.styles.js.map +1 -1
  21. package/cjs/components/Slider/components/Single/Single.styles_1r9f1e0.css +6 -0
  22. package/cjs/components/Slider/components/SliderBase/SliderBase.css +5 -5
  23. package/cjs/components/Slider/components/SliderBase/SliderBase.js +12 -31
  24. package/cjs/components/Slider/components/SliderBase/SliderBase.js.map +1 -1
  25. package/cjs/components/Slider/components/SliderBase/SliderBase.styles.js +7 -7
  26. package/cjs/components/Slider/components/SliderBase/SliderBase.styles.js.map +1 -1
  27. package/cjs/components/Slider/components/SliderBase/SliderBase.styles_9s4eb3.css +5 -0
  28. package/cjs/components/Slider/ui/Handler/Handler.css +3 -3
  29. package/cjs/components/Slider/ui/Handler/Handler.js +88 -49
  30. package/cjs/components/Slider/ui/Handler/Handler.js.map +1 -1
  31. package/cjs/components/Slider/ui/Handler/Handler.styles.js +7 -17
  32. package/cjs/components/Slider/ui/Handler/Handler.styles.js.map +1 -1
  33. package/cjs/components/Slider/ui/Handler/Handler.styles_8crx5z.css +2 -0
  34. package/cjs/components/Slider/ui/Thumb/Thumb.css +1 -1
  35. package/cjs/components/Slider/ui/Thumb/Thumb.js +2 -3
  36. package/cjs/components/Slider/ui/Thumb/Thumb.js.map +1 -1
  37. package/cjs/components/Slider/ui/Thumb/Thumb.styles.js +1 -1
  38. package/cjs/components/Slider/ui/Thumb/Thumb.styles.js.map +1 -1
  39. package/cjs/components/Slider/ui/Thumb/Thumb.styles_4w4gzn.css +1 -0
  40. package/cjs/components/Slider/utils/index.js +10 -28
  41. package/cjs/components/Slider/utils/index.js.map +1 -1
  42. package/cjs/components/Slider/variations/_view/base.js +1 -1
  43. package/cjs/components/Slider/variations/_view/base.js.map +1 -1
  44. package/cjs/components/Slider/variations/_view/base_x642ct.css +1 -0
  45. package/cjs/index.css +13 -15
  46. package/cjs/index.js +1 -1
  47. package/cjs/utils/index.js.map +1 -1
  48. package/emotion/cjs/components/Notification/Notification.js +2 -2
  49. package/emotion/cjs/components/Notification/Notification.template-doc.mdx +15 -7
  50. package/emotion/cjs/components/Notification/NotificationsPortal.js +5 -3
  51. package/emotion/cjs/components/Notification/NotificationsProvider.js +3 -1
  52. package/emotion/cjs/components/Notification/index.js +4 -4
  53. package/emotion/cjs/components/Slider/Slider.js +2 -10
  54. package/emotion/cjs/components/Slider/Slider.template-doc.mdx +0 -26
  55. package/emotion/cjs/components/Slider/Slider.tokens.js +17 -23
  56. package/emotion/cjs/components/Slider/components/Double/Double.js +19 -54
  57. package/emotion/cjs/components/Slider/components/Single/Single.js +33 -64
  58. package/emotion/cjs/components/Slider/components/Single/Single.styles.js +9 -18
  59. package/emotion/cjs/components/Slider/components/SliderBase/SliderBase.js +12 -31
  60. package/emotion/cjs/components/Slider/components/SliderBase/SliderBase.styles.js +10 -10
  61. package/emotion/cjs/components/Slider/ui/Handler/Handler.js +88 -52
  62. package/emotion/cjs/components/Slider/ui/Handler/Handler.styles.js +15 -9
  63. package/emotion/cjs/components/Slider/ui/Thumb/Thumb.js +2 -3
  64. package/emotion/cjs/components/Slider/ui/Thumb/Thumb.styles.js +3 -3
  65. package/emotion/cjs/components/Slider/utils/index.js +10 -28
  66. package/emotion/cjs/components/Slider/variations/_view/base.js +1 -2
  67. package/emotion/cjs/examples/plasma_b2c/components/Notification/Notification.js +5 -3
  68. package/emotion/cjs/examples/plasma_b2c/components/Notification/Notification.stories.tsx +25 -4
  69. package/emotion/cjs/examples/plasma_b2c/components/Slider/Slider.config.js +7 -7
  70. package/emotion/cjs/examples/plasma_b2c/components/Slider/Slider.stories.tsx +16 -90
  71. package/emotion/cjs/examples/plasma_web/components/Notification/Notification.js +5 -3
  72. package/emotion/cjs/examples/plasma_web/components/Notification/Notification.stories.tsx +25 -4
  73. package/emotion/cjs/examples/plasma_web/components/Slider/Slider.config.js +7 -7
  74. package/emotion/cjs/examples/plasma_web/components/Slider/Slider.stories.tsx +15 -90
  75. package/emotion/es/components/Notification/Notification.js +1 -1
  76. package/emotion/es/components/Notification/Notification.template-doc.mdx +15 -7
  77. package/emotion/es/components/Notification/NotificationsPortal.js +5 -3
  78. package/emotion/es/components/Notification/NotificationsProvider.js +3 -1
  79. package/emotion/es/components/Notification/index.js +1 -1
  80. package/emotion/es/components/Slider/Slider.js +2 -11
  81. package/emotion/es/components/Slider/Slider.template-doc.mdx +0 -26
  82. package/emotion/es/components/Slider/Slider.tokens.js +17 -23
  83. package/emotion/es/components/Slider/components/Double/Double.js +19 -54
  84. package/emotion/es/components/Slider/components/Single/Single.js +34 -65
  85. package/emotion/es/components/Slider/components/Single/Single.styles.js +8 -17
  86. package/emotion/es/components/Slider/components/SliderBase/SliderBase.js +12 -31
  87. package/emotion/es/components/Slider/components/SliderBase/SliderBase.styles.js +11 -11
  88. package/emotion/es/components/Slider/ui/Handler/Handler.js +86 -51
  89. package/emotion/es/components/Slider/ui/Handler/Handler.styles.js +16 -10
  90. package/emotion/es/components/Slider/ui/Thumb/Thumb.js +2 -3
  91. package/emotion/es/components/Slider/ui/Thumb/Thumb.styles.js +3 -3
  92. package/emotion/es/components/Slider/utils/index.js +10 -28
  93. package/emotion/es/components/Slider/variations/_view/base.js +1 -2
  94. package/emotion/es/examples/plasma_b2c/components/Notification/Notification.js +6 -4
  95. package/emotion/es/examples/plasma_b2c/components/Notification/Notification.stories.tsx +25 -4
  96. package/emotion/es/examples/plasma_b2c/components/Slider/Slider.config.js +7 -7
  97. package/emotion/es/examples/plasma_b2c/components/Slider/Slider.stories.tsx +16 -90
  98. package/emotion/es/examples/plasma_web/components/Notification/Notification.js +6 -4
  99. package/emotion/es/examples/plasma_web/components/Notification/Notification.stories.tsx +25 -4
  100. package/emotion/es/examples/plasma_web/components/Slider/Slider.config.js +7 -7
  101. package/emotion/es/examples/plasma_web/components/Slider/Slider.stories.tsx +15 -90
  102. package/es/components/Notification/Notification.js +2 -2
  103. package/es/components/Notification/Notification.js.map +1 -1
  104. package/es/components/Notification/Notification.types.js.map +1 -1
  105. package/es/components/Notification/NotificationsPortal.js +4 -2
  106. package/es/components/Notification/NotificationsPortal.js.map +1 -1
  107. package/es/components/Notification/NotificationsProvider.js +3 -1
  108. package/es/components/Notification/NotificationsProvider.js.map +1 -1
  109. package/es/components/Slider/Slider.css +13 -15
  110. package/es/components/Slider/Slider.js +3 -11
  111. package/es/components/Slider/Slider.js.map +1 -1
  112. package/es/components/Slider/Slider.tokens.js +17 -23
  113. package/es/components/Slider/Slider.tokens.js.map +1 -1
  114. package/es/components/Slider/components/Double/Double.css +8 -8
  115. package/es/components/Slider/components/Double/Double.js +19 -54
  116. package/es/components/Slider/components/Double/Double.js.map +1 -1
  117. package/es/components/Slider/components/Single/Single.css +14 -14
  118. package/es/components/Slider/components/Single/Single.js +34 -65
  119. package/es/components/Slider/components/Single/Single.js.map +1 -1
  120. package/es/components/Slider/components/Single/Single.styles.js +4 -4
  121. package/es/components/Slider/components/Single/Single.styles.js.map +1 -1
  122. package/es/components/Slider/components/Single/Single.styles_1r9f1e0.css +6 -0
  123. package/es/components/Slider/components/SliderBase/SliderBase.css +5 -5
  124. package/es/components/Slider/components/SliderBase/SliderBase.js +12 -31
  125. package/es/components/Slider/components/SliderBase/SliderBase.js.map +1 -1
  126. package/es/components/Slider/components/SliderBase/SliderBase.styles.js +7 -7
  127. package/es/components/Slider/components/SliderBase/SliderBase.styles.js.map +1 -1
  128. package/es/components/Slider/components/SliderBase/SliderBase.styles_9s4eb3.css +5 -0
  129. package/es/components/Slider/ui/Handler/Handler.css +3 -3
  130. package/es/components/Slider/ui/Handler/Handler.js +87 -48
  131. package/es/components/Slider/ui/Handler/Handler.js.map +1 -1
  132. package/es/components/Slider/ui/Handler/Handler.styles.js +7 -17
  133. package/es/components/Slider/ui/Handler/Handler.styles.js.map +1 -1
  134. package/es/components/Slider/ui/Handler/Handler.styles_8crx5z.css +2 -0
  135. package/es/components/Slider/ui/Thumb/Thumb.css +1 -1
  136. package/es/components/Slider/ui/Thumb/Thumb.js +2 -3
  137. package/es/components/Slider/ui/Thumb/Thumb.js.map +1 -1
  138. package/es/components/Slider/ui/Thumb/Thumb.styles.js +1 -1
  139. package/es/components/Slider/ui/Thumb/Thumb.styles.js.map +1 -1
  140. package/es/components/Slider/ui/Thumb/Thumb.styles_4w4gzn.css +1 -0
  141. package/es/components/Slider/utils/index.js +10 -28
  142. package/es/components/Slider/utils/index.js.map +1 -1
  143. package/es/components/Slider/variations/_view/base.js +1 -1
  144. package/es/components/Slider/variations/_view/base.js.map +1 -1
  145. package/es/components/Slider/variations/_view/base_x642ct.css +1 -0
  146. package/es/index.css +13 -15
  147. package/es/index.js +1 -1
  148. package/es/utils/index.js.map +1 -1
  149. package/package.json +2 -2
  150. package/styled-components/cjs/components/Notification/Notification.js +2 -2
  151. package/styled-components/cjs/components/Notification/Notification.template-doc.mdx +15 -7
  152. package/styled-components/cjs/components/Notification/NotificationsPortal.js +4 -2
  153. package/styled-components/cjs/components/Notification/NotificationsProvider.js +3 -1
  154. package/styled-components/cjs/components/Notification/index.js +4 -4
  155. package/styled-components/cjs/components/Slider/Slider.js +2 -10
  156. package/styled-components/cjs/components/Slider/Slider.template-doc.mdx +0 -26
  157. package/styled-components/cjs/components/Slider/Slider.tokens.js +17 -23
  158. package/styled-components/cjs/components/Slider/components/Double/Double.js +19 -54
  159. package/styled-components/cjs/components/Slider/components/Single/Single.js +33 -64
  160. package/styled-components/cjs/components/Slider/components/Single/Single.styles.js +6 -6
  161. package/styled-components/cjs/components/Slider/components/SliderBase/SliderBase.js +12 -31
  162. package/styled-components/cjs/components/Slider/components/SliderBase/SliderBase.styles.js +6 -6
  163. package/styled-components/cjs/components/Slider/ui/Handler/Handler.js +88 -52
  164. package/styled-components/cjs/components/Slider/ui/Handler/Handler.styles.js +4 -7
  165. package/styled-components/cjs/components/Slider/ui/Thumb/Thumb.js +2 -3
  166. package/styled-components/cjs/components/Slider/ui/Thumb/Thumb.styles.js +2 -2
  167. package/styled-components/cjs/components/Slider/utils/index.js +10 -28
  168. package/styled-components/cjs/components/Slider/variations/_view/base.js +1 -2
  169. package/styled-components/cjs/examples/plasma_b2c/components/Notification/Notification.js +5 -3
  170. package/styled-components/cjs/examples/plasma_b2c/components/Notification/Notification.stories.tsx +25 -4
  171. package/styled-components/cjs/examples/plasma_b2c/components/Slider/Slider.config.js +3 -3
  172. package/styled-components/cjs/examples/plasma_b2c/components/Slider/Slider.stories.tsx +16 -90
  173. package/styled-components/cjs/examples/plasma_web/components/Notification/Notification.js +5 -3
  174. package/styled-components/cjs/examples/plasma_web/components/Notification/Notification.stories.tsx +25 -4
  175. package/styled-components/cjs/examples/plasma_web/components/Slider/Slider.config.js +3 -3
  176. package/styled-components/cjs/examples/plasma_web/components/Slider/Slider.stories.tsx +15 -90
  177. package/styled-components/es/components/Notification/Notification.js +1 -1
  178. package/styled-components/es/components/Notification/Notification.template-doc.mdx +15 -7
  179. package/styled-components/es/components/Notification/NotificationsPortal.js +4 -2
  180. package/styled-components/es/components/Notification/NotificationsProvider.js +3 -1
  181. package/styled-components/es/components/Notification/index.js +1 -1
  182. package/styled-components/es/components/Slider/Slider.js +2 -11
  183. package/styled-components/es/components/Slider/Slider.template-doc.mdx +0 -26
  184. package/styled-components/es/components/Slider/Slider.tokens.js +17 -23
  185. package/styled-components/es/components/Slider/components/Double/Double.js +19 -54
  186. package/styled-components/es/components/Slider/components/Single/Single.js +34 -65
  187. package/styled-components/es/components/Slider/components/Single/Single.styles.js +5 -5
  188. package/styled-components/es/components/Slider/components/SliderBase/SliderBase.js +12 -31
  189. package/styled-components/es/components/Slider/components/SliderBase/SliderBase.styles.js +7 -7
  190. package/styled-components/es/components/Slider/ui/Handler/Handler.js +86 -51
  191. package/styled-components/es/components/Slider/ui/Handler/Handler.styles.js +5 -8
  192. package/styled-components/es/components/Slider/ui/Thumb/Thumb.js +2 -3
  193. package/styled-components/es/components/Slider/ui/Thumb/Thumb.styles.js +2 -2
  194. package/styled-components/es/components/Slider/utils/index.js +10 -28
  195. package/styled-components/es/components/Slider/variations/_view/base.js +1 -2
  196. package/styled-components/es/examples/plasma_b2c/components/Notification/Notification.js +6 -4
  197. package/styled-components/es/examples/plasma_b2c/components/Notification/Notification.stories.tsx +25 -4
  198. package/styled-components/es/examples/plasma_b2c/components/Slider/Slider.config.js +3 -3
  199. package/styled-components/es/examples/plasma_b2c/components/Slider/Slider.stories.tsx +16 -90
  200. package/styled-components/es/examples/plasma_web/components/Notification/Notification.js +6 -4
  201. package/styled-components/es/examples/plasma_web/components/Notification/Notification.stories.tsx +25 -4
  202. package/styled-components/es/examples/plasma_web/components/Slider/Slider.config.js +3 -3
  203. package/styled-components/es/examples/plasma_web/components/Slider/Slider.stories.tsx +15 -90
  204. package/types/components/Notification/Notification.d.ts +3 -3
  205. package/types/components/Notification/Notification.d.ts.map +1 -1
  206. package/types/components/Notification/Notification.types.d.ts +11 -5
  207. package/types/components/Notification/Notification.types.d.ts.map +1 -1
  208. package/types/components/Notification/NotificationsProvider.d.ts +4 -3
  209. package/types/components/Notification/NotificationsProvider.d.ts.map +1 -1
  210. package/types/components/Notification/index.d.ts +2 -2
  211. package/types/components/Notification/index.d.ts.map +1 -1
  212. package/types/components/Slider/Slider.d.ts.map +1 -1
  213. package/types/components/Slider/Slider.tokens.d.ts +16 -22
  214. package/types/components/Slider/Slider.tokens.d.ts.map +1 -1
  215. package/types/components/Slider/components/Double/Double.d.ts.map +1 -1
  216. package/types/components/Slider/components/Double/Double.types.d.ts +0 -1
  217. package/types/components/Slider/components/Double/Double.types.d.ts.map +1 -1
  218. package/types/components/Slider/components/Single/Single.d.ts.map +1 -1
  219. package/types/components/Slider/components/Single/Single.styles.d.ts +1 -1
  220. package/types/components/Slider/components/Single/Single.styles.d.ts.map +1 -1
  221. package/types/components/Slider/components/Single/Single.types.d.ts +7 -80
  222. package/types/components/Slider/components/Single/Single.types.d.ts.map +1 -1
  223. package/types/components/Slider/components/SliderBase/SliderBase.d.ts.map +1 -1
  224. package/types/components/Slider/components/SliderBase/SliderBase.styles.d.ts +1 -1
  225. package/types/components/Slider/components/SliderBase/SliderBase.styles.d.ts.map +1 -1
  226. package/types/components/Slider/components/SliderBase/SliderBase.types.d.ts +0 -6
  227. package/types/components/Slider/components/SliderBase/SliderBase.types.d.ts.map +1 -1
  228. package/types/components/Slider/ui/Handler/Handler.d.ts.map +1 -1
  229. package/types/components/Slider/ui/Handler/Handler.styles.d.ts +2 -6
  230. package/types/components/Slider/ui/Handler/Handler.styles.d.ts.map +1 -1
  231. package/types/components/Slider/ui/Handler/Handler.types.d.ts +1 -5
  232. package/types/components/Slider/ui/Handler/Handler.types.d.ts.map +1 -1
  233. package/types/components/Slider/ui/Thumb/Thumb.d.ts +1 -1
  234. package/types/components/Slider/ui/Thumb/Thumb.d.ts.map +1 -1
  235. package/types/components/Slider/ui/Thumb/Thumb.styles.d.ts.map +1 -1
  236. package/types/components/Slider/ui/Thumb/Thumb.types.d.ts +0 -1
  237. package/types/components/Slider/ui/Thumb/Thumb.types.d.ts.map +1 -1
  238. package/types/components/Slider/utils/index.d.ts +8 -26
  239. package/types/components/Slider/utils/index.d.ts.map +1 -1
  240. package/types/components/Slider/variations/_view/base.d.ts.map +1 -1
  241. package/types/examples/plasma_b2c/components/Notification/Notification.d.ts +4 -2
  242. package/types/examples/plasma_b2c/components/Notification/Notification.d.ts.map +1 -1
  243. package/types/examples/plasma_b2c/components/Slider/Slider.config.d.ts.map +1 -1
  244. package/types/examples/plasma_b2c/components/Slider/Slider.d.ts +2 -84
  245. package/types/examples/plasma_b2c/components/Slider/Slider.d.ts.map +1 -1
  246. package/types/examples/plasma_web/components/Notification/Notification.d.ts +4 -13
  247. package/types/examples/plasma_web/components/Notification/Notification.d.ts.map +1 -1
  248. package/types/examples/plasma_web/components/Slider/Slider.config.d.ts.map +1 -1
  249. package/types/examples/plasma_web/components/Slider/Slider.d.ts +2 -84
  250. package/types/examples/plasma_web/components/Slider/Slider.d.ts.map +1 -1
  251. package/types/utils/index.d.ts +1 -1
  252. package/types/utils/index.d.ts.map +1 -1
  253. package/cjs/components/Slider/components/DoubleUncontrolled/DoubleUncontrolled.css +0 -98
  254. package/cjs/components/Slider/components/Single/Single.styles_1h7n2s2.css +0 -6
  255. package/cjs/components/Slider/components/SliderBase/SliderBase.styles_1qt1224.css +0 -5
  256. package/cjs/components/Slider/ui/Handler/Handler.styles_irtcgm.css +0 -2
  257. package/cjs/components/Slider/ui/Handler/computeKeyPressData.js +0 -122
  258. package/cjs/components/Slider/ui/Handler/computeKeyPressData.js.map +0 -1
  259. package/cjs/components/Slider/ui/Thumb/Thumb.styles_uyn20e.css +0 -1
  260. package/cjs/components/Slider/variations/_view/base_1s3f6q8.css +0 -1
  261. package/emotion/cjs/components/Slider/ui/Handler/computeKeyPressData.js +0 -121
  262. package/emotion/es/components/Slider/ui/Handler/computeKeyPressData.js +0 -115
  263. package/es/components/Slider/components/DoubleUncontrolled/DoubleUncontrolled.css +0 -98
  264. package/es/components/Slider/components/Single/Single.styles_1h7n2s2.css +0 -6
  265. package/es/components/Slider/components/SliderBase/SliderBase.styles_1qt1224.css +0 -5
  266. package/es/components/Slider/ui/Handler/Handler.styles_irtcgm.css +0 -2
  267. package/es/components/Slider/ui/Handler/computeKeyPressData.js +0 -118
  268. package/es/components/Slider/ui/Handler/computeKeyPressData.js.map +0 -1
  269. package/es/components/Slider/ui/Thumb/Thumb.styles_uyn20e.css +0 -1
  270. package/es/components/Slider/variations/_view/base_1s3f6q8.css +0 -1
  271. package/styled-components/cjs/components/Slider/ui/Handler/computeKeyPressData.js +0 -121
  272. package/styled-components/es/components/Slider/ui/Handler/computeKeyPressData.js +0 -115
  273. package/types/components/Slider/ui/Handler/computeKeyPressData.d.ts +0 -12
  274. package/types/components/Slider/ui/Handler/computeKeyPressData.d.ts.map +0 -1
@@ -6,7 +6,7 @@ Object.defineProperty(exports, "__esModule", {
6
6
  exports.Thumb = void 0;
7
7
  var _react = /*#__PURE__*/_interopRequireDefault( /*#__PURE__*/require("react"));
8
8
  var _Thumb = /*#__PURE__*/require("./Thumb.styles");
9
- var _excluded = ["min", "max", "value", "ariaValueMin", "ariaLabel", "disabled", "orientation"];
9
+ var _excluded = ["min", "max", "value", "ariaValueMin", "ariaLabel", "disabled"];
10
10
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
11
11
  function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
12
12
  function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
@@ -19,7 +19,6 @@ var Thumb = exports.Thumb = function Thumb(_ref) {
19
19
  ariaValueMin = _ref$ariaValueMin === void 0 ? min : _ref$ariaValueMin,
20
20
  ariaLabel = _ref.ariaLabel,
21
21
  disabled = _ref.disabled,
22
- orientation = _ref.orientation,
23
22
  rest = _objectWithoutProperties(_ref, _excluded);
24
23
  return /*#__PURE__*/_react["default"].createElement(_Thumb.ThumbBase, _extends({
25
24
  role: "slider",
@@ -28,6 +27,6 @@ var Thumb = exports.Thumb = function Thumb(_ref) {
28
27
  "aria-valuemax": max,
29
28
  "aria-valuenow": value,
30
29
  disabled: disabled,
31
- "aria-orientation": orientation
30
+ "aria-orientation": "horizontal"
32
31
  }, rest));
33
32
  };
@@ -10,8 +10,8 @@ var _Slider = /*#__PURE__*/require("../../Slider.tokens");
10
10
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
11
11
  var ThumbBase = exports.ThumbBase = /*#__PURE__*/_styledComponents["default"].div.withConfig({
12
12
  componentId: "plasma-new-hope__sc-13botku-0"
13
- })(["width:var(--thumb-size);height:var(--thumb-size);min-width:var(--thumb-size);min-height:var(--thumb-size);position:relative;border-radius:50%;box-sizing:border-box;background:var(", ");margin:0.0625rem;transition:border-color 0.1s ease-in-out;&:after{background:var(", ");margin:-0.0625rem;content:'';position:absolute;inset:0;z-index:-1;border-radius:inherit;}&:not([disabled]):hover:after,&:not([disabled]):active:after{background:var(", ");}&[disabled]{cursor:not-allowed;}&:focus{outline:none;}", ""], _Slider.tokens.thumbBackgroundColor, _Slider.tokens.thumbBorderColor, _Slider.tokens.thumbFocusBorderColor, /*#__PURE__*/(0, _mixins.addFocus)({
14
- outlineOffset: '0.0625rem',
13
+ })(["width:var(", ");height:var(", ");position:relative;left:-0.125rem;top:-0.125rem;border-radius:50%;box-sizing:border-box;background:var(", ");margin:0.125rem;transition:border-color 0.1s ease-in-out;&:after{background:var(", ");margin:-0.125rem;content:'';position:absolute;inset:0;z-index:-1;border-radius:inherit;}&:not([disabled]):hover:after,&:not([disabled]):active:after{background:var(", ");}&[disabled]{cursor:not-allowed;}&:focus{outline:none;}", ""], _Slider.tokens.thumbSize, _Slider.tokens.thumbSize, _Slider.tokens.thumbBackgroundColor, _Slider.tokens.thumbBorderColor, _Slider.tokens.thumbFocusBorderColor, /*#__PURE__*/(0, _mixins.addFocus)({
14
+ outlineOffset: '0.125rem',
15
15
  outlineSize: '0.125rem',
16
16
  outlineRadius: '50%',
17
17
  outlineColor: /*#__PURE__*/"var(".concat(_Slider.tokens.thumbFocusBorderColor, ")")
@@ -14,8 +14,8 @@ exports.sizeData = void 0;
14
14
  * @param {number} max
15
15
  * @return {number}
16
16
  */
17
- function getSliderThumbValue(handleCenterPosRelative, stepSize, min, max) {
18
- var newValue = Math.round(handleCenterPosRelative / stepSize) + min;
17
+ function getSliderThumbValue(handleCenterXRelative, stepSize, min, max) {
18
+ var newValue = Math.round(handleCenterXRelative / stepSize) + min;
19
19
  return Math.min(Math.max(newValue, min), max);
20
20
  }
21
21
 
@@ -26,11 +26,11 @@ function getSliderThumbValue(handleCenterPosRelative, stepSize, min, max) {
26
26
  * @param {'left' | 'right'} side
27
27
  * @return Array<number>
28
28
  */
29
- function getOffsets(ref, side, isVertical) {
29
+ function getOffsets(ref, side) {
30
30
  if (!ref || !('current' in ref) || !ref.current || !side) {
31
31
  return [0, 0];
32
32
  }
33
- var size = isVertical ? ref.current.clientHeight : ref.current.clientWidth;
33
+ var size = ref.current.clientWidth;
34
34
  if (side === 'left') {
35
35
  return [0, size];
36
36
  }
@@ -41,33 +41,15 @@ function getOffsets(ref, side, isVertical) {
41
41
  }
42
42
  var sizeData = exports.sizeData = {
43
43
  s: {
44
- small: {
45
- indent: 0.5,
46
- fontSizeMultiplier: 16
47
- },
48
- large: {
49
- indent: 0.625,
50
- fontSizeMultiplier: 16
51
- }
44
+ indent: 0.5,
45
+ fontSizeMultiplier: 16
52
46
  },
53
47
  m: {
54
- small: {
55
- indent: 0.5,
56
- fontSizeMultiplier: 16
57
- },
58
- large: {
59
- indent: 0.625,
60
- fontSizeMultiplier: 16
61
- }
48
+ indent: 0.75,
49
+ fontSizeMultiplier: 16
62
50
  },
63
51
  l: {
64
- small: {
65
- indent: 0.5,
66
- fontSizeMultiplier: 16
67
- },
68
- large: {
69
- indent: 0.625,
70
- fontSizeMultiplier: 16
71
- }
52
+ indent: 0.75,
53
+ fontSizeMultiplier: 16
72
54
  }
73
55
  };
@@ -5,5 +5,4 @@ Object.defineProperty(exports, "__esModule", {
5
5
  });
6
6
  exports.base = void 0;
7
7
  var _styledComponents = /*#__PURE__*/require("styled-components");
8
- var _Slider = /*#__PURE__*/require("../../Slider.tokens");
9
- var base = exports.base = /*#__PURE__*/(0, _styledComponents.css)(["&.", "{height:100%;display:inline-flex;}"], _Slider.classes.verticalOrientation);
8
+ var base = exports.base = /*#__PURE__*/(0, _styledComponents.css)([""]);
@@ -16,14 +16,16 @@ var _engines = /*#__PURE__*/require("../../../../engines");
16
16
  var _Notification2 = /*#__PURE__*/require("./Notification.config");
17
17
  var _Modal = /*#__PURE__*/require("../../../../components/Modal");
18
18
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
19
- var mergedConfig = /*#__PURE__*/(0, _engines.mergeConfig)(_Notification.noticationConfig, _Notification2.config);
19
+ var mergedConfig = /*#__PURE__*/(0, _engines.mergeConfig)(_Notification.notificationConfig, _Notification2.config);
20
20
  var Notification = exports.Notification = /*#__PURE__*/(0, _engines.component)(mergedConfig);
21
21
  var NotificationsProvider = exports.NotificationsProvider = function NotificationsProvider(_ref) {
22
22
  var children = _ref.children,
23
23
  _ref$frame = _ref.frame,
24
- frame = _ref$frame === void 0 ? 'theme-root' : _ref$frame;
24
+ frame = _ref$frame === void 0 ? 'theme-root' : _ref$frame,
25
+ placement = _ref.placement;
25
26
  return /*#__PURE__*/_react["default"].createElement(_Notification.NotificationsProvider, {
26
27
  config: mergedConfig,
27
- frame: frame
28
+ frame: frame,
29
+ placement: placement
28
30
  }, children);
29
31
  };
@@ -5,6 +5,7 @@ import type { StoryObj, Meta } from '@storybook/react';
5
5
  import { Button } from '../Button/Button';
6
6
  import { Modal } from '../Modal/Modal';
7
7
  import {
8
+ NotificationPlacement,
8
9
  NotificationIconPlacement,
9
10
  NotificationLayout,
10
11
  addNotification,
@@ -20,6 +21,7 @@ const titles = ['Выполнено', 'Внимание', 'Ошибка'];
20
21
  const texts = ['SSH ключ успешно скопирован', 'Нельзя скопировать SSH ключ', 'Не удалось скопировать SSH ключ'];
21
22
  const size = ['xs', 'xxs'];
22
23
  const iconPlacement = ['top', 'left'];
24
+ const notificationsPlacements = ['bottom-right', 'bottom-left'];
23
25
 
24
26
  const longText = `JavaScript frameworks are an essential part of modern front-end web development,
25
27
  providing developers with proven tools for building scalable, interactive web applications.
@@ -49,6 +51,7 @@ interface StoryDefaultProps {
49
51
  layout: NotificationLayout;
50
52
  size: 'xs' | 'xxs';
51
53
  iconPlacement: NotificationIconPlacement;
54
+ placement?: NotificationPlacement;
52
55
  }
53
56
 
54
57
  const StoryDefault = ({ title, children, iconPlacement, size, layout, showLeftIcon, ...rest }: StoryDefaultProps) => {
@@ -111,9 +114,10 @@ type StoryLiveDemoProps = ComponentProps<typeof Notification> & {
111
114
  layout: NotificationLayout;
112
115
  size: 'xs' | 'xxs';
113
116
  iconPlacement: NotificationIconPlacement;
117
+ placement?: NotificationPlacement;
114
118
  };
115
119
 
116
- const StoryLiveDemo = ({ timeout, ...rest }: StoryLiveDemoProps) => {
120
+ const StoryLiveDemo = ({ timeout, placement, ...rest }: StoryLiveDemoProps) => {
117
121
  const count = useRef(0);
118
122
  const handleClick = useCallback(() => {
119
123
  addNotification({ icon: <IconDisclosureRight />, ...rest, ...getNotificationProps(count.current) }, timeout);
@@ -121,7 +125,7 @@ const StoryLiveDemo = ({ timeout, ...rest }: StoryLiveDemoProps) => {
121
125
  }, [count, rest]);
122
126
 
123
127
  return (
124
- <NotificationsProvider>
128
+ <NotificationsProvider placement={placement}>
125
129
  <Button text="Добавить уведомление" onClick={handleClick} />
126
130
  </NotificationsProvider>
127
131
  );
@@ -135,20 +139,28 @@ export const LiveDemo: StoryObj<StoryLiveDemoProps> = {
135
139
  type: 'select',
136
140
  },
137
141
  },
142
+ placement: {
143
+ options: notificationsPlacements,
144
+ control: {
145
+ type: 'select',
146
+ },
147
+ },
138
148
  },
139
149
  args: {
140
150
  timeout: 3000,
141
151
  role: 'alert',
142
152
  layout: 'vertical',
153
+ placement: 'bottom-right',
143
154
  },
144
155
  render: (args) => <StoryLiveDemo {...args} />,
145
156
  };
146
157
 
147
158
  type StoryWithModalProps = ComponentProps<typeof Notification> & {
148
159
  timeout: number;
160
+ placement?: NotificationPlacement;
149
161
  };
150
162
 
151
- const StoryWithModal = ({ timeout }: StoryWithModalProps) => {
163
+ const StoryWithModal = ({ timeout, placement }: StoryWithModalProps) => {
152
164
  const [isModalOpen, setIsModalOpen] = useState(false);
153
165
  const count = useRef(0);
154
166
  const handleClick = useCallback(() => {
@@ -157,7 +169,7 @@ const StoryWithModal = ({ timeout }: StoryWithModalProps) => {
157
169
  }, [count]);
158
170
 
159
171
  return (
160
- <NotificationsProvider>
172
+ <NotificationsProvider placement={placement}>
161
173
  <PopupProvider>
162
174
  <Button text="Open modal" onClick={() => setIsModalOpen(true)} />
163
175
  <Modal frame="theme-root" opened={isModalOpen} onClose={() => setIsModalOpen(false)}>
@@ -172,6 +184,15 @@ const StoryWithModal = ({ timeout }: StoryWithModalProps) => {
172
184
  export const WithModal: StoryObj<StoryLiveDemoProps> = {
173
185
  args: {
174
186
  timeout: 3500,
187
+ placement: 'bottom-right',
188
+ },
189
+ argTypes: {
190
+ placement: {
191
+ options: notificationsPlacements,
192
+ control: {
193
+ type: 'select',
194
+ },
195
+ },
175
196
  },
176
197
  render: (args) => <StoryWithModal {...args} />,
177
198
  };
@@ -18,9 +18,9 @@ var config = exports.config = {
18
18
  gradient: /*#__PURE__*/(0, _styledComponents.css)(["", ":var(--text-primary);", ":var(--text-secondary);", ":var(--surface-solid-tertiary);", ":var(--on-light-surface-solid-card);", ":var(--surface-accent-gradient);", ":var(--surface-solid-tertiary);", ":var(--surface-accent-gradient);", ":var(--text-secondary);", ":var(--surface-transparent-primary);", ":var(--text-primary);", ":var(--text-secondary);", ":var(--text-primary);", ":var(--text-primary);"], _Slider.sliderTokens.labelColor, _Slider.sliderTokens.rangeValueColor, _Slider.sliderTokens.thumbBorderColor, _Slider.sliderTokens.thumbBackgroundColor, _Slider.sliderTokens.thumbFocusBorderColor, _Slider.sliderTokens.railBackgroundColor, _Slider.sliderTokens.fillColor, _Slider.sliderTokens.textFieldColor, _Slider.sliderTokens.textFieldBackgroundColor, _Slider.sliderTokens.textFieldCaretColor, _Slider.sliderTokens.textFieldPlaceholderColor, _Slider.sliderTokens.textFiledFocusColor, _Slider.sliderTokens.textFieldActiveColor)
19
19
  },
20
20
  size: {
21
- l: /*#__PURE__*/(0, _styledComponents.css)(["", ":1.5rem;", ":0.375rem;", ":0.25rem;", ":0.25rem;", ":0.875rem;", ":1rem;", ":var(--plasma-typo-body-l-font-family);", ":var(--plasma-typo-body-l-font-size);", ":var(--plasma-typo-body-l-font-style);", ":var(--plasma-typo-body-l-font-weight);", ":var(--plasma-typo-body-l-letter-spacing);", ":var(--plasma-typo-body-l-line-height);", ":0.75rem;", ":0.875rem;", ":0.875rem;", ":0.75rem;", ":var(--plasma-typo-body-m-font-family);", ":var(--plasma-typo-body-m-font-size);", ":var(--plasma-typo-body-m-font-style);", ":var(--plasma-typo-body-m-font-weight);", ":var(--plasma-typo-body-m-letter-spacing);", ":var(--plasma-typo-body-m-line-height);", ":1rem;", ":1.25rem;", ":0.0625rem solid;", ":1.625rem;", ":0.25rem;", ":0.125rem;", ":0.75rem;", ":0.125rem;", ":3.5rem;", ":1.25rem 1rem 1.25rem 1rem;", ":0.75rem;", ":var(--plasma-typo-body-l-font-family);", ":var(--plasma-typo-body-l-font-size);", ":var(--plasma-typo-body-l-font-style);", ":var(--plasma-typo-body-l-font-weight);", ":var(--plasma-typo-body-l-letter-spacing);", ":var(--plasma-typo-body-l-line-height);"], _Slider.sliderTokens.size, _Slider.sliderTokens.doubleWrapperGap, _Slider.sliderTokens.labelWrapperGap, _Slider.sliderTokens.labelWrapperMarginBottom, _Slider.sliderTokens.labelWrapperMarginRight, _Slider.sliderTokens.labelWrapperVerticalMargin, _Slider.sliderTokens.labelFontFamily, _Slider.sliderTokens.labelFontSize, _Slider.sliderTokens.labelFontStyle, _Slider.sliderTokens.labelFontWeight, _Slider.sliderTokens.labelLetterSpacing, _Slider.sliderTokens.labelLineHeight, _Slider.sliderTokens.rangeValueHorizontalMargin, _Slider.sliderTokens.rangeValueBottomOffset, _Slider.sliderTokens.rangeValueHorizontalOffset, _Slider.sliderTokens.rangeValueVerticalMargin, _Slider.sliderTokens.valueFontFamily, _Slider.sliderTokens.valueFontSize, _Slider.sliderTokens.valueFontStyle, _Slider.sliderTokens.valueFontWeight, _Slider.sliderTokens.valueLetterSpacing, _Slider.sliderTokens.valueLineHeight, _Slider.sliderTokens.thumbSize, _Slider.sliderTokens.thumbSizeLarge, _Slider.sliderTokens.thumbBorder, _Slider.sliderTokens.currentValueTopOffset, _Slider.sliderTokens.railThickness, _Slider.sliderTokens.railBorderRadius, _Slider.sliderTokens.railIndent, _Slider.sliderTokens.textFieldWrapperGap, _Slider.sliderTokens.textFieldHeight, _Slider.sliderTokens.textFieldPadding, _Slider.sliderTokens.textFieldBorderRadius, _Slider.sliderTokens.textFieldFontFamily, _Slider.sliderTokens.textFieldFontSize, _Slider.sliderTokens.textFieldFontStyle, _Slider.sliderTokens.textFieldFontWeight, _Slider.sliderTokens.textFieldLetterSpacing, _Slider.sliderTokens.textFieldLineHeight),
22
- m: /*#__PURE__*/(0, _styledComponents.css)(["", ":1.5rem;", ":0.375rem;", ":0.25rem;", ":0.25rem;", ":0.875rem;", ":0.75rem;", ":var(--plasma-typo-body-m-font-family);", ":var(--plasma-typo-body-m-font-size);", ":var(--plasma-typo-body-m-font-style);", ":var(--plasma-typo-body-m-font-weight);", ":var(--plasma-typo-body-m-letter-spacing);", ":var(--plasma-typo-body-m-line-height);", ":0.75rem;", ":0.75rem;", ":0.875rem;", ":0.625rem;", ":var(--plasma-typo-body-s-font-family);", ":var(--plasma-typo-body-s-font-size);", ":var(--plasma-typo-body-s-font-style);", ":var(--plasma-typo-body-s-font-weight);", ":var(--plasma-typo-body-s-letter-spacing);", ":var(--plasma-typo-body-s-line-height);", ":1rem;", ":1.25rem;", ":0.0625rem solid;", ":1.75rem;", ":0.25rem;", ":0.125rem;", ":0.75rem;", ":0.125rem;", ":3rem;", ":0.875rem 1rem 0.875rem 1rem;", ":0.75rem;", ":var(--plasma-typo-body-m-font-family);", ":var(--plasma-typo-body-m-font-size);", ":var(--plasma-typo-body-m-font-style);", ":var(--plasma-typo-body-m-font-weight);", ":var(--plasma-typo-body-m-letter-spacing);", ":var(--plasma-typo-body-m-line-height);"], _Slider.sliderTokens.size, _Slider.sliderTokens.doubleWrapperGap, _Slider.sliderTokens.labelWrapperGap, _Slider.sliderTokens.labelWrapperMarginBottom, _Slider.sliderTokens.labelWrapperMarginRight, _Slider.sliderTokens.labelWrapperVerticalMargin, _Slider.sliderTokens.labelFontFamily, _Slider.sliderTokens.labelFontSize, _Slider.sliderTokens.labelFontStyle, _Slider.sliderTokens.labelFontWeight, _Slider.sliderTokens.labelLetterSpacing, _Slider.sliderTokens.labelLineHeight, _Slider.sliderTokens.rangeValueHorizontalMargin, _Slider.sliderTokens.rangeValueBottomOffset, _Slider.sliderTokens.rangeValueHorizontalOffset, _Slider.sliderTokens.rangeValueVerticalMargin, _Slider.sliderTokens.valueFontFamily, _Slider.sliderTokens.valueFontSize, _Slider.sliderTokens.valueFontStyle, _Slider.sliderTokens.valueFontWeight, _Slider.sliderTokens.valueLetterSpacing, _Slider.sliderTokens.valueLineHeight, _Slider.sliderTokens.thumbSize, _Slider.sliderTokens.thumbSizeLarge, _Slider.sliderTokens.thumbBorder, _Slider.sliderTokens.currentValueTopOffset, _Slider.sliderTokens.railThickness, _Slider.sliderTokens.railBorderRadius, _Slider.sliderTokens.railIndent, _Slider.sliderTokens.textFieldWrapperGap, _Slider.sliderTokens.textFieldHeight, _Slider.sliderTokens.textFieldPadding, _Slider.sliderTokens.textFieldBorderRadius, _Slider.sliderTokens.textFieldFontFamily, _Slider.sliderTokens.textFieldFontSize, _Slider.sliderTokens.textFieldFontStyle, _Slider.sliderTokens.textFieldFontWeight, _Slider.sliderTokens.textFieldLetterSpacing, _Slider.sliderTokens.textFieldLineHeight),
23
- s: /*#__PURE__*/(0, _styledComponents.css)(["", ":1rem;", ":0.375rem;", ":0.25rem;", ":0.25rem;", ":0.875rem;", ":0.625rem;", ":var(--plasma-typo-body-s-font-family);", ":var(--plasma-typo-body-s-font-size);", ":var(--plasma-typo-body-s-font-style);", ":var(--plasma-typo-body-s-font-weight);", ":var(--plasma-typo-body-s-letter-spacing);", ":var(--plasma-typo-body-s-line-height);", ":0.5rem;", ":0.625rem;", ":0.625rem;", ":0.5rem;", ":var(--plasma-typo-body-xs-font-family);", ":var(--plasma-typo-body-xs-font-size);", ":var(--plasma-typo-body-xs-font-style);", ":var(--plasma-typo-body-xs-font-weight);", ":var(--plasma-typo-body-xs-letter-spacing);", ":var(--plasma-typo-body-xs-line-height);", ":1rem;", ":1.25rem;", ":0.0625rem solid;", ":1.25rem;", ":0.25rem;", ":0.125rem;", ":0.75rem;", ":0.125rem;", ":2.5rem;", ":0.5rem 1rem 0.5rem 1rem;", ":0.625rem;", ":var(--plasma-typo-body-s-font-family);", ":var(--plasma-typo-body-s-font-size);", ":var(--plasma-typo-body-s-font-style);", ":var(--plasma-typo-body-s-font-weight);", ":var(--plasma-typo-body-s-letter-spacing);", ":var(--plasma-typo-body-s-line-height);"], _Slider.sliderTokens.size, _Slider.sliderTokens.doubleWrapperGap, _Slider.sliderTokens.labelWrapperGap, _Slider.sliderTokens.labelWrapperMarginBottom, _Slider.sliderTokens.labelWrapperMarginRight, _Slider.sliderTokens.labelWrapperVerticalMargin, _Slider.sliderTokens.labelFontFamily, _Slider.sliderTokens.labelFontSize, _Slider.sliderTokens.labelFontStyle, _Slider.sliderTokens.labelFontWeight, _Slider.sliderTokens.labelLetterSpacing, _Slider.sliderTokens.labelLineHeight, _Slider.sliderTokens.rangeValueHorizontalMargin, _Slider.sliderTokens.rangeValueBottomOffset, _Slider.sliderTokens.rangeValueHorizontalOffset, _Slider.sliderTokens.rangeValueVerticalMargin, _Slider.sliderTokens.valueFontFamily, _Slider.sliderTokens.valueFontSize, _Slider.sliderTokens.valueFontStyle, _Slider.sliderTokens.valueFontWeight, _Slider.sliderTokens.valueLetterSpacing, _Slider.sliderTokens.valueLineHeight, _Slider.sliderTokens.thumbSize, _Slider.sliderTokens.thumbSizeLarge, _Slider.sliderTokens.thumbBorder, _Slider.sliderTokens.currentValueTopOffset, _Slider.sliderTokens.railThickness, _Slider.sliderTokens.railBorderRadius, _Slider.sliderTokens.railIndent, _Slider.sliderTokens.textFieldWrapperGap, _Slider.sliderTokens.textFieldHeight, _Slider.sliderTokens.textFieldPadding, _Slider.sliderTokens.textFieldBorderRadius, _Slider.sliderTokens.textFieldFontFamily, _Slider.sliderTokens.textFieldFontSize, _Slider.sliderTokens.textFieldFontStyle, _Slider.sliderTokens.textFieldFontWeight, _Slider.sliderTokens.textFieldLetterSpacing, _Slider.sliderTokens.textFieldLineHeight)
21
+ l: /*#__PURE__*/(0, _styledComponents.css)(["", ":1.5rem;", ":0.375rem;", ":0.25rem;", ":0.25rem;", ":0.875rem;", ":var(--plasma-typo-body-l-font-family);", ":var(--plasma-typo-body-l-font-size);", ":var(--plasma-typo-body-l-font-style);", ":var(--plasma-typo-body-l-font-weight);", ":var(--plasma-typo-body-l-letter-spacing);", ":var(--plasma-typo-body-l-line-height);", ":0.75rem;", ":0.75rem;", ":-1.25rem;", ":var(--plasma-typo-body-s-font-family);", ":var(--plasma-typo-body-s-font-size);", ":var(--plasma-typo-body-s-font-style);", ":var(--plasma-typo-body-s-font-weight);", ":var(--plasma-typo-body-s-letter-spacing);", ":var(--plasma-typo-body-s-line-height);", ":1.5rem;", ":0.125rem solid;", ":1.625rem;", ":var(--plasma-typo-text-s-font-family);", ":var(--plasma-typo-text-s-font-size);", ":var(--plasma-typo-text-s-font-style);", ":var(--plasma-typo-text-s-font-weight);", ":var(--plasma-typo-text-s-letter-spacing);", ":var(--plasma-typo-text-s-line-height);", ":0.25rem;", ":0.125rem;", ":0.75rem;", ":0.125rem;", ":3.5rem;", ":1.25rem 1rem 1.25rem 1rem;", ":0.75rem;", ":var(--plasma-typo-body-l-font-family);", ":var(--plasma-typo-body-l-font-size);", ":var(--plasma-typo-body-l-font-style);", ":var(--plasma-typo-body-l-font-weight);", ":var(--plasma-typo-body-l-letter-spacing);", ":var(--plasma-typo-body-l-line-height);"], _Slider.sliderTokens.height, _Slider.sliderTokens.doubleWrapperGap, _Slider.sliderTokens.labelWrapperGap, _Slider.sliderTokens.labelWrapperMarginBottom, _Slider.sliderTokens.labelWrapperMarginRight, _Slider.sliderTokens.labelFontFamily, _Slider.sliderTokens.labelFontSize, _Slider.sliderTokens.labelFontStyle, _Slider.sliderTokens.labelFontWeight, _Slider.sliderTokens.labelLetterSpacing, _Slider.sliderTokens.labelLineHeight, _Slider.sliderTokens.rangeMinValueMargin, _Slider.sliderTokens.rangeMaxValueMargin, _Slider.sliderTokens.rangeValueBottomOffset, _Slider.sliderTokens.rangeValueFontFamily, _Slider.sliderTokens.rangeValueFontSize, _Slider.sliderTokens.rangeValueFontStyle, _Slider.sliderTokens.rangeValueFontWeight, _Slider.sliderTokens.rangeValueLetterSpacing, _Slider.sliderTokens.rangeValueLineHeight, _Slider.sliderTokens.thumbSize, _Slider.sliderTokens.thumbBorder, _Slider.sliderTokens.currentValueTopOffset, _Slider.sliderTokens.currentValueFontFamily, _Slider.sliderTokens.currentValueFontSize, _Slider.sliderTokens.currentValueFontStyle, _Slider.sliderTokens.currentValueFontWeight, _Slider.sliderTokens.currentValueLetterSpacing, _Slider.sliderTokens.currentValueLineHeight, _Slider.sliderTokens.railHeight, _Slider.sliderTokens.railBorderRadius, _Slider.sliderTokens.railIndent, _Slider.sliderTokens.textFieldWrapperGap, _Slider.sliderTokens.textFieldHeight, _Slider.sliderTokens.textFieldPadding, _Slider.sliderTokens.textFieldBorderRadius, _Slider.sliderTokens.textFieldFontFamily, _Slider.sliderTokens.textFieldFontSize, _Slider.sliderTokens.textFieldFontStyle, _Slider.sliderTokens.textFieldFontWeight, _Slider.sliderTokens.textFieldLetterSpacing, _Slider.sliderTokens.textFieldLineHeight),
22
+ m: /*#__PURE__*/(0, _styledComponents.css)(["", ":1.5rem;", ":0.375rem;", ":0.25rem;", ":0.25rem;", ":0.875rem;", ":var(--plasma-typo-body-m-font-family);", ":var(--plasma-typo-body-m-font-size);", ":var(--plasma-typo-body-m-font-style);", ":var(--plasma-typo-body-m-font-weight);", ":var(--plasma-typo-body-m-letter-spacing);", ":var(--plasma-typo-body-m-line-height);", ":0.75rem;", ":0.75rem;", ":-1.25rem;", ":var(--plasma-typo-body-s-font-family);", ":var(--plasma-typo-body-s-font-size);", ":var(--plasma-typo-body-s-font-style);", ":var(--plasma-typo-body-s-font-weight);", ":var(--plasma-typo-body-s-letter-spacing);", ":var(--plasma-typo-body-s-line-height);", ":1.5rem;", ":0.125rem solid;", ":1.75rem;", ":var(--plasma-typo-text-xs-font-family);", ":var(--plasma-typo-text-xs-font-size);", ":var(--plasma-typo-text-xs-font-style);", ":var(--plasma-typo-text-xs-font-weight);", ":var(--plasma-typo-text-xs-letter-spacing);", ":var(--plasma-typo-text-xs-line-height);", ":0.25rem;", ":0.125rem;", ":0.75rem;", ":0.125rem;", ":3rem;", ":0.875rem 1rem 0.875rem 1rem;", ":0.75rem;", ":var(--plasma-typo-body-m-font-family);", ":var(--plasma-typo-body-m-font-size);", ":var(--plasma-typo-body-m-font-style);", ":var(--plasma-typo-body-m-font-weight);", ":var(--plasma-typo-body-m-letter-spacing);", ":var(--plasma-typo-body-m-line-height);"], _Slider.sliderTokens.height, _Slider.sliderTokens.doubleWrapperGap, _Slider.sliderTokens.labelWrapperGap, _Slider.sliderTokens.labelWrapperMarginBottom, _Slider.sliderTokens.labelWrapperMarginRight, _Slider.sliderTokens.labelFontFamily, _Slider.sliderTokens.labelFontSize, _Slider.sliderTokens.labelFontStyle, _Slider.sliderTokens.labelFontWeight, _Slider.sliderTokens.labelLetterSpacing, _Slider.sliderTokens.labelLineHeight, _Slider.sliderTokens.rangeMinValueMargin, _Slider.sliderTokens.rangeMaxValueMargin, _Slider.sliderTokens.rangeValueBottomOffset, _Slider.sliderTokens.rangeValueFontFamily, _Slider.sliderTokens.rangeValueFontSize, _Slider.sliderTokens.rangeValueFontStyle, _Slider.sliderTokens.rangeValueFontWeight, _Slider.sliderTokens.rangeValueLetterSpacing, _Slider.sliderTokens.rangeValueLineHeight, _Slider.sliderTokens.thumbSize, _Slider.sliderTokens.thumbBorder, _Slider.sliderTokens.currentValueTopOffset, _Slider.sliderTokens.currentValueFontFamily, _Slider.sliderTokens.currentValueFontSize, _Slider.sliderTokens.currentValueFontStyle, _Slider.sliderTokens.currentValueFontWeight, _Slider.sliderTokens.currentValueLetterSpacing, _Slider.sliderTokens.currentValueLineHeight, _Slider.sliderTokens.railHeight, _Slider.sliderTokens.railBorderRadius, _Slider.sliderTokens.railIndent, _Slider.sliderTokens.textFieldWrapperGap, _Slider.sliderTokens.textFieldHeight, _Slider.sliderTokens.textFieldPadding, _Slider.sliderTokens.textFieldBorderRadius, _Slider.sliderTokens.textFieldFontFamily, _Slider.sliderTokens.textFieldFontSize, _Slider.sliderTokens.textFieldFontStyle, _Slider.sliderTokens.textFieldFontWeight, _Slider.sliderTokens.textFieldLetterSpacing, _Slider.sliderTokens.textFieldLineHeight),
23
+ s: /*#__PURE__*/(0, _styledComponents.css)(["", ":1rem;", ":0.375rem;", ":0.25rem;", ":0.25rem;", ":0.875rem;", ":var(--plasma-typo-body-s-font-family);", ":var(--plasma-typo-body-s-font-size);", ":var(--plasma-typo-body-s-font-style);", ":var(--plasma-typo-body-s-font-weight);", ":var(--plasma-typo-body-s-letter-spacing);", ":var(--plasma-typo-body-s-line-height);", ":0.5rem;", ":0.5rem;", ":-1.25rem;", ":var(--plasma-typo-body-xs-font-family);", ":var(--plasma-typo-body-xs-font-size);", ":var(--plasma-typo-body-xs-font-style);", ":var(--plasma-typo-body-xs-font-weight);", ":var(--plasma-typo-body-xs-letter-spacing);", ":var(--plasma-typo-body-xs-line-height);", ":1rem;", ":0.125rem solid;", ":1.25rem;", ":var(--plasma-typo-text-xs-font-family);", ":var(--plasma-typo-text-xs-font-size);", ":var(--plasma-typo-text-xs-font-style);", ":var(--plasma-typo-text-xs-font-weight);", ":var(--plasma-typo-text-xs-letter-spacing);", ":var(--plasma-typo-text-xs-line-height);", ":0.25rem;", ":0.125rem;", ":0.75rem;", ":0.125rem;", ":2.5rem;", ":0.5rem 1rem 0.5rem 1rem;", ":0.625rem;", ":var(--plasma-typo-body-s-font-family);", ":var(--plasma-typo-body-s-font-size);", ":var(--plasma-typo-body-s-font-style);", ":var(--plasma-typo-body-s-font-weight);", ":var(--plasma-typo-body-s-letter-spacing);", ":var(--plasma-typo-body-s-line-height);"], _Slider.sliderTokens.height, _Slider.sliderTokens.doubleWrapperGap, _Slider.sliderTokens.labelWrapperGap, _Slider.sliderTokens.labelWrapperMarginBottom, _Slider.sliderTokens.labelWrapperMarginRight, _Slider.sliderTokens.labelFontFamily, _Slider.sliderTokens.labelFontSize, _Slider.sliderTokens.labelFontStyle, _Slider.sliderTokens.labelFontWeight, _Slider.sliderTokens.labelLetterSpacing, _Slider.sliderTokens.labelLineHeight, _Slider.sliderTokens.rangeMinValueMargin, _Slider.sliderTokens.rangeMaxValueMargin, _Slider.sliderTokens.rangeValueBottomOffset, _Slider.sliderTokens.rangeValueFontFamily, _Slider.sliderTokens.rangeValueFontSize, _Slider.sliderTokens.rangeValueFontStyle, _Slider.sliderTokens.rangeValueFontWeight, _Slider.sliderTokens.rangeValueLetterSpacing, _Slider.sliderTokens.rangeValueLineHeight, _Slider.sliderTokens.thumbSize, _Slider.sliderTokens.thumbBorder, _Slider.sliderTokens.currentValueTopOffset, _Slider.sliderTokens.currentValueFontFamily, _Slider.sliderTokens.currentValueFontSize, _Slider.sliderTokens.currentValueFontStyle, _Slider.sliderTokens.currentValueFontWeight, _Slider.sliderTokens.currentValueLetterSpacing, _Slider.sliderTokens.currentValueLineHeight, _Slider.sliderTokens.railHeight, _Slider.sliderTokens.railBorderRadius, _Slider.sliderTokens.railIndent, _Slider.sliderTokens.textFieldWrapperGap, _Slider.sliderTokens.textFieldHeight, _Slider.sliderTokens.textFieldPadding, _Slider.sliderTokens.textFieldBorderRadius, _Slider.sliderTokens.textFieldFontFamily, _Slider.sliderTokens.textFieldFontSize, _Slider.sliderTokens.textFieldFontStyle, _Slider.sliderTokens.textFieldFontWeight, _Slider.sliderTokens.textFieldLetterSpacing, _Slider.sliderTokens.textFieldLineHeight)
24
24
  },
25
25
  disabled: {
26
26
  "true": /*#__PURE__*/(0, _styledComponents.css)(["", ":0.4;"], _Slider.sliderTokens.disabledOpacity)
@@ -3,19 +3,16 @@ import type { ComponentProps } from 'react';
3
3
  import styled from 'styled-components';
4
4
  import { disableProps } from '@salutejs/plasma-sb-utils';
5
5
  import type { StoryObj, Meta } from '@storybook/react';
6
+ import { action } from '@storybook/addon-actions';
6
7
 
7
- import { IconMic } from '../../../../components/_Icon';
8
8
  import { WithTheme } from '../../../_helpers';
9
9
 
10
10
  import { Slider } from './Slider';
11
11
 
12
12
  const sizes = ['l', 'm', 's'];
13
- const pointerSizes = ['small', 'large', 'none'];
14
13
  const views = ['default', 'accent', 'gradient'];
15
- const sliderAligns = ['center', 'left', 'right', 'none'];
16
- const labelPlacements = ['top', 'left'];
17
- const scaleAligns = ['side', 'bottom'];
18
- const orientations: Array<string> = ['vertical', 'horizontal'];
14
+ const labelPlacements = ['outer', 'inner'];
15
+ const rangeValuesPlacement = ['outer', 'inner'];
19
16
 
20
17
  const meta: Meta<typeof Slider> = {
21
18
  title: 'plasma_b2c/Slider',
@@ -34,24 +31,9 @@ const meta: Meta<typeof Slider> = {
34
31
  type: 'inline-radio',
35
32
  },
36
33
  },
37
- pointerSize: {
38
- options: pointerSizes,
39
- control: {
40
- type: 'inline-radio',
41
- },
42
- },
43
- orientation: {
44
- options: orientations,
45
- control: {
46
- type: 'select',
47
- },
48
- },
49
34
  ...disableProps([
50
35
  'value',
51
36
  'onChangeCommitted',
52
- 'onChangeTextField',
53
- 'onBlurTextField',
54
- 'onKeyDownTextField',
55
37
  'ariaLabel',
56
38
  'onChange',
57
39
  'fontSizeMultiplier',
@@ -71,9 +53,8 @@ type StorySingleProps = StoryProps;
71
53
  type StorySingle = StoryObj<StorySingleProps>;
72
54
  type StoryDouble = StoryObj<StoryProps>;
73
55
 
74
- const SliderWrapper = styled.div<{ isVertical?: boolean }>`
75
- width: ${({ isVertical }) => (isVertical ? 'auto' : '25rem')};
76
- height: ${({ isVertical }) => (isVertical ? '25rem' : 'auto')};
56
+ const SliderWrapper = styled.div`
57
+ width: 25rem;
77
58
  `;
78
59
 
79
60
  const StoryDefault = (args: StorySingleProps) => {
@@ -87,86 +68,41 @@ const StoryDefault = (args: StorySingleProps) => {
87
68
  setValue(values);
88
69
  };
89
70
 
90
- const { hasIcon, showIcon, orientation, labelPlacement, labelVerticalPlacement, ...rest } = args;
91
- const isVertical = orientation === 'vertical';
92
-
93
71
  return (
94
- <SliderWrapper isVertical={isVertical}>
95
- <Slider
96
- value={value}
97
- orientation={orientation}
98
- labelPlacement={labelPlacement}
99
- labelContent={showIcon ? <IconMic size={rest.size === 's' ? 'xs' : 's'} /> : null}
100
- onChangeCommitted={onChangeCommittedHandle}
101
- onChange={onChangeHandle}
102
- {...rest}
103
- />
72
+ <SliderWrapper>
73
+ <Slider value={value} onChangeCommitted={onChangeCommittedHandle} onChange={onChangeHandle} {...args} />
104
74
  </SliderWrapper>
105
75
  );
106
76
  };
107
77
 
108
78
  export const Default: StorySingle = {
109
79
  argTypes: {
110
- sliderAlign: {
111
- options: sliderAligns,
112
- control: {
113
- type: 'inline-radio',
114
- },
115
- if: { arg: 'orientation', eq: 'vertical' },
116
- },
117
80
  labelPlacement: {
118
81
  options: labelPlacements,
119
82
  control: {
120
83
  type: 'inline-radio',
121
84
  },
122
- if: { arg: 'orientation', eq: 'horizontal' },
123
- },
124
- labelReversed: {
125
- control: {
126
- type: 'boolean',
127
- expanded: true,
128
- },
129
- if: { arg: 'orientation', eq: 'vertical' },
130
- },
131
- scaleAlign: {
132
- options: scaleAligns,
133
- control: {
134
- type: 'inline-radio',
135
- },
136
- if: { arg: 'orientation', eq: 'horizontal' },
137
85
  },
138
- orientation: {
139
- options: orientations,
86
+ rangeValuesPlacement: {
87
+ options: rangeValuesPlacement,
140
88
  control: {
141
89
  type: 'inline-radio',
142
90
  },
143
91
  },
144
- reversed: {
145
- control: {
146
- type: 'boolean',
147
- },
148
- if: { arg: 'orientation', eq: 'vertical' },
149
- },
150
92
  },
151
93
  args: {
152
94
  view: 'default',
153
95
  size: 'm',
154
- pointerSize: 'small',
155
96
  min: 0,
156
97
  max: 100,
157
- orientation: 'horizontal',
158
- ariaLabel: 'Цена микрофона',
98
+ disabled: false,
99
+ ariaLabel: 'Цена товара',
159
100
  multipleStepSize: 10,
160
- label: 'Цена микрофона',
161
- labelPlacement: 'top',
162
- sliderAlign: 'center',
163
- scaleAlign: 'bottom',
164
- showScale: true,
101
+ label: 'Цена товара',
102
+ labelPlacement: 'outer',
103
+ rangeValuesPlacement: 'outer',
104
+ showRangeValues: true,
165
105
  showCurrentValue: false,
166
- showIcon: true,
167
- reversed: false,
168
- labelReversed: false,
169
- disabled: false,
170
106
  },
171
107
  render: (args) => <StoryDefault {...args} />,
172
108
  };
@@ -206,7 +142,7 @@ const StoryMultipleValues = (args: StoryProps) => {
206
142
  };
207
143
 
208
144
  return (
209
- <SliderWrapper isVertical={args.orientation === 'vertical'}>
145
+ <SliderWrapper>
210
146
  <Slider
211
147
  value={value}
212
148
  onKeyDownTextField={onKeyDownTextField}
@@ -223,7 +159,6 @@ export const MultipleValues: StoryDouble = {
223
159
  args: {
224
160
  view: 'default',
225
161
  size: 'm',
226
- pointerSize: 'small',
227
162
  min: 0,
228
163
  max: 100,
229
164
  disabled: false,
@@ -231,14 +166,5 @@ export const MultipleValues: StoryDouble = {
231
166
  ariaLabel: ['Минимальная цена товара', 'Максимальная цена товара'],
232
167
  multipleStepSize: 10,
233
168
  },
234
- argTypes: {
235
- pointerSize: {
236
- options: ['small', 'large'],
237
- control: {
238
- type: 'inline-radio',
239
- },
240
- },
241
- ...disableProps(['orientation']),
242
- },
243
169
  render: (args) => <StoryMultipleValues {...args} />,
244
170
  };
@@ -16,14 +16,16 @@ var _engines = /*#__PURE__*/require("../../../../engines");
16
16
  var _Notification2 = /*#__PURE__*/require("./Notification.config");
17
17
  var _Modal = /*#__PURE__*/require("../../../../components/Modal");
18
18
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
19
- var mergedConfig = /*#__PURE__*/(0, _engines.mergeConfig)(_Notification.noticationConfig, _Notification2.config);
19
+ var mergedConfig = /*#__PURE__*/(0, _engines.mergeConfig)(_Notification.notificationConfig, _Notification2.config);
20
20
  var Notification = exports.Notification = /*#__PURE__*/(0, _engines.component)(mergedConfig);
21
21
  var NotificationsProvider = exports.NotificationsProvider = function NotificationsProvider(_ref) {
22
22
  var children = _ref.children,
23
23
  _ref$frame = _ref.frame,
24
- frame = _ref$frame === void 0 ? 'theme-root' : _ref$frame;
24
+ frame = _ref$frame === void 0 ? 'theme-root' : _ref$frame,
25
+ placement = _ref.placement;
25
26
  return /*#__PURE__*/_react["default"].createElement(_Notification.NotificationsProvider, {
26
27
  config: mergedConfig,
27
- frame: frame
28
+ frame: frame,
29
+ placement: placement
28
30
  }, children);
29
31
  };
@@ -5,6 +5,7 @@ import type { StoryObj, Meta } from '@storybook/react';
5
5
  import { Button } from '../Button/Button';
6
6
  import { Modal } from '../Modal/Modal';
7
7
  import {
8
+ NotificationPlacement,
8
9
  NotificationIconPlacement,
9
10
  NotificationLayout,
10
11
  addNotification,
@@ -20,6 +21,7 @@ const titles = ['Выполнено', 'Внимание', 'Ошибка'];
20
21
  const texts = ['SSH ключ успешно скопирован', 'Нельзя скопировать SSH ключ', 'Не удалось скопировать SSH ключ'];
21
22
  const size = ['xs', 'xxs'];
22
23
  const iconPlacement = ['top', 'left'];
24
+ const notificationsPlacements = ['bottom-right', 'bottom-left'];
23
25
 
24
26
  const longText = `JavaScript frameworks are an essential part of modern front-end web development,
25
27
  providing developers with proven tools for building scalable, interactive web applications.
@@ -49,6 +51,7 @@ interface StoryDefaultProps {
49
51
  layout: NotificationLayout;
50
52
  size: 'xs' | 'xxs';
51
53
  iconPlacement: NotificationIconPlacement;
54
+ placement?: NotificationPlacement;
52
55
  }
53
56
 
54
57
  const StoryDefault = ({ title, children, iconPlacement, size, layout, showLeftIcon, ...rest }: StoryDefaultProps) => {
@@ -111,9 +114,10 @@ type StoryLiveDemoProps = ComponentProps<typeof Notification> & {
111
114
  layout: NotificationLayout;
112
115
  size: 'xs' | 'xxs';
113
116
  iconPlacement: NotificationIconPlacement;
117
+ placement?: NotificationPlacement;
114
118
  };
115
119
 
116
- const StoryLiveDemo = ({ timeout, ...rest }: StoryLiveDemoProps) => {
120
+ const StoryLiveDemo = ({ timeout, placement, ...rest }: StoryLiveDemoProps) => {
117
121
  const count = useRef(0);
118
122
  const handleClick = useCallback(() => {
119
123
  addNotification({ icon: <IconDisclosureRight />, ...rest, ...getNotificationProps(count.current) }, timeout);
@@ -121,7 +125,7 @@ const StoryLiveDemo = ({ timeout, ...rest }: StoryLiveDemoProps) => {
121
125
  }, [count, rest]);
122
126
 
123
127
  return (
124
- <NotificationsProvider>
128
+ <NotificationsProvider placement={placement}>
125
129
  <Button text="Добавить уведомление" onClick={handleClick} />
126
130
  </NotificationsProvider>
127
131
  );
@@ -135,20 +139,28 @@ export const LiveDemo: StoryObj<StoryLiveDemoProps> = {
135
139
  type: 'select',
136
140
  },
137
141
  },
142
+ placement: {
143
+ options: notificationsPlacements,
144
+ control: {
145
+ type: 'select',
146
+ },
147
+ },
138
148
  },
139
149
  args: {
140
150
  timeout: 3000,
141
151
  role: 'alert',
142
152
  layout: 'vertical',
153
+ placement: 'bottom-right',
143
154
  },
144
155
  render: (args) => <StoryLiveDemo {...args} />,
145
156
  };
146
157
 
147
158
  type StoryWithModalProps = ComponentProps<typeof Notification> & {
148
159
  timeout: number;
160
+ placement?: NotificationPlacement;
149
161
  };
150
162
 
151
- const StoryWithModal = ({ timeout }: StoryWithModalProps) => {
163
+ const StoryWithModal = ({ timeout, placement }: StoryWithModalProps) => {
152
164
  const [isModalOpen, setIsModalOpen] = useState(false);
153
165
  const count = useRef(0);
154
166
  const handleClick = useCallback(() => {
@@ -157,7 +169,7 @@ const StoryWithModal = ({ timeout }: StoryWithModalProps) => {
157
169
  }, [count]);
158
170
 
159
171
  return (
160
- <NotificationsProvider>
172
+ <NotificationsProvider placement={placement}>
161
173
  <PopupProvider>
162
174
  <Button text="Open modal" onClick={() => setIsModalOpen(true)} />
163
175
  <Modal frame="theme-root" opened={isModalOpen} onClose={() => setIsModalOpen(false)}>
@@ -172,6 +184,15 @@ const StoryWithModal = ({ timeout }: StoryWithModalProps) => {
172
184
  export const WithModal: StoryObj<StoryLiveDemoProps> = {
173
185
  args: {
174
186
  timeout: 3500,
187
+ placement: 'bottom-right',
188
+ },
189
+ argTypes: {
190
+ placement: {
191
+ options: notificationsPlacements,
192
+ control: {
193
+ type: 'select',
194
+ },
195
+ },
175
196
  },
176
197
  render: (args) => <StoryWithModal {...args} />,
177
198
  };