From ec19d05092e65b8ffa4bad27eafb6ef90c081ac7 Mon Sep 17 00:00:00 2001 From: Udimberto Silvestre Junior Date: Tue, 13 Aug 2019 15:46:32 -0300 Subject: [PATCH] Update: 'Modal' children width behavior; --- dist/components/Modal/Modal.js | 15 ++++++++++----- src/components/Modal/Modal.jsx | 8 +++++--- src/components/Modal/Modal.mdx | 4 ++-- 3 files changed, 17 insertions(+), 10 deletions(-) diff --git a/dist/components/Modal/Modal.js b/dist/components/Modal/Modal.js index 63d9479a..86b85482 100644 --- a/dist/components/Modal/Modal.js +++ b/dist/components/Modal/Modal.js @@ -35,7 +35,7 @@ var _ref = process.env.NODE_ENV === "production" ? { } : { name: "1sy9iaq", styles: "body{overflow:hidden;}", - map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/Modal/Modal.jsx"],"names":[],"mappings":"AAgN2C","file":"../../../src/components/Modal/Modal.jsx","sourcesContent":["/* Core Packages */\nimport React, { forwardRef, useEffect, useState, useRef } from 'react';\nimport PropTypes from 'prop-types';\nimport { Global, css } from '@emotion/core';\n\n/* Helper Components */\nimport {\n    H1,\n    Flex,\n    ActionBar,\n} from '../';\n\n/* Component Styles */\nimport ModalStyled from './ModalStyles';\nimport ModalOverlayStyled from './ModalOverlayStyles';\n\n/* Component Itself */\nconst Modal = forwardRef((props, ref) => {\n\n    /**\n     * Global props\n     */\n    const {\n        addEventListener,\n        removeEventListener,\n    } = document;\n\n    /**\n     * Inherit Props\n     */\n    const {\n        title,\n        header,\n        contentJustify,\n        alignItems,\n        children,\n        footer,\n        footerProps,\n        overlayProps,\n\n        className,\n        styles,\n\n        opened,\n        openedCallback,\n        closeOnEscape,\n        closeByEscape,\n        unblockScrolling,\n\n        ...rest\n    } = props;\n\n    /**\n     * State values\n     */\n    const [ active, setActive ]             = useState(opened);\n    const [ visible, setVisible ]           = useState(opened);\n    const [ unmounted, setUnmounted ]       = useState(false);\n    const [ activeTimer, setActiveTimer ]   = useState(null);\n    const [ visibleTimer, setVisibleTimer ] = useState(null);\n\n    /**\n     * State reference\n     */\n    const modalRef = useRef(null);\n\n    /**\n     * Watch for `opened` prop changes\n     */\n    useEffect(() => {\n        if (!opened) {\n            handleClose();\n            unlisten();\n\n            return unlisten;\n        }\n\n        if (opened || active) {\n            handleOpen();\n        }\n\n        return unlisten;\n    }, [ opened ]);\n\n    /**\n     * Handle with close by escape key\n     *\n     * @param {object} evt - DOM click event\n     */\n    function handleCloseOnScape (evt) {\n        const { key, keyCode, target } = (evt || {});\n        const { nodeName } = (target || {});\n        const isEscPressed = (key === 'Escape' || key === 'Esc' || keyCode === 27);\n\n        if (!isEscPressed) {\n            return;\n        }\n\n        handleClose();\n\n        return;\n    }\n\n    /**\n     * Add Event Listeners to handle with modal visibility\n     */\n    function listen () {\n        if (closeOnEscape || closeByEscape) {\n            addEventListener('keydown', handleCloseOnScape);\n        }\n    }\n\n    /**\n     * Remove Event Listeners\n     */\n    function unlisten () {\n        clearTimeout(activeTimer);\n        clearTimeout(visibleTimer);\n\n        removeEventListener('keydown', handleCloseOnScape);\n    }\n\n    /**\n     * Handle with Dropdown close event\n     *\n     * @param {object} evt - DOM click event\n     */\n    function handleClose(evt) {\n        clearTimeout(visibleTimer);\n\n        if (unmounted ||\n            (evt &&\n            evt.target &&\n            modalRef &&\n            modalRef.current &&\n            modalRef.current.contains(evt.target))) {\n            return;\n        }\n\n        unlisten();\n        setActive(false);\n        setVisible(true);\n\n        setVisibleTimer(setTimeout(() => {\n            if (unmounted) {\n                return;\n            }\n\n            setVisible(false);\n            openedCallback(false);\n            modalRef.current.focus();\n        }, 100));\n    }\n\n    /**\n     * Handle with Dropdown open event\n     *\n     * @param {object} evt - DOM click event\n     */\n    function handleOpen(evt) {\n        clearTimeout(activeTimer);\n\n        if (unmounted) {\n            return;\n        }\n\n        if (evt && evt.preventDefault) {\n            evt.preventDefault();\n        }\n\n        setActive(false);\n        setVisible(true);\n\n        setActiveTimer(setTimeout(() => {\n            if (unmounted) {\n                return;\n            }\n\n            setActive(true);\n            listen();\n        }, 50));\n    }\n\n    /**\n     * Render\n     */\n    return (\n        <>\n            {(!active || !visible) ? (null) : (\n                <ModalOverlayStyled\n                    onClick={(evt) => (closeOnEscape || closeByEscape) && handleClose(evt)}\n                    className={`aph-modal-overlay ${active ? ' active' : ''}${visible ? ' visible' : ''}`}\n                    {...overlayProps}\n                />\n            )}\n            <ModalStyled\n                {...rest}\n                ref={modalRef}\n                open\n                opened={active && visible}\n                role=\"dialog\"\n                styles={styles}\n                hasFooter={(footer || Object.keys(footerProps).length) ? true : false}\n                className={`aph-modal ${className || ''}${active ? ' active' : ''}${visible ? ' visible' : ''}`}>\n                {(!active || !visible) ? (null) : (\n                    <>\n                        {unblockScrolling ? (null) : (\n                            <Global\n                                styles={css`\n                                    body {\n                                        overflow: hidden;\n                                    }\n                                `}\n                            />\n                        )}\n                        <Flex\n                            flex\n                            flexDirection=\"column\"\n                            className=\"aph-modal__container\">\n                            {(!title) ? (null) : (\n                                <H1 className=\"aph-modal__container__title\" bold center>\n                                    {title}\n                                </H1>\n                            )}\n                            {(!header) ? (null) : (\n                                <header className=\"aph-modal__container__header\">\n                                    {header}\n                                </header>\n                            )}\n                            <Flex\n                                flex\n                                alignItems={alignItems}\n                                justifyContent={contentJustify || 'start'}\n                                flexDirection=\"column\"\n                                styles={{ flex: 1 }}\n                                className=\"aph-modal__container__content\">\n                                {children}\n                            </Flex>\n                        </Flex>\n                        <ActionBar\n                            {...footerProps}\n                            className={`aph-modal__content__footer ${footerProps.className || ''}`}\n                            visible={footerProps.visible || (typeof footerProps.visible === 'undefined' && footer ? true : false)}\n                            styles={{\n                                ...footerProps.styles,\n                                padding  : '10px 0',\n                                minHeight: 'initial'\n                            }}>\n                            {footer}\n                        </ActionBar>\n                    </>\n                )}\n            </ModalStyled>\n        </>\n    );\n});\n\n/* Default props */\nModal.defaultProps = {\n    title : '',\n    header: undefined,\n\n    opened          : false,\n    openedCallback  : () => {},\n    closeOnEscape   : false,\n    unblockScrolling: false,\n\n    /**\n     * Flex `justify-content`\n     * flex-start || center || flex-end\n     */\n    contentJustify: 'flex-start',\n\n    alignItems: 'center',\n    footerProps: {},\n    styles     : {},\n\n    overlayProps: {},\n};\n\n/* Prop Types */\nModal.propTypes = {\n    title: PropTypes.string,\n    header: PropTypes.any,\n\n    opened          : PropTypes.bool,\n    openedCallback  : PropTypes.func.isRequired,\n    closeOnEscape   : PropTypes.bool,\n    unblockScrolling: PropTypes.bool,\n\n    contentJustify: PropTypes.string,\n    alignItems: PropTypes.string,\n\n    overlayProps: PropTypes.object,\n};\n\n/* Exporting */\nexport default Modal;\n"]} */" + map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/Modal/Modal.jsx"],"names":[],"mappings":"AAgN2C","file":"../../../src/components/Modal/Modal.jsx","sourcesContent":["/* Core Packages */\nimport React, { forwardRef, useEffect, useState, useRef } from 'react';\nimport PropTypes from 'prop-types';\nimport { Global, css } from '@emotion/core';\n\n/* Helper Components */\nimport {\n    H1,\n    Flex,\n    ActionBar,\n} from '../';\n\n/* Component Styles */\nimport ModalStyled from './ModalStyles';\nimport ModalOverlayStyled from './ModalOverlayStyles';\n\n/* Component Itself */\nconst Modal = forwardRef((props, ref) => {\n\n    /**\n     * Global props\n     */\n    const {\n        addEventListener,\n        removeEventListener,\n    } = document;\n\n    /**\n     * Inherit Props\n     */\n    const {\n        title,\n        header,\n        contentJustify,\n        alignItems,\n        children,\n        footer,\n        footerProps,\n        overlayProps,\n\n        className,\n        styles,\n\n        opened,\n        openedCallback,\n        closeOnEscape,\n        closeByEscape,\n        unblockScrolling,\n\n        ...rest\n    } = props;\n\n    /**\n     * State values\n     */\n    const [ active, setActive ]             = useState(opened);\n    const [ visible, setVisible ]           = useState(opened);\n    const [ unmounted, setUnmounted ]       = useState(false);\n    const [ activeTimer, setActiveTimer ]   = useState(null);\n    const [ visibleTimer, setVisibleTimer ] = useState(null);\n\n    /**\n     * State reference\n     */\n    const modalRef = useRef(null);\n\n    /**\n     * Watch for `opened` prop changes\n     */\n    useEffect(() => {\n        if (!opened) {\n            handleClose();\n            unlisten();\n\n            return unlisten;\n        }\n\n        if (opened || active) {\n            handleOpen();\n        }\n\n        return unlisten;\n    }, [ opened ]);\n\n    /**\n     * Handle with close by escape key\n     *\n     * @param {object} evt - DOM click event\n     */\n    function handleCloseOnScape (evt) {\n        const { key, keyCode, target } = (evt || {});\n        const { nodeName } = (target || {});\n        const isEscPressed = (key === 'Escape' || key === 'Esc' || keyCode === 27);\n\n        if (!isEscPressed) {\n            return;\n        }\n\n        handleClose();\n\n        return;\n    }\n\n    /**\n     * Add Event Listeners to handle with modal visibility\n     */\n    function listen () {\n        if (closeOnEscape || closeByEscape) {\n            addEventListener('keydown', handleCloseOnScape);\n        }\n    }\n\n    /**\n     * Remove Event Listeners\n     */\n    function unlisten () {\n        clearTimeout(activeTimer);\n        clearTimeout(visibleTimer);\n\n        removeEventListener('keydown', handleCloseOnScape);\n    }\n\n    /**\n     * Handle with Dropdown close event\n     *\n     * @param {object} evt - DOM click event\n     */\n    function handleClose(evt) {\n        clearTimeout(visibleTimer);\n\n        if (unmounted ||\n            (evt &&\n            evt.target &&\n            modalRef &&\n            modalRef.current &&\n            modalRef.current.contains(evt.target))) {\n            return;\n        }\n\n        unlisten();\n        setActive(false);\n        setVisible(true);\n\n        setVisibleTimer(setTimeout(() => {\n            if (unmounted) {\n                return;\n            }\n\n            setVisible(false);\n            openedCallback(false);\n            modalRef.current.focus();\n        }, 100));\n    }\n\n    /**\n     * Handle with Dropdown open event\n     *\n     * @param {object} evt - DOM click event\n     */\n    function handleOpen(evt) {\n        clearTimeout(activeTimer);\n\n        if (unmounted) {\n            return;\n        }\n\n        if (evt && evt.preventDefault) {\n            evt.preventDefault();\n        }\n\n        setActive(false);\n        setVisible(true);\n\n        setActiveTimer(setTimeout(() => {\n            if (unmounted) {\n                return;\n            }\n\n            setActive(true);\n            listen();\n        }, 50));\n    }\n\n    /**\n     * Render\n     */\n    return (\n        <>\n            {(!active || !visible) ? (null) : (\n                <ModalOverlayStyled\n                    onClick={(evt) => (closeOnEscape || closeByEscape) && handleClose(evt)}\n                    className={`aph-modal-overlay ${active ? ' active' : ''}${visible ? ' visible' : ''}`}\n                    {...overlayProps}\n                />\n            )}\n            <ModalStyled\n                {...rest}\n                ref={modalRef}\n                open\n                opened={active && visible}\n                role=\"dialog\"\n                styles={styles}\n                hasFooter={(footer || Object.keys(footerProps).length) ? true : false}\n                className={`aph-modal ${className || ''}${active ? ' active' : ''}${visible ? ' visible' : ''}`}>\n                {(!active || !visible) ? (null) : (\n                    <>\n                        {unblockScrolling ? (null) : (\n                            <Global\n                                styles={css`\n                                    body {\n                                        overflow: hidden;\n                                    }\n                                `}\n                            />\n                        )}\n                        <Flex\n                            flex\n                            flexDirection=\"column\"\n                            className=\"aph-modal__container\">\n                            {(!title) ? (null) : (\n                                <H1 className=\"aph-modal__container__title\" bold center>\n                                    {title}\n                                </H1>\n                            )}\n                            {(!header) ? (null) : (\n                                <header className=\"aph-modal__container__header\">\n                                    {header}\n                                </header>\n                            )}\n                            <Flex\n                                flex\n                                alignItems=\"center\"\n                                justifyContent={contentJustify || 'start'}\n                                styles={{ flex: 1, width: '100%' }}\n                                flexDirection=\"column\"\n                                className=\"aph-modal__container__content\">\n                                <Flex styles={{ width: '100%' }}>\n                                    {children}\n                                </Flex>\n                            </Flex>\n                        </Flex>\n                        <ActionBar\n                            {...footerProps}\n                            className={`aph-modal__content__footer ${footerProps.className || ''}`}\n                            visible={footerProps.visible || (typeof footerProps.visible === 'undefined' && footer ? true : false)}\n                            styles={{\n                                ...footerProps.styles,\n                                padding  : '10px 0',\n                                minHeight: 'initial'\n                            }}>\n                            {footer}\n                        </ActionBar>\n                    </>\n                )}\n            </ModalStyled>\n        </>\n    );\n});\n\n/* Default props */\nModal.defaultProps = {\n    title : '',\n    header: undefined,\n\n    opened          : false,\n    openedCallback  : () => {},\n    closeOnEscape   : false,\n    unblockScrolling: false,\n\n    /**\n     * Flex `justify-content`\n     * flex-start || center || flex-end\n     */\n    contentJustify: 'flex-start',\n\n    alignItems: 'center',\n    footerProps: {},\n    styles     : {},\n\n    overlayProps: {},\n};\n\n/* Prop Types */\nModal.propTypes = {\n    title: PropTypes.string,\n    header: PropTypes.any,\n\n    opened          : PropTypes.bool,\n    openedCallback  : PropTypes.func.isRequired,\n    closeOnEscape   : PropTypes.bool,\n    unblockScrolling: PropTypes.bool,\n\n    contentJustify: PropTypes.string,\n    alignItems: PropTypes.string,\n\n    overlayProps: PropTypes.object,\n};\n\n/* Exporting */\nexport default Modal;\n"]} */" }; /* Component Itself */ @@ -245,14 +245,19 @@ var Modal = (0, _react.forwardRef)(function (props, ref) { className: "aph-modal__container__header" }, header), _react.default.createElement(_.Flex, { flex: true, - alignItems: alignItems, + alignItems: "center", justifyContent: contentJustify || 'start', - flexDirection: "column", styles: { - flex: 1 + flex: 1, + width: '100%' }, + flexDirection: "column", className: "aph-modal__container__content" - }, children)), _react.default.createElement(_.ActionBar, _extends({}, footerProps, { + }, _react.default.createElement(_.Flex, { + styles: { + width: '100%' + } + }, children))), _react.default.createElement(_.ActionBar, _extends({}, footerProps, { className: "aph-modal__content__footer " + (footerProps.className || ''), visible: footerProps.visible || (typeof footerProps.visible === 'undefined' && footer ? true : false), styles: _objectSpread({}, footerProps.styles, { diff --git a/src/components/Modal/Modal.jsx b/src/components/Modal/Modal.jsx index 51357ff5..23220d40 100644 --- a/src/components/Modal/Modal.jsx +++ b/src/components/Modal/Modal.jsx @@ -229,12 +229,14 @@ const Modal = forwardRef((props, ref) => { )} - {children} + + {children} + - {/*