@alfalab/core-components-universal-modal 1.0.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.
- package/Component.responsive.d.ts +15 -0
- package/Component.responsive.js +44 -0
- package/Context.d.ts +4 -0
- package/Context.js +9 -0
- package/ResponsiveContext.d.ts +4 -0
- package/ResponsiveContext.js +9 -0
- package/components/content/base-content/base-content.d.ts +17 -0
- package/components/content/base-content/base-content.js +28 -0
- package/components/content/base-content/index.css +44 -0
- package/components/content/desktop/Component.desktop.d.ts +10 -0
- package/components/content/desktop/Component.desktop.js +20 -0
- package/components/content/index.d.ts +7 -0
- package/components/content/index.js +13 -0
- package/components/content/mobile/Component.mobile.d.ts +5 -0
- package/components/content/mobile/Component.mobile.js +23 -0
- package/components/content/mobile/mobile.css +38 -0
- package/components/content/responsive/Component.responsive.d.ts +6 -0
- package/components/content/responsive/Component.responsive.js +24 -0
- package/components/footer/base-footer/base-footer.d.ts +29 -0
- package/components/footer/base-footer/base-footer.js +34 -0
- package/components/footer/base-footer/index.css +48 -0
- package/components/footer/desktop/Component.desktop.d.ts +10 -0
- package/components/footer/desktop/Component.desktop.js +34 -0
- package/components/footer/desktop/desktop.css +30 -0
- package/components/footer/desktop/layout.css +58 -0
- package/components/footer/index.d.ts +7 -0
- package/components/footer/index.js +13 -0
- package/components/footer/mobile/Component.mobile.d.ts +5 -0
- package/components/footer/mobile/Component.mobile.js +31 -0
- package/components/footer/mobile/layout.mobile.css +50 -0
- package/components/footer/mobile/mobile.css +34 -0
- package/components/footer/responsive/Component.responsive.d.ts +6 -0
- package/components/footer/responsive/Component.responsive.js +24 -0
- package/components/header/base-header/index.css +72 -0
- package/components/header/desktop/Component.desktop.d.ts +11 -0
- package/components/header/desktop/Component.desktop.js +44 -0
- package/components/header/desktop/desktop.css +57 -0
- package/components/header/index.d.ts +7 -0
- package/components/header/index.js +13 -0
- package/components/header/mobile/Component.mobile.d.ts +5 -0
- package/components/header/mobile/Component.mobile.js +38 -0
- package/components/header/mobile/mobile.css +59 -0
- package/components/header/responsive/Component.responsive.d.ts +6 -0
- package/components/header/responsive/Component.responsive.js +24 -0
- package/cssm/Component.responsive.d.ts +15 -0
- package/cssm/Component.responsive.js +58 -0
- package/cssm/Context.d.ts +4 -0
- package/cssm/Context.js +9 -0
- package/cssm/ResponsiveContext.d.ts +4 -0
- package/cssm/ResponsiveContext.js +9 -0
- package/cssm/components/content/base-content/base-content.d.ts +17 -0
- package/cssm/components/content/base-content/base-content.js +27 -0
- package/cssm/components/content/base-content/index.module.css +43 -0
- package/cssm/components/content/desktop/Component.desktop.d.ts +10 -0
- package/cssm/components/content/desktop/Component.desktop.js +20 -0
- package/cssm/components/content/index.d.ts +7 -0
- package/cssm/components/content/index.js +13 -0
- package/cssm/components/content/mobile/Component.mobile.d.ts +5 -0
- package/cssm/components/content/mobile/Component.mobile.js +22 -0
- package/cssm/components/content/mobile/mobile.module.css +37 -0
- package/cssm/components/content/responsive/Component.responsive.d.ts +6 -0
- package/cssm/components/content/responsive/Component.responsive.js +24 -0
- package/cssm/components/footer/base-footer/base-footer.d.ts +29 -0
- package/cssm/components/footer/base-footer/base-footer.js +33 -0
- package/cssm/components/footer/base-footer/index.module.css +47 -0
- package/cssm/components/footer/desktop/Component.desktop.d.ts +10 -0
- package/cssm/components/footer/desktop/Component.desktop.js +32 -0
- package/cssm/components/footer/desktop/desktop.module.css +29 -0
- package/cssm/components/footer/desktop/layout.module.css +54 -0
- package/cssm/components/footer/index.d.ts +7 -0
- package/cssm/components/footer/index.js +13 -0
- package/cssm/components/footer/mobile/Component.mobile.d.ts +5 -0
- package/cssm/components/footer/mobile/Component.mobile.js +29 -0
- package/cssm/components/footer/mobile/layout.mobile.module.css +47 -0
- package/cssm/components/footer/mobile/mobile.module.css +33 -0
- package/cssm/components/footer/responsive/Component.responsive.d.ts +6 -0
- package/cssm/components/footer/responsive/Component.responsive.js +24 -0
- package/cssm/components/header/base-header/index.module.css +71 -0
- package/cssm/components/header/desktop/Component.desktop.d.ts +11 -0
- package/cssm/components/header/desktop/Component.desktop.js +44 -0
- package/cssm/components/header/desktop/desktop.module.css +56 -0
- package/cssm/components/header/index.d.ts +7 -0
- package/cssm/components/header/index.js +13 -0
- package/cssm/components/header/mobile/Component.mobile.d.ts +5 -0
- package/cssm/components/header/mobile/Component.mobile.js +38 -0
- package/cssm/components/header/mobile/mobile.module.css +58 -0
- package/cssm/components/header/responsive/Component.responsive.d.ts +6 -0
- package/cssm/components/header/responsive/Component.responsive.js +24 -0
- package/cssm/desktop/Component.desktop.d.ts +9 -0
- package/cssm/desktop/Component.desktop.js +58 -0
- package/cssm/desktop/components/base-universal-modal-content/base-universal-modal-content.d.ts +7 -0
- package/cssm/desktop/components/base-universal-modal-content/base-universal-modal-content.js +121 -0
- package/cssm/desktop/components/base-universal-modal-content/base-universal-modal-content.module.css +34 -0
- package/cssm/desktop/components/buttons/arrow-button/arrow-button.d.ts +6 -0
- package/cssm/desktop/components/buttons/arrow-button/arrow-button.js +22 -0
- package/cssm/desktop/components/buttons/arrow-button/arrow-button.module.css +31 -0
- package/cssm/desktop/components/buttons/arrow-button/index.d.ts +1 -0
- package/cssm/desktop/components/buttons/arrow-button/index.js +9 -0
- package/cssm/desktop/components/buttons/cross-button/cross-button.d.ts +6 -0
- package/cssm/desktop/components/buttons/cross-button/cross-button.js +20 -0
- package/cssm/desktop/components/buttons/cross-button/cross-button.module.css +28 -0
- package/cssm/desktop/components/buttons/cross-button/index.d.ts +1 -0
- package/cssm/desktop/components/buttons/cross-button/index.js +9 -0
- package/cssm/desktop/components/center-modal/center-modal.d.ts +4 -0
- package/cssm/desktop/components/center-modal/center-modal.js +43 -0
- package/cssm/desktop/components/center-modal/index.d.ts +1 -0
- package/cssm/desktop/components/center-modal/index.js +9 -0
- package/cssm/desktop/components/center-modal/styles/center-modal.module.css +52 -0
- package/cssm/desktop/components/center-modal/styles/index.module.css +1084 -0
- package/cssm/desktop/components/center-modal/styles/transitions/safari-transitions.module.css +23 -0
- package/cssm/desktop/components/center-modal/styles/transitions/transitions.module.css +23 -0
- package/cssm/desktop/components/side-modal/get-default-transition-props.d.ts +20 -0
- package/cssm/desktop/components/side-modal/get-default-transition-props.js +42 -0
- package/cssm/desktop/components/side-modal/index.d.ts +1 -0
- package/cssm/desktop/components/side-modal/index.js +9 -0
- package/cssm/desktop/components/side-modal/side-modal.d.ts +4 -0
- package/cssm/desktop/components/side-modal/side-modal.js +50 -0
- package/cssm/desktop/components/side-modal/styles/index.module.css +1087 -0
- package/cssm/desktop/components/side-modal/styles/side-modal.module.css +55 -0
- package/cssm/desktop/components/side-modal/styles/transitions/transitions.module.css +330 -0
- package/cssm/desktop/constants/index.d.ts +3 -0
- package/cssm/desktop/constants/index.js +9 -0
- package/cssm/desktop/hooks/useModalHeight.d.ts +4 -0
- package/cssm/desktop/hooks/useModalHeight.js +33 -0
- package/cssm/desktop/hooks/useModalWheel.d.ts +6 -0
- package/cssm/desktop/hooks/useModalWheel.js +19 -0
- package/cssm/desktop/hooks/useModalWidth.d.ts +4 -0
- package/cssm/desktop/hooks/useModalWidth.js +41 -0
- package/cssm/desktop/index.d.ts +10 -0
- package/cssm/desktop/index.js +34 -0
- package/cssm/desktop/styles/margins.module.css +1552 -0
- package/cssm/desktop/styles/transitions/full-size-backdrop-transitions.module.css +59 -0
- package/cssm/desktop/styles/transitions/full-size-vertical-bottom-transitions.module.css +24 -0
- package/cssm/desktop/styles/transitions/full-size-vertical-center-transitions.module.css +20 -0
- package/cssm/desktop/styles/transitions/full-size-vertical-top-transitions.module.css +24 -0
- package/cssm/desktop/types/props.d.ts +45 -0
- package/cssm/desktop/types/props.js +2 -0
- package/cssm/desktop/utils/get-full-size-modal-transitions.d.ts +16 -0
- package/cssm/desktop/utils/get-full-size-modal-transitions.js +54 -0
- package/cssm/desktop/utils/get-margins.d.ts +7 -0
- package/cssm/desktop/utils/get-margins.js +22 -0
- package/cssm/desktop/vars.css +24 -0
- package/cssm/index.d.ts +8 -0
- package/cssm/index.js +33 -0
- package/cssm/mobile/Component.mobile.d.ts +9 -0
- package/cssm/mobile/Component.mobile.js +45 -0
- package/cssm/mobile/components/buttons/arrow-button/arrow-button.d.ts +6 -0
- package/cssm/mobile/components/buttons/arrow-button/arrow-button.js +20 -0
- package/cssm/mobile/components/buttons/arrow-button/arrow-button.module.css +30 -0
- package/cssm/mobile/components/buttons/arrow-button/index.d.ts +1 -0
- package/cssm/mobile/components/buttons/arrow-button/index.js +9 -0
- package/cssm/mobile/components/buttons/cross-button/cross-button.d.ts +6 -0
- package/cssm/mobile/components/buttons/cross-button/cross-button.js +20 -0
- package/cssm/mobile/components/buttons/cross-button/cross-button.module.css +30 -0
- package/cssm/mobile/components/buttons/cross-button/index.d.ts +1 -0
- package/cssm/mobile/components/buttons/cross-button/index.js +9 -0
- package/cssm/mobile/index.d.ts +10 -0
- package/cssm/mobile/index.js +34 -0
- package/cssm/mobile/mobile.module.css +38 -0
- package/cssm/mobile/transitions/right-side-transitions.mobile.module.css +37 -0
- package/cssm/mobile/transitions/transitions.mobile.module.css +24 -0
- package/cssm/mobile/types/props.d.ts +11 -0
- package/cssm/mobile/types/props.js +2 -0
- package/cssm/mobile/vars.css +24 -0
- package/cssm/shared/index.d.ts +2 -0
- package/cssm/shared/index.js +11 -0
- package/cssm/typings/index.d.ts +22 -0
- package/cssm/typings/index.js +2 -0
- package/cssm/typings/margin-type.d.ts +8 -0
- package/cssm/typings/margin-type.js +2 -0
- package/cssm/utils/getUniversalModalTestIds.d.ts +8 -0
- package/cssm/utils/getUniversalModalTestIds.js +17 -0
- package/cssm/vars.css +26 -0
- package/desktop/Component.desktop.d.ts +9 -0
- package/desktop/Component.desktop.js +51 -0
- package/desktop/components/base-universal-modal-content/base-universal-modal-content.css +35 -0
- package/desktop/components/base-universal-modal-content/base-universal-modal-content.d.ts +7 -0
- package/desktop/components/base-universal-modal-content/base-universal-modal-content.js +122 -0
- package/desktop/components/buttons/arrow-button/arrow-button.css +32 -0
- package/desktop/components/buttons/arrow-button/arrow-button.d.ts +6 -0
- package/desktop/components/buttons/arrow-button/arrow-button.js +23 -0
- package/desktop/components/buttons/arrow-button/index.d.ts +1 -0
- package/desktop/components/buttons/arrow-button/index.js +9 -0
- package/desktop/components/buttons/cross-button/cross-button.css +29 -0
- package/desktop/components/buttons/cross-button/cross-button.d.ts +6 -0
- package/desktop/components/buttons/cross-button/cross-button.js +21 -0
- package/desktop/components/buttons/cross-button/index.d.ts +1 -0
- package/desktop/components/buttons/cross-button/index.js +9 -0
- package/desktop/components/center-modal/center-modal.d.ts +4 -0
- package/desktop/components/center-modal/center-modal.js +46 -0
- package/desktop/components/center-modal/index.d.ts +1 -0
- package/desktop/components/center-modal/index.js +9 -0
- package/desktop/components/center-modal/styles/index.css +1085 -0
- package/desktop/components/center-modal/styles/transitions/safari-transitions.css +24 -0
- package/desktop/components/center-modal/styles/transitions/transitions.css +24 -0
- package/desktop/components/side-modal/get-default-transition-props.d.ts +20 -0
- package/desktop/components/side-modal/get-default-transition-props.js +43 -0
- package/desktop/components/side-modal/index.d.ts +1 -0
- package/desktop/components/side-modal/index.js +9 -0
- package/desktop/components/side-modal/side-modal.d.ts +4 -0
- package/desktop/components/side-modal/side-modal.js +51 -0
- package/desktop/components/side-modal/styles/index.css +1088 -0
- package/desktop/components/side-modal/styles/transitions/transitions.css +331 -0
- package/desktop/constants/index.d.ts +3 -0
- package/desktop/constants/index.js +9 -0
- package/desktop/hooks/useModalHeight.d.ts +4 -0
- package/desktop/hooks/useModalHeight.js +33 -0
- package/desktop/hooks/useModalWheel.d.ts +6 -0
- package/desktop/hooks/useModalWheel.js +19 -0
- package/desktop/hooks/useModalWidth.d.ts +4 -0
- package/desktop/hooks/useModalWidth.js +41 -0
- package/desktop/index.d.ts +10 -0
- package/desktop/index.js +27 -0
- package/desktop/package.json +3 -0
- package/desktop/styles/transitions/full-size-backdrop-transitions.css +60 -0
- package/desktop/styles/transitions/full-size-vertical-bottom-transitions.css +25 -0
- package/desktop/styles/transitions/full-size-vertical-center-transitions.css +21 -0
- package/desktop/styles/transitions/full-size-vertical-top-transitions.css +25 -0
- package/desktop/types/props.d.ts +45 -0
- package/desktop/types/props.js +2 -0
- package/desktop/utils/get-full-size-modal-transitions.d.ts +16 -0
- package/desktop/utils/get-full-size-modal-transitions.js +55 -0
- package/desktop/utils/get-margins.d.ts +7 -0
- package/desktop/utils/get-margins.js +22 -0
- package/esm/Component.responsive.d.ts +15 -0
- package/esm/Component.responsive.js +35 -0
- package/esm/Context.d.ts +4 -0
- package/esm/Context.js +5 -0
- package/esm/ResponsiveContext.d.ts +4 -0
- package/esm/ResponsiveContext.js +5 -0
- package/esm/components/content/base-content/base-content.d.ts +17 -0
- package/esm/components/content/base-content/base-content.js +19 -0
- package/esm/components/content/base-content/index.css +44 -0
- package/esm/components/content/desktop/Component.desktop.d.ts +10 -0
- package/esm/components/content/desktop/Component.desktop.js +11 -0
- package/esm/components/content/index.d.ts +7 -0
- package/esm/components/content/index.js +3 -0
- package/esm/components/content/mobile/Component.mobile.d.ts +5 -0
- package/esm/components/content/mobile/Component.mobile.js +14 -0
- package/esm/components/content/mobile/mobile.css +38 -0
- package/esm/components/content/responsive/Component.responsive.d.ts +6 -0
- package/esm/components/content/responsive/Component.responsive.js +16 -0
- package/esm/components/footer/base-footer/base-footer.d.ts +29 -0
- package/esm/components/footer/base-footer/base-footer.js +25 -0
- package/esm/components/footer/base-footer/index.css +48 -0
- package/esm/components/footer/desktop/Component.desktop.d.ts +10 -0
- package/esm/components/footer/desktop/Component.desktop.js +25 -0
- package/esm/components/footer/desktop/desktop.css +30 -0
- package/esm/components/footer/desktop/layout.css +58 -0
- package/esm/components/footer/index.d.ts +7 -0
- package/esm/components/footer/index.js +3 -0
- package/esm/components/footer/mobile/Component.mobile.d.ts +5 -0
- package/esm/components/footer/mobile/Component.mobile.js +22 -0
- package/esm/components/footer/mobile/layout.mobile.css +50 -0
- package/esm/components/footer/mobile/mobile.css +34 -0
- package/esm/components/footer/responsive/Component.responsive.d.ts +6 -0
- package/esm/components/footer/responsive/Component.responsive.js +16 -0
- package/esm/components/header/base-header/index.css +72 -0
- package/esm/components/header/desktop/Component.desktop.d.ts +11 -0
- package/esm/components/header/desktop/Component.desktop.js +35 -0
- package/esm/components/header/desktop/desktop.css +57 -0
- package/esm/components/header/index.d.ts +7 -0
- package/esm/components/header/index.js +3 -0
- package/esm/components/header/mobile/Component.mobile.d.ts +5 -0
- package/esm/components/header/mobile/Component.mobile.js +29 -0
- package/esm/components/header/mobile/mobile.css +59 -0
- package/esm/components/header/responsive/Component.responsive.d.ts +6 -0
- package/esm/components/header/responsive/Component.responsive.js +16 -0
- package/esm/desktop/Component.desktop.d.ts +9 -0
- package/esm/desktop/Component.desktop.js +42 -0
- package/esm/desktop/components/base-universal-modal-content/base-universal-modal-content.css +35 -0
- package/esm/desktop/components/base-universal-modal-content/base-universal-modal-content.d.ts +7 -0
- package/esm/desktop/components/base-universal-modal-content/base-universal-modal-content.js +114 -0
- package/esm/desktop/components/buttons/arrow-button/arrow-button.css +32 -0
- package/esm/desktop/components/buttons/arrow-button/arrow-button.d.ts +6 -0
- package/esm/desktop/components/buttons/arrow-button/arrow-button.js +15 -0
- package/esm/desktop/components/buttons/arrow-button/index.d.ts +1 -0
- package/esm/desktop/components/buttons/arrow-button/index.js +1 -0
- package/esm/desktop/components/buttons/cross-button/cross-button.css +29 -0
- package/esm/desktop/components/buttons/cross-button/cross-button.d.ts +6 -0
- package/esm/desktop/components/buttons/cross-button/cross-button.js +13 -0
- package/esm/desktop/components/buttons/cross-button/index.d.ts +1 -0
- package/esm/desktop/components/buttons/cross-button/index.js +1 -0
- package/esm/desktop/components/center-modal/center-modal.d.ts +4 -0
- package/esm/desktop/components/center-modal/center-modal.js +37 -0
- package/esm/desktop/components/center-modal/index.d.ts +1 -0
- package/esm/desktop/components/center-modal/index.js +1 -0
- package/esm/desktop/components/center-modal/styles/index.css +1085 -0
- package/esm/desktop/components/center-modal/styles/transitions/safari-transitions.css +24 -0
- package/esm/desktop/components/center-modal/styles/transitions/transitions.css +24 -0
- package/esm/desktop/components/side-modal/get-default-transition-props.d.ts +20 -0
- package/esm/desktop/components/side-modal/get-default-transition-props.js +35 -0
- package/esm/desktop/components/side-modal/index.d.ts +1 -0
- package/esm/desktop/components/side-modal/index.js +1 -0
- package/esm/desktop/components/side-modal/side-modal.d.ts +4 -0
- package/esm/desktop/components/side-modal/side-modal.js +42 -0
- package/esm/desktop/components/side-modal/styles/index.css +1088 -0
- package/esm/desktop/components/side-modal/styles/transitions/transitions.css +331 -0
- package/esm/desktop/constants/index.d.ts +3 -0
- package/esm/desktop/constants/index.js +4 -0
- package/esm/desktop/hooks/useModalHeight.d.ts +4 -0
- package/esm/desktop/hooks/useModalHeight.js +29 -0
- package/esm/desktop/hooks/useModalWheel.d.ts +6 -0
- package/esm/desktop/hooks/useModalWheel.js +15 -0
- package/esm/desktop/hooks/useModalWidth.d.ts +4 -0
- package/esm/desktop/hooks/useModalWidth.js +37 -0
- package/esm/desktop/index.d.ts +10 -0
- package/esm/desktop/index.js +13 -0
- package/esm/desktop/styles/transitions/full-size-backdrop-transitions.css +60 -0
- package/esm/desktop/styles/transitions/full-size-vertical-bottom-transitions.css +25 -0
- package/esm/desktop/styles/transitions/full-size-vertical-center-transitions.css +21 -0
- package/esm/desktop/styles/transitions/full-size-vertical-top-transitions.css +25 -0
- package/esm/desktop/types/props.d.ts +45 -0
- package/esm/desktop/types/props.js +1 -0
- package/esm/desktop/utils/get-full-size-modal-transitions.d.ts +16 -0
- package/esm/desktop/utils/get-full-size-modal-transitions.js +51 -0
- package/esm/desktop/utils/get-margins.d.ts +7 -0
- package/esm/desktop/utils/get-margins.js +18 -0
- package/esm/index.d.ts +8 -0
- package/esm/index.js +11 -0
- package/esm/index.module-c4f215c8.js +4 -0
- package/esm/mobile/Component.mobile.d.ts +9 -0
- package/esm/mobile/Component.mobile.js +32 -0
- package/esm/mobile/components/buttons/arrow-button/arrow-button.css +31 -0
- package/esm/mobile/components/buttons/arrow-button/arrow-button.d.ts +6 -0
- package/esm/mobile/components/buttons/arrow-button/arrow-button.js +13 -0
- package/esm/mobile/components/buttons/arrow-button/index.d.ts +1 -0
- package/esm/mobile/components/buttons/arrow-button/index.js +1 -0
- package/esm/mobile/components/buttons/cross-button/cross-button.css +31 -0
- package/esm/mobile/components/buttons/cross-button/cross-button.d.ts +6 -0
- package/esm/mobile/components/buttons/cross-button/cross-button.js +13 -0
- package/esm/mobile/components/buttons/cross-button/index.d.ts +1 -0
- package/esm/mobile/components/buttons/cross-button/index.js +1 -0
- package/esm/mobile/index.d.ts +10 -0
- package/esm/mobile/index.js +14 -0
- package/esm/mobile/mobile.css +39 -0
- package/esm/mobile/transitions/right-side-transitions.mobile.css +38 -0
- package/esm/mobile/transitions/transitions.mobile.css +25 -0
- package/esm/mobile/types/props.d.ts +11 -0
- package/esm/mobile/types/props.js +1 -0
- package/esm/shared/index.d.ts +2 -0
- package/esm/shared/index.js +2 -0
- package/esm/typings/index.d.ts +22 -0
- package/esm/typings/index.js +1 -0
- package/esm/typings/margin-type.d.ts +8 -0
- package/esm/typings/margin-type.js +1 -0
- package/esm/utils/getUniversalModalTestIds.d.ts +8 -0
- package/esm/utils/getUniversalModalTestIds.js +13 -0
- package/index.d.ts +8 -0
- package/index.js +23 -0
- package/index.module-7936578a.js +6 -0
- package/mobile/Component.mobile.d.ts +9 -0
- package/mobile/Component.mobile.js +42 -0
- package/mobile/components/buttons/arrow-button/arrow-button.css +31 -0
- package/mobile/components/buttons/arrow-button/arrow-button.d.ts +6 -0
- package/mobile/components/buttons/arrow-button/arrow-button.js +21 -0
- package/mobile/components/buttons/arrow-button/index.d.ts +1 -0
- package/mobile/components/buttons/arrow-button/index.js +9 -0
- package/mobile/components/buttons/cross-button/cross-button.css +31 -0
- package/mobile/components/buttons/cross-button/cross-button.d.ts +6 -0
- package/mobile/components/buttons/cross-button/cross-button.js +21 -0
- package/mobile/components/buttons/cross-button/index.d.ts +1 -0
- package/mobile/components/buttons/cross-button/index.js +9 -0
- package/mobile/index.d.ts +10 -0
- package/mobile/index.js +28 -0
- package/mobile/mobile.css +39 -0
- package/mobile/package.json +3 -0
- package/mobile/transitions/right-side-transitions.mobile.css +38 -0
- package/mobile/transitions/transitions.mobile.css +25 -0
- package/mobile/types/props.d.ts +11 -0
- package/mobile/types/props.js +2 -0
- package/modern/Component.responsive.d.ts +15 -0
- package/modern/Component.responsive.js +33 -0
- package/modern/Context.d.ts +4 -0
- package/modern/Context.js +5 -0
- package/modern/ResponsiveContext.d.ts +4 -0
- package/modern/ResponsiveContext.js +5 -0
- package/modern/components/content/base-content/base-content.d.ts +17 -0
- package/modern/components/content/base-content/base-content.js +17 -0
- package/modern/components/content/base-content/index.css +44 -0
- package/modern/components/content/desktop/Component.desktop.d.ts +10 -0
- package/modern/components/content/desktop/Component.desktop.js +7 -0
- package/modern/components/content/index.d.ts +7 -0
- package/modern/components/content/index.js +3 -0
- package/modern/components/content/mobile/Component.mobile.d.ts +5 -0
- package/modern/components/content/mobile/Component.mobile.js +10 -0
- package/modern/components/content/mobile/mobile.css +38 -0
- package/modern/components/content/responsive/Component.responsive.d.ts +6 -0
- package/modern/components/content/responsive/Component.responsive.js +14 -0
- package/modern/components/footer/base-footer/base-footer.d.ts +29 -0
- package/modern/components/footer/base-footer/base-footer.js +23 -0
- package/modern/components/footer/base-footer/index.css +48 -0
- package/modern/components/footer/desktop/Component.desktop.d.ts +10 -0
- package/modern/components/footer/desktop/Component.desktop.js +22 -0
- package/modern/components/footer/desktop/desktop.css +30 -0
- package/modern/components/footer/desktop/layout.css +58 -0
- package/modern/components/footer/index.d.ts +7 -0
- package/modern/components/footer/index.js +3 -0
- package/modern/components/footer/mobile/Component.mobile.d.ts +5 -0
- package/modern/components/footer/mobile/Component.mobile.js +19 -0
- package/modern/components/footer/mobile/layout.mobile.css +50 -0
- package/modern/components/footer/mobile/mobile.css +34 -0
- package/modern/components/footer/responsive/Component.responsive.d.ts +6 -0
- package/modern/components/footer/responsive/Component.responsive.js +14 -0
- package/modern/components/header/base-header/index.css +72 -0
- package/modern/components/header/desktop/Component.desktop.d.ts +11 -0
- package/modern/components/header/desktop/Component.desktop.js +32 -0
- package/modern/components/header/desktop/desktop.css +57 -0
- package/modern/components/header/index.d.ts +7 -0
- package/modern/components/header/index.js +3 -0
- package/modern/components/header/mobile/Component.mobile.d.ts +5 -0
- package/modern/components/header/mobile/Component.mobile.js +26 -0
- package/modern/components/header/mobile/mobile.css +59 -0
- package/modern/components/header/responsive/Component.responsive.d.ts +6 -0
- package/modern/components/header/responsive/Component.responsive.js +14 -0
- package/modern/desktop/Component.desktop.d.ts +9 -0
- package/modern/desktop/Component.desktop.js +40 -0
- package/modern/desktop/components/base-universal-modal-content/base-universal-modal-content.css +35 -0
- package/modern/desktop/components/base-universal-modal-content/base-universal-modal-content.d.ts +7 -0
- package/modern/desktop/components/base-universal-modal-content/base-universal-modal-content.js +112 -0
- package/modern/desktop/components/buttons/arrow-button/arrow-button.css +32 -0
- package/modern/desktop/components/buttons/arrow-button/arrow-button.d.ts +6 -0
- package/modern/desktop/components/buttons/arrow-button/arrow-button.js +15 -0
- package/modern/desktop/components/buttons/arrow-button/index.d.ts +1 -0
- package/modern/desktop/components/buttons/arrow-button/index.js +1 -0
- package/modern/desktop/components/buttons/cross-button/cross-button.css +29 -0
- package/modern/desktop/components/buttons/cross-button/cross-button.d.ts +6 -0
- package/modern/desktop/components/buttons/cross-button/cross-button.js +13 -0
- package/modern/desktop/components/buttons/cross-button/index.d.ts +1 -0
- package/modern/desktop/components/buttons/cross-button/index.js +1 -0
- package/modern/desktop/components/center-modal/center-modal.d.ts +4 -0
- package/modern/desktop/components/center-modal/center-modal.js +48 -0
- package/modern/desktop/components/center-modal/index.d.ts +1 -0
- package/modern/desktop/components/center-modal/index.js +1 -0
- package/modern/desktop/components/center-modal/styles/index.css +1085 -0
- package/modern/desktop/components/center-modal/styles/transitions/safari-transitions.css +24 -0
- package/modern/desktop/components/center-modal/styles/transitions/transitions.css +24 -0
- package/modern/desktop/components/side-modal/get-default-transition-props.d.ts +20 -0
- package/modern/desktop/components/side-modal/get-default-transition-props.js +34 -0
- package/modern/desktop/components/side-modal/index.d.ts +1 -0
- package/modern/desktop/components/side-modal/index.js +1 -0
- package/modern/desktop/components/side-modal/side-modal.d.ts +4 -0
- package/modern/desktop/components/side-modal/side-modal.js +51 -0
- package/modern/desktop/components/side-modal/styles/index.css +1088 -0
- package/modern/desktop/components/side-modal/styles/transitions/transitions.css +331 -0
- package/modern/desktop/constants/index.d.ts +3 -0
- package/modern/desktop/constants/index.js +4 -0
- package/modern/desktop/hooks/useModalHeight.d.ts +4 -0
- package/modern/desktop/hooks/useModalHeight.js +29 -0
- package/modern/desktop/hooks/useModalWheel.d.ts +6 -0
- package/modern/desktop/hooks/useModalWheel.js +15 -0
- package/modern/desktop/hooks/useModalWidth.d.ts +4 -0
- package/modern/desktop/hooks/useModalWidth.js +37 -0
- package/modern/desktop/index.d.ts +10 -0
- package/modern/desktop/index.js +12 -0
- package/modern/desktop/styles/transitions/full-size-backdrop-transitions.css +60 -0
- package/modern/desktop/styles/transitions/full-size-vertical-bottom-transitions.css +25 -0
- package/modern/desktop/styles/transitions/full-size-vertical-center-transitions.css +21 -0
- package/modern/desktop/styles/transitions/full-size-vertical-top-transitions.css +25 -0
- package/modern/desktop/types/props.d.ts +45 -0
- package/modern/desktop/types/props.js +1 -0
- package/modern/desktop/utils/get-full-size-modal-transitions.d.ts +16 -0
- package/modern/desktop/utils/get-full-size-modal-transitions.js +51 -0
- package/modern/desktop/utils/get-margins.d.ts +7 -0
- package/modern/desktop/utils/get-margins.js +17 -0
- package/modern/index.d.ts +8 -0
- package/modern/index.js +10 -0
- package/modern/index.module-2718b9b5.js +4 -0
- package/modern/mobile/Component.mobile.d.ts +9 -0
- package/modern/mobile/Component.mobile.js +35 -0
- package/modern/mobile/components/buttons/arrow-button/arrow-button.css +31 -0
- package/modern/mobile/components/buttons/arrow-button/arrow-button.d.ts +6 -0
- package/modern/mobile/components/buttons/arrow-button/arrow-button.js +13 -0
- package/modern/mobile/components/buttons/arrow-button/index.d.ts +1 -0
- package/modern/mobile/components/buttons/arrow-button/index.js +1 -0
- package/modern/mobile/components/buttons/cross-button/cross-button.css +31 -0
- package/modern/mobile/components/buttons/cross-button/cross-button.d.ts +6 -0
- package/modern/mobile/components/buttons/cross-button/cross-button.js +13 -0
- package/modern/mobile/components/buttons/cross-button/index.d.ts +1 -0
- package/modern/mobile/components/buttons/cross-button/index.js +1 -0
- package/modern/mobile/index.d.ts +10 -0
- package/modern/mobile/index.js +13 -0
- package/modern/mobile/mobile.css +39 -0
- package/modern/mobile/transitions/right-side-transitions.mobile.css +38 -0
- package/modern/mobile/transitions/transitions.mobile.css +25 -0
- package/modern/mobile/types/props.d.ts +11 -0
- package/modern/mobile/types/props.js +1 -0
- package/modern/shared/index.d.ts +2 -0
- package/modern/shared/index.js +2 -0
- package/modern/typings/index.d.ts +22 -0
- package/modern/typings/index.js +1 -0
- package/modern/typings/margin-type.d.ts +8 -0
- package/modern/typings/margin-type.js +1 -0
- package/modern/utils/getUniversalModalTestIds.d.ts +8 -0
- package/modern/utils/getUniversalModalTestIds.js +13 -0
- package/moderncssm/Component.responsive.d.ts +15 -0
- package/moderncssm/Component.responsive.js +47 -0
- package/moderncssm/Context.d.ts +4 -0
- package/moderncssm/Context.js +5 -0
- package/moderncssm/ResponsiveContext.d.ts +4 -0
- package/moderncssm/ResponsiveContext.js +5 -0
- package/moderncssm/components/content/base-content/base-content.d.ts +17 -0
- package/moderncssm/components/content/base-content/base-content.js +15 -0
- package/moderncssm/components/content/base-content/index.module.css +26 -0
- package/moderncssm/components/content/desktop/Component.desktop.d.ts +10 -0
- package/moderncssm/components/content/desktop/Component.desktop.js +7 -0
- package/moderncssm/components/content/index.d.ts +7 -0
- package/moderncssm/components/content/index.js +3 -0
- package/moderncssm/components/content/mobile/Component.mobile.d.ts +5 -0
- package/moderncssm/components/content/mobile/Component.mobile.js +8 -0
- package/moderncssm/components/content/mobile/mobile.module.css +18 -0
- package/moderncssm/components/content/responsive/Component.responsive.d.ts +6 -0
- package/moderncssm/components/content/responsive/Component.responsive.js +14 -0
- package/moderncssm/components/footer/base-footer/base-footer.d.ts +29 -0
- package/moderncssm/components/footer/base-footer/base-footer.js +21 -0
- package/moderncssm/components/footer/base-footer/index.module.css +23 -0
- package/moderncssm/components/footer/desktop/Component.desktop.d.ts +10 -0
- package/moderncssm/components/footer/desktop/Component.desktop.js +18 -0
- package/moderncssm/components/footer/desktop/desktop.module.css +10 -0
- package/moderncssm/components/footer/desktop/layout.module.css +42 -0
- package/moderncssm/components/footer/index.d.ts +7 -0
- package/moderncssm/components/footer/index.js +3 -0
- package/moderncssm/components/footer/mobile/Component.mobile.d.ts +5 -0
- package/moderncssm/components/footer/mobile/Component.mobile.js +15 -0
- package/moderncssm/components/footer/mobile/layout.mobile.module.css +37 -0
- package/moderncssm/components/footer/mobile/mobile.module.css +14 -0
- package/moderncssm/components/footer/responsive/Component.responsive.d.ts +6 -0
- package/moderncssm/components/footer/responsive/Component.responsive.js +14 -0
- package/moderncssm/components/header/base-header/index.module.css +71 -0
- package/moderncssm/components/header/desktop/Component.desktop.d.ts +11 -0
- package/moderncssm/components/header/desktop/Component.desktop.js +30 -0
- package/moderncssm/components/header/desktop/desktop.module.css +45 -0
- package/moderncssm/components/header/index.d.ts +7 -0
- package/moderncssm/components/header/index.js +3 -0
- package/moderncssm/components/header/mobile/Component.mobile.d.ts +5 -0
- package/moderncssm/components/header/mobile/Component.mobile.js +24 -0
- package/moderncssm/components/header/mobile/mobile.module.css +31 -0
- package/moderncssm/components/header/responsive/Component.responsive.d.ts +6 -0
- package/moderncssm/components/header/responsive/Component.responsive.js +14 -0
- package/moderncssm/desktop/Component.desktop.d.ts +9 -0
- package/moderncssm/desktop/Component.desktop.js +47 -0
- package/moderncssm/desktop/components/base-universal-modal-content/base-universal-modal-content.d.ts +7 -0
- package/moderncssm/desktop/components/base-universal-modal-content/base-universal-modal-content.js +110 -0
- package/moderncssm/desktop/components/base-universal-modal-content/base-universal-modal-content.module.css +20 -0
- package/moderncssm/desktop/components/buttons/arrow-button/arrow-button.d.ts +6 -0
- package/moderncssm/desktop/components/buttons/arrow-button/arrow-button.js +13 -0
- package/moderncssm/desktop/components/buttons/arrow-button/arrow-button.module.css +8 -0
- package/moderncssm/desktop/components/buttons/arrow-button/index.d.ts +1 -0
- package/moderncssm/desktop/components/buttons/arrow-button/index.js +1 -0
- package/moderncssm/desktop/components/buttons/cross-button/cross-button.d.ts +6 -0
- package/moderncssm/desktop/components/buttons/cross-button/cross-button.js +11 -0
- package/moderncssm/desktop/components/buttons/cross-button/cross-button.module.css +7 -0
- package/moderncssm/desktop/components/buttons/cross-button/index.d.ts +1 -0
- package/moderncssm/desktop/components/buttons/cross-button/index.js +1 -0
- package/moderncssm/desktop/components/center-modal/center-modal.d.ts +4 -0
- package/moderncssm/desktop/components/center-modal/center-modal.js +42 -0
- package/moderncssm/desktop/components/center-modal/index.d.ts +1 -0
- package/moderncssm/desktop/components/center-modal/index.js +1 -0
- package/moderncssm/desktop/components/center-modal/styles/center-modal.module.css +38 -0
- package/moderncssm/desktop/components/center-modal/styles/index.module.css +2110 -0
- package/moderncssm/desktop/components/center-modal/styles/transitions/safari-transitions.module.css +23 -0
- package/moderncssm/desktop/components/center-modal/styles/transitions/transitions.module.css +23 -0
- package/moderncssm/desktop/components/side-modal/get-default-transition-props.d.ts +20 -0
- package/moderncssm/desktop/components/side-modal/get-default-transition-props.js +32 -0
- package/moderncssm/desktop/components/side-modal/index.d.ts +1 -0
- package/moderncssm/desktop/components/side-modal/index.js +1 -0
- package/moderncssm/desktop/components/side-modal/side-modal.d.ts +4 -0
- package/moderncssm/desktop/components/side-modal/side-modal.js +49 -0
- package/moderncssm/desktop/components/side-modal/styles/index.module.css +2117 -0
- package/moderncssm/desktop/components/side-modal/styles/side-modal.module.css +45 -0
- package/moderncssm/desktop/components/side-modal/styles/transitions/transitions.module.css +330 -0
- package/moderncssm/desktop/constants/index.d.ts +3 -0
- package/moderncssm/desktop/constants/index.js +4 -0
- package/moderncssm/desktop/hooks/useModalHeight.d.ts +4 -0
- package/moderncssm/desktop/hooks/useModalHeight.js +29 -0
- package/moderncssm/desktop/hooks/useModalWheel.d.ts +6 -0
- package/moderncssm/desktop/hooks/useModalWheel.js +15 -0
- package/moderncssm/desktop/hooks/useModalWidth.d.ts +4 -0
- package/moderncssm/desktop/hooks/useModalWidth.js +37 -0
- package/moderncssm/desktop/index.d.ts +10 -0
- package/moderncssm/desktop/index.js +19 -0
- package/moderncssm/desktop/styles/margins.module.css +1552 -0
- package/moderncssm/desktop/styles/transitions/full-size-backdrop-transitions.module.css +52 -0
- package/moderncssm/desktop/styles/transitions/full-size-vertical-bottom-transitions.module.css +24 -0
- package/moderncssm/desktop/styles/transitions/full-size-vertical-center-transitions.module.css +20 -0
- package/moderncssm/desktop/styles/transitions/full-size-vertical-top-transitions.module.css +24 -0
- package/moderncssm/desktop/types/props.d.ts +45 -0
- package/moderncssm/desktop/types/props.js +1 -0
- package/moderncssm/desktop/utils/get-full-size-modal-transitions.d.ts +16 -0
- package/moderncssm/desktop/utils/get-full-size-modal-transitions.js +43 -0
- package/moderncssm/desktop/utils/get-margins.d.ts +7 -0
- package/moderncssm/desktop/utils/get-margins.js +17 -0
- package/moderncssm/desktop/vars.css +2 -0
- package/moderncssm/index.d.ts +8 -0
- package/moderncssm/index.js +20 -0
- package/moderncssm/mobile/Component.mobile.d.ts +9 -0
- package/moderncssm/mobile/Component.mobile.js +35 -0
- package/moderncssm/mobile/components/buttons/arrow-button/arrow-button.d.ts +6 -0
- package/moderncssm/mobile/components/buttons/arrow-button/arrow-button.js +11 -0
- package/moderncssm/mobile/components/buttons/arrow-button/arrow-button.module.css +11 -0
- package/moderncssm/mobile/components/buttons/arrow-button/index.d.ts +1 -0
- package/moderncssm/mobile/components/buttons/arrow-button/index.js +1 -0
- package/moderncssm/mobile/components/buttons/cross-button/cross-button.d.ts +6 -0
- package/moderncssm/mobile/components/buttons/cross-button/cross-button.js +11 -0
- package/moderncssm/mobile/components/buttons/cross-button/cross-button.module.css +11 -0
- package/moderncssm/mobile/components/buttons/cross-button/index.d.ts +1 -0
- package/moderncssm/mobile/components/buttons/cross-button/index.js +1 -0
- package/moderncssm/mobile/index.d.ts +10 -0
- package/moderncssm/mobile/index.js +19 -0
- package/moderncssm/mobile/mobile.module.css +21 -0
- package/moderncssm/mobile/transitions/right-side-transitions.mobile.module.css +23 -0
- package/moderncssm/mobile/transitions/transitions.mobile.module.css +24 -0
- package/moderncssm/mobile/types/props.d.ts +11 -0
- package/moderncssm/mobile/types/props.js +1 -0
- package/moderncssm/mobile/vars.css +2 -0
- package/moderncssm/shared/index.d.ts +2 -0
- package/moderncssm/shared/index.js +2 -0
- package/moderncssm/typings/index.d.ts +22 -0
- package/moderncssm/typings/index.js +1 -0
- package/moderncssm/typings/margin-type.d.ts +8 -0
- package/moderncssm/typings/margin-type.js +1 -0
- package/moderncssm/utils/getUniversalModalTestIds.d.ts +8 -0
- package/moderncssm/utils/getUniversalModalTestIds.js +13 -0
- package/moderncssm/vars.css +6 -0
- package/package.json +32 -0
- package/shared/index.d.ts +2 -0
- package/shared/index.js +11 -0
- package/shared/package.json +3 -0
- package/src/Component.responsive.tsx +32 -0
- package/src/Context.tsx +3 -0
- package/src/ResponsiveContext.ts +5 -0
- package/src/components/content/base-content/base-content.tsx +42 -0
- package/src/components/content/base-content/index.module.css +21 -0
- package/src/components/content/desktop/Component.desktop.tsx +15 -0
- package/src/components/content/index.ts +8 -0
- package/src/components/content/mobile/Component.mobile.tsx +12 -0
- package/src/components/content/mobile/mobile.module.css +13 -0
- package/src/components/content/responsive/Component.responsive.tsx +18 -0
- package/src/components/footer/base-footer/base-footer.tsx +71 -0
- package/src/components/footer/base-footer/index.module.css +20 -0
- package/src/components/footer/desktop/Component.desktop.tsx +39 -0
- package/src/components/footer/desktop/desktop.module.css +5 -0
- package/src/components/footer/desktop/layout.module.css +34 -0
- package/src/components/footer/index.ts +8 -0
- package/src/components/footer/mobile/Component.mobile.tsx +31 -0
- package/src/components/footer/mobile/layout.mobile.module.css +30 -0
- package/src/components/footer/mobile/mobile.module.css +9 -0
- package/src/components/footer/responsive/Component.responsive.tsx +18 -0
- package/src/components/header/base-header/index.module.css +64 -0
- package/src/components/header/desktop/Component.desktop.tsx +77 -0
- package/src/components/header/desktop/desktop.module.css +32 -0
- package/src/components/header/index.ts +8 -0
- package/src/components/header/mobile/Component.mobile.tsx +59 -0
- package/src/components/header/mobile/mobile.module.css +29 -0
- package/src/components/header/responsive/Component.responsive.tsx +18 -0
- package/src/desktop/Component.desktop.tsx +60 -0
- package/src/desktop/components/base-universal-modal-content/base-universal-modal-content.module.css +20 -0
- package/src/desktop/components/base-universal-modal-content/base-universal-modal-content.tsx +155 -0
- package/src/desktop/components/buttons/arrow-button/arrow-button.module.css +7 -0
- package/src/desktop/components/buttons/arrow-button/arrow-button.tsx +29 -0
- package/src/desktop/components/buttons/arrow-button/index.ts +1 -0
- package/src/desktop/components/buttons/cross-button/cross-button.module.css +6 -0
- package/src/desktop/components/buttons/cross-button/cross-button.tsx +24 -0
- package/src/desktop/components/buttons/cross-button/index.ts +1 -0
- package/src/desktop/components/center-modal/center-modal.tsx +84 -0
- package/src/desktop/components/center-modal/index.ts +1 -0
- package/src/desktop/components/center-modal/styles/center-modal.module.css +33 -0
- package/src/desktop/components/center-modal/styles/index.module.css +2 -0
- package/src/desktop/components/center-modal/styles/transitions/safari-transitions.module.css +23 -0
- package/src/desktop/components/center-modal/styles/transitions/transitions.module.css +23 -0
- package/src/desktop/components/side-modal/get-default-transition-props.ts +41 -0
- package/src/desktop/components/side-modal/index.ts +1 -0
- package/src/desktop/components/side-modal/side-modal.tsx +95 -0
- package/src/desktop/components/side-modal/styles/index.module.css +2 -0
- package/src/desktop/components/side-modal/styles/side-modal.module.css +45 -0
- package/src/desktop/components/side-modal/styles/transitions/transitions.module.css +46 -0
- package/src/desktop/constants/index.ts +2 -0
- package/src/desktop/hooks/useModalHeight.tsx +42 -0
- package/src/desktop/hooks/useModalWheel.tsx +16 -0
- package/src/desktop/hooks/useModalWidth.tsx +52 -0
- package/src/desktop/index.ts +14 -0
- package/src/desktop/package.json +3 -0
- package/src/desktop/styles/margins.module.css +27 -0
- package/src/desktop/styles/transitions/full-size-backdrop-transitions.module.css +52 -0
- package/src/desktop/styles/transitions/full-size-vertical-bottom-transitions.module.css +24 -0
- package/src/desktop/styles/transitions/full-size-vertical-center-transitions.module.css +20 -0
- package/src/desktop/styles/transitions/full-size-vertical-top-transitions.module.css +24 -0
- package/src/desktop/types/props.ts +66 -0
- package/src/desktop/utils/get-full-size-modal-transitions.ts +64 -0
- package/src/desktop/utils/get-margins.ts +24 -0
- package/src/desktop/vars.css +6 -0
- package/src/index.ts +11 -0
- package/src/mobile/Component.mobile.tsx +44 -0
- package/src/mobile/components/buttons/arrow-button/arrow-button.module.css +11 -0
- package/src/mobile/components/buttons/arrow-button/arrow-button.tsx +24 -0
- package/src/mobile/components/buttons/arrow-button/index.ts +1 -0
- package/src/mobile/components/buttons/cross-button/cross-button.module.css +11 -0
- package/src/mobile/components/buttons/cross-button/cross-button.tsx +24 -0
- package/src/mobile/components/buttons/cross-button/index.ts +1 -0
- package/src/mobile/index.ts +14 -0
- package/src/mobile/mobile.module.css +21 -0
- package/src/mobile/package.json +3 -0
- package/src/mobile/transitions/right-side-transitions.mobile.module.css +23 -0
- package/src/mobile/transitions/transitions.mobile.module.css +24 -0
- package/src/mobile/types/props.ts +23 -0
- package/src/mobile/vars.css +8 -0
- package/src/shared/index.ts +2 -0
- package/src/shared/package.json +3 -0
- package/src/typings/index.ts +25 -0
- package/src/typings/margin-type.ts +8 -0
- package/src/utils/getUniversalModalTestIds.ts +11 -0
- package/src/vars.css +12 -0
- package/typings/index.d.ts +22 -0
- package/typings/index.js +2 -0
- package/typings/margin-type.d.ts +8 -0
- package/typings/margin-type.js +2 -0
- package/utils/getUniversalModalTestIds.d.ts +8 -0
- package/utils/getUniversalModalTestIds.js +17 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { SideModal } from './side-modal';
|
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
import React, { forwardRef, useRef } from 'react';
|
|
2
|
+
import cn from 'classnames';
|
|
3
|
+
|
|
4
|
+
import { BaseModal } from '@alfalab/core-components-base-modal';
|
|
5
|
+
|
|
6
|
+
import { useModalHeight } from '../../hooks/useModalHeight';
|
|
7
|
+
import { useModalWheel } from '../../hooks/useModalWheel';
|
|
8
|
+
import { useModalWidth } from '../../hooks/useModalWidth';
|
|
9
|
+
import { ModalBySideProps } from '../../types/props';
|
|
10
|
+
import { getFullSizeModalTransitions } from '../../utils/get-full-size-modal-transitions';
|
|
11
|
+
import { getMargins } from '../../utils/get-margins';
|
|
12
|
+
import { BaseUniversalModalContent } from '../base-universal-modal-content/base-universal-modal-content';
|
|
13
|
+
|
|
14
|
+
import { getDefaultTransitionProps } from './get-default-transition-props';
|
|
15
|
+
|
|
16
|
+
import styles from './styles/index.module.css';
|
|
17
|
+
|
|
18
|
+
export const SideModal = forwardRef<HTMLDivElement, ModalBySideProps>((props, ref) => {
|
|
19
|
+
const {
|
|
20
|
+
width = 500,
|
|
21
|
+
height = 'fullHeight',
|
|
22
|
+
horizontalAlign = 'center',
|
|
23
|
+
verticalAlign = 'center',
|
|
24
|
+
overlay = true,
|
|
25
|
+
open,
|
|
26
|
+
dataTestId,
|
|
27
|
+
className,
|
|
28
|
+
children,
|
|
29
|
+
margin,
|
|
30
|
+
onClose,
|
|
31
|
+
...restProps
|
|
32
|
+
} = props;
|
|
33
|
+
const componentRef = useRef<HTMLDivElement>(null);
|
|
34
|
+
const contentRef = useRef<HTMLDivElement>(null);
|
|
35
|
+
|
|
36
|
+
useModalWidth(width, open, componentRef);
|
|
37
|
+
useModalHeight(height, open, componentRef);
|
|
38
|
+
const { wheelDeltaY, handleWheel } = useModalWheel(overlay);
|
|
39
|
+
|
|
40
|
+
const isHorizontalStart = horizontalAlign === 'start';
|
|
41
|
+
const isHorizontalEnd = horizontalAlign === 'end';
|
|
42
|
+
const isVerticalCenter = verticalAlign === 'center';
|
|
43
|
+
const isVerticalBottom = verticalAlign === 'bottom';
|
|
44
|
+
|
|
45
|
+
const {
|
|
46
|
+
isFullSizeModal,
|
|
47
|
+
componentTransitions: fullSizeModalContentTransitions,
|
|
48
|
+
backdropTransitions: fullSizeModalBackdropTransitions,
|
|
49
|
+
} = getFullSizeModalTransitions({ verticalAlign, width, height });
|
|
50
|
+
|
|
51
|
+
return (
|
|
52
|
+
<BaseModal
|
|
53
|
+
{...restProps}
|
|
54
|
+
open={open}
|
|
55
|
+
dataTestId={dataTestId}
|
|
56
|
+
ref={ref}
|
|
57
|
+
componentRef={componentRef}
|
|
58
|
+
contentElementRef={contentRef}
|
|
59
|
+
scrollHandler='content'
|
|
60
|
+
disableBlockingScroll={!overlay}
|
|
61
|
+
wrapperClassName={cn(styles.wrapper, {
|
|
62
|
+
[styles.wrapperAlignStart]: isHorizontalStart,
|
|
63
|
+
[styles.wrapperAlignEnd]: isHorizontalEnd,
|
|
64
|
+
[styles.wrapperJustifyCenter]: isVerticalCenter,
|
|
65
|
+
[styles.wrapperJustifyEnd]: isVerticalBottom,
|
|
66
|
+
})}
|
|
67
|
+
className={cn(styles.component, className, {
|
|
68
|
+
[styles.overlayHidden]: !overlay,
|
|
69
|
+
...getMargins({ styles, margin }),
|
|
70
|
+
})}
|
|
71
|
+
contentClassName={styles.content}
|
|
72
|
+
transitionProps={{
|
|
73
|
+
...getDefaultTransitionProps({
|
|
74
|
+
horizontalAlign,
|
|
75
|
+
margin,
|
|
76
|
+
}),
|
|
77
|
+
...(isFullSizeModal && fullSizeModalContentTransitions),
|
|
78
|
+
...restProps.transitionProps,
|
|
79
|
+
}}
|
|
80
|
+
backdropProps={{
|
|
81
|
+
transparent: !overlay,
|
|
82
|
+
...(isFullSizeModal && fullSizeModalBackdropTransitions),
|
|
83
|
+
...restProps.backdropProps,
|
|
84
|
+
}}
|
|
85
|
+
onWheel={handleWheel}
|
|
86
|
+
onClose={onClose}
|
|
87
|
+
>
|
|
88
|
+
<div className={styles.container}>
|
|
89
|
+
<BaseUniversalModalContent wheelDeltaY={wheelDeltaY}>
|
|
90
|
+
{children}
|
|
91
|
+
</BaseUniversalModalContent>
|
|
92
|
+
</div>
|
|
93
|
+
</BaseModal>
|
|
94
|
+
);
|
|
95
|
+
});
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
@import '@alfalab/core-components-vars/src/index.css';
|
|
2
|
+
|
|
3
|
+
.wrapper {
|
|
4
|
+
overflow-x: hidden;
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
.wrapperAlignStart {
|
|
8
|
+
align-items: start;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
.wrapperAlignEnd {
|
|
12
|
+
align-items: end;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
.wrapperJustifyCenter {
|
|
16
|
+
justify-content: center;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
.wrapperJustifyEnd {
|
|
20
|
+
justify-content: end;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
.component {
|
|
24
|
+
min-width: 500px;
|
|
25
|
+
min-height: 264px;
|
|
26
|
+
height: 100%;
|
|
27
|
+
border-radius: var(--border-radius-24);
|
|
28
|
+
overflow-x: hidden;
|
|
29
|
+
margin: unset;
|
|
30
|
+
|
|
31
|
+
/*
|
|
32
|
+
Применяем аппаратное ускорение с помощью will-change и backface-visibility
|
|
33
|
+
Также в классах анимации добавлен translateZ(0)
|
|
34
|
+
*/
|
|
35
|
+
will-change: transform;
|
|
36
|
+
backface-visibility: hidden;
|
|
37
|
+
|
|
38
|
+
&.overlayHidden {
|
|
39
|
+
box-shadow: var(--shadow-m);
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
& .container {
|
|
43
|
+
height: 100%;
|
|
44
|
+
}
|
|
45
|
+
}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
:root {
|
|
2
|
+
--universal-modal-transitions-timeout: 200ms;
|
|
3
|
+
}
|
|
4
|
+
|
|
5
|
+
/* prettier-ignore */
|
|
6
|
+
@each $size in 0, 2, 4, 8, 12, 16, 20, 24, 32, 40, 48, 56, 64, 72, 80, 96, 128 {
|
|
7
|
+
.enterLeft-$(size) {
|
|
8
|
+
transform: translateX(calc(-100% - $(size)px)) translateZ(0);
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
/* prettier-ignore */
|
|
13
|
+
@each $size in 0, 2, 4, 8, 12, 16, 20, 24, 32, 40, 48, 56, 64, 72, 80, 96, 128 {
|
|
14
|
+
.enterRight-$(size) {
|
|
15
|
+
transform: translateX(calc(100% + $(size)px)) translateZ(0);
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
.enterActive {
|
|
20
|
+
transform: translateX(0);
|
|
21
|
+
transition: transform var(--universal-modal-transitions-timeout) ease-in;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
.enterDone {
|
|
25
|
+
transform: translateX(0);
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
.exit {
|
|
29
|
+
transform: translateX(0);
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
/* prettier-ignore */
|
|
33
|
+
@each $size in 0, 2, 4, 8, 12, 16, 20, 24, 32, 40, 48, 56, 64, 72, 80, 96, 128 {
|
|
34
|
+
.exitActiveLeft-$(size) {
|
|
35
|
+
transform: translateX(calc(-100% - $(size)px)) translateZ(0);
|
|
36
|
+
transition: transform var(--universal-modal-transitions-timeout) ease-out;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
/* prettier-ignore */
|
|
41
|
+
@each $size in 0, 2, 4, 8, 12, 16, 20, 24, 32, 40, 48, 56, 64, 72, 80, 96, 128 {
|
|
42
|
+
.exitActiveRight-$(size) {
|
|
43
|
+
transform: translateX(calc(100% + $(size)px)) translateZ(0);
|
|
44
|
+
transition: transform var(--universal-modal-transitions-timeout) ease-out;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { MutableRefObject, useEffect } from 'react';
|
|
2
|
+
|
|
3
|
+
import { isClient } from '@alfalab/core-components-shared';
|
|
4
|
+
|
|
5
|
+
/** Устанавливает необходимую высоту модального окна */
|
|
6
|
+
export const useModalHeight = (
|
|
7
|
+
height: number | 'fullHeight',
|
|
8
|
+
open: boolean,
|
|
9
|
+
componentRef: MutableRefObject<HTMLDivElement | null>,
|
|
10
|
+
) => {
|
|
11
|
+
const ref = componentRef;
|
|
12
|
+
|
|
13
|
+
useEffect(() => {
|
|
14
|
+
if (ref.current) {
|
|
15
|
+
let viewportHeight = 0;
|
|
16
|
+
let computedMarginTop = 0;
|
|
17
|
+
let computedMarginBottom = 0;
|
|
18
|
+
|
|
19
|
+
if (isClient()) {
|
|
20
|
+
viewportHeight = Math.max(
|
|
21
|
+
document.documentElement.clientHeight || 0,
|
|
22
|
+
window.innerHeight || 0,
|
|
23
|
+
);
|
|
24
|
+
// рассчитываем margin'ы для дальнейшего вычитания из высоты viewport'а
|
|
25
|
+
computedMarginTop = parseFloat(window.getComputedStyle(ref.current).marginTop);
|
|
26
|
+
computedMarginBottom = parseFloat(
|
|
27
|
+
window.getComputedStyle(ref.current).marginBottom,
|
|
28
|
+
);
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
if (height > viewportHeight || height === 'fullHeight') {
|
|
32
|
+
ref.current.style.height = `calc(100% - ${computedMarginTop}px - ${computedMarginBottom}px)`;
|
|
33
|
+
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
if (!Number.isNaN(parseFloat(String(height)))) {
|
|
38
|
+
ref.current.style.height = `${parseFloat(String(height))}px`;
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
}, [open, height, ref]);
|
|
42
|
+
};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { useState, WheelEvent } from 'react';
|
|
2
|
+
|
|
3
|
+
export const useModalWheel = (overlay: boolean) => {
|
|
4
|
+
const [wheelDeltaY, setWheelDeltaY] = useState<number>(0);
|
|
5
|
+
|
|
6
|
+
// передаем e.deltaY от события на элементе dialog компонента base-modal
|
|
7
|
+
const handleWheel = (e: WheelEvent<HTMLElement>) => {
|
|
8
|
+
const target = e.target as HTMLDivElement;
|
|
9
|
+
|
|
10
|
+
if (target.getAttribute('role') === 'dialog' && overlay) {
|
|
11
|
+
setWheelDeltaY(e.deltaY);
|
|
12
|
+
}
|
|
13
|
+
};
|
|
14
|
+
|
|
15
|
+
return { wheelDeltaY, handleWheel };
|
|
16
|
+
};
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import { MutableRefObject, useContext, useEffect } from 'react';
|
|
2
|
+
|
|
3
|
+
import { isClient } from '@alfalab/core-components-shared';
|
|
4
|
+
|
|
5
|
+
import { ResponsiveContext } from '../../ResponsiveContext';
|
|
6
|
+
|
|
7
|
+
/** Устанавливает необходимую ширину модального окна */
|
|
8
|
+
export const useModalWidth = (
|
|
9
|
+
width: number | 'fullWidth',
|
|
10
|
+
open: boolean,
|
|
11
|
+
componentRef: MutableRefObject<HTMLDivElement | null>,
|
|
12
|
+
) => {
|
|
13
|
+
const ref = componentRef;
|
|
14
|
+
const context = useContext(ResponsiveContext);
|
|
15
|
+
const { setModalWidth } = context || {};
|
|
16
|
+
|
|
17
|
+
useEffect(() => {
|
|
18
|
+
if (ref.current) {
|
|
19
|
+
let viewportWidth = 0;
|
|
20
|
+
let computedMarginLeft = 0;
|
|
21
|
+
let computedMarginRight = 0;
|
|
22
|
+
|
|
23
|
+
if (isClient()) {
|
|
24
|
+
viewportWidth = Math.max(
|
|
25
|
+
document.documentElement.clientWidth || 0,
|
|
26
|
+
window.innerWidth || 0,
|
|
27
|
+
);
|
|
28
|
+
|
|
29
|
+
computedMarginLeft = parseFloat(window.getComputedStyle(ref.current).marginLeft);
|
|
30
|
+
computedMarginRight = parseFloat(window.getComputedStyle(ref.current).marginRight);
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
if (width > viewportWidth || width === 'fullWidth') {
|
|
34
|
+
ref.current.style.width = `calc(100% - ${computedMarginLeft}px - ${computedMarginRight}px)`;
|
|
35
|
+
|
|
36
|
+
if (setModalWidth) {
|
|
37
|
+
setModalWidth(viewportWidth - computedMarginLeft - computedMarginRight);
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
return;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
if (!Number.isNaN(parseFloat(String(width)))) {
|
|
44
|
+
ref.current.style.width = `${parseFloat(String(width))}px`;
|
|
45
|
+
|
|
46
|
+
if (setModalWidth) {
|
|
47
|
+
setModalWidth(width);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
}, [open, width, ref, setModalWidth, context]);
|
|
52
|
+
};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export { UniversalModalDesktop, UniversalModalDesktopComponent } from './Component.desktop';
|
|
2
|
+
export type { UniversalModalDesktopProps } from './types/props';
|
|
3
|
+
|
|
4
|
+
export { HeaderDesktop } from '../components/header';
|
|
5
|
+
export type { HeaderDesktopProps } from '../components/header';
|
|
6
|
+
|
|
7
|
+
export { FooterDesktop } from '../components/footer';
|
|
8
|
+
export type { FooterDesktopProps } from '../components/footer';
|
|
9
|
+
|
|
10
|
+
export { ContentDesktop } from '../components/content';
|
|
11
|
+
export type { ContentDesktopProps } from '../components/content';
|
|
12
|
+
|
|
13
|
+
export { CrossButtonDesktop } from './components/buttons/cross-button';
|
|
14
|
+
export { ArrowButtonDesktop } from './components/buttons/arrow-button';
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
/* prettier-ignore */
|
|
2
|
+
@for $i from 0 to 128 {
|
|
3
|
+
.marginTop-$(i) {
|
|
4
|
+
margin-top: $(i)px;
|
|
5
|
+
}
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
/* prettier-ignore */
|
|
9
|
+
@for $i from 0 to 128 {
|
|
10
|
+
.marginRight-$(i) {
|
|
11
|
+
margin-right: $(i)px;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
/* prettier-ignore */
|
|
16
|
+
@for $i from 0 to 128 {
|
|
17
|
+
.marginBottom-$(i) {
|
|
18
|
+
margin-bottom: $(i)px;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
/* prettier-ignore */
|
|
23
|
+
@for $i from 0 to 128 {
|
|
24
|
+
.marginLeft-$(i) {
|
|
25
|
+
margin-left: $(i)px;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
@import '@alfalab/core-components-vars/src/index.css';
|
|
2
|
+
|
|
3
|
+
:root {
|
|
4
|
+
--universal-modal-backdrop-visible-background: var(--color-light-overlay-default);
|
|
5
|
+
--universal-modal-backdrop-hidden-background: transparent;
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
@keyframes step_1 {
|
|
9
|
+
0% {
|
|
10
|
+
opacity: 1;
|
|
11
|
+
}
|
|
12
|
+
100% {
|
|
13
|
+
opacity: 0.5;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
@keyframes step_2 {
|
|
18
|
+
0% {
|
|
19
|
+
opacity: 0.5;
|
|
20
|
+
}
|
|
21
|
+
100% {
|
|
22
|
+
opacity: 0;
|
|
23
|
+
background-color: var(--universal-modal-backdrop-hidden-background);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
.appear,
|
|
28
|
+
.enter {
|
|
29
|
+
background-color: var(--universal-modal-backdrop-hidden-background);
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
.appearActive,
|
|
33
|
+
.enterActive,
|
|
34
|
+
.appearDone,
|
|
35
|
+
.enterDone {
|
|
36
|
+
background-color: var(--universal-modal-backdrop-visible-background);
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
.exit {
|
|
40
|
+
background-color: var(--universal-modal-backdrop-visible-background);
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
.exitActive {
|
|
44
|
+
opacity: 1;
|
|
45
|
+
animation: step_1 200ms cubic-bezier(0, 0, 1, 0),
|
|
46
|
+
step_2 200ms cubic-bezier(0, 0, 0, 1) 200ms forwards;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
.exitDone {
|
|
50
|
+
opacity: 0;
|
|
51
|
+
background-color: var(--universal-modal-backdrop-hidden-background);
|
|
52
|
+
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
.appear,
|
|
2
|
+
.enter {
|
|
3
|
+
opacity: 0;
|
|
4
|
+
transform: translateY(40px);
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
.appearActive,
|
|
8
|
+
.enterActive {
|
|
9
|
+
opacity: 1;
|
|
10
|
+
transform: translateY(0);
|
|
11
|
+
transition: opacity 200ms cubic-bezier(0, 0, 0, 1), transform 200ms cubic-bezier(0, 0, 0, 1);
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
.exit {
|
|
15
|
+
opacity: 1;
|
|
16
|
+
transform: translateY(0);
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
.exitActive,
|
|
20
|
+
.exitDone {
|
|
21
|
+
opacity: 0;
|
|
22
|
+
transform: translateY(40px);
|
|
23
|
+
transition: opacity 200ms cubic-bezier(0, 0, 1, 0), transform 200ms cubic-bezier(0, 0, 1, 0);
|
|
24
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
.appear,
|
|
2
|
+
.enter {
|
|
3
|
+
opacity: 0;
|
|
4
|
+
}
|
|
5
|
+
|
|
6
|
+
.appearActive,
|
|
7
|
+
.enterActive {
|
|
8
|
+
opacity: 1;
|
|
9
|
+
transition: opacity 200ms cubic-bezier(0, 0, 0, 1);
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
.exit {
|
|
13
|
+
opacity: 1;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
.exitActive,
|
|
17
|
+
.exitDone {
|
|
18
|
+
opacity: 0;
|
|
19
|
+
transition: opacity 200ms cubic-bezier(0, 0, 1, 0);
|
|
20
|
+
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
.appear,
|
|
2
|
+
.enter {
|
|
3
|
+
opacity: 0;
|
|
4
|
+
transform: translateY(-40px);
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
.appearActive,
|
|
8
|
+
.enterActive {
|
|
9
|
+
opacity: 1;
|
|
10
|
+
transform: translateY(0);
|
|
11
|
+
transition: opacity 200ms cubic-bezier(0, 0, 0, 1), transform 200ms cubic-bezier(0, 0, 0, 1);
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
.exit {
|
|
15
|
+
opacity: 1;
|
|
16
|
+
transform: translateY(0);
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
.exitActive,
|
|
20
|
+
.exitDone {
|
|
21
|
+
opacity: 0;
|
|
22
|
+
transform: translateY(-40px);
|
|
23
|
+
transition: opacity 200ms cubic-bezier(0, 0, 1, 0), transform 200ms cubic-bezier(0, 0, 1, 0);
|
|
24
|
+
}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { BaseModalProps } from '@alfalab/core-components-base-modal';
|
|
2
|
+
|
|
3
|
+
import { TMargin } from '../../typings/margin-type';
|
|
4
|
+
|
|
5
|
+
export type BaseUniversalModalProps = {
|
|
6
|
+
/**
|
|
7
|
+
* Расположение по горизонтали и сторона с которой модал “выезжает” при открытии
|
|
8
|
+
* @default center
|
|
9
|
+
*/
|
|
10
|
+
horizontalAlign?: 'start' | 'center' | 'end';
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* Расположение модального окна по вертикали
|
|
14
|
+
* @default center
|
|
15
|
+
*/
|
|
16
|
+
verticalAlign?: 'top' | 'center' | 'bottom';
|
|
17
|
+
|
|
18
|
+
/**
|
|
19
|
+
* Ширина модального окна
|
|
20
|
+
* fullWidth - ширина модального окна подстроится под viewport
|
|
21
|
+
* minWidth - 500
|
|
22
|
+
* @default 500
|
|
23
|
+
*/
|
|
24
|
+
width?: number | 'fullWidth';
|
|
25
|
+
|
|
26
|
+
/**
|
|
27
|
+
* Высота модального окна
|
|
28
|
+
* fullHeight - высота модального окна подстроится под viewport
|
|
29
|
+
* minHeight - 264
|
|
30
|
+
* @default fullHeight
|
|
31
|
+
*/
|
|
32
|
+
height?: number | 'fullHeight';
|
|
33
|
+
|
|
34
|
+
/**
|
|
35
|
+
* Наличие оверлея
|
|
36
|
+
* @default true
|
|
37
|
+
*/
|
|
38
|
+
overlay?: boolean;
|
|
39
|
+
|
|
40
|
+
/**
|
|
41
|
+
* Устанавливает отступы модального окна
|
|
42
|
+
*/
|
|
43
|
+
margin?: TMargin;
|
|
44
|
+
|
|
45
|
+
/**
|
|
46
|
+
* Хэндлер закрытия модалки
|
|
47
|
+
*/
|
|
48
|
+
onClose?: () => void;
|
|
49
|
+
};
|
|
50
|
+
|
|
51
|
+
export type UniversalModalDesktopProps = BaseUniversalModalProps &
|
|
52
|
+
Pick<
|
|
53
|
+
BaseModalProps,
|
|
54
|
+
| 'children'
|
|
55
|
+
| 'dataTestId'
|
|
56
|
+
| 'open'
|
|
57
|
+
| 'className'
|
|
58
|
+
| 'wrapperClassName'
|
|
59
|
+
| 'onUnmount'
|
|
60
|
+
| 'transitionProps'
|
|
61
|
+
| 'backdropProps'
|
|
62
|
+
>;
|
|
63
|
+
|
|
64
|
+
export type ModalBySideProps = UniversalModalDesktopProps;
|
|
65
|
+
|
|
66
|
+
export type ModalByCenterProps = UniversalModalDesktopProps;
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { TransitionProps } from 'react-transition-group/Transition';
|
|
2
|
+
|
|
3
|
+
import { BackdropProps } from '@alfalab/core-components-backdrop';
|
|
4
|
+
import { exhaustiveCheck } from '@alfalab/core-components-shared';
|
|
5
|
+
|
|
6
|
+
import { UniversalModalDesktopProps } from '../types/props';
|
|
7
|
+
|
|
8
|
+
import fullSizeBackdropTransitions from '../styles/transitions/full-size-backdrop-transitions.module.css';
|
|
9
|
+
import fullSizeVerticalBottomTransitions from '../styles/transitions/full-size-vertical-bottom-transitions.module.css';
|
|
10
|
+
import fullSizeVerticalCenterTransitions from '../styles/transitions/full-size-vertical-center-transitions.module.css';
|
|
11
|
+
import fullSizeVerticalTopTransitions from '../styles/transitions/full-size-vertical-top-transitions.module.css';
|
|
12
|
+
|
|
13
|
+
type Params = {
|
|
14
|
+
verticalAlign: Exclude<UniversalModalDesktopProps['verticalAlign'], undefined>;
|
|
15
|
+
width: UniversalModalDesktopProps['width'];
|
|
16
|
+
height: UniversalModalDesktopProps['height'];
|
|
17
|
+
};
|
|
18
|
+
|
|
19
|
+
type ReturnType = {
|
|
20
|
+
isFullSizeModal: boolean;
|
|
21
|
+
backdropTransitions: Partial<BackdropProps>;
|
|
22
|
+
componentTransitions: Partial<TransitionProps>;
|
|
23
|
+
};
|
|
24
|
+
|
|
25
|
+
export const getFullSizeModalTransitions = (params: Params): ReturnType => {
|
|
26
|
+
const { verticalAlign, width, height } = params;
|
|
27
|
+
|
|
28
|
+
const isFullSizeModal = width === 'fullWidth' && height === 'fullHeight';
|
|
29
|
+
|
|
30
|
+
const backdropTransitions = {
|
|
31
|
+
timeout: {
|
|
32
|
+
enter: 0,
|
|
33
|
+
exit: 400,
|
|
34
|
+
},
|
|
35
|
+
transitionClassNames: fullSizeBackdropTransitions,
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
const getContentTransitionsClassNames = () => {
|
|
39
|
+
switch (verticalAlign) {
|
|
40
|
+
case 'top':
|
|
41
|
+
return fullSizeVerticalTopTransitions;
|
|
42
|
+
case 'bottom':
|
|
43
|
+
return fullSizeVerticalBottomTransitions;
|
|
44
|
+
case 'center':
|
|
45
|
+
return fullSizeVerticalCenterTransitions;
|
|
46
|
+
default:
|
|
47
|
+
return exhaustiveCheck(verticalAlign);
|
|
48
|
+
}
|
|
49
|
+
};
|
|
50
|
+
|
|
51
|
+
const componentTransitions = {
|
|
52
|
+
timeout: {
|
|
53
|
+
enter: 200,
|
|
54
|
+
exit: 400,
|
|
55
|
+
},
|
|
56
|
+
classNames: getContentTransitionsClassNames(),
|
|
57
|
+
};
|
|
58
|
+
|
|
59
|
+
return {
|
|
60
|
+
isFullSizeModal,
|
|
61
|
+
backdropTransitions,
|
|
62
|
+
componentTransitions,
|
|
63
|
+
};
|
|
64
|
+
};
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { hasOwnProperty } from '@alfalab/core-components-shared';
|
|
2
|
+
|
|
3
|
+
import { UniversalModalDesktopProps } from '../types/props';
|
|
4
|
+
|
|
5
|
+
type Params = {
|
|
6
|
+
styles: Record<string, string>;
|
|
7
|
+
margin: UniversalModalDesktopProps['margin'];
|
|
8
|
+
};
|
|
9
|
+
|
|
10
|
+
export const getMargins = (params: Params): Record<string, boolean> => {
|
|
11
|
+
const { margin, styles } = params;
|
|
12
|
+
|
|
13
|
+
const hasMarginTop = (margin && hasOwnProperty(margin, 'top')) || false;
|
|
14
|
+
const hasMarginRight = (margin && hasOwnProperty(margin, 'right')) || false;
|
|
15
|
+
const hasMarginBottom = (margin && hasOwnProperty(margin, 'bottom')) || false;
|
|
16
|
+
const hasMarginLeft = (margin && hasOwnProperty(margin, 'left')) || false;
|
|
17
|
+
|
|
18
|
+
return {
|
|
19
|
+
[styles[`marginTop-${margin?.top}`]]: hasMarginTop,
|
|
20
|
+
[styles[`marginRight-${margin?.right}`]]: hasMarginRight,
|
|
21
|
+
[styles[`marginBottom-${margin?.bottom}`]]: hasMarginBottom,
|
|
22
|
+
[styles[`marginLeft-${margin?.left}`]]: hasMarginLeft,
|
|
23
|
+
};
|
|
24
|
+
};
|
package/src/index.ts
ADDED
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export { UniversalModalResponsive, UniversalModal } from './Component.responsive';
|
|
2
|
+
export type { UniversalModalResponsiveProps } from './typings';
|
|
3
|
+
|
|
4
|
+
export { ContentResponsive } from './components/content';
|
|
5
|
+
export type { ContentResponsiveProps } from './components/content';
|
|
6
|
+
|
|
7
|
+
export { HeaderResponsive } from './components/header';
|
|
8
|
+
export type { HeaderResponsiveProps } from './components/header';
|
|
9
|
+
|
|
10
|
+
export { FooterResponsive } from './components/footer';
|
|
11
|
+
export type { FooterResponsiveProps } from './components/footer';
|