@hh.ru/magritte-ui-drop 12.1.3 → 12.2.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/Drop.js CHANGED
@@ -1,10 +1,10 @@
1
1
  import './index.css';
2
2
  import { jsx, jsxs } from 'react/jsx-runtime';
3
- import { forwardRef, useState, useRef, useEffect, cloneElement } from 'react';
3
+ import { forwardRef, useState, useRef, useEffect, useCallback, cloneElement } from 'react';
4
4
  import { usePlacement, DropBase } from '@hh.ru/magritte-internal-drop-base';
5
5
  import { isActionBarComponent } from '@hh.ru/magritte-ui-action-bar';
6
6
  import { useBreakpoint } from '@hh.ru/magritte-ui-breakpoint';
7
- import { s as styles, D as DropContainer } from './DropContainer-DGf8vK7N.js';
7
+ import { s as styles, D as DropContainer } from './DropContainer-OMwBRGe4.js';
8
8
  import { Layer } from '@hh.ru/magritte-ui-layer';
9
9
  import 'classnames';
10
10
  import '@hh.ru/magritte-common-use-multiple-refs';
@@ -29,7 +29,7 @@ const isKeyboardInput = (element) => {
29
29
  tagName === 'textarea' ||
30
30
  element.hasAttribute('contenteditable'));
31
31
  };
32
- const DropComponent = ({ visible, activatorRef, onClose, maxWidth = 320, minHeight = 200, width, children, footer, role = 'dialog', showDivider = 'with-scroll', widthEqualToActivator = false, allowShrinkHeightToFitIntoViewport = true, autoFocusWhenOpened, closeByClickOutside = true, 'data-qa': dataQA = 'drop', onAppear, onBeforeExit, onAfterExit, placement, forcePlacement, ignoreIntersections, lockPlacement = false, padding = 24, paddingLeft, paddingRight, paddingTop, paddingBottom, paddingFooter, paddingFooterLeft, paddingFooterRight, paddingFooterBottom, paddingFooterTop, ...props }, ref) => {
32
+ const DropComponent = ({ visible, activatorRef, onClose, maxWidth = 320, minHeight = 200, width, children, footer, role = 'dialog', showDivider = 'with-scroll', widthEqualToActivator = false, allowShrinkHeightToFitIntoViewport = true, autoFocusWhenOpened, closeByClickOutside = true, 'data-qa': dataQA = 'drop', onAppear, onBeforeExit, onAfterExit: _onAfterExit, placement, forcePlacement, ignoreIntersections, lockPlacement = false, padding = 24, paddingLeft, paddingRight, paddingTop, paddingBottom, paddingFooter, paddingFooterLeft, paddingFooterRight, paddingFooterBottom, paddingFooterTop, keyboardNavigationMode = 'loop', returnFocusOnClose = true, ...props }, ref) => {
33
33
  const { isMobile } = useBreakpoint();
34
34
  const [animationTimeout, setAnimationTimeout] = useState(200);
35
35
  const [isPlacementLockedByFocus, setPlacementLockedByFocus] = useState(false);
@@ -83,6 +83,12 @@ const DropComponent = ({ visible, activatorRef, onClose, maxWidth = 320, minHeig
83
83
  activatorElement.removeEventListener('blur', blurHandler);
84
84
  };
85
85
  }, [visible, activatorRef, isMobile]);
86
+ const onAfterExit = useCallback(() => {
87
+ if (returnFocusOnClose && activatorRef.current !== null && document.contains(activatorRef.current)) {
88
+ activatorRef.current.focus();
89
+ }
90
+ _onAfterExit?.();
91
+ }, [returnFocusOnClose, activatorRef, _onAfterExit]);
86
92
  if (isMobile) {
87
93
  return null;
88
94
  }
@@ -114,7 +120,7 @@ const DropComponent = ({ visible, activatorRef, onClose, maxWidth = 320, minHeig
114
120
  enterActive: styles.dropEnterActive,
115
121
  exit: styles.dropExit,
116
122
  exitActive: styles.dropExitActive,
117
- }, animationTimeout: animationTimeout, widthEqualToActivator: widthEqualToActivator, allowShrinkHeightToFitIntoViewport: allowShrinkHeightToFitIntoViewport, ignoreIntersections: actualIgnoreIntersections, minHeight: minHeight, ref: ref, onAppear: onAppear, onBeforeExit: onBeforeExit, onAfterExit: onAfterExit, forceDropMetricsUpdate: forceUpdateDropMetricsRef, lockPlacement: isPlacementLockedByFocus || lockPlacement, children: (resizeRefCallbackFactory) => (jsxs("div", { className: styles.drop, style: widthStyle, "data-qa": dataQA, onFocus: focusHandler, onBlur: blurHandler, children: [jsx(DropContainer, { showDivider: footer ? showDivider : false, ref: resizeRefCallbackFactory('scroll-container', false, true), padding: { padding, ...contentPaddingProps }, withFooter: Boolean(footer), children: jsx("div", { ref: resizeRefCallbackFactory('drop-content'), children: children }) }, "drop-container"), footer && (jsx("div", { ref: resizeRefCallbackFactory('drop-footer'), "data-qa": "drop-footer", style: { padding: paddingFooter ?? padding, ...footerPaddingProps }, children: isActionBarComponent(footer)
123
+ }, animationTimeout: animationTimeout, widthEqualToActivator: widthEqualToActivator, allowShrinkHeightToFitIntoViewport: allowShrinkHeightToFitIntoViewport, ignoreIntersections: actualIgnoreIntersections, minHeight: minHeight, ref: ref, onAppear: onAppear, onBeforeExit: onBeforeExit, onAfterExit: onAfterExit, forceDropMetricsUpdate: forceUpdateDropMetricsRef, lockPlacement: isPlacementLockedByFocus || lockPlacement, keyboardNavigationMode: keyboardNavigationMode, children: (resizeRefCallbackFactory) => (jsxs("div", { className: styles.drop, style: widthStyle, "data-qa": dataQA, onFocus: focusHandler, onBlur: blurHandler, children: [jsx(DropContainer, { showDivider: footer ? showDivider : false, ref: resizeRefCallbackFactory('scroll-container', false, true), padding: { padding, ...contentPaddingProps }, withFooter: Boolean(footer), children: jsx("div", { ref: resizeRefCallbackFactory('drop-content'), children: children }) }, "drop-container"), footer && (jsx("div", { ref: resizeRefCallbackFactory('drop-footer'), "data-qa": "drop-footer", style: { padding: paddingFooter ?? padding, ...footerPaddingProps }, children: isActionBarComponent(footer)
118
124
  ? cloneElement(footer, {
119
125
  type: footer.props.type || 'vertical',
120
126
  padding: footer.props.padding || 0,
package/Drop.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"Drop.js","sources":["../src/Drop.tsx"],"sourcesContent":["import {\n useEffect,\n useState,\n type ReactElement,\n ForwardedRef,\n forwardRef,\n useRef,\n RefObject,\n CSSProperties,\n type FocusEvent,\n cloneElement,\n} from 'react';\n\nimport { DropBase, type Placement, usePlacement } from '@hh.ru/magritte-internal-drop-base';\nimport { isActionBarComponent } from '@hh.ru/magritte-ui-action-bar';\nimport { useBreakpoint } from '@hh.ru/magritte-ui-breakpoint';\nimport { DropContainer } from '@hh.ru/magritte-ui-drop/DropContainer';\nimport type { DropProps, DropPadding } from '@hh.ru/magritte-ui-drop/types';\nimport { Layer } from '@hh.ru/magritte-ui-layer';\n\nimport styles from './drop.less';\n\nconst AVAILABLE_PLACEMENTS_LIST: Set<Placement> = new Set([\n 'left-top',\n 'left-bottom',\n 'right-top',\n 'right-bottom',\n 'top-left',\n 'top-right',\n 'bottom-left',\n 'bottom-right',\n]);\n\nconst genPaddingProps = (paddingProps: {\n Left?: DropPadding;\n Right?: DropPadding;\n Top?: DropPadding;\n Bottom?: DropPadding;\n}) =>\n Object.entries(paddingProps).reduce<Record<string, number>>(\n (acc, [key, value]) => (value !== undefined ? { ...acc, [`padding${key}`]: value } : acc),\n {}\n );\n\nconst isKeyboardInput = (element: HTMLElement): boolean => {\n const tagName = element.tagName.toLowerCase();\n const keyboardInputTypes = ['text', 'password', 'email', 'number', 'tel', 'url', 'search'];\n return (\n (tagName === 'input' && keyboardInputTypes.includes((element as HTMLInputElement).type)) ||\n tagName === 'textarea' ||\n element.hasAttribute('contenteditable')\n );\n};\n\nconst DropComponent = (\n {\n visible,\n activatorRef,\n onClose,\n maxWidth = 320,\n minHeight = 200,\n width,\n children,\n footer,\n role = 'dialog',\n showDivider = 'with-scroll',\n widthEqualToActivator = false,\n allowShrinkHeightToFitIntoViewport = true,\n autoFocusWhenOpened,\n closeByClickOutside = true,\n 'data-qa': dataQA = 'drop',\n onAppear,\n onBeforeExit,\n onAfterExit,\n placement,\n forcePlacement,\n ignoreIntersections,\n lockPlacement = false,\n padding = 24,\n paddingLeft,\n paddingRight,\n paddingTop,\n paddingBottom,\n paddingFooter,\n paddingFooterLeft,\n paddingFooterRight,\n paddingFooterBottom,\n paddingFooterTop,\n ...props\n }: DropProps,\n ref: ForwardedRef<HTMLElement>\n): ReactElement | null => {\n const { isMobile } = useBreakpoint();\n const [animationTimeout, setAnimationTimeout] = useState(200);\n const [isPlacementLockedByFocus, setPlacementLockedByFocus] = useState(false);\n const forceUpdateDropMetricsRef = useRef<VoidFunction>();\n\n const actualIgnoreIntersections =\n ignoreIntersections === undefined ? !allowShrinkHeightToFitIntoViewport : ignoreIntersections;\n\n const placementsList = usePlacement(placement as Placement, AVAILABLE_PLACEMENTS_LIST, !!forcePlacement);\n\n useEffect(() => {\n const animationTimeoutElement = document.createElement('div');\n animationTimeoutElement.classList.add(styles.dropAnimationTimeout);\n document.body.appendChild(animationTimeoutElement);\n const style = window.getComputedStyle(animationTimeoutElement);\n const animationTimeout = parseInt(style.getPropertyValue(`--animation-duration`), 10);\n if (Number.isInteger(animationTimeout)) {\n setAnimationTimeout(animationTimeout);\n }\n document.body.removeChild(animationTimeoutElement);\n }, []);\n\n useEffect(() => {\n forceUpdateDropMetricsRef.current?.();\n }, [\n maxWidth,\n padding,\n paddingLeft,\n paddingRight,\n paddingTop,\n paddingBottom,\n paddingFooter,\n paddingFooterLeft,\n paddingFooterRight,\n paddingFooterTop,\n paddingFooterBottom,\n footer,\n ]);\n\n const focusHandler = (event: Event | FocusEvent) => {\n const target = event.target;\n if (!target || !isKeyboardInput(target as HTMLElement)) {\n return;\n }\n setPlacementLockedByFocus(true);\n };\n const blurHandler = () => setPlacementLockedByFocus(false);\n\n useEffect(() => {\n if (!visible || isMobile || !activatorRef.current) {\n return void 0;\n }\n\n const activatorElement = activatorRef.current;\n activatorElement.addEventListener('focus', focusHandler);\n activatorElement.addEventListener('blur', blurHandler);\n return () => {\n activatorElement.removeEventListener('focus', focusHandler);\n activatorElement.removeEventListener('blur', blurHandler);\n };\n }, [visible, activatorRef, isMobile]);\n\n if (isMobile) {\n return null;\n }\n\n let widthStyle: CSSProperties;\n if (widthEqualToActivator) {\n widthStyle = { width: '100%' };\n } else {\n widthStyle = width ? { width } : { maxWidth };\n }\n\n let currentPaddingBottom = paddingBottom;\n if (footer && currentPaddingBottom === undefined) {\n currentPaddingBottom = 0;\n }\n\n const contentPaddingProps = genPaddingProps({\n Left: paddingLeft,\n Right: paddingRight,\n Top: paddingTop,\n Bottom: currentPaddingBottom,\n });\n\n const footerPaddingProps = genPaddingProps({\n Left: paddingFooterLeft,\n Right: paddingFooterRight,\n Top: paddingFooterTop,\n Bottom: paddingFooterBottom,\n });\n\n return (\n <Layer layer=\"drop\">\n <DropBase\n {...props}\n visible={visible}\n placement={placementsList}\n activatorRef={activatorRef}\n closeByClickOutside={closeByClickOutside}\n onClose={onClose}\n autoFocusWhenOpened={autoFocusWhenOpened ?? role !== 'status'}\n animationClassNames={{\n enter: styles.dropEnter,\n enterActive: styles.dropEnterActive,\n exit: styles.dropExit,\n exitActive: styles.dropExitActive,\n }}\n animationTimeout={animationTimeout}\n widthEqualToActivator={widthEqualToActivator}\n allowShrinkHeightToFitIntoViewport={allowShrinkHeightToFitIntoViewport}\n ignoreIntersections={actualIgnoreIntersections}\n minHeight={minHeight}\n ref={ref}\n onAppear={onAppear}\n onBeforeExit={onBeforeExit}\n onAfterExit={onAfterExit}\n forceDropMetricsUpdate={forceUpdateDropMetricsRef as RefObject<VoidFunction>}\n lockPlacement={isPlacementLockedByFocus || lockPlacement}\n >\n {(resizeRefCallbackFactory) => (\n <div\n className={styles.drop}\n style={widthStyle}\n data-qa={dataQA}\n key=\"drop-outer-container\"\n onFocus={focusHandler}\n onBlur={blurHandler}\n >\n <DropContainer\n key=\"drop-container\"\n showDivider={footer ? showDivider : false}\n ref={resizeRefCallbackFactory('scroll-container', false, true)}\n padding={{ padding, ...contentPaddingProps }}\n withFooter={Boolean(footer)}\n >\n <div ref={resizeRefCallbackFactory('drop-content')}>{children}</div>\n </DropContainer>\n {footer && (\n <div\n ref={resizeRefCallbackFactory('drop-footer')}\n data-qa=\"drop-footer\"\n style={{ padding: paddingFooter ?? padding, ...footerPaddingProps }}\n >\n {isActionBarComponent(footer)\n ? cloneElement(footer, {\n type: footer.props.type || 'vertical',\n padding: footer.props.padding || 0,\n showDivider: false,\n })\n : footer}\n </div>\n )}\n <div className={styles.dropBorder} />\n </div>\n )}\n </DropBase>\n </Layer>\n );\n};\n\nconst Drop = forwardRef<HTMLElement, DropProps>(DropComponent);\nexport { Drop };\n"],"names":["_jsx","_jsxs"],"mappings":"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"}
1
+ {"version":3,"file":"Drop.js","sources":["../src/Drop.tsx"],"sourcesContent":["import {\n type CSSProperties,\n type FocusEvent,\n type ForwardedRef,\n type ReactElement,\n type RefObject,\n cloneElement,\n forwardRef,\n useCallback,\n useEffect,\n useRef,\n useState,\n} from 'react';\n\nimport { DropBase, type Placement, usePlacement } from '@hh.ru/magritte-internal-drop-base';\nimport { isActionBarComponent } from '@hh.ru/magritte-ui-action-bar';\nimport { useBreakpoint } from '@hh.ru/magritte-ui-breakpoint';\nimport { DropContainer } from '@hh.ru/magritte-ui-drop/DropContainer';\nimport type { DropProps, DropPadding } from '@hh.ru/magritte-ui-drop/types';\nimport { Layer } from '@hh.ru/magritte-ui-layer';\n\nimport styles from './drop.less';\n\nconst AVAILABLE_PLACEMENTS_LIST: Set<Placement> = new Set([\n 'left-top',\n 'left-bottom',\n 'right-top',\n 'right-bottom',\n 'top-left',\n 'top-right',\n 'bottom-left',\n 'bottom-right',\n]);\n\nconst genPaddingProps = (paddingProps: {\n Left?: DropPadding;\n Right?: DropPadding;\n Top?: DropPadding;\n Bottom?: DropPadding;\n}) =>\n Object.entries(paddingProps).reduce<Record<string, number>>(\n (acc, [key, value]) => (value !== undefined ? { ...acc, [`padding${key}`]: value } : acc),\n {}\n );\n\nconst isKeyboardInput = (element: HTMLElement): boolean => {\n const tagName = element.tagName.toLowerCase();\n const keyboardInputTypes = ['text', 'password', 'email', 'number', 'tel', 'url', 'search'];\n return (\n (tagName === 'input' && keyboardInputTypes.includes((element as HTMLInputElement).type)) ||\n tagName === 'textarea' ||\n element.hasAttribute('contenteditable')\n );\n};\n\nconst DropComponent = (\n {\n visible,\n activatorRef,\n onClose,\n maxWidth = 320,\n minHeight = 200,\n width,\n children,\n footer,\n role = 'dialog',\n showDivider = 'with-scroll',\n widthEqualToActivator = false,\n allowShrinkHeightToFitIntoViewport = true,\n autoFocusWhenOpened,\n closeByClickOutside = true,\n 'data-qa': dataQA = 'drop',\n onAppear,\n onBeforeExit,\n onAfterExit: _onAfterExit,\n placement,\n forcePlacement,\n ignoreIntersections,\n lockPlacement = false,\n padding = 24,\n paddingLeft,\n paddingRight,\n paddingTop,\n paddingBottom,\n paddingFooter,\n paddingFooterLeft,\n paddingFooterRight,\n paddingFooterBottom,\n paddingFooterTop,\n keyboardNavigationMode = 'loop',\n returnFocusOnClose = true,\n ...props\n }: DropProps,\n ref: ForwardedRef<HTMLElement>\n): ReactElement | null => {\n const { isMobile } = useBreakpoint();\n const [animationTimeout, setAnimationTimeout] = useState(200);\n const [isPlacementLockedByFocus, setPlacementLockedByFocus] = useState(false);\n const forceUpdateDropMetricsRef = useRef<VoidFunction>();\n\n const actualIgnoreIntersections =\n ignoreIntersections === undefined ? !allowShrinkHeightToFitIntoViewport : ignoreIntersections;\n\n const placementsList = usePlacement(placement as Placement, AVAILABLE_PLACEMENTS_LIST, !!forcePlacement);\n\n useEffect(() => {\n const animationTimeoutElement = document.createElement('div');\n animationTimeoutElement.classList.add(styles.dropAnimationTimeout);\n document.body.appendChild(animationTimeoutElement);\n const style = window.getComputedStyle(animationTimeoutElement);\n const animationTimeout = parseInt(style.getPropertyValue(`--animation-duration`), 10);\n if (Number.isInteger(animationTimeout)) {\n setAnimationTimeout(animationTimeout);\n }\n document.body.removeChild(animationTimeoutElement);\n }, []);\n\n useEffect(() => {\n forceUpdateDropMetricsRef.current?.();\n }, [\n maxWidth,\n padding,\n paddingLeft,\n paddingRight,\n paddingTop,\n paddingBottom,\n paddingFooter,\n paddingFooterLeft,\n paddingFooterRight,\n paddingFooterTop,\n paddingFooterBottom,\n footer,\n ]);\n\n const focusHandler = (event: Event | FocusEvent) => {\n const target = event.target;\n if (!target || !isKeyboardInput(target as HTMLElement)) {\n return;\n }\n setPlacementLockedByFocus(true);\n };\n const blurHandler = () => setPlacementLockedByFocus(false);\n\n useEffect(() => {\n if (!visible || isMobile || !activatorRef.current) {\n return void 0;\n }\n\n const activatorElement = activatorRef.current;\n activatorElement.addEventListener('focus', focusHandler);\n activatorElement.addEventListener('blur', blurHandler);\n return () => {\n activatorElement.removeEventListener('focus', focusHandler);\n activatorElement.removeEventListener('blur', blurHandler);\n };\n }, [visible, activatorRef, isMobile]);\n\n const onAfterExit = useCallback(() => {\n if (returnFocusOnClose && activatorRef.current !== null && document.contains(activatorRef.current)) {\n activatorRef.current.focus();\n }\n _onAfterExit?.();\n }, [returnFocusOnClose, activatorRef, _onAfterExit]);\n\n if (isMobile) {\n return null;\n }\n\n let widthStyle: CSSProperties;\n if (widthEqualToActivator) {\n widthStyle = { width: '100%' };\n } else {\n widthStyle = width ? { width } : { maxWidth };\n }\n\n let currentPaddingBottom = paddingBottom;\n if (footer && currentPaddingBottom === undefined) {\n currentPaddingBottom = 0;\n }\n\n const contentPaddingProps = genPaddingProps({\n Left: paddingLeft,\n Right: paddingRight,\n Top: paddingTop,\n Bottom: currentPaddingBottom,\n });\n\n const footerPaddingProps = genPaddingProps({\n Left: paddingFooterLeft,\n Right: paddingFooterRight,\n Top: paddingFooterTop,\n Bottom: paddingFooterBottom,\n });\n\n return (\n <Layer layer=\"drop\">\n <DropBase\n {...props}\n visible={visible}\n placement={placementsList}\n activatorRef={activatorRef}\n closeByClickOutside={closeByClickOutside}\n onClose={onClose}\n autoFocusWhenOpened={autoFocusWhenOpened ?? role !== 'status'}\n animationClassNames={{\n enter: styles.dropEnter,\n enterActive: styles.dropEnterActive,\n exit: styles.dropExit,\n exitActive: styles.dropExitActive,\n }}\n animationTimeout={animationTimeout}\n widthEqualToActivator={widthEqualToActivator}\n allowShrinkHeightToFitIntoViewport={allowShrinkHeightToFitIntoViewport}\n ignoreIntersections={actualIgnoreIntersections}\n minHeight={minHeight}\n ref={ref}\n onAppear={onAppear}\n onBeforeExit={onBeforeExit}\n onAfterExit={onAfterExit}\n forceDropMetricsUpdate={forceUpdateDropMetricsRef as RefObject<VoidFunction>}\n lockPlacement={isPlacementLockedByFocus || lockPlacement}\n keyboardNavigationMode={keyboardNavigationMode}\n >\n {(resizeRefCallbackFactory) => (\n <div\n className={styles.drop}\n style={widthStyle}\n data-qa={dataQA}\n key=\"drop-outer-container\"\n onFocus={focusHandler}\n onBlur={blurHandler}\n >\n <DropContainer\n key=\"drop-container\"\n showDivider={footer ? showDivider : false}\n ref={resizeRefCallbackFactory('scroll-container', false, true)}\n padding={{ padding, ...contentPaddingProps }}\n withFooter={Boolean(footer)}\n >\n <div ref={resizeRefCallbackFactory('drop-content')}>{children}</div>\n </DropContainer>\n {footer && (\n <div\n ref={resizeRefCallbackFactory('drop-footer')}\n data-qa=\"drop-footer\"\n style={{ padding: paddingFooter ?? padding, ...footerPaddingProps }}\n >\n {isActionBarComponent(footer)\n ? cloneElement(footer, {\n type: footer.props.type || 'vertical',\n padding: footer.props.padding || 0,\n showDivider: false,\n })\n : footer}\n </div>\n )}\n <div className={styles.dropBorder} />\n </div>\n )}\n </DropBase>\n </Layer>\n );\n};\n\nconst Drop = forwardRef<HTMLElement, DropProps>(DropComponent);\nexport { Drop };\n"],"names":["_jsx","_jsxs"],"mappings":"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"}
@@ -6,7 +6,7 @@ import { useMultipleRefs } from '@hh.ru/magritte-common-use-multiple-refs';
6
6
  import { Divider } from '@hh.ru/magritte-ui-divider';
7
7
  import { useScrollbar, Scrollbar } from '@hh.ru/magritte-ui-scrollbar';
8
8
 
9
- var styles = {"drop":"magritte-drop___Z10P4_12-1-3","drop-border":"magritte-drop-border___UDWjW_12-1-3","dropBorder":"magritte-drop-border___UDWjW_12-1-3","drop-container-wrapper":"magritte-drop-container-wrapper___o-ySf_12-1-3","dropContainerWrapper":"magritte-drop-container-wrapper___o-ySf_12-1-3","drop-container-wrapper-with-footer":"magritte-drop-container-wrapper-with-footer___-6tNU_12-1-3","dropContainerWrapperWithFooter":"magritte-drop-container-wrapper-with-footer___-6tNU_12-1-3","drop-container":"magritte-drop-container___dbMt9_12-1-3","dropContainer":"magritte-drop-container___dbMt9_12-1-3","divider-container":"magritte-divider-container___ZCdDW_12-1-3","dividerContainer":"magritte-divider-container___ZCdDW_12-1-3","drop-enter":"magritte-drop-enter___4vEuH_12-1-3","dropEnter":"magritte-drop-enter___4vEuH_12-1-3","drop-exit":"magritte-drop-exit___brFjz_12-1-3","dropExit":"magritte-drop-exit___brFjz_12-1-3","drop-enter-active":"magritte-drop-enter-active___SQUog_12-1-3","dropEnterActive":"magritte-drop-enter-active___SQUog_12-1-3","drop-exit-active":"magritte-drop-exit-active___GB0ET_12-1-3","dropExitActive":"magritte-drop-exit-active___GB0ET_12-1-3","drop-animation-timeout":"magritte-drop-animation-timeout___uO7LF_12-1-3","dropAnimationTimeout":"magritte-drop-animation-timeout___uO7LF_12-1-3"};
9
+ var styles = {"drop":"magritte-drop___Z10P4_12-2-0","drop-border":"magritte-drop-border___UDWjW_12-2-0","dropBorder":"magritte-drop-border___UDWjW_12-2-0","drop-container-wrapper":"magritte-drop-container-wrapper___o-ySf_12-2-0","dropContainerWrapper":"magritte-drop-container-wrapper___o-ySf_12-2-0","drop-container-wrapper-with-footer":"magritte-drop-container-wrapper-with-footer___-6tNU_12-2-0","dropContainerWrapperWithFooter":"magritte-drop-container-wrapper-with-footer___-6tNU_12-2-0","drop-container":"magritte-drop-container___dbMt9_12-2-0","dropContainer":"magritte-drop-container___dbMt9_12-2-0","divider-container":"magritte-divider-container___ZCdDW_12-2-0","dividerContainer":"magritte-divider-container___ZCdDW_12-2-0","drop-enter":"magritte-drop-enter___4vEuH_12-2-0","dropEnter":"magritte-drop-enter___4vEuH_12-2-0","drop-exit":"magritte-drop-exit___brFjz_12-2-0","dropExit":"magritte-drop-exit___brFjz_12-2-0","drop-enter-active":"magritte-drop-enter-active___SQUog_12-2-0","dropEnterActive":"magritte-drop-enter-active___SQUog_12-2-0","drop-exit-active":"magritte-drop-exit-active___GB0ET_12-2-0","dropExitActive":"magritte-drop-exit-active___GB0ET_12-2-0","drop-animation-timeout":"magritte-drop-animation-timeout___uO7LF_12-2-0","dropAnimationTimeout":"magritte-drop-animation-timeout___uO7LF_12-2-0"};
10
10
 
11
11
  const DropContainer = forwardRef(({ children, showDivider, padding, withFooter }, ref) => {
12
12
  const dividerRef = useRef(null);
@@ -60,4 +60,4 @@ const DropContainer = forwardRef(({ children, showDivider, padding, withFooter }
60
60
  DropContainer.displayName = 'DropContainer';
61
61
 
62
62
  export { DropContainer as D, styles as s };
63
- //# sourceMappingURL=DropContainer-DGf8vK7N.js.map
63
+ //# sourceMappingURL=DropContainer-OMwBRGe4.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"DropContainer-DGf8vK7N.js","sources":["../src/DropContainer.tsx"],"sourcesContent":["import { useRef, type PropsWithChildren, useEffect, useCallback, forwardRef, CSSProperties } from 'react';\nimport classnames from 'classnames';\n\nimport { useMultipleRefs } from '@hh.ru/magritte-common-use-multiple-refs';\nimport { Divider, type ShowDivider } from '@hh.ru/magritte-ui-divider';\nimport { Scrollbar, useScrollbar } from '@hh.ru/magritte-ui-scrollbar';\n\nimport styles from './drop.less';\n\nexport const DropContainer = forwardRef<\n HTMLDivElement,\n PropsWithChildren<{\n showDivider: ShowDivider;\n padding: CSSProperties;\n withFooter: boolean;\n }>\n>(({ children, showDivider, padding, withFooter }, ref) => {\n const dividerRef = useRef<HTMLDivElement>(null);\n const showDividerRef = useRef(showDivider);\n showDividerRef.current = showDivider;\n const contentContainerRef = useRef<HTMLDivElement>(null);\n const { hasVerticalScroll, verticalScrollbarProps, ...scrollbar } = useScrollbar({ axis: 'vertical' });\n const contentContainerRefMulti = useMultipleRefs(contentContainerRef, ref, scrollbar.scrollContainerRef);\n\n const updateDividerVisibility = useCallback(\n (showDivider: ShowDivider) => {\n const scrollableContainer = contentContainerRef.current;\n const divider = dividerRef.current;\n if (!scrollableContainer || !divider) {\n return;\n }\n\n if (showDivider === 'always') {\n divider.style.visibility = 'visible';\n }\n\n if (showDivider === 'with-scroll') {\n const isNotScrolledToEnd =\n scrollableContainer.scrollHeight - scrollableContainer.scrollTop > scrollableContainer.offsetHeight;\n divider.style.visibility = isNotScrolledToEnd ? 'visible' : 'hidden';\n }\n\n if (showDivider === false) {\n divider.style.visibility = 'hidden';\n }\n },\n [contentContainerRef, dividerRef]\n );\n\n useEffect(() => {\n const observer = new ResizeObserver(() => {\n updateDividerVisibility(showDividerRef.current);\n });\n observer.observe(contentContainerRef.current as Element);\n return () => observer.disconnect();\n }, [updateDividerVisibility]);\n\n useEffect(() => {\n updateDividerVisibility(showDividerRef.current);\n // eslint-disable-next-line disable-autofix/react-hooks/exhaustive-deps\n }, [updateDividerVisibility, showDividerRef.current]);\n\n const props =\n showDividerRef.current === 'with-scroll'\n ? {\n onScroll: ({ target }: { target: EventTarget }) => {\n const scrollableContainer = target as HTMLDivElement;\n\n if (dividerRef.current) {\n const isNotScrolledToEnd =\n scrollableContainer.scrollHeight - scrollableContainer.scrollTop >\n scrollableContainer.offsetHeight;\n dividerRef.current.style.visibility = isNotScrolledToEnd ? 'visible' : 'hidden';\n }\n },\n }\n : {};\n\n return (\n <>\n <div\n className={classnames(\n styles.dropContainerWrapper,\n { [styles.dropContainerWrapperWithFooter]: withFooter },\n scrollbar.hoverContainerCssClass\n )}\n >\n <div ref={contentContainerRefMulti} className={styles.dropContainer} {...props} style={padding}>\n {children}\n </div>\n {hasVerticalScroll && <Scrollbar {...verticalScrollbarProps} />}\n </div>\n <div ref={dividerRef} className={styles.dividerContainer} data-qa=\"drop-divider\">\n <Divider />\n </div>\n </>\n );\n});\n\nDropContainer.displayName = 'DropContainer';\n"],"names":["_jsxs","_Fragment","_jsx"],"mappings":"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"}
1
+ {"version":3,"file":"DropContainer-OMwBRGe4.js","sources":["../src/DropContainer.tsx"],"sourcesContent":["import { useRef, type PropsWithChildren, useEffect, useCallback, forwardRef, CSSProperties } from 'react';\nimport classnames from 'classnames';\n\nimport { useMultipleRefs } from '@hh.ru/magritte-common-use-multiple-refs';\nimport { Divider, type ShowDivider } from '@hh.ru/magritte-ui-divider';\nimport { Scrollbar, useScrollbar } from '@hh.ru/magritte-ui-scrollbar';\n\nimport styles from './drop.less';\n\nexport const DropContainer = forwardRef<\n HTMLDivElement,\n PropsWithChildren<{\n showDivider: ShowDivider;\n padding: CSSProperties;\n withFooter: boolean;\n }>\n>(({ children, showDivider, padding, withFooter }, ref) => {\n const dividerRef = useRef<HTMLDivElement>(null);\n const showDividerRef = useRef(showDivider);\n showDividerRef.current = showDivider;\n const contentContainerRef = useRef<HTMLDivElement>(null);\n const { hasVerticalScroll, verticalScrollbarProps, ...scrollbar } = useScrollbar({ axis: 'vertical' });\n const contentContainerRefMulti = useMultipleRefs(contentContainerRef, ref, scrollbar.scrollContainerRef);\n\n const updateDividerVisibility = useCallback(\n (showDivider: ShowDivider) => {\n const scrollableContainer = contentContainerRef.current;\n const divider = dividerRef.current;\n if (!scrollableContainer || !divider) {\n return;\n }\n\n if (showDivider === 'always') {\n divider.style.visibility = 'visible';\n }\n\n if (showDivider === 'with-scroll') {\n const isNotScrolledToEnd =\n scrollableContainer.scrollHeight - scrollableContainer.scrollTop > scrollableContainer.offsetHeight;\n divider.style.visibility = isNotScrolledToEnd ? 'visible' : 'hidden';\n }\n\n if (showDivider === false) {\n divider.style.visibility = 'hidden';\n }\n },\n [contentContainerRef, dividerRef]\n );\n\n useEffect(() => {\n const observer = new ResizeObserver(() => {\n updateDividerVisibility(showDividerRef.current);\n });\n observer.observe(contentContainerRef.current as Element);\n return () => observer.disconnect();\n }, [updateDividerVisibility]);\n\n useEffect(() => {\n updateDividerVisibility(showDividerRef.current);\n // eslint-disable-next-line disable-autofix/react-hooks/exhaustive-deps\n }, [updateDividerVisibility, showDividerRef.current]);\n\n const props =\n showDividerRef.current === 'with-scroll'\n ? {\n onScroll: ({ target }: { target: EventTarget }) => {\n const scrollableContainer = target as HTMLDivElement;\n\n if (dividerRef.current) {\n const isNotScrolledToEnd =\n scrollableContainer.scrollHeight - scrollableContainer.scrollTop >\n scrollableContainer.offsetHeight;\n dividerRef.current.style.visibility = isNotScrolledToEnd ? 'visible' : 'hidden';\n }\n },\n }\n : {};\n\n return (\n <>\n <div\n className={classnames(\n styles.dropContainerWrapper,\n { [styles.dropContainerWrapperWithFooter]: withFooter },\n scrollbar.hoverContainerCssClass\n )}\n >\n <div ref={contentContainerRefMulti} className={styles.dropContainer} {...props} style={padding}>\n {children}\n </div>\n {hasVerticalScroll && <Scrollbar {...verticalScrollbarProps} />}\n </div>\n <div ref={dividerRef} className={styles.dividerContainer} data-qa=\"drop-divider\">\n <Divider />\n </div>\n </>\n );\n});\n\nDropContainer.displayName = 'DropContainer';\n"],"names":["_jsxs","_Fragment","_jsx"],"mappings":"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"}
package/DropContainer.js CHANGED
@@ -5,5 +5,5 @@ import 'classnames';
5
5
  import '@hh.ru/magritte-common-use-multiple-refs';
6
6
  import '@hh.ru/magritte-ui-divider';
7
7
  import '@hh.ru/magritte-ui-scrollbar';
8
- export { D as DropContainer } from './DropContainer-DGf8vK7N.js';
8
+ export { D as DropContainer } from './DropContainer-OMwBRGe4.js';
9
9
  //# sourceMappingURL=DropContainer.js.map
package/index.css CHANGED
@@ -19,7 +19,7 @@
19
19
  --magritte-color-component-drop-background-content-v24-3-0:#1B1B1B;
20
20
  --magritte-shadow-level-2-color-v24-3-0:#0000003d;
21
21
  }
22
- .magritte-drop___Z10P4_12-1-3{
22
+ .magritte-drop___Z10P4_12-2-0{
23
23
  position:relative;
24
24
  display:flex;
25
25
  flex-direction:column;
@@ -30,7 +30,7 @@
30
30
  height:100%;
31
31
  overflow:hidden;
32
32
  }
33
- .magritte-drop-border___UDWjW_12-1-3{
33
+ .magritte-drop-border___UDWjW_12-2-0{
34
34
  box-shadow:inset 0 0 0 1px var(--magritte-color-stroke-neutral-v24-3-0);
35
35
  position:absolute;
36
36
  border-radius:24px;
@@ -38,16 +38,16 @@
38
38
  inset:0;
39
39
  z-index:1;
40
40
  }
41
- .magritte-drop-container-wrapper___o-ySf_12-1-3{
41
+ .magritte-drop-container-wrapper___o-ySf_12-2-0{
42
42
  position:relative;
43
43
  overflow:hidden;
44
44
  --magritte-ui-scrollbar-border-radius:24px;
45
45
  }
46
- .magritte-drop-container-wrapper-with-footer___-6tNU_12-1-3{
46
+ .magritte-drop-container-wrapper-with-footer___-6tNU_12-2-0{
47
47
  --magritte-ui-scrollbar-border-bottom-left-radius:0;
48
48
  --magritte-ui-scrollbar-border-bottom-right-radius:0;
49
49
  }
50
- .magritte-drop-container___dbMt9_12-1-3{
50
+ .magritte-drop-container___dbMt9_12-2-0{
51
51
  width:100%;
52
52
  height:100%;
53
53
  box-sizing:border-box;
@@ -55,74 +55,74 @@
55
55
  overscroll-behavior:contain;
56
56
  scrollbar-width:none;
57
57
  }
58
- .magritte-drop-container___dbMt9_12-1-3::-webkit-scrollbar{
58
+ .magritte-drop-container___dbMt9_12-2-0::-webkit-scrollbar{
59
59
  display:none;
60
60
  }
61
- .magritte-divider-container___ZCdDW_12-1-3{
61
+ .magritte-divider-container___ZCdDW_12-2-0{
62
62
  visibility:hidden;
63
63
  }
64
64
  @media (prefers-reduced-motion: no-preference){
65
- .magritte-drop-enter___4vEuH_12-1-3 .magritte-drop___Z10P4_12-1-3{
65
+ .magritte-drop-enter___4vEuH_12-2-0 .magritte-drop___Z10P4_12-2-0{
66
66
  opacity:0;
67
67
  }
68
- .magritte-drop-exit___brFjz_12-1-3 .magritte-drop___Z10P4_12-1-3,
69
- .magritte-drop-enter-active___SQUog_12-1-3 .magritte-drop___Z10P4_12-1-3{
68
+ .magritte-drop-exit___brFjz_12-2-0 .magritte-drop___Z10P4_12-2-0,
69
+ .magritte-drop-enter-active___SQUog_12-2-0 .magritte-drop___Z10P4_12-2-0{
70
70
  opacity:1;
71
71
  }
72
- .magritte-drop-exit-active___GB0ET_12-1-3 .magritte-drop___Z10P4_12-1-3{
72
+ .magritte-drop-exit-active___GB0ET_12-2-0 .magritte-drop___Z10P4_12-2-0{
73
73
  opacity:0;
74
74
  }
75
- .magritte-drop-animation-timeout___uO7LF_12-1-3,
76
- .magritte-drop-enter-active___SQUog_12-1-3 .magritte-drop___Z10P4_12-1-3{
75
+ .magritte-drop-animation-timeout___uO7LF_12-2-0,
76
+ .magritte-drop-enter-active___SQUog_12-2-0 .magritte-drop___Z10P4_12-2-0{
77
77
  transition-property:opacity, transform;
78
78
  transition-duration:var(--magritte-semantic-animation-ease-in-out-200-duration-v24-3-0);
79
79
  transition-timing-function:var(--magritte-semantic-animation-ease-in-out-200-timing-function-v24-3-0);
80
80
  --animation-duration:var(--magritte-semantic-animation-ease-in-out-200-duration-v24-3-0);
81
81
  }
82
- .magritte-drop-animation-timeout___uO7LF_12-1-3,
83
- .magritte-drop-exit-active___GB0ET_12-1-3 .magritte-drop___Z10P4_12-1-3{
82
+ .magritte-drop-animation-timeout___uO7LF_12-2-0,
83
+ .magritte-drop-exit-active___GB0ET_12-2-0 .magritte-drop___Z10P4_12-2-0{
84
84
  transition-property:opacity, transform;
85
85
  transition-duration:var(--magritte-semantic-animation-ease-in-out-100-duration-v24-3-0);
86
86
  transition-timing-function:var(--magritte-semantic-animation-ease-in-out-200-timing-function-v24-3-0);
87
87
  }
88
- .magritte-drop-enter___4vEuH_12-1-3[data-magritte-drop-base-direction='top'] .magritte-drop___Z10P4_12-1-3{
88
+ .magritte-drop-enter___4vEuH_12-2-0[data-magritte-drop-base-direction='top'] .magritte-drop___Z10P4_12-2-0{
89
89
  transform:translateY(-4px);
90
90
  }
91
- .magritte-drop-exit-active___GB0ET_12-1-3[data-magritte-drop-base-direction='top'] .magritte-drop___Z10P4_12-1-3{
91
+ .magritte-drop-exit-active___GB0ET_12-2-0[data-magritte-drop-base-direction='top'] .magritte-drop___Z10P4_12-2-0{
92
92
  transform:translateY(-4px);
93
93
  }
94
- .magritte-drop-enter___4vEuH_12-1-3[data-magritte-drop-base-direction='bottom'] .magritte-drop___Z10P4_12-1-3{
94
+ .magritte-drop-enter___4vEuH_12-2-0[data-magritte-drop-base-direction='bottom'] .magritte-drop___Z10P4_12-2-0{
95
95
  transform:translateY(4px);
96
96
  }
97
- .magritte-drop-exit-active___GB0ET_12-1-3[data-magritte-drop-base-direction='bottom'] .magritte-drop___Z10P4_12-1-3{
97
+ .magritte-drop-exit-active___GB0ET_12-2-0[data-magritte-drop-base-direction='bottom'] .magritte-drop___Z10P4_12-2-0{
98
98
  transform:translateY(4px);
99
99
  }
100
- .magritte-drop-enter___4vEuH_12-1-3[data-magritte-drop-base-direction='left'] .magritte-drop___Z10P4_12-1-3{
100
+ .magritte-drop-enter___4vEuH_12-2-0[data-magritte-drop-base-direction='left'] .magritte-drop___Z10P4_12-2-0{
101
101
  transform:translateX(-4px);
102
102
  }
103
- .magritte-drop-exit-active___GB0ET_12-1-3[data-magritte-drop-base-direction='left'] .magritte-drop___Z10P4_12-1-3{
103
+ .magritte-drop-exit-active___GB0ET_12-2-0[data-magritte-drop-base-direction='left'] .magritte-drop___Z10P4_12-2-0{
104
104
  transform:translateX(4px);
105
105
  }
106
- .magritte-drop-enter___4vEuH_12-1-3[data-magritte-drop-base-direction='right'] .magritte-drop___Z10P4_12-1-3{
106
+ .magritte-drop-enter___4vEuH_12-2-0[data-magritte-drop-base-direction='right'] .magritte-drop___Z10P4_12-2-0{
107
107
  transform:translateX(4px);
108
108
  }
109
- .magritte-drop-exit-active___GB0ET_12-1-3[data-magritte-drop-base-direction='right'] .magritte-drop___Z10P4_12-1-3{
109
+ .magritte-drop-exit-active___GB0ET_12-2-0[data-magritte-drop-base-direction='right'] .magritte-drop___Z10P4_12-2-0{
110
110
  transform:translateX(4px);
111
111
  }
112
- .magritte-drop-exit___brFjz_12-1-3[data-magritte-drop-base-direction='left'] .magritte-drop___Z10P4_12-1-3,
113
- .magritte-drop-enter-active___SQUog_12-1-3[data-magritte-drop-base-direction='left'] .magritte-drop___Z10P4_12-1-3{
112
+ .magritte-drop-exit___brFjz_12-2-0[data-magritte-drop-base-direction='left'] .magritte-drop___Z10P4_12-2-0,
113
+ .magritte-drop-enter-active___SQUog_12-2-0[data-magritte-drop-base-direction='left'] .magritte-drop___Z10P4_12-2-0{
114
114
  transform:translateX(0%);
115
115
  }
116
- .magritte-drop-exit___brFjz_12-1-3[data-magritte-drop-base-direction='bottom'] .magritte-drop___Z10P4_12-1-3,
117
- .magritte-drop-enter-active___SQUog_12-1-3[data-magritte-drop-base-direction='bottom'] .magritte-drop___Z10P4_12-1-3{
116
+ .magritte-drop-exit___brFjz_12-2-0[data-magritte-drop-base-direction='bottom'] .magritte-drop___Z10P4_12-2-0,
117
+ .magritte-drop-enter-active___SQUog_12-2-0[data-magritte-drop-base-direction='bottom'] .magritte-drop___Z10P4_12-2-0{
118
118
  transform:translateY(0%);
119
119
  }
120
- .magritte-drop-exit___brFjz_12-1-3[data-magritte-drop-base-direction='right'] .magritte-drop___Z10P4_12-1-3,
121
- .magritte-drop-enter-active___SQUog_12-1-3[data-magritte-drop-base-direction='right'] .magritte-drop___Z10P4_12-1-3{
120
+ .magritte-drop-exit___brFjz_12-2-0[data-magritte-drop-base-direction='right'] .magritte-drop___Z10P4_12-2-0,
121
+ .magritte-drop-enter-active___SQUog_12-2-0[data-magritte-drop-base-direction='right'] .magritte-drop___Z10P4_12-2-0{
122
122
  transform:translateX(0%);
123
123
  }
124
- .magritte-drop-exit___brFjz_12-1-3[data-magritte-drop-base-direction='top'] .magritte-drop___Z10P4_12-1-3,
125
- .magritte-drop-enter-active___SQUog_12-1-3[data-magritte-drop-base-direction='top'] .magritte-drop___Z10P4_12-1-3{
124
+ .magritte-drop-exit___brFjz_12-2-0[data-magritte-drop-base-direction='top'] .magritte-drop___Z10P4_12-2-0,
125
+ .magritte-drop-enter-active___SQUog_12-2-0[data-magritte-drop-base-direction='top'] .magritte-drop___Z10P4_12-2-0{
126
126
  transform:translateY(0%);
127
127
  }
128
128
  }
package/index.js CHANGED
@@ -5,7 +5,7 @@ import 'react';
5
5
  import '@hh.ru/magritte-internal-drop-base';
6
6
  import '@hh.ru/magritte-ui-action-bar';
7
7
  import '@hh.ru/magritte-ui-breakpoint';
8
- import './DropContainer-DGf8vK7N.js';
8
+ import './DropContainer-OMwBRGe4.js';
9
9
  import 'classnames';
10
10
  import '@hh.ru/magritte-common-use-multiple-refs';
11
11
  import '@hh.ru/magritte-ui-divider';
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@hh.ru/magritte-ui-drop",
3
- "version": "12.1.3",
3
+ "version": "12.2.0",
4
4
  "main": "index.js",
5
5
  "types": "index.d.ts",
6
6
  "sideEffects": [
@@ -21,9 +21,9 @@
21
21
  "dependencies": {
22
22
  "@hh.ru/magritte-common-use-multiple-refs": "1.1.10",
23
23
  "@hh.ru/magritte-design-tokens": "24.3.0",
24
- "@hh.ru/magritte-internal-drop-base": "7.1.15",
24
+ "@hh.ru/magritte-internal-drop-base": "7.1.16",
25
25
  "@hh.ru/magritte-internal-layer-name": "3.3.0",
26
- "@hh.ru/magritte-ui-action-bar": "5.3.0",
26
+ "@hh.ru/magritte-ui-action-bar": "5.3.1",
27
27
  "@hh.ru/magritte-ui-breakpoint": "6.0.6",
28
28
  "@hh.ru/magritte-ui-divider": "3.0.15",
29
29
  "@hh.ru/magritte-ui-layer": "3.2.0",
@@ -36,5 +36,5 @@
36
36
  "publishConfig": {
37
37
  "access": "public"
38
38
  },
39
- "gitHead": "83b35a5f729c8f70b4da1d92e4b8022cc7cb2127"
39
+ "gitHead": "cd762742faf8206ce237c2fa3984574d9121696b"
40
40
  }
package/types.d.ts CHANGED
@@ -13,7 +13,7 @@ export interface DropPropsOnly {
13
13
  /** Минимальная высота Drop */
14
14
  minHeight?: number;
15
15
  /** Роли для доступности */
16
- role?: 'alertdialog' | 'dialog' | 'listbox' | 'status';
16
+ role?: Extract<React.AriaRole, 'alertdialog' | 'combobox' | 'dialog' | 'listbox' | 'menu' | 'menubar' | 'status'>;
17
17
  /** Содержимое нижнего контейнера */
18
18
  footer?: ReactNode;
19
19
  /** Размер паддинга */
@@ -56,5 +56,7 @@ export interface DropPropsOnly {
56
56
  * то будет использоваться оно, вне зависимости от значений других пропсов.
57
57
  */
58
58
  ignoreIntersections?: boolean;
59
+ /** Возвращать ли фокус на активатор после закрытия дропа, по умолчанию `true` */
60
+ returnFocusOnClose?: boolean;
59
61
  }
60
62
  export type DropProps = Omit<DropBasePermanentProps, 'arrowGuardDistance' | 'children' | 'animationTimeout' | 'animationClassNames' | 'role' | 'guardDistanceToActivator' | 'placement' | 'allowShrinkHeightToFitIntoViewport' | 'minHeight' | 'guardDistanceToViewport' | 'ignoreIntersections'> & PropsWithChildren<DropPropsOnly>;