@servicetitan/navigation 11.0.0 → 11.1.1
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/dist/components/badge-tag.js +7 -2
- package/dist/components/badge-tag.js.map +1 -1
- package/dist/components/counter-tag.js +10 -2
- package/dist/components/counter-tag.js.map +1 -1
- package/dist/components/header-navigation/header-navigation-content.js +44 -8
- package/dist/components/header-navigation/header-navigation-content.js.map +1 -1
- package/dist/components/header-navigation/header-navigation-links.js +49 -13
- package/dist/components/header-navigation/header-navigation-links.js.map +1 -1
- package/dist/components/header-navigation/header-navigation-stories.module.less.d.ts +3 -0
- package/dist/components/header-navigation/header-navigation.js +178 -46
- package/dist/components/header-navigation/header-navigation.js.map +1 -1
- package/dist/components/header-navigation/header-navigation.module.less.d.ts +22 -0
- package/dist/components/header-navigation/index.js +1 -0
- package/dist/components/header-navigation/index.js.map +1 -1
- package/dist/components/header-navigation/with-tooltip.js +7 -1
- package/dist/components/header-navigation/with-tooltip.js.map +1 -1
- package/dist/components/left-navigation/header-navigation-tiny-links.js +62 -15
- package/dist/components/left-navigation/header-navigation-tiny-links.js.map +1 -1
- package/dist/components/left-navigation/header-navigation-tiny.js +27 -2
- package/dist/components/left-navigation/header-navigation-tiny.js.map +1 -1
- package/dist/components/left-navigation/header-navigation-tiny.module.less.d.ts +15 -0
- package/dist/components/left-navigation/index.d.ts +1 -1
- package/dist/components/left-navigation/index.d.ts.map +1 -1
- package/dist/components/left-navigation/index.js +1 -1
- package/dist/components/left-navigation/index.js.map +1 -1
- package/dist/components/left-navigation/interface-internal.js +2 -1
- package/dist/components/left-navigation/interface-internal.js.map +1 -1
- package/dist/components/left-navigation/interface.js +2 -1
- package/dist/components/left-navigation/interface.js.map +1 -1
- package/dist/components/left-navigation/side-navigation-context.js +4 -3
- package/dist/components/left-navigation/side-navigation-context.js.map +1 -1
- package/dist/components/left-navigation/side-navigation-links-internal.js +76 -16
- package/dist/components/left-navigation/side-navigation-links-internal.js.map +1 -1
- package/dist/components/left-navigation/side-navigation-links.js +34 -13
- package/dist/components/left-navigation/side-navigation-links.js.map +1 -1
- package/dist/components/left-navigation/side-navigation.js +314 -85
- package/dist/components/left-navigation/side-navigation.js.map +1 -1
- package/dist/components/left-navigation/side-navigation.module.less.d.ts +48 -0
- package/dist/components/left-navigation/with-tooltip.js +12 -1
- package/dist/components/left-navigation/with-tooltip.js.map +1 -1
- package/dist/components/links.js +28 -7
- package/dist/components/links.js.map +1 -1
- package/dist/components/logo/logo-company-title.js +19 -3
- package/dist/components/logo/logo-company-title.js.map +1 -1
- package/dist/components/logo/logo-titan-text.js +50 -6
- package/dist/components/logo/logo-titan-text.js.map +1 -1
- package/dist/components/logo/logo-titan-text.module.less.d.ts +6 -0
- package/dist/components/logo/logo-titan.d.ts +1 -0
- package/dist/components/logo/logo-titan.d.ts.map +1 -1
- package/dist/components/logo/logo-titan.js +53 -8
- package/dist/components/logo/logo-titan.js.map +1 -1
- package/dist/components/profile-dropdown/profile-dropdown.d.ts.map +1 -1
- package/dist/components/profile-dropdown/profile-dropdown.js +174 -33
- package/dist/components/profile-dropdown/profile-dropdown.js.map +1 -1
- package/dist/components/profile-dropdown/profile-dropdown.module.less.d.ts +23 -0
- package/dist/components/profile-dropdown/profile-icon.js +49 -3
- package/dist/components/profile-dropdown/profile-icon.js.map +1 -1
- package/dist/components/titan-layout/index.d.ts +2 -2
- package/dist/components/titan-layout/index.d.ts.map +1 -1
- package/dist/components/titan-layout/index.js +1 -2
- package/dist/components/titan-layout/index.js.map +1 -1
- package/dist/components/titan-layout/interface-internal.js +2 -1
- package/dist/components/titan-layout/interface-internal.js.map +1 -1
- package/dist/components/titan-layout/interface.js +2 -1
- package/dist/components/titan-layout/interface.js.map +1 -1
- package/dist/components/titan-layout/layout-context.js +15 -6
- package/dist/components/titan-layout/layout-context.js.map +1 -1
- package/dist/components/titan-layout/layout-header-dark.d.ts +10 -0
- package/dist/components/titan-layout/layout-header-dark.d.ts.map +1 -0
- package/dist/components/titan-layout/layout-header-dark.js +146 -0
- package/dist/components/titan-layout/layout-header-dark.js.map +1 -0
- package/dist/components/titan-layout/layout-header-links.js +61 -15
- package/dist/components/titan-layout/layout-header-links.js.map +1 -1
- package/dist/components/titan-layout/layout-header.d.ts +2 -6
- package/dist/components/titan-layout/layout-header.d.ts.map +1 -1
- package/dist/components/titan-layout/layout-header.js +46 -2
- package/dist/components/titan-layout/layout-header.js.map +1 -1
- package/dist/components/titan-layout/layout-header.module.less +337 -83
- package/dist/components/titan-layout/layout-header.module.less.d.ts +35 -0
- package/dist/components/titan-layout/layout-logo.d.ts +5 -3
- package/dist/components/titan-layout/layout-logo.d.ts.map +1 -1
- package/dist/components/titan-layout/layout-logo.js +47 -9
- package/dist/components/titan-layout/layout-logo.js.map +1 -1
- package/dist/components/titan-layout/layout-logo.stories.d.ts +15 -4
- package/dist/components/titan-layout/layout-logo.stories.d.ts.map +1 -1
- package/dist/components/titan-layout/layout-profile.js +75 -23
- package/dist/components/titan-layout/layout-profile.js.map +1 -1
- package/dist/components/titan-layout/layout-sidebar-links-internal.js +162 -36
- package/dist/components/titan-layout/layout-sidebar-links-internal.js.map +1 -1
- package/dist/components/titan-layout/layout-sidebar-links.js +33 -13
- package/dist/components/titan-layout/layout-sidebar-links.js.map +1 -1
- package/dist/components/titan-layout/layout-sidebar.js +198 -34
- package/dist/components/titan-layout/layout-sidebar.js.map +1 -1
- package/dist/components/titan-layout/layout-sidebar.module.less +6 -2
- package/dist/components/titan-layout/layout-sidebar.module.less.d.ts +49 -0
- package/dist/components/titan-layout/notifications-context.js +20 -10
- package/dist/components/titan-layout/notifications-context.js.map +1 -1
- package/dist/components/titan-layout/titan-layout.d.ts +7 -8
- package/dist/components/titan-layout/titan-layout.d.ts.map +1 -1
- package/dist/components/titan-layout/titan-layout.js +271 -117
- package/dist/components/titan-layout/titan-layout.js.map +1 -1
- package/dist/components/titan-layout/titan-layout.module.less +7 -2
- package/dist/components/titan-layout/titan-layout.module.less.d.ts +17 -0
- package/dist/components/titan-layout/titan-layout.stories.d.ts +6 -0
- package/dist/components/titan-layout/titan-layout.stories.d.ts.map +1 -1
- package/dist/components/titan-layout/with-tooltip.d.ts +4 -1
- package/dist/components/titan-layout/with-tooltip.d.ts.map +1 -1
- package/dist/components/titan-layout/with-tooltip.js +13 -1
- package/dist/components/titan-layout/with-tooltip.js.map +1 -1
- package/dist/index.d.ts +4 -3
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -3
- package/dist/index.js.map +1 -1
- package/dist/test/data-stories.module.less.d.ts +3 -0
- package/dist/test/data.js +223 -90
- package/dist/test/data.js.map +1 -1
- package/dist/utils/counter-tag.js +2 -1
- package/dist/utils/counter-tag.js.map +1 -1
- package/dist/utils/navigation-context.js +12 -6
- package/dist/utils/navigation-context.js.map +1 -1
- package/dist/utils/navigation-legacy.js +2 -1
- package/dist/utils/navigation-legacy.js.map +1 -1
- package/dist/utils/navigation.js +2 -1
- package/dist/utils/navigation.js.map +1 -1
- package/dist/utils/side-nav.js +9 -6
- package/dist/utils/side-nav.js.map +1 -1
- package/dist/utils/use-breakpoint.js +11 -8
- package/dist/utils/use-breakpoint.js.map +1 -1
- package/package.json +4 -4
- package/src/components/left-navigation/index.ts +1 -1
- package/src/components/logo/logo-titan.tsx +3 -1
- package/src/components/profile-dropdown/profile-dropdown.tsx +8 -4
- package/src/components/titan-layout/index.ts +2 -2
- package/src/components/titan-layout/layout-header-dark.tsx +186 -0
- package/src/components/titan-layout/layout-header-links.tsx +1 -1
- package/src/components/titan-layout/layout-header.module.less +337 -83
- package/src/components/titan-layout/layout-header.module.less.d.ts +19 -2
- package/src/components/titan-layout/layout-header.tsx +13 -16
- package/src/components/titan-layout/layout-logo.stories.tsx +103 -15
- package/src/components/titan-layout/layout-logo.tsx +33 -36
- package/src/components/titan-layout/layout-profile.stories.tsx +1 -1
- package/src/components/titan-layout/layout-sidebar.module.less +6 -2
- package/src/components/titan-layout/layout-sidebar.tsx +1 -1
- package/src/components/titan-layout/titan-layout.module.less +7 -2
- package/src/components/titan-layout/titan-layout.module.less.d.ts +2 -1
- package/src/components/titan-layout/titan-layout.stories.tsx +80 -23
- package/src/components/titan-layout/titan-layout.tsx +96 -85
- package/src/components/titan-layout/with-tooltip.tsx +5 -2
- package/src/index.ts +4 -5
- package/dist/components/header-navigation/header-navigation-extra-stacked.stories.js +0 -13
- package/dist/components/header-navigation/header-navigation-extra-stacked.stories.js.map +0 -1
- package/dist/components/header-navigation/header-navigation-extra.stories.js +0 -29
- package/dist/components/header-navigation/header-navigation-extra.stories.js.map +0 -1
- package/dist/components/header-navigation/header-navigation-stacked.stories.js +0 -50
- package/dist/components/header-navigation/header-navigation-stacked.stories.js.map +0 -1
- package/dist/components/header-navigation/header-navigation.stories.js +0 -54
- package/dist/components/header-navigation/header-navigation.stories.js.map +0 -1
- package/dist/components/layout.stories.js +0 -29
- package/dist/components/layout.stories.js.map +0 -1
- package/dist/components/left-navigation/header-navigation-extra-tiny.stories.js +0 -13
- package/dist/components/left-navigation/header-navigation-extra-tiny.stories.js.map +0 -1
- package/dist/components/left-navigation/header-navigation-tiny.stories.js +0 -30
- package/dist/components/left-navigation/header-navigation-tiny.stories.js.map +0 -1
- package/dist/components/left-navigation/side-navigation.stories.js +0 -115
- package/dist/components/left-navigation/side-navigation.stories.js.map +0 -1
- package/dist/components/logo/logo.stories.js +0 -20
- package/dist/components/logo/logo.stories.js.map +0 -1
- package/dist/components/profile-dropdown/profile-dropdown-stacked.stories.js +0 -13
- package/dist/components/profile-dropdown/profile-dropdown-stacked.stories.js.map +0 -1
- package/dist/components/profile-dropdown/profile-dropdown-tiny.stories.js +0 -13
- package/dist/components/profile-dropdown/profile-dropdown-tiny.stories.js.map +0 -1
- package/dist/components/profile-dropdown/profile-dropdown.stories.js +0 -51
- package/dist/components/profile-dropdown/profile-dropdown.stories.js.map +0 -1
- package/dist/components/titan-layout/layout-logo.stories.js +0 -17
- package/dist/components/titan-layout/layout-logo.stories.js.map +0 -1
- package/dist/components/titan-layout/layout-profile.stories.js +0 -13
- package/dist/components/titan-layout/layout-profile.stories.js.map +0 -1
- package/dist/components/titan-layout/titan-layout.stories.js +0 -83
- package/dist/components/titan-layout/titan-layout.stories.js.map +0 -1
|
@@ -1,8 +1,13 @@
|
|
|
1
1
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
2
|
import { Badge } from '@servicetitan/anvil2';
|
|
3
3
|
import classNames from 'classnames';
|
|
4
|
-
export const BadgeTag = ({ className, data, longClassName })
|
|
4
|
+
export const BadgeTag = ({ className, data, longClassName })=>{
|
|
5
5
|
const { value, className: dataClassName, ...rest } = data !== null && data !== void 0 ? data : {};
|
|
6
|
-
return value ?
|
|
6
|
+
return value ? /*#__PURE__*/ _jsx(Badge, {
|
|
7
|
+
...rest,
|
|
8
|
+
className: classNames(className, dataClassName, typeof value === 'number' && value >= 100 && longClassName),
|
|
9
|
+
children: typeof value === 'number' ? value >= 100 ? '99+' : value : undefined
|
|
10
|
+
}) : null;
|
|
7
11
|
};
|
|
12
|
+
|
|
8
13
|
//# sourceMappingURL=badge-tag.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"sources":["../../src/components/badge-tag.tsx"],"sourcesContent":["import { Badge } from '@servicetitan/anvil2';\nimport classNames from 'classnames';\nimport { FC } from 'react';\nimport { CounterTagData } from '../utils/counter-tag';\n\nexport interface BadgeTagProps extends CounterTagData {\n [key: string]: any;\n className?: string;\n}\n\nexport const BadgeTag: FC<{\n className?: string;\n longClassName?: string;\n data: BadgeTagProps | undefined;\n}> = ({ className, data, longClassName }) => {\n const { value, className: dataClassName, ...rest } = data ?? {};\n\n return value ? (\n <Badge\n {...rest}\n className={classNames(\n className,\n dataClassName,\n typeof value === 'number' && value >= 100 && longClassName\n )}\n >\n {typeof value === 'number' ? (value >= 100 ? '99+' : value) : undefined}\n </Badge>\n ) : null;\n};\n"],"names":["Badge","classNames","BadgeTag","className","data","longClassName","value","dataClassName","rest","undefined"],"mappings":";AAAA,SAASA,KAAK,QAAQ,uBAAuB;AAC7C,OAAOC,gBAAgB,aAAa;AASpC,OAAO,MAAMC,WAIR,CAAC,EAAEC,SAAS,EAAEC,IAAI,EAAEC,aAAa,EAAE;IACpC,MAAM,EAAEC,KAAK,EAAEH,WAAWI,aAAa,EAAE,GAAGC,MAAM,GAAGJ,iBAAAA,kBAAAA,OAAQ,CAAC;IAE9D,OAAOE,sBACH,KAACN;QACI,GAAGQ,IAAI;QACRL,WAAWF,WACPE,WACAI,eACA,OAAOD,UAAU,YAAYA,SAAS,OAAOD;kBAGhD,OAAOC,UAAU,WAAYA,SAAS,MAAM,QAAQA,QAASG;SAElE;AACR,EAAE"}
|
|
@@ -1,8 +1,16 @@
|
|
|
1
1
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
2
|
import { Tag } from '@servicetitan/design-system';
|
|
3
3
|
import classNames from 'classnames';
|
|
4
|
-
export const CounterTag = ({ className, data, longClassName })
|
|
4
|
+
export const CounterTag = ({ className, data, longClassName })=>{
|
|
5
5
|
const { value, className: dataClassName, ...rest } = data !== null && data !== void 0 ? data : {};
|
|
6
|
-
return value ?
|
|
6
|
+
return value ? /*#__PURE__*/ _jsx(Tag, {
|
|
7
|
+
color: "critical",
|
|
8
|
+
...rest,
|
|
9
|
+
className: classNames(className, dataClassName, typeof value === 'number' && value > 10 && longClassName),
|
|
10
|
+
compact: true,
|
|
11
|
+
badge: true,
|
|
12
|
+
children: value
|
|
13
|
+
}) : null;
|
|
7
14
|
};
|
|
15
|
+
|
|
8
16
|
//# sourceMappingURL=counter-tag.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"sources":["../../src/components/counter-tag.tsx"],"sourcesContent":["import { Tag } from '@servicetitan/design-system';\nimport classNames from 'classnames';\nimport { FC } from 'react';\nimport { CounterTagData } from '../utils/counter-tag';\n\nexport interface CounterTagProps extends CounterTagData {\n [key: string]: any;\n className: string;\n}\n\nexport const CounterTag: FC<{\n className?: string;\n longClassName?: string;\n data: CounterTagProps | undefined;\n}> = ({ className, data, longClassName }) => {\n const { value, className: dataClassName, ...rest } = data ?? {};\n\n return value ? (\n <Tag\n color=\"critical\"\n {...rest}\n className={classNames(\n className,\n dataClassName,\n typeof value === 'number' && value > 10 && longClassName\n )}\n compact\n badge\n >\n {value}\n </Tag>\n ) : null;\n};\n"],"names":["Tag","classNames","CounterTag","className","data","longClassName","value","dataClassName","rest","color","compact","badge"],"mappings":";AAAA,SAASA,GAAG,QAAQ,8BAA8B;AAClD,OAAOC,gBAAgB,aAAa;AASpC,OAAO,MAAMC,aAIR,CAAC,EAAEC,SAAS,EAAEC,IAAI,EAAEC,aAAa,EAAE;IACpC,MAAM,EAAEC,KAAK,EAAEH,WAAWI,aAAa,EAAE,GAAGC,MAAM,GAAGJ,iBAAAA,kBAAAA,OAAQ,CAAC;IAE9D,OAAOE,sBACH,KAACN;QACGS,OAAM;QACL,GAAGD,IAAI;QACRL,WAAWF,WACPE,WACAI,eACA,OAAOD,UAAU,YAAYA,QAAQ,MAAMD;QAE/CK,OAAO;QACPC,KAAK;kBAEJL;SAEL;AACR,EAAE"}
|
|
@@ -7,16 +7,52 @@ import { getCounterTag } from '../../utils/side-nav';
|
|
|
7
7
|
import { CounterTag } from '../counter-tag';
|
|
8
8
|
import * as Styles from './header-navigation.module.less';
|
|
9
9
|
import { withTooltip } from './with-tooltip';
|
|
10
|
-
/** Content for navigation items */
|
|
11
|
-
export const HeaderNavigationItemContent = ({ title, titleClassName, counterClassName, iconClassName, iconComponent: IconComponent, iconName, tag, }) => {
|
|
10
|
+
/** Content for navigation items */ export const HeaderNavigationItemContent = ({ title, titleClassName, counterClassName, iconClassName, iconComponent: IconComponent, iconName, tag })=>{
|
|
12
11
|
const iconClass = classNames(Styles.navigationIcon, iconClassName);
|
|
13
|
-
return
|
|
12
|
+
return /*#__PURE__*/ _jsxs(Fragment, {
|
|
13
|
+
children: [
|
|
14
|
+
IconComponent ? /*#__PURE__*/ _jsx("i", {
|
|
15
|
+
className: iconClass,
|
|
16
|
+
children: /*#__PURE__*/ _jsx(IconComponent, {})
|
|
17
|
+
}) : iconName ? /*#__PURE__*/ _jsx(Icon, {
|
|
18
|
+
name: iconName,
|
|
19
|
+
className: iconClass
|
|
20
|
+
}) : /*#__PURE__*/ _jsx("i", {
|
|
21
|
+
className: iconClass
|
|
22
|
+
}),
|
|
23
|
+
!!title && /*#__PURE__*/ _jsx("span", {
|
|
24
|
+
className: classNames(Styles.navigationItemTitle, titleClassName),
|
|
25
|
+
children: title
|
|
26
|
+
}),
|
|
27
|
+
!!tag && /*#__PURE__*/ _jsx(CounterTag, {
|
|
28
|
+
data: tag,
|
|
29
|
+
className: classNames(Styles.navigationItemCounter, counterClassName),
|
|
30
|
+
longClassName: Styles.navigationItemCounterLong
|
|
31
|
+
})
|
|
32
|
+
]
|
|
33
|
+
});
|
|
14
34
|
};
|
|
15
|
-
/** Navigation main menu item */
|
|
16
|
-
export const HeaderNavigationItem = ({ id, to, counter, title, hint, className, iconClassName, iconComponent, iconName, isActive, main, minimized, tag, }) => {
|
|
35
|
+
/** Navigation main menu item */ export const HeaderNavigationItem = ({ id, to, counter, title, hint, className, iconClassName, iconComponent, iconName, isActive, main, minimized, tag })=>{
|
|
17
36
|
const NavigationComponent = useContext(NavigationComponentContext);
|
|
18
|
-
return withTooltip(_jsx(NavigationComponent, {
|
|
19
|
-
|
|
20
|
-
|
|
37
|
+
return withTooltip(/*#__PURE__*/ _jsx(NavigationComponent, {
|
|
38
|
+
"data-cy": `navigation-item-${id}`,
|
|
39
|
+
"data-pendo": `navigation-item-${id}`,
|
|
40
|
+
to: to,
|
|
41
|
+
title: hint,
|
|
42
|
+
className: classNames(Styles.navigationItem, main ? Styles.navigationItemMain : Styles.navigationItemOverflow, className, {
|
|
43
|
+
[Styles.navigationItemActive]: isActive === true
|
|
44
|
+
}),
|
|
45
|
+
isActive: typeof isActive === 'function' ? isActive : undefined,
|
|
46
|
+
activeClassName: Styles.navigationItemActive,
|
|
47
|
+
children: /*#__PURE__*/ _jsx(HeaderNavigationItemContent, {
|
|
48
|
+
title: minimized ? undefined : title,
|
|
49
|
+
titleClassName: main ? '' : 'm-l-half',
|
|
50
|
+
tag: getCounterTag(counter, tag),
|
|
51
|
+
iconComponent: iconComponent,
|
|
52
|
+
iconClassName: iconClassName,
|
|
53
|
+
iconName: iconName
|
|
54
|
+
})
|
|
55
|
+
}, id), minimized ? title : undefined);
|
|
21
56
|
};
|
|
57
|
+
|
|
22
58
|
//# sourceMappingURL=header-navigation-content.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"sources":["../../../src/components/header-navigation/header-navigation-content.tsx"],"sourcesContent":["import { Icon, IconPropsStrict } from '@servicetitan/design-system';\nimport classNames from 'classnames';\nimport { FC, Fragment, useContext } from 'react';\nimport { NavigationComponentContext } from '../../utils/navigation-context';\nimport { HeaderNavigationItemData } from '../../utils/navigation-legacy';\nimport { getCounterTag } from '../../utils/side-nav';\nimport { CounterTag, CounterTagProps } from '../counter-tag';\nimport * as Styles from './header-navigation.module.less';\nimport { withTooltip } from './with-tooltip';\n\nexport interface HeaderNavigationItemContentPropsStrict {\n /** item text */\n title?: string;\n /** text component class name */\n titleClassName?: string;\n /** counter tag shown for item */\n tag: CounterTagProps | undefined;\n /** counter component class name */\n counterClassName?: string;\n /** icon component class name */\n iconClassName?: string;\n /** IconComponent custom icon component */\n iconComponent?: FC;\n /** iconName name of anvil icon */\n iconName?: IconPropsStrict['name'];\n}\n\n/** Content for navigation items */\nexport const HeaderNavigationItemContent: FC<HeaderNavigationItemContentPropsStrict> = ({\n title,\n titleClassName,\n counterClassName,\n iconClassName,\n iconComponent: IconComponent,\n iconName,\n tag,\n}) => {\n const iconClass = classNames(Styles.navigationIcon, iconClassName);\n return (\n <Fragment>\n {IconComponent ? (\n <i className={iconClass}>\n <IconComponent />\n </i>\n ) : iconName ? (\n <Icon name={iconName} className={iconClass} />\n ) : (\n <i className={iconClass} />\n )}\n\n {!!title && (\n <span className={classNames(Styles.navigationItemTitle, titleClassName)}>\n {title}\n </span>\n )}\n\n {!!tag && (\n <CounterTag\n data={tag}\n className={classNames(Styles.navigationItemCounter, counterClassName)}\n longClassName={Styles.navigationItemCounterLong}\n />\n )}\n </Fragment>\n );\n};\n\ninterface HeaderNavigationItemPropsStrict extends HeaderNavigationItemData {\n minimized: boolean;\n main: boolean;\n}\n\n/** Navigation main menu item */\nexport const HeaderNavigationItem: FC<HeaderNavigationItemPropsStrict> = ({\n id,\n to,\n counter,\n title,\n hint,\n className,\n iconClassName,\n iconComponent,\n iconName,\n isActive,\n main,\n minimized,\n tag,\n}) => {\n const NavigationComponent = useContext(NavigationComponentContext);\n\n return withTooltip(\n <NavigationComponent\n data-cy={`navigation-item-${id}`}\n data-pendo={`navigation-item-${id}`}\n key={id}\n to={to}\n title={hint}\n className={classNames(\n Styles.navigationItem,\n main ? Styles.navigationItemMain : Styles.navigationItemOverflow,\n className,\n {\n [Styles.navigationItemActive]: isActive === true,\n }\n )}\n isActive={typeof isActive === 'function' ? isActive : undefined}\n activeClassName={Styles.navigationItemActive}\n >\n <HeaderNavigationItemContent\n title={minimized ? undefined : title}\n titleClassName={main ? '' : 'm-l-half'}\n tag={getCounterTag(counter, tag)}\n iconComponent={iconComponent}\n iconClassName={iconClassName}\n iconName={iconName}\n />\n </NavigationComponent>,\n minimized ? title : undefined\n );\n};\n"],"names":["Icon","classNames","Fragment","useContext","NavigationComponentContext","getCounterTag","CounterTag","Styles","withTooltip","HeaderNavigationItemContent","title","titleClassName","counterClassName","iconClassName","iconComponent","IconComponent","iconName","tag","iconClass","navigationIcon","i","className","name","span","navigationItemTitle","data","navigationItemCounter","longClassName","navigationItemCounterLong","HeaderNavigationItem","id","to","counter","hint","isActive","main","minimized","NavigationComponent","data-cy","data-pendo","navigationItem","navigationItemMain","navigationItemOverflow","navigationItemActive","undefined","activeClassName"],"mappings":";AAAA,SAASA,IAAI,QAAyB,8BAA8B;AACpE,OAAOC,gBAAgB,aAAa;AACpC,SAAaC,QAAQ,EAAEC,UAAU,QAAQ,QAAQ;AACjD,SAASC,0BAA0B,QAAQ,iCAAiC;AAE5E,SAASC,aAAa,QAAQ,uBAAuB;AACrD,SAASC,UAAU,QAAyB,iBAAiB;AAC7D,YAAYC,YAAY,kCAAkC;AAC1D,SAASC,WAAW,QAAQ,iBAAiB;AAmB7C,iCAAiC,GACjC,OAAO,MAAMC,8BAA0E,CAAC,EACpFC,KAAK,EACLC,cAAc,EACdC,gBAAgB,EAChBC,aAAa,EACbC,eAAeC,aAAa,EAC5BC,QAAQ,EACRC,GAAG,EACN;IACG,MAAMC,YAAYjB,WAAWM,OAAOY,cAAc,EAAEN;IACpD,qBACI,MAACX;;YACIa,8BACG,KAACK;gBAAEC,WAAWH;0BACV,cAAA,KAACH;iBAELC,yBACA,KAAChB;gBAAKsB,MAAMN;gBAAUK,WAAWH;+BAEjC,KAACE;gBAAEC,WAAWH;;YAGjB,CAAC,CAACR,uBACC,KAACa;gBAAKF,WAAWpB,WAAWM,OAAOiB,mBAAmB,EAAEb;0BACnDD;;YAIR,CAAC,CAACO,qBACC,KAACX;gBACGmB,MAAMR;gBACNI,WAAWpB,WAAWM,OAAOmB,qBAAqB,EAAEd;gBACpDe,eAAepB,OAAOqB,yBAAyB;;;;AAKnE,EAAE;AAOF,8BAA8B,GAC9B,OAAO,MAAMC,uBAA4D,CAAC,EACtEC,EAAE,EACFC,EAAE,EACFC,OAAO,EACPtB,KAAK,EACLuB,IAAI,EACJZ,SAAS,EACTR,aAAa,EACbC,aAAa,EACbE,QAAQ,EACRkB,QAAQ,EACRC,IAAI,EACJC,SAAS,EACTnB,GAAG,EACN;IACG,MAAMoB,sBAAsBlC,WAAWC;IAEvC,OAAOI,0BACH,KAAC6B;QACGC,WAAS,CAAC,gBAAgB,EAAER,IAAI;QAChCS,cAAY,CAAC,gBAAgB,EAAET,IAAI;QAEnCC,IAAIA;QACJrB,OAAOuB;QACPZ,WAAWpB,WACPM,OAAOiC,cAAc,EACrBL,OAAO5B,OAAOkC,kBAAkB,GAAGlC,OAAOmC,sBAAsB,EAChErB,WACA;YACI,CAACd,OAAOoC,oBAAoB,CAAC,EAAET,aAAa;QAChD;QAEJA,UAAU,OAAOA,aAAa,aAAaA,WAAWU;QACtDC,iBAAiBtC,OAAOoC,oBAAoB;kBAE5C,cAAA,KAAClC;YACGC,OAAO0B,YAAYQ,YAAYlC;YAC/BC,gBAAgBwB,OAAO,KAAK;YAC5BlB,KAAKZ,cAAc2B,SAASf;YAC5BH,eAAeA;YACfD,eAAeA;YACfG,UAAUA;;OApBTc,KAuBTM,YAAY1B,QAAQkC;AAE5B,EAAE"}
|
|
@@ -7,20 +7,56 @@ import { getCounterTag } from '../../utils/side-nav';
|
|
|
7
7
|
import { HeaderNavigationItemContent } from './header-navigation-content';
|
|
8
8
|
import * as Styles from './header-navigation.module.less';
|
|
9
9
|
import { withTooltip } from './with-tooltip';
|
|
10
|
-
/** Navigation extra item with link */
|
|
11
|
-
export const HeaderNavigationLink = ({ id, to, counter, hint, tooltip, className, icon, iconActive, iconClassName, iconComponent, iconName, isActive, label, labelClassName, tag, target, title, ...rest }) => {
|
|
10
|
+
/** Navigation extra item with link */ export const HeaderNavigationLink = ({ id, to, counter, hint, tooltip, className, icon, iconActive, iconClassName, iconComponent, iconName, isActive, label, labelClassName, tag, target, title, ...rest })=>{
|
|
12
11
|
const NavigationComponent = useContext(NavigationComponentContext);
|
|
13
|
-
return withTooltip(_createElement(NavigationComponent, {
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
12
|
+
return withTooltip(/*#__PURE__*/ _createElement(NavigationComponent, {
|
|
13
|
+
"data-cy": `navigation-link-${id}`,
|
|
14
|
+
"data-pendo": `navigation-link-${id}`,
|
|
15
|
+
...rest,
|
|
16
|
+
key: id,
|
|
17
|
+
to: to,
|
|
18
|
+
title: hint,
|
|
19
|
+
className: classNames(Styles.navigationLink, Styles.navigationItem, className, {
|
|
20
|
+
[Styles.navigationItemActive]: isActive === true
|
|
21
|
+
}),
|
|
22
|
+
isActive: typeof isActive === 'function' ? isActive : undefined,
|
|
23
|
+
activeClassName: Styles.navigationItemActive,
|
|
24
|
+
target: target
|
|
25
|
+
}, /*#__PURE__*/ _jsx(HeaderNavigationItemContent, {
|
|
26
|
+
tag: getCounterTag(counter, tag),
|
|
27
|
+
iconComponent: iconComponent,
|
|
28
|
+
iconClassName: iconClassName,
|
|
29
|
+
iconName: iconName,
|
|
30
|
+
title: label,
|
|
31
|
+
titleClassName: labelClassName
|
|
32
|
+
})), tooltip);
|
|
17
33
|
};
|
|
18
|
-
/** Navigation extra item with icon button */
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
34
|
+
/** Navigation extra item with icon button */ export const HeaderNavigationTrigger = ({ id, className, counter, icon, iconActive, iconClassName, iconComponent, iconName, isActive, label, labelClassName, hint, tag, tooltip, title, ...rest })=>{
|
|
35
|
+
return withTooltip(/*#__PURE__*/ _jsx("div", {
|
|
36
|
+
"data-cy": `navigation-trigger-${id}`,
|
|
37
|
+
"data-pendo": `navigation-trigger-${id}`,
|
|
38
|
+
...rest,
|
|
39
|
+
title: hint,
|
|
40
|
+
className: classNames(Styles.navigationItem, Styles.navigationLink, {
|
|
41
|
+
[Styles.navigationItemActive]: isActive === true
|
|
42
|
+
}, 'cursor-pointer', className),
|
|
43
|
+
children: /*#__PURE__*/ _jsx(HeaderNavigationItemContent, {
|
|
44
|
+
tag: getCounterTag(counter, tag),
|
|
45
|
+
iconComponent: iconComponent,
|
|
46
|
+
iconClassName: iconClassName,
|
|
47
|
+
iconName: iconName,
|
|
48
|
+
title: label,
|
|
49
|
+
titleClassName: labelClassName
|
|
50
|
+
})
|
|
51
|
+
}), tooltip);
|
|
23
52
|
};
|
|
24
|
-
/** Navigation extra item with custom content */
|
|
25
|
-
|
|
53
|
+
/** Navigation extra item with custom content */ export const HeaderNavigationTriggerCustom = ({ children, id, className, tooltip, title, ...rest })=>withTooltip(/*#__PURE__*/ _jsx("div", {
|
|
54
|
+
"data-cy": `navigation-custom-${id}`,
|
|
55
|
+
"data-pendo": `navigation-custom-${id}`,
|
|
56
|
+
...rest,
|
|
57
|
+
title: title,
|
|
58
|
+
className: classNames(Styles.navigationItem, Styles.navigationLink, 'cursor-pointer', className),
|
|
59
|
+
children: children
|
|
60
|
+
}), tooltip);
|
|
61
|
+
|
|
26
62
|
//# sourceMappingURL=header-navigation-links.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"sources":["../../../src/components/header-navigation/header-navigation-links.tsx"],"sourcesContent":["import classNames from 'classnames';\nimport { FC, ReactNode, useContext } from 'react';\nimport { NavigationComponentContext } from '../../utils/navigation-context';\nimport {\n HeaderNavigationLinkProps,\n HeaderNavigationTriggerProps,\n} from '../../utils/navigation-legacy';\nimport { getCounterTag } from '../../utils/side-nav';\nimport { HeaderNavigationItemContent } from './header-navigation-content';\nimport * as Styles from './header-navigation.module.less';\nimport { withTooltip } from './with-tooltip';\n\n/** Navigation extra item with link */\nexport const HeaderNavigationLink: FC<HeaderNavigationLinkProps> = ({\n id,\n to,\n counter,\n hint,\n tooltip,\n className,\n icon,\n iconActive,\n iconClassName,\n iconComponent,\n iconName,\n isActive,\n label,\n labelClassName,\n tag,\n target,\n title,\n ...rest\n}) => {\n const NavigationComponent = useContext(NavigationComponentContext);\n\n return withTooltip(\n <NavigationComponent\n data-cy={`navigation-link-${id}`}\n data-pendo={`navigation-link-${id}`}\n {...rest}\n key={id}\n to={to}\n title={hint}\n className={classNames(Styles.navigationLink, Styles.navigationItem, className, {\n [Styles.navigationItemActive]: isActive === true,\n })}\n isActive={typeof isActive === 'function' ? isActive : undefined}\n activeClassName={Styles.navigationItemActive}\n target={target}\n >\n <HeaderNavigationItemContent\n tag={getCounterTag(counter, tag)}\n iconComponent={iconComponent}\n iconClassName={iconClassName}\n iconName={iconName}\n title={label}\n titleClassName={labelClassName}\n />\n </NavigationComponent>,\n tooltip\n );\n};\n\n/** Navigation extra item with icon button */\nexport const HeaderNavigationTrigger: FC<HeaderNavigationTriggerProps> = ({\n id,\n className,\n counter,\n icon,\n iconActive,\n iconClassName,\n iconComponent,\n iconName,\n isActive,\n label,\n labelClassName,\n hint,\n tag,\n tooltip,\n title,\n ...rest\n}) => {\n return withTooltip(\n <div\n data-cy={`navigation-trigger-${id}`}\n data-pendo={`navigation-trigger-${id}`}\n {...rest}\n title={hint}\n className={classNames(\n Styles.navigationItem,\n Styles.navigationLink,\n {\n [Styles.navigationItemActive]: isActive === true,\n },\n 'cursor-pointer',\n className\n )}\n >\n <HeaderNavigationItemContent\n tag={getCounterTag(counter, tag)}\n iconComponent={iconComponent}\n iconClassName={iconClassName}\n iconName={iconName}\n title={label}\n titleClassName={labelClassName}\n />\n </div>,\n tooltip\n );\n};\n\n/** Navigation extra item with custom content */\nexport const HeaderNavigationTriggerCustom: FC<\n Omit<\n HeaderNavigationTriggerProps,\n | 'counter'\n | 'iconSize'\n | 'iconName'\n | 'iconComponent'\n | 'iconClassName'\n | 'icon'\n | 'iconActive'\n > & { children: ReactNode }\n> = ({ children, id, className, tooltip, title, ...rest }) =>\n withTooltip(\n <div\n data-cy={`navigation-custom-${id}`}\n data-pendo={`navigation-custom-${id}`}\n {...rest}\n title={title}\n className={classNames(\n Styles.navigationItem,\n Styles.navigationLink,\n 'cursor-pointer',\n className\n )}\n >\n {children}\n </div>,\n tooltip\n );\n"],"names":["classNames","useContext","NavigationComponentContext","getCounterTag","HeaderNavigationItemContent","Styles","withTooltip","HeaderNavigationLink","id","to","counter","hint","tooltip","className","icon","iconActive","iconClassName","iconComponent","iconName","isActive","label","labelClassName","tag","target","title","rest","NavigationComponent","data-cy","data-pendo","key","navigationLink","navigationItem","navigationItemActive","undefined","activeClassName","titleClassName","HeaderNavigationTrigger","div","HeaderNavigationTriggerCustom","children"],"mappings":";;AAAA,OAAOA,gBAAgB,aAAa;AACpC,SAAwBC,UAAU,QAAQ,QAAQ;AAClD,SAASC,0BAA0B,QAAQ,iCAAiC;AAK5E,SAASC,aAAa,QAAQ,uBAAuB;AACrD,SAASC,2BAA2B,QAAQ,8BAA8B;AAC1E,YAAYC,YAAY,kCAAkC;AAC1D,SAASC,WAAW,QAAQ,iBAAiB;AAE7C,oCAAoC,GACpC,OAAO,MAAMC,uBAAsD,CAAC,EAChEC,EAAE,EACFC,EAAE,EACFC,OAAO,EACPC,IAAI,EACJC,OAAO,EACPC,SAAS,EACTC,IAAI,EACJC,UAAU,EACVC,aAAa,EACbC,aAAa,EACbC,QAAQ,EACRC,QAAQ,EACRC,KAAK,EACLC,cAAc,EACdC,GAAG,EACHC,MAAM,EACNC,KAAK,EACL,GAAGC,MACN;IACG,MAAMC,sBAAsBzB,WAAWC;IAEvC,OAAOI,0BACH,eAACoB;QACGC,WAAS,CAAC,gBAAgB,EAAEnB,IAAI;QAChCoB,cAAY,CAAC,gBAAgB,EAAEpB,IAAI;QAClC,GAAGiB,IAAI;QACRI,KAAKrB;QACLC,IAAIA;QACJe,OAAOb;QACPE,WAAWb,WAAWK,OAAOyB,cAAc,EAAEzB,OAAO0B,cAAc,EAAElB,WAAW;YAC3E,CAACR,OAAO2B,oBAAoB,CAAC,EAAEb,aAAa;QAChD;QACAA,UAAU,OAAOA,aAAa,aAAaA,WAAWc;QACtDC,iBAAiB7B,OAAO2B,oBAAoB;QAC5CT,QAAQA;qBAER,KAACnB;QACGkB,KAAKnB,cAAcO,SAASY;QAC5BL,eAAeA;QACfD,eAAeA;QACfE,UAAUA;QACVM,OAAOJ;QACPe,gBAAgBd;SAGxBT;AAER,EAAE;AAEF,2CAA2C,GAC3C,OAAO,MAAMwB,0BAA4D,CAAC,EACtE5B,EAAE,EACFK,SAAS,EACTH,OAAO,EACPI,IAAI,EACJC,UAAU,EACVC,aAAa,EACbC,aAAa,EACbC,QAAQ,EACRC,QAAQ,EACRC,KAAK,EACLC,cAAc,EACdV,IAAI,EACJW,GAAG,EACHV,OAAO,EACPY,KAAK,EACL,GAAGC,MACN;IACG,OAAOnB,0BACH,KAAC+B;QACGV,WAAS,CAAC,mBAAmB,EAAEnB,IAAI;QACnCoB,cAAY,CAAC,mBAAmB,EAAEpB,IAAI;QACrC,GAAGiB,IAAI;QACRD,OAAOb;QACPE,WAAWb,WACPK,OAAO0B,cAAc,EACrB1B,OAAOyB,cAAc,EACrB;YACI,CAACzB,OAAO2B,oBAAoB,CAAC,EAAEb,aAAa;QAChD,GACA,kBACAN;kBAGJ,cAAA,KAACT;YACGkB,KAAKnB,cAAcO,SAASY;YAC5BL,eAAeA;YACfD,eAAeA;YACfE,UAAUA;YACVM,OAAOJ;YACPe,gBAAgBd;;QAGxBT;AAER,EAAE;AAEF,8CAA8C,GAC9C,OAAO,MAAM0B,gCAWT,CAAC,EAAEC,QAAQ,EAAE/B,EAAE,EAAEK,SAAS,EAAED,OAAO,EAAEY,KAAK,EAAE,GAAGC,MAAM,GACrDnB,0BACI,KAAC+B;QACGV,WAAS,CAAC,kBAAkB,EAAEnB,IAAI;QAClCoB,cAAY,CAAC,kBAAkB,EAAEpB,IAAI;QACpC,GAAGiB,IAAI;QACRD,OAAOA;QACPX,WAAWb,WACPK,OAAO0B,cAAc,EACrB1B,OAAOyB,cAAc,EACrB,kBACAjB;kBAGH0B;QAEL3B,SACF"}
|
|
@@ -8,89 +8,221 @@ import { HeaderNavigationItem } from './header-navigation-content';
|
|
|
8
8
|
import * as Styles from './header-navigation.module.less';
|
|
9
9
|
function useForceUpdate() {
|
|
10
10
|
const [, setTick] = useState(0);
|
|
11
|
-
return useCallback(()
|
|
12
|
-
setTick(tick
|
|
11
|
+
return useCallback(()=>{
|
|
12
|
+
setTick((tick)=>tick + 1);
|
|
13
13
|
}, []);
|
|
14
14
|
}
|
|
15
|
-
const HeaderNavigationOverflow = ({ items, overflow })
|
|
16
|
-
var _a, _b;
|
|
15
|
+
const HeaderNavigationOverflow = ({ items, overflow })=>{
|
|
17
16
|
const [isOpen, setIsOpen] = useState(false);
|
|
18
|
-
|
|
17
|
+
var _overflow_direction, _overflow_width;
|
|
18
|
+
return /*#__PURE__*/ _jsx(Popover, {
|
|
19
|
+
open: isOpen,
|
|
20
|
+
trigger: /*#__PURE__*/ _jsx(Icon, {
|
|
21
|
+
name: "more_vert",
|
|
22
|
+
size: "24px",
|
|
23
|
+
className: "c-pointer",
|
|
24
|
+
onClick: ()=>setIsOpen(true),
|
|
25
|
+
color: "white",
|
|
26
|
+
"data-cy": "navigation-overflow-trigger",
|
|
27
|
+
"data-pendo": "navigation-overflow-trigger"
|
|
28
|
+
}),
|
|
29
|
+
direction: (_overflow_direction = overflow === null || overflow === void 0 ? void 0 : overflow.direction) !== null && _overflow_direction !== void 0 ? _overflow_direction : 'bl',
|
|
30
|
+
width: (_overflow_width = overflow === null || overflow === void 0 ? void 0 : overflow.width) !== null && _overflow_width !== void 0 ? _overflow_width : 'xs',
|
|
31
|
+
portal: overflow === null || overflow === void 0 ? void 0 : overflow.portal,
|
|
32
|
+
onClickOutside: ()=>setIsOpen(false),
|
|
33
|
+
wrapperClassName: "d-if-i align-items-center",
|
|
34
|
+
popoverContentClassName: Styles.overflowPopover,
|
|
35
|
+
children: /*#__PURE__*/ _jsx("div", {
|
|
36
|
+
onClick: ()=>setIsOpen(false),
|
|
37
|
+
className: Styles.navigationOverflow,
|
|
38
|
+
"data-cy": "navigation-overflow-content",
|
|
39
|
+
children: items.map((item)=>/*#__PURE__*/ _createElement(HeaderNavigationItem, {
|
|
40
|
+
...item,
|
|
41
|
+
key: item.id,
|
|
42
|
+
minimized: false,
|
|
43
|
+
main: false
|
|
44
|
+
}))
|
|
45
|
+
})
|
|
46
|
+
});
|
|
19
47
|
};
|
|
20
|
-
var MinimizedState
|
|
21
|
-
(function (MinimizedState) {
|
|
48
|
+
var MinimizedState = /*#__PURE__*/ function(MinimizedState) {
|
|
22
49
|
MinimizedState[MinimizedState["Calculating"] = 0] = "Calculating";
|
|
23
50
|
MinimizedState[MinimizedState["Minimized"] = 1] = "Minimized";
|
|
24
51
|
MinimizedState[MinimizedState["Full"] = 2] = "Full";
|
|
25
|
-
|
|
26
|
-
|
|
52
|
+
return MinimizedState;
|
|
53
|
+
}(MinimizedState || {});
|
|
54
|
+
export const HeaderNavigation = ({ children, className, id, items, itemsOverflow, left, leftClassName, rightClassName, minWidth = 800, overflow })=>{
|
|
27
55
|
const leftRef = useRef(null);
|
|
28
56
|
const rightRef = useRef(null);
|
|
29
57
|
const centerRef = useRef(null);
|
|
30
58
|
const navigationRef = useRef(null);
|
|
31
59
|
const forceUpdate = useForceUpdate();
|
|
32
|
-
const [minimized, setMinimized] = useState(
|
|
33
|
-
useEffect(()
|
|
34
|
-
const handleResize = ()
|
|
35
|
-
setMinimized(
|
|
60
|
+
const [minimized, setMinimized] = useState(0);
|
|
61
|
+
useEffect(()=>{
|
|
62
|
+
const handleResize = ()=>{
|
|
63
|
+
setMinimized(0);
|
|
36
64
|
forceUpdate();
|
|
37
65
|
};
|
|
38
66
|
window.addEventListener('resize', handleResize);
|
|
39
|
-
return ()
|
|
40
|
-
}, [
|
|
41
|
-
|
|
42
|
-
|
|
67
|
+
return ()=>window.removeEventListener('resize', handleResize);
|
|
68
|
+
}, [
|
|
69
|
+
forceUpdate
|
|
70
|
+
]);
|
|
71
|
+
useEffect(()=>{
|
|
72
|
+
setMinimized(0);
|
|
43
73
|
forceUpdate();
|
|
44
|
-
}, [
|
|
45
|
-
|
|
74
|
+
}, [
|
|
75
|
+
items,
|
|
76
|
+
itemsOverflow,
|
|
77
|
+
forceUpdate
|
|
78
|
+
]);
|
|
79
|
+
const updateIsMinimized = ()=>{
|
|
46
80
|
if (centerRef.current && navigationRef.current) {
|
|
47
81
|
if (navigationRef.current.clientWidth > centerRef.current.clientWidth) {
|
|
48
|
-
setMinimized(
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
setMinimized(MinimizedState.Full);
|
|
82
|
+
setMinimized(1);
|
|
83
|
+
} else if (minimized === 0) {
|
|
84
|
+
setMinimized(2);
|
|
52
85
|
}
|
|
53
86
|
}
|
|
54
87
|
};
|
|
55
|
-
useEffect(()
|
|
88
|
+
useEffect(()=>{
|
|
56
89
|
updateIsMinimized();
|
|
57
90
|
});
|
|
58
|
-
return
|
|
59
|
-
|
|
60
|
-
|
|
91
|
+
return /*#__PURE__*/ _jsx(NavigationLegacyContext.Provider, {
|
|
92
|
+
value: true,
|
|
93
|
+
children: /*#__PURE__*/ _jsxs("div", {
|
|
94
|
+
className: classNames(Styles.header, className, {
|
|
95
|
+
[Styles.calculating]: minimized === 0
|
|
96
|
+
}),
|
|
97
|
+
style: {
|
|
98
|
+
minWidth: `${minWidth}px`
|
|
99
|
+
},
|
|
100
|
+
id: id,
|
|
101
|
+
"data-cy": "header-navigation",
|
|
102
|
+
children: [
|
|
103
|
+
/*#__PURE__*/ _jsx("div", {
|
|
104
|
+
className: leftClassName,
|
|
105
|
+
ref: leftRef,
|
|
106
|
+
"data-cy": "navigation-left",
|
|
107
|
+
children: left
|
|
108
|
+
}),
|
|
109
|
+
/*#__PURE__*/ _jsx("div", {
|
|
110
|
+
ref: centerRef,
|
|
111
|
+
className: classNames('d-if flex-grow-1 flex-basis-0 justify-content-center', Styles.center),
|
|
112
|
+
"data-cy": "navigation-items",
|
|
113
|
+
children: /*#__PURE__*/ _jsxs("div", {
|
|
114
|
+
ref: navigationRef,
|
|
115
|
+
className: classNames('d-if'),
|
|
116
|
+
children: [
|
|
117
|
+
items === null || items === void 0 ? void 0 : items.map((item)=>/*#__PURE__*/ _createElement(HeaderNavigationItem, {
|
|
118
|
+
...item,
|
|
119
|
+
minimized: minimized === 1,
|
|
120
|
+
main: true,
|
|
121
|
+
key: item.id
|
|
122
|
+
})),
|
|
123
|
+
!!(itemsOverflow === null || itemsOverflow === void 0 ? void 0 : itemsOverflow.length) && /*#__PURE__*/ _jsx(HeaderNavigationOverflow, {
|
|
124
|
+
items: itemsOverflow,
|
|
125
|
+
overflow: overflow
|
|
126
|
+
})
|
|
127
|
+
]
|
|
128
|
+
})
|
|
129
|
+
}),
|
|
130
|
+
/*#__PURE__*/ _jsx("div", {
|
|
131
|
+
className: classNames('d-f flex-row justify-content-end align-items-center', Styles.right, rightClassName),
|
|
132
|
+
ref: rightRef,
|
|
133
|
+
"data-cy": "navigation-right",
|
|
134
|
+
children: children
|
|
135
|
+
})
|
|
136
|
+
]
|
|
137
|
+
})
|
|
138
|
+
});
|
|
61
139
|
};
|
|
62
|
-
export const HeaderNavigationStacked = ({ className, id, items, itemsOverflow, left, leftClassName, right, rightClassName, center, centerClassName, minWidth = 800, overflow
|
|
140
|
+
export const HeaderNavigationStacked = ({ className, id, items, itemsOverflow, left, leftClassName, right, rightClassName, center, centerClassName, minWidth = 800, overflow })=>{
|
|
63
141
|
const bottomRef = useRef(null);
|
|
64
142
|
const navigationRef = useRef(null);
|
|
65
143
|
const forceUpdate = useForceUpdate();
|
|
66
|
-
const [minimized, setMinimized] = useState(
|
|
67
|
-
useEffect(()
|
|
68
|
-
const handleResize = ()
|
|
69
|
-
setMinimized(
|
|
144
|
+
const [minimized, setMinimized] = useState(0);
|
|
145
|
+
useEffect(()=>{
|
|
146
|
+
const handleResize = ()=>{
|
|
147
|
+
setMinimized(0);
|
|
70
148
|
forceUpdate();
|
|
71
149
|
};
|
|
72
150
|
window.addEventListener('resize', handleResize);
|
|
73
|
-
return ()
|
|
74
|
-
}, [
|
|
75
|
-
|
|
76
|
-
|
|
151
|
+
return ()=>window.removeEventListener('resize', handleResize);
|
|
152
|
+
}, [
|
|
153
|
+
forceUpdate
|
|
154
|
+
]);
|
|
155
|
+
useEffect(()=>{
|
|
156
|
+
setMinimized(0);
|
|
77
157
|
forceUpdate();
|
|
78
|
-
}, [
|
|
79
|
-
|
|
158
|
+
}, [
|
|
159
|
+
items,
|
|
160
|
+
itemsOverflow,
|
|
161
|
+
forceUpdate
|
|
162
|
+
]);
|
|
163
|
+
const updateIsMinimized = ()=>{
|
|
80
164
|
if (bottomRef.current && navigationRef.current) {
|
|
81
165
|
if (navigationRef.current.clientWidth + 16 > bottomRef.current.clientWidth) {
|
|
82
|
-
setMinimized(
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
setMinimized(MinimizedState.Full);
|
|
166
|
+
setMinimized(1);
|
|
167
|
+
} else if (minimized === 0) {
|
|
168
|
+
setMinimized(2);
|
|
86
169
|
}
|
|
87
170
|
}
|
|
88
171
|
};
|
|
89
|
-
useEffect(()
|
|
172
|
+
useEffect(()=>{
|
|
90
173
|
updateIsMinimized();
|
|
91
174
|
});
|
|
92
|
-
return
|
|
93
|
-
|
|
94
|
-
|
|
175
|
+
return /*#__PURE__*/ _jsx(NavigationLegacyContext.Provider, {
|
|
176
|
+
value: true,
|
|
177
|
+
children: /*#__PURE__*/ _jsxs("div", {
|
|
178
|
+
className: classNames(Styles.headerStacked, {
|
|
179
|
+
[Styles.calculating]: minimized === 0
|
|
180
|
+
}, className),
|
|
181
|
+
style: {
|
|
182
|
+
minWidth: `${minWidth}px`
|
|
183
|
+
},
|
|
184
|
+
id: id,
|
|
185
|
+
"data-cy": "header-navigation",
|
|
186
|
+
children: [
|
|
187
|
+
/*#__PURE__*/ _jsx("div", {
|
|
188
|
+
className: classNames(Styles.heTopLeft, leftClassName),
|
|
189
|
+
"data-cy": "navigation-left",
|
|
190
|
+
children: left
|
|
191
|
+
}),
|
|
192
|
+
/*#__PURE__*/ _jsx("div", {
|
|
193
|
+
className: classNames(Styles.heTopCenter, centerClassName),
|
|
194
|
+
"data-cy": "navigation-center",
|
|
195
|
+
children: center
|
|
196
|
+
}),
|
|
197
|
+
/*#__PURE__*/ _jsx("div", {
|
|
198
|
+
className: classNames('d-f flex-row justify-content-end align-items-center', Styles.heTopRight, rightClassName),
|
|
199
|
+
"data-cy": "navigation-right",
|
|
200
|
+
children: right
|
|
201
|
+
}),
|
|
202
|
+
/*#__PURE__*/ _jsx("div", {
|
|
203
|
+
ref: bottomRef,
|
|
204
|
+
className: classNames(Styles.heBottom, 'd-if flex-grow-1 flex-basis-0 justify-content-center', Styles.center),
|
|
205
|
+
"data-cy": "navigation-items",
|
|
206
|
+
children: /*#__PURE__*/ _jsxs("div", {
|
|
207
|
+
ref: navigationRef,
|
|
208
|
+
className: classNames('d-if'),
|
|
209
|
+
children: [
|
|
210
|
+
items === null || items === void 0 ? void 0 : items.map((item)=>/*#__PURE__*/ _createElement(HeaderNavigationItem, {
|
|
211
|
+
...item,
|
|
212
|
+
minimized: minimized === 1,
|
|
213
|
+
main: true,
|
|
214
|
+
key: item.id
|
|
215
|
+
})),
|
|
216
|
+
!!(itemsOverflow === null || itemsOverflow === void 0 ? void 0 : itemsOverflow.length) && /*#__PURE__*/ _jsx(HeaderNavigationOverflow, {
|
|
217
|
+
items: itemsOverflow,
|
|
218
|
+
overflow: overflow
|
|
219
|
+
})
|
|
220
|
+
]
|
|
221
|
+
})
|
|
222
|
+
})
|
|
223
|
+
]
|
|
224
|
+
})
|
|
225
|
+
});
|
|
95
226
|
};
|
|
227
|
+
|
|
96
228
|
//# sourceMappingURL=header-navigation.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"header-navigation.js","sourceRoot":"","sources":["../../../src/components/header-navigation/header-navigation.tsx"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"sources":["../../../src/components/header-navigation/header-navigation.tsx"],"sourcesContent":["import { Icon, Popover, PopoverPropsStrict } from '@servicetitan/design-system';\nimport classNames from 'classnames';\nimport { FC, ReactElement, ReactNode, useCallback, useEffect, useRef, useState } from 'react';\nimport { NavigationLegacyContext } from '../../utils/navigation-context';\nimport { HeaderNavigationItemData } from '../../utils/navigation-legacy';\nimport { HeaderNavigationItem } from './header-navigation-content';\nimport * as Styles from './header-navigation.module.less';\n\nfunction useForceUpdate() {\n const [, setTick] = useState(0);\n return useCallback(() => {\n setTick(tick => tick + 1);\n }, []);\n}\n\nexport interface HeaderNavigationOverflowProps {\n direction: PopoverPropsStrict['direction'];\n width: PopoverPropsStrict['width'];\n portal?: boolean;\n}\n\nconst HeaderNavigationOverflow: FC<{\n items: HeaderNavigationItemData[];\n overflow?: HeaderNavigationOverflowProps;\n}> = ({ items, overflow }) => {\n const [isOpen, setIsOpen] = useState(false);\n\n return (\n <Popover\n open={isOpen}\n trigger={\n <Icon\n name=\"more_vert\"\n size=\"24px\"\n className=\"c-pointer\"\n onClick={() => setIsOpen(true)}\n color=\"white\"\n data-cy=\"navigation-overflow-trigger\"\n data-pendo=\"navigation-overflow-trigger\"\n />\n }\n direction={overflow?.direction ?? 'bl'}\n width={overflow?.width ?? 'xs'}\n portal={overflow?.portal}\n onClickOutside={() => setIsOpen(false)}\n wrapperClassName=\"d-if-i align-items-center\"\n popoverContentClassName={Styles.overflowPopover}\n >\n <div\n onClick={() => setIsOpen(false)}\n className={Styles.navigationOverflow}\n data-cy=\"navigation-overflow-content\"\n >\n {items.map(item => (\n <HeaderNavigationItem {...item} key={item.id} minimized={false} main={false} />\n ))}\n </div>\n </Popover>\n );\n};\n\nexport interface HeaderNavigationProps {\n /** extra navigation */\n children?: ReactNode;\n /** container class name */\n className?: string;\n /** extra navigation container class name */\n rightClassName?: string;\n /** container id */\n id?: string;\n /** left content (usually used for logo) */\n left?: ReactElement;\n /** left container class name */\n leftClassName?: string;\n /** minimal width for navigation bar */\n minWidth?: number;\n /** main navigation items */\n items?: HeaderNavigationItemData[];\n /** main navigation overflow items */\n itemsOverflow?: HeaderNavigationItemData[];\n /** props for main items overflow component */\n overflow?: HeaderNavigationOverflowProps;\n}\n\nenum MinimizedState {\n Calculating,\n Minimized,\n Full,\n}\n\nexport const HeaderNavigation: FC<HeaderNavigationProps> = ({\n children,\n className,\n id,\n items,\n itemsOverflow,\n left,\n leftClassName,\n rightClassName,\n minWidth = 800,\n overflow,\n}) => {\n const leftRef = useRef<HTMLDivElement>(null);\n const rightRef = useRef<HTMLDivElement>(null);\n const centerRef = useRef<HTMLDivElement>(null);\n const navigationRef = useRef<HTMLDivElement>(null);\n const forceUpdate = useForceUpdate();\n const [minimized, setMinimized] = useState(MinimizedState.Calculating);\n\n useEffect(() => {\n const handleResize = () => {\n setMinimized(MinimizedState.Calculating);\n forceUpdate();\n };\n\n window.addEventListener('resize', handleResize);\n return () => window.removeEventListener('resize', handleResize);\n }, [forceUpdate]);\n\n useEffect(() => {\n setMinimized(MinimizedState.Calculating);\n forceUpdate();\n }, [items, itemsOverflow, forceUpdate]);\n\n const updateIsMinimized = () => {\n if (centerRef.current && navigationRef.current) {\n if (navigationRef.current.clientWidth > centerRef.current.clientWidth) {\n setMinimized(MinimizedState.Minimized);\n } else if (minimized === MinimizedState.Calculating) {\n setMinimized(MinimizedState.Full);\n }\n }\n };\n\n useEffect(() => {\n updateIsMinimized();\n });\n\n return (\n <NavigationLegacyContext.Provider value>\n <div\n className={classNames(Styles.header, className, {\n [Styles.calculating]: minimized === MinimizedState.Calculating,\n })}\n style={{ minWidth: `${minWidth}px` }}\n id={id}\n data-cy=\"header-navigation\"\n >\n <div className={leftClassName} ref={leftRef} data-cy=\"navigation-left\">\n {left}\n </div>\n <div\n ref={centerRef}\n className={classNames(\n 'd-if flex-grow-1 flex-basis-0 justify-content-center',\n Styles.center\n )}\n data-cy=\"navigation-items\"\n >\n <div ref={navigationRef} className={classNames('d-if')}>\n {items?.map(item => (\n <HeaderNavigationItem\n {...item}\n minimized={minimized === MinimizedState.Minimized}\n main\n key={item.id}\n />\n ))}\n {!!itemsOverflow?.length && (\n <HeaderNavigationOverflow items={itemsOverflow} overflow={overflow} />\n )}\n </div>\n </div>\n <div\n className={classNames(\n 'd-f flex-row justify-content-end align-items-center',\n Styles.right,\n rightClassName\n )}\n ref={rightRef}\n data-cy=\"navigation-right\"\n >\n {children}\n </div>\n </div>\n </NavigationLegacyContext.Provider>\n );\n};\n\nexport interface HeaderNavigationStackedProps {\n /** container class name */\n className?: string;\n /** extra navigation */\n right?: ReactNode;\n /** extra navigation container class name */\n rightClassName?: string;\n /** container id */\n id?: string;\n /** left content (usually used for logo) */\n left?: ReactElement;\n /** left container class name */\n leftClassName?: string;\n /** center content */\n center?: ReactElement;\n /** center container class name */\n centerClassName?: string;\n /** minimal width for navigation bar */\n minWidth?: number;\n /** main navigation items */\n items?: HeaderNavigationItemData[];\n /** main navigation overflow items */\n itemsOverflow?: HeaderNavigationItemData[];\n /** props for main items overflow component */\n overflow?: HeaderNavigationOverflowProps;\n}\n\nexport const HeaderNavigationStacked: FC<HeaderNavigationStackedProps> = ({\n className,\n id,\n items,\n itemsOverflow,\n left,\n leftClassName,\n right,\n rightClassName,\n center,\n centerClassName,\n minWidth = 800,\n overflow,\n}) => {\n const bottomRef = useRef<HTMLDivElement>(null);\n const navigationRef = useRef<HTMLDivElement>(null);\n const forceUpdate = useForceUpdate();\n const [minimized, setMinimized] = useState(MinimizedState.Calculating);\n\n useEffect(() => {\n const handleResize = () => {\n setMinimized(MinimizedState.Calculating);\n forceUpdate();\n };\n\n window.addEventListener('resize', handleResize);\n return () => window.removeEventListener('resize', handleResize);\n }, [forceUpdate]);\n\n useEffect(() => {\n setMinimized(MinimizedState.Calculating);\n forceUpdate();\n }, [items, itemsOverflow, forceUpdate]);\n\n const updateIsMinimized = () => {\n if (bottomRef.current && navigationRef.current) {\n if (navigationRef.current.clientWidth + 16 > bottomRef.current.clientWidth) {\n setMinimized(MinimizedState.Minimized);\n } else if (minimized === MinimizedState.Calculating) {\n setMinimized(MinimizedState.Full);\n }\n }\n };\n\n useEffect(() => {\n updateIsMinimized();\n });\n\n return (\n <NavigationLegacyContext.Provider value>\n <div\n className={classNames(\n Styles.headerStacked,\n {\n [Styles.calculating]: minimized === MinimizedState.Calculating,\n },\n className\n )}\n style={{ minWidth: `${minWidth}px` }}\n id={id}\n data-cy=\"header-navigation\"\n >\n <div\n className={classNames(Styles.heTopLeft, leftClassName)}\n data-cy=\"navigation-left\"\n >\n {left}\n </div>\n <div\n className={classNames(Styles.heTopCenter, centerClassName)}\n data-cy=\"navigation-center\"\n >\n {center}\n </div>\n <div\n className={classNames(\n 'd-f flex-row justify-content-end align-items-center',\n Styles.heTopRight,\n rightClassName\n )}\n data-cy=\"navigation-right\"\n >\n {right}\n </div>\n <div\n ref={bottomRef}\n className={classNames(\n Styles.heBottom,\n 'd-if flex-grow-1 flex-basis-0 justify-content-center',\n Styles.center\n )}\n data-cy=\"navigation-items\"\n >\n <div ref={navigationRef} className={classNames('d-if')}>\n {items?.map(item => (\n <HeaderNavigationItem\n {...item}\n minimized={minimized === MinimizedState.Minimized}\n main\n key={item.id}\n />\n ))}\n {!!itemsOverflow?.length && (\n <HeaderNavigationOverflow items={itemsOverflow} overflow={overflow} />\n )}\n </div>\n </div>\n </div>\n </NavigationLegacyContext.Provider>\n );\n};\n"],"names":["Icon","Popover","classNames","useCallback","useEffect","useRef","useState","NavigationLegacyContext","HeaderNavigationItem","Styles","useForceUpdate","setTick","tick","HeaderNavigationOverflow","items","overflow","isOpen","setIsOpen","open","trigger","name","size","className","onClick","color","data-cy","data-pendo","direction","width","portal","onClickOutside","wrapperClassName","popoverContentClassName","overflowPopover","div","navigationOverflow","map","item","key","id","minimized","main","MinimizedState","HeaderNavigation","children","itemsOverflow","left","leftClassName","rightClassName","minWidth","leftRef","rightRef","centerRef","navigationRef","forceUpdate","setMinimized","handleResize","window","addEventListener","removeEventListener","updateIsMinimized","current","clientWidth","Provider","value","header","calculating","style","ref","center","length","right","HeaderNavigationStacked","centerClassName","bottomRef","headerStacked","heTopLeft","heTopCenter","heTopRight","heBottom"],"mappings":";;AAAA,SAASA,IAAI,EAAEC,OAAO,QAA4B,8BAA8B;AAChF,OAAOC,gBAAgB,aAAa;AACpC,SAAsCC,WAAW,EAAEC,SAAS,EAAEC,MAAM,EAAEC,QAAQ,QAAQ,QAAQ;AAC9F,SAASC,uBAAuB,QAAQ,iCAAiC;AAEzE,SAASC,oBAAoB,QAAQ,8BAA8B;AACnE,YAAYC,YAAY,kCAAkC;AAE1D,SAASC;IACL,MAAM,GAAGC,QAAQ,GAAGL,SAAS;IAC7B,OAAOH,YAAY;QACfQ,QAAQC,CAAAA,OAAQA,OAAO;IAC3B,GAAG,EAAE;AACT;AAQA,MAAMC,2BAGD,CAAC,EAAEC,KAAK,EAAEC,QAAQ,EAAE;IACrB,MAAM,CAACC,QAAQC,UAAU,GAAGX,SAAS;QAgBlBS,qBACJA;IAff,qBACI,KAACd;QACGiB,MAAMF;QACNG,uBACI,KAACnB;YACGoB,MAAK;YACLC,MAAK;YACLC,WAAU;YACVC,SAAS,IAAMN,UAAU;YACzBO,OAAM;YACNC,WAAQ;YACRC,cAAW;;QAGnBC,WAAWZ,CAAAA,sBAAAA,qBAAAA,+BAAAA,SAAUY,SAAS,cAAnBZ,iCAAAA,sBAAuB;QAClCa,OAAOb,CAAAA,kBAAAA,qBAAAA,+BAAAA,SAAUa,KAAK,cAAfb,6BAAAA,kBAAmB;QAC1Bc,MAAM,EAAEd,qBAAAA,+BAAAA,SAAUc,MAAM;QACxBC,gBAAgB,IAAMb,UAAU;QAChCc,kBAAiB;QACjBC,yBAAyBvB,OAAOwB,eAAe;kBAE/C,cAAA,KAACC;YACGX,SAAS,IAAMN,UAAU;YACzBK,WAAWb,OAAO0B,kBAAkB;YACpCV,WAAQ;sBAEPX,MAAMsB,GAAG,CAACC,CAAAA,qBACP,eAAC7B;oBAAsB,GAAG6B,IAAI;oBAAEC,KAAKD,KAAKE,EAAE;oBAAEC,WAAW;oBAAOC,MAAM;;;;AAK1F;AAyBA,IAAA,AAAKC,wCAAAA;;;;WAAAA;EAAAA;AAML,OAAO,MAAMC,mBAA8C,CAAC,EACxDC,QAAQ,EACRtB,SAAS,EACTiB,EAAE,EACFzB,KAAK,EACL+B,aAAa,EACbC,IAAI,EACJC,aAAa,EACbC,cAAc,EACdC,WAAW,GAAG,EACdlC,QAAQ,EACX;IACG,MAAMmC,UAAU7C,OAAuB;IACvC,MAAM8C,WAAW9C,OAAuB;IACxC,MAAM+C,YAAY/C,OAAuB;IACzC,MAAMgD,gBAAgBhD,OAAuB;IAC7C,MAAMiD,cAAc5C;IACpB,MAAM,CAAC8B,WAAWe,aAAa,GAAGjD;IAElCF,UAAU;QACN,MAAMoD,eAAe;YACjBD;YACAD;QACJ;QAEAG,OAAOC,gBAAgB,CAAC,UAAUF;QAClC,OAAO,IAAMC,OAAOE,mBAAmB,CAAC,UAAUH;IACtD,GAAG;QAACF;KAAY;IAEhBlD,UAAU;QACNmD;QACAD;IACJ,GAAG;QAACxC;QAAO+B;QAAeS;KAAY;IAEtC,MAAMM,oBAAoB;QACtB,IAAIR,UAAUS,OAAO,IAAIR,cAAcQ,OAAO,EAAE;YAC5C,IAAIR,cAAcQ,OAAO,CAACC,WAAW,GAAGV,UAAUS,OAAO,CAACC,WAAW,EAAE;gBACnEP;YACJ,OAAO,IAAIf,iBAA0C;gBACjDe;YACJ;QACJ;IACJ;IAEAnD,UAAU;QACNwD;IACJ;IAEA,qBACI,KAACrD,wBAAwBwD,QAAQ;QAACC,KAAK;kBACnC,cAAA,MAAC9B;YACGZ,WAAWpB,WAAWO,OAAOwD,MAAM,EAAE3C,WAAW;gBAC5C,CAACb,OAAOyD,WAAW,CAAC,EAAE1B;YAC1B;YACA2B,OAAO;gBAAElB,UAAU,GAAGA,SAAS,EAAE,CAAC;YAAC;YACnCV,IAAIA;YACJd,WAAQ;;8BAER,KAACS;oBAAIZ,WAAWyB;oBAAeqB,KAAKlB;oBAASzB,WAAQ;8BAChDqB;;8BAEL,KAACZ;oBACGkC,KAAKhB;oBACL9B,WAAWpB,WACP,wDACAO,OAAO4D,MAAM;oBAEjB5C,WAAQ;8BAER,cAAA,MAACS;wBAAIkC,KAAKf;wBAAe/B,WAAWpB,WAAW;;4BAC1CY,kBAAAA,4BAAAA,MAAOsB,GAAG,CAACC,CAAAA,qBACR,eAAC7B;oCACI,GAAG6B,IAAI;oCACRG,WAAWA;oCACXC,IAAI;oCACJH,KAAKD,KAAKE,EAAE;;4BAGnB,CAAC,EAACM,0BAAAA,oCAAAA,cAAeyB,MAAM,mBACpB,KAACzD;gCAAyBC,OAAO+B;gCAAe9B,UAAUA;;;;;8BAItE,KAACmB;oBACGZ,WAAWpB,WACP,uDACAO,OAAO8D,KAAK,EACZvB;oBAEJoB,KAAKjB;oBACL1B,WAAQ;8BAEPmB;;;;;AAKrB,EAAE;AA6BF,OAAO,MAAM4B,0BAA4D,CAAC,EACtElD,SAAS,EACTiB,EAAE,EACFzB,KAAK,EACL+B,aAAa,EACbC,IAAI,EACJC,aAAa,EACbwB,KAAK,EACLvB,cAAc,EACdqB,MAAM,EACNI,eAAe,EACfxB,WAAW,GAAG,EACdlC,QAAQ,EACX;IACG,MAAM2D,YAAYrE,OAAuB;IACzC,MAAMgD,gBAAgBhD,OAAuB;IAC7C,MAAMiD,cAAc5C;IACpB,MAAM,CAAC8B,WAAWe,aAAa,GAAGjD;IAElCF,UAAU;QACN,MAAMoD,eAAe;YACjBD;YACAD;QACJ;QAEAG,OAAOC,gBAAgB,CAAC,UAAUF;QAClC,OAAO,IAAMC,OAAOE,mBAAmB,CAAC,UAAUH;IACtD,GAAG;QAACF;KAAY;IAEhBlD,UAAU;QACNmD;QACAD;IACJ,GAAG;QAACxC;QAAO+B;QAAeS;KAAY;IAEtC,MAAMM,oBAAoB;QACtB,IAAIc,UAAUb,OAAO,IAAIR,cAAcQ,OAAO,EAAE;YAC5C,IAAIR,cAAcQ,OAAO,CAACC,WAAW,GAAG,KAAKY,UAAUb,OAAO,CAACC,WAAW,EAAE;gBACxEP;YACJ,OAAO,IAAIf,iBAA0C;gBACjDe;YACJ;QACJ;IACJ;IAEAnD,UAAU;QACNwD;IACJ;IAEA,qBACI,KAACrD,wBAAwBwD,QAAQ;QAACC,KAAK;kBACnC,cAAA,MAAC9B;YACGZ,WAAWpB,WACPO,OAAOkE,aAAa,EACpB;gBACI,CAAClE,OAAOyD,WAAW,CAAC,EAAE1B;YAC1B,GACAlB;YAEJ6C,OAAO;gBAAElB,UAAU,GAAGA,SAAS,EAAE,CAAC;YAAC;YACnCV,IAAIA;YACJd,WAAQ;;8BAER,KAACS;oBACGZ,WAAWpB,WAAWO,OAAOmE,SAAS,EAAE7B;oBACxCtB,WAAQ;8BAEPqB;;8BAEL,KAACZ;oBACGZ,WAAWpB,WAAWO,OAAOoE,WAAW,EAAEJ;oBAC1ChD,WAAQ;8BAEP4C;;8BAEL,KAACnC;oBACGZ,WAAWpB,WACP,uDACAO,OAAOqE,UAAU,EACjB9B;oBAEJvB,WAAQ;8BAEP8C;;8BAEL,KAACrC;oBACGkC,KAAKM;oBACLpD,WAAWpB,WACPO,OAAOsE,QAAQ,EACf,wDACAtE,OAAO4D,MAAM;oBAEjB5C,WAAQ;8BAER,cAAA,MAACS;wBAAIkC,KAAKf;wBAAe/B,WAAWpB,WAAW;;4BAC1CY,kBAAAA,4BAAAA,MAAOsB,GAAG,CAACC,CAAAA,qBACR,eAAC7B;oCACI,GAAG6B,IAAI;oCACRG,WAAWA;oCACXC,IAAI;oCACJH,KAAKD,KAAKE,EAAE;;4BAGnB,CAAC,EAACM,0BAAAA,oCAAAA,cAAeyB,MAAM,mBACpB,KAACzD;gCAAyBC,OAAO+B;gCAAe9B,UAAUA;;;;;;;;AAOtF,EAAE"}
|