@entur-partner/common 4.1.0 → 4.4.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.
@@ -1 +1 @@
1
- {"version":3,"file":"common.cjs.production.min.js","sources":["../src/Box.tsx","../src/Stack.tsx","../src/FeatureToggle.tsx","../src/EnturPartnerLogo.tsx","../src/UserMenu.tsx","../src/LanguageSelect.tsx","../src/ErrorBoundary.tsx","../src/helpers.ts","../src/FormatDateTime.tsx","../src/ConfirmModal.tsx","../src/PermissionCheck.tsx","../src/ActionBar.tsx","../src/AuditInfo.tsx","../src/Breadcrumbs.tsx","../src/Content.tsx","../src/ExpandableMultiLanguageInput.tsx","../src/FormatCurrencyAmount.tsx","../src/Link.tsx","../src/LinkButton.tsx","../src/Menu.tsx","../src/MultiLanguageInput.tsx","../src/OrganisationDropdown.tsx","../src/Pager.tsx","../src/PermissionCheckedRoute.tsx","../src/RouteLeavingGuard.tsx","../src/StatusLabel.tsx","../src/Text.tsx","../src/Unbutton.tsx","../src/useEventListener.ts"],"sourcesContent":["import './Box.scss';\n\nimport React, { ReactNode } from 'react';\nimport cx from 'classnames';\n\ntype StyleSpacing =\n | 'none'\n | 'extraSmall2'\n | 'extraSmall'\n | 'small'\n | 'medium'\n | 'large'\n | 'extraLarge'\n | 'extraLarge2'\n | 'extraLarge3'\n | 'extraLarge4'\n | 'extraLarge5'\n | 'extraLarge6'\n | 'extraLarge7'\n | 'extraLarge8'\n | 'extraLarge9';\n\ntype StyleMargin = StyleSpacing | 'auto';\n\ntype StyleDisplay = 'block' | 'flex' | 'inline' | 'inline-block';\ntype StyleJustifyContent = 'center' | 'space-between' | 'start' | 'end';\ntype StyleAlignItems = 'center' | 'start' | 'end' | 'stretch' | 'baseline';\n\ntype StyleMaxWidth =\n | 'none'\n | 'extraSmall'\n | 'small'\n | 'medium'\n | 'large'\n | 'extraLarge'\n | 'extraLarge2'\n | 'extraLarge3'\n | 'extraLarge4'\n | 'extraLarge5'\n | 'extraLarge6'\n | 'full';\ntype StyleWidth = 'auto' | 'full';\n\nexport type StyleBackground = 'blue' | 'lavender' | 'white' | 'blue70';\nexport type StyleColor = 'blue' | 'lavender' | 'white' | 'black';\n\ntype StyleFlexDirection = 'row' | 'column' | 'row-reverse' | 'column-reverse';\ntype StyleFlexWrap = 'wrap' | 'nowrap' | 'wrap-reverse';\n\nexport type ResponsiveStyleSpacing =\n | StyleSpacing\n | [StyleSpacing?, StyleSpacing?, StyleSpacing?];\nexport type ResponsiveStyleMargin =\n | StyleMargin\n | [StyleMargin?, StyleMargin?, StyleMargin?];\n\nexport type ResponsiveStyleDisplay =\n | StyleDisplay\n | [StyleDisplay?, StyleDisplay?, StyleDisplay?];\nexport type ResponsiveStyleJustifyContent =\n | StyleJustifyContent\n | [StyleJustifyContent?, StyleJustifyContent?, StyleJustifyContent?];\nexport type ResponsiveStyleAlignItems =\n | StyleAlignItems\n | [StyleAlignItems?, StyleAlignItems?, StyleAlignItems?];\n\nexport type ResponsiveStyleMaxWidth =\n | StyleMaxWidth\n | [StyleMaxWidth?, StyleMaxWidth?, StyleMaxWidth?];\nexport type ResponsiveStyleWidth =\n | StyleWidth\n | [StyleWidth?, StyleWidth?, StyleWidth?];\n\nexport type ResponsiveStyleFlexDirection =\n | StyleFlexDirection\n | [StyleFlexDirection?, StyleFlexDirection?, StyleFlexDirection?];\nexport type ResponsiveStyleFlexWrap =\n | StyleFlexWrap\n | [StyleFlexWrap?, StyleFlexWrap?, StyleFlexWrap?];\n\nexport interface BoxProps {\n className?: string;\n as?: React.ElementType;\n [key: string]: any;\n children: ReactNode;\n\n contrast?: boolean;\n\n paddingTop?: ResponsiveStyleSpacing;\n paddingRight?: ResponsiveStyleSpacing;\n paddingBottom?: ResponsiveStyleSpacing;\n paddingLeft?: ResponsiveStyleSpacing;\n paddingX?: ResponsiveStyleSpacing;\n paddingY?: ResponsiveStyleSpacing;\n padding?: ResponsiveStyleSpacing;\n\n marginTop?: ResponsiveStyleMargin;\n marginRight?: ResponsiveStyleMargin;\n marginBottom?: ResponsiveStyleMargin;\n marginLeft?: ResponsiveStyleMargin;\n marginX?: ResponsiveStyleMargin;\n marginY?: ResponsiveStyleMargin;\n margin?: ResponsiveStyleMargin;\n\n display?: ResponsiveStyleDisplay;\n justifyContent?: ResponsiveStyleJustifyContent;\n alignItems?: ResponsiveStyleAlignItems;\n\n maxWidth?: ResponsiveStyleMaxWidth;\n width?: ResponsiveStyleWidth;\n background?: StyleBackground;\n color?: StyleColor;\n\n flexDirection?: ResponsiveStyleFlexDirection;\n flexWrap?: ResponsiveStyleFlexWrap;\n}\n\ntype ResponsiveProp = string | [string?, string?, string?];\n\nexport function responsiveProp(prefix: string, prop: ResponsiveProp): string[] {\n if (Array.isArray(prop)) {\n const classes = [];\n prop[0] && classes.push(prefix + prop[0]);\n prop[1] && classes.push(`${prefix}${prop[1]}-lg`);\n prop[2] && classes.push(`${prefix}${prop[2]}-xl`);\n return classes;\n }\n return [prefix + prop];\n}\n\nexport const Box = ({\n as: Component = 'div',\n children,\n contrast,\n paddingTop,\n paddingRight,\n paddingBottom,\n paddingLeft,\n paddingX,\n paddingY,\n padding,\n marginTop,\n marginRight,\n marginBottom,\n marginLeft,\n marginX,\n marginY,\n margin,\n display,\n justifyContent,\n alignItems,\n maxWidth,\n width,\n background,\n color,\n flexDirection,\n flexWrap,\n className,\n ...rest\n}: BoxProps) => {\n const classes = [];\n const resolvedPaddingTop = paddingTop || paddingY || padding;\n const resolvedPaddingBottom = paddingBottom || paddingY || padding;\n const resolvedPaddingLeft = paddingLeft || paddingX || padding;\n const resolvedPaddingRight = paddingRight || paddingX || padding;\n\n const resolvedMarginTop = marginTop || marginY || margin;\n const resolvedMarginBottom = marginBottom || marginY || margin;\n const resolvedMarginLeft = marginLeft || marginX || margin;\n const resolvedMarginRight = marginRight || marginX || margin;\n\n contrast && classes.push('eds-contrast');\n resolvedPaddingTop &&\n classes.push(...responsiveProp('eps-pt-', resolvedPaddingTop));\n resolvedPaddingBottom &&\n classes.push(...responsiveProp('eps-pb-', resolvedPaddingBottom));\n resolvedPaddingLeft &&\n classes.push(...responsiveProp('eps-pl-', resolvedPaddingLeft));\n resolvedPaddingRight &&\n classes.push(...responsiveProp('eps-pr-', resolvedPaddingRight));\n resolvedMarginTop &&\n classes.push(...responsiveProp('eps-mt-', resolvedMarginTop));\n resolvedMarginBottom &&\n classes.push(...responsiveProp('eps-mb-', resolvedMarginBottom));\n resolvedMarginLeft &&\n classes.push(...responsiveProp('eps-ml-', resolvedMarginLeft));\n resolvedMarginRight &&\n classes.push(...responsiveProp('eps-mr-', resolvedMarginRight));\n\n display && classes.push(...responsiveProp('eps-', display));\n justifyContent &&\n classes.push(...responsiveProp('eps-justify-', justifyContent));\n if (alignItems) {\n classes.push(...responsiveProp('eps-items-', alignItems));\n }\n\n maxWidth && classes.push(...responsiveProp('eps-max-w-', maxWidth));\n width && classes.push(...responsiveProp('eps-w-', width));\n\n color && classes.push(`eps-color-${color}`);\n background && classes.push(`eps-bg-${background}`);\n\n flexDirection && classes.push(...responsiveProp('eps-flex-', flexDirection));\n flexWrap && classes.push(...responsiveProp('eps-flex-wrap-', flexWrap));\n\n const classList = cx(classes, className);\n\n return (\n <Component className={classList} {...rest}>\n {children}\n </Component>\n );\n};\n","import React, { ReactNode, Children } from 'react';\n\nimport { ResponsiveStyleSpacing, Box } from './Box';\n\nexport interface StackProps {\n className?: string;\n children: ReactNode;\n space: ResponsiveStyleSpacing;\n}\n\nexport const Stack = ({ children, space, className }: StackProps) => {\n const stackItems = Children.toArray(children);\n if (stackItems.length <= 1) {\n return <>{stackItems}</>;\n }\n\n return (\n <div className={className}>\n {stackItems.map((child, index) =>\n index === stackItems.length - 1 ? (\n <div key={index}>{child}</div>\n ) : (\n <Box paddingBottom={space} key={index}>\n {child}\n </Box>\n )\n )}\n </div>\n );\n};\n","import React, { ReactNode } from 'react';\n\n/**\n * Returns true if the provided flag exist in localStorage\n * or is set as an environment variable.\n *\n * @param flag case sensitive flag. If it is an environment variable\n * you can drop the REACT_APP_ prefix.\n */\nexport function useFeatureToggle(flag: string): boolean {\n if (\n process.env[`REACT_APP_${flag}`] === 'true' ||\n window.localStorage?.getItem(flag) === 'true' ||\n window.localStorage?.getItem(`REACT_APP_${flag}`) === 'true'\n ) {\n return true;\n }\n return false;\n}\n\nexport interface FeatureToggleProps {\n /** Visible if flag exist, hidden if not.*/\n children: ReactNode;\n /** Case sensitive flag. If it is an environment variable\n * you can drop the REACT_APP_ prefix. */\n flag: string;\n}\n\nexport const FeatureToggle = ({ children, flag }: FeatureToggleProps) => {\n const feature = useFeatureToggle(flag);\n if (feature) {\n return <>{children}</>;\n }\n return null;\n};\n","import './EnturPartnerLogo.scss';\n\nimport React, { FC } from 'react';\nimport classnames from 'classnames';\n\ninterface LogoProps {\n title: string;\n className?: string;\n [key: string]: any;\n}\n\nexport const EnturPartnerLogoSvg: FC<LogoProps> = ({ title, ...rest }) => {\n return (\n <svg width={257} height={37} viewBox=\"0 0 257 37\" {...rest}>\n <title>{title}</title>\n <g fill=\"none\" fillRule=\"evenodd\">\n <path\n fill=\"#FFF\"\n d=\"M0 .231V25.72h18.745v-4.318H4.869v-6.163h12.31v-4.318H4.87V4.55h13.876V.231z\"\n />\n <path fill=\"#FF5959\" d=\"M0 36.408h45.253v-4.32H0z\" />\n <path\n fill=\"#FFF\"\n d=\"M40.384.231v15.425L23.656.231h-.521V25.72h4.869V10.573L44.732 25.72h.521V.23zM69.25 15.238h-7.267v21.17h-4.87v-21.17H49.81V10.92h19.44zM83.863 36.86c-1.646 0-3.142-.255-4.486-.765-1.345-.51-2.493-1.23-3.443-2.159-.95-.928-1.687-2.054-2.208-3.378-.522-1.323-.783-2.797-.783-4.422V10.92h4.869v15.216c0 1.277.209 2.333.626 3.169.417.836.933 1.497 1.548 1.985a5.346 5.346 0 001.982 1.01c.707.186 1.339.278 1.895.278.557 0 1.188-.092 1.896-.279a5.35 5.35 0 001.982-1.01c.614-.487 1.13-1.148 1.548-1.984.417-.836.625-1.892.625-3.169V10.92h4.87v15.216c0 1.625-.256 3.1-.766 4.422-.51 1.324-1.24 2.45-2.19 3.378-.952.929-2.1 1.648-3.444 2.159-1.344.51-2.851.766-4.52.766M104.21 24.047h5.546c1.016 0 1.854-.127 2.513-.383.658-.255 1.179-.592 1.56-1.01.381-.418.641-.888.78-1.41.138-.522.208-1.05.208-1.584 0-.627-.099-1.207-.295-1.741a3.718 3.718 0 00-.901-1.393c-.405-.394-.924-.708-1.56-.94-.636-.232-1.404-.348-2.305-.348h-5.546v8.81zm0 4.248v8.113h-4.87V10.92h11.567c1.3 0 2.49.215 3.57.644 1.08.43 2.004 1.033 2.77 1.81a8.287 8.287 0 011.794 2.787c.43 1.079.645 2.257.645 3.534 0 .952-.128 1.874-.383 2.768-.256.894-.61 1.7-1.063 2.42a7.32 7.32 0 01-1.672 1.863 5.929 5.929 0 01-2.178 1.096l6.339 8.566h-5.808l-5.893-8.113h-4.818z\"\n />\n <g fill=\"#FF5959\">\n <path d=\"M141.051 23.448h5.628c4.185 0 5.989-1.984 5.989-4.942 0-2.742-1.515-4.618-5.989-4.618h-5.628v9.56zm0 3.067v9.776h-3.571V10.75h9.632c6.674 0 9.127 3.211 9.127 7.54 0 4.979-3.102 8.226-9.2 8.226h-5.988zM169.695 28.715c-1.371-.288-2.958-.505-4.401-.505-2.85 0-4.041 1.263-4.041 3.139s1.407 2.706 3.463 2.706c2.49 0 4.979-1.443 4.979-4.221v-1.119zm-4.293-2.958c1.551 0 3.174.253 4.293.469v-.83c0-2.525-1.154-3.896-4.33-3.896-2.164 0-3.824.866-4.942 2.092l-2.02-2.272c1.732-1.66 3.644-2.598 7.07-2.598 5.052 0 7.469 1.876 7.469 7.215v10.354h-3.211V34.02h-.108c-1.082 1.767-3.211 2.705-5.592 2.705-3.32 0-6.241-1.66-6.241-5.303 0-3.103 1.912-5.664 7.612-5.664zM178.965 19.191h3.211v2.886h.108c.938-1.984 2.922-3.355 5.231-3.355.47 0 .938.036 1.335.144l-.144 3.14a6.77 6.77 0 00-1.552-.181c-3.246 0-4.798 2.633-4.798 5.483v8.983h-3.39v-17.1zM199.961 36.291h-1.912c-4.004 0-5.988-.938-5.988-5.772v-8.55h-2.778V19.19h2.778v-4.654h3.355v4.654h4.473v2.778h-4.473v7.973c0 3.427 1.587 3.535 3.319 3.535h1.226v2.814zM219.767 36.291h-3.391V26.84c0-2.778-1.083-5.375-4.257-5.375-3.14 0-5.268 2.597-5.268 6.169v8.658h-3.391v-17.1h3.32v2.814h.143c.794-1.623 3.067-3.283 5.99-3.283 4.941 0 6.854 3.644 6.854 8.081v9.488zM227.847 26.262h10.57c0-2.597-2.272-4.726-5.087-4.726-2.922 0-5.014 1.948-5.483 4.726zm-.036 2.453c.397 3.355 2.633 5.195 5.844 5.195 2.778 0 4.618-1.623 5.484-2.67l2.164 1.804c-1.37 1.913-4.365 3.716-8.045 3.716-4.942 0-8.73-3.535-8.73-8.55 0-5.195 3.752-9.488 8.983-9.488 5.303 0 8.009 4.365 8.009 8.19 0 .649-.036 1.226-.072 1.803H227.81zM246.245 19.191h3.21v2.886h.109c.938-1.984 2.922-3.355 5.231-3.355.469 0 .938.036 1.335.144l-.145 3.14a6.77 6.77 0 00-1.551-.181c-3.247 0-4.798 2.633-4.798 5.483v8.983h-3.391v-17.1z\" />\n </g>\n </g>\n </svg>\n );\n};\n\ninterface EnturPartnerLogoProps {\n altText: string;\n as?: 'div' | React.ElementType;\n className?: string;\n}\n\nexport const EnturPartnerLogo: FC<EnturPartnerLogoProps> = ({\n as: Component = 'nav',\n className,\n altText,\n}) => {\n const classList = classnames(['eps-logo-wrapper', className]);\n\n return (\n <Component className={classList}>\n <EnturPartnerLogoSvg title={altText} className=\"logo\" />\n </Component>\n );\n};\n","import './UserMenu.scss';\n\nimport React, { FC, useState } from 'react';\nimport cx from 'classnames';\nimport {\n UserIcon,\n UploadIcon,\n PrivacyIcon,\n DownArrowIcon,\n UKIcon,\n NorwayIcon,\n} from '@entur/icons';\nimport { SecondaryButton } from '@entur/button';\nimport { Heading6 } from '@entur/typography';\n\ninterface UserMenuProps {\n userName: string;\n messages: {\n logout: string;\n termsAndConditions: string;\n switchLanguage: string;\n };\n onLogout: () => void;\n onShowGdprDialog: () => void;\n onLanguageChange: (language: string) => void;\n language: string;\n className?: string;\n}\n\nexport const UserMenu: FC<UserMenuProps> = ({\n className,\n messages,\n onLogout,\n onLanguageChange,\n onShowGdprDialog,\n userName,\n language,\n}) => {\n const triggerClassList = cx(['eps-user-menu__trigger-button', className]);\n const [open, setOpen] = useState(false);\n\n return (\n <div id=\"eps-user-menu\">\n <CustomOverflowMenu\n open={open}\n onOpenChange={setOpen}\n className={triggerClassList}\n userName={userName}\n >\n <div id=\"eps-overflow-menu\">\n <CustomOverflowMenuItem\n onClick={() => {\n onShowGdprDialog();\n setOpen(false);\n }}\n className=\"eps-overflow-menu__item\"\n >\n <span aria-hidden>\n <PrivacyIcon size=\"1rem\" inline />\n </span>\n {messages.termsAndConditions}\n </CustomOverflowMenuItem>\n {language === 'en' ? (\n <CustomOverflowMenuItem\n onClick={() => {\n onLanguageChange('nb');\n setOpen(false);\n }}\n className=\"eps-overflow-menu__item\"\n >\n <span aria-hidden className=\"eps-overflow-menu__icon-margin\">\n <NorwayIcon size=\"1rem\" inline />\n </span>\n {messages.switchLanguage}\n </CustomOverflowMenuItem>\n ) : (\n <CustomOverflowMenuItem\n onClick={() => {\n onLanguageChange('en');\n setOpen(false);\n }}\n className=\"eps-overflow-menu__item\"\n >\n <span aria-hidden className=\"eps-overflow-menu__icon-margin\">\n <UKIcon size=\"1rem\" inline />\n </span>\n {messages.switchLanguage}\n </CustomOverflowMenuItem>\n )}\n <CustomOverflowMenuItem\n onClick={() => {\n onLogout();\n setOpen(false);\n }}\n data-testid=\"user-menu-logout\"\n className=\"eps-overflow-menu__item\"\n >\n <span aria-hidden>\n <UploadIcon\n size=\"1rem\"\n inline\n style={{ transform: 'rotate(90deg)' }}\n />\n </span>\n {messages.logout}\n </CustomOverflowMenuItem>\n </div>\n </CustomOverflowMenu>\n </div>\n );\n};\n\nconst CustomOverflowMenu: React.FC<{\n className?: string;\n children: React.ReactNode;\n userName: string;\n open: boolean;\n onOpenChange: (open: boolean) => void;\n}> = ({ className, children, userName, open, onOpenChange, ...rest }) => {\n const overflowItemsClasses = cx('eps-overflow-menu__group', {\n 'eps-overflow-menu__group--open': open,\n });\n const overflowContentRef = React.useRef<HTMLDivElement>(null);\n const overflowMenuTriggerRef = React.useRef<HTMLButtonElement>(null);\n useOutsideClick(overflowContentRef, overflowMenuTriggerRef, () =>\n onOpenChange(false)\n );\n return (\n <div>\n <SecondaryButton\n className={cx('eps-overflow-menu__button', className)}\n onClick={() => onOpenChange(open ? false : true)}\n aria-haspopup={true}\n role=\"button\"\n aria-expanded={open}\n ref={overflowMenuTriggerRef}\n {...rest}\n >\n <div className=\"eps-overflow-menu__button-contents\">\n <span className=\"eds-overflow-menu__user-icon\">\n <UserIcon inline />\n </span>\n <Heading6 margin=\"none\" as=\"span\">\n {userName}\n </Heading6>\n <span className=\"eps-arrow-icon\">\n <DownArrowIcon inline />\n </span>\n </div>\n </SecondaryButton>\n {open && (\n <div\n className={overflowItemsClasses}\n role=\"menu\"\n ref={overflowContentRef}\n >\n {children}\n </div>\n )}\n </div>\n );\n};\n\nconst CustomOverflowMenuItem: React.FC<\n React.DetailedHTMLProps<\n React.ButtonHTMLAttributes<HTMLButtonElement>,\n HTMLButtonElement\n >\n> = (props) => {\n return (\n <button\n className={cx(props.className, 'eps-overflow-menu__item')}\n role=\"menuitem\"\n {...props}\n />\n );\n};\n\nfunction elementContainsEventTarget(element: HTMLElement | null, event: Event) {\n if (!element) {\n return false;\n }\n\n if (element.contains(event.target as Node)) {\n return true;\n }\n\n // For elements inside a Shadow DOM we need to check the composedPath\n if (event.composed && event.composedPath) {\n const contains = event.composedPath().find((target) => {\n if (target === window) {\n return false;\n }\n return element.contains(target as Node);\n });\n return contains ? true : false;\n }\n\n return false;\n}\n\nfunction useOutsideClick(\n ref: React.RefObject<HTMLDivElement>,\n buttonRef: React.RefObject<HTMLButtonElement>,\n handler: () => void\n) {\n React.useEffect(() => {\n const listener = (event: Event) => {\n if (\n elementContainsEventTarget(ref.current, event) ||\n elementContainsEventTarget(buttonRef.current, event)\n ) {\n return;\n }\n\n handler();\n };\n\n document.addEventListener('mousedown', listener);\n document.addEventListener('touchstart', listener);\n\n return () => {\n document.removeEventListener('mousedown', listener);\n document.removeEventListener('touchstart', listener);\n };\n }, [ref, buttonRef, handler]);\n}\n","import './LanguageSelect.scss';\n\nimport React, { FC } from 'react';\nimport { SegmentedControl, SegmentedChoice } from '@entur/form';\nimport cx from 'classnames';\nimport { assertIsDefined } from '@entur-partner/util';\n\nexport type LanguageKey = 'nob' | 'nno' | 'eng';\n\nexport interface LanguageOption {\n value: LanguageKey;\n label: string;\n required: boolean;\n}\n\nexport interface LanguageSelectProps {\n language: string;\n options: LanguageOption[];\n className?: string;\n onChange: (language: string) => void;\n [key: string]: any;\n}\n\nexport const LanguageSelect: FC<LanguageSelectProps> = ({\n language,\n options,\n className,\n onChange,\n ...rest\n}) => {\n const classNames = cx('eps-language-select', className);\n return (\n <div {...rest} className={classNames}>\n <SegmentedControl\n onChange={(language) => {\n assertIsDefined(language);\n onChange(language);\n }}\n selectedValue={language}\n >\n {options.map((option) => (\n <SegmentedChoice key={option.value} value={option.value}>\n {option.label}\n {option.required && <span className=\"asterisk-margin\">{'*'}</span>}\n </SegmentedChoice>\n ))}\n </SegmentedControl>\n </div>\n );\n};\n","import { ReactNode, Component, ErrorInfo } from 'react';\n\nimport { isFunction } from './helpers';\n\ntype FallbackOptions = {\n retry: () => void;\n error: Error;\n};\n\ntype RenderProp = (options: FallbackOptions) => ReactNode;\n\ntype Props = {\n handleError?: (error: Error, errorInfo: ErrorInfo) => void;\n fallback: ReactNode | RenderProp;\n children: ReactNode;\n};\n\ntype State = {\n error: null | Error;\n};\n\nexport class ErrorBoundary extends Component<Props, State> {\n constructor(props: Props) {\n super(props);\n this.state = { error: null };\n }\n\n static getDerivedStateFromError(error: Error): State {\n return {\n error,\n };\n }\n\n componentDidCatch(error: Error, errorInfo: ErrorInfo) {\n // React always logs in development\n this.props.handleError?.(error, errorInfo);\n }\n\n render() {\n const { error } = this.state;\n const { fallback, children } = this.props;\n\n if (error) {\n if (isFunction<RenderProp>(fallback)) {\n return fallback({ retry: () => this.setState({ error: null }), error });\n }\n return fallback;\n }\n\n return children;\n }\n}\n","export function isFunction<T>(functionToCheck: any): functionToCheck is T {\n return (\n functionToCheck && {}.toString.call(functionToCheck) === '[object Function]'\n );\n}\n","import React, { FC } from 'react';\nimport { localeDate, localeDateTime } from '@entur-partner/util';\n\nexport interface FormatDateTimeProps {\n date: string | Date;\n locale: string;\n [key: string]: any;\n}\n\nexport const FormatDateTime: FC<FormatDateTimeProps> = ({\n date,\n locale,\n as: Component = 'main',\n hideTime,\n ...rest\n}) => {\n return (\n <Component {...rest}>\n {hideTime ? localeDate(date, locale) : localeDateTime(date, locale)}\n </Component>\n );\n};\n","import './ConfirmModal.scss';\n\nimport React, { ReactNode, FC } from 'react';\nimport { Modal, ModalProps } from '@entur/modal';\nimport { Paragraph } from '@entur/typography';\nimport { isString } from '@entur-partner/util';\nimport { ButtonGroup, SecondaryButton, PrimaryButton } from '@entur/button';\n\nimport { Box } from './Box';\n\nexport interface BaseConfirmModalProps extends Partial<ModalProps> {\n title: string;\n children: React.ReactNode;\n closeLabel: string;\n\n /** Deprecated use children prop */\n message?: ReactNode;\n /** Deprecated use open prop */\n isOpen?: boolean;\n /** Deprecated use onDismiss prop */\n onClose?: () => void;\n}\n\ninterface CustomConfirmModalButtons extends BaseConfirmModalProps {\n buttons: ReactNode[];\n}\n\ninterface DefaultConfirmModalHandler extends BaseConfirmModalProps {\n onConfirm: () => void;\n messages: {\n confirm: string;\n cancel: string;\n };\n}\n\nexport type ConfirmModalProps =\n | CustomConfirmModalButtons\n | DefaultConfirmModalHandler;\n\nexport const ConfirmModal: FC<ConfirmModalProps> = ({\n isOpen = false,\n children,\n message,\n size = 'medium',\n buttons,\n onConfirm,\n messages,\n onClose,\n onDismiss,\n ...rest\n}) => {\n const childrenToRender = children ? children : message;\n const handleDismiss = onClose ? onClose : onDismiss;\n return (\n <Modal size={size} open={isOpen} onDismiss={handleDismiss} {...rest}>\n {isString(childrenToRender) ? (\n <Paragraph>{childrenToRender}</Paragraph>\n ) : (\n <Box paddingBottom=\"medium\">{childrenToRender}</Box>\n )}\n\n <ButtonGroup>\n {onConfirm ? (\n <>\n <SecondaryButton\n onClick={handleDismiss}\n data-testid=\"cancel-modal-button\"\n >\n {messages.cancel}\n </SecondaryButton>\n <PrimaryButton\n onClick={onConfirm}\n data-testid=\"confirm-modal-button\"\n >\n {messages.confirm}\n </PrimaryButton>\n </>\n ) : (\n buttons\n )}\n </ButtonGroup>\n </Modal>\n );\n};\n","import React, { ReactNode, FC } from 'react';\nimport { BusinessCapability } from '@entur-partner/permission-client-node';\nimport { hasAllPermissions, hasOneOfPermissions } from '@entur-partner/util';\n\n/**\n * Note: We use BusinessCapability here, not because we only want to check\n * BusinessCapabilities but because it represents a minimal subset of what we\n * need to check.\n */\nexport interface PermissionCheckProps {\n children: ReactNode;\n /** User permissions to check */\n permissions: BusinessCapability[];\n /** Check that at least one of the permissions is present */\n oneOf?: BusinessCapability[];\n /** Check that all of the permissions is present */\n all?: BusinessCapability[] | BusinessCapability;\n /** Rendered if check fails. Defaults to null */\n fallback?: ReactNode;\n}\n\n/**\n * Note: This component uses BusinessCapability, not because we only want to\n * check BusinessCapabilities but because it represents a minimal subset of\n * what we need to check.\n */\nexport const PermissionCheck: FC<PermissionCheckProps> = ({\n children,\n fallback = null,\n permissions,\n oneOf = [],\n all = [],\n}) => {\n const allIsAllowed = hasAllPermissions(all, permissions);\n\n const oneOfIsAllowed = hasOneOfPermissions(oneOf, permissions);\n\n const allowed = allIsAllowed && oneOfIsAllowed;\n return <>{allowed ? children : fallback}</>;\n};\n","import './ActionBar.scss';\nimport React, { ReactNode } from 'react';\n\nexport interface ActionBarProps {\n children: ReactNode;\n}\n\nconst ActionBarLeft = ({ children }: ActionBarProps) => {\n return <div className=\"eps-action-bar-left\">{children}</div>;\n};\n\nconst ActionBarRight = ({ children }: ActionBarProps) => {\n return <div className=\"eps-action-bar-right\">{children}</div>;\n};\n\nconst ActionBar = ({ children }: ActionBarProps) => {\n return (\n <>\n <div className=\"eps-action-bar-padding\" />\n <div className=\"eps-action-bar\">{children}</div>\n </>\n );\n};\n\nexport { ActionBar, ActionBarLeft, ActionBarRight };\n","import './AuditInfo.scss';\n\nimport React, { FC } from 'react';\nimport cx from 'classnames';\nimport { isDateString, isDate } from '@entur-partner/util';\n\nimport { FormatDateTime } from './FormatDateTime';\nimport { Stack } from './Stack';\n\ninterface Item {\n label: string;\n value: Date | string;\n}\n\nexport interface AuditInfoProps {\n items: Item[];\n locale: string;\n className?: string;\n [key: string]: any;\n}\n\nexport const AuditInfo: FC<AuditInfoProps> = ({\n items,\n locale,\n className,\n ...rest\n}) => {\n const classNames = cx('ep-audit-info', className);\n return (\n <div className={classNames} {...rest}>\n {items.map(({ label, value }, i) => (\n <Stack space=\"small\" key={i}>\n <div className=\"ep-audit-info-label\">{label}</div>\n <div>\n {isDate(value) || isDateString(value) ? (\n <FormatDateTime date={value} locale={locale} />\n ) : (\n <span>{value}</span>\n )}\n </div>\n </Stack>\n ))}\n </div>\n );\n};\n","import './Breadcrumbs.scss';\nimport React, { FC, ReactElement } from 'react';\nimport { Link } from 'react-router-dom';\nimport { BreadcrumbNavigation, BreadcrumbItem } from '@entur/menu';\n\nexport interface BreadcrumbsProps {\n pathname: string;\n onBreadcrumbLookup: (path: string) => string | undefined;\n prependBreadcrumbItem?: ReactElement;\n}\n\nexport const Breadcrumbs: FC<BreadcrumbsProps> = ({\n prependBreadcrumbItem,\n pathname,\n onBreadcrumbLookup,\n}) => {\n const paths: string[] = pathname === '/' ? [] : ['/'];\n\n // support paths with and without trailing slash, except root\n const adjustedPathname =\n pathname.length > 1 ? pathname.replace(/\\/$/, '') : pathname;\n\n adjustedPathname.split('/').reduce((prev, curr) => {\n const path = `${prev}/${curr}`;\n paths.push(path);\n return path;\n });\n\n const breadcrumbs = paths\n .map((path) => ({ title: onBreadcrumbLookup(path), path }))\n .filter(({ title }) => title !== undefined);\n\n const breadcrumbElements = breadcrumbs.map(({ title, path }, i) => {\n const isLast = i === breadcrumbs.length - 1;\n if (isLast) {\n return (\n <BreadcrumbItem key={path} as={'span'}>\n {title}\n </BreadcrumbItem>\n );\n }\n return (\n <BreadcrumbItem key={path} as={Link} to={path}>\n {title}\n </BreadcrumbItem>\n );\n });\n\n if (prependBreadcrumbItem) {\n return (\n <BreadcrumbNavigation>\n {[prependBreadcrumbItem, ...breadcrumbElements]}\n </BreadcrumbNavigation>\n );\n }\n\n return <BreadcrumbNavigation>{breadcrumbElements}</BreadcrumbNavigation>;\n};\n","import './Content.scss';\n\nimport React, { FC, ReactNode } from 'react';\nimport classnames from 'classnames';\n\ninterface ContentProps {\n children: ReactNode;\n as?: 'main' | React.ElementType;\n className?: string;\n}\nexport const Content: FC<ContentProps> = ({\n as: Component = 'main',\n className,\n children,\n}) => {\n const classList = classnames(['eps-content', className]);\n\n return <Component className={classList}>{children}</Component>;\n};\n","import React, { ChangeEvent } from 'react';\nimport { VariantType } from '@entur/form';\nimport { ExpandablePanel } from '@entur/expand';\n\nimport { LanguageKey, LanguageOption } from './LanguageSelect';\nimport { Stack } from './Stack';\n\nexport type MultiLanguageValues = Record<LanguageKey, string>;\n\ntype ExpandableMultiLanguageInputProps = {\n title: string;\n inputComponent: React.ElementType;\n languages: LanguageOption[];\n values: MultiLanguageValues;\n onChange: (values: MultiLanguageValues) => void;\n name: string;\n variant?: (lang: LanguageKey) => VariantType;\n feedback?: (lang: LanguageKey) => string;\n [key: string]: any;\n};\n\nexport const ExpandableMultiLanguageInput = ({\n title,\n inputComponent: InputComponent,\n languages,\n values,\n onChange,\n name,\n variant,\n feedback,\n ...rest\n}: ExpandableMultiLanguageInputProps) => {\n const handleOnChange = (language: LanguageKey, value?: string) => {\n const changes = { ...values };\n if (value === '' || !value) {\n delete changes[language];\n } else {\n changes[language] = value;\n }\n onChange(changes);\n };\n\n return (\n <ExpandablePanel\n title={title}\n defaultOpen\n contentStyle={{\n padding: '4px 4px 4px 4px',\n marginTop: '16px',\n marginBottom: '16px',\n }}\n >\n <Stack space=\"medium\">\n {languages.map(({ value: langKey, label, required }) => (\n <InputComponent\n data-testid={`multi-lang-input-${name}-${langKey}`}\n key={title + langKey}\n label={required ? label + '*' : label}\n variant={variant && variant(langKey)}\n feedback={feedback && feedback(langKey)}\n name={name}\n onChange={(e: ChangeEvent<HTMLInputElement>) => {\n handleOnChange(langKey, e.target.value);\n }}\n value={values[langKey] || ''}\n {...rest}\n />\n ))}\n </Stack>\n </ExpandablePanel>\n );\n};\n","import React, { FC } from 'react';\n\nexport interface FormatCurrencyAmountProps {\n amount: number | string;\n as?: 'span' | React.ElementType;\n [key: string]: any;\n}\n\nexport const FormatCurrencyAmount: FC<FormatCurrencyAmountProps> = ({\n amount,\n as: Component = 'span',\n ...rest\n}) => {\n const parsedAmount = Number(amount) || 0;\n\n const formattedAmount = new Intl.NumberFormat('nb-NO', {\n maximumFractionDigits: 2,\n minimumFractionDigits: 2,\n }).format(parsedAmount);\n\n return <Component {...rest}>{formattedAmount}</Component>;\n};\n","import React, { FC } from 'react';\nimport { Link as RouterLink, LinkProps } from 'react-router-dom';\nimport { Link as A } from '@entur/typography';\n\ninterface Props extends LinkProps {}\n\nexport const Link: FC<Props> = (props) => {\n return (\n <A {...props} as={RouterLink}>\n {props.children}\n </A>\n );\n};\n","import './LinkButton.scss';\n\nimport React, { ReactNode } from 'react';\nimport { Link } from '@entur/typography';\nimport cx from 'classnames';\n\nexport interface LinkButtonProps {\n children: ReactNode;\n className?: string;\n [key: string]: any;\n}\n\nexport const LinkButton = ({\n children,\n className,\n ...rest\n}: LinkButtonProps) => (\n <Link {...rest} as=\"button\" className={cx('eps-link-button', className)}>\n {children}\n </Link>\n);\n","import './Menu.scss';\n\nimport React, { FC, ReactNode } from 'react';\nimport classnames from 'classnames';\n\ninterface MenuProps {\n children: ReactNode;\n as?: 'div' | React.ElementType;\n className?: string;\n}\nexport const Menu: FC<MenuProps> = ({\n as: Component = 'nav',\n className,\n children,\n}) => {\n const classList = classnames(['eds-contrast', 'eps-menu', className]);\n\n return <Component className={classList}>{children}</Component>;\n};\n","import './MultiLanguageInput.scss';\n\nimport React, { FC, useState, ChangeEvent, FocusEvent } from 'react';\nimport cx from 'classnames';\nimport { VariantType } from '@entur/form';\n\nimport { Stack } from './Stack';\nimport { LanguageSelect, LanguageOption } from './LanguageSelect';\n\ntype Values = { [key: string]: string };\n\nexport interface MultiLanguageInputProps {\n className?: string;\n onBlur?: (e: FocusEvent<HTMLDivElement>) => void;\n inputComponent: React.ElementType;\n values: { [key: string]: string };\n languages: LanguageOption[];\n onChange: (values: Values) => void;\n name: string;\n alertLevel?: VariantType;\n alertLabel?: string;\n label?: string;\n defaultLanguage?: string;\n [key: string]: any;\n}\n/**\n * @deprecated use ExpandableMultiLanguageInput\n */\nexport const MultiLanguageInput: FC<MultiLanguageInputProps> = ({\n className,\n inputComponent: InputComponent,\n alertLabel,\n alertLevel,\n name,\n languages,\n values,\n onChange,\n defaultLanguage = 'nob',\n label = '',\n onBlur = () => {},\n ...rest\n}) => {\n const [language, setLanguage] = useState(defaultLanguage);\n const classNames = cx('multi-language-input', className);\n const currentValue = values[language];\n\n const handleOnBlur = (e: FocusEvent<HTMLDivElement>) => {\n e.persist();\n const currentTarget = e.currentTarget;\n setTimeout(() => {\n if (currentTarget && !currentTarget.contains(document.activeElement)) {\n onBlur(e);\n }\n }, 0);\n };\n\n const handleLanguageChange = (language: string) => {\n setLanguage(language);\n };\n\n const handleOnChange = (value?: string) => {\n const changes = Object.assign({}, values);\n if (value === '' || !value) {\n delete changes[language];\n } else {\n changes[language] = value;\n }\n onChange(changes);\n };\n\n return (\n <div\n className={classNames}\n tabIndex={0}\n onBlur={handleOnBlur}\n data-testid={`multi-lang-input-${name}`}\n >\n <Stack space=\"extraSmall\">\n <LanguageSelect\n language={language}\n options={languages}\n onChange={(lang) => handleLanguageChange(lang)}\n />\n <InputComponent\n label={label}\n variant={alertLevel}\n feedback={alertLabel}\n name={name}\n className=\"language-item\"\n onChange={(e: ChangeEvent<HTMLInputElement>) =>\n handleOnChange(e.target.value)\n }\n value={currentValue || ''}\n {...rest}\n />\n </Stack>\n </div>\n );\n};\n","import React, { FC } from 'react';\nimport { Dropdown } from '@entur/dropdown';\n\ninterface Organisation {\n name: string;\n id: string;\n}\n\ninterface OrganisationDropDownProps {\n label: string;\n onChange: (id: string) => void;\n organisations: Organisation[];\n selectedOrganisationId?: string;\n [key: string]: any;\n}\n\nexport const OrganisationDropDown: FC<OrganisationDropDownProps> = ({\n label,\n organisations,\n onChange: handleChange,\n selectedOrganisationId,\n ...rest\n}) => {\n const selectedOrganisation = organisations.find(\n (org) => org.id === selectedOrganisationId\n );\n\n return (\n <Dropdown\n label={label}\n searchable={true}\n clearable={true}\n className=\"eds-contrast\"\n items={[\n ...organisations\n .sort((a, b) => a.name.localeCompare(b.name, 'nb'))\n .map((organisation) => {\n return {\n value: organisation.id,\n label: organisation.name,\n };\n }),\n ]}\n initialSelectedItem={\n selectedOrganisation\n ? {\n value: selectedOrganisation.id,\n label: selectedOrganisation.name,\n }\n : null\n }\n onChange={(selectedValue) => {\n if (selectedValue) {\n handleChange(selectedValue.value);\n }\n }}\n {...rest}\n />\n );\n};\n","import React, { FC } from 'react';\nimport { Pagination } from '@entur/menu';\n\nexport interface PagerProps {\n currentPage: number;\n collectionSize: number;\n pageSize: number;\n onPageChange: (page: number) => void;\n}\n\nexport const Pager: FC<PagerProps> = ({\n collectionSize,\n pageSize,\n onPageChange,\n currentPage,\n}) => {\n const pageCount = Math.ceil(collectionSize / pageSize);\n return (\n <Pagination\n pageCount={pageCount}\n currentPage={currentPage}\n onPageChange={(page) => {\n onPageChange(page);\n }}\n />\n );\n};\n","import { BusinessCapability } from '@entur-partner/permission-client-node';\nimport React from 'react';\nimport {\n Route,\n Redirect,\n RouteComponentProps,\n RouteProps,\n} from 'react-router-dom';\n\nimport { PermissionCheck } from './PermissionCheck';\n\ninterface PermissionCheckedRouteProps\n extends RouteComponentProps,\n Omit<RouteProps, 'location'> {\n actualPermissions: BusinessCapability[];\n all?: BusinessCapability[];\n oneOf?: BusinessCapability[];\n onReject?: React.ReactNode;\n}\n\nexport const PermissionCheckedRoute = ({\n children,\n actualPermissions,\n all,\n oneOf,\n onReject,\n ...props\n}: PermissionCheckedRouteProps) => {\n const redirect = (\n <Redirect\n to={{\n pathname: '/unauthorized',\n state: { from: props.location },\n }}\n />\n );\n return (\n <PermissionCheck\n permissions={actualPermissions}\n all={all}\n oneOf={oneOf}\n fallback={onReject ? onReject : redirect}\n >\n <Route {...props}>{children}</Route>\n </PermissionCheck>\n );\n};\n","import React, { useState, FC, ReactNode } from 'react';\nimport { Prompt, useHistory } from 'react-router-dom';\nimport { Location } from 'history';\nimport { ModalProps } from '@entur/modal';\n\nimport { ConfirmModal } from './ConfirmModal';\n\nexport interface RouteLeavingGuardProps extends Partial<ModalProps> {\n title: string;\n closeLabel: string;\n messages: {\n cancel: string;\n confirm: string;\n };\n children: ReactNode;\n shouldBlockNavigation: (location: Location) => boolean;\n}\n\ntype Status = 'BLOCKED' | 'ALLOW';\n\nexport const RouteLeavingGuard: FC<RouteLeavingGuardProps> = ({\n children,\n shouldBlockNavigation,\n ...rest\n}) => {\n const history = useHistory();\n\n const [status, setStatus] = useState<Status>('ALLOW');\n const [lastLocation, setLastLocation] = useState(history.location);\n\n const closeModal = () => {\n setStatus('ALLOW');\n };\n\n const allowNavigation = (nextLocation: Location): boolean => {\n if (shouldBlockNavigation(nextLocation) && status === 'ALLOW') {\n setStatus('BLOCKED');\n setLastLocation(nextLocation);\n return false;\n }\n return true;\n };\n\n const handleConfirm = () => {\n history.push(lastLocation.pathname);\n };\n\n return (\n <>\n <Prompt message={allowNavigation} />\n <ConfirmModal\n onDismiss={closeModal}\n open={status === 'BLOCKED'}\n onConfirm={handleConfirm}\n {...rest}\n >\n {children}\n </ConfirmModal>\n </>\n );\n};\n","import './StatusLabel.scss';\n\nimport React, { FC } from 'react';\nimport cx from 'classnames';\n\ninterface StatusLabelProps {\n label: string;\n active: boolean;\n aggressiveInactive?: boolean;\n showBullet?: boolean;\n center?: boolean;\n}\nexport const StatusLabel: FC<StatusLabelProps> = ({\n active = false,\n label = '',\n aggressiveInactive,\n showBullet,\n center,\n}) => {\n const bulletClassNames = cx('eps-status-label__bullet', {\n active,\n aggressive: aggressiveInactive,\n });\n const statusLabelClassNames = cx('eps-status-label', {\n center,\n });\n return (\n <div className={statusLabelClassNames}>\n {showBullet && <div className={bulletClassNames} />}\n <div>{label}</div>\n </div>\n );\n};\n","import './Text.scss';\n\nimport React, { ReactNode } from 'react';\nimport cx from 'classnames';\n\nimport { StyleColor, responsiveProp, Box } from './Box';\n\ntype StyleFontSize =\n | 'extraSmall'\n | 'small'\n | 'medium'\n | 'large'\n | 'extraLarge'\n | 'extraLarge2'\n | 'extraLarge3'\n | 'extraLarge4';\n\ntype StyleFontWeight = 'body' | 'heading';\n\ntype StyleLineHeight =\n | 'extraSmall'\n | 'small'\n | 'medium'\n | 'large'\n | 'extraLarge'\n | 'extraLarge2'\n | 'extraLarge3'\n | 'extraLarge4'\n | 'extraLarge5'\n | 'extraLarge6'\n | 'extraLarge7';\n\nexport type ResponsiveStyleFontSize =\n | StyleFontSize\n | [StyleFontSize?, StyleFontSize?, StyleFontSize?];\n\nexport type ResponsiveStyleLineHeight =\n | StyleLineHeight\n | [StyleLineHeight?, StyleLineHeight?, StyleLineHeight?];\n\nexport interface TextProps {\n className?: string;\n as?: React.ElementType;\n children: ReactNode;\n\n fontSize?: ResponsiveStyleFontSize;\n lineHeight?: ResponsiveStyleLineHeight;\n color?: StyleColor;\n fontWeight?: StyleFontWeight;\n\n [key: string]: any;\n}\n\nexport const Text = ({\n as: component = 'span',\n children,\n fontSize,\n color,\n lineHeight,\n fontWeight,\n className,\n ...rest\n}: TextProps) => {\n const classes = [];\n\n fontSize && classes.push(...responsiveProp('eps-font-size-', fontSize));\n lineHeight && classes.push(...responsiveProp('eps-line-height-', lineHeight));\n fontWeight && classes.push('eps-font-weight-' + fontWeight);\n\n const classList = cx(classes, className);\n\n return (\n <Box as={component} color={color} className={classList} {...rest}>\n {children}\n </Box>\n );\n};\n","import './Unbutton.scss';\n\nimport React, { FC } from 'react';\nimport { Button, ButtonProps } from '@entur/button';\nimport cx from 'classnames';\n\ninterface UnbuttonProps extends Omit<ButtonProps, 'variant'> {}\n\nexport const Unbutton: FC<UnbuttonProps> = ({\n children,\n className,\n ...rest\n}) => (\n <Button variant=\"primary\" {...rest} className={cx('eps-unbutton', className)}>\n {children}\n </Button>\n);\n","/*global EventListener WindowEventHandlers*/\nimport { useEffect, useRef } from 'react';\n\ninterface TypedEventListener<T extends Event> {\n (evt: T): void;\n}\n\nexport function useEventListener<T extends Event = Event>(\n eventName: string,\n handler: TypedEventListener<T>,\n element: WindowEventHandlers = window\n) {\n const savedHandler = useRef<TypedEventListener<T>>();\n\n useEffect(() => {\n savedHandler.current = handler;\n }, [handler]);\n\n useEffect(() => {\n const isSupported = element && element.addEventListener;\n if (!isSupported) return;\n\n const eventListener = ((event: T): void =>\n savedHandler.current?.(event)) as EventListener;\n\n element.addEventListener(eventName, eventListener);\n\n return () => {\n element.removeEventListener(eventName, eventListener);\n };\n }, [eventName, element]);\n}\n"],"names":["responsiveProp","prefix","prop","Array","isArray","classes","push","Box","_ref","_ref$as","as","Component","children","contrast","paddingTop","paddingRight","paddingBottom","paddingLeft","paddingX","paddingY","padding","marginTop","marginRight","marginBottom","marginLeft","marginX","marginY","margin","display","justifyContent","alignItems","maxWidth","width","background","color","flexDirection","flexWrap","className","rest","_objectWithoutPropertiesLoose","_excluded","resolvedPaddingTop","resolvedPaddingBottom","resolvedPaddingLeft","resolvedPaddingRight","resolvedMarginTop","resolvedMarginBottom","resolvedMarginLeft","resolvedMarginRight","apply","classList","cx","React","createElement","_extends","Stack","space","stackItems","Children","toArray","length","Fragment","map","child","index","key","useFeatureToggle","flag","_window$localStorage","_window$localStorage2","process","env","getItem","window","localStorage","FeatureToggle","EnturPartnerLogoSvg","title","height","viewBox","fill","fillRule","d","CustomOverflowMenu","_ref2","ref","buttonRef","handler","userName","open","onOpenChange","overflowItemsClasses","overflowContentRef","useRef","overflowMenuTriggerRef","useEffect","listener","event","elementContainsEventTarget","current","document","addEventListener","removeEventListener","SecondaryButton","onClick","role","UserIcon","inline","Heading6","DownArrowIcon","CustomOverflowMenuItem","props","element","contains","target","composed","composedPath","find","LanguageSelect","language","options","onChange","classNames","SegmentedControl","assertIsDefined","selectedValue","option","SegmentedChoice","value","label","required","ErrorBoundary","_Component","_this","call","this","state","error","getDerivedStateFromError","_proto","prototype","componentDidCatch","errorInfo","_this$props$handleErr","_this$props","handleError","render","functionToCheck","_this2","_this$props2","fallback","toString","retry","setState","FormatDateTime","date","locale","hideTime","localeDate","localeDateTime","ConfirmModal","_ref$isOpen","isOpen","message","_ref$size","size","buttons","onConfirm","messages","onClose","onDismiss","childrenToRender","handleDismiss","Modal","isString","Paragraph","ButtonGroup","cancel","PrimaryButton","confirm","PermissionCheck","_ref$fallback","permissions","_ref$oneOf","oneOf","_ref$all","all","allIsAllowed","hasAllPermissions","oneOfIsAllowed","hasOneOfPermissions","_ref3","items","i","isDate","isDateString","prependBreadcrumbItem","pathname","onBreadcrumbLookup","paths","replace","split","reduce","prev","curr","path","breadcrumbs","filter","undefined","breadcrumbElements","BreadcrumbItem","Link","to","BreadcrumbNavigation","classnames","_ref2$as","altText","InputComponent","inputComponent","languages","values","name","variant","feedback","ExpandablePanel","defaultOpen","contentStyle","langKey","e","changes","amount","parsedAmount","Number","formattedAmount","Intl","NumberFormat","maximumFractionDigits","minimumFractionDigits","format","A","RouterLink","alertLabel","alertLevel","_ref$defaultLanguage","defaultLanguage","_ref$label","_ref$onBlur","onBlur","useState","_useState","setLanguage","currentValue","tabIndex","persist","currentTarget","setTimeout","activeElement","lang","handleLanguageChange","Object","assign","organisations","handleChange","selectedOrganisationId","selectedOrganisation","org","id","Dropdown","searchable","clearable","sort","a","b","localeCompare","organisation","initialSelectedItem","collectionSize","onPageChange","currentPage","pageCount","Math","ceil","pageSize","Pagination","page","actualPermissions","onReject","redirect","Redirect","from","location","Route","shouldBlockNavigation","history","useHistory","status","setStatus","_useState2","lastLocation","setLastLocation","Prompt","nextLocation","_ref$active","active","showBullet","center","bulletClassNames","aggressive","aggressiveInactive","statusLabelClassNames","component","fontSize","lineHeight","fontWeight","Button","onLogout","onLanguageChange","onShowGdprDialog","triggerClassList","setOpen","PrivacyIcon","termsAndConditions","NorwayIcon","switchLanguage","UKIcon","UploadIcon","style","transform","logout","eventName","savedHandler","eventListener"],"mappings":"4tCAuHgB,SAAAA,EAAeC,EAAgBC,GAC7C,GAAIC,MAAMC,QAAQF,GAAO,CACjBG,IAAAA,EAAU,GAIhB,OAHAH,EAAK,IAAMG,EAAQC,KAAKL,EAASC,EAAK,IACtCA,EAAK,IAAMG,EAAQC,KAAR,GAAgBL,EAASC,EAAK,GAAzC,OACAA,EAAK,IAAMG,EAAQC,KAAR,GAAgBL,EAASC,EAAK,GAAzC,OACOG,EAET,MAAO,CAACJ,EAASC,GAGNK,IAAAA,EAAM,SA6BJC,GAAA,IAAAC,EAAAD,EA5BbE,GAAIC,aAAY,MA4BHF,EA3BbG,IAAAA,SACAC,IAAAA,SACAC,IAAAA,WACAC,IAAAA,aACAC,IAAAA,cACAC,IAAAA,YACAC,IAAAA,SACAC,IAAAA,SACAC,IAAAA,QACAC,IAAAA,UACAC,IAAAA,YACAC,IAAAA,aACAC,IAAAA,WACAC,IAAAA,QACAC,IAAAA,QACAC,IAAAA,OACAC,IAAAA,QACAC,IAAAA,eACAC,IAAAA,WACAC,IAAAA,SACAC,IAAAA,MACAC,IAAAA,WACAC,IAAAA,MACAC,IAAAA,cACAC,IAAAA,SACAC,IAAAA,UACGC,EACUC,EAAA/B,EAAAgC,GACPnC,EAAU,GACVoC,EAAqB3B,GAAcK,GAAYC,EAC/CsB,EAAwB1B,GAAiBG,GAAYC,EACrDuB,EAAsB1B,GAAeC,GAAYE,EACjDwB,EAAuB7B,GAAgBG,GAAYE,EAEnDyB,EAAoBxB,GAAaK,GAAWC,EAC5CmB,EAAuBvB,GAAgBG,GAAWC,EAClDoB,EAAqBvB,GAAcC,GAAWE,EAC9CqB,EAAsB1B,GAAeG,GAAWE,EAEtDd,GAAYR,EAAQC,KAAK,gBACzBmC,GACEpC,EAAQC,KAARD,MAAAA,EAAgBL,EAAe,UAAWyC,IAC5CC,GACErC,EAAQC,KAARD,MAAAA,EAAgBL,EAAe,UAAW0C,IAC5CC,GACEtC,EAAQC,KAARD,MAAAA,EAAgBL,EAAe,UAAW2C,IAC5CC,GACEvC,EAAQC,KAARD,MAAAA,EAAgBL,EAAe,UAAW4C,IAC5CC,GACExC,EAAQC,KAARD,MAAAA,EAAgBL,EAAe,UAAW6C,IAC5CC,GACEzC,EAAQC,KAARD,MAAAA,EAAgBL,EAAe,UAAW8C,IAC5CC,GACE1C,EAAQC,KAARD,MAAAA,EAAgBL,EAAe,UAAW+C,IAC5CC,GACE3C,EAAQC,KAARD,MAAAA,EAAgBL,EAAe,UAAWgD,IAE5CpB,GAAWvB,EAAQC,KAARD,MAAAA,EAAgBL,EAAe,OAAQ4B,IAClDC,GACExB,EAAQC,KAARD,MAAAA,EAAgBL,EAAe,eAAgB6B,IAC7CC,GACFzB,EAAQC,KAAR2C,MAAA5C,EAAgBL,EAAe,aAAc8B,IAG/CC,GAAY1B,EAAQC,KAARD,MAAAA,EAAgBL,EAAe,aAAc+B,IACzDC,GAAS3B,EAAQC,KAARD,MAAAA,EAAgBL,EAAe,SAAUgC,IAElDE,GAAS7B,EAAQC,KAAR,aAA0B4B,GACnCD,GAAc5B,EAAQC,KAAR,UAAuB2B,GAErCE,GAAiB9B,EAAQC,KAARD,MAAAA,EAAgBL,EAAe,YAAamC,IAC7DC,GAAY/B,EAAQC,KAARD,MAAAA,EAAgBL,EAAe,iBAAkBoC,IAE7D,IAAMc,EAAYC,EAAAA,QAAG9C,EAASgC,GAE9B,OACEe,UAAAC,cAAC1C,EAAD2C,EAAA,CAAWjB,UAAWa,GAAeZ,GAClC1B,ICvMM2C,EAAQ,SAA+C/C,GAA5CI,IAAU4C,IAAAA,MAAOnB,IAAAA,UACjCoB,EAAaC,EAAAA,SAASC,UADN/C,UAEtB,OAAI6C,EAAWG,QAAU,EAChBR,EAAAA,QAAAC,cAAAD,EAAAA,QAAAS,SAAA,KAAGJ,GAIVL,EAAK,QAAAC,cAAA,MAAA,CAAAhB,UAAWA,GACboB,EAAWK,KAAI,SAACC,EAAOC,GAAR,OACdA,IAAUP,EAAWG,OAAS,EAC5BR,+BAAKa,IAAKD,GAAQD,GAElBX,UAAAC,cAAC9C,EAAG,CAACS,cAAewC,EAAOS,IAAKD,GAC7BD,mCCdP,SAAUG,EAAiBC,GAAY,IAAAC,EAAAC,EAC3C,MACuC,SAArCC,QAAQC,IAAR,aAAyBJ,IACc,UAAlBK,OAArBC,EAAAA,OAAOC,mBAAcF,EAAAA,EAAAA,QAAQL,KACyB,UAAtD,OAAAE,EAAAI,OAAOC,mBAAP,EAAAL,EAAqBG,QAArB,aAA0CL,IAejCQ,gBCjBAC,EAAqC,SAAuBpE,GAApBqE,IAAAA,IAAAA,MAAUvC,EAAUC,EAAA/B,EAAAgC,GACvE,OACEY,UAAAC,cAAA,MAAAC,EAAA,CAAKtB,MAAO,IAAK8C,OAAQ,GAAIC,QAAQ,cAAiBzC,GACpDc,UAAAC,cAAA,QAAA,KAAQwB,GACRzB,EAAAA,QAAAC,cAAA,IAAA,CAAG2B,KAAK,OAAOC,SAAS,WACtB7B,EAAA,QAAAC,cAAA,OAAA,CACE2B,KAAK,OACLE,EAAE,iFAEJ9B,EAAAA,QAAAC,cAAA,OAAA,CAAM2B,KAAK,UAAUE,EAAE,8BACvB9B,EAAAA,QAAAC,cAAA,OAAA,CACE2B,KAAK,OACLE,EAAE,+sCAEJ9B,EAAAA,QAAGC,cAAA,IAAA,CAAA2B,KAAK,WACN5B,EAAM,QAAAC,cAAA,OAAA,CAAA6B,EAAE,gwDCsFZC,EAMD,SAAmEC,GAAhE/C,IAoFNgD,EACAC,EACAC,EAtFMlD,IAAAA,UAAWzB,IAAAA,SAAU4E,IAAAA,SAAUC,IAAAA,KAAMC,IAAAA,aAAiBpD,EAAUC,EAAA6C,EAAA5C,GAChEmD,EAAuBxC,EAAE,QAAC,2BAA4B,CACxBsC,iCAAAA,IAE9BG,EAAqBxC,EAAAA,QAAMyC,OAAuB,MAClDC,EAAyB1C,EAAAA,QAAMyC,OAA0B,MAI/D,OA+EAzC,EAAK,QAAC2C,WAAU,WACd,IAAMC,EAAW,SAACC,GAEdC,EAA2Bb,EAAIc,QAASF,IACxCC,EAA2BZ,EAAUa,QAASF,IAKhDV,KAMF,OAHAa,SAASC,iBAAiB,YAAaL,GACvCI,SAASC,iBAAiB,aAAcL,GAEjC,WACLI,SAASE,oBAAoB,YAAaN,GAC1CI,SAASE,oBAAoB,aAAcN,MAE5C,CAvBHX,EA9EgBO,EA+EhBN,EA/EoCQ,EAgFpCP,EAhF4D,WAC1DG,OAAAA,GAAa,MAGbtC,EAAA,QAAAC,cAAA,MAAA,KACED,EAAAA,QAAAC,cAACkD,EAADA,gBAAAjD,EAAA,CACEjB,UAAWc,EAAAA,QAAG,4BAA6Bd,GAC3CmE,QAAS,WAAA,OAAMd,GAAaD,qBACb,EACfgB,KAAK,yBACUhB,EACfJ,IAAKS,GACDxD,GAEJc,UAAKC,cAAA,MAAA,CAAAhB,UAAU,sCACbe,EAAM,QAAAC,cAAA,OAAA,CAAAhB,UAAU,gCACde,EAAA,QAAAC,cAACqD,WAAQ,CAACC,QAAM,KAElBvD,EAAAA,QAACC,cAAAuD,WAAS,CAAAjF,OAAO,OAAOjB,GAAG,QACxB8E,GAEHpC,UAAMC,cAAA,OAAA,CAAAhB,UAAU,kBACde,EAAA,QAAAC,cAACwD,gBAAc,CAAAF,QAAS,OAI7BlB,GACCrC,EAAAA,QACEC,cAAA,MAAA,CAAAhB,UAAWsD,EACXc,KAAK,OACLpB,IAAKO,GAEJhF,KAOLkG,EAKF,SAACC,GACH,OACE3D,iCAAAE,EAAA,CACEjB,UAAWc,EAAE,QAAC4D,EAAM1E,UAAW,2BAC/BoE,KAAK,YACDM,KAKV,SAASb,EAA2Bc,EAA6Bf,GAC3D,SAACe,KAIDA,EAAQC,SAAShB,EAAMiB,SAKvBjB,EAAMkB,UAAYlB,EAAMmB,cACTnB,EAAMmB,eAAeC,MAAK,SAACH,GACtCA,OAAAA,IAAWzC,QAGRuC,EAAQC,SAASC,4HC1KjBI,EAA0C,SAMlD9G,GALH+G,IAAAA,IAAAA,SACAC,IAAAA,QACAnF,IAAAA,UACAoF,IAAAA,SACGnF,EACAC,EAAA/B,EAAAgC,GACGkF,EAAavE,EAAAA,QAAG,sBAAuBd,GAC7C,OACEe,EAAAA,QAASC,cAAA,WAAAf,EAAT,CAAeD,UAAWqF,IACxBtE,EAAAA,QAAAC,cAACsE,mBACC,CAAAF,SAAU,SAACF,GACTK,EAAeA,gBAACL,GAChBE,EAASF,IAEXM,cAAeN,GAEdC,EAAQ1D,KAAI,SAACgE,GAAD,OACX1E,EAAA,QAAAC,cAAC0E,kBAAe,CAAC9D,IAAK6D,EAAOE,MAAOA,MAAOF,EAAOE,OAC/CF,EAAOG,MACPH,EAAOI,UAAY9E,EAAM,QAAAC,cAAA,OAAA,CAAAhB,UAAU,mBAAmB,qQCtBtD8F,EAAb,SAAAC,WACE,SAAAD,EAAYpB,GAAY,IAAAsB,EAAA,OACtBA,EAAAD,EAAAE,KAAAC,KAAMxB,IAANwB,MACKC,MAAQ,CAAEC,MAAO,MAFAJ,IAD1BD,KAAAD,yEAAAA,EAMSO,yBAAP,SAAgCD,GACvB,MAAA,CACLA,MAAAA,IARN,IAAAE,EAAAR,EAAAS,UAAA,OAAAD,EAYEE,kBAAA,SAAkBJ,EAAcK,GAAoB,IAAAC,EAAAC,EAEzBP,OAAzBM,GAAAC,EAAAT,KAAKxB,OAAMkC,cAAcR,EAAAA,KAAAA,EAAAA,EAAOK,IAGlCI,EAAAA,OAAA,WAAM,ICtCsBC,EDsCtBC,EAAAb,KACIE,EAAUF,KAAKC,MAAfC,MACRY,EAA+Bd,KAAKxB,MAA5BuC,IAAAA,SAAU1I,IAAAA,SAElB,OAAI6H,GC1CsBU,ED2CGG,ICzC4B,sBAAtC,GAAGC,SAASjB,KAAKa,GD0CzBG,EAAS,CAAEE,MAAO,WAAM,OAAAJ,EAAKK,SAAS,CAAEhB,MAAO,QAASA,MAAAA,IAE1Da,EAGF1I,GA5BXuH,EAAA,CAAmCxH,EAAnCA,+CEZa+I,EAA0C,SAMlDlJ,GALHmJ,IAAAA,IAAAA,KACAC,IAAAA,OAIGnJ,EAAAD,EAHHE,GAAIC,aAAY,OAGbF,EAFHoJ,IAAAA,SACGvH,EACAC,EAAA/B,EAAAgC,GAEDY,OAAAA,EAAAA,QAACC,cAAA1C,EAAc2B,EAAAA,GAAAA,GACZuH,EAAWC,EAAAA,WAAWH,EAAMC,GAAUG,EAAcA,eAACJ,EAAMC,wJCqBrDI,EAAsC,SAW9CxJ,GAAA,IAAAyJ,EAAAzJ,EAVH0J,OAAAA,cAUGD,EATHrJ,IAAAA,SACAuJ,IAAAA,QAQGC,EAAA5J,EAPH6J,KAAAA,aAAO,SAOJD,EANHE,IAAAA,QACAC,IAAAA,UACAC,IAAAA,SACAC,IAAAA,QACAC,IAAAA,UACGpI,EACAC,EAAA/B,EAAAgC,GACGmI,EAAmB/J,GAAsBuJ,EACzCS,EAAgBH,GAAoBC,EAC1C,OACEtH,UAACC,cAAAwH,EAADA,MAAAvH,EAAA,CAAO+G,KAAMA,EAAM5E,KAAMyE,EAAQQ,UAAWE,GAAmBtI,GAC5DwI,EAAAA,SAASH,GACRvH,EAAAA,QAACC,cAAA0H,EAADA,UAAY,KAAAJ,GAEZvH,EAAAA,QAAAC,cAAC9C,EAAG,CAACS,cAAc,UAAU2J,GAG/BvH,EAAA,QAAAC,cAAC2H,EAADA,YACG,KAAAT,EACCnH,EAAA,QAAAC,cAAAD,EAAA,QAAAS,SAAA,KACET,EAAC,QAAAC,cAAAkD,kBACC,CAAAC,QAASoE,EACG,cAAA,uBAEXJ,EAASS,QAEZ7H,EAAAA,QAACC,cAAA6H,EAAAA,eACC1E,QAAS+D,EACG,cAAA,wBAEXC,EAASW,UAIdb,4CCpDGc,EAA4C,SAMpD5K,GALHI,IAAAA,IAAAA,SAKGyK,EAAA7K,EAJH8I,SAAAA,aAAW,KAIR+B,EAHHC,IAAAA,YAGGC,EAAA/K,EAFHgL,MAAAA,aAAQ,GAELD,EAAAE,EAAAjL,EADHkL,IAEMC,EAAeC,EAAAA,6BAFf,GACHH,EACyCH,GAEtCO,EAAiBC,EAAAA,oBAAoBN,EAAOF,GAGlD,OAAOlI,EAAA,QAAAC,cAAAD,UAAAS,SAAA,KADS8H,GAAgBE,EACZjL,EAAW0I,+JCvBf,SAAiCyC,GAA9BnL,IAAAA,IAAAA,SACnB,OACEwC,EAAA,QAAAC,cAAAD,UAAAS,SAAA,KACET,EAAK,QAAAC,cAAA,MAAA,CAAAhB,UAAU,2BACfe,EAAAA,QAAKC,cAAA,MAAA,CAAAhB,UAAU,kBAAkBzB,2BAZjB,SAAiCJ,GACrD,OAAO4C,+BAAKf,UAAU,yBADCzB,kCAIF,SAAiCwE,GACtD,OAAOhC,+BAAKf,UAAU,0BADEzB,6BCUmB,SAKxCJ,GAJHwL,IAAAA,IAAAA,MACApC,IAAAA,OACAvH,IAAAA,UACGC,EACAC,EAAA/B,EAAAgC,GACGkF,EAAavE,EAAAA,QAAG,gBAAiBd,GACvC,OACEe,UAAAC,cAAA,MAAAC,EAAA,CAAKjB,UAAWqF,GAAgBpF,GAC7B0J,EAAMlI,KAAI,WAAmBmI,GAAhBhE,IAAOD,IAAAA,MAAV,OACT5E,EAAA,QAAAC,cAACE,EAAK,CAACC,MAAM,QAAQS,IAAKgI,GACxB7I,EAAA,QAAAC,cAAA,MAAA,CAAKhB,UAAU,yBAFL4F,OAGV7E,EAAAA,QAAAC,cAAA,MAAA,KACG6I,EAAAA,OAAOlE,IAAUmE,EAAYA,aAACnE,GAC7B5E,EAAAA,sBAACsG,EAAc,CAACC,KAAM3B,EAAO4B,OAAQA,IAErCxG,EAAA,QAAAC,cAAA,OAAA,KAAO2E,4CC1B4B,SAI5CxH,GAHH4L,IAAAA,IAAAA,sBACAC,IAAAA,SACAC,IAAAA,mBAEMC,EAA+B,MAAbF,EAAmB,GAAK,CAAC,MAI/CA,EAASzI,OAAS,EAAIyI,EAASG,QAAQ,MAAO,IAAMH,GAErCI,MAAM,KAAKC,QAAO,SAACC,EAAMC,GACxC,IAAMC,EAAUF,EAAN,IAAcC,EAExB,OADAL,EAAMjM,KAAKuM,GACJA,KAGT,IAAMC,EAAcP,EACjBzI,KAAI,SAAC+I,GAAU,MAAA,CAAEhI,MAAOyH,EAAmBO,GAAOA,KAAAA,MAClDE,QAAO,SAAA3H,GAAeP,YAAUmI,MAAtBnI,SAEPoI,EAAqBH,EAAYhJ,KAAI,SAAAiI,EAAkBE,GAAfpH,IAAOgI,IAAAA,KAEnD,OAEIzJ,EAAA,QAAAC,cAAC6J,iBAHUjB,IAAMa,EAAYlJ,OAAS,EAGvB,CAACK,IAAK4I,EAAMnM,GAAI,SAMjBuD,IAAK4I,EAAMnM,GAAIyM,OAAMC,GAAIP,KAVChI,UAgB9C,OAEIzB,EAAA,QAAAC,cAACgK,EAAAA,qBAAoB,KAFrBjB,EAGIA,CAAAA,GAA0Ba,OAAAA,GAKJA,2CC9CS,SAIpCzM,GAAA,IAAAC,EAAAD,EAHHE,GAAIC,aAAY,OAGbF,EADHG,IAAAA,SAEMsC,EAAYoK,EAAU,QAAC,CAAC,gBAH9BjL,YAKA,OAAOe,EAAA,QAAAC,cAAC1C,EAAU,CAAA0B,UAAWa,GAAYtC,6BXsBgB,SAItDwE,GAAA,IAAAmI,EAAAnI,EAHH1E,GAAIC,aAAY,MAGb4M,EADHC,IAAAA,QAEMtK,EAAYoK,EAAU,QAAC,CAAC,qBAH9BjL,YAKA,OACEe,EAAC,QAAAC,cAAA1C,EAAU,CAAA0B,UAAWa,GACpBE,EAAA,QAAAC,cAACuB,EAAmB,CAACC,MAAO2I,EAASnL,UAAU,sGY3BT,SAUJ7B,GATtCqE,IAAAA,IAAAA,MACgB4I,IAAhBC,eACAC,IAAAA,UACAC,IAAAA,OACAnG,IAAAA,SACAoG,IAAAA,KACAC,IAAAA,QACAC,IAAAA,SACGzL,EACmCC,EAAA/B,EAAAgC,GAWtC,OACEY,EAAC,QAAAC,cAAA2K,kBACC,CAAAnJ,MAAOA,EACPoJ,aACA,EAAAC,aAAc,CACZ9M,QAAS,kBACTC,UAAW,OACXE,aAAc,SAGhB6B,EAAA,QAAAC,cAACE,EAAM,CAAAC,MAAM,UACVmK,EAAU7J,KAAI,SAAAsB,GAAU+I,IAAAA,IAAPnG,MAAgBC,IAAAA,MAAnB,OACb7E,UAACC,cAAAoK,EAADnK,EAAA,CACmCuK,cAAAA,oBAAAA,MAAQM,EACzClK,IAAKY,EAAQsJ,EACblG,QAJqCC,SAInBD,EAAQ,IAAMA,EAChC6F,QAASA,GAAWA,EAAQK,GAC5BJ,SAAUA,GAAYA,EAASI,GAC/BN,KAAMA,EACNpG,SAAU,SAAC2G,GA7BE,IAAC7G,EAAuBS,EACvCqG,EADgB9G,EA8BG4G,EA9BoBnG,EA8BXoG,EAAElH,OAAOc,MA7BrCqG,EAAeT,EAAAA,GAAAA,GACP,KAAV5F,GAAiBA,EAGnBqG,EAAQ9G,GAAYS,SAFbqG,EAAQ9G,GAIjBE,EAAS4G,IAyBDrG,MAAO4F,EAAOO,IAAY,IACtB7L,gCbrCa,SAA2C9B,GAAxCI,IAAAA,IAAAA,SAE9B,OADgBsD,IADwBC,MAG/Bf,EAAAA,QAAAC,cAAAD,EAAAA,QAAAS,SAAA,KAAGjD,GAEL,mCczB0D,SAI9DJ,GAHH8N,IAAAA,IAAAA,OAGG7N,EAAAD,EAFHE,GAAIC,aAAY,OAEbF,EADA6B,EACAC,EAAA/B,EAAAgC,GACG+L,EAAeC,OAAOF,IAAW,EAEjCG,EAAkB,IAAIC,KAAKC,aAAa,QAAS,CACrDC,sBAAuB,EACvBC,sBAAuB,IACtBC,OAAOP,GAEHnL,OAAAA,wBAACzC,EAAc2B,EAAAA,GAAAA,GAAOmM,mECdA,SAAC1H,GAC9B,OACE3D,EAAAA,QAAAC,cAAC0L,EAAAA,UAAMhI,EAAP,CAAcrG,GAAIsO,EAAAA,OACfjI,EAAMnG,8BCGa,SAAAJ,GACxBI,IAAAA,IAAAA,SACAyB,IAAAA,UACGC,EAHqBC,EAAA/B,EAAAgC,GAAA,OAKxBY,EAAAA,QAACC,cAAA8J,EAAAA,UAAS7K,EAAV,CAAgB5B,GAAG,SAAS2B,UAAWc,EAAAA,QAAG,kBAAmBd,KAC1DzB,iBCR8B,SAI9BJ,GAAA,IAAAC,EAAAD,EAHHE,GAAIC,aAAY,MAGbF,EADHG,IAAAA,SAEMsC,EAAYoK,EAAAA,QAAW,CAAC,eAAgB,aAH9CjL,YAKA,OAAOe,EAAA,QAAAC,cAAC1C,EAAU,CAAA0B,UAAWa,GAAYtC,+BCWoB,SAa1DJ,GAZH6B,IAAAA,IAAAA,UACgBoL,IAAhBC,eACAuB,IAAAA,WACAC,IAAAA,WACArB,IAAAA,KACAF,IAAAA,UACAC,IAAAA,OACAnG,IAAAA,SAKG0H,EAAA3O,EAJH4O,gBAAAA,aAAkB,MAIfD,EAAAE,EAAA7O,EAHHyH,MAAAA,aAAQ,GAGLoH,EAAAC,EAAA9O,EAFH+O,OAAAA,OAEG,IAAAD,EAFM,aAENA,EADAhN,EACAC,EAAA/B,EAAAgC,GAC6BgN,EAAAA,EAAQA,SAACJ,GAAlC7H,EAAPkI,EAAA,GAAiBC,EAAjBD,EAAA,GACM/H,EAAavE,EAAAA,QAAG,uBAAwBd,GACxCsN,EAAe/B,EAAOrG,GA0B5B,OACEnE,EACE,QAAAC,cAAA,MAAA,CAAAhB,UAAWqF,EACXkI,SAAU,EACVL,OA5BiB,SAACnB,GACpBA,EAAEyB,UACF,IAAMC,EAAgB1B,EAAE0B,cACxBC,YAAW,WACLD,IAAkBA,EAAc7I,SAASb,SAAS4J,gBACpDT,EAAOnB,KAER,IAsBgCP,cAAAA,oBAAAA,GAEjCzK,EAAA,QAAAC,cAACE,EAAK,CAACC,MAAM,cACXJ,EAAC,QAAAC,cAAAiE,GACCC,SAAUA,EACVC,QAASmG,EACTlG,SAAU,SAACwI,GAASC,OAzBC,SAAC3I,GAC5BmI,EAAYnI,GAwBc2I,CAAqBD,MAE3C7M,EAAC,QAAAC,cAAAoK,EAADnK,EAAA,CACE2E,MAAOA,EACP6F,QAASoB,EACTnB,SAAUkB,EACVpB,KAAMA,EACNxL,UAAU,gBACVoF,SAAU,SAAC2G,GAAD,OA7BMpG,EA8BCoG,EAAElH,OAAOc,MA7B1BqG,EAAU8B,OAAOC,OAAO,GAAIxC,GACpB,KAAV5F,GAAiBA,EAGnBqG,EAAQ9G,GAAYS,SAFbqG,EAAQ9G,QAIjBE,EAAS4G,GAPY,IAACrG,EAChBqG,GA+BArG,MAAO2H,GAAgB,IACnBrN,oCC7EqD,SAM9D9B,GALHyH,IAAAA,IAAAA,MACAoI,IAAAA,cACUC,IAAV7I,SACA8I,IAAAA,uBACGjO,EACAC,EAAA/B,EAAAgC,GACGgO,EAAuBH,EAAchJ,MACzC,SAACoJ,GAAD,OAASA,EAAIC,KAAOH,KAGtB,OACEnN,wBAACuN,EAADA,SAAArN,EAAA,CACE2E,MAAOA,EACP2I,YAAY,EACZC,WAAW,EACXxO,UAAU,eACV2J,gBACKqE,EACAS,MAAK,SAACC,EAAGC,GAAMD,OAAAA,EAAElD,KAAKoD,cAAcD,EAAEnD,KAAM,SAC5C/J,KAAI,SAACoN,GACG,MAAA,CACLlJ,MAAOkJ,EAAaR,GACpBzI,MAAOiJ,EAAarD,UAI5BsD,oBACEX,EACI,CACExI,MAAOwI,EAAqBE,GAC5BzI,MAAOuI,EAAqB3C,MAE9B,KAENpG,SAAU,SAACI,GACLA,GACFyI,EAAazI,EAAcG,SAG3B1F,mBC9C2B,SAKhC9B,GAJH4Q,IAEAC,IAAAA,aACAC,IAAAA,YAEMC,EAAYC,KAAKC,OALvBL,iBACAM,UAKA,OACEtO,EAAC,QAAAC,cAAAsO,aACC,CAAAJ,UAAWA,EACXD,YAAaA,EACbD,aAAc,SAACO,GACbP,EAAaO,gECFiB,SAOJpR,GANhCI,IAAAA,IAAAA,SACAiR,IAAAA,kBACAnG,IAAAA,IACAF,IAAAA,MACAsG,IAAAA,SACG/K,EAC6BxE,EAAA/B,EAAAgC,GAC1BuP,EACJ3O,EAAAA,sBAAC4O,WAAQ,CACP5E,GAAI,CACFf,SAAU,gBACV7D,MAAO,CAAEyJ,KAAMlL,EAAMmL,aAI3B,OACE9O,EAAC,QAAAC,cAAA+H,EACC,CAAAE,YAAauG,EACbnG,IAAKA,EACLF,MAAOA,EACPlC,SAAUwI,GAAsBC,GAEhC3O,EAAC,QAAAC,cAAA8O,QAAD7O,EAAA,GAAWyD,GAAQnG,+BCvBoC,SAIxDJ,GAHHI,IAAAA,IAAAA,SACAwR,IAAAA,sBACG9P,EACAC,EAAA/B,EAAAgC,GACG6P,EAAUC,EAAAA,aAEY9C,EAAAA,EAAQA,SAAS,SAAtC+C,EAAP9C,EAAA,GAAe+C,EAAf/C,EAAA,GACAgD,EAAwCjD,EAAAA,SAAS6C,EAAQH,UAAlDQ,EAAPD,EAAA,GAAqBE,EAArBF,EAAA,GAmBA,OACErP,EAAA,QAAAC,cAAAD,UAAAS,SAAA,KACET,EAAA,QAAAC,cAACuP,SAAM,CAACzI,QAfY,SAAC0I,GACnBT,OAAAA,EAAsBS,IAA4B,UAAXN,IACzCC,EAAU,WACVG,EAAgBE,IACT,MAYPzP,EAAC,QAAAC,cAAA2G,EAAD1G,EAAA,CACEoH,UArBa,WACjB8H,EAAU,UAqBN/M,KAAiB,YAAX8M,EACNhI,UAVgB,WACpB8H,EAAQ/R,KAAKoS,EAAarG,YAUlB/J,GAEH1B,yCC5CwC,SAM5CJ,GAAA,IAAAsS,EAAAtS,EALHuS,OAKG1D,EAAA7O,EAJHyH,MAAAA,aAAQ,GAILoH,EAFH2D,IAAAA,WACAC,IAAAA,OAEMC,EAAmB/P,EAAE,QAAC,2BAA4B,CACtD4P,mBAFCD,EAGDK,aANFC,qBAQMC,EAAwBlQ,EAAE,QAAC,mBAAoB,CACnD8P,OAAAA,IAEF,OACE7P,EAAA,QAAAC,cAAA,MAAA,CAAKhB,UAAWgR,GACbL,GAAc5P,EAAAA,QAAAC,cAAA,MAAA,CAAKhB,UAAW6Q,IAC/B9P,EAAA,QAAAC,cAAA,MAAA,KAAM4E,kBCwBQ,SASJzH,GAAA,IAAAC,EAAAD,EARdE,GAAI4S,aAAY,OAQF7S,EAPdG,IAAAA,SACA2S,IAAAA,SACArR,IAAAA,MACAsR,IAAAA,WACAC,IAAAA,WACApR,IAAAA,UACGC,EACWC,EAAA/B,EAAAgC,GACRnC,EAAU,GAEhBkT,GAAYlT,EAAQC,KAARD,MAAAA,EAAgBL,EAAe,iBAAkBuT,IAC7DC,GAAcnT,EAAQC,KAARD,MAAAA,EAAgBL,EAAe,mBAAoBwT,IACjEC,GAAcpT,EAAQC,KAAK,mBAAqBmT,GAEhD,IAAMvQ,EAAYC,EAAAA,QAAG9C,EAASgC,GAE9B,OACEe,wBAAC7C,EAAD+C,EAAA,CAAK5C,GAAI4S,EAAWpR,MAAOA,EAAOG,UAAWa,GAAeZ,GACzD1B,qBCjEoC,SAAAJ,GACzCI,IAAAA,IAAAA,SACAyB,IAAAA,UACGC,EAHsCC,EAAA/B,EAAAgC,GAAA,OAKzCY,UAACC,cAAAqQ,EAADA,OAAApQ,EAAA,CAAQwK,QAAQ,WAAcxL,EAA9B,CAAoCD,UAAWc,EAAAA,QAAG,eAAgBd,KAC/DzB,qBvBesC,SAQtCJ,GAPH6B,IACAmI,IAAAA,SACAmJ,IAAAA,SACAC,IAAAA,iBACAC,IAAAA,iBACArO,IAAAA,SACA+B,IAAAA,SAEMuM,EAAmB3Q,EAAE,QAAC,CAAC,kCAR7Bd,YASwBmN,EAAAA,EAAQA,UAAC,GAApBuE,EAAbtE,EAAA,GAEA,OACErM,EAAA,QAAAC,cAAA,MAAA,CAAKqN,GAAG,iBACNtN,EAAA,QAAAC,cAAC8B,EACC,CAAAM,KALNgK,EAAA,GAMM/J,aAAcqO,EACd1R,UAAWyR,EACXtO,SAAUA,GAEVpC,EAAK,QAAAC,cAAA,MAAA,CAAAqN,GAAG,qBACNtN,EAAA,QAAAC,cAACyD,EAAsB,CACrBN,QAAS,WACPqN,IACAE,GAAQ,IAEV1R,UAAU,2BAEVe,EAAA,QAAAC,cAAA,OAAA,CAAA,eAAA,GACED,EAAC,QAAAC,cAAA2Q,eAAY3J,KAAK,OAAO1D,aAE1B6D,EAASyJ,oBAEE,OAAb1M,EACCnE,EAAAA,QAACC,cAAAyD,EACC,CAAAN,QAAS,WACPoN,EAAiB,MACjBG,GAAQ,IAEV1R,UAAU,2BAEVe,EAAkB,QAAAC,cAAA,OAAA,CAAA,eAAA,EAAAhB,UAAU,kCAC1Be,EAAC,QAAAC,cAAA6Q,cAAW7J,KAAK,OAAO1D,aAEzB6D,EAAS2J,gBAGZ/Q,EAAA,QAAAC,cAACyD,EAAsB,CACrBN,QAAS,WACPoN,EAAiB,MACjBG,GAAQ,IAEV1R,UAAU,2BAEVe,EAAkB,QAAAC,cAAA,OAAA,CAAA,eAAA,EAAAhB,UAAU,kCAC1Be,EAAC,QAAAC,cAAA+Q,UAAO/J,KAAK,OAAO1D,aAErB6D,EAAS2J,gBAGd/Q,EAAA,QAAAC,cAACyD,EAAsB,CACrBN,QAAS,WACPmN,IACAI,GAAQ,IAEE,cAAA,mBACZ1R,UAAU,2BAEVe,EAAA,QAAAC,cAAA,OAAA,CAAA,eAAA,GACED,EAAA,QAAAC,cAACgR,aACC,CAAAhK,KAAK,OACL1D,QAAM,EACN2N,MAAO,CAAEC,UAAW,oBAGvB/J,EAASgK,8DwBjGhB,SACJC,EACAlP,EACAyB,QAAqC,IAArCA,IAAAA,EAA+BvC,QAEzBiQ,IAAAA,EAAe7O,EAAAA,SAErBE,EAAAA,WAAU,WACR2O,EAAavO,QAAUZ,IACtB,CAACA,IAEJQ,EAAAA,WAAU,WAEJ,GADgBiB,GAAWA,EAAQX,iBACnC,CAEJ,IAAMsO,EAAiB,SAAC1O,GACtByO,OADqB,MACrBA,EAAavO,aADQ,EACrBuO,EAAavO,QAAUF,IAIzB,OAFAe,EAAQX,iBAAiBoO,EAAWE,GAE7B,WACL3N,EAAQV,oBAAoBmO,EAAWE,OAExC,CAACF,EAAWzN"}
1
+ {"version":3,"file":"common.cjs.production.min.js","sources":["../src/Box.tsx","../src/environment.ts","../src/Stack.tsx","../src/FeatureToggle.tsx","../src/EnturPartnerLogo.tsx","../src/UserMenu.tsx","../src/LanguageSelect.tsx","../src/ErrorBoundary.tsx","../src/helpers.ts","../src/FormatDateTime.tsx","../src/ConfirmModal.tsx","../src/PermissionCheck.tsx","../src/ActionBar.tsx","../src/AuditInfo.tsx","../src/Breadcrumbs.tsx","../src/Content.tsx","../src/ExpandableMultiLanguageInput.tsx","../src/FormatCurrencyAmount.tsx","../src/Link.tsx","../src/LinkButton.tsx","../src/Menu.tsx","../src/MultiLanguageInput.tsx","../src/OrganisationDropdown.tsx","../src/Pager.tsx","../src/PermissionCheckedRoute.tsx","../src/RouteLeavingGuard.tsx","../src/StatusLabel.tsx","../src/Text.tsx","../src/Unbutton.tsx","../src/useEventListener.ts"],"sourcesContent":["import './Box.scss';\n\nimport React, { ReactNode } from 'react';\nimport cx from 'classnames';\n\ntype StyleSpacing =\n | 'none'\n | 'extraSmall2'\n | 'extraSmall'\n | 'small'\n | 'medium'\n | 'large'\n | 'extraLarge'\n | 'extraLarge2'\n | 'extraLarge3'\n | 'extraLarge4'\n | 'extraLarge5'\n | 'extraLarge6'\n | 'extraLarge7'\n | 'extraLarge8'\n | 'extraLarge9';\n\ntype StyleMargin = StyleSpacing | 'auto';\n\ntype StyleDisplay = 'block' | 'flex' | 'inline' | 'inline-block';\ntype StyleJustifyContent = 'center' | 'space-between' | 'start' | 'end';\ntype StyleAlignItems = 'center' | 'start' | 'end' | 'stretch' | 'baseline';\n\ntype StyleMaxWidth =\n | 'none'\n | 'extraSmall'\n | 'small'\n | 'medium'\n | 'large'\n | 'extraLarge'\n | 'extraLarge2'\n | 'extraLarge3'\n | 'extraLarge4'\n | 'extraLarge5'\n | 'extraLarge6'\n | 'full';\ntype StyleWidth = 'auto' | 'full';\n\nexport type StyleBackground = 'blue' | 'lavender' | 'white' | 'blue70';\nexport type StyleColor = 'blue' | 'lavender' | 'white' | 'black';\n\ntype StyleFlexDirection = 'row' | 'column' | 'row-reverse' | 'column-reverse';\ntype StyleFlexWrap = 'wrap' | 'nowrap' | 'wrap-reverse';\n\nexport type ResponsiveStyleSpacing =\n | StyleSpacing\n | [StyleSpacing?, StyleSpacing?, StyleSpacing?];\nexport type ResponsiveStyleMargin =\n | StyleMargin\n | [StyleMargin?, StyleMargin?, StyleMargin?];\n\nexport type ResponsiveStyleDisplay =\n | StyleDisplay\n | [StyleDisplay?, StyleDisplay?, StyleDisplay?];\nexport type ResponsiveStyleJustifyContent =\n | StyleJustifyContent\n | [StyleJustifyContent?, StyleJustifyContent?, StyleJustifyContent?];\nexport type ResponsiveStyleAlignItems =\n | StyleAlignItems\n | [StyleAlignItems?, StyleAlignItems?, StyleAlignItems?];\n\nexport type ResponsiveStyleMaxWidth =\n | StyleMaxWidth\n | [StyleMaxWidth?, StyleMaxWidth?, StyleMaxWidth?];\nexport type ResponsiveStyleWidth =\n | StyleWidth\n | [StyleWidth?, StyleWidth?, StyleWidth?];\n\nexport type ResponsiveStyleFlexDirection =\n | StyleFlexDirection\n | [StyleFlexDirection?, StyleFlexDirection?, StyleFlexDirection?];\nexport type ResponsiveStyleFlexWrap =\n | StyleFlexWrap\n | [StyleFlexWrap?, StyleFlexWrap?, StyleFlexWrap?];\n\nexport interface BoxProps {\n className?: string;\n as?: React.ElementType;\n [key: string]: any;\n children: ReactNode;\n\n contrast?: boolean;\n\n paddingTop?: ResponsiveStyleSpacing;\n paddingRight?: ResponsiveStyleSpacing;\n paddingBottom?: ResponsiveStyleSpacing;\n paddingLeft?: ResponsiveStyleSpacing;\n paddingX?: ResponsiveStyleSpacing;\n paddingY?: ResponsiveStyleSpacing;\n padding?: ResponsiveStyleSpacing;\n\n marginTop?: ResponsiveStyleMargin;\n marginRight?: ResponsiveStyleMargin;\n marginBottom?: ResponsiveStyleMargin;\n marginLeft?: ResponsiveStyleMargin;\n marginX?: ResponsiveStyleMargin;\n marginY?: ResponsiveStyleMargin;\n margin?: ResponsiveStyleMargin;\n\n display?: ResponsiveStyleDisplay;\n justifyContent?: ResponsiveStyleJustifyContent;\n alignItems?: ResponsiveStyleAlignItems;\n\n maxWidth?: ResponsiveStyleMaxWidth;\n width?: ResponsiveStyleWidth;\n background?: StyleBackground;\n color?: StyleColor;\n\n flexDirection?: ResponsiveStyleFlexDirection;\n flexWrap?: ResponsiveStyleFlexWrap;\n}\n\ntype ResponsiveProp = string | [string?, string?, string?];\n\nexport function responsiveProp(prefix: string, prop: ResponsiveProp): string[] {\n if (Array.isArray(prop)) {\n const classes = [];\n prop[0] && classes.push(prefix + prop[0]);\n prop[1] && classes.push(`${prefix}${prop[1]}-lg`);\n prop[2] && classes.push(`${prefix}${prop[2]}-xl`);\n return classes;\n }\n return [prefix + prop];\n}\n\nexport const Box = ({\n as: Component = 'div',\n children,\n contrast,\n paddingTop,\n paddingRight,\n paddingBottom,\n paddingLeft,\n paddingX,\n paddingY,\n padding,\n marginTop,\n marginRight,\n marginBottom,\n marginLeft,\n marginX,\n marginY,\n margin,\n display,\n justifyContent,\n alignItems,\n maxWidth,\n width,\n background,\n color,\n flexDirection,\n flexWrap,\n className,\n ...rest\n}: BoxProps) => {\n const classes = [];\n const resolvedPaddingTop = paddingTop || paddingY || padding;\n const resolvedPaddingBottom = paddingBottom || paddingY || padding;\n const resolvedPaddingLeft = paddingLeft || paddingX || padding;\n const resolvedPaddingRight = paddingRight || paddingX || padding;\n\n const resolvedMarginTop = marginTop || marginY || margin;\n const resolvedMarginBottom = marginBottom || marginY || margin;\n const resolvedMarginLeft = marginLeft || marginX || margin;\n const resolvedMarginRight = marginRight || marginX || margin;\n\n contrast && classes.push('eds-contrast');\n resolvedPaddingTop &&\n classes.push(...responsiveProp('eps-pt-', resolvedPaddingTop));\n resolvedPaddingBottom &&\n classes.push(...responsiveProp('eps-pb-', resolvedPaddingBottom));\n resolvedPaddingLeft &&\n classes.push(...responsiveProp('eps-pl-', resolvedPaddingLeft));\n resolvedPaddingRight &&\n classes.push(...responsiveProp('eps-pr-', resolvedPaddingRight));\n resolvedMarginTop &&\n classes.push(...responsiveProp('eps-mt-', resolvedMarginTop));\n resolvedMarginBottom &&\n classes.push(...responsiveProp('eps-mb-', resolvedMarginBottom));\n resolvedMarginLeft &&\n classes.push(...responsiveProp('eps-ml-', resolvedMarginLeft));\n resolvedMarginRight &&\n classes.push(...responsiveProp('eps-mr-', resolvedMarginRight));\n\n display && classes.push(...responsiveProp('eps-', display));\n justifyContent &&\n classes.push(...responsiveProp('eps-justify-', justifyContent));\n if (alignItems) {\n classes.push(...responsiveProp('eps-items-', alignItems));\n }\n\n maxWidth && classes.push(...responsiveProp('eps-max-w-', maxWidth));\n width && classes.push(...responsiveProp('eps-w-', width));\n\n color && classes.push(`eps-color-${color}`);\n background && classes.push(`eps-bg-${background}`);\n\n flexDirection && classes.push(...responsiveProp('eps-flex-', flexDirection));\n flexWrap && classes.push(...responsiveProp('eps-flex-wrap-', flexWrap));\n\n const classList = cx(classes, className);\n\n return (\n <Component className={classList} {...rest}>\n {children}\n </Component>\n );\n};\n","export enum Environment {\n Local = 'local',\n Development = 'dev',\n Staging = 'staging',\n Production = 'prod',\n}\n\nconst environmentColors: Record<\n Exclude<Environment, Environment.Production>,\n string\n> = {\n [Environment.Local]: '#B482FB',\n [Environment.Development]: '#5AC39A',\n [Environment.Staging]: '#FFCA28',\n};\n\n/**\n * Gets the color for the given environment. This is the color used for the environment\n * indicator. There is no color for production as it should not have any special environment\n * indication.\n */\nexport const getColorForEnvironment = (\n environment: Exclude<Environment, Environment.Production>\n) => environmentColors[environment];\n\nconst humanReadableEnvironment: Record<Environment, string> = {\n [Environment.Local]: 'Local',\n [Environment.Development]: 'Dev',\n [Environment.Staging]: 'Staging',\n [Environment.Production]: 'Prod',\n};\n\nexport const getHumanReadableEnvironment = (environment: Environment) =>\n humanReadableEnvironment[environment];\n","import React, { ReactNode, Children } from 'react';\n\nimport { ResponsiveStyleSpacing, Box } from './Box';\n\nexport interface StackProps {\n className?: string;\n children: ReactNode;\n space: ResponsiveStyleSpacing;\n}\n\nexport const Stack = ({ children, space, className }: StackProps) => {\n const stackItems = Children.toArray(children);\n if (stackItems.length <= 1) {\n return <>{stackItems}</>;\n }\n\n return (\n <div className={className}>\n {stackItems.map((child, index) =>\n index === stackItems.length - 1 ? (\n <div key={index}>{child}</div>\n ) : (\n <Box paddingBottom={space} key={index}>\n {child}\n </Box>\n )\n )}\n </div>\n );\n};\n","import React, { ReactNode } from 'react';\n\n/**\n * Returns true if the provided flag exist in localStorage\n * or is set as an environment variable.\n *\n * @param flag case sensitive flag. If it is an environment variable\n * you can drop the REACT_APP_ prefix.\n */\nexport function featureFlag(flag: string): boolean {\n return (\n process.env[`REACT_APP_${flag}`] === 'true' ||\n window.localStorage?.getItem(flag) === 'true' ||\n window.localStorage?.getItem(`REACT_APP_${flag}`) === 'true'\n );\n}\n\n/**\n * Returns true if the provided flag exist in localStorage\n * or is set as an environment variable.\n *\n * @param flag case sensitive flag. If it is an environment variable\n * you can drop the REACT_APP_ prefix.\n */\nexport function useFeatureToggle(flag: string): boolean {\n return featureFlag(flag);\n}\n\nexport interface FeatureToggleProps {\n /** Visible if flag exist, hidden if not.*/\n children: ReactNode;\n /** Case sensitive flag. If it is an environment variable\n * you can drop the REACT_APP_ prefix. */\n flag: string;\n}\n\nexport const FeatureToggle = ({ children, flag }: FeatureToggleProps) => {\n const feature = useFeatureToggle(flag);\n if (feature) {\n return <>{children}</>;\n }\n return null;\n};\n","import './EnturPartnerLogo.scss';\n\nimport React, { FC } from 'react';\nimport classnames from 'classnames';\n\nimport { Environment, getColorForEnvironment } from './environment';\n\ninterface LogoProps {\n title: string;\n className?: string;\n accentColor?: string;\n [key: string]: any;\n}\n\nexport const EnturPartnerLogoSvg: FC<LogoProps> = ({\n title,\n accentColor = '#FF5959',\n ...rest\n}) => {\n return (\n <svg width={257} height={37} viewBox=\"0 0 257 37\" {...rest}>\n <title>{title}</title>\n <g fill=\"none\" fillRule=\"evenodd\">\n <path\n fill=\"#FFF\"\n d=\"M0 .231V25.72h18.745v-4.318H4.869v-6.163h12.31v-4.318H4.87V4.55h13.876V.231z\"\n />\n <path fill={accentColor} d=\"M0 36.408h45.253v-4.32H0z\" />\n <path\n fill=\"#FFF\"\n d=\"M40.384.231v15.425L23.656.231h-.521V25.72h4.869V10.573L44.732 25.72h.521V.23zM69.25 15.238h-7.267v21.17h-4.87v-21.17H49.81V10.92h19.44zM83.863 36.86c-1.646 0-3.142-.255-4.486-.765-1.345-.51-2.493-1.23-3.443-2.159-.95-.928-1.687-2.054-2.208-3.378-.522-1.323-.783-2.797-.783-4.422V10.92h4.869v15.216c0 1.277.209 2.333.626 3.169.417.836.933 1.497 1.548 1.985a5.346 5.346 0 001.982 1.01c.707.186 1.339.278 1.895.278.557 0 1.188-.092 1.896-.279a5.35 5.35 0 001.982-1.01c.614-.487 1.13-1.148 1.548-1.984.417-.836.625-1.892.625-3.169V10.92h4.87v15.216c0 1.625-.256 3.1-.766 4.422-.51 1.324-1.24 2.45-2.19 3.378-.952.929-2.1 1.648-3.444 2.159-1.344.51-2.851.766-4.52.766M104.21 24.047h5.546c1.016 0 1.854-.127 2.513-.383.658-.255 1.179-.592 1.56-1.01.381-.418.641-.888.78-1.41.138-.522.208-1.05.208-1.584 0-.627-.099-1.207-.295-1.741a3.718 3.718 0 00-.901-1.393c-.405-.394-.924-.708-1.56-.94-.636-.232-1.404-.348-2.305-.348h-5.546v8.81zm0 4.248v8.113h-4.87V10.92h11.567c1.3 0 2.49.215 3.57.644 1.08.43 2.004 1.033 2.77 1.81a8.287 8.287 0 011.794 2.787c.43 1.079.645 2.257.645 3.534 0 .952-.128 1.874-.383 2.768-.256.894-.61 1.7-1.063 2.42a7.32 7.32 0 01-1.672 1.863 5.929 5.929 0 01-2.178 1.096l6.339 8.566h-5.808l-5.893-8.113h-4.818z\"\n />\n <g fill={accentColor}>\n <path d=\"M141.051 23.448h5.628c4.185 0 5.989-1.984 5.989-4.942 0-2.742-1.515-4.618-5.989-4.618h-5.628v9.56zm0 3.067v9.776h-3.571V10.75h9.632c6.674 0 9.127 3.211 9.127 7.54 0 4.979-3.102 8.226-9.2 8.226h-5.988zM169.695 28.715c-1.371-.288-2.958-.505-4.401-.505-2.85 0-4.041 1.263-4.041 3.139s1.407 2.706 3.463 2.706c2.49 0 4.979-1.443 4.979-4.221v-1.119zm-4.293-2.958c1.551 0 3.174.253 4.293.469v-.83c0-2.525-1.154-3.896-4.33-3.896-2.164 0-3.824.866-4.942 2.092l-2.02-2.272c1.732-1.66 3.644-2.598 7.07-2.598 5.052 0 7.469 1.876 7.469 7.215v10.354h-3.211V34.02h-.108c-1.082 1.767-3.211 2.705-5.592 2.705-3.32 0-6.241-1.66-6.241-5.303 0-3.103 1.912-5.664 7.612-5.664zM178.965 19.191h3.211v2.886h.108c.938-1.984 2.922-3.355 5.231-3.355.47 0 .938.036 1.335.144l-.144 3.14a6.77 6.77 0 00-1.552-.181c-3.246 0-4.798 2.633-4.798 5.483v8.983h-3.39v-17.1zM199.961 36.291h-1.912c-4.004 0-5.988-.938-5.988-5.772v-8.55h-2.778V19.19h2.778v-4.654h3.355v4.654h4.473v2.778h-4.473v7.973c0 3.427 1.587 3.535 3.319 3.535h1.226v2.814zM219.767 36.291h-3.391V26.84c0-2.778-1.083-5.375-4.257-5.375-3.14 0-5.268 2.597-5.268 6.169v8.658h-3.391v-17.1h3.32v2.814h.143c.794-1.623 3.067-3.283 5.99-3.283 4.941 0 6.854 3.644 6.854 8.081v9.488zM227.847 26.262h10.57c0-2.597-2.272-4.726-5.087-4.726-2.922 0-5.014 1.948-5.483 4.726zm-.036 2.453c.397 3.355 2.633 5.195 5.844 5.195 2.778 0 4.618-1.623 5.484-2.67l2.164 1.804c-1.37 1.913-4.365 3.716-8.045 3.716-4.942 0-8.73-3.535-8.73-8.55 0-5.195 3.752-9.488 8.983-9.488 5.303 0 8.009 4.365 8.009 8.19 0 .649-.036 1.226-.072 1.803H227.81zM246.245 19.191h3.21v2.886h.109c.938-1.984 2.922-3.355 5.231-3.355.469 0 .938.036 1.335.144l-.145 3.14a6.77 6.77 0 00-1.551-.181c-3.247 0-4.798 2.633-4.798 5.483v8.983h-3.391v-17.1z\" />\n </g>\n </g>\n </svg>\n );\n};\n\ninterface EnturPartnerLogoProps {\n altText: string;\n as?: 'div' | React.ElementType;\n className?: string;\n environment?: Environment;\n}\n\nexport const EnturPartnerLogo: FC<EnturPartnerLogoProps> = ({\n as: Component = 'nav',\n className,\n altText,\n environment,\n}) => {\n const classList = classnames(['eps-logo-wrapper', className]);\n\n return (\n <Component className={classList}>\n <EnturPartnerLogoSvg\n title={altText}\n className=\"logo\"\n accentColor={\n environment !== undefined && environment !== Environment.Production\n ? getColorForEnvironment(environment)\n : undefined\n }\n />\n </Component>\n );\n};\n","import './UserMenu.scss';\n\nimport React, { FC, useState } from 'react';\nimport cx from 'classnames';\nimport {\n DownArrowIcon,\n NorwayIcon,\n UKIcon,\n UploadIcon,\n UserIcon,\n} from '@entur/icons';\nimport { SecondaryButton } from '@entur/button';\nimport { Heading6 } from '@entur/typography';\n\nimport {\n Environment,\n getColorForEnvironment,\n getHumanReadableEnvironment,\n} from './environment';\n\ninterface UserMenuProps {\n userName: string;\n messages: {\n logout: string;\n switchLanguage: string;\n };\n onLogout: () => void;\n onLanguageChange: (language: string) => void;\n language: string;\n className?: string;\n environment?: Environment;\n}\n\nexport const UserMenu: FC<UserMenuProps> = ({\n className,\n messages,\n onLogout,\n onLanguageChange,\n userName,\n language,\n environment,\n}) => {\n const triggerClassList = cx(['eps-user-menu__trigger-button', className]);\n const [open, setOpen] = useState(false);\n\n return (\n <div id=\"eps-user-menu\">\n <CustomOverflowMenu\n open={open}\n onOpenChange={setOpen}\n className={triggerClassList}\n userName={userName}\n environment={environment}\n >\n <div id=\"eps-overflow-menu\">\n {language === 'en' ? (\n <CustomOverflowMenuItem\n onClick={() => {\n onLanguageChange('nb');\n setOpen(false);\n }}\n className=\"eps-overflow-menu__item\"\n >\n <span aria-hidden className=\"eps-overflow-menu__icon-margin\">\n <NorwayIcon size=\"1rem\" inline />\n </span>\n {messages.switchLanguage}\n </CustomOverflowMenuItem>\n ) : (\n <CustomOverflowMenuItem\n onClick={() => {\n onLanguageChange('en');\n setOpen(false);\n }}\n className=\"eps-overflow-menu__item\"\n >\n <span aria-hidden className=\"eps-overflow-menu__icon-margin\">\n <UKIcon size=\"1rem\" inline />\n </span>\n {messages.switchLanguage}\n </CustomOverflowMenuItem>\n )}\n <CustomOverflowMenuItem\n onClick={() => {\n onLogout();\n setOpen(false);\n }}\n data-testid=\"user-menu-logout\"\n className=\"eps-overflow-menu__item\"\n >\n <span aria-hidden>\n <UploadIcon\n size=\"1rem\"\n inline\n style={{ transform: 'rotate(90deg)' }}\n />\n </span>\n {messages.logout}\n </CustomOverflowMenuItem>\n </div>\n </CustomOverflowMenu>\n </div>\n );\n};\n\nconst CustomOverflowMenu: React.FC<{\n className?: string;\n children: React.ReactNode;\n userName: string;\n open: boolean;\n onOpenChange: (open: boolean) => void;\n environment?: Environment;\n}> = ({\n className,\n children,\n userName,\n open,\n onOpenChange,\n environment,\n ...rest\n}) => {\n const overflowItemsClasses = cx('eps-overflow-menu__group', {\n 'eps-overflow-menu__group--open': open,\n });\n const overflowContentRef = React.useRef<HTMLDivElement>(null);\n const overflowMenuTriggerRef = React.useRef<HTMLButtonElement>(null);\n useOutsideClick(overflowContentRef, overflowMenuTriggerRef, () =>\n onOpenChange(false)\n );\n return (\n <div>\n <SecondaryButton\n className={cx('eps-overflow-menu__button', className)}\n onClick={() => onOpenChange(open ? false : true)}\n aria-haspopup={true}\n role=\"button\"\n aria-expanded={open}\n ref={overflowMenuTriggerRef}\n {...rest}\n >\n <div className=\"eps-overflow-menu__button-contents\">\n <span className=\"eds-overflow-menu__user-icon\">\n <UserIcon inline />\n </span>\n <Heading6 margin=\"none\" as=\"span\">\n {userName}\n {environment !== undefined &&\n environment !== Environment.Production && (\n <span style={{ color: getColorForEnvironment(environment) }}>\n {' '}\n ({getHumanReadableEnvironment(environment)})\n </span>\n )}\n </Heading6>\n <span className=\"eps-arrow-icon\">\n <DownArrowIcon inline />\n </span>\n </div>\n </SecondaryButton>\n {open && (\n <div\n className={overflowItemsClasses}\n role=\"menu\"\n ref={overflowContentRef}\n >\n {children}\n </div>\n )}\n </div>\n );\n};\n\nconst CustomOverflowMenuItem: React.FC<\n React.DetailedHTMLProps<\n React.ButtonHTMLAttributes<HTMLButtonElement>,\n HTMLButtonElement\n >\n> = (props) => {\n return (\n <button\n className={cx(props.className, 'eps-overflow-menu__item')}\n role=\"menuitem\"\n {...props}\n />\n );\n};\n\nfunction elementContainsEventTarget(element: HTMLElement | null, event: Event) {\n if (!element) {\n return false;\n }\n\n if (element.contains(event.target as Node)) {\n return true;\n }\n\n // For elements inside a Shadow DOM we need to check the composedPath\n if (event.composed && event.composedPath) {\n const contains = event.composedPath().find((target) => {\n if (target === window) {\n return false;\n }\n return element.contains(target as Node);\n });\n return contains ? true : false;\n }\n\n return false;\n}\n\nfunction useOutsideClick(\n ref: React.RefObject<HTMLDivElement>,\n buttonRef: React.RefObject<HTMLButtonElement>,\n handler: () => void\n) {\n React.useEffect(() => {\n const listener = (event: Event) => {\n if (\n elementContainsEventTarget(ref.current, event) ||\n elementContainsEventTarget(buttonRef.current, event)\n ) {\n return;\n }\n\n handler();\n };\n\n document.addEventListener('mousedown', listener);\n document.addEventListener('touchstart', listener);\n\n return () => {\n document.removeEventListener('mousedown', listener);\n document.removeEventListener('touchstart', listener);\n };\n }, [ref, buttonRef, handler]);\n}\n","import './LanguageSelect.scss';\n\nimport React, { FC } from 'react';\nimport { SegmentedControl, SegmentedChoice } from '@entur/form';\nimport cx from 'classnames';\nimport { assertIsDefined } from '@entur-partner/util';\n\nexport type LanguageKey = 'nob' | 'nno' | 'eng';\n\nexport interface LanguageOption {\n value: LanguageKey;\n label: string;\n required: boolean;\n}\n\nexport interface LanguageSelectProps {\n language: string;\n options: LanguageOption[];\n className?: string;\n onChange: (language: string) => void;\n [key: string]: any;\n}\n\nexport const LanguageSelect: FC<LanguageSelectProps> = ({\n language,\n options,\n className,\n onChange,\n ...rest\n}) => {\n const classNames = cx('eps-language-select', className);\n return (\n <div {...rest} className={classNames}>\n <SegmentedControl\n onChange={(language) => {\n assertIsDefined(language);\n onChange(language);\n }}\n selectedValue={language}\n >\n {options.map((option) => (\n <SegmentedChoice key={option.value} value={option.value}>\n {option.label}\n {option.required && <span className=\"asterisk-margin\">{'*'}</span>}\n </SegmentedChoice>\n ))}\n </SegmentedControl>\n </div>\n );\n};\n","import { ReactNode, Component, ErrorInfo } from 'react';\n\nimport { isFunction } from './helpers';\n\ntype FallbackOptions = {\n retry: () => void;\n error: Error;\n};\n\ntype RenderProp = (options: FallbackOptions) => ReactNode;\n\ntype Props = {\n handleError?: (error: Error, errorInfo: ErrorInfo) => void;\n fallback: ReactNode | RenderProp;\n children: ReactNode;\n};\n\ntype State = {\n error: null | Error;\n};\n\nexport class ErrorBoundary extends Component<Props, State> {\n constructor(props: Props) {\n super(props);\n this.state = { error: null };\n }\n\n static getDerivedStateFromError(error: Error): State {\n return {\n error,\n };\n }\n\n componentDidCatch(error: Error, errorInfo: ErrorInfo) {\n // React always logs in development\n this.props.handleError?.(error, errorInfo);\n }\n\n render() {\n const { error } = this.state;\n const { fallback, children } = this.props;\n\n if (error) {\n if (isFunction<RenderProp>(fallback)) {\n return fallback({ retry: () => this.setState({ error: null }), error });\n }\n return fallback;\n }\n\n return children;\n }\n}\n","export function isFunction<T>(functionToCheck: any): functionToCheck is T {\n return (\n functionToCheck && {}.toString.call(functionToCheck) === '[object Function]'\n );\n}\n","import React, { FC } from 'react';\nimport { localeDate, localeDateTime } from '@entur-partner/util';\n\nexport interface FormatDateTimeProps {\n date: string | Date;\n locale: string;\n [key: string]: any;\n}\n\nexport const FormatDateTime: FC<FormatDateTimeProps> = ({\n date,\n locale,\n as: Component = 'main',\n hideTime,\n ...rest\n}) => {\n return (\n <Component {...rest}>\n {hideTime ? localeDate(date, locale) : localeDateTime(date, locale)}\n </Component>\n );\n};\n","import './ConfirmModal.scss';\n\nimport React, { ReactNode, FC } from 'react';\nimport { Modal, ModalProps } from '@entur/modal';\nimport { Paragraph } from '@entur/typography';\nimport { isString } from '@entur-partner/util';\nimport { ButtonGroup, SecondaryButton, PrimaryButton } from '@entur/button';\n\nimport { Box } from './Box';\n\nexport interface BaseConfirmModalProps extends Partial<ModalProps> {\n title: string;\n children: React.ReactNode;\n closeLabel: string;\n\n /** Deprecated use children prop */\n message?: ReactNode;\n /** Deprecated use open prop */\n isOpen?: boolean;\n /** Deprecated use onDismiss prop */\n onClose?: () => void;\n}\n\ninterface CustomConfirmModalButtons extends BaseConfirmModalProps {\n buttons: ReactNode[];\n}\n\ninterface DefaultConfirmModalHandler extends BaseConfirmModalProps {\n onConfirm: () => void;\n messages: {\n confirm: string;\n cancel: string;\n };\n}\n\nexport type ConfirmModalProps =\n | CustomConfirmModalButtons\n | DefaultConfirmModalHandler;\n\nexport const ConfirmModal: FC<ConfirmModalProps> = ({\n isOpen = false,\n children,\n message,\n size = 'medium',\n buttons,\n onConfirm,\n messages,\n onClose,\n onDismiss,\n ...rest\n}) => {\n const childrenToRender = children ? children : message;\n const handleDismiss = onClose ? onClose : onDismiss;\n return (\n <Modal size={size} open={isOpen} onDismiss={handleDismiss} {...rest}>\n {isString(childrenToRender) ? (\n <Paragraph>{childrenToRender}</Paragraph>\n ) : (\n <Box paddingBottom=\"medium\">{childrenToRender}</Box>\n )}\n\n <ButtonGroup>\n {onConfirm ? (\n <>\n <SecondaryButton\n onClick={handleDismiss}\n data-testid=\"cancel-modal-button\"\n >\n {messages.cancel}\n </SecondaryButton>\n <PrimaryButton\n onClick={onConfirm}\n data-testid=\"confirm-modal-button\"\n >\n {messages.confirm}\n </PrimaryButton>\n </>\n ) : (\n buttons\n )}\n </ButtonGroup>\n </Modal>\n );\n};\n","import React, { ReactNode, FC } from 'react';\nimport { BusinessCapability } from '@entur-partner/permission-client-node';\nimport { hasAllPermissions, hasOneOfPermissions } from '@entur-partner/util';\n\n/**\n * Note: We use BusinessCapability here, not because we only want to check\n * BusinessCapabilities but because it represents a minimal subset of what we\n * need to check.\n */\nexport interface PermissionCheckProps {\n children: ReactNode;\n /** User permissions to check */\n permissions: BusinessCapability[];\n /** Check that at least one of the permissions is present */\n oneOf?: BusinessCapability[];\n /** Check that all of the permissions is present */\n all?: BusinessCapability[] | BusinessCapability;\n /** Rendered if check fails. Defaults to null */\n fallback?: ReactNode;\n}\n\n/**\n * Note: This component uses BusinessCapability, not because we only want to\n * check BusinessCapabilities but because it represents a minimal subset of\n * what we need to check.\n */\nexport const PermissionCheck: FC<PermissionCheckProps> = ({\n children,\n fallback = null,\n permissions,\n oneOf = [],\n all = [],\n}) => {\n const allIsAllowed = hasAllPermissions(all, permissions);\n\n const oneOfIsAllowed = hasOneOfPermissions(oneOf, permissions);\n\n const allowed = allIsAllowed && oneOfIsAllowed;\n return <>{allowed ? children : fallback}</>;\n};\n","import './ActionBar.scss';\nimport React, { ReactNode } from 'react';\n\nexport interface ActionBarProps {\n children: ReactNode;\n}\n\nconst ActionBarLeft = ({ children }: ActionBarProps) => {\n return <div className=\"eps-action-bar-left\">{children}</div>;\n};\n\nconst ActionBarRight = ({ children }: ActionBarProps) => {\n return <div className=\"eps-action-bar-right\">{children}</div>;\n};\n\nconst ActionBar = ({ children }: ActionBarProps) => {\n return (\n <>\n <div className=\"eps-action-bar-padding\" />\n <div className=\"eps-action-bar\">{children}</div>\n </>\n );\n};\n\nexport { ActionBar, ActionBarLeft, ActionBarRight };\n","import './AuditInfo.scss';\n\nimport React, { FC } from 'react';\nimport cx from 'classnames';\nimport { isDateString, isDate } from '@entur-partner/util';\n\nimport { FormatDateTime } from './FormatDateTime';\nimport { Stack } from './Stack';\n\ninterface Item {\n label: string;\n value: Date | string;\n}\n\nexport interface AuditInfoProps {\n items: Item[];\n locale: string;\n className?: string;\n [key: string]: any;\n}\n\nexport const AuditInfo: FC<AuditInfoProps> = ({\n items,\n locale,\n className,\n ...rest\n}) => {\n const classNames = cx('ep-audit-info', className);\n return (\n <div className={classNames} {...rest}>\n {items.map(({ label, value }, i) => (\n <Stack space=\"small\" key={i}>\n <div className=\"ep-audit-info-label\">{label}</div>\n <div>\n {isDate(value) || isDateString(value) ? (\n <FormatDateTime date={value} locale={locale} />\n ) : (\n <span>{value}</span>\n )}\n </div>\n </Stack>\n ))}\n </div>\n );\n};\n","import './Breadcrumbs.scss';\nimport React, { FC, ReactElement } from 'react';\nimport { Link } from 'react-router-dom';\nimport { BreadcrumbNavigation, BreadcrumbItem } from '@entur/menu';\n\nexport interface BreadcrumbsProps {\n pathname: string;\n onBreadcrumbLookup: (path: string) => string | undefined;\n prependBreadcrumbItem?: ReactElement;\n}\n\nexport const Breadcrumbs: FC<BreadcrumbsProps> = ({\n prependBreadcrumbItem,\n pathname,\n onBreadcrumbLookup,\n}) => {\n const paths: string[] = pathname === '/' ? [] : ['/'];\n\n // support paths with and without trailing slash, except root\n const adjustedPathname =\n pathname.length > 1 ? pathname.replace(/\\/$/, '') : pathname;\n\n adjustedPathname.split('/').reduce((prev, curr) => {\n const path = `${prev}/${curr}`;\n paths.push(path);\n return path;\n });\n\n const breadcrumbs = paths\n .map((path) => ({ title: onBreadcrumbLookup(path), path }))\n .filter(({ title }) => title !== undefined);\n\n const breadcrumbElements = breadcrumbs.map(({ title, path }, i) => {\n const isLast = i === breadcrumbs.length - 1;\n if (isLast) {\n return (\n <BreadcrumbItem key={path} as={'span'}>\n {title}\n </BreadcrumbItem>\n );\n }\n return (\n <BreadcrumbItem key={path} as={Link} to={path}>\n {title}\n </BreadcrumbItem>\n );\n });\n\n if (prependBreadcrumbItem) {\n return (\n <BreadcrumbNavigation>\n {[prependBreadcrumbItem, ...breadcrumbElements]}\n </BreadcrumbNavigation>\n );\n }\n\n return <BreadcrumbNavigation>{breadcrumbElements}</BreadcrumbNavigation>;\n};\n","import './Content.scss';\n\nimport React, { FC, ReactNode } from 'react';\nimport classnames from 'classnames';\n\ninterface ContentProps {\n children: ReactNode;\n as?: 'main' | React.ElementType;\n className?: string;\n}\nexport const Content: FC<ContentProps> = ({\n as: Component = 'main',\n className,\n children,\n}) => {\n const classList = classnames(['eps-content', className]);\n\n return <Component className={classList}>{children}</Component>;\n};\n","import React, { ChangeEvent } from 'react';\nimport { VariantType } from '@entur/form';\nimport { ExpandablePanel } from '@entur/expand';\n\nimport { LanguageKey, LanguageOption } from './LanguageSelect';\nimport { Stack } from './Stack';\n\nexport type MultiLanguageValues = Record<LanguageKey, string>;\n\ntype ExpandableMultiLanguageInputProps = {\n title: string;\n inputComponent: React.ElementType;\n languages: LanguageOption[];\n values: MultiLanguageValues;\n onChange: (values: MultiLanguageValues) => void;\n name: string;\n variant?: (lang: LanguageKey) => VariantType;\n feedback?: (lang: LanguageKey) => string;\n [key: string]: any;\n};\n\nexport const ExpandableMultiLanguageInput = ({\n title,\n inputComponent: InputComponent,\n languages,\n values,\n onChange,\n name,\n variant,\n feedback,\n ...rest\n}: ExpandableMultiLanguageInputProps) => {\n const handleOnChange = (language: LanguageKey, value?: string) => {\n const changes = { ...values };\n if (value === '' || !value) {\n delete changes[language];\n } else {\n changes[language] = value;\n }\n onChange(changes);\n };\n\n return (\n <ExpandablePanel\n title={title}\n defaultOpen\n contentStyle={{\n padding: '4px 4px 4px 4px',\n marginTop: '16px',\n marginBottom: '16px',\n }}\n >\n <Stack space=\"medium\">\n {languages.map(({ value: langKey, label, required }) => (\n <InputComponent\n data-testid={`multi-lang-input-${name}-${langKey}`}\n key={title + langKey}\n label={required ? label + '*' : label}\n variant={variant && variant(langKey)}\n feedback={feedback && feedback(langKey)}\n name={name}\n onChange={(e: ChangeEvent<HTMLInputElement>) => {\n handleOnChange(langKey, e.target.value);\n }}\n value={values[langKey] || ''}\n {...rest}\n />\n ))}\n </Stack>\n </ExpandablePanel>\n );\n};\n","import React, { FC } from 'react';\n\nexport interface FormatCurrencyAmountProps {\n amount: number | string;\n as?: 'span' | React.ElementType;\n [key: string]: any;\n}\n\nexport const FormatCurrencyAmount: FC<FormatCurrencyAmountProps> = ({\n amount,\n as: Component = 'span',\n ...rest\n}) => {\n const parsedAmount = Number(amount) || 0;\n\n const formattedAmount = new Intl.NumberFormat('nb-NO', {\n maximumFractionDigits: 2,\n minimumFractionDigits: 2,\n }).format(parsedAmount);\n\n return <Component {...rest}>{formattedAmount}</Component>;\n};\n","import React, { FC } from 'react';\nimport { Link as RouterLink, LinkProps } from 'react-router-dom';\nimport { Link as A } from '@entur/typography';\n\ninterface Props extends LinkProps {}\n\nexport const Link: FC<Props> = (props) => {\n return (\n <A {...props} as={RouterLink}>\n {props.children}\n </A>\n );\n};\n","import './LinkButton.scss';\n\nimport React, { ReactNode } from 'react';\nimport { Link } from '@entur/typography';\nimport cx from 'classnames';\n\nexport interface LinkButtonProps {\n children: ReactNode;\n className?: string;\n [key: string]: any;\n}\n\nexport const LinkButton = ({\n children,\n className,\n ...rest\n}: LinkButtonProps) => (\n <Link {...rest} as=\"button\" className={cx('eps-link-button', className)}>\n {children}\n </Link>\n);\n","import './Menu.scss';\n\nimport React, { FC, ReactNode } from 'react';\nimport classnames from 'classnames';\n\ninterface MenuProps {\n children: ReactNode;\n as?: 'div' | React.ElementType;\n className?: string;\n}\nexport const Menu: FC<MenuProps> = ({\n as: Component = 'nav',\n className,\n children,\n}) => {\n const classList = classnames(['eds-contrast', 'eps-menu', className]);\n\n return <Component className={classList}>{children}</Component>;\n};\n","import './MultiLanguageInput.scss';\n\nimport React, { FC, useState, ChangeEvent, FocusEvent } from 'react';\nimport cx from 'classnames';\nimport { VariantType } from '@entur/form';\n\nimport { Stack } from './Stack';\nimport { LanguageSelect, LanguageOption } from './LanguageSelect';\n\ntype Values = { [key: string]: string };\n\nexport interface MultiLanguageInputProps {\n className?: string;\n onBlur?: (e: FocusEvent<HTMLDivElement>) => void;\n inputComponent: React.ElementType;\n values: { [key: string]: string };\n languages: LanguageOption[];\n onChange: (values: Values) => void;\n name: string;\n alertLevel?: VariantType;\n alertLabel?: string;\n label?: string;\n defaultLanguage?: string;\n [key: string]: any;\n}\n/**\n * @deprecated use ExpandableMultiLanguageInput\n */\nexport const MultiLanguageInput: FC<MultiLanguageInputProps> = ({\n className,\n inputComponent: InputComponent,\n alertLabel,\n alertLevel,\n name,\n languages,\n values,\n onChange,\n defaultLanguage = 'nob',\n label = '',\n onBlur = () => {},\n ...rest\n}) => {\n const [language, setLanguage] = useState(defaultLanguage);\n const classNames = cx('multi-language-input', className);\n const currentValue = values[language];\n\n const handleOnBlur = (e: FocusEvent<HTMLDivElement>) => {\n e.persist();\n const currentTarget = e.currentTarget;\n setTimeout(() => {\n if (currentTarget && !currentTarget.contains(document.activeElement)) {\n onBlur(e);\n }\n }, 0);\n };\n\n const handleLanguageChange = (language: string) => {\n setLanguage(language);\n };\n\n const handleOnChange = (value?: string) => {\n const changes = Object.assign({}, values);\n if (value === '' || !value) {\n delete changes[language];\n } else {\n changes[language] = value;\n }\n onChange(changes);\n };\n\n return (\n <div\n className={classNames}\n tabIndex={0}\n onBlur={handleOnBlur}\n data-testid={`multi-lang-input-${name}`}\n >\n <Stack space=\"extraSmall\">\n <LanguageSelect\n language={language}\n options={languages}\n onChange={(lang) => handleLanguageChange(lang)}\n />\n <InputComponent\n label={label}\n variant={alertLevel}\n feedback={alertLabel}\n name={name}\n className=\"language-item\"\n onChange={(e: ChangeEvent<HTMLInputElement>) =>\n handleOnChange(e.target.value)\n }\n value={currentValue || ''}\n {...rest}\n />\n </Stack>\n </div>\n );\n};\n","import React, { FC } from 'react';\nimport { Dropdown } from '@entur/dropdown';\n\ninterface Organisation {\n name: string;\n id: string;\n}\n\ninterface OrganisationDropDownProps {\n label: string;\n onChange: (id: string) => void;\n organisations: Organisation[];\n selectedOrganisationId?: string;\n [key: string]: any;\n}\n\nexport const OrganisationDropDown: FC<OrganisationDropDownProps> = ({\n label,\n organisations,\n onChange: handleChange,\n selectedOrganisationId,\n ...rest\n}) => {\n const selectedOrganisation = organisations.find(\n (org) => org.id === selectedOrganisationId\n );\n\n return (\n <Dropdown\n label={label}\n searchable={true}\n clearable={true}\n className=\"eds-contrast\"\n items={[\n ...organisations\n .sort((a, b) => a.name.localeCompare(b.name, 'nb'))\n .map((organisation) => {\n return {\n value: organisation.id,\n label: organisation.name,\n };\n }),\n ]}\n initialSelectedItem={\n selectedOrganisation\n ? {\n value: selectedOrganisation.id,\n label: selectedOrganisation.name,\n }\n : null\n }\n onChange={(selectedValue) => {\n if (selectedValue) {\n handleChange(selectedValue.value);\n }\n }}\n {...rest}\n />\n );\n};\n","import React, { FC } from 'react';\nimport { Pagination } from '@entur/menu';\n\nexport interface PagerProps {\n currentPage: number;\n collectionSize: number;\n pageSize: number;\n onPageChange: (page: number) => void;\n}\n\nexport const Pager: FC<PagerProps> = ({\n collectionSize,\n pageSize,\n onPageChange,\n currentPage,\n}) => {\n const pageCount = Math.ceil(collectionSize / pageSize);\n return (\n <Pagination\n pageCount={pageCount}\n currentPage={currentPage}\n onPageChange={(page) => {\n onPageChange(page);\n }}\n />\n );\n};\n","import { BusinessCapability } from '@entur-partner/permission-client-node';\nimport React from 'react';\nimport {\n Route,\n Redirect,\n RouteComponentProps,\n RouteProps,\n} from 'react-router-dom';\n\nimport { PermissionCheck } from './PermissionCheck';\n\ninterface PermissionCheckedRouteProps\n extends RouteComponentProps,\n Omit<RouteProps, 'location'> {\n actualPermissions: BusinessCapability[];\n all?: BusinessCapability[];\n oneOf?: BusinessCapability[];\n onReject?: React.ReactNode;\n}\n\nexport const PermissionCheckedRoute = ({\n children,\n actualPermissions,\n all,\n oneOf,\n onReject,\n ...props\n}: PermissionCheckedRouteProps) => {\n const redirect = (\n <Redirect\n to={{\n pathname: '/unauthorized',\n state: { from: props.location },\n }}\n />\n );\n return (\n <PermissionCheck\n permissions={actualPermissions}\n all={all}\n oneOf={oneOf}\n fallback={onReject ? onReject : redirect}\n >\n <Route {...props}>{children}</Route>\n </PermissionCheck>\n );\n};\n","import React, { useState, FC, ReactNode } from 'react';\nimport { Prompt, useHistory } from 'react-router-dom';\nimport { Location } from 'history';\nimport { ModalProps } from '@entur/modal';\n\nimport { ConfirmModal } from './ConfirmModal';\n\nexport interface RouteLeavingGuardProps extends Partial<ModalProps> {\n title: string;\n closeLabel: string;\n messages: {\n cancel: string;\n confirm: string;\n };\n children: ReactNode;\n shouldBlockNavigation: (location: Location) => boolean;\n}\n\ntype Status = 'BLOCKED' | 'ALLOW';\n\nexport const RouteLeavingGuard: FC<RouteLeavingGuardProps> = ({\n children,\n shouldBlockNavigation,\n ...rest\n}) => {\n const history = useHistory();\n\n const [status, setStatus] = useState<Status>('ALLOW');\n const [lastLocation, setLastLocation] = useState(history.location);\n\n const closeModal = () => {\n setStatus('ALLOW');\n };\n\n const allowNavigation = (nextLocation: Location): boolean => {\n if (shouldBlockNavigation(nextLocation) && status === 'ALLOW') {\n setStatus('BLOCKED');\n setLastLocation(nextLocation);\n return false;\n }\n return true;\n };\n\n const handleConfirm = () => {\n history.push(lastLocation.pathname);\n };\n\n return (\n <>\n <Prompt message={allowNavigation} />\n <ConfirmModal\n onDismiss={closeModal}\n open={status === 'BLOCKED'}\n onConfirm={handleConfirm}\n {...rest}\n >\n {children}\n </ConfirmModal>\n </>\n );\n};\n","import './StatusLabel.scss';\n\nimport React, { FC } from 'react';\nimport cx from 'classnames';\n\ninterface StatusLabelProps {\n label: string;\n active: boolean;\n aggressiveInactive?: boolean;\n showBullet?: boolean;\n center?: boolean;\n}\nexport const StatusLabel: FC<StatusLabelProps> = ({\n active = false,\n label = '',\n aggressiveInactive,\n showBullet,\n center,\n}) => {\n const bulletClassNames = cx('eps-status-label__bullet', {\n active,\n aggressive: aggressiveInactive,\n });\n const statusLabelClassNames = cx('eps-status-label', {\n center,\n });\n return (\n <div className={statusLabelClassNames}>\n {showBullet && <div className={bulletClassNames} />}\n <div>{label}</div>\n </div>\n );\n};\n","import './Text.scss';\n\nimport React, { ReactNode } from 'react';\nimport cx from 'classnames';\n\nimport { StyleColor, responsiveProp, Box } from './Box';\n\ntype StyleFontSize =\n | 'extraSmall'\n | 'small'\n | 'medium'\n | 'large'\n | 'extraLarge'\n | 'extraLarge2'\n | 'extraLarge3'\n | 'extraLarge4';\n\ntype StyleFontWeight = 'body' | 'heading';\n\ntype StyleLineHeight =\n | 'extraSmall'\n | 'small'\n | 'medium'\n | 'large'\n | 'extraLarge'\n | 'extraLarge2'\n | 'extraLarge3'\n | 'extraLarge4'\n | 'extraLarge5'\n | 'extraLarge6'\n | 'extraLarge7';\n\nexport type ResponsiveStyleFontSize =\n | StyleFontSize\n | [StyleFontSize?, StyleFontSize?, StyleFontSize?];\n\nexport type ResponsiveStyleLineHeight =\n | StyleLineHeight\n | [StyleLineHeight?, StyleLineHeight?, StyleLineHeight?];\n\nexport interface TextProps {\n className?: string;\n as?: React.ElementType;\n children: ReactNode;\n\n fontSize?: ResponsiveStyleFontSize;\n lineHeight?: ResponsiveStyleLineHeight;\n color?: StyleColor;\n fontWeight?: StyleFontWeight;\n\n [key: string]: any;\n}\n\nexport const Text = ({\n as: component = 'span',\n children,\n fontSize,\n color,\n lineHeight,\n fontWeight,\n className,\n ...rest\n}: TextProps) => {\n const classes = [];\n\n fontSize && classes.push(...responsiveProp('eps-font-size-', fontSize));\n lineHeight && classes.push(...responsiveProp('eps-line-height-', lineHeight));\n fontWeight && classes.push('eps-font-weight-' + fontWeight);\n\n const classList = cx(classes, className);\n\n return (\n <Box as={component} color={color} className={classList} {...rest}>\n {children}\n </Box>\n );\n};\n","import './Unbutton.scss';\n\nimport React, { FC } from 'react';\nimport { Button, ButtonProps } from '@entur/button';\nimport cx from 'classnames';\n\ninterface UnbuttonProps extends Omit<ButtonProps, 'variant'> {}\n\nexport const Unbutton: FC<UnbuttonProps> = ({\n children,\n className,\n ...rest\n}) => (\n <Button variant=\"primary\" {...rest} className={cx('eps-unbutton', className)}>\n {children}\n </Button>\n);\n","/*global EventListener WindowEventHandlers*/\nimport { useEffect, useRef } from 'react';\n\ninterface TypedEventListener<T extends Event> {\n (evt: T): void;\n}\n\nexport function useEventListener<T extends Event = Event>(\n eventName: string,\n handler: TypedEventListener<T>,\n element: WindowEventHandlers = window\n) {\n const savedHandler = useRef<TypedEventListener<T>>();\n\n useEffect(() => {\n savedHandler.current = handler;\n }, [handler]);\n\n useEffect(() => {\n const isSupported = element && element.addEventListener;\n if (!isSupported) return;\n\n const eventListener = ((event: T): void =>\n savedHandler.current?.(event)) as EventListener;\n\n element.addEventListener(eventName, eventListener);\n\n return () => {\n element.removeEventListener(eventName, eventListener);\n };\n }, [eventName, element]);\n}\n"],"names":["responsiveProp","prefix","prop","Array","isArray","classes","push","Box","Environment","_ref","_ref$as","as","Component","children","contrast","paddingTop","paddingRight","paddingBottom","paddingLeft","paddingX","paddingY","padding","marginTop","marginRight","marginBottom","marginLeft","marginX","marginY","margin","display","justifyContent","alignItems","maxWidth","width","background","color","flexDirection","flexWrap","className","rest","_objectWithoutPropertiesLoose","_excluded","resolvedPaddingTop","resolvedPaddingBottom","resolvedPaddingLeft","resolvedPaddingRight","resolvedMarginTop","resolvedMarginBottom","resolvedMarginLeft","resolvedMarginRight","apply","classList","cx","React","createElement","_extends","Stack","space","stackItems","Children","toArray","length","Fragment","map","child","index","key","featureFlag","flag","_window$localStorage","_window$localStorage2","process","env","getItem","window","localStorage","useFeatureToggle","environmentColors","Local","Development","Staging","_environmentColors","getColorForEnvironment","environment","humanReadableEnvironment","_humanReadableEnviron","Production","getHumanReadableEnvironment","EnturPartnerLogoSvg","title","_ref$accentColor","accentColor","height","viewBox","fill","fillRule","d","CustomOverflowMenu","_ref2","ref","buttonRef","handler","userName","open","onOpenChange","overflowItemsClasses","overflowContentRef","useRef","overflowMenuTriggerRef","useEffect","listener","event","elementContainsEventTarget","current","document","addEventListener","removeEventListener","SecondaryButton","onClick","role","UserIcon","inline","Heading6","undefined","style","DownArrowIcon","CustomOverflowMenuItem","props","element","contains","target","composed","composedPath","find","LanguageSelect","language","options","onChange","classNames","SegmentedControl","assertIsDefined","selectedValue","option","SegmentedChoice","value","label","required","ErrorBoundary","_Component","_this","call","this","state","error","getDerivedStateFromError","_proto","prototype","componentDidCatch","errorInfo","_this$props$handleErr","_this$props","handleError","render","functionToCheck","_this2","_this$props2","fallback","toString","retry","setState","FormatDateTime","date","locale","hideTime","localeDate","localeDateTime","ConfirmModal","_ref$isOpen","isOpen","message","_ref$size","size","buttons","onConfirm","messages","onClose","onDismiss","childrenToRender","handleDismiss","Modal","isString","Paragraph","ButtonGroup","cancel","PrimaryButton","confirm","PermissionCheck","_ref$fallback","permissions","_ref$oneOf","oneOf","_ref$all","all","allIsAllowed","hasAllPermissions","oneOfIsAllowed","hasOneOfPermissions","_ref3","items","i","isDate","isDateString","prependBreadcrumbItem","pathname","onBreadcrumbLookup","paths","replace","split","reduce","prev","curr","path","breadcrumbs","filter","breadcrumbElements","BreadcrumbItem","Link","to","BreadcrumbNavigation","classnames","_ref2$as","altText","InputComponent","inputComponent","languages","values","name","variant","feedback","ExpandablePanel","defaultOpen","contentStyle","langKey","e","changes","amount","parsedAmount","Number","formattedAmount","Intl","NumberFormat","maximumFractionDigits","minimumFractionDigits","format","A","RouterLink","alertLabel","alertLevel","_ref$defaultLanguage","defaultLanguage","_ref$label","_ref$onBlur","onBlur","useState","_useState","setLanguage","currentValue","tabIndex","persist","currentTarget","setTimeout","activeElement","lang","handleLanguageChange","Object","assign","organisations","handleChange","selectedOrganisationId","selectedOrganisation","org","id","Dropdown","searchable","clearable","sort","a","b","localeCompare","organisation","initialSelectedItem","collectionSize","onPageChange","currentPage","pageCount","Math","ceil","pageSize","Pagination","page","actualPermissions","onReject","redirect","Redirect","from","location","Route","shouldBlockNavigation","history","useHistory","status","setStatus","_useState2","lastLocation","setLastLocation","Prompt","nextLocation","_ref$active","active","showBullet","center","bulletClassNames","aggressive","aggressiveInactive","statusLabelClassNames","component","fontSize","lineHeight","fontWeight","Button","onLogout","onLanguageChange","triggerClassList","setOpen","NorwayIcon","switchLanguage","UKIcon","UploadIcon","transform","logout","eventName","savedHandler","eventListener"],"mappings":"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"}
@@ -1,7 +1,7 @@
1
1
  import React, { Children, useState, useRef, useEffect, Component } from 'react';
2
2
  import cx from 'classnames';
3
3
  import { Link as Link$1, Heading6, Paragraph } from '@entur/typography';
4
- import { PrivacyIcon, NorwayIcon, UKIcon, UploadIcon, UserIcon, DownArrowIcon } from '@entur/icons';
4
+ import { NorwayIcon, UKIcon, UploadIcon, UserIcon, DownArrowIcon } from '@entur/icons';
5
5
  import { SecondaryButton, Button, ButtonGroup, PrimaryButton } from '@entur/button';
6
6
  import { Dropdown } from '@entur/dropdown';
7
7
  import { SegmentedControl, SegmentedChoice } from '@entur/form';
@@ -205,14 +205,21 @@ var LinkButton = function LinkButton(_ref) {
205
205
  * you can drop the REACT_APP_ prefix.
206
206
  */
207
207
 
208
- function useFeatureToggle(flag) {
208
+ function featureFlag(flag) {
209
209
  var _window$localStorage, _window$localStorage2;
210
210
 
211
- if (process.env["REACT_APP_" + flag] === 'true' || ((_window$localStorage = window.localStorage) == null ? void 0 : _window$localStorage.getItem(flag)) === 'true' || ((_window$localStorage2 = window.localStorage) == null ? void 0 : _window$localStorage2.getItem("REACT_APP_" + flag)) === 'true') {
212
- return true;
213
- }
211
+ return process.env["REACT_APP_" + flag] === 'true' || ((_window$localStorage = window.localStorage) == null ? void 0 : _window$localStorage.getItem(flag)) === 'true' || ((_window$localStorage2 = window.localStorage) == null ? void 0 : _window$localStorage2.getItem("REACT_APP_" + flag)) === 'true';
212
+ }
213
+ /**
214
+ * Returns true if the provided flag exist in localStorage
215
+ * or is set as an environment variable.
216
+ *
217
+ * @param flag case sensitive flag. If it is an environment variable
218
+ * you can drop the REACT_APP_ prefix.
219
+ */
214
220
 
215
- return false;
221
+ function useFeatureToggle(flag) {
222
+ return featureFlag(flag);
216
223
  }
217
224
  var FeatureToggle = function FeatureToggle(_ref) {
218
225
  var children = _ref.children,
@@ -226,9 +233,37 @@ var FeatureToggle = function FeatureToggle(_ref) {
226
233
  return null;
227
234
  };
228
235
 
229
- var _excluded$d = ["title"];
236
+ var _environmentColors, _humanReadableEnviron;
237
+
238
+ var Environment;
239
+
240
+ (function (Environment) {
241
+ Environment["Local"] = "local";
242
+ Environment["Development"] = "dev";
243
+ Environment["Staging"] = "staging";
244
+ Environment["Production"] = "prod";
245
+ })(Environment || (Environment = {}));
246
+
247
+ var environmentColors = (_environmentColors = {}, _environmentColors[Environment.Local] = '#B482FB', _environmentColors[Environment.Development] = '#5AC39A', _environmentColors[Environment.Staging] = '#FFCA28', _environmentColors);
248
+ /**
249
+ * Gets the color for the given environment. This is the color used for the environment
250
+ * indicator. There is no color for production as it should not have any special environment
251
+ * indication.
252
+ */
253
+
254
+ var getColorForEnvironment = function getColorForEnvironment(environment) {
255
+ return environmentColors[environment];
256
+ };
257
+ var humanReadableEnvironment = (_humanReadableEnviron = {}, _humanReadableEnviron[Environment.Local] = 'Local', _humanReadableEnviron[Environment.Development] = 'Dev', _humanReadableEnviron[Environment.Staging] = 'Staging', _humanReadableEnviron[Environment.Production] = 'Prod', _humanReadableEnviron);
258
+ var getHumanReadableEnvironment = function getHumanReadableEnvironment(environment) {
259
+ return humanReadableEnvironment[environment];
260
+ };
261
+
262
+ var _excluded$d = ["title", "accentColor"];
230
263
  var EnturPartnerLogoSvg = function EnturPartnerLogoSvg(_ref) {
231
264
  var title = _ref.title,
265
+ _ref$accentColor = _ref.accentColor,
266
+ accentColor = _ref$accentColor === void 0 ? '#FF5959' : _ref$accentColor,
232
267
  rest = _objectWithoutPropertiesLoose(_ref, _excluded$d);
233
268
 
234
269
  return React.createElement("svg", _extends({
@@ -242,13 +277,13 @@ var EnturPartnerLogoSvg = function EnturPartnerLogoSvg(_ref) {
242
277
  fill: "#FFF",
243
278
  d: "M0 .231V25.72h18.745v-4.318H4.869v-6.163h12.31v-4.318H4.87V4.55h13.876V.231z"
244
279
  }), React.createElement("path", {
245
- fill: "#FF5959",
280
+ fill: accentColor,
246
281
  d: "M0 36.408h45.253v-4.32H0z"
247
282
  }), React.createElement("path", {
248
283
  fill: "#FFF",
249
284
  d: "M40.384.231v15.425L23.656.231h-.521V25.72h4.869V10.573L44.732 25.72h.521V.23zM69.25 15.238h-7.267v21.17h-4.87v-21.17H49.81V10.92h19.44zM83.863 36.86c-1.646 0-3.142-.255-4.486-.765-1.345-.51-2.493-1.23-3.443-2.159-.95-.928-1.687-2.054-2.208-3.378-.522-1.323-.783-2.797-.783-4.422V10.92h4.869v15.216c0 1.277.209 2.333.626 3.169.417.836.933 1.497 1.548 1.985a5.346 5.346 0 001.982 1.01c.707.186 1.339.278 1.895.278.557 0 1.188-.092 1.896-.279a5.35 5.35 0 001.982-1.01c.614-.487 1.13-1.148 1.548-1.984.417-.836.625-1.892.625-3.169V10.92h4.87v15.216c0 1.625-.256 3.1-.766 4.422-.51 1.324-1.24 2.45-2.19 3.378-.952.929-2.1 1.648-3.444 2.159-1.344.51-2.851.766-4.52.766M104.21 24.047h5.546c1.016 0 1.854-.127 2.513-.383.658-.255 1.179-.592 1.56-1.01.381-.418.641-.888.78-1.41.138-.522.208-1.05.208-1.584 0-.627-.099-1.207-.295-1.741a3.718 3.718 0 00-.901-1.393c-.405-.394-.924-.708-1.56-.94-.636-.232-1.404-.348-2.305-.348h-5.546v8.81zm0 4.248v8.113h-4.87V10.92h11.567c1.3 0 2.49.215 3.57.644 1.08.43 2.004 1.033 2.77 1.81a8.287 8.287 0 011.794 2.787c.43 1.079.645 2.257.645 3.534 0 .952-.128 1.874-.383 2.768-.256.894-.61 1.7-1.063 2.42a7.32 7.32 0 01-1.672 1.863 5.929 5.929 0 01-2.178 1.096l6.339 8.566h-5.808l-5.893-8.113h-4.818z"
250
285
  }), React.createElement("g", {
251
- fill: "#FF5959"
286
+ fill: accentColor
252
287
  }, React.createElement("path", {
253
288
  d: "M141.051 23.448h5.628c4.185 0 5.989-1.984 5.989-4.942 0-2.742-1.515-4.618-5.989-4.618h-5.628v9.56zm0 3.067v9.776h-3.571V10.75h9.632c6.674 0 9.127 3.211 9.127 7.54 0 4.979-3.102 8.226-9.2 8.226h-5.988zM169.695 28.715c-1.371-.288-2.958-.505-4.401-.505-2.85 0-4.041 1.263-4.041 3.139s1.407 2.706 3.463 2.706c2.49 0 4.979-1.443 4.979-4.221v-1.119zm-4.293-2.958c1.551 0 3.174.253 4.293.469v-.83c0-2.525-1.154-3.896-4.33-3.896-2.164 0-3.824.866-4.942 2.092l-2.02-2.272c1.732-1.66 3.644-2.598 7.07-2.598 5.052 0 7.469 1.876 7.469 7.215v10.354h-3.211V34.02h-.108c-1.082 1.767-3.211 2.705-5.592 2.705-3.32 0-6.241-1.66-6.241-5.303 0-3.103 1.912-5.664 7.612-5.664zM178.965 19.191h3.211v2.886h.108c.938-1.984 2.922-3.355 5.231-3.355.47 0 .938.036 1.335.144l-.144 3.14a6.77 6.77 0 00-1.552-.181c-3.246 0-4.798 2.633-4.798 5.483v8.983h-3.39v-17.1zM199.961 36.291h-1.912c-4.004 0-5.988-.938-5.988-5.772v-8.55h-2.778V19.19h2.778v-4.654h3.355v4.654h4.473v2.778h-4.473v7.973c0 3.427 1.587 3.535 3.319 3.535h1.226v2.814zM219.767 36.291h-3.391V26.84c0-2.778-1.083-5.375-4.257-5.375-3.14 0-5.268 2.597-5.268 6.169v8.658h-3.391v-17.1h3.32v2.814h.143c.794-1.623 3.067-3.283 5.99-3.283 4.941 0 6.854 3.644 6.854 8.081v9.488zM227.847 26.262h10.57c0-2.597-2.272-4.726-5.087-4.726-2.922 0-5.014 1.948-5.483 4.726zm-.036 2.453c.397 3.355 2.633 5.195 5.844 5.195 2.778 0 4.618-1.623 5.484-2.67l2.164 1.804c-1.37 1.913-4.365 3.716-8.045 3.716-4.942 0-8.73-3.535-8.73-8.55 0-5.195 3.752-9.488 8.983-9.488 5.303 0 8.009 4.365 8.009 8.19 0 .649-.036 1.226-.072 1.803H227.81zM246.245 19.191h3.21v2.886h.109c.938-1.984 2.922-3.355 5.231-3.355.469 0 .938.036 1.335.144l-.145 3.14a6.77 6.77 0 00-1.551-.181c-3.247 0-4.798 2.633-4.798 5.483v8.983h-3.391v-17.1z"
254
289
  }))));
@@ -257,13 +292,15 @@ var EnturPartnerLogo = function EnturPartnerLogo(_ref2) {
257
292
  var _ref2$as = _ref2.as,
258
293
  Component = _ref2$as === void 0 ? 'nav' : _ref2$as,
259
294
  className = _ref2.className,
260
- altText = _ref2.altText;
295
+ altText = _ref2.altText,
296
+ environment = _ref2.environment;
261
297
  var classList = cx(['eps-logo-wrapper', className]);
262
298
  return React.createElement(Component, {
263
299
  className: classList
264
300
  }, React.createElement(EnturPartnerLogoSvg, {
265
301
  title: altText,
266
- className: "logo"
302
+ className: "logo",
303
+ accentColor: environment !== undefined && environment !== Environment.Production ? getColorForEnvironment(environment) : undefined
267
304
  }));
268
305
  };
269
306
 
@@ -289,15 +326,15 @@ var Content = function Content(_ref) {
289
326
  }, children);
290
327
  };
291
328
 
292
- var _excluded$c = ["className", "children", "userName", "open", "onOpenChange"];
329
+ var _excluded$c = ["className", "children", "userName", "open", "onOpenChange", "environment"];
293
330
  var UserMenu = function UserMenu(_ref) {
294
331
  var className = _ref.className,
295
332
  messages = _ref.messages,
296
333
  onLogout = _ref.onLogout,
297
334
  onLanguageChange = _ref.onLanguageChange,
298
- onShowGdprDialog = _ref.onShowGdprDialog,
299
335
  userName = _ref.userName,
300
- language = _ref.language;
336
+ language = _ref.language,
337
+ environment = _ref.environment;
301
338
  var triggerClassList = cx(['eps-user-menu__trigger-button', className]);
302
339
 
303
340
  var _useState = useState(false),
@@ -310,21 +347,11 @@ var UserMenu = function UserMenu(_ref) {
310
347
  open: open,
311
348
  onOpenChange: setOpen,
312
349
  className: triggerClassList,
313
- userName: userName
350
+ userName: userName,
351
+ environment: environment
314
352
  }, React.createElement("div", {
315
353
  id: "eps-overflow-menu"
316
- }, React.createElement(CustomOverflowMenuItem, {
317
- onClick: function onClick() {
318
- onShowGdprDialog();
319
- setOpen(false);
320
- },
321
- className: "eps-overflow-menu__item"
322
- }, React.createElement("span", {
323
- "aria-hidden": true
324
- }, React.createElement(PrivacyIcon, {
325
- size: "1rem",
326
- inline: true
327
- })), messages.termsAndConditions), language === 'en' ? React.createElement(CustomOverflowMenuItem, {
354
+ }, language === 'en' ? React.createElement(CustomOverflowMenuItem, {
328
355
  onClick: function onClick() {
329
356
  onLanguageChange('nb');
330
357
  setOpen(false);
@@ -372,6 +399,7 @@ var CustomOverflowMenu = function CustomOverflowMenu(_ref2) {
372
399
  userName = _ref2.userName,
373
400
  open = _ref2.open,
374
401
  onOpenChange = _ref2.onOpenChange,
402
+ environment = _ref2.environment,
375
403
  rest = _objectWithoutPropertiesLoose(_ref2, _excluded$c);
376
404
 
377
405
  var overflowItemsClasses = cx('eps-overflow-menu__group', {
@@ -400,7 +428,11 @@ var CustomOverflowMenu = function CustomOverflowMenu(_ref2) {
400
428
  })), React.createElement(Heading6, {
401
429
  margin: "none",
402
430
  as: "span"
403
- }, userName), React.createElement("span", {
431
+ }, userName, environment !== undefined && environment !== Environment.Production && React.createElement("span", {
432
+ style: {
433
+ color: getColorForEnvironment(environment)
434
+ }
435
+ }, ' ', "(", getHumanReadableEnvironment(environment), ")")), React.createElement("span", {
404
436
  className: "eps-arrow-icon"
405
437
  }, React.createElement(DownArrowIcon, {
406
438
  inline: true
@@ -1045,5 +1077,5 @@ var Text = function Text(_ref) {
1045
1077
  }, rest), children);
1046
1078
  };
1047
1079
 
1048
- export { ActionBar, ActionBarLeft, ActionBarRight, AuditInfo, Box, Breadcrumbs, ConfirmModal, Content, EnturPartnerLogo, EnturPartnerLogoSvg, ErrorBoundary, ExpandableMultiLanguageInput, FeatureToggle, FormatCurrencyAmount, FormatDateTime, LanguageSelect, Link, LinkButton, Menu, MultiLanguageInput, OrganisationDropDown, Pager, PermissionCheck, PermissionCheckedRoute, RouteLeavingGuard, Stack, StatusLabel, Text, Unbutton, UserMenu, responsiveProp, useEventListener, useFeatureToggle };
1080
+ export { ActionBar, ActionBarLeft, ActionBarRight, AuditInfo, Box, Breadcrumbs, ConfirmModal, Content, EnturPartnerLogo, EnturPartnerLogoSvg, Environment, ErrorBoundary, ExpandableMultiLanguageInput, FeatureToggle, FormatCurrencyAmount, FormatDateTime, LanguageSelect, Link, LinkButton, Menu, MultiLanguageInput, OrganisationDropDown, Pager, PermissionCheck, PermissionCheckedRoute, RouteLeavingGuard, Stack, StatusLabel, Text, Unbutton, UserMenu, featureFlag, getColorForEnvironment, getHumanReadableEnvironment, responsiveProp, useEventListener, useFeatureToggle };
1049
1081
  //# sourceMappingURL=common.esm.js.map