@alfalab/core-components-universal-modal 3.0.7 → 3.1.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 (246) hide show
  1. package/components/content/base-content/index.css +1 -1
  2. package/components/content/base-content/index.module.css.js +1 -1
  3. package/components/content/desktop/desktop.css +2 -2
  4. package/components/content/desktop/desktop.module.css.js +1 -1
  5. package/components/content/mobile/mobile.css +3 -3
  6. package/components/content/mobile/mobile.module.css.js +1 -1
  7. package/components/footer/base-footer/index.css +3 -3
  8. package/components/footer/base-footer/index.module.css.js +1 -1
  9. package/components/footer/desktop/desktop.css +1 -1
  10. package/components/footer/desktop/desktop.module.css.js +1 -1
  11. package/components/footer/desktop/layout.css +9 -9
  12. package/components/footer/desktop/layout.module.css.js +1 -1
  13. package/components/footer/mobile/layout.mobile.css +8 -8
  14. package/components/footer/mobile/layout.mobile.module.css.js +1 -1
  15. package/components/footer/mobile/mobile.css +2 -2
  16. package/components/footer/mobile/mobile.module.css.js +1 -1
  17. package/components/header/base-header/index.css +4 -4
  18. package/components/header/base-header/index.module.css.js +1 -1
  19. package/components/header/desktop/desktop.css +5 -5
  20. package/components/header/desktop/desktop.module.css.js +1 -1
  21. package/components/header/mobile/mobile.css +3 -3
  22. package/components/header/mobile/mobile.module.css.js +1 -1
  23. package/cssm/desktop/components/center-modal/center-modal.js +13 -8
  24. package/cssm/desktop/components/center-modal/center-modal.js.map +1 -1
  25. package/cssm/desktop/components/center-modal/index.module.css +7 -3
  26. package/cssm/desktop/components/modal-content/modal-content.d.ts +3 -3
  27. package/cssm/desktop/components/modal-content/modal-content.js +1 -3
  28. package/cssm/desktop/components/modal-content/modal-content.js.map +1 -1
  29. package/cssm/desktop/components/side-modal/index.module.css +6 -2
  30. package/cssm/desktop/components/side-modal/side-modal.js +14 -9
  31. package/cssm/desktop/components/side-modal/side-modal.js.map +1 -1
  32. package/cssm/desktop/hooks/use-scrollable-container-ref.d.ts +10 -0
  33. package/cssm/desktop/hooks/use-scrollable-container-ref.js +27 -0
  34. package/cssm/desktop/hooks/use-scrollable-container-ref.js.map +1 -0
  35. package/desktop/components/center-modal/center-modal.js +13 -8
  36. package/desktop/components/center-modal/center-modal.js.map +1 -1
  37. package/desktop/components/center-modal/index.css +527 -523
  38. package/desktop/components/center-modal/index.module.css.js +1 -1
  39. package/desktop/components/center-modal/index.module.css.js.map +1 -1
  40. package/desktop/components/center-modal/transitions/safari-transitions.css +7 -7
  41. package/desktop/components/center-modal/transitions/safari-transitions.module.css.js +1 -1
  42. package/desktop/components/center-modal/transitions/transitions.css +7 -7
  43. package/desktop/components/center-modal/transitions/transitions.module.css.js +1 -1
  44. package/desktop/components/modal-content/modal-content.css +4 -4
  45. package/desktop/components/modal-content/modal-content.d.ts +3 -3
  46. package/desktop/components/modal-content/modal-content.js +1 -3
  47. package/desktop/components/modal-content/modal-content.js.map +1 -1
  48. package/desktop/components/modal-content/modal-content.module.css.js +1 -1
  49. package/desktop/components/side-modal/index.css +529 -525
  50. package/desktop/components/side-modal/index.module.css.js +1 -1
  51. package/desktop/components/side-modal/index.module.css.js.map +1 -1
  52. package/desktop/components/side-modal/side-modal.js +14 -9
  53. package/desktop/components/side-modal/side-modal.js.map +1 -1
  54. package/desktop/components/side-modal/transitions/transitions.css +71 -71
  55. package/desktop/components/side-modal/transitions/transitions.module.css.js +1 -1
  56. package/desktop/hooks/use-scrollable-container-ref.d.ts +10 -0
  57. package/desktop/hooks/use-scrollable-container-ref.js +27 -0
  58. package/desktop/hooks/use-scrollable-container-ref.js.map +1 -0
  59. package/desktop/styles/transitions/full-size-backdrop-transitions.css +13 -13
  60. package/desktop/styles/transitions/full-size-backdrop-transitions.module.css.js +1 -1
  61. package/desktop/styles/transitions/full-size-vertical-bottom-transitions.css +7 -7
  62. package/desktop/styles/transitions/full-size-vertical-bottom-transitions.module.css.js +1 -1
  63. package/desktop/styles/transitions/full-size-vertical-center-transitions.css +7 -7
  64. package/desktop/styles/transitions/full-size-vertical-center-transitions.module.css.js +1 -1
  65. package/desktop/styles/transitions/full-size-vertical-top-transitions.css +7 -7
  66. package/desktop/styles/transitions/full-size-vertical-top-transitions.module.css.js +1 -1
  67. package/esm/components/content/base-content/index.css +1 -1
  68. package/esm/components/content/base-content/index.module.css.js +1 -1
  69. package/esm/components/content/desktop/desktop.css +2 -2
  70. package/esm/components/content/desktop/desktop.module.css.js +1 -1
  71. package/esm/components/content/mobile/mobile.css +3 -3
  72. package/esm/components/content/mobile/mobile.module.css.js +1 -1
  73. package/esm/components/footer/base-footer/index.css +3 -3
  74. package/esm/components/footer/base-footer/index.module.css.js +1 -1
  75. package/esm/components/footer/desktop/desktop.css +1 -1
  76. package/esm/components/footer/desktop/desktop.module.css.js +1 -1
  77. package/esm/components/footer/desktop/layout.css +9 -9
  78. package/esm/components/footer/desktop/layout.module.css.js +1 -1
  79. package/esm/components/footer/mobile/layout.mobile.css +8 -8
  80. package/esm/components/footer/mobile/layout.mobile.module.css.js +1 -1
  81. package/esm/components/footer/mobile/mobile.css +2 -2
  82. package/esm/components/footer/mobile/mobile.module.css.js +1 -1
  83. package/esm/components/header/base-header/index.css +4 -4
  84. package/esm/components/header/base-header/index.module.css.js +1 -1
  85. package/esm/components/header/desktop/desktop.css +5 -5
  86. package/esm/components/header/desktop/desktop.module.css.js +1 -1
  87. package/esm/components/header/mobile/mobile.css +3 -3
  88. package/esm/components/header/mobile/mobile.module.css.js +1 -1
  89. package/esm/desktop/components/center-modal/center-modal.js +13 -8
  90. package/esm/desktop/components/center-modal/center-modal.js.map +1 -1
  91. package/esm/desktop/components/center-modal/index.css +527 -523
  92. package/esm/desktop/components/center-modal/index.module.css.js +1 -1
  93. package/esm/desktop/components/center-modal/index.module.css.js.map +1 -1
  94. package/esm/desktop/components/center-modal/transitions/safari-transitions.css +7 -7
  95. package/esm/desktop/components/center-modal/transitions/safari-transitions.module.css.js +1 -1
  96. package/esm/desktop/components/center-modal/transitions/transitions.css +7 -7
  97. package/esm/desktop/components/center-modal/transitions/transitions.module.css.js +1 -1
  98. package/esm/desktop/components/modal-content/modal-content.css +4 -4
  99. package/esm/desktop/components/modal-content/modal-content.d.ts +3 -3
  100. package/esm/desktop/components/modal-content/modal-content.js +1 -3
  101. package/esm/desktop/components/modal-content/modal-content.js.map +1 -1
  102. package/esm/desktop/components/modal-content/modal-content.module.css.js +1 -1
  103. package/esm/desktop/components/side-modal/index.css +529 -525
  104. package/esm/desktop/components/side-modal/index.module.css.js +1 -1
  105. package/esm/desktop/components/side-modal/index.module.css.js.map +1 -1
  106. package/esm/desktop/components/side-modal/side-modal.js +14 -9
  107. package/esm/desktop/components/side-modal/side-modal.js.map +1 -1
  108. package/esm/desktop/components/side-modal/transitions/transitions.css +71 -71
  109. package/esm/desktop/components/side-modal/transitions/transitions.module.css.js +1 -1
  110. package/esm/desktop/hooks/use-scrollable-container-ref.d.ts +10 -0
  111. package/esm/desktop/hooks/use-scrollable-container-ref.js +23 -0
  112. package/esm/desktop/hooks/use-scrollable-container-ref.js.map +1 -0
  113. package/esm/desktop/styles/transitions/full-size-backdrop-transitions.css +13 -13
  114. package/esm/desktop/styles/transitions/full-size-backdrop-transitions.module.css.js +1 -1
  115. package/esm/desktop/styles/transitions/full-size-vertical-bottom-transitions.css +7 -7
  116. package/esm/desktop/styles/transitions/full-size-vertical-bottom-transitions.module.css.js +1 -1
  117. package/esm/desktop/styles/transitions/full-size-vertical-center-transitions.css +7 -7
  118. package/esm/desktop/styles/transitions/full-size-vertical-center-transitions.module.css.js +1 -1
  119. package/esm/desktop/styles/transitions/full-size-vertical-top-transitions.css +7 -7
  120. package/esm/desktop/styles/transitions/full-size-vertical-top-transitions.module.css.js +1 -1
  121. package/esm/mobile/mobile.css +3 -3
  122. package/esm/mobile/mobile.module.css.js +1 -1
  123. package/esm/mobile/transitions/right-side-transitions.mobile.css +7 -7
  124. package/esm/mobile/transitions/right-side-transitions.mobile.module.css.js +1 -1
  125. package/esm/mobile/transitions/transitions.mobile.css +7 -7
  126. package/esm/mobile/transitions/transitions.mobile.module.css.js +1 -1
  127. package/mobile/mobile.css +3 -3
  128. package/mobile/mobile.module.css.js +1 -1
  129. package/mobile/transitions/right-side-transitions.mobile.css +7 -7
  130. package/mobile/transitions/right-side-transitions.mobile.module.css.js +1 -1
  131. package/mobile/transitions/transitions.mobile.css +7 -7
  132. package/mobile/transitions/transitions.mobile.module.css.js +1 -1
  133. package/modern/components/content/base-content/index.css +1 -1
  134. package/modern/components/content/base-content/index.module.css.js +1 -1
  135. package/modern/components/content/desktop/desktop.css +2 -2
  136. package/modern/components/content/desktop/desktop.module.css.js +1 -1
  137. package/modern/components/content/mobile/mobile.css +3 -3
  138. package/modern/components/content/mobile/mobile.module.css.js +1 -1
  139. package/modern/components/footer/base-footer/index.css +3 -3
  140. package/modern/components/footer/base-footer/index.module.css.js +1 -1
  141. package/modern/components/footer/desktop/desktop.css +1 -1
  142. package/modern/components/footer/desktop/desktop.module.css.js +1 -1
  143. package/modern/components/footer/desktop/layout.css +9 -9
  144. package/modern/components/footer/desktop/layout.module.css.js +1 -1
  145. package/modern/components/footer/mobile/layout.mobile.css +8 -8
  146. package/modern/components/footer/mobile/layout.mobile.module.css.js +1 -1
  147. package/modern/components/footer/mobile/mobile.css +2 -2
  148. package/modern/components/footer/mobile/mobile.module.css.js +1 -1
  149. package/modern/components/header/base-header/index.css +4 -4
  150. package/modern/components/header/base-header/index.module.css.js +1 -1
  151. package/modern/components/header/desktop/desktop.css +5 -5
  152. package/modern/components/header/desktop/desktop.module.css.js +1 -1
  153. package/modern/components/header/mobile/mobile.css +3 -3
  154. package/modern/components/header/mobile/mobile.module.css.js +1 -1
  155. package/modern/desktop/components/center-modal/center-modal.js +12 -8
  156. package/modern/desktop/components/center-modal/center-modal.js.map +1 -1
  157. package/modern/desktop/components/center-modal/index.css +527 -523
  158. package/modern/desktop/components/center-modal/index.module.css.js +1 -1
  159. package/modern/desktop/components/center-modal/index.module.css.js.map +1 -1
  160. package/modern/desktop/components/center-modal/transitions/safari-transitions.css +7 -7
  161. package/modern/desktop/components/center-modal/transitions/safari-transitions.module.css.js +1 -1
  162. package/modern/desktop/components/center-modal/transitions/transitions.css +7 -7
  163. package/modern/desktop/components/center-modal/transitions/transitions.module.css.js +1 -1
  164. package/modern/desktop/components/modal-content/modal-content.css +4 -4
  165. package/modern/desktop/components/modal-content/modal-content.d.ts +3 -3
  166. package/modern/desktop/components/modal-content/modal-content.js +1 -3
  167. package/modern/desktop/components/modal-content/modal-content.js.map +1 -1
  168. package/modern/desktop/components/modal-content/modal-content.module.css.js +1 -1
  169. package/modern/desktop/components/side-modal/index.css +529 -525
  170. package/modern/desktop/components/side-modal/index.module.css.js +1 -1
  171. package/modern/desktop/components/side-modal/index.module.css.js.map +1 -1
  172. package/modern/desktop/components/side-modal/side-modal.js +12 -8
  173. package/modern/desktop/components/side-modal/side-modal.js.map +1 -1
  174. package/modern/desktop/components/side-modal/transitions/transitions.css +71 -71
  175. package/modern/desktop/components/side-modal/transitions/transitions.module.css.js +1 -1
  176. package/modern/desktop/hooks/use-scrollable-container-ref.d.ts +10 -0
  177. package/modern/desktop/hooks/use-scrollable-container-ref.js +21 -0
  178. package/modern/desktop/hooks/use-scrollable-container-ref.js.map +1 -0
  179. package/modern/desktop/styles/transitions/full-size-backdrop-transitions.css +13 -13
  180. package/modern/desktop/styles/transitions/full-size-backdrop-transitions.module.css.js +1 -1
  181. package/modern/desktop/styles/transitions/full-size-vertical-bottom-transitions.css +7 -7
  182. package/modern/desktop/styles/transitions/full-size-vertical-bottom-transitions.module.css.js +1 -1
  183. package/modern/desktop/styles/transitions/full-size-vertical-center-transitions.css +7 -7
  184. package/modern/desktop/styles/transitions/full-size-vertical-center-transitions.module.css.js +1 -1
  185. package/modern/desktop/styles/transitions/full-size-vertical-top-transitions.css +7 -7
  186. package/modern/desktop/styles/transitions/full-size-vertical-top-transitions.module.css.js +1 -1
  187. package/modern/mobile/mobile.css +3 -3
  188. package/modern/mobile/mobile.module.css.js +1 -1
  189. package/modern/mobile/transitions/right-side-transitions.mobile.css +7 -7
  190. package/modern/mobile/transitions/right-side-transitions.mobile.module.css.js +1 -1
  191. package/modern/mobile/transitions/transitions.mobile.css +7 -7
  192. package/modern/mobile/transitions/transitions.mobile.module.css.js +1 -1
  193. package/moderncssm/desktop/components/center-modal/center-modal.js +12 -8
  194. package/moderncssm/desktop/components/center-modal/center-modal.js.map +1 -1
  195. package/moderncssm/desktop/components/center-modal/index.module.css +9 -4
  196. package/moderncssm/desktop/components/modal-content/modal-content.d.ts +3 -3
  197. package/moderncssm/desktop/components/modal-content/modal-content.js +1 -3
  198. package/moderncssm/desktop/components/modal-content/modal-content.js.map +1 -1
  199. package/moderncssm/desktop/components/side-modal/index.module.css +7 -2
  200. package/moderncssm/desktop/components/side-modal/side-modal.js +12 -8
  201. package/moderncssm/desktop/components/side-modal/side-modal.js.map +1 -1
  202. package/moderncssm/desktop/hooks/use-scrollable-container-ref.d.ts +10 -0
  203. package/moderncssm/desktop/hooks/use-scrollable-container-ref.js +21 -0
  204. package/moderncssm/desktop/hooks/use-scrollable-container-ref.js.map +1 -0
  205. package/package.json +3 -3
  206. package/src/desktop/components/center-modal/center-modal.module.css +1 -5
  207. package/src/desktop/components/center-modal/center-modal.tsx +14 -14
  208. package/src/desktop/components/center-modal/index.module.css +2 -1
  209. package/src/desktop/components/modal-content/modal-content.tsx +8 -9
  210. package/src/desktop/components/side-modal/index.module.css +2 -1
  211. package/src/desktop/components/side-modal/side-modal.module.css +0 -4
  212. package/src/desktop/components/side-modal/side-modal.tsx +14 -14
  213. package/src/desktop/hooks/use-scrollable-container-ref.ts +29 -0
  214. package/src/desktop/styles/common.module.css +10 -0
  215. package/cssm/desktop/hooks/use-outside-scroll.d.ts +0 -8
  216. package/cssm/desktop/hooks/use-outside-scroll.js +0 -21
  217. package/cssm/desktop/hooks/use-outside-scroll.js.map +0 -1
  218. package/cssm/desktop/hooks/useModalWheel.d.ts +0 -5
  219. package/cssm/desktop/hooks/useModalWheel.js +0 -20
  220. package/cssm/desktop/hooks/useModalWheel.js.map +0 -1
  221. package/desktop/hooks/use-outside-scroll.d.ts +0 -8
  222. package/desktop/hooks/use-outside-scroll.js +0 -21
  223. package/desktop/hooks/use-outside-scroll.js.map +0 -1
  224. package/desktop/hooks/useModalWheel.d.ts +0 -5
  225. package/desktop/hooks/useModalWheel.js +0 -20
  226. package/desktop/hooks/useModalWheel.js.map +0 -1
  227. package/esm/desktop/hooks/use-outside-scroll.d.ts +0 -8
  228. package/esm/desktop/hooks/use-outside-scroll.js +0 -17
  229. package/esm/desktop/hooks/use-outside-scroll.js.map +0 -1
  230. package/esm/desktop/hooks/useModalWheel.d.ts +0 -5
  231. package/esm/desktop/hooks/useModalWheel.js +0 -16
  232. package/esm/desktop/hooks/useModalWheel.js.map +0 -1
  233. package/modern/desktop/hooks/use-outside-scroll.d.ts +0 -8
  234. package/modern/desktop/hooks/use-outside-scroll.js +0 -17
  235. package/modern/desktop/hooks/use-outside-scroll.js.map +0 -1
  236. package/modern/desktop/hooks/useModalWheel.d.ts +0 -5
  237. package/modern/desktop/hooks/useModalWheel.js +0 -16
  238. package/modern/desktop/hooks/useModalWheel.js.map +0 -1
  239. package/moderncssm/desktop/hooks/use-outside-scroll.d.ts +0 -8
  240. package/moderncssm/desktop/hooks/use-outside-scroll.js +0 -17
  241. package/moderncssm/desktop/hooks/use-outside-scroll.js.map +0 -1
  242. package/moderncssm/desktop/hooks/useModalWheel.d.ts +0 -5
  243. package/moderncssm/desktop/hooks/useModalWheel.js +0 -16
  244. package/moderncssm/desktop/hooks/useModalWheel.js.map +0 -1
  245. package/src/desktop/hooks/use-outside-scroll.ts +0 -20
  246. package/src/desktop/hooks/useModalWheel.ts +0 -16
@@ -1,6 +1,6 @@
1
1
  import './full-size-vertical-top-transitions.css';
2
2
 
3
- const fullSizeVerticalTopTransitions = {"appear":"universal-modal__appear_1r3vm","enter":"universal-modal__enter_1r3vm","appearActive":"universal-modal__appearActive_1r3vm","enterActive":"universal-modal__enterActive_1r3vm","exit":"universal-modal__exit_1r3vm","exitActive":"universal-modal__exitActive_1r3vm","exitDone":"universal-modal__exitDone_1r3vm"};
3
+ const fullSizeVerticalTopTransitions = {"appear":"universal-modal__appear_qhje1","enter":"universal-modal__enter_qhje1","appearActive":"universal-modal__appearActive_qhje1","enterActive":"universal-modal__enterActive_qhje1","exit":"universal-modal__exit_qhje1","exitActive":"universal-modal__exitActive_qhje1","exitDone":"universal-modal__exitDone_qhje1"};
4
4
 
5
5
  export { fullSizeVerticalTopTransitions as default };
6
6
  //# sourceMappingURL=full-size-vertical-top-transitions.module.css.js.map
@@ -1,7 +1,7 @@
1
1
  :root {
2
2
  --gap-0: 0px;
3
3
  }
4
- .universal-modal__component_vlc5a {
4
+ .universal-modal__component_1sesv {
5
5
  top: var(--gap-0);
6
6
  height: 100%;
7
7
  width: 100%;
@@ -11,10 +11,10 @@
11
11
  display: flex;
12
12
  flex-direction: column;
13
13
  }
14
- .universal-modal__component_vlc5a .universal-modal__content_vlc5a {
14
+ .universal-modal__component_1sesv .universal-modal__content_1sesv {
15
15
  height: auto;
16
16
  }
17
- .universal-modal__component_vlc5a.universal-modal__component_vlc5a {
17
+ .universal-modal__component_1sesv.universal-modal__component_1sesv {
18
18
  position: fixed;
19
19
  flex: 1;
20
20
  }
@@ -1,6 +1,6 @@
1
1
  import './mobile.css';
2
2
 
3
- const styles = {"component":"universal-modal__component_vlc5a","content":"universal-modal__content_vlc5a"};
3
+ const styles = {"component":"universal-modal__component_1sesv","content":"universal-modal__content_1sesv"};
4
4
 
5
5
  export { styles as default };
6
6
  //# sourceMappingURL=mobile.module.css.js.map
@@ -1,18 +1,18 @@
1
- .universal-modal__appear_1dfvp,
2
- .universal-modal__enter_1dfvp {
1
+ .universal-modal__appear_lb0xx,
2
+ .universal-modal__enter_lb0xx {
3
3
  transform: translateX(100%);
4
4
  }
5
- .universal-modal__appearActive_1dfvp,
6
- .universal-modal__enterActive_1dfvp {
5
+ .universal-modal__appearActive_lb0xx,
6
+ .universal-modal__enterActive_lb0xx {
7
7
  transform: translateX(0);
8
8
  transition: transform 280ms ease-in-out;
9
9
  transition-delay: 80ms;
10
10
  }
11
- .universal-modal__exit_1dfvp {
11
+ .universal-modal__exit_lb0xx {
12
12
  transform: translateX(0);
13
13
  }
14
- .universal-modal__exitActive_1dfvp,
15
- .universal-modal__exitDone_1dfvp {
14
+ .universal-modal__exitActive_lb0xx,
15
+ .universal-modal__exitDone_lb0xx {
16
16
  transform: translateX(100%);
17
17
  transition: transform 280ms ease-in-out;
18
18
  }
@@ -1,6 +1,6 @@
1
1
  import './right-side-transitions.mobile.css';
2
2
 
3
- const rightSideTransitions = {"appear":"universal-modal__appear_1dfvp","enter":"universal-modal__enter_1dfvp","appearActive":"universal-modal__appearActive_1dfvp","enterActive":"universal-modal__enterActive_1dfvp","exit":"universal-modal__exit_1dfvp","exitActive":"universal-modal__exitActive_1dfvp","exitDone":"universal-modal__exitDone_1dfvp"};
3
+ const rightSideTransitions = {"appear":"universal-modal__appear_lb0xx","enter":"universal-modal__enter_lb0xx","appearActive":"universal-modal__appearActive_lb0xx","enterActive":"universal-modal__enterActive_lb0xx","exit":"universal-modal__exit_lb0xx","exitActive":"universal-modal__exitActive_lb0xx","exitDone":"universal-modal__exitDone_lb0xx"};
4
4
 
5
5
  export { rightSideTransitions as default };
6
6
  //# sourceMappingURL=right-side-transitions.mobile.module.css.js.map
@@ -1,11 +1,11 @@
1
- .universal-modal__appear_19v2h,
2
- .universal-modal__enter_19v2h {
1
+ .universal-modal__appear_e8qz6,
2
+ .universal-modal__enter_e8qz6 {
3
3
  opacity: 0;
4
4
  transform: translateY(15px);
5
5
  }
6
6
 
7
- .universal-modal__appearActive_19v2h,
8
- .universal-modal__enterActive_19v2h {
7
+ .universal-modal__appearActive_e8qz6,
8
+ .universal-modal__enterActive_e8qz6 {
9
9
  opacity: 1;
10
10
  transform: translateY(0);
11
11
  transition:
@@ -13,13 +13,13 @@
13
13
  transform 200ms ease-in;
14
14
  }
15
15
 
16
- .universal-modal__exit_19v2h {
16
+ .universal-modal__exit_e8qz6 {
17
17
  opacity: 1;
18
18
  transform: translateY(0);
19
19
  }
20
20
 
21
- .universal-modal__exitActive_19v2h,
22
- .universal-modal__exitDone_19v2h {
21
+ .universal-modal__exitActive_e8qz6,
22
+ .universal-modal__exitDone_e8qz6 {
23
23
  opacity: 0;
24
24
  transform: translateY(15px);
25
25
  transition:
@@ -1,6 +1,6 @@
1
1
  import './transitions.mobile.css';
2
2
 
3
- const transitions = {"appear":"universal-modal__appear_19v2h","enter":"universal-modal__enter_19v2h","appearActive":"universal-modal__appearActive_19v2h","enterActive":"universal-modal__enterActive_19v2h","exit":"universal-modal__exit_19v2h","exitActive":"universal-modal__exitActive_19v2h","exitDone":"universal-modal__exitDone_19v2h"};
3
+ const transitions = {"appear":"universal-modal__appear_e8qz6","enter":"universal-modal__enter_e8qz6","appearActive":"universal-modal__appearActive_e8qz6","enterActive":"universal-modal__enterActive_e8qz6","exit":"universal-modal__exit_e8qz6","exitActive":"universal-modal__exitActive_e8qz6","exitDone":"universal-modal__exitDone_e8qz6"};
4
4
 
5
5
  export { transitions as default };
6
6
  //# sourceMappingURL=transitions.mobile.module.css.js.map
@@ -2,7 +2,7 @@ import React, { forwardRef, useRef } from 'react';
2
2
  import cn from 'classnames';
3
3
  import { BaseModal } from '@alfalab/core-components-base-modal/moderncssm';
4
4
  import { isMacOS, isSafari } from '@alfalab/core-components-shared/moderncssm';
5
- import { useModalWheel } from '../../hooks/useModalWheel.js';
5
+ import { useScrollableContainerRef } from '../../hooks/use-scrollable-container-ref.js';
6
6
  import { getFullSizeModalTransitions } from '../../utils/get-full-size-modal-transitions.js';
7
7
  import { getHeightStyle } from '../../utils/get-height-style.js';
8
8
  import { getMarginStyles } from '../../utils/get-margin-styles.js';
@@ -15,23 +15,27 @@ import transitions from './transitions/transitions.module.css';
15
15
  // в safari некорректно отрабатывает transform:scale (???), поэтому применяем немного другую анимацию
16
16
  const transitionProps = isMacOS() && isSafari() ? safariTransitions : transitions;
17
17
  const CenterModal = forwardRef((props, ref) => {
18
- const { dataTestId, className, open, children, width = 500, height = 'hugContent', verticalAlign = 'center', overlay = true, margin, scrollableContainerRef, onClose, ...restProps } = props;
18
+ const { dataTestId, className, open, children, width = 500, height = 'hugContent', verticalAlign = 'center', overlay = true, margin, scrollableContainerRef: scrollableContainerRefProp, onClose, ...restProps } = props;
19
19
  const componentRef = useRef(null);
20
- const { wheelDeltaY, handleWheel } = useModalWheel(overlay);
20
+ const { handleWheel, scrollableContainerRef } = useScrollableContainerRef({
21
+ overlay,
22
+ refObject: scrollableContainerRefProp,
23
+ });
21
24
  const { isFullSizeModal, componentTransitions: fullSizeModalContentTransitions, backdropTransitions: fullSizeModalBackdropTransitions, } = getFullSizeModalTransitions({ verticalAlign, width, height });
22
- return (React.createElement(BaseModal, { ...restProps, open: open, dataTestId: dataTestId, ref: ref, componentRef: componentRef, scrollHandler: 'content', disableBlockingScroll: !overlay, wrapperClassName: cn({
25
+ const withoutOverlay = !overlay;
26
+ return (React.createElement(BaseModal, { ...restProps, open: open, dataTestId: dataTestId, ref: ref, componentRef: componentRef, scrollHandler: 'content', disableBlockingScroll: withoutOverlay, wrapperClassName: cn(styles.baseModalContainer, {
23
27
  [styles.wrapperJustifyStart]: verticalAlign === 'top',
24
28
  [styles.wrapperJustifyCenter]: verticalAlign === 'center',
25
29
  [styles.wrapperJustifyEnd]: verticalAlign === 'bottom',
26
- }), className: cn(styles.component, className, {
27
- [styles.overlayHidden]: !overlay,
30
+ [styles.withoutOverlay]: withoutOverlay,
31
+ }), className: cn(styles.component, className, styles.baseModalComponent, {
28
32
  ...getMarginStyles({ styles, margin }),
29
33
  }), transitionProps: {
30
34
  classNames: transitionProps,
31
35
  ...(isFullSizeModal && fullSizeModalContentTransitions),
32
36
  ...restProps.transitionProps,
33
37
  }, backdropProps: {
34
- transparent: !overlay,
38
+ shouldRender: overlay,
35
39
  ...(isFullSizeModal && fullSizeModalBackdropTransitions),
36
40
  ...restProps.backdropProps,
37
41
  }, componentDivProps: {
@@ -40,7 +44,7 @@ const CenterModal = forwardRef((props, ref) => {
40
44
  ...getHeightStyle(height, margin),
41
45
  },
42
46
  }, onWheel: handleWheel, onClose: onClose },
43
- React.createElement(ModalContent, { height: height, wheelDeltaY: wheelDeltaY, scrollableContainerRef: scrollableContainerRef }, children)));
47
+ React.createElement(ModalContent, { height: height, scrollableContainerRef: scrollableContainerRef }, children)));
44
48
  });
45
49
 
46
50
  export { CenterModal };
@@ -1 +1 @@
1
- {"version":3,"file":"center-modal.js","sources":["../../../../src/desktop/components/center-modal/center-modal.tsx"],"sourcesContent":["import React, { forwardRef, useRef } from 'react';\nimport cn from 'classnames';\n\nimport { BaseModal } from '@alfalab/core-components-base-modal';\nimport { isMacOS, isSafari } from '@alfalab/core-components-shared';\n\nimport { useModalWheel } from '../../hooks/useModalWheel';\nimport { type UniversalModalDesktopProps } from '../../types/props';\nimport { getFullSizeModalTransitions } from '../../utils/get-full-size-modal-transitions';\nimport { getHeightStyle } from '../../utils/get-height-style';\nimport { getMarginStyles } from '../../utils/get-margin-styles';\nimport { getWidthStyle } from '../../utils/get-width-style';\nimport { ModalContent } from '../modal-content/modal-content';\n\nimport styles from './index.module.css';\nimport safariTransitions from './transitions/safari-transitions.module.css';\nimport transitions from './transitions/transitions.module.css';\n\n// в safari некорректно отрабатывает transform:scale (???), поэтому применяем немного другую анимацию\nconst transitionProps = isMacOS() && isSafari() ? safariTransitions : transitions;\n\nexport const CenterModal = forwardRef<HTMLDivElement, UniversalModalDesktopProps>((props, ref) => {\n const {\n dataTestId,\n className,\n open,\n children,\n width = 500,\n height = 'hugContent',\n verticalAlign = 'center',\n overlay = true,\n margin,\n scrollableContainerRef,\n onClose,\n ...restProps\n } = props;\n\n const componentRef = useRef<HTMLDivElement>(null);\n\n const { wheelDeltaY, handleWheel } = useModalWheel(overlay);\n\n const {\n isFullSizeModal,\n componentTransitions: fullSizeModalContentTransitions,\n backdropTransitions: fullSizeModalBackdropTransitions,\n } = getFullSizeModalTransitions({ verticalAlign, width, height });\n\n return (\n <BaseModal\n {...restProps}\n open={open}\n dataTestId={dataTestId}\n ref={ref}\n componentRef={componentRef}\n scrollHandler='content'\n disableBlockingScroll={!overlay}\n wrapperClassName={cn({\n [styles.wrapperJustifyStart]: verticalAlign === 'top',\n [styles.wrapperJustifyCenter]: verticalAlign === 'center',\n [styles.wrapperJustifyEnd]: verticalAlign === 'bottom',\n })}\n className={cn(styles.component, className, {\n [styles.overlayHidden]: !overlay,\n ...getMarginStyles({ styles, margin }),\n })}\n transitionProps={{\n classNames: transitionProps,\n ...(isFullSizeModal && fullSizeModalContentTransitions),\n ...restProps.transitionProps,\n }}\n backdropProps={{\n transparent: !overlay,\n ...(isFullSizeModal && fullSizeModalBackdropTransitions),\n ...restProps.backdropProps,\n }}\n componentDivProps={{\n style: {\n width: getWidthStyle(width, margin),\n ...getHeightStyle(height, margin),\n },\n }}\n onWheel={handleWheel}\n onClose={onClose}\n >\n <ModalContent\n height={height}\n wheelDeltaY={wheelDeltaY}\n scrollableContainerRef={scrollableContainerRef}\n >\n {children}\n </ModalContent>\n </BaseModal>\n );\n});\n"],"names":[],"mappings":";;;;;;;;;;;;;;AAkBA;AACA,MAAM,eAAe,GAAG,OAAO,EAAE,IAAI,QAAQ,EAAE,GAAG,iBAAiB,GAAG,WAAW;AAEpE,MAAA,WAAW,GAAG,UAAU,CAA6C,CAAC,KAAK,EAAE,GAAG,KAAI;AAC7F,IAAA,MAAM,EACF,UAAU,EACV,SAAS,EACT,IAAI,EACJ,QAAQ,EACR,KAAK,GAAG,GAAG,EACX,MAAM,GAAG,YAAY,EACrB,aAAa,GAAG,QAAQ,EACxB,OAAO,GAAG,IAAI,EACd,MAAM,EACN,sBAAsB,EACtB,OAAO,EACP,GAAG,SAAS,EACf,GAAG,KAAK;AAET,IAAA,MAAM,YAAY,GAAG,MAAM,CAAiB,IAAI,CAAC;IAEjD,MAAM,EAAE,WAAW,EAAE,WAAW,EAAE,GAAG,aAAa,CAAC,OAAO,CAAC;IAE3D,MAAM,EACF,eAAe,EACf,oBAAoB,EAAE,+BAA+B,EACrD,mBAAmB,EAAE,gCAAgC,GACxD,GAAG,2BAA2B,CAAC,EAAE,aAAa,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC;AAEjE,IAAA,QACI,KAAA,CAAA,aAAA,CAAC,SAAS,EAAA,EAAA,GACF,SAAS,EACb,IAAI,EAAE,IAAI,EACV,UAAU,EAAE,UAAU,EACtB,GAAG,EAAE,GAAG,EACR,YAAY,EAAE,YAAY,EAC1B,aAAa,EAAC,SAAS,EACvB,qBAAqB,EAAE,CAAC,OAAO,EAC/B,gBAAgB,EAAE,EAAE,CAAC;AACjB,YAAA,CAAC,MAAM,CAAC,mBAAmB,GAAG,aAAa,KAAK,KAAK;AACrD,YAAA,CAAC,MAAM,CAAC,oBAAoB,GAAG,aAAa,KAAK,QAAQ;AACzD,YAAA,CAAC,MAAM,CAAC,iBAAiB,GAAG,aAAa,KAAK,QAAQ;SACzD,CAAC,EACF,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,SAAS,EAAE,SAAS,EAAE;AACvC,YAAA,CAAC,MAAM,CAAC,aAAa,GAAG,CAAC,OAAO;AAChC,YAAA,GAAG,eAAe,CAAC,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC;SACzC,CAAC,EACF,eAAe,EAAE;AACb,YAAA,UAAU,EAAE,eAAe;AAC3B,YAAA,IAAI,eAAe,IAAI,+BAA+B,CAAC;YACvD,GAAG,SAAS,CAAC,eAAe;AAC/B,SAAA,EACD,aAAa,EAAE;YACX,WAAW,EAAE,CAAC,OAAO;AACrB,YAAA,IAAI,eAAe,IAAI,gCAAgC,CAAC;YACxD,GAAG,SAAS,CAAC,aAAa;AAC7B,SAAA,EACD,iBAAiB,EAAE;AACf,YAAA,KAAK,EAAE;AACH,gBAAA,KAAK,EAAE,aAAa,CAAC,KAAK,EAAE,MAAM,CAAC;AACnC,gBAAA,GAAG,cAAc,CAAC,MAAM,EAAE,MAAM,CAAC;AACpC,aAAA;AACJ,SAAA,EACD,OAAO,EAAE,WAAW,EACpB,OAAO,EAAE,OAAO,EAAA;AAEhB,QAAA,KAAA,CAAA,aAAA,CAAC,YAAY,EACT,EAAA,MAAM,EAAE,MAAM,EACd,WAAW,EAAE,WAAW,EACxB,sBAAsB,EAAE,sBAAsB,EAAA,EAE7C,QAAQ,CACE,CACP;AAEpB,CAAC;;;;"}
1
+ {"version":3,"file":"center-modal.js","sources":["../../../../src/desktop/components/center-modal/center-modal.tsx"],"sourcesContent":["import React, { forwardRef, useRef } from 'react';\nimport cn from 'classnames';\n\nimport { BaseModal } from '@alfalab/core-components-base-modal';\nimport { isMacOS, isSafari } from '@alfalab/core-components-shared';\n\nimport { useScrollableContainerRef } from '../../hooks/use-scrollable-container-ref';\nimport { type UniversalModalDesktopProps } from '../../types/props';\nimport { getFullSizeModalTransitions } from '../../utils/get-full-size-modal-transitions';\nimport { getHeightStyle } from '../../utils/get-height-style';\nimport { getMarginStyles } from '../../utils/get-margin-styles';\nimport { getWidthStyle } from '../../utils/get-width-style';\nimport { ModalContent } from '../modal-content/modal-content';\n\nimport styles from './index.module.css';\nimport safariTransitions from './transitions/safari-transitions.module.css';\nimport transitions from './transitions/transitions.module.css';\n\n// в safari некорректно отрабатывает transform:scale (???), поэтому применяем немного другую анимацию\nconst transitionProps = isMacOS() && isSafari() ? safariTransitions : transitions;\n\nexport const CenterModal = forwardRef<HTMLDivElement, UniversalModalDesktopProps>((props, ref) => {\n const {\n dataTestId,\n className,\n open,\n children,\n width = 500,\n height = 'hugContent',\n verticalAlign = 'center',\n overlay = true,\n margin,\n scrollableContainerRef: scrollableContainerRefProp,\n onClose,\n ...restProps\n } = props;\n\n const componentRef = useRef<HTMLDivElement>(null);\n const { handleWheel, scrollableContainerRef } = useScrollableContainerRef({\n overlay,\n refObject: scrollableContainerRefProp,\n });\n\n const {\n isFullSizeModal,\n componentTransitions: fullSizeModalContentTransitions,\n backdropTransitions: fullSizeModalBackdropTransitions,\n } = getFullSizeModalTransitions({ verticalAlign, width, height });\n\n const withoutOverlay = !overlay;\n\n return (\n <BaseModal\n {...restProps}\n open={open}\n dataTestId={dataTestId}\n ref={ref}\n componentRef={componentRef}\n scrollHandler='content'\n disableBlockingScroll={withoutOverlay}\n wrapperClassName={cn(styles.baseModalContainer, {\n [styles.wrapperJustifyStart]: verticalAlign === 'top',\n [styles.wrapperJustifyCenter]: verticalAlign === 'center',\n [styles.wrapperJustifyEnd]: verticalAlign === 'bottom',\n [styles.withoutOverlay]: withoutOverlay,\n })}\n className={cn(styles.component, className, styles.baseModalComponent, {\n ...getMarginStyles({ styles, margin }),\n })}\n transitionProps={{\n classNames: transitionProps,\n ...(isFullSizeModal && fullSizeModalContentTransitions),\n ...restProps.transitionProps,\n }}\n backdropProps={{\n shouldRender: overlay,\n ...(isFullSizeModal && fullSizeModalBackdropTransitions),\n ...restProps.backdropProps,\n }}\n componentDivProps={{\n style: {\n width: getWidthStyle(width, margin),\n ...getHeightStyle(height, margin),\n },\n }}\n onWheel={handleWheel}\n onClose={onClose}\n >\n <ModalContent height={height} scrollableContainerRef={scrollableContainerRef}>\n {children}\n </ModalContent>\n </BaseModal>\n );\n});\n"],"names":[],"mappings":";;;;;;;;;;;;;;AAkBA;AACA,MAAM,eAAe,GAAG,OAAO,EAAE,IAAI,QAAQ,EAAE,GAAG,iBAAiB,GAAG,WAAW;AAEpE,MAAA,WAAW,GAAG,UAAU,CAA6C,CAAC,KAAK,EAAE,GAAG,KAAI;AAC7F,IAAA,MAAM,EACF,UAAU,EACV,SAAS,EACT,IAAI,EACJ,QAAQ,EACR,KAAK,GAAG,GAAG,EACX,MAAM,GAAG,YAAY,EACrB,aAAa,GAAG,QAAQ,EACxB,OAAO,GAAG,IAAI,EACd,MAAM,EACN,sBAAsB,EAAE,0BAA0B,EAClD,OAAO,EACP,GAAG,SAAS,EACf,GAAG,KAAK;AAET,IAAA,MAAM,YAAY,GAAG,MAAM,CAAiB,IAAI,CAAC;AACjD,IAAA,MAAM,EAAE,WAAW,EAAE,sBAAsB,EAAE,GAAG,yBAAyB,CAAC;QACtE,OAAO;AACP,QAAA,SAAS,EAAE,0BAA0B;AACxC,KAAA,CAAC;IAEF,MAAM,EACF,eAAe,EACf,oBAAoB,EAAE,+BAA+B,EACrD,mBAAmB,EAAE,gCAAgC,GACxD,GAAG,2BAA2B,CAAC,EAAE,aAAa,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC;AAEjE,IAAA,MAAM,cAAc,GAAG,CAAC,OAAO;AAE/B,IAAA,QACI,KAAC,CAAA,aAAA,CAAA,SAAS,EACF,EAAA,GAAA,SAAS,EACb,IAAI,EAAE,IAAI,EACV,UAAU,EAAE,UAAU,EACtB,GAAG,EAAE,GAAG,EACR,YAAY,EAAE,YAAY,EAC1B,aAAa,EAAC,SAAS,EACvB,qBAAqB,EAAE,cAAc,EACrC,gBAAgB,EAAE,EAAE,CAAC,MAAM,CAAC,kBAAkB,EAAE;AAC5C,YAAA,CAAC,MAAM,CAAC,mBAAmB,GAAG,aAAa,KAAK,KAAK;AACrD,YAAA,CAAC,MAAM,CAAC,oBAAoB,GAAG,aAAa,KAAK,QAAQ;AACzD,YAAA,CAAC,MAAM,CAAC,iBAAiB,GAAG,aAAa,KAAK,QAAQ;AACtD,YAAA,CAAC,MAAM,CAAC,cAAc,GAAG,cAAc;AAC1C,SAAA,CAAC,EACF,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,SAAS,EAAE,SAAS,EAAE,MAAM,CAAC,kBAAkB,EAAE;AAClE,YAAA,GAAG,eAAe,CAAC,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC;SACzC,CAAC,EACF,eAAe,EAAE;AACb,YAAA,UAAU,EAAE,eAAe;AAC3B,YAAA,IAAI,eAAe,IAAI,+BAA+B,CAAC;YACvD,GAAG,SAAS,CAAC,eAAe;AAC/B,SAAA,EACD,aAAa,EAAE;AACX,YAAA,YAAY,EAAE,OAAO;AACrB,YAAA,IAAI,eAAe,IAAI,gCAAgC,CAAC;YACxD,GAAG,SAAS,CAAC,aAAa;AAC7B,SAAA,EACD,iBAAiB,EAAE;AACf,YAAA,KAAK,EAAE;AACH,gBAAA,KAAK,EAAE,aAAa,CAAC,KAAK,EAAE,MAAM,CAAC;AACnC,gBAAA,GAAG,cAAc,CAAC,MAAM,EAAE,MAAM,CAAC;AACpC,aAAA;AACJ,SAAA,EACD,OAAO,EAAE,WAAW,EACpB,OAAO,EAAE,OAAO,EAAA;AAEhB,QAAA,KAAA,CAAA,aAAA,CAAC,YAAY,EAAA,EAAC,MAAM,EAAE,MAAM,EAAE,sBAAsB,EAAE,sBAAsB,EACvE,EAAA,QAAQ,CACE,CACP;AAEpB,CAAC;;;;"}
@@ -10,10 +10,6 @@
10
10
  backface-visibility: hidden;
11
11
  }
12
12
 
13
- .component.overlayHidden {
14
- box-shadow: var(--shadow-m);
15
- }
16
-
17
13
  .wrapperJustifyStart {
18
14
  justify-content: flex-start;
19
15
  }
@@ -26,6 +22,15 @@
26
22
  justify-content: flex-end;
27
23
  }
28
24
 
25
+ .baseModalContainer.withoutOverlay {
26
+ pointer-events: none;
27
+ }
28
+
29
+ .baseModalContainer.withoutOverlay .baseModalComponent {
30
+ pointer-events: auto;
31
+ box-shadow: var(--shadow-m);
32
+ }
33
+
29
34
  .marginTop-0 {
30
35
  margin-top: 0px;
31
36
  }
@@ -1,8 +1,8 @@
1
1
  import { type FC } from 'react';
2
2
  import { type BaseModalProps } from '@alfalab/core-components-base-modal/moderncssm';
3
3
  import { type UniversalModalDesktopProps } from '../../types/props';
4
- interface Props extends Pick<BaseModalProps, 'children'>, Pick<UniversalModalDesktopProps, 'height' | 'scrollableContainerRef'> {
5
- wheelDeltaY: number;
6
- }
4
+ type PickedBaseModalProps = Pick<BaseModalProps, 'children'>;
5
+ type PickedUniversalModalDesktopProps = Pick<UniversalModalDesktopProps, 'height' | 'scrollableContainerRef'>;
6
+ type Props = PickedBaseModalProps & PickedUniversalModalDesktopProps;
7
7
  export declare const ModalContent: FC<Props>;
8
8
  export {};
@@ -3,13 +3,12 @@ import mergeRefs from 'react-merge-refs';
3
3
  import cn from 'classnames';
4
4
  import { Scrollbar } from '@alfalab/core-components-scrollbar/moderncssm';
5
5
  import { useModalHighlighted } from '../../hooks/use-modal-highlighted.js';
6
- import { useOutsideScroll } from '../../hooks/use-outside-scroll.js';
7
6
  import { useSetScrollbarHeight } from '../../hooks/use-set-scrollbar-height.js';
8
7
  import { setFooterAndHeaderRefs } from '../../utils/set-footer-and-header-refs.js';
9
8
  import styles from './modal-content.module.css';
10
9
 
11
10
  const ModalContent = (props) => {
12
- const { children, wheelDeltaY, height, scrollableContainerRef = null } = props;
11
+ const { children, height, scrollableContainerRef = null } = props;
13
12
  const scrollableNodeRef = useRef(null);
14
13
  const scrollbarContentNodeRef = useRef(null);
15
14
  const scrollbarRef = useRef(null);
@@ -17,7 +16,6 @@ const ModalContent = (props) => {
17
16
  const headerElementRef = useRef(null);
18
17
  const footerElementRef = useRef(null);
19
18
  const { handleScroll } = useModalHighlighted({ scrollbarContentNodeRef, scrollableNodeRef });
20
- useOutsideScroll({ scrollableNodeRef, wheelDeltaY });
21
19
  const { enhancedChildren } = setFooterAndHeaderRefs({
22
20
  children,
23
21
  headerElementRef,
@@ -1 +1 @@
1
- {"version":3,"file":"modal-content.js","sources":["../../../../src/desktop/components/modal-content/modal-content.tsx"],"sourcesContent":["import React, { type FC, useRef } from 'react';\nimport mergeRefs from 'react-merge-refs';\nimport cn from 'classnames';\n\nimport { type BaseModalProps } from '@alfalab/core-components-base-modal';\nimport { Scrollbar } from '@alfalab/core-components-scrollbar';\n\nimport { useModalHighlighted } from '../../hooks/use-modal-highlighted';\nimport { useOutsideScroll } from '../../hooks/use-outside-scroll';\nimport { useSetScrollbarHeight } from '../../hooks/use-set-scrollbar-height';\nimport { type UniversalModalDesktopProps } from '../../types/props';\nimport { setFooterAndHeaderRefs } from '../../utils/set-footer-and-header-refs';\n\nimport styles from './modal-content.module.css';\n\ninterface Props\n extends Pick<BaseModalProps, 'children'>,\n Pick<UniversalModalDesktopProps, 'height' | 'scrollableContainerRef'> {\n wheelDeltaY: number;\n}\n\nexport const ModalContent: FC<Props> = (props) => {\n const { children, wheelDeltaY, height, scrollableContainerRef = null } = props;\n\n const scrollableNodeRef = useRef<HTMLDivElement>(null);\n const scrollbarContentNodeRef = useRef<HTMLDivElement>(null);\n const scrollbarRef = useRef<HTMLDivElement | null>(null);\n const verticalBarRef = useRef<HTMLDivElement>(null);\n const headerElementRef = useRef<HTMLDivElement>(null);\n const footerElementRef = useRef<HTMLDivElement | null>(null);\n\n const { handleScroll } = useModalHighlighted({ scrollbarContentNodeRef, scrollableNodeRef });\n\n useOutsideScroll({ scrollableNodeRef, wheelDeltaY });\n\n const { enhancedChildren } = setFooterAndHeaderRefs({\n children,\n headerElementRef,\n footerElementRef,\n });\n\n useSetScrollbarHeight({ scrollbarRef, verticalBarRef, headerElementRef, footerElementRef });\n\n return (\n <Scrollbar\n className={styles.scrollable}\n ref={scrollbarRef}\n verticalBarRef={verticalBarRef}\n scrollableNodeProps={{\n ref: mergeRefs([scrollableNodeRef, scrollableContainerRef]),\n className: styles.scrollableNode,\n }}\n contentNodeProps={{\n ref: scrollbarContentNodeRef,\n className: cn(styles.contentNode, {\n [styles.hugContent]: height === 'hugContent',\n }),\n }}\n onContentScroll={handleScroll}\n >\n {enhancedChildren}\n </Scrollbar>\n );\n};\n"],"names":[],"mappings":";;;;;;;;;;AAqBa,MAAA,YAAY,GAAc,CAAC,KAAK,KAAI;AAC7C,IAAA,MAAM,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,EAAE,sBAAsB,GAAG,IAAI,EAAE,GAAG,KAAK;AAE9E,IAAA,MAAM,iBAAiB,GAAG,MAAM,CAAiB,IAAI,CAAC;AACtD,IAAA,MAAM,uBAAuB,GAAG,MAAM,CAAiB,IAAI,CAAC;AAC5D,IAAA,MAAM,YAAY,GAAG,MAAM,CAAwB,IAAI,CAAC;AACxD,IAAA,MAAM,cAAc,GAAG,MAAM,CAAiB,IAAI,CAAC;AACnD,IAAA,MAAM,gBAAgB,GAAG,MAAM,CAAiB,IAAI,CAAC;AACrD,IAAA,MAAM,gBAAgB,GAAG,MAAM,CAAwB,IAAI,CAAC;AAE5D,IAAA,MAAM,EAAE,YAAY,EAAE,GAAG,mBAAmB,CAAC,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,CAAC;AAE5F,IAAA,gBAAgB,CAAC,EAAE,iBAAiB,EAAE,WAAW,EAAE,CAAC;AAEpD,IAAA,MAAM,EAAE,gBAAgB,EAAE,GAAG,sBAAsB,CAAC;QAChD,QAAQ;QACR,gBAAgB;QAChB,gBAAgB;AACnB,KAAA,CAAC;IAEF,qBAAqB,CAAC,EAAE,YAAY,EAAE,cAAc,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,CAAC;AAE3F,IAAA,QACI,KAAC,CAAA,aAAA,CAAA,SAAS,IACN,SAAS,EAAE,MAAM,CAAC,UAAU,EAC5B,GAAG,EAAE,YAAY,EACjB,cAAc,EAAE,cAAc,EAC9B,mBAAmB,EAAE;YACjB,GAAG,EAAE,SAAS,CAAC,CAAC,iBAAiB,EAAE,sBAAsB,CAAC,CAAC;YAC3D,SAAS,EAAE,MAAM,CAAC,cAAc;AACnC,SAAA,EACD,gBAAgB,EAAE;AACd,YAAA,GAAG,EAAE,uBAAuB;AAC5B,YAAA,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,WAAW,EAAE;AAC9B,gBAAA,CAAC,MAAM,CAAC,UAAU,GAAG,MAAM,KAAK,YAAY;aAC/C,CAAC;AACL,SAAA,EACD,eAAe,EAAE,YAAY,IAE5B,gBAAgB,CACT;AAEpB;;;;"}
1
+ {"version":3,"file":"modal-content.js","sources":["../../../../src/desktop/components/modal-content/modal-content.tsx"],"sourcesContent":["import React, { type FC, useRef } from 'react';\nimport mergeRefs from 'react-merge-refs';\nimport cn from 'classnames';\n\nimport { type BaseModalProps } from '@alfalab/core-components-base-modal';\nimport { Scrollbar } from '@alfalab/core-components-scrollbar';\n\nimport { useModalHighlighted } from '../../hooks/use-modal-highlighted';\nimport { useSetScrollbarHeight } from '../../hooks/use-set-scrollbar-height';\nimport { type UniversalModalDesktopProps } from '../../types/props';\nimport { setFooterAndHeaderRefs } from '../../utils/set-footer-and-header-refs';\n\nimport styles from './modal-content.module.css';\n\ntype PickedBaseModalProps = Pick<BaseModalProps, 'children'>;\ntype PickedUniversalModalDesktopProps = Pick<\n UniversalModalDesktopProps,\n 'height' | 'scrollableContainerRef'\n>;\n\ntype Props = PickedBaseModalProps & PickedUniversalModalDesktopProps;\n\nexport const ModalContent: FC<Props> = (props) => {\n const { children, height, scrollableContainerRef = null } = props;\n\n const scrollableNodeRef = useRef<HTMLDivElement>(null);\n const scrollbarContentNodeRef = useRef<HTMLDivElement>(null);\n const scrollbarRef = useRef<HTMLDivElement | null>(null);\n const verticalBarRef = useRef<HTMLDivElement>(null);\n const headerElementRef = useRef<HTMLDivElement>(null);\n const footerElementRef = useRef<HTMLDivElement | null>(null);\n\n const { handleScroll } = useModalHighlighted({ scrollbarContentNodeRef, scrollableNodeRef });\n\n const { enhancedChildren } = setFooterAndHeaderRefs({\n children,\n headerElementRef,\n footerElementRef,\n });\n\n useSetScrollbarHeight({ scrollbarRef, verticalBarRef, headerElementRef, footerElementRef });\n\n return (\n <Scrollbar\n className={styles.scrollable}\n ref={scrollbarRef}\n verticalBarRef={verticalBarRef}\n scrollableNodeProps={{\n ref: mergeRefs([scrollableNodeRef, scrollableContainerRef]),\n className: styles.scrollableNode,\n }}\n contentNodeProps={{\n ref: scrollbarContentNodeRef,\n className: cn(styles.contentNode, {\n [styles.hugContent]: height === 'hugContent',\n }),\n }}\n onContentScroll={handleScroll}\n >\n {enhancedChildren}\n </Scrollbar>\n );\n};\n"],"names":[],"mappings":";;;;;;;;;AAsBa,MAAA,YAAY,GAAc,CAAC,KAAK,KAAI;IAC7C,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,sBAAsB,GAAG,IAAI,EAAE,GAAG,KAAK;AAEjE,IAAA,MAAM,iBAAiB,GAAG,MAAM,CAAiB,IAAI,CAAC;AACtD,IAAA,MAAM,uBAAuB,GAAG,MAAM,CAAiB,IAAI,CAAC;AAC5D,IAAA,MAAM,YAAY,GAAG,MAAM,CAAwB,IAAI,CAAC;AACxD,IAAA,MAAM,cAAc,GAAG,MAAM,CAAiB,IAAI,CAAC;AACnD,IAAA,MAAM,gBAAgB,GAAG,MAAM,CAAiB,IAAI,CAAC;AACrD,IAAA,MAAM,gBAAgB,GAAG,MAAM,CAAwB,IAAI,CAAC;AAE5D,IAAA,MAAM,EAAE,YAAY,EAAE,GAAG,mBAAmB,CAAC,EAAE,uBAAuB,EAAE,iBAAiB,EAAE,CAAC;AAE5F,IAAA,MAAM,EAAE,gBAAgB,EAAE,GAAG,sBAAsB,CAAC;QAChD,QAAQ;QACR,gBAAgB;QAChB,gBAAgB;AACnB,KAAA,CAAC;IAEF,qBAAqB,CAAC,EAAE,YAAY,EAAE,cAAc,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,CAAC;AAE3F,IAAA,QACI,KAAC,CAAA,aAAA,CAAA,SAAS,IACN,SAAS,EAAE,MAAM,CAAC,UAAU,EAC5B,GAAG,EAAE,YAAY,EACjB,cAAc,EAAE,cAAc,EAC9B,mBAAmB,EAAE;YACjB,GAAG,EAAE,SAAS,CAAC,CAAC,iBAAiB,EAAE,sBAAsB,CAAC,CAAC;YAC3D,SAAS,EAAE,MAAM,CAAC,cAAc;AACnC,SAAA,EACD,gBAAgB,EAAE;AACd,YAAA,GAAG,EAAE,uBAAuB;AAC5B,YAAA,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,WAAW,EAAE;AAC9B,gBAAA,CAAC,MAAM,CAAC,UAAU,GAAG,MAAM,KAAK,YAAY;aAC/C,CAAC;AACL,SAAA,EACD,eAAe,EAAE,YAAY,IAE5B,gBAAgB,CACT;AAEpB;;;;"}
@@ -30,10 +30,15 @@
30
30
  backface-visibility: hidden;
31
31
  }
32
32
 
33
- .component.overlayHidden {
34
- box-shadow: var(--shadow-m);
33
+ .baseModalContainer.withoutOverlay {
34
+ pointer-events: none;
35
35
  }
36
36
 
37
+ .baseModalContainer.withoutOverlay .baseModalComponent {
38
+ pointer-events: auto;
39
+ box-shadow: var(--shadow-m);
40
+ }
41
+
37
42
  .marginTop-0 {
38
43
  margin-top: 0px;
39
44
  }
@@ -1,7 +1,7 @@
1
1
  import React, { forwardRef, useRef } from 'react';
2
2
  import cn from 'classnames';
3
3
  import { BaseModal } from '@alfalab/core-components-base-modal/moderncssm';
4
- import { useModalWheel } from '../../hooks/useModalWheel.js';
4
+ import { useScrollableContainerRef } from '../../hooks/use-scrollable-container-ref.js';
5
5
  import { getFullSizeModalTransitions } from '../../utils/get-full-size-modal-transitions.js';
6
6
  import { getHeightStyle } from '../../utils/get-height-style.js';
7
7
  import { getMarginStyles } from '../../utils/get-margin-styles.js';
@@ -11,18 +11,22 @@ import { getDefaultTransitionProps } from './get-default-transition-props.js';
11
11
  import styles from './index.module.css';
12
12
 
13
13
  const SideModal = forwardRef((props, ref) => {
14
- const { width = 500, height = 'fullHeight', horizontalAlign = 'center', verticalAlign = 'center', overlay = true, open, dataTestId, className, children, margin, scrollableContainerRef, onClose, ...restProps } = props;
14
+ const { width = 500, height = 'fullHeight', horizontalAlign = 'center', verticalAlign = 'center', overlay = true, open, dataTestId, className, children, margin, scrollableContainerRef: scrollableContainerRefProp, onClose, ...restProps } = props;
15
15
  const componentRef = useRef(null);
16
16
  const contentRef = useRef(null);
17
- const { wheelDeltaY, handleWheel } = useModalWheel(overlay);
17
+ const { handleWheel, scrollableContainerRef } = useScrollableContainerRef({
18
+ overlay,
19
+ refObject: scrollableContainerRefProp,
20
+ });
18
21
  const { isFullSizeModal, componentTransitions: fullSizeModalContentTransitions, backdropTransitions: fullSizeModalBackdropTransitions, } = getFullSizeModalTransitions({ verticalAlign, width, height });
19
- return (React.createElement(BaseModal, { ...restProps, open: open, dataTestId: dataTestId, ref: ref, componentRef: componentRef, contentElementRef: contentRef, scrollHandler: 'content', disableBlockingScroll: !overlay, wrapperClassName: cn(styles.wrapper, {
22
+ const withoutOverlay = !overlay;
23
+ return (React.createElement(BaseModal, { ...restProps, open: open, dataTestId: dataTestId, ref: ref, componentRef: componentRef, contentElementRef: contentRef, scrollHandler: 'content', disableBlockingScroll: withoutOverlay, wrapperClassName: cn(styles.wrapper, styles.baseModalContainer, {
20
24
  [styles.wrapperAlignStart]: horizontalAlign === 'start',
21
25
  [styles.wrapperAlignEnd]: horizontalAlign === 'end',
22
26
  [styles.wrapperJustifyCenter]: verticalAlign === 'center',
23
27
  [styles.wrapperJustifyEnd]: verticalAlign === 'bottom',
24
- }), className: cn(styles.component, className, {
25
- [styles.overlayHidden]: !overlay,
28
+ [styles.withoutOverlay]: withoutOverlay,
29
+ }), className: cn(styles.component, className, styles.baseModalComponent, {
26
30
  ...getMarginStyles({ styles, margin }),
27
31
  }), contentClassName: styles.content, transitionProps: {
28
32
  ...getDefaultTransitionProps({
@@ -32,7 +36,7 @@ const SideModal = forwardRef((props, ref) => {
32
36
  ...(isFullSizeModal && fullSizeModalContentTransitions),
33
37
  ...restProps.transitionProps,
34
38
  }, backdropProps: {
35
- transparent: !overlay,
39
+ shouldRender: overlay,
36
40
  ...(isFullSizeModal && fullSizeModalBackdropTransitions),
37
41
  ...restProps.backdropProps,
38
42
  }, componentDivProps: {
@@ -41,7 +45,7 @@ const SideModal = forwardRef((props, ref) => {
41
45
  ...getHeightStyle(height, margin),
42
46
  },
43
47
  }, onWheel: handleWheel, onClose: onClose },
44
- React.createElement(ModalContent, { height: height, wheelDeltaY: wheelDeltaY, scrollableContainerRef: scrollableContainerRef }, children)));
48
+ React.createElement(ModalContent, { height: height, scrollableContainerRef: scrollableContainerRef }, children)));
45
49
  });
46
50
 
47
51
  export { SideModal };
@@ -1 +1 @@
1
- {"version":3,"file":"side-modal.js","sources":["../../../../src/desktop/components/side-modal/side-modal.tsx"],"sourcesContent":["import React, { forwardRef, useRef } from 'react';\nimport cn from 'classnames';\n\nimport { BaseModal } from '@alfalab/core-components-base-modal';\n\nimport { useModalWheel } from '../../hooks/useModalWheel';\nimport { type UniversalModalDesktopProps } from '../../types/props';\nimport { getFullSizeModalTransitions } from '../../utils/get-full-size-modal-transitions';\nimport { getHeightStyle } from '../../utils/get-height-style';\nimport { getMarginStyles } from '../../utils/get-margin-styles';\nimport { getWidthStyle } from '../../utils/get-width-style';\nimport { ModalContent } from '../modal-content/modal-content';\n\nimport { getDefaultTransitionProps } from './get-default-transition-props';\n\nimport styles from './index.module.css';\n\nexport const SideModal = forwardRef<HTMLDivElement, UniversalModalDesktopProps>((props, ref) => {\n const {\n width = 500,\n height = 'fullHeight',\n horizontalAlign = 'center',\n verticalAlign = 'center',\n overlay = true,\n open,\n dataTestId,\n className,\n children,\n margin,\n scrollableContainerRef,\n onClose,\n ...restProps\n } = props;\n const componentRef = useRef<HTMLDivElement>(null);\n const contentRef = useRef<HTMLDivElement>(null);\n\n const { wheelDeltaY, handleWheel } = useModalWheel(overlay);\n\n const {\n isFullSizeModal,\n componentTransitions: fullSizeModalContentTransitions,\n backdropTransitions: fullSizeModalBackdropTransitions,\n } = getFullSizeModalTransitions({ verticalAlign, width, height });\n\n return (\n <BaseModal\n {...restProps}\n open={open}\n dataTestId={dataTestId}\n ref={ref}\n componentRef={componentRef}\n contentElementRef={contentRef}\n scrollHandler='content'\n disableBlockingScroll={!overlay}\n wrapperClassName={cn(styles.wrapper, {\n [styles.wrapperAlignStart]: horizontalAlign === 'start',\n [styles.wrapperAlignEnd]: horizontalAlign === 'end',\n [styles.wrapperJustifyCenter]: verticalAlign === 'center',\n [styles.wrapperJustifyEnd]: verticalAlign === 'bottom',\n })}\n className={cn(styles.component, className, {\n [styles.overlayHidden]: !overlay,\n ...getMarginStyles({ styles, margin }),\n })}\n contentClassName={styles.content}\n transitionProps={{\n ...getDefaultTransitionProps({\n horizontalAlign,\n margin,\n }),\n ...(isFullSizeModal && fullSizeModalContentTransitions),\n ...restProps.transitionProps,\n }}\n backdropProps={{\n transparent: !overlay,\n ...(isFullSizeModal && fullSizeModalBackdropTransitions),\n ...restProps.backdropProps,\n }}\n componentDivProps={{\n style: {\n width: getWidthStyle(width, margin),\n ...getHeightStyle(height, margin),\n },\n }}\n onWheel={handleWheel}\n onClose={onClose}\n >\n <ModalContent\n height={height}\n wheelDeltaY={wheelDeltaY}\n scrollableContainerRef={scrollableContainerRef}\n >\n {children}\n </ModalContent>\n </BaseModal>\n );\n});\n"],"names":[],"mappings":";;;;;;;;;;;;AAiBa,MAAA,SAAS,GAAG,UAAU,CAA6C,CAAC,KAAK,EAAE,GAAG,KAAI;AAC3F,IAAA,MAAM,EACF,KAAK,GAAG,GAAG,EACX,MAAM,GAAG,YAAY,EACrB,eAAe,GAAG,QAAQ,EAC1B,aAAa,GAAG,QAAQ,EACxB,OAAO,GAAG,IAAI,EACd,IAAI,EACJ,UAAU,EACV,SAAS,EACT,QAAQ,EACR,MAAM,EACN,sBAAsB,EACtB,OAAO,EACP,GAAG,SAAS,EACf,GAAG,KAAK;AACT,IAAA,MAAM,YAAY,GAAG,MAAM,CAAiB,IAAI,CAAC;AACjD,IAAA,MAAM,UAAU,GAAG,MAAM,CAAiB,IAAI,CAAC;IAE/C,MAAM,EAAE,WAAW,EAAE,WAAW,EAAE,GAAG,aAAa,CAAC,OAAO,CAAC;IAE3D,MAAM,EACF,eAAe,EACf,oBAAoB,EAAE,+BAA+B,EACrD,mBAAmB,EAAE,gCAAgC,GACxD,GAAG,2BAA2B,CAAC,EAAE,aAAa,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC;AAEjE,IAAA,QACI,KAAC,CAAA,aAAA,CAAA,SAAS,OACF,SAAS,EACb,IAAI,EAAE,IAAI,EACV,UAAU,EAAE,UAAU,EACtB,GAAG,EAAE,GAAG,EACR,YAAY,EAAE,YAAY,EAC1B,iBAAiB,EAAE,UAAU,EAC7B,aAAa,EAAC,SAAS,EACvB,qBAAqB,EAAE,CAAC,OAAO,EAC/B,gBAAgB,EAAE,EAAE,CAAC,MAAM,CAAC,OAAO,EAAE;AACjC,YAAA,CAAC,MAAM,CAAC,iBAAiB,GAAG,eAAe,KAAK,OAAO;AACvD,YAAA,CAAC,MAAM,CAAC,eAAe,GAAG,eAAe,KAAK,KAAK;AACnD,YAAA,CAAC,MAAM,CAAC,oBAAoB,GAAG,aAAa,KAAK,QAAQ;AACzD,YAAA,CAAC,MAAM,CAAC,iBAAiB,GAAG,aAAa,KAAK,QAAQ;SACzD,CAAC,EACF,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,SAAS,EAAE,SAAS,EAAE;AACvC,YAAA,CAAC,MAAM,CAAC,aAAa,GAAG,CAAC,OAAO;AAChC,YAAA,GAAG,eAAe,CAAC,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC;SACzC,CAAC,EACF,gBAAgB,EAAE,MAAM,CAAC,OAAO,EAChC,eAAe,EAAE;AACb,YAAA,GAAG,yBAAyB,CAAC;gBACzB,eAAe;gBACf,MAAM;aACT,CAAC;AACF,YAAA,IAAI,eAAe,IAAI,+BAA+B,CAAC;YACvD,GAAG,SAAS,CAAC,eAAe;AAC/B,SAAA,EACD,aAAa,EAAE;YACX,WAAW,EAAE,CAAC,OAAO;AACrB,YAAA,IAAI,eAAe,IAAI,gCAAgC,CAAC;YACxD,GAAG,SAAS,CAAC,aAAa;AAC7B,SAAA,EACD,iBAAiB,EAAE;AACf,YAAA,KAAK,EAAE;AACH,gBAAA,KAAK,EAAE,aAAa,CAAC,KAAK,EAAE,MAAM,CAAC;AACnC,gBAAA,GAAG,cAAc,CAAC,MAAM,EAAE,MAAM,CAAC;AACpC,aAAA;AACJ,SAAA,EACD,OAAO,EAAE,WAAW,EACpB,OAAO,EAAE,OAAO,EAAA;AAEhB,QAAA,KAAA,CAAA,aAAA,CAAC,YAAY,EACT,EAAA,MAAM,EAAE,MAAM,EACd,WAAW,EAAE,WAAW,EACxB,sBAAsB,EAAE,sBAAsB,EAAA,EAE7C,QAAQ,CACE,CACP;AAEpB,CAAC;;;;"}
1
+ {"version":3,"file":"side-modal.js","sources":["../../../../src/desktop/components/side-modal/side-modal.tsx"],"sourcesContent":["import React, { forwardRef, useRef } from 'react';\nimport cn from 'classnames';\n\nimport { BaseModal } from '@alfalab/core-components-base-modal';\n\nimport { useScrollableContainerRef } from '../../hooks/use-scrollable-container-ref';\nimport { type UniversalModalDesktopProps } from '../../types/props';\nimport { getFullSizeModalTransitions } from '../../utils/get-full-size-modal-transitions';\nimport { getHeightStyle } from '../../utils/get-height-style';\nimport { getMarginStyles } from '../../utils/get-margin-styles';\nimport { getWidthStyle } from '../../utils/get-width-style';\nimport { ModalContent } from '../modal-content/modal-content';\n\nimport { getDefaultTransitionProps } from './get-default-transition-props';\n\nimport styles from './index.module.css';\n\nexport const SideModal = forwardRef<HTMLDivElement, UniversalModalDesktopProps>((props, ref) => {\n const {\n width = 500,\n height = 'fullHeight',\n horizontalAlign = 'center',\n verticalAlign = 'center',\n overlay = true,\n open,\n dataTestId,\n className,\n children,\n margin,\n scrollableContainerRef: scrollableContainerRefProp,\n onClose,\n ...restProps\n } = props;\n const componentRef = useRef<HTMLDivElement>(null);\n const contentRef = useRef<HTMLDivElement>(null);\n const { handleWheel, scrollableContainerRef } = useScrollableContainerRef({\n overlay,\n refObject: scrollableContainerRefProp,\n });\n\n const {\n isFullSizeModal,\n componentTransitions: fullSizeModalContentTransitions,\n backdropTransitions: fullSizeModalBackdropTransitions,\n } = getFullSizeModalTransitions({ verticalAlign, width, height });\n\n const withoutOverlay = !overlay;\n\n return (\n <BaseModal\n {...restProps}\n open={open}\n dataTestId={dataTestId}\n ref={ref}\n componentRef={componentRef}\n contentElementRef={contentRef}\n scrollHandler='content'\n disableBlockingScroll={withoutOverlay}\n wrapperClassName={cn(styles.wrapper, styles.baseModalContainer, {\n [styles.wrapperAlignStart]: horizontalAlign === 'start',\n [styles.wrapperAlignEnd]: horizontalAlign === 'end',\n [styles.wrapperJustifyCenter]: verticalAlign === 'center',\n [styles.wrapperJustifyEnd]: verticalAlign === 'bottom',\n [styles.withoutOverlay]: withoutOverlay,\n })}\n className={cn(styles.component, className, styles.baseModalComponent, {\n ...getMarginStyles({ styles, margin }),\n })}\n contentClassName={styles.content}\n transitionProps={{\n ...getDefaultTransitionProps({\n horizontalAlign,\n margin,\n }),\n ...(isFullSizeModal && fullSizeModalContentTransitions),\n ...restProps.transitionProps,\n }}\n backdropProps={{\n shouldRender: overlay,\n ...(isFullSizeModal && fullSizeModalBackdropTransitions),\n ...restProps.backdropProps,\n }}\n componentDivProps={{\n style: {\n width: getWidthStyle(width, margin),\n ...getHeightStyle(height, margin),\n },\n }}\n onWheel={handleWheel}\n onClose={onClose}\n >\n <ModalContent height={height} scrollableContainerRef={scrollableContainerRef}>\n {children}\n </ModalContent>\n </BaseModal>\n );\n});\n"],"names":[],"mappings":";;;;;;;;;;;;AAiBa,MAAA,SAAS,GAAG,UAAU,CAA6C,CAAC,KAAK,EAAE,GAAG,KAAI;AAC3F,IAAA,MAAM,EACF,KAAK,GAAG,GAAG,EACX,MAAM,GAAG,YAAY,EACrB,eAAe,GAAG,QAAQ,EAC1B,aAAa,GAAG,QAAQ,EACxB,OAAO,GAAG,IAAI,EACd,IAAI,EACJ,UAAU,EACV,SAAS,EACT,QAAQ,EACR,MAAM,EACN,sBAAsB,EAAE,0BAA0B,EAClD,OAAO,EACP,GAAG,SAAS,EACf,GAAG,KAAK;AACT,IAAA,MAAM,YAAY,GAAG,MAAM,CAAiB,IAAI,CAAC;AACjD,IAAA,MAAM,UAAU,GAAG,MAAM,CAAiB,IAAI,CAAC;AAC/C,IAAA,MAAM,EAAE,WAAW,EAAE,sBAAsB,EAAE,GAAG,yBAAyB,CAAC;QACtE,OAAO;AACP,QAAA,SAAS,EAAE,0BAA0B;AACxC,KAAA,CAAC;IAEF,MAAM,EACF,eAAe,EACf,oBAAoB,EAAE,+BAA+B,EACrD,mBAAmB,EAAE,gCAAgC,GACxD,GAAG,2BAA2B,CAAC,EAAE,aAAa,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC;AAEjE,IAAA,MAAM,cAAc,GAAG,CAAC,OAAO;IAE/B,QACI,oBAAC,SAAS,EAAA,EAAA,GACF,SAAS,EACb,IAAI,EAAE,IAAI,EACV,UAAU,EAAE,UAAU,EACtB,GAAG,EAAE,GAAG,EACR,YAAY,EAAE,YAAY,EAC1B,iBAAiB,EAAE,UAAU,EAC7B,aAAa,EAAC,SAAS,EACvB,qBAAqB,EAAE,cAAc,EACrC,gBAAgB,EAAE,EAAE,CAAC,MAAM,CAAC,OAAO,EAAE,MAAM,CAAC,kBAAkB,EAAE;AAC5D,YAAA,CAAC,MAAM,CAAC,iBAAiB,GAAG,eAAe,KAAK,OAAO;AACvD,YAAA,CAAC,MAAM,CAAC,eAAe,GAAG,eAAe,KAAK,KAAK;AACnD,YAAA,CAAC,MAAM,CAAC,oBAAoB,GAAG,aAAa,KAAK,QAAQ;AACzD,YAAA,CAAC,MAAM,CAAC,iBAAiB,GAAG,aAAa,KAAK,QAAQ;AACtD,YAAA,CAAC,MAAM,CAAC,cAAc,GAAG,cAAc;AAC1C,SAAA,CAAC,EACF,SAAS,EAAE,EAAE,CAAC,MAAM,CAAC,SAAS,EAAE,SAAS,EAAE,MAAM,CAAC,kBAAkB,EAAE;AAClE,YAAA,GAAG,eAAe,CAAC,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC;SACzC,CAAC,EACF,gBAAgB,EAAE,MAAM,CAAC,OAAO,EAChC,eAAe,EAAE;AACb,YAAA,GAAG,yBAAyB,CAAC;gBACzB,eAAe;gBACf,MAAM;aACT,CAAC;AACF,YAAA,IAAI,eAAe,IAAI,+BAA+B,CAAC;YACvD,GAAG,SAAS,CAAC,eAAe;AAC/B,SAAA,EACD,aAAa,EAAE;AACX,YAAA,YAAY,EAAE,OAAO;AACrB,YAAA,IAAI,eAAe,IAAI,gCAAgC,CAAC;YACxD,GAAG,SAAS,CAAC,aAAa;AAC7B,SAAA,EACD,iBAAiB,EAAE;AACf,YAAA,KAAK,EAAE;AACH,gBAAA,KAAK,EAAE,aAAa,CAAC,KAAK,EAAE,MAAM,CAAC;AACnC,gBAAA,GAAG,cAAc,CAAC,MAAM,EAAE,MAAM,CAAC;AACpC,aAAA;AACJ,SAAA,EACD,OAAO,EAAE,WAAW,EACpB,OAAO,EAAE,OAAO,EAAA;AAEhB,QAAA,KAAA,CAAA,aAAA,CAAC,YAAY,EAAA,EAAC,MAAM,EAAE,MAAM,EAAE,sBAAsB,EAAE,sBAAsB,EACvE,EAAA,QAAQ,CACE,CACP;AAEpB,CAAC;;;;"}
@@ -0,0 +1,10 @@
1
+ import { type RefObject, type WheelEvent } from 'react';
2
+ interface Params {
3
+ overlay: boolean;
4
+ refObject?: RefObject<HTMLDivElement>;
5
+ }
6
+ export declare const useScrollableContainerRef: ({ overlay, refObject }: Params) => {
7
+ handleWheel: (e: WheelEvent<HTMLElement>) => void;
8
+ scrollableContainerRef: RefObject<HTMLDivElement>;
9
+ };
10
+ export {};
@@ -0,0 +1,21 @@
1
+ import { useRef, useCallback } from 'react';
2
+
3
+ const useScrollableContainerRef = ({ overlay, refObject }) => {
4
+ const innerScrollableContainerRef = useRef(null);
5
+ const scrollableContainerRef = refObject || innerScrollableContainerRef;
6
+ const handleWheel = useCallback((e) => {
7
+ if (!overlay || e.target !== e.currentTarget) {
8
+ return;
9
+ }
10
+ scrollableContainerRef.current?.scrollBy({
11
+ top: e.deltaY,
12
+ });
13
+ }, [overlay, scrollableContainerRef]);
14
+ return {
15
+ handleWheel,
16
+ scrollableContainerRef,
17
+ };
18
+ };
19
+
20
+ export { useScrollableContainerRef };
21
+ //# sourceMappingURL=use-scrollable-container-ref.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-scrollable-container-ref.js","sources":["../../../src/desktop/hooks/use-scrollable-container-ref.ts"],"sourcesContent":["import { type RefObject, useCallback, useRef, type WheelEvent } from 'react';\n\ninterface Params {\n overlay: boolean;\n refObject?: RefObject<HTMLDivElement>;\n}\n\nexport const useScrollableContainerRef = ({ overlay, refObject }: Params) => {\n const innerScrollableContainerRef = useRef<HTMLDivElement>(null);\n const scrollableContainerRef = refObject || innerScrollableContainerRef;\n\n const handleWheel = useCallback(\n (e: WheelEvent<HTMLElement>) => {\n if (!overlay || e.target !== e.currentTarget) {\n return;\n }\n\n scrollableContainerRef.current?.scrollBy({\n top: e.deltaY,\n });\n },\n [overlay, scrollableContainerRef],\n );\n\n return {\n handleWheel,\n scrollableContainerRef,\n };\n};\n"],"names":[],"mappings":";;AAOa,MAAA,yBAAyB,GAAG,CAAC,EAAE,OAAO,EAAE,SAAS,EAAU,KAAI;AACxE,IAAA,MAAM,2BAA2B,GAAG,MAAM,CAAiB,IAAI,CAAC;AAChE,IAAA,MAAM,sBAAsB,GAAG,SAAS,IAAI,2BAA2B;AAEvE,IAAA,MAAM,WAAW,GAAG,WAAW,CAC3B,CAAC,CAA0B,KAAI;QAC3B,IAAI,CAAC,OAAO,IAAI,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC,aAAa,EAAE;YAC1C;;AAGJ,QAAA,sBAAsB,CAAC,OAAO,EAAE,QAAQ,CAAC;YACrC,GAAG,EAAE,CAAC,CAAC,MAAM;AAChB,SAAA,CAAC;AACN,KAAC,EACD,CAAC,OAAO,EAAE,sBAAsB,CAAC,CACpC;IAED,OAAO;QACH,WAAW;QACX,sBAAsB;KACzB;AACL;;;;"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@alfalab/core-components-universal-modal",
3
- "version": "3.0.7",
3
+ "version": "3.1.0",
4
4
  "description": "UniversalModal component",
5
5
  "keywords": [],
6
6
  "license": "MIT",
@@ -11,7 +11,7 @@
11
11
  "module": "./esm/index.js",
12
12
  "dependencies": {
13
13
  "@alfalab/core-components-backdrop": "^5.0.2",
14
- "@alfalab/core-components-base-modal": "^7.1.2",
14
+ "@alfalab/core-components-base-modal": "^7.1.3",
15
15
  "@alfalab/core-components-mq": "^6.0.3",
16
16
  "@alfalab/core-components-navigation-bar-private": "^2.0.6",
17
17
  "@alfalab/core-components-scrollbar": "^5.0.2",
@@ -30,6 +30,6 @@
30
30
  "access": "public",
31
31
  "directory": "dist"
32
32
  },
33
- "themesVersion": "15.0.2",
33
+ "themesVersion": "15.0.3",
34
34
  "varsVersion": "11.0.2"
35
35
  }
@@ -1,4 +1,4 @@
1
- @import '../../../vars.css';
1
+ @import '@alfalab/core-components-vars/src/index.css';
2
2
 
3
3
  .component {
4
4
  border-radius: var(--border-radius-24);
@@ -11,10 +11,6 @@
11
11
  */
12
12
  will-change: transform, opacity;
13
13
  backface-visibility: hidden;
14
-
15
- &.overlayHidden {
16
- box-shadow: var(--shadow-m);
17
- }
18
14
  }
19
15
 
20
16
  .wrapperJustifyStart {
@@ -4,7 +4,7 @@ import cn from 'classnames';
4
4
  import { BaseModal } from '@alfalab/core-components-base-modal';
5
5
  import { isMacOS, isSafari } from '@alfalab/core-components-shared';
6
6
 
7
- import { useModalWheel } from '../../hooks/useModalWheel';
7
+ import { useScrollableContainerRef } from '../../hooks/use-scrollable-container-ref';
8
8
  import { type UniversalModalDesktopProps } from '../../types/props';
9
9
  import { getFullSizeModalTransitions } from '../../utils/get-full-size-modal-transitions';
10
10
  import { getHeightStyle } from '../../utils/get-height-style';
@@ -30,14 +30,16 @@ export const CenterModal = forwardRef<HTMLDivElement, UniversalModalDesktopProps
30
30
  verticalAlign = 'center',
31
31
  overlay = true,
32
32
  margin,
33
- scrollableContainerRef,
33
+ scrollableContainerRef: scrollableContainerRefProp,
34
34
  onClose,
35
35
  ...restProps
36
36
  } = props;
37
37
 
38
38
  const componentRef = useRef<HTMLDivElement>(null);
39
-
40
- const { wheelDeltaY, handleWheel } = useModalWheel(overlay);
39
+ const { handleWheel, scrollableContainerRef } = useScrollableContainerRef({
40
+ overlay,
41
+ refObject: scrollableContainerRefProp,
42
+ });
41
43
 
42
44
  const {
43
45
  isFullSizeModal,
@@ -45,6 +47,8 @@ export const CenterModal = forwardRef<HTMLDivElement, UniversalModalDesktopProps
45
47
  backdropTransitions: fullSizeModalBackdropTransitions,
46
48
  } = getFullSizeModalTransitions({ verticalAlign, width, height });
47
49
 
50
+ const withoutOverlay = !overlay;
51
+
48
52
  return (
49
53
  <BaseModal
50
54
  {...restProps}
@@ -53,14 +57,14 @@ export const CenterModal = forwardRef<HTMLDivElement, UniversalModalDesktopProps
53
57
  ref={ref}
54
58
  componentRef={componentRef}
55
59
  scrollHandler='content'
56
- disableBlockingScroll={!overlay}
57
- wrapperClassName={cn({
60
+ disableBlockingScroll={withoutOverlay}
61
+ wrapperClassName={cn(styles.baseModalContainer, {
58
62
  [styles.wrapperJustifyStart]: verticalAlign === 'top',
59
63
  [styles.wrapperJustifyCenter]: verticalAlign === 'center',
60
64
  [styles.wrapperJustifyEnd]: verticalAlign === 'bottom',
65
+ [styles.withoutOverlay]: withoutOverlay,
61
66
  })}
62
- className={cn(styles.component, className, {
63
- [styles.overlayHidden]: !overlay,
67
+ className={cn(styles.component, className, styles.baseModalComponent, {
64
68
  ...getMarginStyles({ styles, margin }),
65
69
  })}
66
70
  transitionProps={{
@@ -69,7 +73,7 @@ export const CenterModal = forwardRef<HTMLDivElement, UniversalModalDesktopProps
69
73
  ...restProps.transitionProps,
70
74
  }}
71
75
  backdropProps={{
72
- transparent: !overlay,
76
+ shouldRender: overlay,
73
77
  ...(isFullSizeModal && fullSizeModalBackdropTransitions),
74
78
  ...restProps.backdropProps,
75
79
  }}
@@ -82,11 +86,7 @@ export const CenterModal = forwardRef<HTMLDivElement, UniversalModalDesktopProps
82
86
  onWheel={handleWheel}
83
87
  onClose={onClose}
84
88
  >
85
- <ModalContent
86
- height={height}
87
- wheelDeltaY={wheelDeltaY}
88
- scrollableContainerRef={scrollableContainerRef}
89
- >
89
+ <ModalContent height={height} scrollableContainerRef={scrollableContainerRef}>
90
90
  {children}
91
91
  </ModalContent>
92
92
  </BaseModal>
@@ -1,2 +1,3 @@
1
- @import 'center-modal.module.css';
1
+ @import './center-modal.module.css';
2
+ @import '../../styles/common.module.css';
2
3
  @import '../../styles/margins.module.css';
@@ -6,21 +6,22 @@ import { type BaseModalProps } from '@alfalab/core-components-base-modal';
6
6
  import { Scrollbar } from '@alfalab/core-components-scrollbar';
7
7
 
8
8
  import { useModalHighlighted } from '../../hooks/use-modal-highlighted';
9
- import { useOutsideScroll } from '../../hooks/use-outside-scroll';
10
9
  import { useSetScrollbarHeight } from '../../hooks/use-set-scrollbar-height';
11
10
  import { type UniversalModalDesktopProps } from '../../types/props';
12
11
  import { setFooterAndHeaderRefs } from '../../utils/set-footer-and-header-refs';
13
12
 
14
13
  import styles from './modal-content.module.css';
15
14
 
16
- interface Props
17
- extends Pick<BaseModalProps, 'children'>,
18
- Pick<UniversalModalDesktopProps, 'height' | 'scrollableContainerRef'> {
19
- wheelDeltaY: number;
20
- }
15
+ type PickedBaseModalProps = Pick<BaseModalProps, 'children'>;
16
+ type PickedUniversalModalDesktopProps = Pick<
17
+ UniversalModalDesktopProps,
18
+ 'height' | 'scrollableContainerRef'
19
+ >;
20
+
21
+ type Props = PickedBaseModalProps & PickedUniversalModalDesktopProps;
21
22
 
22
23
  export const ModalContent: FC<Props> = (props) => {
23
- const { children, wheelDeltaY, height, scrollableContainerRef = null } = props;
24
+ const { children, height, scrollableContainerRef = null } = props;
24
25
 
25
26
  const scrollableNodeRef = useRef<HTMLDivElement>(null);
26
27
  const scrollbarContentNodeRef = useRef<HTMLDivElement>(null);
@@ -31,8 +32,6 @@ export const ModalContent: FC<Props> = (props) => {
31
32
 
32
33
  const { handleScroll } = useModalHighlighted({ scrollbarContentNodeRef, scrollableNodeRef });
33
34
 
34
- useOutsideScroll({ scrollableNodeRef, wheelDeltaY });
35
-
36
35
  const { enhancedChildren } = setFooterAndHeaderRefs({
37
36
  children,
38
37
  headerElementRef,
@@ -1,2 +1,3 @@
1
- @import 'side-modal.module.css';
1
+ @import './side-modal.module.css';
2
+ @import '../../styles/common.module.css';
2
3
  @import '../../styles/margins.module.css';
@@ -31,8 +31,4 @@
31
31
  */
32
32
  will-change: transform;
33
33
  backface-visibility: hidden;
34
-
35
- &.overlayHidden {
36
- box-shadow: var(--shadow-m);
37
- }
38
34
  }