@hh.ru/magritte-ui-modal 5.0.0 → 5.0.2
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/Modal.js +1 -1
- package/{ModalContentWithHeader-BZMj-Rqc.js → ModalContentWithHeader-BQmiz6P-.js} +2 -2
- package/{ModalContentWithHeader-BZMj-Rqc.js.map → ModalContentWithHeader-BQmiz6P-.js.map} +1 -1
- package/ModalContentWithHeader.js +1 -1
- package/ModalHeader.js +1 -1
- package/index.css +70 -70
- package/index.js +1 -1
- package/package.json +10 -10
package/Modal.js
CHANGED
|
@@ -13,7 +13,7 @@ import { InternalLayerName } from '@hh.ru/magritte-internal-layer-name';
|
|
|
13
13
|
import { isActionBarComponent } from '@hh.ru/magritte-ui-action-bar';
|
|
14
14
|
import { Breakpoint, useBreakpoint } from '@hh.ru/magritte-ui-breakpoint';
|
|
15
15
|
import { Layer } from '@hh.ru/magritte-ui-layer';
|
|
16
|
-
import { s as styles, M as ModalContentWithHeader } from './ModalContentWithHeader-
|
|
16
|
+
import { s as styles, M as ModalContentWithHeader } from './ModalContentWithHeader-BQmiz6P-.js';
|
|
17
17
|
import { useModalOrder } from './useModalOrder.js';
|
|
18
18
|
import { isValidTreeSelectorWrapper } from '@hh.ru/magritte-ui-tree-selector';
|
|
19
19
|
import '@hh.ru/magritte-common-func-utils';
|
|
@@ -6,7 +6,7 @@ import { requestAnimation } from '@hh.ru/magritte-common-func-utils';
|
|
|
6
6
|
import { Divider } from '@hh.ru/magritte-ui-divider';
|
|
7
7
|
import { ModalHeader } from './ModalHeader.js';
|
|
8
8
|
|
|
9
|
-
var styles = {"modal-overlay":"magritte-modal-overlay___lK22l_5-0-
|
|
9
|
+
var styles = {"modal-overlay":"magritte-modal-overlay___lK22l_5-0-2","modalOverlay":"magritte-modal-overlay___lK22l_5-0-2","modal":"magritte-modal___RAW6S_5-0-2","size-small":"magritte-size-small___2JTM2_5-0-2","sizeSmall":"magritte-size-small___2JTM2_5-0-2","size-medium":"magritte-size-medium___cWCe7_5-0-2","sizeMedium":"magritte-size-medium___cWCe7_5-0-2","no-vertical-paddings":"magritte-no-vertical-paddings___Z3-oM_5-0-2","noVerticalPaddings":"magritte-no-vertical-paddings___Z3-oM_5-0-2","no-horizontal-paddings":"magritte-no-horizontal-paddings___aT95Y_5-0-2","noHorizontalPaddings":"magritte-no-horizontal-paddings___aT95Y_5-0-2","modal-full-height":"magritte-modal-full-height___gIM4E_5-0-2","modalFullHeight":"magritte-modal-full-height___gIM4E_5-0-2","modal-content":"magritte-modal-content___46QFS_5-0-2","modalContent":"magritte-modal-content___46QFS_5-0-2","modal-content-wrapper":"magritte-modal-content-wrapper___23XFT_5-0-2","modalContentWrapper":"magritte-modal-content-wrapper___23XFT_5-0-2","modal-content-wrapper__one-line":"magritte-modal-content-wrapper__one-line___tYg8d_5-0-2","modalContentWrapperOneLine":"magritte-modal-content-wrapper__one-line___tYg8d_5-0-2","divider-container":"magritte-divider-container___qP3VK_5-0-2","dividerContainer":"magritte-divider-container___qP3VK_5-0-2","divider-container-hidden":"magritte-divider-container-hidden___EIxB-_5-0-2","dividerContainerHidden":"magritte-divider-container-hidden___EIxB-_5-0-2","modal-footer":"magritte-modal-footer___8xPqQ_5-0-2","modalFooter":"magritte-modal-footer___8xPqQ_5-0-2","modal-buttons-container":"magritte-modal-buttons-container___1O1Nr_5-0-2","modalButtonsContainer":"magritte-modal-buttons-container___1O1Nr_5-0-2","animation-timeout":"magritte-animation-timeout___w-j7K_5-0-2","animationTimeout":"magritte-animation-timeout___w-j7K_5-0-2","modal-animation-enter-active":"magritte-modal-animation-enter-active___E8KLu_5-0-2","modalAnimationEnterActive":"magritte-modal-animation-enter-active___E8KLu_5-0-2","modal-animation-exit-active":"magritte-modal-animation-exit-active___ERjKa_5-0-2","modalAnimationExitActive":"magritte-modal-animation-exit-active___ERjKa_5-0-2","modal-animation-enter":"magritte-modal-animation-enter___kruLO_5-0-2","modalAnimationEnter":"magritte-modal-animation-enter___kruLO_5-0-2","modal-animation-exit":"magritte-modal-animation-exit___0jNgl_5-0-2","modalAnimationExit":"magritte-modal-animation-exit___0jNgl_5-0-2","content-scroll-preserver":"magritte-content-scroll-preserver___Tw5Px_5-0-2","contentScrollPreserver":"magritte-content-scroll-preserver___Tw5Px_5-0-2","content-sticky-container":"magritte-content-sticky-container___nqEXj_5-0-2","contentStickyContainer":"magritte-content-sticky-container___nqEXj_5-0-2"};
|
|
10
10
|
|
|
11
11
|
const checkIsScrolledToBottom = (el) => {
|
|
12
12
|
return Math.abs(el.scrollHeight - el.scrollTop - el.clientHeight) < 1;
|
|
@@ -129,4 +129,4 @@ const ModalContentWithHeader = ({ labelId, children, headerHeight: _headerHeight
|
|
|
129
129
|
};
|
|
130
130
|
|
|
131
131
|
export { ModalContentWithHeader as M, styles as s };
|
|
132
|
-
//# sourceMappingURL=ModalContentWithHeader-
|
|
132
|
+
//# sourceMappingURL=ModalContentWithHeader-BQmiz6P-.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ModalContentWithHeader-BZMj-Rqc.js","sources":["../src/ModalContentWithHeader.tsx"],"sourcesContent":["import { FC, PropsWithChildren, useCallback, useLayoutEffect, useRef } from 'react';\nimport classnames from 'classnames';\n\nimport { requestAnimation } from '@hh.ru/magritte-common-func-utils';\nimport { Divider } from '@hh.ru/magritte-ui-divider';\nimport { ModalHeader } from '@hh.ru/magritte-ui-modal/ModalHeader';\nimport { ModalHeaderProps } from '@hh.ru/magritte-ui-modal/types';\n\nimport styles from './modal.less';\n\nconst checkIsScrolledToBottom = (el: HTMLElement) => {\n return Math.abs(el.scrollHeight - el.scrollTop - el.clientHeight) < 1;\n};\n\nconst clamp = (value: number, min: number, max: number) => Math.min(Math.max(value, min), max);\n\n// Минимальная высота до которой может сжаться хедер\nconst HEADER_SHRINK_MIN_HEIGHT = 148;\n// Минимальная высота отступа между хедером и контентом\nconst HEADER_MARGIN_MIN_HEIGHT = 12;\n// Максимальная высота отступа между хедером и контентом\nconst HEADER_MARGIN_MAX_HEIGHT = 24;\nconst HEADER_MARGIN_HEIGHT_DELTA = HEADER_MARGIN_MAX_HEIGHT - HEADER_MARGIN_MIN_HEIGHT;\n\n// Вычисляет минимальную высоту до которой может сжаться хедер с учетом высоты контента, чтобы не спровоцировать\n// изменение размера модалки\nconst calcHeaderShrinkLimit = (\n headerHeight: number,\n headerMaxHeight: number,\n contentHeight: number,\n contentScrollHeight: number,\n marginHeight: number\n) => {\n // Высота контента скрытого под скроллом когда хедер и марджин под ним имеет максимальную допустимую высоту\n const contentScrollDelta =\n contentScrollHeight - // Высота контента скрытого под скроллом в текущем состоянии\n contentHeight + // Высота контейнера содержащего контент\n (HEADER_MARGIN_MAX_HEIGHT - marginHeight) + // Дельта между текущей высотой марджина и максимальной допустимой\n (headerMaxHeight - headerHeight); // Дельта между текущей высотой хедера и максимальной допустимой\n\n const headerShrinkMinHeight = headerMaxHeight - (contentScrollDelta - HEADER_MARGIN_HEIGHT_DELTA);\n\n return Math.max(headerShrinkMinHeight, HEADER_SHRINK_MIN_HEIGHT);\n};\n\nconst shrinkByDelta = (\n headerImageContainer: HTMLDivElement | null,\n headerWrapper: HTMLDivElement | null,\n headerMinHeight: number,\n headerMaxHeight: number,\n scrollDeltaY: number\n) => {\n if (!headerImageContainer || !headerWrapper) {\n return;\n }\n\n const marginHeight = clamp(\n HEADER_MARGIN_MAX_HEIGHT - scrollDeltaY,\n HEADER_MARGIN_MIN_HEIGHT,\n HEADER_MARGIN_MAX_HEIGHT\n );\n headerWrapper.style.marginBottom = `${marginHeight}px`;\n\n const headerHeight = clamp(\n // Тут прибаляем дельту марджина потому что сначала должен сжаться отступ\n Math.floor(headerMaxHeight - scrollDeltaY + HEADER_MARGIN_HEIGHT_DELTA),\n headerMinHeight,\n headerMaxHeight\n );\n headerImageContainer.style.height = `${headerHeight}px`;\n};\n\nexport const ModalContentWithHeader: FC<\n PropsWithChildren<ModalHeaderProps & { labelId: string; isTreeSelectorChild: boolean }>\n> = ({ labelId, children, headerHeight: _headerHeight = 0, isTreeSelectorChild, ...modalHeaderProps }) => {\n const { title, headerImage, actions, actionLink, options } = modalHeaderProps;\n\n const bottomDividerVisibleRef = useRef(false);\n const contentContainerRef = useRef<HTMLDivElement>(null);\n const headerImageContainerRef = useRef<HTMLDivElement>(null);\n const headerWrapperRef = useRef<HTMLDivElement>(null);\n const spacePreserverRef = useRef<HTMLDivElement>(null);\n const stickyContainerRef = useRef<HTMLDivElement>(null);\n const headerHeightRef = useRef(0);\n const minHeaderHeightRef = useRef(0);\n const headerImageRef = useRef(!!headerImage);\n headerHeightRef.current = headerImage ? Math.max(_headerHeight, 200) : 0;\n headerImageRef.current = !!headerImage;\n\n const bottomDividerContainerRef = useRef<HTMLDivElement>(null);\n const topDividerContainerRef = useRef<HTMLDivElement>(null);\n\n const withoutHeader = !title && !headerImage && !actions && !actionLink && !options;\n const onlyActions = !title && !headerImage && !options && (actions || actionLink);\n\n const isTopDividerVisible = () => {\n if (!contentContainerRef.current) {\n return false;\n }\n\n const topDividerVisible = headerImageRef.current\n ? contentContainerRef.current.scrollTop >\n headerHeightRef.current - minHeaderHeightRef.current + HEADER_MARGIN_HEIGHT_DELTA\n : contentContainerRef.current.scrollTop !== 0;\n\n return topDividerVisible && (options || !headerImage) && !onlyActions && !withoutHeader;\n };\n\n const updateHeaderDimensions = useCallback(() => {\n if (\n !headerImageContainerRef.current ||\n !headerWrapperRef.current ||\n !stickyContainerRef.current ||\n !spacePreserverRef.current ||\n !contentContainerRef.current\n ) {\n return;\n }\n\n if (!headerImageRef.current) {\n spacePreserverRef.current.style.height = '0';\n return;\n }\n\n minHeaderHeightRef.current = calcHeaderShrinkLimit(\n headerImageContainerRef.current.clientHeight,\n headerHeightRef.current,\n contentContainerRef.current.clientHeight,\n stickyContainerRef.current.scrollHeight,\n parseInt(headerWrapperRef.current.style.marginBottom || '0', 10)\n );\n\n shrinkByDelta(\n headerImageContainerRef.current,\n headerWrapperRef.current,\n minHeaderHeightRef.current,\n headerHeightRef.current,\n contentContainerRef.current.scrollTop\n );\n const preserverSize = headerHeightRef.current - minHeaderHeightRef.current + HEADER_MARGIN_HEIGHT_DELTA;\n spacePreserverRef.current.style.height = `${preserverSize}px`;\n }, []);\n\n useLayoutEffect(() => {\n if (contentContainerRef.current) {\n const observer = new ResizeObserver(\n requestAnimation(() => {\n if (!contentContainerRef.current) {\n return;\n }\n const isScrollable =\n contentContainerRef.current.scrollHeight > contentContainerRef.current.clientHeight;\n const hasScroll = isScrollable && !checkIsScrolledToBottom(contentContainerRef.current);\n bottomDividerVisibleRef.current = hasScroll;\n bottomDividerContainerRef.current?.classList.toggle(\n styles.dividerContainerHidden,\n !bottomDividerVisibleRef.current\n );\n updateHeaderDimensions();\n })\n );\n observer.observe(contentContainerRef.current);\n return () => observer.disconnect();\n }\n\n return undefined;\n }, [updateHeaderDimensions]);\n\n useLayoutEffect(() => {\n updateHeaderDimensions();\n if (!options && headerImage) {\n topDividerContainerRef.current?.classList.toggle(styles.dividerContainerHidden, true);\n }\n }, [headerImage, updateHeaderDimensions, options]);\n\n const handleScroll = () => {\n if (!contentContainerRef.current) {\n return;\n }\n\n bottomDividerVisibleRef.current = !checkIsScrolledToBottom(contentContainerRef.current);\n bottomDividerContainerRef.current?.classList.toggle(\n styles.dividerContainerHidden,\n !bottomDividerVisibleRef.current\n );\n topDividerContainerRef.current?.classList.toggle(styles.dividerContainerHidden, !isTopDividerVisible());\n if (headerImageRef.current) {\n shrinkByDelta(\n headerImageContainerRef.current,\n headerWrapperRef.current,\n minHeaderHeightRef.current,\n headerHeightRef.current,\n contentContainerRef.current.scrollTop\n );\n }\n };\n\n return (\n <>\n <div\n className={classnames(styles.modalContentWrapper, {\n [styles.modalContentWrapperOneLine]: onlyActions,\n })}\n >\n <ModalHeader\n {...modalHeaderProps}\n headerHeight={headerHeightRef.current}\n labelId={labelId}\n wrapperRef={headerWrapperRef}\n ref={headerImageContainerRef}\n />\n <div\n className={classnames(styles.dividerContainer, {\n [styles.dividerContainerHidden]: !isTopDividerVisible(),\n })}\n ref={topDividerContainerRef}\n >\n <Divider />\n </div>\n <div\n className={classnames(styles.modalContent)}\n ref={contentContainerRef}\n onScroll={handleScroll}\n data-qa=\"modal-content-scroll-container\"\n >\n {isTreeSelectorChild ? (\n children\n ) : (\n <>\n <div className={styles.contentStickyContainer} ref={stickyContainerRef}>\n {children}\n </div>\n <div ref={spacePreserverRef} />\n </>\n )}\n </div>\n </div>\n <div\n className={classnames(styles.dividerContainer, {\n [styles.dividerContainerHidden]: !bottomDividerVisibleRef.current,\n })}\n ref={bottomDividerContainerRef}\n >\n <Divider />\n </div>\n </>\n );\n};\n"],"names":["_jsxs","_Fragment","_jsx"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"ModalContentWithHeader-BQmiz6P-.js","sources":["../src/ModalContentWithHeader.tsx"],"sourcesContent":["import { FC, PropsWithChildren, useCallback, useLayoutEffect, useRef } from 'react';\nimport classnames from 'classnames';\n\nimport { requestAnimation } from '@hh.ru/magritte-common-func-utils';\nimport { Divider } from '@hh.ru/magritte-ui-divider';\nimport { ModalHeader } from '@hh.ru/magritte-ui-modal/ModalHeader';\nimport { ModalHeaderProps } from '@hh.ru/magritte-ui-modal/types';\n\nimport styles from './modal.less';\n\nconst checkIsScrolledToBottom = (el: HTMLElement) => {\n return Math.abs(el.scrollHeight - el.scrollTop - el.clientHeight) < 1;\n};\n\nconst clamp = (value: number, min: number, max: number) => Math.min(Math.max(value, min), max);\n\n// Минимальная высота до которой может сжаться хедер\nconst HEADER_SHRINK_MIN_HEIGHT = 148;\n// Минимальная высота отступа между хедером и контентом\nconst HEADER_MARGIN_MIN_HEIGHT = 12;\n// Максимальная высота отступа между хедером и контентом\nconst HEADER_MARGIN_MAX_HEIGHT = 24;\nconst HEADER_MARGIN_HEIGHT_DELTA = HEADER_MARGIN_MAX_HEIGHT - HEADER_MARGIN_MIN_HEIGHT;\n\n// Вычисляет минимальную высоту до которой может сжаться хедер с учетом высоты контента, чтобы не спровоцировать\n// изменение размера модалки\nconst calcHeaderShrinkLimit = (\n headerHeight: number,\n headerMaxHeight: number,\n contentHeight: number,\n contentScrollHeight: number,\n marginHeight: number\n) => {\n // Высота контента скрытого под скроллом когда хедер и марджин под ним имеет максимальную допустимую высоту\n const contentScrollDelta =\n contentScrollHeight - // Высота контента скрытого под скроллом в текущем состоянии\n contentHeight + // Высота контейнера содержащего контент\n (HEADER_MARGIN_MAX_HEIGHT - marginHeight) + // Дельта между текущей высотой марджина и максимальной допустимой\n (headerMaxHeight - headerHeight); // Дельта между текущей высотой хедера и максимальной допустимой\n\n const headerShrinkMinHeight = headerMaxHeight - (contentScrollDelta - HEADER_MARGIN_HEIGHT_DELTA);\n\n return Math.max(headerShrinkMinHeight, HEADER_SHRINK_MIN_HEIGHT);\n};\n\nconst shrinkByDelta = (\n headerImageContainer: HTMLDivElement | null,\n headerWrapper: HTMLDivElement | null,\n headerMinHeight: number,\n headerMaxHeight: number,\n scrollDeltaY: number\n) => {\n if (!headerImageContainer || !headerWrapper) {\n return;\n }\n\n const marginHeight = clamp(\n HEADER_MARGIN_MAX_HEIGHT - scrollDeltaY,\n HEADER_MARGIN_MIN_HEIGHT,\n HEADER_MARGIN_MAX_HEIGHT\n );\n headerWrapper.style.marginBottom = `${marginHeight}px`;\n\n const headerHeight = clamp(\n // Тут прибаляем дельту марджина потому что сначала должен сжаться отступ\n Math.floor(headerMaxHeight - scrollDeltaY + HEADER_MARGIN_HEIGHT_DELTA),\n headerMinHeight,\n headerMaxHeight\n );\n headerImageContainer.style.height = `${headerHeight}px`;\n};\n\nexport const ModalContentWithHeader: FC<\n PropsWithChildren<ModalHeaderProps & { labelId: string; isTreeSelectorChild: boolean }>\n> = ({ labelId, children, headerHeight: _headerHeight = 0, isTreeSelectorChild, ...modalHeaderProps }) => {\n const { title, headerImage, actions, actionLink, options } = modalHeaderProps;\n\n const bottomDividerVisibleRef = useRef(false);\n const contentContainerRef = useRef<HTMLDivElement>(null);\n const headerImageContainerRef = useRef<HTMLDivElement>(null);\n const headerWrapperRef = useRef<HTMLDivElement>(null);\n const spacePreserverRef = useRef<HTMLDivElement>(null);\n const stickyContainerRef = useRef<HTMLDivElement>(null);\n const headerHeightRef = useRef(0);\n const minHeaderHeightRef = useRef(0);\n const headerImageRef = useRef(!!headerImage);\n headerHeightRef.current = headerImage ? Math.max(_headerHeight, 200) : 0;\n headerImageRef.current = !!headerImage;\n\n const bottomDividerContainerRef = useRef<HTMLDivElement>(null);\n const topDividerContainerRef = useRef<HTMLDivElement>(null);\n\n const withoutHeader = !title && !headerImage && !actions && !actionLink && !options;\n const onlyActions = !title && !headerImage && !options && (actions || actionLink);\n\n const isTopDividerVisible = () => {\n if (!contentContainerRef.current) {\n return false;\n }\n\n const topDividerVisible = headerImageRef.current\n ? contentContainerRef.current.scrollTop >\n headerHeightRef.current - minHeaderHeightRef.current + HEADER_MARGIN_HEIGHT_DELTA\n : contentContainerRef.current.scrollTop !== 0;\n\n return topDividerVisible && (options || !headerImage) && !onlyActions && !withoutHeader;\n };\n\n const updateHeaderDimensions = useCallback(() => {\n if (\n !headerImageContainerRef.current ||\n !headerWrapperRef.current ||\n !stickyContainerRef.current ||\n !spacePreserverRef.current ||\n !contentContainerRef.current\n ) {\n return;\n }\n\n if (!headerImageRef.current) {\n spacePreserverRef.current.style.height = '0';\n return;\n }\n\n minHeaderHeightRef.current = calcHeaderShrinkLimit(\n headerImageContainerRef.current.clientHeight,\n headerHeightRef.current,\n contentContainerRef.current.clientHeight,\n stickyContainerRef.current.scrollHeight,\n parseInt(headerWrapperRef.current.style.marginBottom || '0', 10)\n );\n\n shrinkByDelta(\n headerImageContainerRef.current,\n headerWrapperRef.current,\n minHeaderHeightRef.current,\n headerHeightRef.current,\n contentContainerRef.current.scrollTop\n );\n const preserverSize = headerHeightRef.current - minHeaderHeightRef.current + HEADER_MARGIN_HEIGHT_DELTA;\n spacePreserverRef.current.style.height = `${preserverSize}px`;\n }, []);\n\n useLayoutEffect(() => {\n if (contentContainerRef.current) {\n const observer = new ResizeObserver(\n requestAnimation(() => {\n if (!contentContainerRef.current) {\n return;\n }\n const isScrollable =\n contentContainerRef.current.scrollHeight > contentContainerRef.current.clientHeight;\n const hasScroll = isScrollable && !checkIsScrolledToBottom(contentContainerRef.current);\n bottomDividerVisibleRef.current = hasScroll;\n bottomDividerContainerRef.current?.classList.toggle(\n styles.dividerContainerHidden,\n !bottomDividerVisibleRef.current\n );\n updateHeaderDimensions();\n })\n );\n observer.observe(contentContainerRef.current);\n return () => observer.disconnect();\n }\n\n return undefined;\n }, [updateHeaderDimensions]);\n\n useLayoutEffect(() => {\n updateHeaderDimensions();\n if (!options && headerImage) {\n topDividerContainerRef.current?.classList.toggle(styles.dividerContainerHidden, true);\n }\n }, [headerImage, updateHeaderDimensions, options]);\n\n const handleScroll = () => {\n if (!contentContainerRef.current) {\n return;\n }\n\n bottomDividerVisibleRef.current = !checkIsScrolledToBottom(contentContainerRef.current);\n bottomDividerContainerRef.current?.classList.toggle(\n styles.dividerContainerHidden,\n !bottomDividerVisibleRef.current\n );\n topDividerContainerRef.current?.classList.toggle(styles.dividerContainerHidden, !isTopDividerVisible());\n if (headerImageRef.current) {\n shrinkByDelta(\n headerImageContainerRef.current,\n headerWrapperRef.current,\n minHeaderHeightRef.current,\n headerHeightRef.current,\n contentContainerRef.current.scrollTop\n );\n }\n };\n\n return (\n <>\n <div\n className={classnames(styles.modalContentWrapper, {\n [styles.modalContentWrapperOneLine]: onlyActions,\n })}\n >\n <ModalHeader\n {...modalHeaderProps}\n headerHeight={headerHeightRef.current}\n labelId={labelId}\n wrapperRef={headerWrapperRef}\n ref={headerImageContainerRef}\n />\n <div\n className={classnames(styles.dividerContainer, {\n [styles.dividerContainerHidden]: !isTopDividerVisible(),\n })}\n ref={topDividerContainerRef}\n >\n <Divider />\n </div>\n <div\n className={classnames(styles.modalContent)}\n ref={contentContainerRef}\n onScroll={handleScroll}\n data-qa=\"modal-content-scroll-container\"\n >\n {isTreeSelectorChild ? (\n children\n ) : (\n <>\n <div className={styles.contentStickyContainer} ref={stickyContainerRef}>\n {children}\n </div>\n <div ref={spacePreserverRef} />\n </>\n )}\n </div>\n </div>\n <div\n className={classnames(styles.dividerContainer, {\n [styles.dividerContainerHidden]: !bottomDividerVisibleRef.current,\n })}\n ref={bottomDividerContainerRef}\n >\n <Divider />\n </div>\n </>\n );\n};\n"],"names":["_jsxs","_Fragment","_jsx"],"mappings":"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"}
|
|
@@ -5,6 +5,6 @@ import 'classnames';
|
|
|
5
5
|
import '@hh.ru/magritte-common-func-utils';
|
|
6
6
|
import '@hh.ru/magritte-ui-divider';
|
|
7
7
|
import './ModalHeader.js';
|
|
8
|
-
export { M as ModalContentWithHeader } from './ModalContentWithHeader-
|
|
8
|
+
export { M as ModalContentWithHeader } from './ModalContentWithHeader-BQmiz6P-.js';
|
|
9
9
|
import '@hh.ru/magritte-ui-title';
|
|
10
10
|
//# sourceMappingURL=ModalContentWithHeader.js.map
|
package/ModalHeader.js
CHANGED
|
@@ -4,7 +4,7 @@ import { forwardRef } from 'react';
|
|
|
4
4
|
import classnames from 'classnames';
|
|
5
5
|
import { Title } from '@hh.ru/magritte-ui-title';
|
|
6
6
|
|
|
7
|
-
var styles = {"content":"magritte-content___o6ktq_5-0-
|
|
7
|
+
var styles = {"content":"magritte-content___o6ktq_5-0-2","options":"magritte-options___qfErQ_5-0-2","actions":"magritte-actions___nQILV_5-0-2","actions-with-link":"magritte-actions-with-link___hnDux_5-0-2","actionsWithLink":"magritte-actions-with-link___hnDux_5-0-2","content-with-image":"magritte-content-with-image___YarBO_5-0-2","contentWithImage":"magritte-content-with-image___YarBO_5-0-2","actions-single":"magritte-actions-single___usfKu_5-0-2","actionsSingle":"magritte-actions-single___usfKu_5-0-2","image-container":"magritte-image-container___ioL3y_5-0-2","imageContainer":"magritte-image-container___ioL3y_5-0-2","title-wrapper":"magritte-title-wrapper___O--QR_5-0-2","titleWrapper":"magritte-title-wrapper___O--QR_5-0-2","wrapper":"magritte-wrapper___zH8vB_5-0-2"};
|
|
8
8
|
|
|
9
9
|
const ModalHeader = forwardRef(({ title, headerImage, headerHeight, titleAlignment, titleElement, titleMaxLines, titleSize, titleDescription, titleDescriptionMaxLines, titleStyle, titleDescriptionStyle, options, actions: _actions, actionLink, labelId, wrapperRef, }, ref) => {
|
|
10
10
|
const actions = Array.isArray(_actions) ? _actions.slice(0, 5) : _actions;
|
package/index.css
CHANGED
|
@@ -1,23 +1,23 @@
|
|
|
1
1
|
:root{
|
|
2
|
-
--magritte-color-component-modal-background-action-v19-
|
|
3
|
-
--magritte-gradient-component-modal-background-fade-v19-
|
|
2
|
+
--magritte-color-component-modal-background-action-v19-1-0:#20262b99;
|
|
3
|
+
--magritte-gradient-component-modal-background-fade-v19-1-0:linear-gradient(180deg, #00000000 0%, #0000007a 100%);
|
|
4
4
|
}
|
|
5
5
|
:root{
|
|
6
|
-
--magritte-static-border-radius-300-v19-
|
|
7
|
-
--magritte-static-border-radius-400-v19-
|
|
6
|
+
--magritte-static-border-radius-300-v19-1-0:12px;
|
|
7
|
+
--magritte-static-border-radius-400-v19-1-0:16px;
|
|
8
8
|
}
|
|
9
9
|
.magritte-night-theme{
|
|
10
|
-
--magritte-color-component-modal-background-action-v19-
|
|
11
|
-
--magritte-gradient-component-modal-background-fade-v19-
|
|
10
|
+
--magritte-color-component-modal-background-action-v19-1-0:#20262b99;
|
|
11
|
+
--magritte-gradient-component-modal-background-fade-v19-1-0:linear-gradient(180deg, #00000000 0%, #0000007a 100%);
|
|
12
12
|
}
|
|
13
|
-
.magritte-content___o6ktq_5-0-
|
|
13
|
+
.magritte-content___o6ktq_5-0-2{
|
|
14
14
|
display:flex;
|
|
15
15
|
align-items:flex-start;
|
|
16
16
|
}
|
|
17
|
-
.magritte-content___o6ktq_5-0-
|
|
17
|
+
.magritte-content___o6ktq_5-0-2 + .magritte-options___qfErQ_5-0-2{
|
|
18
18
|
margin-top:24px;
|
|
19
19
|
}
|
|
20
|
-
.magritte-actions___nQILV_5-0-
|
|
20
|
+
.magritte-actions___nQILV_5-0-2{
|
|
21
21
|
position:relative;
|
|
22
22
|
z-index:1;
|
|
23
23
|
display:flex;
|
|
@@ -26,65 +26,65 @@
|
|
|
26
26
|
margin-left:auto;
|
|
27
27
|
--magritte-ui-link-padding-override:9px;
|
|
28
28
|
}
|
|
29
|
-
.magritte-actions-with-link___hnDux_5-0-
|
|
29
|
+
.magritte-actions-with-link___hnDux_5-0-2{
|
|
30
30
|
padding:0 8px 0 28px;
|
|
31
31
|
}
|
|
32
|
-
.magritte-content-with-image___YarBO_5-0-
|
|
32
|
+
.magritte-content-with-image___YarBO_5-0-2{
|
|
33
33
|
position:relative;
|
|
34
34
|
flex-direction:column;
|
|
35
35
|
justify-content:flex-end;
|
|
36
36
|
margin:-12px -12px 0;
|
|
37
|
-
border-radius:var(--magritte-static-border-radius-400-v19-
|
|
37
|
+
border-radius:var(--magritte-static-border-radius-400-v19-1-0);
|
|
38
38
|
overflow:hidden;
|
|
39
39
|
padding:12px 24px 24px;
|
|
40
40
|
box-sizing:border-box;
|
|
41
41
|
}
|
|
42
|
-
.magritte-content-with-image___YarBO_5-0-
|
|
42
|
+
.magritte-content-with-image___YarBO_5-0-2 .magritte-actions___nQILV_5-0-2{
|
|
43
43
|
order:-1;
|
|
44
44
|
gap:0;
|
|
45
45
|
margin-right:-16px;
|
|
46
46
|
margin-top:-4px;
|
|
47
47
|
margin-bottom:auto;
|
|
48
48
|
}
|
|
49
|
-
.magritte-content-with-image___YarBO_5-0-
|
|
49
|
+
.magritte-content-with-image___YarBO_5-0-2 .magritte-actions___nQILV_5-0-2:not(.magritte-actions-with-link___hnDux_5-0-2){
|
|
50
50
|
padding:0 4px;
|
|
51
|
-
background-color:var(--magritte-color-component-modal-background-action-v19-
|
|
52
|
-
border-radius:var(--magritte-static-border-radius-300-v19-
|
|
51
|
+
background-color:var(--magritte-color-component-modal-background-action-v19-1-0);
|
|
52
|
+
border-radius:var(--magritte-static-border-radius-300-v19-1-0);
|
|
53
53
|
}
|
|
54
|
-
.magritte-content-with-image___YarBO_5-0-
|
|
54
|
+
.magritte-content-with-image___YarBO_5-0-2 .magritte-actions___nQILV_5-0-2.magritte-actions-single___usfKu_5-0-2:not(.magritte-actions-with-link___hnDux_5-0-2){
|
|
55
55
|
padding:0;
|
|
56
56
|
}
|
|
57
|
-
.magritte-image-container___ioL3y_5-0-
|
|
57
|
+
.magritte-image-container___ioL3y_5-0-2{
|
|
58
58
|
position:absolute;
|
|
59
59
|
left:0;
|
|
60
60
|
bottom:0;
|
|
61
61
|
right:0;
|
|
62
62
|
background-size:cover;
|
|
63
|
-
--modal-header-gradient:var(--magritte-gradient-component-modal-background-fade-v19-
|
|
63
|
+
--modal-header-gradient:var(--magritte-gradient-component-modal-background-fade-v19-1-0);
|
|
64
64
|
}
|
|
65
|
-
.magritte-title-wrapper___O--QR_5-0-
|
|
65
|
+
.magritte-title-wrapper___O--QR_5-0-2{
|
|
66
66
|
position:relative;
|
|
67
67
|
}
|
|
68
|
-
.magritte-wrapper___zH8vB_5-0-
|
|
68
|
+
.magritte-wrapper___zH8vB_5-0-2{
|
|
69
69
|
margin-bottom:24px;
|
|
70
70
|
}
|
|
71
71
|
|
|
72
72
|
:root{
|
|
73
|
-
--magritte-color-background-overlay-v19-
|
|
74
|
-
--magritte-color-component-modal-background-content-v19-
|
|
73
|
+
--magritte-color-background-overlay-v19-1-0:#20262b99;
|
|
74
|
+
--magritte-color-component-modal-background-content-v19-1-0:#ffffff;
|
|
75
75
|
}
|
|
76
76
|
:root{
|
|
77
|
-
--magritte-semantic-animation-ease-in-out-200-timing-function-v19-
|
|
78
|
-
--magritte-semantic-animation-ease-in-out-200-duration-v19-
|
|
79
|
-
--magritte-semantic-animation-ease-in-out-300-timing-function-v19-
|
|
80
|
-
--magritte-semantic-animation-ease-in-out-300-duration-v19-
|
|
81
|
-
--magritte-static-border-radius-600-v19-
|
|
77
|
+
--magritte-semantic-animation-ease-in-out-200-timing-function-v19-1-0:cubic-bezier(0.25, 0.1, 0.25, 1);
|
|
78
|
+
--magritte-semantic-animation-ease-in-out-200-duration-v19-1-0:200ms;
|
|
79
|
+
--magritte-semantic-animation-ease-in-out-300-timing-function-v19-1-0:cubic-bezier(0.25, 0.1, 0.25, 1);
|
|
80
|
+
--magritte-semantic-animation-ease-in-out-300-duration-v19-1-0:300ms;
|
|
81
|
+
--magritte-static-border-radius-600-v19-1-0:24px;
|
|
82
82
|
}
|
|
83
83
|
.magritte-night-theme{
|
|
84
|
-
--magritte-color-background-overlay-v19-
|
|
85
|
-
--magritte-color-component-modal-background-content-v19-
|
|
84
|
+
--magritte-color-background-overlay-v19-1-0:#20262b99;
|
|
85
|
+
--magritte-color-component-modal-background-content-v19-1-0:#1B1B1B;
|
|
86
86
|
}
|
|
87
|
-
.magritte-modal-overlay___lK22l_5-0-
|
|
87
|
+
.magritte-modal-overlay___lK22l_5-0-2{
|
|
88
88
|
position:fixed;
|
|
89
89
|
top:0;
|
|
90
90
|
right:0;
|
|
@@ -93,11 +93,11 @@
|
|
|
93
93
|
display:flex;
|
|
94
94
|
align-items:center;
|
|
95
95
|
justify-content:center;
|
|
96
|
-
background-color:var(--magritte-color-background-overlay-v19-
|
|
96
|
+
background-color:var(--magritte-color-background-overlay-v19-1-0);
|
|
97
97
|
z-index:1;
|
|
98
98
|
user-select:text;
|
|
99
99
|
}
|
|
100
|
-
.magritte-modal___RAW6S_5-0-
|
|
100
|
+
.magritte-modal___RAW6S_5-0-2{
|
|
101
101
|
display:flex;
|
|
102
102
|
box-sizing:border-box;
|
|
103
103
|
margin:0 20px;
|
|
@@ -105,113 +105,113 @@
|
|
|
105
105
|
flex-direction:column;
|
|
106
106
|
max-height:calc(100vh - 24px * 2);
|
|
107
107
|
position:relative;
|
|
108
|
-
background-color:var(--magritte-color-component-modal-background-content-v19-
|
|
109
|
-
border-radius:var(--magritte-static-border-radius-600-v19-
|
|
108
|
+
background-color:var(--magritte-color-component-modal-background-content-v19-1-0);
|
|
109
|
+
border-radius:var(--magritte-static-border-radius-600-v19-1-0);
|
|
110
110
|
overflow:hidden;
|
|
111
111
|
width:800px;
|
|
112
112
|
}
|
|
113
|
-
.magritte-modal___RAW6S_5-0-
|
|
113
|
+
.magritte-modal___RAW6S_5-0-2.magritte-size-small___2JTM2_5-0-2{
|
|
114
114
|
width:460px;
|
|
115
115
|
}
|
|
116
|
-
.magritte-modal___RAW6S_5-0-
|
|
116
|
+
.magritte-modal___RAW6S_5-0-2.magritte-size-medium___cWCe7_5-0-2{
|
|
117
117
|
width:600px;
|
|
118
118
|
}
|
|
119
|
-
.magritte-no-vertical-paddings___Z3-oM_5-0-
|
|
119
|
+
.magritte-no-vertical-paddings___Z3-oM_5-0-2{
|
|
120
120
|
padding-top:0;
|
|
121
121
|
padding-bottom:0;
|
|
122
122
|
}
|
|
123
|
-
.magritte-no-horizontal-paddings___aT95Y_5-0-
|
|
123
|
+
.magritte-no-horizontal-paddings___aT95Y_5-0-2{
|
|
124
124
|
padding-left:0;
|
|
125
125
|
padding-right:0;
|
|
126
126
|
}
|
|
127
|
-
.magritte-modal-full-height___gIM4E_5-0-
|
|
127
|
+
.magritte-modal-full-height___gIM4E_5-0-2{
|
|
128
128
|
height:100%;
|
|
129
129
|
}
|
|
130
|
-
.magritte-modal-content___46QFS_5-0-
|
|
130
|
+
.magritte-modal-content___46QFS_5-0-2{
|
|
131
131
|
flex:1 1;
|
|
132
132
|
overflow-y:auto;
|
|
133
133
|
padding:0 5px;
|
|
134
134
|
margin:0 -5px;
|
|
135
135
|
overscroll-behavior:none;
|
|
136
136
|
}
|
|
137
|
-
.magritte-modal-content-wrapper___23XFT_5-0-
|
|
137
|
+
.magritte-modal-content-wrapper___23XFT_5-0-2{
|
|
138
138
|
display:flex;
|
|
139
139
|
flex-direction:column;
|
|
140
140
|
min-height:0;
|
|
141
141
|
flex:1 1;
|
|
142
142
|
}
|
|
143
|
-
.magritte-modal-content-wrapper__one-line___tYg8d_5-0-
|
|
143
|
+
.magritte-modal-content-wrapper__one-line___tYg8d_5-0-2{
|
|
144
144
|
flex-direction:row-reverse;
|
|
145
145
|
}
|
|
146
|
-
.magritte-divider-container___qP3VK_5-0-
|
|
146
|
+
.magritte-divider-container___qP3VK_5-0-2{
|
|
147
147
|
margin:0 -24px;
|
|
148
148
|
}
|
|
149
|
-
.magritte-divider-container___qP3VK_5-0-
|
|
149
|
+
.magritte-divider-container___qP3VK_5-0-2.magritte-divider-container-hidden___EIxB-_5-0-2{
|
|
150
150
|
display:none;
|
|
151
151
|
}
|
|
152
|
-
.magritte-modal-footer___8xPqQ_5-0-
|
|
152
|
+
.magritte-modal-footer___8xPqQ_5-0-2{
|
|
153
153
|
margin:0 -24px -24px;
|
|
154
|
-
background-color:var(--magritte-color-component-modal-background-content-v19-
|
|
154
|
+
background-color:var(--magritte-color-component-modal-background-content-v19-1-0);
|
|
155
155
|
z-index:1;
|
|
156
156
|
}
|
|
157
|
-
.magritte-modal-buttons-container___1O1Nr_5-0-
|
|
157
|
+
.magritte-modal-buttons-container___1O1Nr_5-0-2{
|
|
158
158
|
display:flex;
|
|
159
159
|
gap:12px;
|
|
160
160
|
}
|
|
161
|
-
.magritte-animation-timeout___w-j7K_5-0-
|
|
162
|
-
.magritte-modal-animation-enter-active___E8KLu_5-0-
|
|
163
|
-
.magritte-modal-animation-exit-active___ERjKa_5-0-
|
|
161
|
+
.magritte-animation-timeout___w-j7K_5-0-2,
|
|
162
|
+
.magritte-modal-animation-enter-active___E8KLu_5-0-2,
|
|
163
|
+
.magritte-modal-animation-exit-active___ERjKa_5-0-2{
|
|
164
164
|
--enter-animation-duration:0;
|
|
165
165
|
--exit-animation-duration:0;
|
|
166
166
|
}
|
|
167
167
|
@media (prefers-reduced-motion: no-preference){
|
|
168
|
-
.magritte-animation-timeout___w-j7K_5-0-
|
|
169
|
-
.magritte-modal-animation-enter-active___E8KLu_5-0-
|
|
170
|
-
.magritte-modal-animation-exit-active___ERjKa_5-0-
|
|
171
|
-
--enter-animation-duration:var(--magritte-semantic-animation-ease-in-out-300-duration-v19-
|
|
172
|
-
--exit-animation-duration:var(--magritte-semantic-animation-ease-in-out-200-duration-v19-
|
|
168
|
+
.magritte-animation-timeout___w-j7K_5-0-2,
|
|
169
|
+
.magritte-modal-animation-enter-active___E8KLu_5-0-2,
|
|
170
|
+
.magritte-modal-animation-exit-active___ERjKa_5-0-2{
|
|
171
|
+
--enter-animation-duration:var(--magritte-semantic-animation-ease-in-out-300-duration-v19-1-0);
|
|
172
|
+
--exit-animation-duration:var(--magritte-semantic-animation-ease-in-out-200-duration-v19-1-0);
|
|
173
173
|
}
|
|
174
174
|
}
|
|
175
|
-
.magritte-modal-animation-enter___kruLO_5-0-
|
|
175
|
+
.magritte-modal-animation-enter___kruLO_5-0-2.magritte-modal-overlay___lK22l_5-0-2{
|
|
176
176
|
opacity:0;
|
|
177
177
|
}
|
|
178
|
-
.magritte-modal-animation-enter___kruLO_5-0-
|
|
178
|
+
.magritte-modal-animation-enter___kruLO_5-0-2 .magritte-modal___RAW6S_5-0-2{
|
|
179
179
|
opacity:0;
|
|
180
180
|
transform:scale(0.96);
|
|
181
181
|
}
|
|
182
|
-
.magritte-modal-animation-enter-active___E8KLu_5-0-
|
|
183
|
-
.magritte-modal-animation-enter-active___E8KLu_5-0-
|
|
182
|
+
.magritte-modal-animation-enter-active___E8KLu_5-0-2 .magritte-modal___RAW6S_5-0-2,
|
|
183
|
+
.magritte-modal-animation-enter-active___E8KLu_5-0-2.magritte-modal-overlay___lK22l_5-0-2{
|
|
184
184
|
opacity:1;
|
|
185
185
|
transform:scale(1);
|
|
186
186
|
transition-property:opacity, transform;
|
|
187
187
|
transition-duration:var(--enter-animation-duration);
|
|
188
|
-
transition-timing-function:var(--magritte-semantic-animation-ease-in-out-300-timing-function-v19-
|
|
188
|
+
transition-timing-function:var(--magritte-semantic-animation-ease-in-out-300-timing-function-v19-1-0);
|
|
189
189
|
}
|
|
190
|
-
.magritte-modal-animation-exit___0jNgl_5-0-
|
|
190
|
+
.magritte-modal-animation-exit___0jNgl_5-0-2.magritte-modal-overlay___lK22l_5-0-2{
|
|
191
191
|
opacity:1;
|
|
192
192
|
}
|
|
193
|
-
.magritte-modal-animation-exit___0jNgl_5-0-
|
|
193
|
+
.magritte-modal-animation-exit___0jNgl_5-0-2 .magritte-modal___RAW6S_5-0-2{
|
|
194
194
|
opacity:1;
|
|
195
195
|
transform:scale(1);
|
|
196
196
|
}
|
|
197
|
-
.magritte-modal-animation-exit-active___ERjKa_5-0-
|
|
197
|
+
.magritte-modal-animation-exit-active___ERjKa_5-0-2.magritte-modal-overlay___lK22l_5-0-2{
|
|
198
198
|
opacity:0;
|
|
199
199
|
}
|
|
200
|
-
.magritte-modal-animation-exit-active___ERjKa_5-0-
|
|
200
|
+
.magritte-modal-animation-exit-active___ERjKa_5-0-2 .magritte-modal___RAW6S_5-0-2{
|
|
201
201
|
opacity:0;
|
|
202
202
|
transform:scale(0.96);
|
|
203
203
|
}
|
|
204
|
-
.magritte-modal-animation-exit-active___ERjKa_5-0-
|
|
205
|
-
.magritte-modal-animation-exit-active___ERjKa_5-0-
|
|
204
|
+
.magritte-modal-animation-exit-active___ERjKa_5-0-2 .magritte-modal___RAW6S_5-0-2,
|
|
205
|
+
.magritte-modal-animation-exit-active___ERjKa_5-0-2.magritte-modal-overlay___lK22l_5-0-2{
|
|
206
206
|
transition-property:opacity, transform;
|
|
207
207
|
transition-duration:var(--exit-animation-duration);
|
|
208
|
-
transition-timing-function:var(--magritte-semantic-animation-ease-in-out-200-timing-function-v19-
|
|
208
|
+
transition-timing-function:var(--magritte-semantic-animation-ease-in-out-200-timing-function-v19-1-0);
|
|
209
209
|
}
|
|
210
|
-
.magritte-content-scroll-preserver___Tw5Px_5-0-
|
|
210
|
+
.magritte-content-scroll-preserver___Tw5Px_5-0-2{
|
|
211
211
|
width:100%;
|
|
212
212
|
height:0;
|
|
213
213
|
}
|
|
214
|
-
.magritte-content-sticky-container___nqEXj_5-0-
|
|
214
|
+
.magritte-content-sticky-container___nqEXj_5-0-2{
|
|
215
215
|
position:sticky;
|
|
216
216
|
top:0;
|
|
217
217
|
min-height:100%;
|
package/index.js
CHANGED
|
@@ -15,7 +15,7 @@ import '@hh.ru/magritte-internal-layer-name';
|
|
|
15
15
|
import '@hh.ru/magritte-ui-action-bar';
|
|
16
16
|
import '@hh.ru/magritte-ui-breakpoint';
|
|
17
17
|
import '@hh.ru/magritte-ui-layer';
|
|
18
|
-
import './ModalContentWithHeader-
|
|
18
|
+
import './ModalContentWithHeader-BQmiz6P-.js';
|
|
19
19
|
import '@hh.ru/magritte-common-func-utils';
|
|
20
20
|
import '@hh.ru/magritte-ui-divider';
|
|
21
21
|
import './ModalHeader.js';
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@hh.ru/magritte-ui-modal",
|
|
3
|
-
"version": "5.0.
|
|
3
|
+
"version": "5.0.2",
|
|
4
4
|
"main": "index.js",
|
|
5
5
|
"types": "index.d.ts",
|
|
6
6
|
"sideEffects": [
|
|
@@ -27,18 +27,18 @@
|
|
|
27
27
|
"@hh.ru/magritte-common-modal-helper": "1.2.7",
|
|
28
28
|
"@hh.ru/magritte-common-use-multiple-refs": "1.1.4",
|
|
29
29
|
"@hh.ru/magritte-common-use-no-bubbling": "1.0.1",
|
|
30
|
-
"@hh.ru/magritte-design-tokens": "19.
|
|
30
|
+
"@hh.ru/magritte-design-tokens": "19.1.0",
|
|
31
31
|
"@hh.ru/magritte-internal-layer-name": "2.2.0",
|
|
32
|
-
"@hh.ru/magritte-ui-action": "4.4.
|
|
33
|
-
"@hh.ru/magritte-ui-action-bar": "2.2.
|
|
32
|
+
"@hh.ru/magritte-ui-action": "4.4.10",
|
|
33
|
+
"@hh.ru/magritte-ui-action-bar": "2.2.2",
|
|
34
34
|
"@hh.ru/magritte-ui-breakpoint": "4.0.3",
|
|
35
|
-
"@hh.ru/magritte-ui-divider": "1.1.
|
|
36
|
-
"@hh.ru/magritte-ui-icon": "7.
|
|
35
|
+
"@hh.ru/magritte-ui-divider": "1.1.33",
|
|
36
|
+
"@hh.ru/magritte-ui-icon": "7.9.0",
|
|
37
37
|
"@hh.ru/magritte-ui-layer": "2.0.6",
|
|
38
38
|
"@hh.ru/magritte-ui-mock-component": "1.0.11",
|
|
39
|
-
"@hh.ru/magritte-ui-theme-provider": "1.1.
|
|
40
|
-
"@hh.ru/magritte-ui-title": "5.0.
|
|
41
|
-
"@hh.ru/magritte-ui-tree-selector": "4.4.
|
|
39
|
+
"@hh.ru/magritte-ui-theme-provider": "1.1.29",
|
|
40
|
+
"@hh.ru/magritte-ui-title": "5.0.7",
|
|
41
|
+
"@hh.ru/magritte-ui-tree-selector": "4.4.9"
|
|
42
42
|
},
|
|
43
43
|
"peerDependencies": {
|
|
44
44
|
"classnames": ">=2.3.2",
|
|
@@ -49,5 +49,5 @@
|
|
|
49
49
|
"publishConfig": {
|
|
50
50
|
"access": "public"
|
|
51
51
|
},
|
|
52
|
-
"gitHead": "
|
|
52
|
+
"gitHead": "b3e0588e408e619e64868eff34e01e3d07260b2d"
|
|
53
53
|
}
|