From 2d88ef54d2acedd0d355657c9885004973cbef7a Mon Sep 17 00:00:00 2001 From: Mikhail Lukin Date: Fri, 13 Dec 2024 14:58:22 +0700 Subject: [PATCH] feat: universal modal atom export refactor --- .../src/Component.responsive.tsx | 2 +- .../src/desktop/Component.desktop.tsx | 81 ++++++++++--------- .../universal-modal/src/docs/development.mdx | 33 ++++++-- packages/universal-modal/src/index.ts | 6 +- .../src/mobile/Component.mobile.tsx | 2 +- 5 files changed, 74 insertions(+), 50 deletions(-) diff --git a/packages/universal-modal/src/Component.responsive.tsx b/packages/universal-modal/src/Component.responsive.tsx index 1fd20c2639..4c6563cba5 100644 --- a/packages/universal-modal/src/Component.responsive.tsx +++ b/packages/universal-modal/src/Component.responsive.tsx @@ -9,7 +9,7 @@ import { UniversalModalDesktop } from './desktop'; import { UniversalModalMobile } from './mobile'; import { UniversalModalResponsiveProps } from './typings'; -const UniversalModal = forwardRef( +export const UniversalModal = forwardRef( ({ children, breakpoint, defaultMatchMediaValue, dataTestId, ...restProps }, ref) => { const isDesktop = useIsDesktop(breakpoint, defaultMatchMediaValue); diff --git a/packages/universal-modal/src/desktop/Component.desktop.tsx b/packages/universal-modal/src/desktop/Component.desktop.tsx index acd39798a0..1028894e9b 100644 --- a/packages/universal-modal/src/desktop/Component.desktop.tsx +++ b/packages/universal-modal/src/desktop/Component.desktop.tsx @@ -11,59 +11,60 @@ import { ModalByCenter } from './components/modal-by-center'; import { ModalBySide } from './components/modal-by-side'; import { UniversalModalDesktopProps } from './types/props'; -const UniversalModalDesktopComponent = forwardRef( - ({ children, dataTestId, horizontalAlign = 'center', ...restProps }, ref) => { - const [modalWidth, setModalWidth] = useState(0); - const [modalHeaderHighlighted, setModalHeaderHighlighted] = useState(false); - const [modalFooterHighlighted, setModalFooterHighlighted] = useState(false); +export const UniversalModalDesktopComponent = forwardRef< + HTMLDivElement, + UniversalModalDesktopProps +>(({ children, dataTestId, horizontalAlign = 'center', ...restProps }, ref) => { + const [modalWidth, setModalWidth] = useState(0); + const [modalHeaderHighlighted, setModalHeaderHighlighted] = useState(false); + const [modalFooterHighlighted, setModalFooterHighlighted] = useState(false); - const contextValue = React.useMemo( - () => ({ - view: 'desktop', - dataTestId, - modalWidth, - modalHeaderHighlighted, - modalFooterHighlighted, - setModalWidth, - setModalHeaderHighlighted, - setModalFooterHighlighted, - }), - [dataTestId, modalWidth, modalHeaderHighlighted, modalFooterHighlighted], - ); - - const renderContent = () => { - if (horizontalAlign === 'center') { - return ( - - {children} - - ); - } + const contextValue = React.useMemo( + () => ({ + view: 'desktop', + dataTestId, + modalWidth, + modalHeaderHighlighted, + modalFooterHighlighted, + setModalWidth, + setModalHeaderHighlighted, + setModalFooterHighlighted, + }), + [dataTestId, modalWidth, modalHeaderHighlighted, modalFooterHighlighted], + ); + const renderContent = () => { + if (horizontalAlign === 'center') { return ( - {children} - + ); - }; + } return ( - - {renderContent()} - + + {children} + ); - }, -); + }; + + return ( + + {renderContent()} + + ); +}); export const UniversalModalDesktop = Object.assign(UniversalModalDesktopComponent, { Content, diff --git a/packages/universal-modal/src/docs/development.mdx b/packages/universal-modal/src/docs/development.mdx index 094cd5edd1..62f0a85e73 100644 --- a/packages/universal-modal/src/docs/development.mdx +++ b/packages/universal-modal/src/docs/development.mdx @@ -4,24 +4,47 @@ import { UniversalModalDesktop } from '../desktop'; import { UniversalModalResponsive } from '..'; import vars from '!!raw-loader!../vars.css'; -## Подключение +## Подключение Responsive ```jsx -// Responsive компонент +// atom +import { UniversalModal } from '@alfalab/core-components/universal-modal'; + +// compound import { UniversalModalResponsive } from '@alfalab/core-components/universal-modal'; + import type {UniversalModalResponsiveProps } from '@alfalab/core-components/universal-modal'; +``` + +## Подключение Desktop -// Desktop компонент +```jsx +// atom +import { UniversalModalDesktopComponent } from '@alfalab/core-components/universal-modal'; + +// compound import { UniversalModalDesktop } from '@alfalab/core-components/universal-modal'; + import type { UniversalModalDesktopProps } from '@alfalab/core-components/universal-modal'; import { ArrowButtonDesktop, CrossButtonDesktop } from '@alfalab/core-components/universal-modal'; +``` -// Mobile компонент +## Подключение Mobile + +```jsx +// atom +import { UniversalModalMobileComponent } from '@alfalab/core-components/universal-modal'; + +// compound import { UniversalModalMobile } from '@alfalab/core-components/universal-modal'; + import type { UniversalModalMobileProps } from '@alfalab/core-components/universal-modal'; import { ArrowButtonDesktopMobile, CrossButtonDesktopMobile } from '@alfalab/core-components/universal-modal'; +``` + +## Атомарный импорт внутренних компонентов -// Атомарный импорт внутренних компонентов +```jsx import { ContentDesktop, ContentMobile } from '@alfalab/core-components/universal-modal'; import type { ContentDesktopProps, ContentMobileProps } from '@alfalab/core-components/universal-modal'; diff --git a/packages/universal-modal/src/index.ts b/packages/universal-modal/src/index.ts index 04d760cb44..e5a7780624 100644 --- a/packages/universal-modal/src/index.ts +++ b/packages/universal-modal/src/index.ts @@ -1,12 +1,12 @@ -export { UniversalModalResponsive } from './Component.responsive'; +export { UniversalModalResponsive, UniversalModal } from './Component.responsive'; export type { UniversalModalResponsiveProps } from './typings'; -export { UniversalModalDesktop } from './desktop/Component.desktop'; +export { UniversalModalDesktop, UniversalModalDesktopComponent } from './desktop/Component.desktop'; export type { UniversalModalDesktopProps } from './desktop/types/props'; export { ArrowButtonDesktop } from './desktop/components/buttons/arrow-button'; export { CrossButtonDesktop } from './desktop/components/buttons/cross-button'; -export { UniversalModalMobile } from './mobile/Component.mobile'; +export { UniversalModalMobile, UniversalModalMobileComponent } from './mobile/Component.mobile'; export type { UniversalModalMobileProps } from './mobile/types/props'; export { ArrowButtonMobile } from './mobile/components/buttons/arrow-button'; export { CrossButtonMobile } from './mobile/components/buttons/cross-button'; diff --git a/packages/universal-modal/src/mobile/Component.mobile.tsx b/packages/universal-modal/src/mobile/Component.mobile.tsx index 5c573bc659..834adf8e9a 100644 --- a/packages/universal-modal/src/mobile/Component.mobile.tsx +++ b/packages/universal-modal/src/mobile/Component.mobile.tsx @@ -16,7 +16,7 @@ import styles from './mobile.module.css'; import rightSideTransitions from './transitions/right-side-transitions.mobile.module.css'; import transitions from './transitions/transitions.mobile.module.css'; -const UniversalModalMobileComponent = forwardRef( +export const UniversalModalMobileComponent = forwardRef( ({ children, className, dataTestId, onClose, appearance = 'bottom', ...restProps }, ref) => { const [modalHeaderHighlighted, setModalHeaderHighlighted] = useState(false); const contextValue = useMemo(