@alfalab/core-components 47.9.0-beta.1 → 47.10.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (475) hide show
  1. package/calendar/Component.responsive.d.ts +1 -0
  2. package/calendar/components/calendar-mobile/Component.d.ts +18 -2
  3. package/calendar/components/calendar-mobile/Component.js +63 -26
  4. package/calendar/components/calendar-mobile/index.css +26 -4
  5. package/calendar/components/calendar-mobile/typings.d.ts +8 -1
  6. package/calendar/components/days-table/Component.d.ts +8 -0
  7. package/calendar/components/days-table/Component.js +21 -2
  8. package/calendar/components/days-table/index.css +8 -0
  9. package/calendar/cssm/Component.responsive.d.ts +1 -0
  10. package/calendar/cssm/components/calendar-mobile/Component.d.ts +18 -2
  11. package/calendar/cssm/components/calendar-mobile/Component.js +62 -25
  12. package/calendar/cssm/components/calendar-mobile/index.module.css +26 -4
  13. package/calendar/cssm/components/calendar-mobile/typings.d.ts +8 -1
  14. package/calendar/cssm/components/days-table/Component.d.ts +8 -0
  15. package/calendar/cssm/components/days-table/Component.js +20 -1
  16. package/calendar/cssm/components/days-table/index.module.css +8 -0
  17. package/calendar/cssm/useCalendar.d.ts +8 -2
  18. package/calendar/cssm/useCalendar.js +4 -1
  19. package/calendar/esm/Component.responsive.d.ts +1 -0
  20. package/calendar/esm/Component.responsive.js +3 -1
  21. package/calendar/esm/components/calendar-mobile/Component.d.ts +18 -2
  22. package/calendar/esm/components/calendar-mobile/Component.js +65 -29
  23. package/calendar/esm/components/calendar-mobile/index.css +26 -4
  24. package/calendar/esm/components/calendar-mobile/index.js +3 -1
  25. package/calendar/esm/components/calendar-mobile/typings.d.ts +8 -1
  26. package/calendar/esm/components/days-table/Component.d.ts +8 -0
  27. package/calendar/esm/components/days-table/Component.js +22 -3
  28. package/calendar/esm/components/days-table/index.css +8 -0
  29. package/calendar/esm/components/days-table/index.js +1 -0
  30. package/calendar/esm/desktop/Component.desktop.js +1 -0
  31. package/calendar/esm/desktop/index.js +1 -0
  32. package/calendar/esm/index.js +3 -1
  33. package/calendar/esm/mobile/index.js +3 -1
  34. package/calendar/esm/useCalendar.d.ts +8 -2
  35. package/calendar/esm/useCalendar.js +4 -1
  36. package/calendar/modern/Component.responsive.d.ts +1 -0
  37. package/calendar/modern/Component.responsive.js +3 -1
  38. package/calendar/modern/components/calendar-mobile/Component.d.ts +18 -2
  39. package/calendar/modern/components/calendar-mobile/Component.js +64 -16
  40. package/calendar/modern/components/calendar-mobile/index.css +26 -4
  41. package/calendar/modern/components/calendar-mobile/index.js +3 -1
  42. package/calendar/modern/components/calendar-mobile/typings.d.ts +8 -1
  43. package/calendar/modern/components/days-table/Component.d.ts +8 -0
  44. package/calendar/modern/components/days-table/Component.js +22 -3
  45. package/calendar/modern/components/days-table/index.css +8 -0
  46. package/calendar/modern/components/days-table/index.js +1 -0
  47. package/calendar/modern/desktop/Component.desktop.js +1 -0
  48. package/calendar/modern/desktop/index.js +1 -0
  49. package/calendar/modern/index.js +3 -1
  50. package/calendar/modern/mobile/index.js +3 -1
  51. package/calendar/modern/useCalendar.d.ts +8 -2
  52. package/calendar/modern/useCalendar.js +3 -1
  53. package/calendar/useCalendar.d.ts +8 -2
  54. package/calendar/useCalendar.js +4 -1
  55. package/calendar-input/components/calendar-input/Component.d.ts +1 -0
  56. package/calendar-input/cssm/components/calendar-input/Component.d.ts +1 -0
  57. package/calendar-input/esm/components/calendar-input/Component.d.ts +1 -0
  58. package/calendar-input/modern/components/calendar-input/Component.d.ts +1 -0
  59. package/date-time-input/components/date-time-input/Component.d.ts +2 -3
  60. package/date-time-input/cssm/components/date-time-input/Component.d.ts +2 -3
  61. package/date-time-input/esm/components/date-time-input/Component.d.ts +2 -3
  62. package/date-time-input/modern/components/date-time-input/Component.d.ts +2 -3
  63. package/gallery/components/header/Component.js +1 -1
  64. package/gallery/components/header/buttons.js +1 -1
  65. package/gallery/components/image-viewer/component.js +1 -1
  66. package/gallery/components/image-viewer/slide.js +1 -1
  67. package/gallery/esm/Component.js +2 -2
  68. package/gallery/esm/components/header/Component.js +1 -1
  69. package/gallery/esm/components/header/buttons.js +1 -1
  70. package/gallery/esm/components/header/index.js +1 -1
  71. package/gallery/esm/components/image-preview/Component.js +1 -1
  72. package/gallery/esm/components/image-preview/index.js +1 -1
  73. package/gallery/esm/components/image-viewer/component.js +1 -1
  74. package/gallery/esm/components/image-viewer/index.js +1 -1
  75. package/gallery/esm/components/image-viewer/slide.js +1 -1
  76. package/gallery/esm/components/index.js +2 -2
  77. package/gallery/esm/components/navigation-bar/Component.js +1 -1
  78. package/gallery/esm/components/navigation-bar/index.js +1 -1
  79. package/gallery/esm/index.js +2 -2
  80. package/gallery/modern/Component.js +2 -2
  81. package/gallery/modern/components/header/Component.js +1 -1
  82. package/gallery/modern/components/header/buttons.js +1 -1
  83. package/gallery/modern/components/header/index.js +1 -1
  84. package/gallery/modern/components/image-preview/Component.js +1 -1
  85. package/gallery/modern/components/image-preview/index.js +1 -1
  86. package/gallery/modern/components/image-viewer/component.js +1 -1
  87. package/gallery/modern/components/image-viewer/index.js +1 -1
  88. package/gallery/modern/components/image-viewer/slide.js +1 -1
  89. package/gallery/modern/components/index.js +2 -2
  90. package/gallery/modern/components/navigation-bar/Component.js +1 -1
  91. package/gallery/modern/components/navigation-bar/index.js +1 -1
  92. package/gallery/modern/index.js +2 -2
  93. package/international-phone-input/{Component-6563e05c.d.ts → Component-9d430401.d.ts} +1 -1
  94. package/international-phone-input/Component.responsive.d.ts +4 -4
  95. package/international-phone-input/components/base-international-phone-input/Component.d.ts +1 -1
  96. package/international-phone-input/cssm/{Component-6563e05c.d.ts → Component-9d430401.d.ts} +1 -1
  97. package/international-phone-input/cssm/Component.responsive.d.ts +4 -4
  98. package/international-phone-input/cssm/components/base-international-phone-input/Component.d.ts +1 -1
  99. package/international-phone-input/cssm/types.d.ts +1 -1
  100. package/international-phone-input/cssm/{typings-6563e05c.d.ts → typings-9d430401.d.ts} +0 -12
  101. package/international-phone-input/cssm/utils-87b0c1c6.d.ts +1 -1
  102. package/international-phone-input/esm/{Component-6563e05c.d.ts → Component-9d430401.d.ts} +1 -1
  103. package/international-phone-input/esm/Component.responsive.d.ts +4 -4
  104. package/international-phone-input/esm/components/base-international-phone-input/Component.d.ts +1 -1
  105. package/international-phone-input/esm/types.d.ts +1 -1
  106. package/international-phone-input/esm/{typings-6563e05c.d.ts → typings-9d430401.d.ts} +0 -12
  107. package/international-phone-input/esm/utils-87b0c1c6.d.ts +1 -1
  108. package/international-phone-input/modern/{Component-6563e05c.d.ts → Component-9d430401.d.ts} +1 -1
  109. package/international-phone-input/modern/Component.responsive.d.ts +4 -4
  110. package/international-phone-input/modern/components/base-international-phone-input/Component.d.ts +1 -1
  111. package/international-phone-input/modern/types.d.ts +1 -1
  112. package/international-phone-input/modern/{typings-6563e05c.d.ts → typings-9d430401.d.ts} +0 -12
  113. package/international-phone-input/modern/utils-87b0c1c6.d.ts +1 -1
  114. package/international-phone-input/types.d.ts +1 -1
  115. package/international-phone-input/{typings-6563e05c.d.ts → typings-9d430401.d.ts} +0 -12
  116. package/international-phone-input/utils-87b0c1c6.d.ts +1 -1
  117. package/package.json +1 -1
  118. package/picker-button/Component-9d430401.d.ts +5 -0
  119. package/picker-button/cssm/Component-9d430401.d.ts +5 -0
  120. package/picker-button/cssm/field/Component.d.ts +1 -1
  121. package/picker-button/cssm/{typings-6563e05c.d.ts → typings-9d430401.d.ts} +0 -12
  122. package/picker-button/cssm/utils-87b0c1c6.d.ts +1 -1
  123. package/picker-button/esm/Component-9d430401.d.ts +5 -0
  124. package/picker-button/esm/field/Component.d.ts +1 -1
  125. package/picker-button/esm/{typings-6563e05c.d.ts → typings-9d430401.d.ts} +0 -12
  126. package/picker-button/esm/utils-87b0c1c6.d.ts +1 -1
  127. package/picker-button/field/Component.d.ts +1 -1
  128. package/picker-button/modern/Component-9d430401.d.ts +5 -0
  129. package/picker-button/modern/field/Component.d.ts +1 -1
  130. package/picker-button/modern/{typings-6563e05c.d.ts → typings-9d430401.d.ts} +0 -12
  131. package/picker-button/modern/utils-87b0c1c6.d.ts +1 -1
  132. package/picker-button/{typings-6563e05c.d.ts → typings-9d430401.d.ts} +0 -12
  133. package/picker-button/utils-87b0c1c6.d.ts +1 -1
  134. package/plate/components/base-plate/Component.js +1 -1
  135. package/plate/esm/Component.responsive.js +1 -1
  136. package/plate/esm/components/base-plate/Component.js +1 -1
  137. package/plate/esm/components/base-plate/index.js +1 -1
  138. package/plate/esm/desktop/Component.desktop.js +1 -1
  139. package/plate/esm/desktop/index.js +1 -1
  140. package/plate/esm/index-2f466837.d.ts +2 -2
  141. package/plate/esm/index.js +1 -1
  142. package/plate/esm/mobile/Component.mobile.js +1 -1
  143. package/plate/esm/mobile/index.js +1 -1
  144. package/plate/esm/shared/index.js +1 -1
  145. package/plate/esm/utils.js +1 -1
  146. package/plate/index-2f466837.d.ts +2 -2
  147. package/plate/modern/Component.responsive.js +1 -1
  148. package/plate/modern/components/base-plate/Component.js +1 -1
  149. package/plate/modern/components/base-plate/index.js +1 -1
  150. package/plate/modern/desktop/Component.desktop.js +1 -1
  151. package/plate/modern/desktop/index.js +1 -1
  152. package/plate/modern/index-2f466837.d.ts +2 -2
  153. package/plate/modern/index.js +1 -1
  154. package/plate/modern/mobile/Component.mobile.js +1 -1
  155. package/plate/modern/mobile/index.js +1 -1
  156. package/plate/modern/shared/index.js +1 -1
  157. package/plate/modern/utils.js +1 -1
  158. package/plate/utils.js +1 -1
  159. package/pure-cell/component.js +1 -1
  160. package/pure-cell/components/addon/component.js +1 -1
  161. package/pure-cell/components/addon/index.d.ts +1 -1
  162. package/pure-cell/components/addon/index.js +1 -1
  163. package/pure-cell/components/amount/component.js +1 -1
  164. package/pure-cell/components/amount/index.d.ts +1 -1
  165. package/pure-cell/components/amount/index.js +1 -1
  166. package/pure-cell/components/amount-title/component.js +1 -1
  167. package/pure-cell/components/amount-title/index.d.ts +1 -1
  168. package/pure-cell/components/amount-title/index.js +1 -1
  169. package/pure-cell/components/category/component.js +1 -1
  170. package/pure-cell/components/category/index.d.ts +1 -1
  171. package/pure-cell/components/category/index.js +1 -1
  172. package/pure-cell/components/content/component.js +1 -1
  173. package/pure-cell/components/content/index.d.ts +1 -1
  174. package/pure-cell/components/content/index.js +1 -1
  175. package/pure-cell/components/footer/component.js +1 -1
  176. package/pure-cell/components/footer/index.d.ts +1 -1
  177. package/pure-cell/components/footer/index.js +1 -1
  178. package/pure-cell/components/footer-button/component.js +1 -1
  179. package/pure-cell/components/footer-button/index.d.ts +1 -1
  180. package/pure-cell/components/footer-button/index.js +1 -1
  181. package/pure-cell/components/footer-text/component.js +1 -1
  182. package/pure-cell/components/footer-text/index.d.ts +1 -1
  183. package/pure-cell/components/footer-text/index.js +1 -1
  184. package/pure-cell/components/graphics/component.js +1 -1
  185. package/pure-cell/components/graphics/index.d.ts +1 -1
  186. package/pure-cell/components/graphics/index.js +1 -1
  187. package/pure-cell/components/main/component.js +1 -1
  188. package/pure-cell/components/main/index.d.ts +1 -1
  189. package/pure-cell/components/main/index.js +1 -1
  190. package/pure-cell/components/text/component.js +1 -1
  191. package/pure-cell/components/text/index.d.ts +1 -1
  192. package/pure-cell/components/text/index.js +1 -1
  193. package/pure-cell/esm/component.js +1 -1
  194. package/pure-cell/esm/components/addon/component.js +1 -1
  195. package/pure-cell/esm/components/addon/index.d.ts +1 -1
  196. package/pure-cell/esm/components/addon/index.js +1 -1
  197. package/pure-cell/esm/components/amount/component.js +1 -1
  198. package/pure-cell/esm/components/amount/index.d.ts +1 -1
  199. package/pure-cell/esm/components/amount/index.js +1 -1
  200. package/pure-cell/esm/components/amount-title/component.js +1 -1
  201. package/pure-cell/esm/components/amount-title/index.d.ts +1 -1
  202. package/pure-cell/esm/components/amount-title/index.js +1 -1
  203. package/pure-cell/esm/components/category/component.js +1 -1
  204. package/pure-cell/esm/components/category/index.d.ts +1 -1
  205. package/pure-cell/esm/components/category/index.js +1 -1
  206. package/pure-cell/esm/components/content/component.js +1 -1
  207. package/pure-cell/esm/components/content/index.d.ts +1 -1
  208. package/pure-cell/esm/components/content/index.js +1 -1
  209. package/pure-cell/esm/components/footer/component.js +1 -1
  210. package/pure-cell/esm/components/footer/index.d.ts +1 -1
  211. package/pure-cell/esm/components/footer/index.js +1 -1
  212. package/pure-cell/esm/components/footer-button/component.js +1 -1
  213. package/pure-cell/esm/components/footer-button/index.d.ts +1 -1
  214. package/pure-cell/esm/components/footer-button/index.js +1 -1
  215. package/pure-cell/esm/components/footer-text/component.js +1 -1
  216. package/pure-cell/esm/components/footer-text/index.d.ts +1 -1
  217. package/pure-cell/esm/components/footer-text/index.js +1 -1
  218. package/pure-cell/esm/components/graphics/component.js +1 -1
  219. package/pure-cell/esm/components/graphics/index.d.ts +1 -1
  220. package/pure-cell/esm/components/graphics/index.js +1 -1
  221. package/pure-cell/esm/components/main/component.js +1 -1
  222. package/pure-cell/esm/components/main/index.d.ts +1 -1
  223. package/pure-cell/esm/components/main/index.js +1 -1
  224. package/pure-cell/esm/components/text/component.js +1 -1
  225. package/pure-cell/esm/components/text/index.d.ts +1 -1
  226. package/pure-cell/esm/components/text/index.js +1 -1
  227. package/pure-cell/esm/index.js +1 -1
  228. package/pure-cell/index.js +1 -1
  229. package/pure-cell/modern/component.js +1 -1
  230. package/pure-cell/modern/components/addon/component.js +1 -1
  231. package/pure-cell/modern/components/addon/index.d.ts +1 -1
  232. package/pure-cell/modern/components/addon/index.js +1 -1
  233. package/pure-cell/modern/components/amount/component.js +1 -1
  234. package/pure-cell/modern/components/amount/index.d.ts +1 -1
  235. package/pure-cell/modern/components/amount/index.js +1 -1
  236. package/pure-cell/modern/components/amount-title/component.js +1 -1
  237. package/pure-cell/modern/components/amount-title/index.d.ts +1 -1
  238. package/pure-cell/modern/components/amount-title/index.js +1 -1
  239. package/pure-cell/modern/components/category/component.js +1 -1
  240. package/pure-cell/modern/components/category/index.d.ts +1 -1
  241. package/pure-cell/modern/components/category/index.js +1 -1
  242. package/pure-cell/modern/components/content/component.js +1 -1
  243. package/pure-cell/modern/components/content/index.d.ts +1 -1
  244. package/pure-cell/modern/components/content/index.js +1 -1
  245. package/pure-cell/modern/components/footer/component.js +1 -1
  246. package/pure-cell/modern/components/footer/index.d.ts +1 -1
  247. package/pure-cell/modern/components/footer/index.js +1 -1
  248. package/pure-cell/modern/components/footer-button/component.js +1 -1
  249. package/pure-cell/modern/components/footer-button/index.d.ts +1 -1
  250. package/pure-cell/modern/components/footer-button/index.js +1 -1
  251. package/pure-cell/modern/components/footer-text/component.js +1 -1
  252. package/pure-cell/modern/components/footer-text/index.d.ts +1 -1
  253. package/pure-cell/modern/components/footer-text/index.js +1 -1
  254. package/pure-cell/modern/components/graphics/component.js +1 -1
  255. package/pure-cell/modern/components/graphics/index.d.ts +1 -1
  256. package/pure-cell/modern/components/graphics/index.js +1 -1
  257. package/pure-cell/modern/components/main/component.js +1 -1
  258. package/pure-cell/modern/components/main/index.d.ts +1 -1
  259. package/pure-cell/modern/components/main/index.js +1 -1
  260. package/pure-cell/modern/components/text/component.js +1 -1
  261. package/pure-cell/modern/components/text/index.d.ts +1 -1
  262. package/pure-cell/modern/components/text/index.js +1 -1
  263. package/pure-cell/modern/index.js +1 -1
  264. package/select/components/base-select/Component.js +14 -14
  265. package/select/components/base-select/components/list-desktop/list-popover-desktop.js +1 -1
  266. package/select/components/base-select/components/list-mobile/list-bottom-sheet-mobile.js +1 -1
  267. package/select/components/base-select/components/list-mobile/list-modal-mobile.js +1 -1
  268. package/select/components/options-list/Component.js +4 -4
  269. package/select/cssm/components/base-select/Component.js +12 -12
  270. package/select/cssm/components/options-list/Component.js +4 -4
  271. package/select/cssm/typings.d.ts +0 -12
  272. package/select/esm/Component.responsive.js +3 -3
  273. package/select/esm/components/base-select/Component.js +14 -14
  274. package/select/esm/components/base-select/components/list-desktop/list-popover-desktop.js +1 -1
  275. package/select/esm/components/base-select/components/list-mobile/list-bottom-sheet-mobile.js +1 -1
  276. package/select/esm/components/base-select/components/list-mobile/list-mobile.js +1 -1
  277. package/select/esm/components/base-select/components/list-mobile/list-modal-mobile.js +1 -1
  278. package/select/esm/components/base-select/index.js +2 -2
  279. package/select/esm/components/index.js +2 -2
  280. package/select/esm/components/options-list/Component.js +4 -4
  281. package/select/esm/desktop/Component.desktop.js +2 -2
  282. package/select/esm/desktop/index.js +2 -2
  283. package/select/esm/index.js +3 -3
  284. package/select/esm/mobile/Component.mobile.js +3 -3
  285. package/select/esm/mobile/Component.modal.mobile.js +3 -3
  286. package/select/esm/mobile/index.js +3 -3
  287. package/select/esm/presets/index.js +1 -1
  288. package/select/esm/presets/useSelectWithApply/hook.js +1 -1
  289. package/select/esm/presets/useSelectWithApply/options-list-with-apply/Component.js +1 -1
  290. package/select/esm/presets/useSelectWithApply/options-list-with-apply/index.d.ts +1 -1
  291. package/select/esm/presets/useSelectWithApply/options-list-with-apply/index.js +1 -1
  292. package/select/esm/shared/index.js +3 -3
  293. package/select/esm/typings.d.ts +0 -12
  294. package/select/mobile/Component.mobile.js +1 -1
  295. package/select/modern/Component.responsive.js +3 -3
  296. package/select/modern/components/base-select/Component.js +4 -4
  297. package/select/modern/components/base-select/components/list-desktop/list-popover-desktop.js +1 -1
  298. package/select/modern/components/base-select/components/list-mobile/list-bottom-sheet-mobile.js +1 -1
  299. package/select/modern/components/base-select/components/list-mobile/list-mobile.js +1 -1
  300. package/select/modern/components/base-select/components/list-mobile/list-modal-mobile.js +1 -1
  301. package/select/modern/components/base-select/index.js +2 -2
  302. package/select/modern/components/index.js +2 -2
  303. package/select/modern/components/options-list/Component.js +2 -2
  304. package/select/modern/desktop/Component.desktop.js +2 -2
  305. package/select/modern/desktop/index.js +2 -2
  306. package/select/modern/index.js +3 -3
  307. package/select/modern/mobile/Component.mobile.js +3 -3
  308. package/select/modern/mobile/Component.modal.mobile.js +3 -3
  309. package/select/modern/mobile/index.js +3 -3
  310. package/select/modern/presets/index.js +1 -1
  311. package/select/modern/presets/useSelectWithApply/hook.js +1 -1
  312. package/select/modern/presets/useSelectWithApply/options-list-with-apply/Component.js +1 -1
  313. package/select/modern/presets/useSelectWithApply/options-list-with-apply/index.d.ts +1 -1
  314. package/select/modern/presets/useSelectWithApply/options-list-with-apply/index.js +1 -1
  315. package/select/modern/shared/index.js +3 -3
  316. package/select/modern/typings.d.ts +0 -12
  317. package/select/presets/index.js +1 -1
  318. package/select/presets/useSelectWithApply/hook.js +1 -1
  319. package/select/presets/useSelectWithApply/options-list-with-apply/Component.js +1 -1
  320. package/select/presets/useSelectWithApply/options-list-with-apply/index.d.ts +1 -1
  321. package/select/presets/useSelectWithApply/options-list-with-apply/index.js +1 -1
  322. package/select/shared/index.js +1 -1
  323. package/select/typings.d.ts +0 -12
  324. package/side-panel/components/controls/Component.js +1 -1
  325. package/side-panel/components/footer/Component.js +1 -1
  326. package/side-panel/esm/Component.responsive.js +1 -1
  327. package/side-panel/esm/components/controls/Component.js +1 -1
  328. package/side-panel/esm/components/controls/index.js +1 -1
  329. package/side-panel/esm/components/footer/Component.desktop.js +1 -1
  330. package/side-panel/esm/components/footer/Component.js +1 -1
  331. package/side-panel/esm/components/footer/Component.mobile.js +1 -1
  332. package/side-panel/esm/desktop/Component.desktop.js +1 -1
  333. package/side-panel/esm/desktop/index.js +1 -1
  334. package/side-panel/esm/index.js +1 -1
  335. package/side-panel/esm/mobile/Component.mobile.js +1 -1
  336. package/side-panel/esm/mobile/index.js +1 -1
  337. package/side-panel/modern/Component.responsive.js +1 -1
  338. package/side-panel/modern/components/controls/Component.js +1 -1
  339. package/side-panel/modern/components/controls/index.js +1 -1
  340. package/side-panel/modern/components/footer/Component.desktop.js +1 -1
  341. package/side-panel/modern/components/footer/Component.js +1 -1
  342. package/side-panel/modern/components/footer/Component.mobile.js +1 -1
  343. package/side-panel/modern/desktop/Component.desktop.js +1 -1
  344. package/side-panel/modern/desktop/index.js +1 -1
  345. package/side-panel/modern/index.js +1 -1
  346. package/side-panel/modern/mobile/Component.mobile.js +1 -1
  347. package/side-panel/modern/mobile/index.js +1 -1
  348. package/themes/compiled/mobile-dark-bluetint.css +5 -5
  349. package/toast-plate/components/base-toast-plate/component.js +2 -2
  350. package/toast-plate/components/base-toast-plate/hooks/useDeprecatedBadge.js +1 -1
  351. package/toast-plate/components/base-toast-plate/utils/getBaseToastPlateTestIds.js +2 -2
  352. package/toast-plate/esm/Component.responsive.js +2 -2
  353. package/toast-plate/esm/components/base-toast-plate/component.js +2 -2
  354. package/toast-plate/esm/components/base-toast-plate/hooks/useDeprecatedBadge.js +1 -1
  355. package/toast-plate/esm/components/base-toast-plate/index.js +2 -2
  356. package/toast-plate/esm/components/base-toast-plate/utils/getBaseToastPlateTestIds.js +2 -2
  357. package/toast-plate/esm/desktop/Component.desktop.js +2 -2
  358. package/toast-plate/esm/desktop/index.js +2 -2
  359. package/toast-plate/esm/index-2f466837.d.ts +2 -2
  360. package/toast-plate/esm/index.js +2 -2
  361. package/toast-plate/esm/mobile/Component.mobile.js +2 -2
  362. package/toast-plate/esm/mobile/index.js +2 -2
  363. package/toast-plate/index-2f466837.d.ts +2 -2
  364. package/toast-plate/modern/Component.responsive.js +2 -2
  365. package/toast-plate/modern/components/base-toast-plate/component.js +2 -2
  366. package/toast-plate/modern/components/base-toast-plate/hooks/useDeprecatedBadge.js +1 -1
  367. package/toast-plate/modern/components/base-toast-plate/index.js +2 -2
  368. package/toast-plate/modern/components/base-toast-plate/utils/getBaseToastPlateTestIds.js +2 -2
  369. package/toast-plate/modern/desktop/Component.desktop.js +2 -2
  370. package/toast-plate/modern/desktop/index.js +2 -2
  371. package/toast-plate/modern/index-2f466837.d.ts +2 -2
  372. package/toast-plate/modern/index.js +2 -2
  373. package/toast-plate/modern/mobile/Component.mobile.js +2 -2
  374. package/toast-plate/modern/mobile/index.js +2 -2
  375. package/typography/esm/component.js +2 -2
  376. package/typography/esm/index.js +2 -2
  377. package/typography/esm/text/component.js +1 -1
  378. package/typography/esm/text/index.js +1 -1
  379. package/typography/esm/title/component.js +1 -1
  380. package/typography/esm/title/index.js +2 -2
  381. package/typography/esm/title-mobile/component.js +2 -2
  382. package/typography/esm/title-mobile/index.js +2 -2
  383. package/typography/esm/title-responsive/component.js +2 -2
  384. package/typography/esm/title-responsive/index.js +2 -2
  385. package/typography/modern/component.js +2 -2
  386. package/typography/modern/index.js +2 -2
  387. package/typography/modern/text/component.js +1 -1
  388. package/typography/modern/text/index.js +1 -1
  389. package/typography/modern/title/component.js +1 -1
  390. package/typography/modern/title/index.js +2 -2
  391. package/typography/modern/title-mobile/component.js +2 -2
  392. package/typography/modern/title-mobile/index.js +2 -2
  393. package/typography/modern/title-responsive/component.js +2 -2
  394. package/typography/modern/title-responsive/index.js +2 -2
  395. package/typography/text/component.js +1 -1
  396. package/typography/title/component.js +1 -1
  397. package/typography/title/index.js +1 -1
  398. package/typography/title-mobile/component.js +1 -1
  399. package/typography/title-responsive/component.js +1 -1
  400. package/universal-date-input/Component-ee245301.d.ts +26 -0
  401. package/universal-date-input/cssm/Component-ee245301.d.ts +26 -0
  402. package/universal-date-input/cssm/index-5712fce2.d.ts +16 -202
  403. package/universal-date-input/cssm/index-ee245301.d.ts +180 -0
  404. package/universal-date-input/esm/Component-ee245301.d.ts +26 -0
  405. package/universal-date-input/esm/index-5712fce2.d.ts +16 -202
  406. package/universal-date-input/esm/index-ee245301.d.ts +180 -0
  407. package/universal-date-input/index-5712fce2.d.ts +16 -202
  408. package/universal-date-input/index-ee245301.d.ts +180 -0
  409. package/universal-date-input/modern/Component-ee245301.d.ts +26 -0
  410. package/universal-date-input/modern/index-5712fce2.d.ts +16 -202
  411. package/universal-date-input/modern/index-ee245301.d.ts +180 -0
  412. package/picker-button/Component-6563e05c.d.ts +0 -5
  413. package/picker-button/cssm/Component-6563e05c.d.ts +0 -5
  414. package/picker-button/esm/Component-6563e05c.d.ts +0 -5
  415. package/picker-button/modern/Component-6563e05c.d.ts +0 -5
  416. /package/gallery/{buttons-9c44ac86.d.ts → buttons-e7e85fbd.d.ts} +0 -0
  417. /package/gallery/{buttons-9c44ac86.js → buttons-e7e85fbd.js} +0 -0
  418. /package/gallery/esm/{buttons-9b94693c.d.ts → buttons-31154ee0.d.ts} +0 -0
  419. /package/gallery/esm/{buttons-9b94693c.js → buttons-31154ee0.js} +0 -0
  420. /package/gallery/esm/{slide-5405aac6.d.ts → slide-3a81fe9b.d.ts} +0 -0
  421. /package/gallery/esm/{slide-5405aac6.js → slide-3a81fe9b.js} +0 -0
  422. /package/gallery/modern/{buttons-d0cf70a8.d.ts → buttons-f48cd370.d.ts} +0 -0
  423. /package/gallery/modern/{buttons-d0cf70a8.js → buttons-f48cd370.js} +0 -0
  424. /package/gallery/modern/{slide-6f8df05e.d.ts → slide-300dada8.d.ts} +0 -0
  425. /package/gallery/modern/{slide-6f8df05e.js → slide-300dada8.js} +0 -0
  426. /package/gallery/{slide-70439402.d.ts → slide-fe937849.d.ts} +0 -0
  427. /package/gallery/{slide-70439402.js → slide-fe937849.js} +0 -0
  428. /package/plate/{PortalContext-fa01f35c.d.ts → PortalContext-7660408e.d.ts} +0 -0
  429. /package/plate/{PortalContext-fa01f35c.js → PortalContext-7660408e.js} +0 -0
  430. /package/plate/esm/{PortalContext-68e159b4.d.ts → PortalContext-ecb78253.d.ts} +0 -0
  431. /package/plate/esm/{PortalContext-68e159b4.js → PortalContext-ecb78253.js} +0 -0
  432. /package/plate/modern/{PortalContext-6b50db51.d.ts → PortalContext-1187e777.d.ts} +0 -0
  433. /package/plate/modern/{PortalContext-6b50db51.js → PortalContext-1187e777.js} +0 -0
  434. /package/pure-cell/{component-d9b4960f.d.ts → component-8e5a4272.d.ts} +0 -0
  435. /package/pure-cell/{component-d9b4960f.js → component-8e5a4272.js} +0 -0
  436. /package/pure-cell/esm/{component-fc54c265.d.ts → component-b802ac98.d.ts} +0 -0
  437. /package/pure-cell/esm/{component-fc54c265.js → component-b802ac98.js} +0 -0
  438. /package/pure-cell/modern/{component-9f2ec12c.d.ts → component-5fcbafb6.d.ts} +0 -0
  439. /package/pure-cell/modern/{component-9f2ec12c.js → component-5fcbafb6.js} +0 -0
  440. /package/select/esm/{hook-ea6af842.d.ts → hook-b2de24a8.d.ts} +0 -0
  441. /package/select/esm/{hook-ea6af842.js → hook-b2de24a8.js} +0 -0
  442. /package/select/esm/{list-popover-desktop-ae0d4030.d.ts → list-popover-desktop-05da245e.d.ts} +0 -0
  443. /package/select/esm/{list-popover-desktop-ae0d4030.js → list-popover-desktop-05da245e.js} +0 -0
  444. /package/select/esm/{mobile.module-549309dc.js → mobile.module-463c9a08.js} +0 -0
  445. /package/select/{hook-d36891be.d.ts → hook-8c4a3c4b.d.ts} +0 -0
  446. /package/select/{hook-d36891be.js → hook-8c4a3c4b.js} +0 -0
  447. /package/select/{list-popover-desktop-ee1e436c.d.ts → list-popover-desktop-0191d188.d.ts} +0 -0
  448. /package/select/{list-popover-desktop-ee1e436c.js → list-popover-desktop-0191d188.js} +0 -0
  449. /package/select/{mobile.module-02f8a33d.js → mobile.module-34ed4d36.js} +0 -0
  450. /package/select/modern/{hook-c1d1e364.d.ts → hook-f6ee5904.d.ts} +0 -0
  451. /package/select/modern/{hook-c1d1e364.js → hook-f6ee5904.js} +0 -0
  452. /package/select/modern/{list-popover-desktop-feab4a2f.d.ts → list-popover-desktop-dde86217.d.ts} +0 -0
  453. /package/select/modern/{list-popover-desktop-feab4a2f.js → list-popover-desktop-dde86217.js} +0 -0
  454. /package/select/modern/{mobile.module-9fee11c2.js → mobile.module-4026b4ce.js} +0 -0
  455. /package/side-panel/esm/{layout.module-15c30846.js → layout.module-57debcbd.js} +0 -0
  456. /package/side-panel/{layout.module-f68730e9.js → layout.module-11cb84d7.js} +0 -0
  457. /package/side-panel/modern/{layout.module-546000a4.js → layout.module-436b690f.js} +0 -0
  458. /package/toast-plate/{PortalContext-5870903f.d.ts → PortalContext-0d20ef98.d.ts} +0 -0
  459. /package/toast-plate/{PortalContext-5870903f.js → PortalContext-0d20ef98.js} +0 -0
  460. /package/toast-plate/esm/{PortalContext-87b75f64.d.ts → PortalContext-0baec972.d.ts} +0 -0
  461. /package/toast-plate/esm/{PortalContext-87b75f64.js → PortalContext-0baec972.js} +0 -0
  462. /package/toast-plate/esm/{getDataTestId-036beec3.d.ts → getDataTestId-7b6aa0a9.d.ts} +0 -0
  463. /package/toast-plate/esm/{getDataTestId-036beec3.js → getDataTestId-7b6aa0a9.js} +0 -0
  464. /package/toast-plate/{getDataTestId-68f38cd2.d.ts → getDataTestId-d6ea897e.d.ts} +0 -0
  465. /package/toast-plate/{getDataTestId-68f38cd2.js → getDataTestId-d6ea897e.js} +0 -0
  466. /package/toast-plate/modern/{PortalContext-4dcb459f.d.ts → PortalContext-3c15badc.d.ts} +0 -0
  467. /package/toast-plate/modern/{PortalContext-4dcb459f.js → PortalContext-3c15badc.js} +0 -0
  468. /package/toast-plate/modern/{getDataTestId-778a5839.d.ts → getDataTestId-d44651c2.d.ts} +0 -0
  469. /package/toast-plate/modern/{getDataTestId-778a5839.js → getDataTestId-d44651c2.js} +0 -0
  470. /package/typography/{colors.module-db7937b7.js → colors.module-78983cf7.js} +0 -0
  471. /package/typography/{common.module-400d3b44.js → common.module-e36e45ad.js} +0 -0
  472. /package/typography/esm/{colors.module-6187dd90.js → colors.module-bbf7489b.js} +0 -0
  473. /package/typography/esm/{common.module-e6ab81d6.js → common.module-26e271a2.js} +0 -0
  474. /package/typography/modern/{colors.module-60a8eceb.js → colors.module-a3636f20.js} +0 -0
  475. /package/typography/modern/{common.module-2115a63b.js → common.module-7f7bb8d3.js} +0 -0
@@ -7,12 +7,14 @@ var reactVirtuoso = require('react-virtuoso');
7
7
  var resizeObserver = require('@juggle/resize-observer');
8
8
  var cn = require('classnames');
9
9
  var endOfDay = require('date-fns/endOfDay');
10
+ var isAfter = require('date-fns/isAfter');
10
11
  var isSameMonth = require('date-fns/isSameMonth');
11
12
  var startOfDay = require('date-fns/startOfDay');
12
13
  var startOfMonth = require('date-fns/startOfMonth');
13
14
  var mobile$1 = require('../../../../button/cssm/mobile');
14
15
  var mobile = require('../../../../modal/cssm/mobile');
15
16
  var coreComponentsShared = require('../../../../shared/cssm');
17
+ var coreComponentsTypography = require('../../../../typography/cssm');
16
18
  var desktop_Component_desktop = require('../../desktop/Component.desktop.js');
17
19
  var useCalendar = require('../../useCalendar.js');
18
20
  var useRange = require('../../useRange.js');
@@ -28,6 +30,7 @@ var React__default = /*#__PURE__*/_interopDefaultCompat(React);
28
30
  var mergeRefs__default = /*#__PURE__*/_interopDefaultCompat(mergeRefs);
29
31
  var cn__default = /*#__PURE__*/_interopDefaultCompat(cn);
30
32
  var endOfDay__default = /*#__PURE__*/_interopDefaultCompat(endOfDay);
33
+ var isAfter__default = /*#__PURE__*/_interopDefaultCompat(isAfter);
31
34
  var isSameMonth__default = /*#__PURE__*/_interopDefaultCompat(isSameMonth);
32
35
  var startOfDay__default = /*#__PURE__*/_interopDefaultCompat(startOfDay);
33
36
  var startOfMonth__default = /*#__PURE__*/_interopDefaultCompat(startOfMonth);
@@ -40,7 +43,8 @@ if (typeof window !== 'undefined' && !window.ResizeObserver) {
40
43
  window.ResizeObserver = resizeObserver.ResizeObserver;
41
44
  }
42
45
  var CalendarMonthOnlyView = function (_a) {
43
- var value = _a.value, _b = _a.mode, mode = _b === void 0 ? 'single' : _b, _c = _a.rangeBehavior, rangeBehavior = _c === void 0 ? 'clarification' : _c, monthTimestamp = _a.month, minDateTimestamp = _a.minDate, maxDateTimestamp = _a.maxDate, defaultMonthTimestamp = _a.defaultMonth, offDays = _a.offDays, events = _a.events, holidays = _a.holidays, onChange = _a.onChange, onMonthTitleClick = _a.onMonthTitleClick, selectedFrom = _a.selectedFrom, selectedTo = _a.selectedTo, _d = _a.yearsAmount, yearsAmount = _d === void 0 ? 3 : _d, dayAddons = _a.dayAddons, _e = _a.shape, shape = _e === void 0 ? 'rounded' : _e, scrollableContainer = _a.scrollableContainer;
46
+ var value = _a.value, _b = _a.mode, mode = _b === void 0 ? 'single' : _b, _c = _a.rangeBehavior, rangeBehavior = _c === void 0 ? 'clarification' : _c, monthTimestamp = _a.month, minDateTimestamp = _a.minDate, maxDateTimestamp = _a.maxDate, defaultMonthTimestamp = _a.defaultMonth, offDays = _a.offDays, events = _a.events, holidays = _a.holidays, onChange = _a.onChange, onMonthTitleClick = _a.onMonthTitleClick, selectedFrom = _a.selectedFrom, selectedTo = _a.selectedTo, _d = _a.yearsAmount, yearsAmount = _d === void 0 ? 3 : _d, dayAddons = _a.dayAddons, _e = _a.shape, shape = _e === void 0 ? 'rounded' : _e, scrollableContainer = _a.scrollableContainer, clickableMonth = _a.clickableMonth, resetCurrentClickedMonth = _a.resetCurrentClickedMonth;
47
+ var _f = React.useState(''), activeMonthLabel = _f[0], setActiveMonthLabel = _f[1];
44
48
  var range = useRange.useRange({
45
49
  mode: mode,
46
50
  value: value,
@@ -51,25 +55,20 @@ var CalendarMonthOnlyView = function (_a) {
51
55
  });
52
56
  var month = React.useMemo(function () { return (monthTimestamp ? new Date(monthTimestamp) : undefined); }, [monthTimestamp]);
53
57
  var minDate = React.useMemo(function () { return (minDateTimestamp ? startOfDay__default.default(minDateTimestamp) : undefined); }, [minDateTimestamp]);
54
- var maxDate = React.useMemo(function () { return (maxDateTimestamp ? endOfDay__default.default(maxDateTimestamp) : undefined); }, [maxDateTimestamp]);
58
+ var maxDate = React.useMemo(function () {
59
+ // блокируем последующие дни после текущего
60
+ if (clickableMonth && !maxDateTimestamp) {
61
+ return new Date();
62
+ }
63
+ return maxDateTimestamp ? endOfDay__default.default(maxDateTimestamp) : undefined;
64
+ }, [maxDateTimestamp, clickableMonth]);
55
65
  var selected = React.useMemo(function () { return (range.value ? new Date(range.value) : undefined); }, [range.value]);
56
66
  var startingDate = React.useRef(range.value);
57
67
  var defaultMonth = React.useMemo(function () {
58
68
  return startOfMonth__default.default(selected ||
59
69
  utils.limitDate(defaultMonthTimestamp || Date.now(), minDateTimestamp, maxDateTimestamp));
60
70
  }, [defaultMonthTimestamp, maxDateTimestamp, minDateTimestamp, selected]);
61
- var _f = useCalendar.useCalendar({
62
- month: month,
63
- defaultMonth: defaultMonth,
64
- view: 'months',
65
- minDate: minDate,
66
- maxDate: maxDate,
67
- selected: selected,
68
- offDays: offDays,
69
- events: events,
70
- onChange: range.onChange,
71
- dayAddons: dayAddons,
72
- }), activeMonth = _f.activeMonth, highlighted = _f.highlighted, getDayProps = _f.getDayProps;
71
+ var _g = useCalendar.useCalendar(tslib.__assign({ month: month, defaultMonth: defaultMonth, view: 'months', minDate: minDate, maxDate: maxDate, selected: selected, offDays: offDays, events: events, onChange: range.onChange, dayAddons: dayAddons }, (clickableMonth && { resetCurrentClickedMonth: resetCurrentClickedMonth }))), activeMonth = _g.activeMonth, highlighted = _g.highlighted, getDayProps = _g.getDayProps;
73
72
  var activeMonths = React.useMemo(function () {
74
73
  var eventsMap = utils.dateArrayToHashTable(events || []);
75
74
  var offDaysMap = utils.dateArrayToHashTable(offDays || []);
@@ -103,14 +102,45 @@ var CalendarMonthOnlyView = function (_a) {
103
102
  var date = range.value || range.selectedFrom || activeMonth.getTime() || Date.now();
104
103
  return activeMonths.findIndex(function (m) { return isSameMonth__default.default(date, m.date); });
105
104
  }, [range.value, range.selectedFrom, activeMonth, activeMonths]);
106
- var renderMonth = function (index) { return (React__default.default.createElement("div", { className: styles__default.default.daysTable, id: "month-".concat(index) },
107
- onMonthTitleClick ? (
108
- /* eslint-disable-next-line jsx-a11y/click-events-have-key-events */
109
- React__default.default.createElement("span", { className: styles__default.default.month, onClick: onMonthTitleClick, tabIndex: 0, role: 'button' }, activeMonths[index].title)) : (React__default.default.createElement("span", { className: styles__default.default.month },
110
- " ",
111
- activeMonths[index].title,
112
- " ")),
113
- React__default.default.createElement(components_daysTable_Component.DaysTable, { withTransition: false, weeks: activeMonths[index].weeks, activeMonth: activeMonth, selectedFrom: range.selectedFrom, selectedTo: range.selectedTo, getDayProps: getDayProps, highlighted: highlighted, hasHeader: false, responsive: true, shape: shape }))); };
105
+ var handleClickMonthLabel = function (index) {
106
+ if (activeMonths[index].title !== activeMonthLabel || activeMonthLabel === '') {
107
+ setActiveMonthLabel(activeMonths[index].title);
108
+ }
109
+ else {
110
+ setActiveMonthLabel('');
111
+ if (onChange) {
112
+ onChange();
113
+ }
114
+ }
115
+ };
116
+ var getMonthTitle = function (index, isClickableMonth) {
117
+ if (isClickableMonth) {
118
+ return (React__default.default.createElement(coreComponentsTypography.Typography.Text, { className: styles__default.default.monthTitle, view: 'primary-small', color: 'primary' }, activeMonths[index].title));
119
+ }
120
+ return "\u00A0".concat(activeMonths[index].title, "\u00A0");
121
+ };
122
+ var renderMonth = function (index) {
123
+ var _a;
124
+ var monthClicked = activeMonthLabel === activeMonths[index].title;
125
+ var isAfterDate = isAfter__default.default(activeMonths[index].date, activeMonth);
126
+ return (React__default.default.createElement("div", { className: styles__default.default.daysTable, id: "month-".concat(index) },
127
+ onMonthTitleClick ? (
128
+ /* eslint-disable-next-line jsx-a11y/click-events-have-key-events */
129
+ React__default.default.createElement("span", { className: styles__default.default.month, onClick: onMonthTitleClick, tabIndex: 0, role: 'button' }, activeMonths[index].title)) : (
130
+ // eslint-disable-next-line jsx-a11y/click-events-have-key-events,jsx-a11y/no-static-element-interactions
131
+ React__default.default.createElement("span", tslib.__assign({ className: cn__default.default(styles__default.default.month, tslib.__assign({}, (clickableMonth && (_a = {},
132
+ _a[styles__default.default.clickableMonth] = true,
133
+ _a[styles__default.default.rectangular] = shape === 'rectangular',
134
+ _a[styles__default.default.active] = monthClicked,
135
+ _a[styles__default.default.disabled] = isAfterDate,
136
+ _a)))) }, (clickableMonth && { onClick: function () { return handleClickMonthLabel(index); } })), getMonthTitle(index, clickableMonth))),
137
+ React__default.default.createElement(components_daysTable_Component.DaysTable, { withTransition: false, weeks: activeMonths[index].weeks, activeMonth: activeMonth, selectedFrom: range.selectedFrom, selectedTo: range.selectedTo, getDayProps: getDayProps, highlighted: highlighted, hasHeader: false, responsive: true, shape: shape, monthClicked: monthClicked, onChange: onChange })));
138
+ };
139
+ React.useImperativeHandle(resetCurrentClickedMonth, function () { return ({
140
+ resetCurrentClickedMonth: function () {
141
+ setActiveMonthLabel('');
142
+ },
143
+ }); });
114
144
  return (React__default.default.createElement(reactVirtuoso.Virtuoso, { totalCount: activeMonths.length, itemContent: renderMonth, initialTopMostItemIndex: { index: initialMonthIndex !== null && initialMonthIndex !== void 0 ? initialMonthIndex : 0, align: 'center' }, increaseViewportBy: 500, itemSize: function (el) { return el.getBoundingClientRect().height + 32; }, customScrollParent: scrollableContainer, useWindowScroll: true, className: styles__default.default.virtuoso }));
115
145
  };
116
146
  var CalendarMonthOnlyViewHeader = function () { return (React__default.default.createElement("table", { className: styles__default.default.dayNames },
@@ -118,8 +148,9 @@ var CalendarMonthOnlyViewHeader = function () { return (React__default.default.c
118
148
  React__default.default.createElement("tr", null, utils.WEEKDAYS.map(function (dayName) { return (React__default.default.createElement("th", { className: styles__default.default.dayName, key: dayName }, dayName)); }))))); };
119
149
  var CalendarMobile = React.forwardRef(function (_a, ref) {
120
150
  var _b, _c;
121
- var _d = _a.hasHeader, hasHeader = _d === void 0 ? true : _d, _e = _a.allowSelectionFromEmptyRange, allowSelectionFromEmptyRange = _e === void 0 ? false : _e, className = _a.className, _f = _a.defaultView, defaultView = _f === void 0 ? 'days' : _f, _g = _a.selectorView, selectorView = _g === void 0 ? 'full' : _g, value = _a.value, selectedFrom = _a.selectedFrom, selectedTo = _a.selectedTo, onChange = _a.onChange, onMonthTitleClick = _a.onMonthTitleClick, dataTestId = _a.dataTestId, open = _a.open, onClose = _a.onClose, _h = _a.title, title = _h === void 0 ? 'Календарь' : _h, _j = _a.yearsAmount, yearsAmount = _j === void 0 ? 3 : _j, onApply = _a.onApply, restProps = tslib.__rest(_a, ["hasHeader", "allowSelectionFromEmptyRange", "className", "defaultView", "selectorView", "value", "selectedFrom", "selectedTo", "onChange", "onMonthTitleClick", "dataTestId", "open", "onClose", "title", "yearsAmount", "onApply"]);
151
+ var _d = _a.hasHeader, hasHeader = _d === void 0 ? true : _d, _e = _a.allowSelectionFromEmptyRange, allowSelectionFromEmptyRange = _e === void 0 ? false : _e, className = _a.className, _f = _a.defaultView, defaultView = _f === void 0 ? 'days' : _f, _g = _a.selectorView, selectorView = _g === void 0 ? 'full' : _g, value = _a.value, selectedFrom = _a.selectedFrom, selectedTo = _a.selectedTo, onChange = _a.onChange, onMonthTitleClick = _a.onMonthTitleClick, dataTestId = _a.dataTestId, open = _a.open, onClose = _a.onClose, _h = _a.title, title = _h === void 0 ? 'Календарь' : _h, _j = _a.yearsAmount, yearsAmount = _j === void 0 ? 3 : _j, onApply = _a.onApply, clickableMonth = _a.clickableMonth, restProps = tslib.__rest(_a, ["hasHeader", "allowSelectionFromEmptyRange", "className", "defaultView", "selectorView", "value", "selectedFrom", "selectedTo", "onChange", "onMonthTitleClick", "dataTestId", "open", "onClose", "title", "yearsAmount", "onApply", "clickableMonth"]);
122
152
  var _k = React.useState(), modalRef = _k[0], setModalRef = _k[1];
153
+ var resetCurrentClickedMonth = React.useRef(null);
123
154
  var monthOnlyView = selectorView === 'month-only';
124
155
  var handleClose = function () {
125
156
  if (onClose)
@@ -130,8 +161,10 @@ var CalendarMobile = React.forwardRef(function (_a, ref) {
130
161
  handleClose === null || handleClose === void 0 ? void 0 : handleClose();
131
162
  };
132
163
  var handleClear = function () {
164
+ var _a;
133
165
  if (onChange)
134
166
  onChange();
167
+ (_a = resetCurrentClickedMonth === null || resetCurrentClickedMonth === void 0 ? void 0 : resetCurrentClickedMonth.current) === null || _a === void 0 ? void 0 : _a.resetCurrentClickedMonth();
135
168
  };
136
169
  var renderDayNames = function () { return (monthOnlyView ? React__default.default.createElement(CalendarMonthOnlyViewHeader, null) : null); };
137
170
  var renderContent = function () {
@@ -144,7 +177,7 @@ var CalendarMobile = React.forwardRef(function (_a, ref) {
144
177
  selectedTo: selectedTo,
145
178
  };
146
179
  if (monthOnlyView) {
147
- return (React__default.default.createElement(CalendarMonthOnlyView, tslib.__assign({ yearsAmount: yearsAmount, scrollableContainer: modalRef, onMonthTitleClick: onMonthTitleClick }, commonProps, restProps)));
180
+ return (React__default.default.createElement(CalendarMonthOnlyView, tslib.__assign({ yearsAmount: yearsAmount, scrollableContainer: modalRef, onMonthTitleClick: onMonthTitleClick, clickableMonth: clickableMonth, resetCurrentClickedMonth: resetCurrentClickedMonth }, commonProps, restProps)));
148
181
  }
149
182
  return (React__default.default.createElement(desktop_Component_desktop.CalendarDesktop, tslib.__assign({ responsive: true, className: cn__default.default(className, styles__default.default.calendar), contentClassName: styles__default.default.content, dataTestId: coreComponentsShared.getDataTestId(dataTestId, 'mobile') }, commonProps, restProps)));
150
183
  };
@@ -160,7 +193,11 @@ var CalendarMobile = React.forwardRef(function (_a, ref) {
160
193
  React__default.default.createElement(mobile$1.ButtonMobile, { view: 'secondary', size: 'm', block: true, onClick: handleClear, dataTestId: coreComponentsShared.getDataTestId(dataTestId, 'btn-reset') }, "\u0421\u0431\u0440\u043E\u0441\u0438\u0442\u044C"),
161
194
  React__default.default.createElement(mobile$1.ButtonMobile, { view: 'primary', size: 'm', block: true, onClick: handleApply, disabled: selectButtonDisabled, dataTestId: coreComponentsShared.getDataTestId(dataTestId, 'btn-apply') }, "\u0412\u044B\u0431\u0440\u0430\u0442\u044C")));
162
195
  }
163
- if (value) {
196
+ /**
197
+ * value может быть числом и объектом, для текущего кейса проверяем на typeof number
198
+ * иначе может приводить к багу, когда выводится кнопка "Выбрать" для дефолтного значения календаря
199
+ */
200
+ if (value && typeof value === 'number') {
164
201
  return (React__default.default.createElement(mobile$1.ButtonMobile, { view: 'primary', size: 'm', block: true, onClick: handleApply, dataTestId: coreComponentsShared.getDataTestId(dataTestId, 'btn-apply') }, "\u0412\u044B\u0431\u0440\u0430\u0442\u044C"));
165
202
  }
166
203
  return (React__default.default.createElement(mobile$1.ButtonMobile, { view: 'secondary', size: 'm', block: true, onClick: handleClose, dataTestId: coreComponentsShared.getDataTestId(dataTestId, 'btn-reset') }, "\u041E\u0442\u043C\u0435\u043D\u0430"));
@@ -1,9 +1,13 @@
1
1
  :root { /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
2
2
  } /* deprecated */ :root {
3
+ --color-light-accent-secondary: #212124;
3
4
  --color-light-modal-bg-primary: #fff;
4
5
  --color-light-neutral-300: #e7e8eb;
6
+ --color-light-neutral-translucent-100: rgba(38, 55, 88, 0.06);
5
7
  --color-light-text-primary: rgba(3, 3, 6, 0.88);
6
- --color-light-text-secondary: rgba(4, 4, 19, 0.55); /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
8
+ --color-light-text-primary-inverted: rgba(255, 255, 255, 0.94);
9
+ --color-light-text-secondary: rgba(4, 4, 19, 0.55);
10
+ --color-light-text-tertiary: rgba(5, 8, 29, 0.38); /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
7
11
  } :root { /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
8
12
  } :root { /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
9
13
  } :root {
@@ -13,7 +17,8 @@
13
17
  /* Up */
14
18
 
15
19
  /* Hard up */
16
- } :root { /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
20
+ } :root { /* deprecated */ /* deprecated */ /* deprecated */
21
+ --border-radius-l: 12px; /* deprecated */ /* deprecated */ /* deprecated */ /* deprecated */
17
22
 
18
23
  /* новые значения, используйте их */
19
24
  } :root { /* deprecated */ /* deprecated */
@@ -87,8 +92,25 @@
87
92
  letter-spacing: 1.25px;
88
93
  text-transform: uppercase;
89
94
  color: var(--color-light-text-primary);
90
- margin-bottom: var(--gap-xs);
91
- } .daysTable {
95
+ margin-bottom: var(--gap-xs)
96
+ } .month.clickableMonth {
97
+ padding: 10px var(--gap-m);
98
+ align-self: flex-start;
99
+ border-radius: 999px;
100
+ background-color: var(--color-light-neutral-translucent-100);
101
+ cursor: pointer;
102
+ text-transform: unset
103
+ } .month.clickableMonth.rectangular {
104
+ border-radius: var(--border-radius-l);
105
+ } .month.clickableMonth.active {
106
+ background-color: var(--color-light-accent-secondary)
107
+ } .month.clickableMonth.active .monthTitle {
108
+ color: var(--color-light-text-primary-inverted);
109
+ } .month.clickableMonth.disabled {
110
+ pointer-events: none
111
+ } .month.clickableMonth.disabled .monthTitle {
112
+ color: var(--color-light-text-tertiary);
113
+ } .daysTable {
92
114
  display: flex;
93
115
  flex-direction: column;
94
116
  margin-top: var(--gap-2xl);
@@ -3,6 +3,9 @@ import React from 'react';
3
3
  import { CalendarDesktopProps } from "../../desktop/index";
4
4
  type OmittedCalendarProps = 'headerClassName' | 'contentClassName';
5
5
  type OmittedCalendarContentProps = 'className' | 'defaultView' | 'selectorView' | 'rangeComplete' | 'onMonthChange' | 'onYearClick' | 'onPeriodClick' | 'dataTestId' | 'hasHeader' | 'responsive' | 'showCurrentYearSelector';
6
+ type ResetCurrentClickedMonth = {
7
+ resetCurrentClickedMonth: () => void;
8
+ };
6
9
  type CalendarContentProps = {
7
10
  /**
8
11
  * Обработчик клика на название месяца в мобильном календаре
@@ -42,5 +45,9 @@ type CalendarMobileProps = {
42
45
  * Обработчик клика на кнопку выбрать
43
46
  */
44
47
  onApply?: () => void;
48
+ /**
49
+ * При клике на месяц будут выбраны все доступные дни месяца
50
+ */
51
+ clickableMonth?: boolean;
45
52
  } & CalendarContentProps & Pick<CalendarDesktopProps, OmittedCalendarContentProps>;
46
- export { CalendarContentProps, CalendarMobileProps };
53
+ export { ResetCurrentClickedMonth, CalendarContentProps, CalendarMobileProps };
@@ -54,6 +54,14 @@ type DaysTableProps = {
54
54
  * Рендерит компонент, обернутый в Transition
55
55
  */
56
56
  withTransition?: boolean;
57
+ /**
58
+ * При клике на месяц будут выбраны все доступные дни месяца
59
+ */
60
+ monthClicked?: boolean;
61
+ /**
62
+ * Обработчик выбора даты
63
+ */
64
+ onChange?: (date?: number, dateTo?: number) => void;
57
65
  };
58
66
  declare const DaysTable: FC<DaysTableProps>;
59
67
  export { DaysTableProps, DaysTable };
@@ -4,6 +4,7 @@ var tslib = require('tslib');
4
4
  var React = require('react');
5
5
  var reactTransitionGroup = require('react-transition-group');
6
6
  var cn = require('classnames');
7
+ var dateFns = require('date-fns');
7
8
  var isEqual = require('date-fns/isEqual');
8
9
  var isLastDayOfMonth = require('date-fns/isLastDayOfMonth');
9
10
  var isSameDay = require('date-fns/isSameDay');
@@ -29,9 +30,11 @@ var styles__default = /*#__PURE__*/_interopDefaultCompat(styles);
29
30
 
30
31
  var DaysTable = function (_a) {
31
32
  var _b;
32
- var _c = _a.weeks, weeks = _c === void 0 ? [] : _c, _d = _a.activeMonth, activeMonth = _d === void 0 ? new Date() : _d, highlighted = _a.highlighted, selectedFrom = _a.selectedFrom, selectedTo = _a.selectedTo, _e = _a.rangeComplete, rangeComplete = _e === void 0 ? selectedFrom && selectedTo : _e, getDayProps = _a.getDayProps, _f = _a.hasHeader, hasHeader = _f === void 0 ? true : _f, responsive = _a.responsive, _g = _a.shape, shape = _g === void 0 ? 'rounded' : _g, _h = _a.withTransition, withTransition = _h === void 0 ? true : _h;
33
+ var _c = _a.weeks, weeks = _c === void 0 ? [] : _c, _d = _a.activeMonth, activeMonth = _d === void 0 ? new Date() : _d, highlighted = _a.highlighted, selectedFrom = _a.selectedFrom, selectedTo = _a.selectedTo, _e = _a.rangeComplete, rangeComplete = _e === void 0 ? selectedFrom && selectedTo : _e, getDayProps = _a.getDayProps, _f = _a.hasHeader, hasHeader = _f === void 0 ? true : _f, responsive = _a.responsive, _g = _a.shape, shape = _g === void 0 ? 'rounded' : _g, _h = _a.withTransition, withTransition = _h === void 0 ? true : _h, _j = _a.monthClicked, monthClicked = _j === void 0 ? false : _j, onChange = _a.onChange;
33
34
  var activeMonthRef = React.useRef(activeMonth);
34
35
  var directionRef = React.useRef();
36
+ var currentStartMonth = React.useRef();
37
+ var currentEndPeriod = React.useRef();
35
38
  activeMonthRef.current = activeMonth;
36
39
  var prevActiveMonth = hooks.usePrevious(activeMonth);
37
40
  if (prevActiveMonth && prevActiveMonth !== activeMonth) {
@@ -74,6 +77,15 @@ var DaysTable = function (_a) {
74
77
  if (!day.disabled)
75
78
  onClick(e);
76
79
  };
80
+ if (dayIdx === 0) {
81
+ currentStartMonth.current = startOfMonth__default.default(day.date).getTime();
82
+ }
83
+ if (isToday__default.default(day.date)) {
84
+ currentEndPeriod.current = dateFns.getTime(day.date);
85
+ }
86
+ else if (!currentEndPeriod.current && isLastDayOfMonth__default.default(day.date)) {
87
+ currentEndPeriod.current = dateFns.getTime(day.date);
88
+ }
77
89
  return (
78
90
  // eslint-disable-next-line jsx-a11y/click-events-have-key-events, jsx-a11y/no-noninteractive-element-interactions
79
91
  React__default.default.createElement("td", tslib.__assign({}, dayProps, { key: day.date.getTime(), className: cn__default.default(styles__default.default.dayWrapper, (_a = {},
@@ -86,6 +98,7 @@ var DaysTable = function (_a) {
86
98
  _a[styles__default.default.rangeStart] = rangeStart,
87
99
  _a[styles__default.default.rangeEnd] = rangeEnd,
88
100
  _a[styles__default.default.cursorPointer] = !day.disabled,
101
+ _a[styles__default.default.shapeRectangular] = shape === 'rectangular',
89
102
  _a)), align: 'center', ref: function (node) {
90
103
  /**
91
104
  * После анимации реф-коллбэк вызывается еще раз, и в него передается null и старый activeMonth.
@@ -112,6 +125,12 @@ var DaysTable = function (_a) {
112
125
  };
113
126
  var renderWeek = function (week, weekIdx) { return (React__default.default.createElement("tr", { key: weekIdx }, week.map(renderDay))); };
114
127
  var renderMonth = function () { return React__default.default.createElement("tbody", null, weeks.map(renderWeek)); };
128
+ React.useEffect(function () {
129
+ if (monthClicked && onChange) {
130
+ onChange(currentStartMonth.current, currentEndPeriod.current);
131
+ }
132
+ // eslint-disable-next-line react-hooks/exhaustive-deps
133
+ }, [monthClicked]);
115
134
  return (React__default.default.createElement("table", { className: cn__default.default(styles__default.default.daysTable, directionRef.current && styles__default.default[directionRef.current], (_b = {},
116
135
  _b[styles__default.default.responsive] = responsive,
117
136
  _b)) },
@@ -160,12 +160,20 @@
160
160
  width: calc(50% + 20px);
161
161
  border-top-right-radius: var(--calendar-day-border-radius);
162
162
  border-bottom-right-radius: var(--calendar-day-border-radius);
163
+ } .rangeEnd.shapeRectangular:before {
164
+ width: calc(50% + 22px);
165
+ border-top-right-radius: var(--border-radius-m);
166
+ border-bottom-right-radius: var(--border-radius-m);
163
167
  } .rangeStart:before {
164
168
  left: auto;
165
169
  right: 0;
166
170
  width: calc(50% + 20px);
167
171
  border-top-left-radius: var(--calendar-day-border-radius);
168
172
  border-bottom-left-radius: var(--calendar-day-border-radius);
173
+ } .rangeStart.shapeRectangular:before {
174
+ width: calc(50% + 22px);
175
+ border-top-left-radius: var(--border-radius-m);
176
+ border-bottom-left-radius: var(--border-radius-m);
169
177
  } .rangeComplete:before {
170
178
  background: var(--calendar-range-complete-background);
171
179
  } .transitLeft:after, .transitRight:after {
@@ -1,5 +1,5 @@
1
1
  /// <reference types="react" />
2
- import { KeyboardEvent, MouseEvent, Ref } from 'react';
2
+ import { KeyboardEvent, MouseEvent, Ref, RefObject } from 'react';
3
3
  import { Day, DayAddons, Month, View } from "./typings";
4
4
  type UseCalendarProps = {
5
5
  /**
@@ -50,8 +50,14 @@ type UseCalendarProps = {
50
50
  * Дополнительный контент под числом
51
51
  */
52
52
  dayAddons?: DayAddons[];
53
+ /**
54
+ * Ref для сброса заголовка clickableMonth
55
+ */
56
+ resetCurrentClickedMonth?: RefObject<{
57
+ resetCurrentClickedMonth: () => void;
58
+ }>;
53
59
  };
54
- declare function useCalendar({ defaultMonth, month, minDate, view, maxDate, selected, events, offDays, holidays, dayAddons, onMonthChange, onChange, }: UseCalendarProps): {
60
+ declare function useCalendar({ defaultMonth, month, minDate, view, maxDate, selected, events, offDays, holidays, dayAddons, onMonthChange, onChange, resetCurrentClickedMonth, }: UseCalendarProps): {
55
61
  activeMonth: Date;
56
62
  weeks: Day[][];
57
63
  months: Month[];
@@ -25,7 +25,7 @@ var startOfMonth__default = /*#__PURE__*/_interopDefaultCompat(startOfMonth);
25
25
  var subYears__default = /*#__PURE__*/_interopDefaultCompat(subYears);
26
26
 
27
27
  function useCalendar(_a) {
28
- var defaultMonth = _a.defaultMonth, month = _a.month, minDate = _a.minDate, _b = _a.view, view = _b === void 0 ? 'days' : _b, maxDate = _a.maxDate, selected = _a.selected, events = _a.events, offDays = _a.offDays, holidays = _a.holidays, dayAddons = _a.dayAddons, onMonthChange = _a.onMonthChange, onChange = _a.onChange;
28
+ var defaultMonth = _a.defaultMonth, month = _a.month, minDate = _a.minDate, _b = _a.view, view = _b === void 0 ? 'days' : _b, maxDate = _a.maxDate, selected = _a.selected, events = _a.events, offDays = _a.offDays, holidays = _a.holidays, dayAddons = _a.dayAddons, onMonthChange = _a.onMonthChange, onChange = _a.onChange, resetCurrentClickedMonth = _a.resetCurrentClickedMonth;
29
29
  var _c = React.useState(defaultMonth), monthState = _c[0], setMonthState = _c[1];
30
30
  var _d = React.useState(), highlighted = _d[0], setHighlighted = _d[1];
31
31
  var uncontrolled = month === undefined;
@@ -179,11 +179,14 @@ function useCalendar(_a) {
179
179
  setHighlighted(undefined);
180
180
  }, []);
181
181
  var handleDayClick = function (event) {
182
+ var _a;
182
183
  var date = event.currentTarget.dataset.date;
183
184
  if (date && onChange) {
184
185
  onChange(+date);
185
186
  }
186
187
  handleDayMouseLeave();
188
+ // сбрасываем выбранный месяц если выбираем дату вручную
189
+ (_a = resetCurrentClickedMonth === null || resetCurrentClickedMonth === void 0 ? void 0 : resetCurrentClickedMonth.current) === null || _a === void 0 ? void 0 : _a.resetCurrentClickedMonth();
187
190
  };
188
191
  var daysControls = React.useMemo(function () { return ({
189
192
  ArrowLeft: function () { return focusDay('prev'); },
@@ -20,6 +20,7 @@ declare const CalendarResponsive: React.ForwardRefExoticComponent<CalendarDeskto
20
20
  allowSelectionFromEmptyRange?: boolean | undefined;
21
21
  hasHeader?: boolean | undefined;
22
22
  onApply?: (() => void) | undefined;
23
+ clickableMonth?: boolean | undefined;
23
24
  } & {
24
25
  onMonthTitleClick?: ((event: React.MouseEvent<HTMLSpanElement, MouseEvent>) => void) | undefined;
25
26
  yearsAmount?: number | undefined;
@@ -8,12 +8,14 @@ import 'react-virtuoso';
8
8
  import '@juggle/resize-observer';
9
9
  import 'classnames';
10
10
  import 'date-fns/endOfDay';
11
+ import 'date-fns/isAfter';
11
12
  import 'date-fns/isSameMonth';
12
13
  import 'date-fns/startOfDay';
13
14
  import 'date-fns/startOfMonth';
14
15
  import '../../button/esm/mobile';
15
16
  import '../../modal/esm/mobile';
16
17
  import '../../shared/esm';
18
+ import '../../typography/esm';
17
19
  import './useCalendar.js';
18
20
  import 'date-fns/addMonths';
19
21
  import 'date-fns/addYears';
@@ -29,7 +31,6 @@ import 'date-fns/eachYearOfInterval';
29
31
  import 'date-fns/endOfWeek';
30
32
  import 'date-fns/endOfYear';
31
33
  import 'date-fns/format';
32
- import 'date-fns/isAfter';
33
34
  import 'date-fns/isBefore';
34
35
  import 'date-fns/lastDayOfMonth';
35
36
  import 'date-fns/max';
@@ -45,6 +46,7 @@ import 'date-fns/differenceInDays';
45
46
  import '@alfalab/hooks';
46
47
  import './components/days-table/Component.js';
47
48
  import 'react-transition-group';
49
+ import 'date-fns';
48
50
  import 'date-fns/isEqual';
49
51
  import 'date-fns/isLastDayOfMonth';
50
52
  import 'date-fns/isToday';
@@ -1,7 +1,22 @@
1
1
  /// <reference types="react" />
2
2
  import React from 'react';
3
- import { CalendarContentProps } from "./typings";
4
- declare const CalendarMonthOnlyView: ({ value, mode, rangeBehavior, month: monthTimestamp, minDate: minDateTimestamp, maxDate: maxDateTimestamp, defaultMonth: defaultMonthTimestamp, offDays, events, holidays, onChange, onMonthTitleClick, selectedFrom, selectedTo, yearsAmount, dayAddons, shape, scrollableContainer, }: CalendarContentProps) => React.JSX.Element;
3
+ import { ResetCurrentClickedMonth } from "./typings";
4
+ declare const CalendarMonthOnlyView: ({ value, mode, rangeBehavior, month: monthTimestamp, minDate: minDateTimestamp, maxDate: maxDateTimestamp, defaultMonth: defaultMonthTimestamp, offDays, events, holidays, onChange, onMonthTitleClick, selectedFrom, selectedTo, yearsAmount, dayAddons, shape, scrollableContainer, clickableMonth, resetCurrentClickedMonth, }: {
5
+ onMonthTitleClick?: ((event: React.MouseEvent<HTMLSpanElement, MouseEvent>) => void) | undefined;
6
+ yearsAmount?: number | undefined;
7
+ scrollableContainer?: HTMLElement | undefined;
8
+ } & Omit<import("../../desktop/index").CalendarDesktopProps, ("className" | "dataTestId" | "hasHeader" | "defaultView" | "selectorView" | "rangeComplete" | "onMonthChange" | "onYearClick" | "onPeriodClick" | "responsive" | "showCurrentYearSelector") | ("contentClassName" | "headerClassName")> & {
9
+ /**
10
+ * FIXME нужно сделать для компонента CalendarMonthOnlyView отдельный тип пропсов, т.к. тип CalendarContentProps intersection для типа CalendarMobileProps
11
+ * FIXME это приводит к тому, что в доку сторибука попадают типы пропсов, которые нужны для работы компонента CalendarMonthOnlyView, но не нужны для компонента CalendarMobile
12
+ * TODO Вынести компонент CalendarMonthOnlyView в отдельный файл
13
+ */
14
+ clickableMonth?: boolean | undefined;
15
+ /**
16
+ * Ref для сброса заголовка clickableMonth
17
+ */
18
+ resetCurrentClickedMonth?: React.RefObject<ResetCurrentClickedMonth> | undefined;
19
+ }) => React.JSX.Element;
5
20
  declare const CalendarMonthOnlyViewHeader: () => React.JSX.Element;
6
21
  declare const CalendarMobile: React.ForwardRefExoticComponent<{
7
22
  title?: string | undefined;
@@ -10,6 +25,7 @@ declare const CalendarMobile: React.ForwardRefExoticComponent<{
10
25
  allowSelectionFromEmptyRange?: boolean | undefined;
11
26
  hasHeader?: boolean | undefined;
12
27
  onApply?: (() => void) | undefined;
28
+ clickableMonth?: boolean | undefined;
13
29
  } & {
14
30
  onMonthTitleClick?: ((event: React.MouseEvent<HTMLSpanElement, MouseEvent>) => void) | undefined;
15
31
  yearsAmount?: number | undefined;