@hh.ru/magritte-ui-drop 6.0.2 → 6.0.3
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.d.ts +2 -2
- package/Drop.js +1 -1
- package/DropContainer-C-OoWz8X.js +36 -0
- package/{DropContainer-b6c5e458.js.map → DropContainer-C-OoWz8X.js.map} +1 -1
- package/DropContainer.d.ts +1 -1
- package/DropContainer.js +1 -1
- package/index.css +66 -66
- package/index.d.ts +2 -2
- package/index.js +1 -1
- package/package.json +12 -11
- package/DropContainer-b6c5e458.js +0 -36
package/Drop.d.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { type ReactElement, ForwardedRef } from 'react';
|
|
2
2
|
import { type DropBaseHorizontalPositionWithoutCenter, type DropBaseVerticalPositionWithoutCenter } from '@hh.ru/magritte-internal-drop-base';
|
|
3
|
-
import type { DropProps } from '
|
|
4
|
-
declare const Drop: (<T extends DropBaseHorizontalPositionWithoutCenter | DropBaseVerticalPositionWithoutCenter>(props: Omit<import("@hh.ru/magritte-internal-drop-base").DropBasePermanentProps, "arrowGuardDistance" | "children" | "animationTimeout" | "animationClassNames" | "role" | "guardDistance" | "occupyAllAvailableViewportHeight"> & T & import("
|
|
3
|
+
import type { DropProps } from '@hh.ru/magritte-ui-drop/types';
|
|
4
|
+
declare const Drop: (<T extends DropBaseHorizontalPositionWithoutCenter | DropBaseVerticalPositionWithoutCenter>(props: Omit<import("@hh.ru/magritte-internal-drop-base").DropBasePermanentProps, "arrowGuardDistance" | "children" | "animationTimeout" | "animationClassNames" | "role" | "guardDistance" | "occupyAllAvailableViewportHeight"> & T & import("@hh.ru/magritte-ui-drop/types").DropPropsOnly & {
|
|
5
5
|
children?: import("react").ReactNode;
|
|
6
6
|
} & {
|
|
7
7
|
ref?: ForwardedRef<HTMLElement> | undefined;
|
package/Drop.js
CHANGED
|
@@ -5,7 +5,7 @@ import classnames from 'classnames';
|
|
|
5
5
|
import { DropBase, INITIAL_HEIGHT_VALUE } from '@hh.ru/magritte-internal-drop-base';
|
|
6
6
|
import { InternalLayerName } from '@hh.ru/magritte-internal-layer-name';
|
|
7
7
|
import { useBreakpoint } from '@hh.ru/magritte-ui-breakpoint';
|
|
8
|
-
import { s as styles, D as DropContainer } from './DropContainer-
|
|
8
|
+
import { s as styles, D as DropContainer } from './DropContainer-C-OoWz8X.js';
|
|
9
9
|
import { PureChildren } from './PureChildren.js';
|
|
10
10
|
import { Layer } from '@hh.ru/magritte-ui-layer';
|
|
11
11
|
import '@hh.ru/magritte-ui-divider';
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import './index.css';
|
|
2
|
+
import { jsxs, Fragment, jsx } from 'react/jsx-runtime';
|
|
3
|
+
import { forwardRef, useRef, useEffect } from 'react';
|
|
4
|
+
import { Divider } from '@hh.ru/magritte-ui-divider';
|
|
5
|
+
|
|
6
|
+
var styles = {"drop":"magritte-drop___Z10P4_6-0-3","drop-container":"magritte-drop-container___dbMt9_6-0-3","dropContainer":"magritte-drop-container___dbMt9_6-0-3","drop-footer":"magritte-drop-footer___v8ZEO_6-0-3","dropFooter":"magritte-drop-footer___v8ZEO_6-0-3","drop-space-300":"magritte-drop-space-300___41acH_6-0-3","dropSpace300":"magritte-drop-space-300___41acH_6-0-3","drop-space-400":"magritte-drop-space-400___XX1RM_6-0-3","dropSpace400":"magritte-drop-space-400___XX1RM_6-0-3","drop-padding":"magritte-drop-padding___xBiJO_6-0-3","dropPadding":"magritte-drop-padding___xBiJO_6-0-3","drop-space-600":"magritte-drop-space-600___6B1i0_6-0-3","dropSpace600":"magritte-drop-space-600___6B1i0_6-0-3","drop-with-footer":"magritte-drop-with-footer___CgBIV_6-0-3","dropWithFooter":"magritte-drop-with-footer___CgBIV_6-0-3","drop-enter":"magritte-drop-enter___4vEuH_6-0-3","dropEnter":"magritte-drop-enter___4vEuH_6-0-3","drop-exit":"magritte-drop-exit___brFjz_6-0-3","dropExit":"magritte-drop-exit___brFjz_6-0-3","drop-enter-active":"magritte-drop-enter-active___SQUog_6-0-3","dropEnterActive":"magritte-drop-enter-active___SQUog_6-0-3","drop-exit-active":"magritte-drop-exit-active___GB0ET_6-0-3","dropExitActive":"magritte-drop-exit-active___GB0ET_6-0-3","drop-animation-timeout":"magritte-drop-animation-timeout___uO7LF_6-0-3","dropAnimationTimeout":"magritte-drop-animation-timeout___uO7LF_6-0-3","drop-direction-top":"magritte-drop-direction-top___3CelS_6-0-3","dropDirectionTop":"magritte-drop-direction-top___3CelS_6-0-3","drop-direction-bottom":"magritte-drop-direction-bottom___719rs_6-0-3","dropDirectionBottom":"magritte-drop-direction-bottom___719rs_6-0-3","drop-direction-left":"magritte-drop-direction-left___2PTob_6-0-3","dropDirectionLeft":"magritte-drop-direction-left___2PTob_6-0-3","drop-direction-right":"magritte-drop-direction-right___SPOr1_6-0-3","dropDirectionRight":"magritte-drop-direction-right___SPOr1_6-0-3"};
|
|
7
|
+
|
|
8
|
+
const DropContainer = forwardRef(({ children, height, dividerState, minHeightForContent }, ref) => {
|
|
9
|
+
const dividerRef = useRef(null);
|
|
10
|
+
const showDivider = dividerState !== 'hide';
|
|
11
|
+
useEffect(() => {
|
|
12
|
+
if (showDivider && ref && 'current' in ref && ref?.current !== null && dividerRef.current && !!height) {
|
|
13
|
+
const hasScroll = ref.current.scrollHeight - ref.current.clientHeight > 0;
|
|
14
|
+
dividerRef.current.style.visibility = hasScroll ? 'visible' : 'hidden';
|
|
15
|
+
}
|
|
16
|
+
}, [ref, dividerRef, height, showDivider]);
|
|
17
|
+
const props = showDivider
|
|
18
|
+
? {
|
|
19
|
+
onScroll: ({ target }) => {
|
|
20
|
+
const scrollableContainer = target;
|
|
21
|
+
if (dividerRef.current && dividerState !== 'showWhenFullyScrolled') {
|
|
22
|
+
const scrollEnded = scrollableContainer.scrollTop +
|
|
23
|
+
scrollableContainer.offsetHeight -
|
|
24
|
+
scrollableContainer.scrollHeight ===
|
|
25
|
+
0;
|
|
26
|
+
dividerRef.current.style.visibility = scrollEnded ? 'hidden' : 'visible';
|
|
27
|
+
}
|
|
28
|
+
},
|
|
29
|
+
}
|
|
30
|
+
: {};
|
|
31
|
+
return (jsxs(Fragment, { children: [jsx("div", { ref: ref, className: styles.dropContainer, style: { height: height === undefined ? `${minHeightForContent}px` : 'auto' }, ...props, children: children }), showDivider && (jsx("div", { ref: dividerRef, "data-qa": "drop-divider", children: jsx(Divider, {}) }))] }));
|
|
32
|
+
});
|
|
33
|
+
DropContainer.displayName = 'DropContainer';
|
|
34
|
+
|
|
35
|
+
export { DropContainer as D, styles as s };
|
|
36
|
+
//# sourceMappingURL=DropContainer-C-OoWz8X.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DropContainer-
|
|
1
|
+
{"version":3,"file":"DropContainer-C-OoWz8X.js","sources":["../src/DropContainer.tsx"],"sourcesContent":["import { useRef, PropsWithChildren, useEffect, forwardRef } from 'react';\n\nimport { Divider } from '@hh.ru/magritte-ui-divider';\nimport type { DividerState } from '@hh.ru/magritte-ui-drop/types';\n\nimport styles from './drop.less';\n\nexport const DropContainer = forwardRef<\n HTMLDivElement,\n PropsWithChildren<{\n height?: number | string;\n dividerState: DividerState;\n minHeightForContent: number;\n }>\n>(({ children, height, dividerState, minHeightForContent }, ref) => {\n const dividerRef = useRef<HTMLDivElement>(null);\n const showDivider = dividerState !== 'hide';\n\n useEffect(() => {\n if (showDivider && ref && 'current' in ref && ref?.current !== null && dividerRef.current && !!height) {\n const hasScroll = ref.current.scrollHeight - ref.current.clientHeight > 0;\n dividerRef.current.style.visibility = hasScroll ? 'visible' : 'hidden';\n }\n }, [ref, dividerRef, height, showDivider]);\n\n const props = showDivider\n ? {\n onScroll: ({ target }: { target: EventTarget }) => {\n const scrollableContainer = target as HTMLDivElement;\n\n if (dividerRef.current && dividerState !== 'showWhenFullyScrolled') {\n const scrollEnded =\n scrollableContainer.scrollTop +\n scrollableContainer.offsetHeight -\n scrollableContainer.scrollHeight ===\n 0;\n\n dividerRef.current.style.visibility = scrollEnded ? 'hidden' : 'visible';\n }\n },\n }\n : {};\n\n return (\n <>\n <div\n ref={ref}\n className={styles.dropContainer}\n style={{ height: height === undefined ? `${minHeightForContent}px` : 'auto' }}\n {...props}\n >\n {children}\n </div>\n {showDivider && (\n <div ref={dividerRef} data-qa=\"drop-divider\">\n <Divider />\n </div>\n )}\n </>\n );\n});\n\nDropContainer.displayName = 'DropContainer';\n"],"names":["_jsxs","_Fragment","_jsx"],"mappings":";;;;;;AAOa,MAAA,aAAa,GAAG,UAAU,CAOrC,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,YAAY,EAAE,mBAAmB,EAAE,EAAE,GAAG,KAAI;AAC/D,IAAA,MAAM,UAAU,GAAG,MAAM,CAAiB,IAAI,CAAC,CAAC;AAChD,IAAA,MAAM,WAAW,GAAG,YAAY,KAAK,MAAM,CAAC;IAE5C,SAAS,CAAC,MAAK;QACX,IAAI,WAAW,IAAI,GAAG,IAAI,SAAS,IAAI,GAAG,IAAI,GAAG,EAAE,OAAO,KAAK,IAAI,IAAI,UAAU,CAAC,OAAO,IAAI,CAAC,CAAC,MAAM,EAAE;AACnG,YAAA,MAAM,SAAS,GAAG,GAAG,CAAC,OAAO,CAAC,YAAY,GAAG,GAAG,CAAC,OAAO,CAAC,YAAY,GAAG,CAAC,CAAC;AAC1E,YAAA,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,UAAU,GAAG,SAAS,GAAG,SAAS,GAAG,QAAQ,CAAC;AAC1E,SAAA;KACJ,EAAE,CAAC,GAAG,EAAE,UAAU,EAAE,MAAM,EAAE,WAAW,CAAC,CAAC,CAAC;IAE3C,MAAM,KAAK,GAAG,WAAW;AACrB,UAAE;AACI,YAAA,QAAQ,EAAE,CAAC,EAAE,MAAM,EAA2B,KAAI;gBAC9C,MAAM,mBAAmB,GAAG,MAAwB,CAAC;AAErD,gBAAA,IAAI,UAAU,CAAC,OAAO,IAAI,YAAY,KAAK,uBAAuB,EAAE;AAChE,oBAAA,MAAM,WAAW,GACb,mBAAmB,CAAC,SAAS;AACzB,wBAAA,mBAAmB,CAAC,YAAY;AAChC,wBAAA,mBAAmB,CAAC,YAAY;AACpC,wBAAA,CAAC,CAAC;AAEN,oBAAA,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,UAAU,GAAG,WAAW,GAAG,QAAQ,GAAG,SAAS,CAAC;AAC5E,iBAAA;aACJ;AACJ,SAAA;UACD,EAAE,CAAC;IAET,QACIA,IACI,CAAAC,QAAA,EAAA,EAAA,QAAA,EAAA,CAAAC,GAAA,CAAA,KAAA,EAAA,EACI,GAAG,EAAE,GAAG,EACR,SAAS,EAAE,MAAM,CAAC,aAAa,EAC/B,KAAK,EAAE,EAAE,MAAM,EAAE,MAAM,KAAK,SAAS,GAAG,CAAA,EAAG,mBAAmB,CAAA,EAAA,CAAI,GAAG,MAAM,EAAE,EACzE,GAAA,KAAK,EAER,QAAA,EAAA,QAAQ,EACP,CAAA,EACL,WAAW,KACRA,GAAA,CAAA,KAAA,EAAA,EAAK,GAAG,EAAE,UAAU,EAAU,SAAA,EAAA,cAAc,EACxC,QAAA,EAAAA,GAAA,CAAC,OAAO,EAAA,EAAA,CAAG,EACT,CAAA,CACT,CACF,EAAA,CAAA,EACL;AACN,CAAC,EAAE;AAEH,aAAa,CAAC,WAAW,GAAG,eAAe;;;;"}
|
package/DropContainer.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
/// <reference types="react" />
|
|
2
|
-
import type { DividerState } from '
|
|
2
|
+
import type { DividerState } from '@hh.ru/magritte-ui-drop/types';
|
|
3
3
|
export declare const DropContainer: import("react").ForwardRefExoticComponent<{
|
|
4
4
|
height?: string | number | undefined;
|
|
5
5
|
dividerState: DividerState;
|
package/DropContainer.js
CHANGED
|
@@ -2,5 +2,5 @@ import './index.css';
|
|
|
2
2
|
import 'react/jsx-runtime';
|
|
3
3
|
import 'react';
|
|
4
4
|
import '@hh.ru/magritte-ui-divider';
|
|
5
|
-
export { D as DropContainer } from './DropContainer-
|
|
5
|
+
export { D as DropContainer } from './DropContainer-C-OoWz8X.js';
|
|
6
6
|
//# sourceMappingURL=DropContainer.js.map
|
package/index.css
CHANGED
|
@@ -1,126 +1,126 @@
|
|
|
1
1
|
:root{
|
|
2
|
-
--magritte-color-component-drop-background-content-v18-2-
|
|
3
|
-
--magritte-shadow-level-2-color-v18-2-
|
|
4
|
-
--magritte-shadow-level-2-x-v18-2-
|
|
5
|
-
--magritte-shadow-level-2-y-v18-2-
|
|
6
|
-
--magritte-shadow-level-2-blur-v18-2-
|
|
7
|
-
--magritte-shadow-level-2-spread-v18-2-
|
|
2
|
+
--magritte-color-component-drop-background-content-v18-2-1:#ffffff;
|
|
3
|
+
--magritte-shadow-level-2-color-v18-2-1:#7090b03d;
|
|
4
|
+
--magritte-shadow-level-2-x-v18-2-1:0px;
|
|
5
|
+
--magritte-shadow-level-2-y-v18-2-1:8px;
|
|
6
|
+
--magritte-shadow-level-2-blur-v18-2-1:16px;
|
|
7
|
+
--magritte-shadow-level-2-spread-v18-2-1:0px;
|
|
8
8
|
}
|
|
9
9
|
:root{
|
|
10
|
-
--magritte-semantic-animation-ease-in-out-100-duration-v18-2-
|
|
11
|
-
--magritte-semantic-animation-ease-in-out-200-timing-function-v18-2-
|
|
12
|
-
--magritte-semantic-animation-ease-in-out-200-duration-v18-2-
|
|
13
|
-
--magritte-static-space-300-v18-2-
|
|
14
|
-
--magritte-static-space-400-v18-2-
|
|
15
|
-
--magritte-static-space-600-v18-2-
|
|
16
|
-
--magritte-static-border-radius-600-v18-2-
|
|
10
|
+
--magritte-semantic-animation-ease-in-out-100-duration-v18-2-1:100ms;
|
|
11
|
+
--magritte-semantic-animation-ease-in-out-200-timing-function-v18-2-1:cubic-bezier(0.25, 0.1, 0.25, 1);
|
|
12
|
+
--magritte-semantic-animation-ease-in-out-200-duration-v18-2-1:200ms;
|
|
13
|
+
--magritte-static-space-300-v18-2-1:12px;
|
|
14
|
+
--magritte-static-space-400-v18-2-1:16px;
|
|
15
|
+
--magritte-static-space-600-v18-2-1:24px;
|
|
16
|
+
--magritte-static-border-radius-600-v18-2-1:24px;
|
|
17
17
|
}
|
|
18
18
|
.magritte-night-theme{
|
|
19
|
-
--magritte-color-component-drop-background-content-v18-2-
|
|
20
|
-
--magritte-shadow-level-2-color-v18-2-
|
|
21
|
-
--magritte-shadow-level-2-x-v18-2-
|
|
22
|
-
--magritte-shadow-level-2-y-v18-2-
|
|
23
|
-
--magritte-shadow-level-2-blur-v18-2-
|
|
24
|
-
--magritte-shadow-level-2-spread-v18-2-
|
|
19
|
+
--magritte-color-component-drop-background-content-v18-2-1:#1B1B1B;
|
|
20
|
+
--magritte-shadow-level-2-color-v18-2-1:#0000003d;
|
|
21
|
+
--magritte-shadow-level-2-x-v18-2-1:0px;
|
|
22
|
+
--magritte-shadow-level-2-y-v18-2-1:8px;
|
|
23
|
+
--magritte-shadow-level-2-blur-v18-2-1:16px;
|
|
24
|
+
--magritte-shadow-level-2-spread-v18-2-1:0px;
|
|
25
25
|
}
|
|
26
|
-
.magritte-drop___Z10P4_6-0-
|
|
26
|
+
.magritte-drop___Z10P4_6-0-3{
|
|
27
27
|
position:relative;
|
|
28
28
|
display:flex;
|
|
29
29
|
flex-direction:column;
|
|
30
|
-
background:var(--magritte-color-component-drop-background-content-v18-2-
|
|
31
|
-
border-radius:var(--magritte-static-border-radius-600-v18-2-
|
|
32
|
-
box-shadow:var(--magritte-shadow-level-2-x-v18-2-
|
|
30
|
+
background:var(--magritte-color-component-drop-background-content-v18-2-1);
|
|
31
|
+
border-radius:var(--magritte-static-border-radius-600-v18-2-1);
|
|
32
|
+
box-shadow:var(--magritte-shadow-level-2-x-v18-2-1) var(--magritte-shadow-level-2-y-v18-2-1) var(--magritte-shadow-level-2-blur-v18-2-1) var(--magritte-shadow-level-2-spread-v18-2-1) var(--magritte-shadow-level-2-color-v18-2-1);
|
|
33
33
|
box-sizing:border-box;
|
|
34
34
|
overflow:hidden;
|
|
35
35
|
}
|
|
36
|
-
.magritte-drop-container___dbMt9_6-0-
|
|
36
|
+
.magritte-drop-container___dbMt9_6-0-3{
|
|
37
37
|
display:block;
|
|
38
38
|
overflow:auto;
|
|
39
39
|
}
|
|
40
|
-
.magritte-drop-footer___v8ZEO_6-0-
|
|
40
|
+
.magritte-drop-footer___v8ZEO_6-0-3{
|
|
41
41
|
display:flex;
|
|
42
42
|
flex-flow:column;
|
|
43
43
|
gap:12px;
|
|
44
44
|
}
|
|
45
|
-
.magritte-drop-space-300___41acH_6-0-
|
|
46
|
-
.magritte-drop-space-300___41acH_6-0-
|
|
47
|
-
padding:var(--magritte-static-space-300-v18-2-
|
|
45
|
+
.magritte-drop-space-300___41acH_6-0-3 .magritte-drop-container___dbMt9_6-0-3,
|
|
46
|
+
.magritte-drop-space-300___41acH_6-0-3 .magritte-drop-footer___v8ZEO_6-0-3{
|
|
47
|
+
padding:var(--magritte-static-space-300-v18-2-1);
|
|
48
48
|
}
|
|
49
|
-
.magritte-drop-space-400___XX1RM_6-0-
|
|
50
|
-
.magritte-drop-space-400___XX1RM_6-0-
|
|
51
|
-
.magritte-drop-space-400___XX1RM_6-0-
|
|
52
|
-
padding:var(--magritte-static-space-400-v18-2-
|
|
49
|
+
.magritte-drop-space-400___XX1RM_6-0-3 .magritte-drop-padding___xBiJO_6-0-3,
|
|
50
|
+
.magritte-drop-space-400___XX1RM_6-0-3 .magritte-drop-container___dbMt9_6-0-3,
|
|
51
|
+
.magritte-drop-space-400___XX1RM_6-0-3 .magritte-drop-footer___v8ZEO_6-0-3{
|
|
52
|
+
padding:var(--magritte-static-space-400-v18-2-1);
|
|
53
53
|
}
|
|
54
|
-
.magritte-drop-space-600___6B1i0_6-0-
|
|
55
|
-
.magritte-drop-space-600___6B1i0_6-0-
|
|
56
|
-
.magritte-drop-space-600___6B1i0_6-0-
|
|
57
|
-
padding:var(--magritte-static-space-600-v18-2-
|
|
54
|
+
.magritte-drop-space-600___6B1i0_6-0-3 .magritte-drop-padding___xBiJO_6-0-3,
|
|
55
|
+
.magritte-drop-space-600___6B1i0_6-0-3 .magritte-drop-container___dbMt9_6-0-3,
|
|
56
|
+
.magritte-drop-space-600___6B1i0_6-0-3 .magritte-drop-footer___v8ZEO_6-0-3{
|
|
57
|
+
padding:var(--magritte-static-space-600-v18-2-1);
|
|
58
58
|
}
|
|
59
|
-
.magritte-drop-with-footer___CgBIV_6-0-
|
|
59
|
+
.magritte-drop-with-footer___CgBIV_6-0-3 .magritte-drop-container___dbMt9_6-0-3{
|
|
60
60
|
padding-bottom:0;
|
|
61
61
|
}
|
|
62
62
|
@media (prefers-reduced-motion: no-preference){
|
|
63
|
-
.magritte-drop-enter___4vEuH_6-0-
|
|
63
|
+
.magritte-drop-enter___4vEuH_6-0-3 .magritte-drop___Z10P4_6-0-3{
|
|
64
64
|
opacity:0;
|
|
65
65
|
}
|
|
66
|
-
.magritte-drop-exit___brFjz_6-0-
|
|
67
|
-
.magritte-drop-enter-active___SQUog_6-0-
|
|
66
|
+
.magritte-drop-exit___brFjz_6-0-3 .magritte-drop___Z10P4_6-0-3,
|
|
67
|
+
.magritte-drop-enter-active___SQUog_6-0-3 .magritte-drop___Z10P4_6-0-3{
|
|
68
68
|
opacity:1;
|
|
69
69
|
}
|
|
70
|
-
.magritte-drop-exit-active___GB0ET_6-0-
|
|
70
|
+
.magritte-drop-exit-active___GB0ET_6-0-3 .magritte-drop___Z10P4_6-0-3{
|
|
71
71
|
opacity:0;
|
|
72
72
|
}
|
|
73
|
-
.magritte-drop-animation-timeout___uO7LF_6-0-
|
|
74
|
-
.magritte-drop-enter-active___SQUog_6-0-
|
|
73
|
+
.magritte-drop-animation-timeout___uO7LF_6-0-3,
|
|
74
|
+
.magritte-drop-enter-active___SQUog_6-0-3 .magritte-drop___Z10P4_6-0-3{
|
|
75
75
|
transition-property:opacity, transform;
|
|
76
|
-
transition-duration:var(--magritte-semantic-animation-ease-in-out-200-duration-v18-2-
|
|
77
|
-
transition-timing-function:var(--magritte-semantic-animation-ease-in-out-200-timing-function-v18-2-
|
|
78
|
-
--animation-duration:var(--magritte-semantic-animation-ease-in-out-200-duration-v18-2-
|
|
76
|
+
transition-duration:var(--magritte-semantic-animation-ease-in-out-200-duration-v18-2-1);
|
|
77
|
+
transition-timing-function:var(--magritte-semantic-animation-ease-in-out-200-timing-function-v18-2-1);
|
|
78
|
+
--animation-duration:var(--magritte-semantic-animation-ease-in-out-200-duration-v18-2-1);
|
|
79
79
|
}
|
|
80
|
-
.magritte-drop-animation-timeout___uO7LF_6-0-
|
|
81
|
-
.magritte-drop-exit-active___GB0ET_6-0-
|
|
80
|
+
.magritte-drop-animation-timeout___uO7LF_6-0-3,
|
|
81
|
+
.magritte-drop-exit-active___GB0ET_6-0-3 .magritte-drop___Z10P4_6-0-3{
|
|
82
82
|
transition-property:opacity, transform;
|
|
83
|
-
transition-duration:var(--magritte-semantic-animation-ease-in-out-100-duration-v18-2-
|
|
84
|
-
transition-timing-function:var(--magritte-semantic-animation-ease-in-out-200-timing-function-v18-2-
|
|
83
|
+
transition-duration:var(--magritte-semantic-animation-ease-in-out-100-duration-v18-2-1);
|
|
84
|
+
transition-timing-function:var(--magritte-semantic-animation-ease-in-out-200-timing-function-v18-2-1);
|
|
85
85
|
}
|
|
86
|
-
.magritte-drop-enter___4vEuH_6-0-
|
|
86
|
+
.magritte-drop-enter___4vEuH_6-0-3 .magritte-drop-direction-top___3CelS_6-0-3{
|
|
87
87
|
transform:translateY(-4px);
|
|
88
88
|
}
|
|
89
|
-
.magritte-drop-exit___brFjz_6-0-
|
|
90
|
-
.magritte-drop-enter-active___SQUog_6-0-
|
|
89
|
+
.magritte-drop-exit___brFjz_6-0-3 .magritte-drop-direction-top___3CelS_6-0-3,
|
|
90
|
+
.magritte-drop-enter-active___SQUog_6-0-3 .magritte-drop-direction-top___3CelS_6-0-3{
|
|
91
91
|
transform:translateY(0%);
|
|
92
92
|
}
|
|
93
|
-
.magritte-drop-exit-active___GB0ET_6-0-
|
|
93
|
+
.magritte-drop-exit-active___GB0ET_6-0-3 .magritte-drop-direction-top___3CelS_6-0-3{
|
|
94
94
|
transform:translateY(-4px);
|
|
95
95
|
}
|
|
96
|
-
.magritte-drop-enter___4vEuH_6-0-
|
|
96
|
+
.magritte-drop-enter___4vEuH_6-0-3 .magritte-drop-direction-bottom___719rs_6-0-3{
|
|
97
97
|
transform:translateY(4px);
|
|
98
98
|
}
|
|
99
|
-
.magritte-drop-exit___brFjz_6-0-
|
|
100
|
-
.magritte-drop-enter-active___SQUog_6-0-
|
|
99
|
+
.magritte-drop-exit___brFjz_6-0-3 .magritte-drop-direction-bottom___719rs_6-0-3,
|
|
100
|
+
.magritte-drop-enter-active___SQUog_6-0-3 .magritte-drop-direction-bottom___719rs_6-0-3{
|
|
101
101
|
transform:translateY(0%);
|
|
102
102
|
}
|
|
103
|
-
.magritte-drop-exit-active___GB0ET_6-0-
|
|
103
|
+
.magritte-drop-exit-active___GB0ET_6-0-3 .magritte-drop-direction-bottom___719rs_6-0-3{
|
|
104
104
|
transform:translateY(4px);
|
|
105
105
|
}
|
|
106
|
-
.magritte-drop-enter___4vEuH_6-0-
|
|
106
|
+
.magritte-drop-enter___4vEuH_6-0-3 .magritte-drop-direction-left___2PTob_6-0-3{
|
|
107
107
|
transform:translateX(-4px);
|
|
108
108
|
}
|
|
109
|
-
.magritte-drop-exit___brFjz_6-0-
|
|
110
|
-
.magritte-drop-enter-active___SQUog_6-0-
|
|
109
|
+
.magritte-drop-exit___brFjz_6-0-3 .magritte-drop-direction-left___2PTob_6-0-3,
|
|
110
|
+
.magritte-drop-enter-active___SQUog_6-0-3 .magritte-drop-direction-left___2PTob_6-0-3{
|
|
111
111
|
transform:translateX(0%);
|
|
112
112
|
}
|
|
113
|
-
.magritte-drop-exit-active___GB0ET_6-0-
|
|
113
|
+
.magritte-drop-exit-active___GB0ET_6-0-3 .magritte-drop-direction-left___2PTob_6-0-3{
|
|
114
114
|
transform:translateX(4px);
|
|
115
115
|
}
|
|
116
|
-
.magritte-drop-enter___4vEuH_6-0-
|
|
116
|
+
.magritte-drop-enter___4vEuH_6-0-3 .magritte-drop-direction-right___SPOr1_6-0-3{
|
|
117
117
|
transform:translateX(4px);
|
|
118
118
|
}
|
|
119
|
-
.magritte-drop-exit___brFjz_6-0-
|
|
120
|
-
.magritte-drop-enter-active___SQUog_6-0-
|
|
119
|
+
.magritte-drop-exit___brFjz_6-0-3 .magritte-drop-direction-right___SPOr1_6-0-3,
|
|
120
|
+
.magritte-drop-enter-active___SQUog_6-0-3 .magritte-drop-direction-right___SPOr1_6-0-3{
|
|
121
121
|
transform:translateX(0%);
|
|
122
122
|
}
|
|
123
|
-
.magritte-drop-exit-active___GB0ET_6-0-
|
|
123
|
+
.magritte-drop-exit-active___GB0ET_6-0-3 .magritte-drop-direction-right___SPOr1_6-0-3{
|
|
124
124
|
transform:translateX(4px);
|
|
125
125
|
}
|
|
126
126
|
}
|
package/index.d.ts
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
export * from '@hh.ru/magritte-ui-theme-provider';
|
|
2
|
-
export * from '
|
|
3
|
-
export type { DropProps } from '
|
|
2
|
+
export * from '@hh.ru/magritte-ui-drop/Drop';
|
|
3
|
+
export type { DropProps } from '@hh.ru/magritte-ui-drop/types';
|
package/index.js
CHANGED
|
@@ -7,7 +7,7 @@ import 'classnames';
|
|
|
7
7
|
import '@hh.ru/magritte-internal-drop-base';
|
|
8
8
|
import '@hh.ru/magritte-internal-layer-name';
|
|
9
9
|
import '@hh.ru/magritte-ui-breakpoint';
|
|
10
|
-
import './DropContainer-
|
|
10
|
+
import './DropContainer-C-OoWz8X.js';
|
|
11
11
|
import '@hh.ru/magritte-ui-divider';
|
|
12
12
|
import './PureChildren.js';
|
|
13
13
|
import '@hh.ru/magritte-ui-layer';
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@hh.ru/magritte-ui-drop",
|
|
3
|
-
"version": "6.0.
|
|
3
|
+
"version": "6.0.3",
|
|
4
4
|
"main": "index.js",
|
|
5
5
|
"types": "index.d.ts",
|
|
6
6
|
"sideEffects": [
|
|
@@ -16,16 +16,17 @@
|
|
|
16
16
|
"eslint-test": "yarn root:eslint-test $(pwd)",
|
|
17
17
|
"ts-config": "yarn root:ts-config $(pwd)",
|
|
18
18
|
"ts-check": "yarn root:ts-check $(pwd)",
|
|
19
|
-
"test": "yarn root:test $(pwd)"
|
|
19
|
+
"test": "yarn root:test $(pwd)",
|
|
20
|
+
"watch": "yarn root:watch $(pwd)"
|
|
20
21
|
},
|
|
21
22
|
"dependencies": {
|
|
22
|
-
"@hh.ru/magritte-design-tokens": "18.2.
|
|
23
|
-
"@hh.ru/magritte-internal-drop-base": "6.0.
|
|
24
|
-
"@hh.ru/magritte-internal-layer-name": "2.1.
|
|
25
|
-
"@hh.ru/magritte-ui-breakpoint": "4.0.
|
|
26
|
-
"@hh.ru/magritte-ui-divider": "1.1.
|
|
27
|
-
"@hh.ru/magritte-ui-layer": "2.0.
|
|
28
|
-
"@hh.ru/magritte-ui-theme-provider": "1.1.
|
|
23
|
+
"@hh.ru/magritte-design-tokens": "18.2.1",
|
|
24
|
+
"@hh.ru/magritte-internal-drop-base": "6.0.2",
|
|
25
|
+
"@hh.ru/magritte-internal-layer-name": "2.1.2",
|
|
26
|
+
"@hh.ru/magritte-ui-breakpoint": "4.0.3",
|
|
27
|
+
"@hh.ru/magritte-ui-divider": "1.1.28",
|
|
28
|
+
"@hh.ru/magritte-ui-layer": "2.0.5",
|
|
29
|
+
"@hh.ru/magritte-ui-theme-provider": "1.1.25"
|
|
29
30
|
},
|
|
30
31
|
"peerDependencies": {
|
|
31
32
|
"classnames": "2.3.2",
|
|
@@ -34,5 +35,5 @@
|
|
|
34
35
|
"publishConfig": {
|
|
35
36
|
"access": "public"
|
|
36
37
|
},
|
|
37
|
-
"gitHead": "
|
|
38
|
-
}
|
|
38
|
+
"gitHead": "bdbcf07ae5f66002ea09633961d0c9c008c70cd6"
|
|
39
|
+
}
|
|
@@ -1,36 +0,0 @@
|
|
|
1
|
-
import './index.css';
|
|
2
|
-
import { jsxs, Fragment, jsx } from 'react/jsx-runtime';
|
|
3
|
-
import { forwardRef, useRef, useEffect } from 'react';
|
|
4
|
-
import { Divider } from '@hh.ru/magritte-ui-divider';
|
|
5
|
-
|
|
6
|
-
var styles = {"drop":"magritte-drop___Z10P4_6-0-2","drop-container":"magritte-drop-container___dbMt9_6-0-2","dropContainer":"magritte-drop-container___dbMt9_6-0-2","drop-footer":"magritte-drop-footer___v8ZEO_6-0-2","dropFooter":"magritte-drop-footer___v8ZEO_6-0-2","drop-space-300":"magritte-drop-space-300___41acH_6-0-2","dropSpace300":"magritte-drop-space-300___41acH_6-0-2","drop-space-400":"magritte-drop-space-400___XX1RM_6-0-2","dropSpace400":"magritte-drop-space-400___XX1RM_6-0-2","drop-padding":"magritte-drop-padding___xBiJO_6-0-2","dropPadding":"magritte-drop-padding___xBiJO_6-0-2","drop-space-600":"magritte-drop-space-600___6B1i0_6-0-2","dropSpace600":"magritte-drop-space-600___6B1i0_6-0-2","drop-with-footer":"magritte-drop-with-footer___CgBIV_6-0-2","dropWithFooter":"magritte-drop-with-footer___CgBIV_6-0-2","drop-enter":"magritte-drop-enter___4vEuH_6-0-2","dropEnter":"magritte-drop-enter___4vEuH_6-0-2","drop-exit":"magritte-drop-exit___brFjz_6-0-2","dropExit":"magritte-drop-exit___brFjz_6-0-2","drop-enter-active":"magritte-drop-enter-active___SQUog_6-0-2","dropEnterActive":"magritte-drop-enter-active___SQUog_6-0-2","drop-exit-active":"magritte-drop-exit-active___GB0ET_6-0-2","dropExitActive":"magritte-drop-exit-active___GB0ET_6-0-2","drop-animation-timeout":"magritte-drop-animation-timeout___uO7LF_6-0-2","dropAnimationTimeout":"magritte-drop-animation-timeout___uO7LF_6-0-2","drop-direction-top":"magritte-drop-direction-top___3CelS_6-0-2","dropDirectionTop":"magritte-drop-direction-top___3CelS_6-0-2","drop-direction-bottom":"magritte-drop-direction-bottom___719rs_6-0-2","dropDirectionBottom":"magritte-drop-direction-bottom___719rs_6-0-2","drop-direction-left":"magritte-drop-direction-left___2PTob_6-0-2","dropDirectionLeft":"magritte-drop-direction-left___2PTob_6-0-2","drop-direction-right":"magritte-drop-direction-right___SPOr1_6-0-2","dropDirectionRight":"magritte-drop-direction-right___SPOr1_6-0-2"};
|
|
7
|
-
|
|
8
|
-
const DropContainer = forwardRef(({ children, height, dividerState, minHeightForContent }, ref) => {
|
|
9
|
-
const dividerRef = useRef(null);
|
|
10
|
-
const showDivider = dividerState !== 'hide';
|
|
11
|
-
useEffect(() => {
|
|
12
|
-
if (showDivider && ref && 'current' in ref && ref?.current !== null && dividerRef.current && !!height) {
|
|
13
|
-
const hasScroll = ref.current.scrollHeight - ref.current.clientHeight > 0;
|
|
14
|
-
dividerRef.current.style.visibility = hasScroll ? 'visible' : 'hidden';
|
|
15
|
-
}
|
|
16
|
-
}, [ref, dividerRef, height, showDivider]);
|
|
17
|
-
const props = showDivider
|
|
18
|
-
? {
|
|
19
|
-
onScroll: ({ target }) => {
|
|
20
|
-
const scrollableContainer = target;
|
|
21
|
-
if (dividerRef.current && dividerState !== 'showWhenFullyScrolled') {
|
|
22
|
-
const scrollEnded = scrollableContainer.scrollTop +
|
|
23
|
-
scrollableContainer.offsetHeight -
|
|
24
|
-
scrollableContainer.scrollHeight ===
|
|
25
|
-
0;
|
|
26
|
-
dividerRef.current.style.visibility = scrollEnded ? 'hidden' : 'visible';
|
|
27
|
-
}
|
|
28
|
-
},
|
|
29
|
-
}
|
|
30
|
-
: {};
|
|
31
|
-
return (jsxs(Fragment, { children: [jsx("div", { ref: ref, className: styles.dropContainer, style: { height: height === undefined ? `${minHeightForContent}px` : 'auto' }, ...props, children: children }), showDivider && (jsx("div", { ref: dividerRef, "data-qa": "drop-divider", children: jsx(Divider, {}) }))] }));
|
|
32
|
-
});
|
|
33
|
-
DropContainer.displayName = 'DropContainer';
|
|
34
|
-
|
|
35
|
-
export { DropContainer as D, styles as s };
|
|
36
|
-
//# sourceMappingURL=DropContainer-b6c5e458.js.map
|