@entur-partner/common 9.3.3-alpha.0 → 9.3.3-alpha.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/ActionBar.d.ts +9 -9
- package/dist/AuditInfo.d.ts +14 -14
- package/dist/Box.d.ts +57 -57
- package/dist/Breadcrumbs.d.ts +8 -8
- package/dist/ConfirmModal.d.ts +28 -28
- package/dist/Content.d.ts +10 -10
- package/dist/EnturPartnerLogo.d.ts +19 -19
- package/dist/ErrorBoundary.d.ts +22 -22
- package/dist/ExpandableMultiLanguageInput.d.ts +17 -17
- package/dist/FeatureToggle.d.ts +25 -25
- package/dist/FormatCurrencyAmount.d.ts +8 -8
- package/dist/FormatDateTime.d.ts +7 -7
- package/dist/LanguageSelect.d.ts +16 -16
- package/dist/LegacyPageTitle.d.ts +16 -0
- package/dist/Link.d.ts +6 -6
- package/dist/LinkButton.d.ts +8 -8
- package/dist/Menu.d.ts +10 -10
- package/dist/MultiLanguageInput.d.ts +28 -28
- package/dist/OrganisationDropdown.d.ts +14 -14
- package/dist/PageTitle.d.ts +6 -15
- package/dist/Pager.d.ts +8 -8
- package/dist/PermissionCheck.d.ts +24 -24
- package/dist/RouteLeavingGuard.d.ts +14 -14
- package/dist/Stack.d.ts +9 -9
- package/dist/StatusLabel.d.ts +11 -11
- package/dist/Text.d.ts +21 -21
- package/dist/Unbutton.d.ts +7 -7
- package/dist/UserMenu/components/CookieSettingsMenuItem.d.ts +9 -9
- package/dist/UserMenu/components/CustomOverflowMenu.d.ts +11 -11
- package/dist/UserMenu/components/CustomOverflowMenuItem.d.ts +3 -3
- package/dist/UserMenu/components/LanguageSwitchMenuItem.d.ts +10 -10
- package/dist/UserMenu/components/LogOutMenuItem.d.ts +9 -9
- package/dist/UserMenu/components/UserMenuItem.d.ts +9 -9
- package/dist/UserMenu/components/VersionMenuItem.d.ts +5 -5
- package/dist/UserMenu/index.d.ts +26 -25
- package/dist/UserMenu/useOutsideClick.d.ts +2 -2
- package/dist/common.cjs.development.js +199 -191
- package/dist/common.cjs.development.js.map +1 -1
- package/dist/common.cjs.production.min.js +1 -1
- package/dist/common.cjs.production.min.js.map +1 -1
- package/dist/common.esm.js +79 -67
- package/dist/common.esm.js.map +1 -1
- package/dist/environment.d.ts +13 -13
- package/dist/index.d.ts +31 -30
- package/dist/styles.css +185 -185
- package/dist/useEventListener.d.ts +3 -3
- package/package.json +6 -7
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),t=require("@entur-partner/util"),n=require("classnames"),a=require("@entur/menu"),r=require("react-router-dom"),l=require("@entur/button"),o=require("@entur/modal"),i=require("@entur/typography"),u=require("@entur/alert"),s=require("@entur/expand"),c=require("@entur/form"),m=require("@entur/dropdown"),d=require("react-helmet-async"),p=require("@entur/icons");function f(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var v=f(e),g=f(n);function h(){return h=Object.assign?Object.assign.bind():function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var a in n)Object.prototype.hasOwnProperty.call(n,a)&&(e[a]=n[a])}return e},h.apply(this,arguments)}function E(e,t){return E=Object.setPrototypeOf?Object.setPrototypeOf.bind():function(e,t){return e.__proto__=t,e},E(e,t)}function b(e,t){if(null==e)return{};var n,a,r={},l=Object.keys(e);for(a=0;a<l.length;a++)t.indexOf(n=l[a])>=0||(r[n]=e[n]);return r}var x=["date","locale","as","hideTime"],N=function(e){var n=e.date,a=e.locale,r=e.as,l=void 0===r?"main":r,o=e.hideTime,i=b(e,x);return v.default.createElement(l,h({},i),o?t.localeDate(n,a):t.localeDateTime(n,a))},C=["as","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"];function y(e,t){if(Array.isArray(t)){var n=[];return t[0]&&n.push(e+t[0]),t[1]&&n.push(""+e+t[1]+"-lg"),t[2]&&n.push(""+e+t[2]+"-xl"),n}return[e+t]}var w,L,k,P=function(e){var t=e.as,n=void 0===t?"div":t,a=e.children,r=e.contrast,l=e.paddingTop,o=e.paddingRight,i=e.paddingBottom,u=e.paddingLeft,s=e.paddingX,c=e.paddingY,m=e.padding,d=e.marginTop,p=e.marginRight,f=e.marginBottom,E=e.marginLeft,x=e.marginX,N=e.marginY,w=e.margin,L=e.display,k=e.justifyContent,P=e.alignItems,_=e.maxWidth,O=e.width,B=e.background,S=e.color,I=e.flexDirection,z=e.flexWrap,F=e.className,D=b(e,C),M=[],T=l||c||m,V=i||c||m,A=u||s||m,j=o||s||m,q=d||N||w,R=f||N||w,H=E||x||w,U=p||x||w;r&&M.push("eds-contrast"),T&&M.push.apply(M,y("eps-pt-",T)),V&&M.push.apply(M,y("eps-pb-",V)),A&&M.push.apply(M,y("eps-pl-",A)),j&&M.push.apply(M,y("eps-pr-",j)),q&&M.push.apply(M,y("eps-mt-",q)),R&&M.push.apply(M,y("eps-mb-",R)),H&&M.push.apply(M,y("eps-ml-",H)),U&&M.push.apply(M,y("eps-mr-",U)),L&&M.push.apply(M,y("eps-",L)),k&&M.push.apply(M,y("eps-justify-",k)),P&&M.push.apply(M,y("eps-items-",P)),_&&M.push.apply(M,y("eps-max-w-",_)),O&&M.push.apply(M,y("eps-w-",O)),S&&M.push("eps-color-"+S),B&&M.push("eps-bg-"+B),I&&M.push.apply(M,y("eps-flex-",I)),z&&M.push.apply(M,y("eps-flex-wrap-",z));var W=g.default(M,F);return v.default.createElement(n,h({className:W},D),a)},_=function(t){var n=t.space,a=t.className,r=e.Children.toArray(t.children);return r.length<=1?v.default.createElement(v.default.Fragment,null,r):v.default.createElement("div",{className:a},r.map((function(e,t){return t===r.length-1?v.default.createElement("div",{key:t},e):v.default.createElement(P,{paddingBottom:n,key:t},e)})))},O=["items","locale","className"],B=["isOpen","children","message","size","buttons","onConfirm","messages","onClose","onDismiss"],S=function(e){var n=e.isOpen,a=void 0!==n&&n,r=e.children,u=e.message,s=e.size,c=void 0===s?"medium":s,m=e.buttons,d=e.onConfirm,p=e.messages,f=e.onClose,g=e.onDismiss,E=b(e,B),x=r||u,N=f||g;return v.default.createElement(o.Modal,h({size:c,open:a,onDismiss:N},E),t.isString(x)?v.default.createElement(i.Paragraph,null,x):v.default.createElement(P,{paddingBottom:"medium"},x),v.default.createElement(l.ButtonGroup,null,d?v.default.createElement(v.default.Fragment,null,v.default.createElement(l.SecondaryButton,{onClick:N,"data-testid":"cancel-modal-button"},p.cancel),v.default.createElement(l.PrimaryButton,{onClick:d,"data-testid":"confirm-modal-button"},p.confirm)):m))};exports.Environment=void 0,(k=exports.Environment||(exports.Environment={})).Local="local",k.Development="dev",k.Staging="staging",k.Production="prod";var I=((w={})[exports.Environment.Local]="#B482FB",w[exports.Environment.Development]="#5AC39A",w[exports.Environment.Staging]="#FFCA28",w),z=function(e){return I[e]},F=((L={})[exports.Environment.Local]="Local",L[exports.Environment.Development]="Dev",L[exports.Environment.Staging]="Staging",L[exports.Environment.Production]="Prod",L),D=function(e){return F[e]},M=["title","accentColor"],T=function(e){var t=e.title,n=e.accentColor,a=void 0===n?"#FF5959":n,r=b(e,M);return v.default.createElement("svg",h({width:257,height:37,viewBox:"0 0 257 37"},r),v.default.createElement("title",null,t),v.default.createElement("g",{fill:"none",fillRule:"evenodd"},v.default.createElement("path",{fill:"#FFF",d:"M0 .231V25.72h18.745v-4.318H4.869v-6.163h12.31v-4.318H4.87V4.55h13.876V.231z"}),v.default.createElement("path",{fill:a,d:"M0 36.408h45.253v-4.32H0z"}),v.default.createElement("path",{fill:"#FFF",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"}),v.default.createElement("g",{fill:a},v.default.createElement("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"}))))},V=function(e){function n(t){var n;return(n=e.call(this,t)||this).state={error:null},n}var a,r;r=e,(a=n).prototype=Object.create(r.prototype),a.prototype.constructor=a,E(a,r),n.getDerivedStateFromError=function(e){return{error:e}};var l=n.prototype;return l.componentDidCatch=function(e,t){var n,a;null==(n=(a=this.props).handleError)||n.call(a,e,t)},l.render=function(){var e=this,n=this.state.error,a=this.props,r=a.fallback,l=a.children;return n?t.isFunction(r)?r({retry:function(){return e.setState({error:null})},error:n}):"NotFoundError"===n.name&&"Failed to execute 'removeChild' on 'Node': The node to be removed is not a child of this node."===n.message?v.default.createElement(j,null):r:l},n}(e.Component),A="EP::locale";function j(){var e=localStorage.getItem(A),t="nb"===e||"nb-NO"===e;return v.default.createElement(P,{maxWidth:"large"},v.default.createElement(u.BannerAlertBox,{variant:"info",title:t?"En ny versjon av nettsiden er tilgjengelig.":"A new version of the website is available."},v.default.createElement(P,{paddingBottom:"medium"},v.default.createElement(i.Paragraph,{margin:"none"},t?"Vennligst oppdater.":"Please refresh.")),v.default.createElement(l.PrimaryButton,{onClick:function(){return window.location.reload()}},t?"Oppdater":"Refresh")))}var q=["title","inputComponent","languages","values","onChange","name","variant","feedback"];function R(e){var t,n;return"true"===(void 0)["VITE_APP_"+e]||"true"===(null==(t=window.localStorage)?void 0:t.getItem(e))||"true"===(null==(n=window.localStorage)?void 0:n.getItem("VITE_APP_"+e))}function H(e){return R(e)}var U=["amount","as"],W=["language","options","className","onChange"],G=function(e){var n=e.language,a=e.options,r=e.className,l=e.onChange,o=b(e,W),i=g.default("eps-language-select",r);return v.default.createElement("div",h({},o,{className:i}),v.default.createElement(c.SegmentedControl,{onChange:function(e){t.assertIsDefined(e),l(e)},selectedValue:n},a.map((function(e){return v.default.createElement(c.SegmentedChoice,{key:e.value,value:e.value},e.label,e.required&&v.default.createElement("span",{className:"asterisk-margin"},"*"))}))))},Y=["children","className"],X=["className","inputComponent","alertLabel","alertLevel","name","languages","values","onChange","defaultLanguage","label","onBlur"],K=["label","organisations","onChange","selectedOrganisationId"],J=["children","shouldBlockNavigation"],Q=["as","children","fontSize","color","lineHeight","fontWeight","className"],Z=["children","className"],$=function(e){return v.default.createElement("button",h({className:g.default(e.className,"eps-overflow-menu__item"),role:"menuitem"},e))},ee=function(e){var t=e.name,n=e.setOpen,a=e.onCookieSettingsOpen;return v.default.createElement($,{onClick:function(){a(),n(!1)},className:"eps-overflow-menu__item"},v.default.createElement("span",{"aria-hidden":!0},v.default.createElement(p.CookieIcon,{size:"1rem",inline:!0})),t)};function te(e,t){return!(!e||!(e.contains(t.target)||t.composed&&t.composedPath&&t.composedPath().find((function(t){return t!==window&&e.contains(t)}))))}var ne=["className","children","userName","open","onOpenChange","environment"],ae=function(e){var t,n,a,r=e.className,o=e.children,u=e.userName,s=e.open,c=e.onOpenChange,m=e.environment,d=b(e,ne),f=g.default("eps-overflow-menu__group",{"eps-overflow-menu__group--open":s}),E=v.default.useRef(null),x=v.default.useRef(null);return v.default.useEffect((function(){var e=function(e){te(t.current,e)||te(n.current,e)||a()};return document.addEventListener("mousedown",e),document.addEventListener("touchstart",e),function(){document.removeEventListener("mousedown",e),document.removeEventListener("touchstart",e)}}),[t=E,n=x,a=function(){return c(!1)}]),v.default.createElement("div",null,v.default.createElement(l.SecondaryButton,h({className:g.default("eps-overflow-menu__button",r),onClick:function(){return c(!s)},"aria-haspopup":!0,"aria-expanded":s,ref:x},d),v.default.createElement("div",{className:"eps-overflow-menu__button-contents"},v.default.createElement("span",{className:"eds-overflow-menu__user-icon"},v.default.createElement(p.UserIcon,{inline:!0})),v.default.createElement(i.Heading6,{margin:"none",as:"span"},u,void 0!==m&&m!==exports.Environment.Production&&v.default.createElement("span",{style:{color:z(m)}}," ","(",D(m),")")),v.default.createElement("span",{className:"eps-arrow-icon"},v.default.createElement(p.DownArrowIcon,{inline:!0})))),s&&v.default.createElement("div",{className:f,role:"menu",ref:E},o))},re=function(e){var t=e.language,n=e.onLanguageChange,a=e.setOpen,r=e.name,l=H("USE_BCP-47_LANGUAGE_KEY"),o=l?"nb-NO":"nb",i=l?"en-GB":"en";return v.default.createElement(v.default.Fragment,null,t===i?v.default.createElement($,{onClick:function(){n(o),a(!1)},className:"eps-overflow-menu__item"},v.default.createElement("span",{"aria-hidden":!0,className:"eps-overflow-menu__icon-margin"},v.default.createElement(p.NorwayIcon,{size:"1rem",inline:!0})),r):v.default.createElement($,{onClick:function(){n(i),a(!1)},className:"eps-overflow-menu__item"},v.default.createElement("span",{"aria-hidden":!0,className:"eps-overflow-menu__icon-margin"},v.default.createElement(p.UKIcon,{size:"1rem",inline:!0})),r))},le=function(e){var t=e.name,n=e.setOpen,a=e.onLogout;return v.default.createElement($,{onClick:function(){a(),n(!1)},"data-testid":"user-menu-logout",className:"eps-overflow-menu__item"},v.default.createElement("span",{"aria-hidden":!0},v.default.createElement(p.LogOutIcon,{size:"1rem",inline:!0})),t)},oe=function(e){var t=e.name,n=e.setOpen,a=e.onNavigateToMyProfile;return v.default.createElement(r.Link,{to:"/permission-admin/my-profile",style:{textDecoration:"none"}},v.default.createElement($,{onClick:function(){n(!1),a()},className:"eps-overflow-menu__item"},v.default.createElement("span",{"aria-hidden":!0},v.default.createElement(p.UserIcon,{size:"1rem",inline:!0})),t))},ie=function(e){var t=e.title,n=e.setOpen,a=r.useNavigate();return v.default.createElement($,{onClick:function(){a("/app-version"),n(!1)},className:"eps-overflow-menu__item"},v.default.createElement("span",{"aria-hidden":!0},v.default.createElement(p.ChannelsIcon,{className:"eps-version-icon",size:"1rem",inline:!0})),t)};exports.ActionBar=function(e){var t=e.children;return v.default.createElement(v.default.Fragment,null,v.default.createElement("div",{className:"eps-action-bar-padding"}),v.default.createElement("div",{className:"eps-action-bar"},t))},exports.ActionBarLeft=function(e){return v.default.createElement("div",{className:"eps-action-bar-left"},e.children)},exports.ActionBarRight=function(e){return v.default.createElement("div",{className:"eps-action-bar-right"},e.children)},exports.AuditInfo=function(e){var n=e.items,a=e.locale,r=e.className,l=b(e,O),o=g.default("ep-audit-info",r);return v.default.createElement("div",h({className:o},l),n.map((function(e){var n=e.label,r=e.value;return v.default.createElement(_,{space:"small",key:r.toString()},v.default.createElement("div",{className:"ep-audit-info-label"},n),v.default.createElement("div",null,t.isDate(r)||t.isDateString(r)?v.default.createElement(N,{date:r,locale:a}):v.default.createElement("span",null,r)))})))},exports.Box=P,exports.Breadcrumbs=function(e){var n=e.prependBreadcrumbItem,l=e.onBreadcrumbLookup,o=t.splitUrlPath(e.pathname).map((function(e){return{title:l(e),path:e}})).filter((function(e){return void 0!==e.title})),i=o.map((function(e,t){var n=e.path;return v.default.createElement(a.BreadcrumbItem,t===o.length-1?{key:n,as:"span"}:{key:n,as:r.Link,to:n},e.title)}));return v.default.createElement(a.BreadcrumbNavigation,null,n?[n].concat(i):i)},exports.ConfirmModal=S,exports.Content=function(e){var t=e.as,n=void 0===t?"main":t,a=e.children,r=g.default(["eps-content",e.className]);return v.default.createElement(n,{className:r},a)},exports.EnturPartnerLogo=function(e){var t=e.as,n=void 0===t?"nav":t,a=e.altText,r=e.environment,l=g.default(["eps-logo-wrapper",e.className]);return v.default.createElement(n,{className:l},v.default.createElement(T,{title:a,className:"logo",accentColor:void 0!==r&&r!==exports.Environment.Production?z(r):void 0}))},exports.EnturPartnerLogoSvg=T,exports.ErrorBoundary=V,exports.ExpandableMultiLanguageInput=function(e){var t=e.title,n=e.inputComponent,a=e.languages,r=e.values,l=e.onChange,o=e.name,i=e.variant,u=e.feedback,c=b(e,q);return v.default.createElement(s.ExpandablePanel,{title:t,defaultOpen:!0,contentStyle:{padding:"4px 4px 4px 4px",marginTop:"16px",marginBottom:"16px"}},v.default.createElement(_,{space:"medium"},a.map((function(e){var a=e.value,s=e.label;return v.default.createElement(n,h({"data-testid":"multi-lang-input-"+o+"-"+a,key:t+a,label:e.required?s+"*":s,variant:null==i?void 0:i(a),feedback:null==u?void 0:u(a),name:o,onChange:function(e){var t,n,o;t=a,n=e.target.value,o=h({},r),""!==n&&n?o[t]=n:delete o[t],l(o)},value:r[a]||""},c))}))))},exports.FeatureToggle=function(e){var t=e.children;return H(e.flag)?v.default.createElement(v.default.Fragment,null,t):null},exports.FormatCurrencyAmount=function(e){var t=e.amount,n=e.as,a=void 0===n?"span":n,r=b(e,U),l=Number(t)||0,o=new Intl.NumberFormat("nb-NO",{maximumFractionDigits:2,minimumFractionDigits:2}).format(l);return v.default.createElement(a,h({},r),o)},exports.FormatDateTime=N,exports.LanguageSelect=G,exports.Link=function(e){return v.default.createElement(i.Link,h({},e,{as:r.Link}),e.children)},exports.LinkButton=function(e){var t=e.children,n=e.className,a=b(e,Y);return v.default.createElement(i.Link,h({},a,{as:"button",className:g.default("eps-link-button",n)}),t)},exports.Menu=function(e){var t=e.as,n=void 0===t?"nav":t,a=e.children,r=g.default(["eds-contrast","eps-menu",e.className]);return v.default.createElement(n,{className:r},a)},exports.MultiLanguageInput=function(t){var n=t.className,a=t.inputComponent,r=t.alertLabel,l=t.alertLevel,o=t.name,i=t.languages,u=t.values,s=t.onChange,c=t.defaultLanguage,m=void 0===c?"nob":c,d=t.label,p=void 0===d?"":d,f=t.onBlur,E=void 0===f?function(){}:f,x=b(t,X),N=e.useState(m),C=N[0],y=N[1],w=g.default("multi-language-input",n),L=u[C];return v.default.createElement("div",{className:w,tabIndex:0,onBlur:function(e){e.persist();var t=e.currentTarget;setTimeout((function(){t&&!t.contains(document.activeElement)&&E(e)}),0)},"data-testid":"multi-lang-input-"+o},v.default.createElement(_,{space:"extraSmall"},v.default.createElement(G,{language:C,options:i,onChange:function(e){return function(e){y(e)}(e)}}),v.default.createElement(a,h({label:p,variant:l,feedback:r,name:o,className:"language-item",onChange:function(e){return t=e.target.value,n=Object.assign({},u),""!==t&&t?n[C]=t:delete n[C],void s(n);var t,n},value:L||""},x))))},exports.OrganisationDropDown=function(t){var n=t.label,a=t.organisations,r=t.onChange,l=t.selectedOrganisationId,o=b(t,K),i=e.useState(),u=i[0],s=i[1];return e.useEffect((function(){s(a.find((function(e){return e.organisationId===l})))}),[l,a]),v.default.createElement(m.SearchableDropdown,h({label:n,items:[].concat(a.sort((function(e,t){return e.tradingName.localeCompare(t.tradingName,"nb")})).map((function(e){return{value:e.organisationId,label:e.tradingName}}))),selectedItem:u?{value:u.organisationId,label:u.tradingName}:null,onChange:function(e){e&&r(e.value)},clearable:!1},o))},exports.PageTitle=function(e){var n=e.onBreadcrumbLookup,a=t.splitUrlPath(e.pathname).map((function(e){return{title:n(e),path:e}})).filter((function(e){return void 0!==e.title})).map((function(e){return e.title})).reverse().join(" | ");return v.default.createElement(d.Helmet,null,v.default.createElement("title",null,a," | Entur Partner"))},exports.Pager=function(e){var t=e.onPageChange,n=e.currentPage,r=Math.ceil(e.collectionSize/e.pageSize);return v.default.createElement(a.Pagination,{pageCount:r,currentPage:n,onPageChange:function(e){t(e)}})},exports.PermissionCheck=function(e){var n=e.children,a=e.fallback,r=void 0===a?null:a,l=e.permissions,o=e.oneOf,i=void 0===o?[]:o,u=e.all,s=t.hasAllPermissions(void 0===u?[]:u,l),c=t.hasOneOfPermissions(i,l);return v.default.createElement(v.default.Fragment,null,s&&c?n:r)},exports.RouteLeavingGuard=function(e){var n=e.children,a=e.shouldBlockNavigation,l=b(e,J);t.assertIsDefined(!!r.useInRouterContext()||void 0,"RouteLeavingGuard must be used within a data router.");var o=r.useBlocker((function(e){var t=e.nextLocation;return e.currentLocation.pathname!==t.pathname&&a(t)}));return v.default.createElement(S,h({onDismiss:function(){"blocked"===o.state&&o.reset()},open:"blocked"===o.state,onConfirm:function(){"blocked"===o.state&&o.proceed()}},l),n)},exports.Stack=_,exports.StatusLabel=function(e){var t=e.active,n=e.label,a=void 0===n?"":n,r=e.showBullet,l=e.center,o=g.default("eps-status-label__bullet",{active:void 0!==t&&t,aggressive:e.aggressiveInactive}),i=g.default("eps-status-label",{center:l});return v.default.createElement("div",{className:i},r&&v.default.createElement("div",{className:o}),v.default.createElement("div",null,a))},exports.Text=function(e){var t=e.as,n=void 0===t?"span":t,a=e.children,r=e.fontSize,l=e.color,o=e.lineHeight,i=e.fontWeight,u=e.className,s=b(e,Q),c=[];r&&c.push.apply(c,y("eps-font-size-",r)),o&&c.push.apply(c,y("eps-line-height-",o)),i&&c.push("eps-font-weight-"+i);var m=g.default(c,u);return v.default.createElement(P,h({as:n,color:l,className:m},s),a)},exports.Unbutton=function(e){var t=e.children,n=e.className,a=b(e,Z);return v.default.createElement(l.Button,h({variant:"primary"},a,{className:g.default("eps-unbutton",n)}),t)},exports.UserMenu=function(t){var n=t.messages,a=t.onLogout,r=t.onLanguageChange,l=t.userName,o=t.language,i=t.environment,u=t.showVersionItem,s=t.showMyProfileItem,c=t.showCookieSettingsItem,m=t.onNavigateToMyProfile,d=t.onCookieSettingsOpen,p=void 0===d?function(){}:d,f=g.default(["eps-user-menu__trigger-button",t.className]),h=e.useState(!1),E=h[1];return v.default.createElement("div",{id:"eps-user-menu"},v.default.createElement(ae,{open:h[0],onOpenChange:E,className:f,userName:l,environment:i},v.default.createElement("div",{id:"eps-overflow-menu"},v.default.createElement(re,{name:n.switchLanguage,language:o,onLanguageChange:r,setOpen:E}),u&&n.appVersion&&v.default.createElement(ie,{title:n.appVersion,setOpen:E}),s&&n.myProfile&&v.default.createElement(oe,{name:n.myProfile,setOpen:E,onNavigateToMyProfile:m}),c&&n.cookieSettings&&v.default.createElement(ee,{name:n.cookieSettings,setOpen:E,onCookieSettingsOpen:p}),v.default.createElement(le,{name:n.logout,setOpen:E,onLogout:a}))))},exports.featureFlag=R,exports.getColorForEnvironment=z,exports.getHumanReadableEnvironment=D,exports.responsiveProp=y,exports.useEventListener=function(t,n,a){void 0===a&&(a=window);var r=e.useRef();e.useEffect((function(){r.current=n}),[n]),e.useEffect((function(){var e;if(null==(e=a)?void 0:e.addEventListener){var n=function(e){return null==r.current?void 0:r.current(e)};return a.addEventListener(t,n),function(){a.removeEventListener(t,n)}}}),[t,a])},exports.useFeatureToggle=H;
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),n=require("@entur-partner/util"),t=require("classnames"),a=require("@entur/menu"),r=require("react-router-dom"),o=require("@entur/button"),i=require("@entur/modal"),l=require("@entur/typography"),s=require("@entur/alert"),c=require("@entur/expand"),u=require("@entur/form"),m=require("react-helmet-async"),p=require("@entur/dropdown"),d=require("@entur/icons");function v(){return v=Object.assign?Object.assign.bind():function(e){for(var n=1;n<arguments.length;n++){var t=arguments[n];for(var a in t)({}).hasOwnProperty.call(t,a)&&(e[a]=t[a])}return e},v.apply(null,arguments)}function g(e,n){if(null==e)return{};var t={};for(var a in e)if({}.hasOwnProperty.call(e,a)){if(-1!==n.indexOf(a))continue;t[a]=e[a]}return t}function f(e,n){return f=Object.setPrototypeOf?Object.setPrototypeOf.bind():function(e,n){return e.__proto__=n,e},f(e,n)}var h=["date","locale","as","hideTime"],E=function(t){var a=t.date,r=t.locale,o=t.as,i=void 0===o?"main":o,l=t.hideTime,s=g(t,h);return e.createElement(i,v({},s),l?n.localeDate(a,r):n.localeDateTime(a,r))},b=["as","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"];function x(e,n){if(Array.isArray(n)){var t=[];return n[0]&&t.push(e+n[0]),n[1]&&t.push(""+e+n[1]+"-lg"),n[2]&&t.push(""+e+n[2]+"-xl"),t}return[e+n]}var N,C,y,L=function(n){var a=n.as,r=void 0===a?"div":a,o=n.children,i=n.contrast,l=n.paddingTop,s=n.paddingRight,c=n.paddingBottom,u=n.paddingLeft,m=n.paddingX,p=n.paddingY,d=n.padding,f=n.marginTop,h=n.marginRight,E=n.marginBottom,N=n.marginLeft,C=n.marginX,y=n.marginY,L=n.margin,w=n.display,k=n.justifyContent,P=n.alignItems,_=n.maxWidth,O=n.width,B=n.background,S=n.color,I=n.flexDirection,z=n.flexWrap,F=n.className,D=g(n,b),M=[],T=l||p||d,V=c||p||d,A=u||m||d,q=s||m||d,j=f||y||L,R=E||y||L,H=N||C||L,U=h||C||L;i&&M.push("eds-contrast"),T&&M.push.apply(M,x("eps-pt-",T)),V&&M.push.apply(M,x("eps-pb-",V)),A&&M.push.apply(M,x("eps-pl-",A)),q&&M.push.apply(M,x("eps-pr-",q)),j&&M.push.apply(M,x("eps-mt-",j)),R&&M.push.apply(M,x("eps-mb-",R)),H&&M.push.apply(M,x("eps-ml-",H)),U&&M.push.apply(M,x("eps-mr-",U)),w&&M.push.apply(M,x("eps-",w)),k&&M.push.apply(M,x("eps-justify-",k)),P&&M.push.apply(M,x("eps-items-",P)),_&&M.push.apply(M,x("eps-max-w-",_)),O&&M.push.apply(M,x("eps-w-",O)),S&&M.push("eps-color-"+S),B&&M.push("eps-bg-"+B),I&&M.push.apply(M,x("eps-flex-",I)),z&&M.push.apply(M,x("eps-flex-wrap-",z));var W=t(M,F);return e.createElement(r,v({className:W},D),o)},w=function(n){var t=n.space,a=n.className,r=e.Children.toArray(n.children);return r.length<=1?e.createElement(e.Fragment,null,r):e.createElement("div",{className:a},r.map(function(n,a){return a===r.length-1?e.createElement("div",{key:a},n):e.createElement(L,{paddingBottom:t,key:a},n)}))},k=["items","locale","className"],P=["isOpen","children","message","size","buttons","onConfirm","messages","onClose","onDismiss"],_=function(t){var a=t.isOpen,r=void 0!==a&&a,s=t.children,c=t.message,u=t.size,m=void 0===u?"medium":u,p=t.buttons,d=t.onConfirm,f=t.messages,h=t.onClose,E=t.onDismiss,b=g(t,P),x=s||c,N=h||E;return e.createElement(i.Modal,v({size:m,open:r,onDismiss:N},b),n.isString(x)?e.createElement(l.Paragraph,null,x):e.createElement(L,{paddingBottom:"medium"},x),e.createElement(o.ButtonGroup,null,d?e.createElement(e.Fragment,null,e.createElement(o.SecondaryButton,{onClick:N,"data-testid":"cancel-modal-button"},f.cancel),e.createElement(o.PrimaryButton,{onClick:d,"data-testid":"confirm-modal-button"},f.confirm)):p))};exports.Environment=void 0,(y=exports.Environment||(exports.Environment={})).Local="local",y.Development="dev",y.Staging="staging",y.Production="prod";var O=((N={})[exports.Environment.Local]="#B482FB",N[exports.Environment.Development]="#5AC39A",N[exports.Environment.Staging]="#FFCA28",N),B=function(e){return O[e]},S=((C={})[exports.Environment.Local]="Local",C[exports.Environment.Development]="Dev",C[exports.Environment.Staging]="Staging",C[exports.Environment.Production]="Prod",C),I=function(e){return S[e]},z=["title","accentColor"],F=function(n){var t=n.title,a=n.accentColor,r=void 0===a?"#FF5959":a,o=g(n,z);return e.createElement("svg",v({width:257,height:37,viewBox:"0 0 257 37"},o),e.createElement("title",null,t),e.createElement("g",{fill:"none",fillRule:"evenodd"},e.createElement("path",{fill:"#FFF",d:"M0 .231V25.72h18.745v-4.318H4.869v-6.163h12.31v-4.318H4.87V4.55h13.876V.231z"}),e.createElement("path",{fill:r,d:"M0 36.408h45.253v-4.32H0z"}),e.createElement("path",{fill:"#FFF",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"}),e.createElement("g",{fill:r},e.createElement("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"}))))},D=function(t){function a(e){var n;return(n=t.call(this,e)||this).state={error:null},n}var r,o;o=t,(r=a).prototype=Object.create(o.prototype),r.prototype.constructor=r,f(r,o),a.getDerivedStateFromError=function(e){return{error:e}};var i=a.prototype;return i.componentDidCatch=function(e,n){var t,a;null==(t=(a=this.props).handleError)||t.call(a,e,n)},i.render=function(){var t=this,a=this.state.error,r=this.props,o=r.fallback,i=r.children;return a?n.isFunction(o)?o({retry:function(){return t.setState({error:null})},error:a}):"NotFoundError"===a.name&&"Failed to execute 'removeChild' on 'Node': The node to be removed is not a child of this node."===a.message?e.createElement(T,null):o:i},a}(e.Component),M="EP::locale";function T(){var n=localStorage.getItem(M),t="nb"===n||"nb-NO"===n;return e.createElement(L,{maxWidth:"large"},e.createElement(s.BannerAlertBox,{variant:"info",title:t?"En ny versjon av nettsiden er tilgjengelig.":"A new version of the website is available."},e.createElement(L,{paddingBottom:"medium"},e.createElement(l.Paragraph,{margin:"none"},t?"Vennligst oppdater.":"Please refresh.")),e.createElement(o.PrimaryButton,{onClick:function(){return window.location.reload()}},t?"Oppdater":"Refresh")))}var V=["title","inputComponent","languages","values","onChange","name","variant","feedback"];function A(e){var n,t;return"true"===(void 0)["VITE_APP_"+e]||"true"===(null==(n=window.localStorage)?void 0:n.getItem(e))||"true"===(null==(t=window.localStorage)?void 0:t.getItem("VITE_APP_"+e))}function q(e){return A(e)}var j=["amount","as"],R=["language","options","className","onChange"],H=function(a){var r=a.language,o=a.options,i=a.className,l=a.onChange,s=g(a,R),c=t("eps-language-select",i);return e.createElement("div",v({},s,{className:c}),e.createElement(u.SegmentedControl,{onChange:function(e){n.assertIsDefined(e),l(e)},selectedValue:r},o.map(function(n){return e.createElement(u.SegmentedChoice,{key:n.value,value:n.value},n.label,n.required&&e.createElement("span",{className:"asterisk-margin"},"*"))})))},U=["children","className"],W=["className","inputComponent","alertLabel","alertLevel","name","languages","values","onChange","defaultLanguage","label","onBlur"],G=["label","organisations","onChange","selectedOrganisationId"],Y=["children","shouldBlockNavigation"],X=["as","children","fontSize","color","lineHeight","fontWeight","className"],K=["children","className"],J=function(n){return e.createElement("button",v({className:t(n.className,"eps-overflow-menu__item"),role:"menuitem"},n))},Q=function(n){var t=n.name,a=n.setOpen,r=n.onCookieSettingsOpen;return e.createElement(J,{onClick:function(){r(),a(!1)},className:"eps-overflow-menu__item"},e.createElement("span",{"aria-hidden":!0},e.createElement(d.CookieIcon,{size:"1rem",inline:!0})),t)};function Z(e,n){return!(!e||!(e.contains(n.target)||n.composed&&n.composedPath&&n.composedPath().find(function(n){return n!==window&&e.contains(n)})))}var $=["className","children","userName","open","onOpenChange","environment"],ee=function(n){var a,r,i,s=n.className,c=n.children,u=n.userName,m=n.open,p=n.onOpenChange,f=n.environment,h=g(n,$),E=t("eps-overflow-menu__group",{"eps-overflow-menu__group--open":m}),b=e.useRef(null),x=e.useRef(null);return e.useEffect(function(){var e=function(e){Z(a.current,e)||Z(r.current,e)||i()};return document.addEventListener("mousedown",e),document.addEventListener("touchstart",e),function(){document.removeEventListener("mousedown",e),document.removeEventListener("touchstart",e)}},[a=b,r=x,i=function(){return p(!1)}]),e.createElement("div",null,e.createElement(o.SecondaryButton,v({className:t("eps-overflow-menu__button",s),onClick:function(){return p(!m)},"aria-haspopup":!0,"aria-expanded":m,ref:x},h),e.createElement("div",{className:"eps-overflow-menu__button-contents"},e.createElement("span",{className:"eds-overflow-menu__user-icon"},e.createElement(d.UserIcon,{inline:!0})),e.createElement(l.Heading6,{margin:"none",as:"span"},u,void 0!==f&&f!==exports.Environment.Production&&e.createElement("span",{style:{color:B(f)}}," ","(",I(f),")")),e.createElement("span",{className:"eps-arrow-icon"},e.createElement(d.DownArrowIcon,{inline:!0})))),m&&e.createElement("div",{className:E,role:"menu",ref:b},c))},ne=function(n){var t=n.language,a=n.onLanguageChange,r=n.setOpen,o=n.name,i=q("USE_BCP-47_LANGUAGE_KEY"),l=i?"nb-NO":"nb",s=i?"en-GB":"en";return e.createElement(e.Fragment,null,t===s?e.createElement(J,{onClick:function(){a(l),r(!1)},className:"eps-overflow-menu__item"},e.createElement("span",{"aria-hidden":!0,className:"eps-overflow-menu__icon-margin"},e.createElement(d.NorwayIcon,{size:"1rem",inline:!0})),o):e.createElement(J,{onClick:function(){a(s),r(!1)},className:"eps-overflow-menu__item"},e.createElement("span",{"aria-hidden":!0,className:"eps-overflow-menu__icon-margin"},e.createElement(d.UKIcon,{size:"1rem",inline:!0})),o))},te=function(n){var t=n.name,a=n.setOpen,r=n.onLogout;return e.createElement(J,{onClick:function(){r(),a(!1)},"data-testid":"user-menu-logout",className:"eps-overflow-menu__item"},e.createElement("span",{"aria-hidden":!0},e.createElement(d.LogOutIcon,{size:"1rem",inline:!0})),t)},ae=function(n){var t=n.name,a=n.setOpen,o=n.onNavigateToMyProfile;return e.createElement(r.Link,{to:"/permission-admin/my-profile",style:{textDecoration:"none"}},e.createElement(J,{onClick:function(){a(!1),o()},className:"eps-overflow-menu__item"},e.createElement("span",{"aria-hidden":!0},e.createElement(d.UserIcon,{size:"1rem",inline:!0})),t))},re=function(n){var t=n.title,a=n.setOpen,o=r.useNavigate();return e.createElement(J,{onClick:function(){o("/app-version"),a(!1)},className:"eps-overflow-menu__item"},e.createElement("span",{"aria-hidden":!0},e.createElement(d.ChannelsIcon,{className:"eps-version-icon",size:"1rem",inline:!0})),t)};exports.ActionBar=function(n){var t=n.children;return e.createElement(e.Fragment,null,e.createElement("div",{className:"eps-action-bar-padding"}),e.createElement("div",{className:"eps-action-bar"},t))},exports.ActionBarLeft=function(n){return e.createElement("div",{className:"eps-action-bar-left"},n.children)},exports.ActionBarRight=function(n){return e.createElement("div",{className:"eps-action-bar-right"},n.children)},exports.AuditInfo=function(a){var r=a.items,o=a.locale,i=a.className,l=g(a,k),s=t("ep-audit-info",i);return e.createElement("div",v({className:s},l),r.map(function(t){var a=t.label,r=t.value;return e.createElement(w,{space:"small",key:r.toString()},e.createElement("div",{className:"ep-audit-info-label"},a),e.createElement("div",null,n.isDate(r)||n.isDateString(r)?e.createElement(E,{date:r,locale:o}):e.createElement("span",null,r)))}))},exports.Box=L,exports.Breadcrumbs=function(t){var o=t.prependBreadcrumbItem,i=t.onBreadcrumbLookup,l=n.splitUrlPath(t.pathname).map(function(e){return{title:i(e),path:e}}).filter(function(e){return void 0!==e.title}),s=l.map(function(n,t){var o=n.path;return e.createElement(a.BreadcrumbItem,t===l.length-1?{key:o,as:"span"}:{key:o,as:r.Link,to:o},n.title)});return e.createElement(a.BreadcrumbNavigation,null,o?[o].concat(s):s)},exports.ConfirmModal=_,exports.Content=function(n){var a=n.as,r=void 0===a?"main":a,o=n.children,i=t(["eps-content",n.className]);return e.createElement(r,{className:i},o)},exports.EnturPartnerLogo=function(n){var a=n.as,r=void 0===a?"nav":a,o=n.altText,i=n.environment,l=t(["eps-logo-wrapper",n.className]);return e.createElement(r,{className:l},e.createElement(F,{title:o,className:"logo",accentColor:void 0!==i&&i!==exports.Environment.Production?B(i):void 0}))},exports.EnturPartnerLogoSvg=F,exports.ErrorBoundary=D,exports.ExpandableMultiLanguageInput=function(n){var t=n.title,a=n.inputComponent,r=n.languages,o=n.values,i=n.onChange,l=n.name,s=n.variant,u=n.feedback,m=g(n,V);return e.createElement(c.ExpandablePanel,{title:t,defaultOpen:!0,contentStyle:{padding:"4px 4px 4px 4px",marginTop:"16px",marginBottom:"16px"}},e.createElement(w,{space:"medium"},r.map(function(n){var r=n.value,c=n.label;return e.createElement(a,v({"data-testid":"multi-lang-input-"+l+"-"+r,key:t+r,label:n.required?c+"*":c,variant:null==s?void 0:s(r),feedback:null==u?void 0:u(r),name:l,onChange:function(e){var n,t,a;n=r,t=e.target.value,a=v({},o),""!==t&&t?a[n]=t:delete a[n],i(a)},value:o[r]||""},m))})))},exports.FeatureToggle=function(n){var t=n.children;return q(n.flag)?e.createElement(e.Fragment,null,t):null},exports.FormatCurrencyAmount=function(n){var t=n.amount,a=n.as,r=void 0===a?"span":a,o=g(n,j),i=Number(t)||0,l=new Intl.NumberFormat("nb-NO",{maximumFractionDigits:2,minimumFractionDigits:2}).format(i);return e.createElement(r,v({},o),l)},exports.FormatDateTime=E,exports.LanguageSelect=H,exports.LegacyPageTitle=function(t){var a=t.onBreadcrumbLookup,r=n.splitUrlPath(t.pathname).map(function(e){return{title:a(e),path:e}}).filter(function(e){return void 0!==e.title}).map(function(e){return e.title}).reverse().join(" | ");return e.createElement(m.Helmet,null,e.createElement("title",null,r," | Entur Partner"))},exports.Link=function(n){return e.createElement(l.Link,v({},n,{as:r.Link}),n.children)},exports.LinkButton=function(n){var a=n.children,r=n.className,o=g(n,U);return e.createElement(l.Link,v({},o,{as:"button",className:t("eps-link-button",r)}),a)},exports.Menu=function(n){var a=n.as,r=void 0===a?"nav":a,o=n.children,i=t(["eds-contrast","eps-menu",n.className]);return e.createElement(r,{className:i},o)},exports.MultiLanguageInput=function(n){var a=n.className,r=n.inputComponent,o=n.alertLabel,i=n.alertLevel,l=n.name,s=n.languages,c=n.values,u=n.onChange,m=n.defaultLanguage,p=void 0===m?"nob":m,d=n.label,f=void 0===d?"":d,h=n.onBlur,E=void 0===h?function(){}:h,b=g(n,W),x=e.useState(p),N=x[0],C=x[1],y=t("multi-language-input",a),L=c[N];return e.createElement("div",{className:y,tabIndex:0,onBlur:function(e){e.persist();var n=e.currentTarget;setTimeout(function(){n&&!n.contains(document.activeElement)&&E(e)},0)},"data-testid":"multi-lang-input-"+l},e.createElement(w,{space:"extraSmall"},e.createElement(H,{language:N,options:s,onChange:function(e){return function(e){C(e)}(e)}}),e.createElement(r,v({label:f,variant:i,feedback:o,name:l,className:"language-item",onChange:function(e){return n=e.target.value,t=Object.assign({},c),""!==n&&n?t[N]=n:delete t[N],void u(t);var n,t},value:L||""},b))))},exports.OrganisationDropDown=function(n){var t=n.label,a=n.organisations,r=n.onChange,o=n.selectedOrganisationId,i=g(n,G),l=e.useState(),s=l[0],c=l[1];return e.useEffect(function(){c(a.find(function(e){return e.organisationId===o}))},[o,a]),e.createElement(p.SearchableDropdown,v({label:t,items:[].concat(a.sort(function(e,n){return e.tradingName.localeCompare(n.tradingName,"nb")}).map(function(e){return{value:e.organisationId,label:e.tradingName}})),selectedItem:s?{value:s.organisationId,label:s.tradingName}:null,onChange:function(e){e&&r(e.value)},clearable:!1},i))},exports.PageTitle=function(t){var a=t.onBreadcrumbLookup,r=n.splitUrlPath(t.pathname).map(function(e){return{title:a(e),path:e}}).filter(function(e){return void 0!==e.title}).map(function(e){return e.title}).reverse().join(" | ");return e.useEffect(function(){document.title=r+" | Entur Partner"},[r]),null},exports.Pager=function(n){var t=n.onPageChange,r=n.currentPage,o=Math.ceil(n.collectionSize/n.pageSize);return e.createElement(a.Pagination,{pageCount:o,currentPage:r,onPageChange:function(e){t(e)}})},exports.PermissionCheck=function(t){var a=t.children,r=t.fallback,o=void 0===r?null:r,i=t.permissions,l=t.oneOf,s=void 0===l?[]:l,c=t.all,u=n.hasAllPermissions(void 0===c?[]:c,i),m=n.hasOneOfPermissions(s,i);return e.createElement(e.Fragment,null,u&&m?a:o)},exports.RouteLeavingGuard=function(t){var a=t.children,o=t.shouldBlockNavigation,i=g(t,Y);n.assertIsDefined(!!r.useInRouterContext()||void 0,"RouteLeavingGuard must be used within a data router.");var l=r.useBlocker(function(e){var n=e.nextLocation;return e.currentLocation.pathname!==n.pathname&&o(n)});return e.createElement(_,v({onDismiss:function(){"blocked"===l.state&&l.reset()},open:"blocked"===l.state,onConfirm:function(){"blocked"===l.state&&l.proceed()}},i),a)},exports.Stack=w,exports.StatusLabel=function(n){var a=n.active,r=n.label,o=void 0===r?"":r,i=n.showBullet,l=n.center,s=t("eps-status-label__bullet",{active:void 0!==a&&a,aggressive:n.aggressiveInactive}),c=t("eps-status-label",{center:l});return e.createElement("div",{className:c},i&&e.createElement("div",{className:s}),e.createElement("div",null,o))},exports.Text=function(n){var a=n.as,r=void 0===a?"span":a,o=n.children,i=n.fontSize,l=n.color,s=n.lineHeight,c=n.fontWeight,u=n.className,m=g(n,X),p=[];i&&p.push.apply(p,x("eps-font-size-",i)),s&&p.push.apply(p,x("eps-line-height-",s)),c&&p.push("eps-font-weight-"+c);var d=t(p,u);return e.createElement(L,v({as:r,color:l,className:d},m),o)},exports.Unbutton=function(n){var a=n.children,r=n.className,i=g(n,K);return e.createElement(o.Button,v({variant:"primary"},i,{className:t("eps-unbutton",r)}),a)},exports.UserMenu=function(n){var a=n.messages,r=n.onLogout,o=n.onLanguageChange,i=n.userName,l=n.language,s=n.environment,c=n.showVersionItem,u=n.showMyProfileItem,m=n.showCookieSettingsItem,p=n.onNavigateToMyProfile,d=n.onCookieSettingsOpen,v=void 0===d?function(){}:d,g=t(["eps-user-menu__trigger-button",n.className]),f=e.useState(!1),h=f[1];return e.createElement("div",{id:"eps-user-menu"},e.createElement(ee,{open:f[0],onOpenChange:h,className:g,userName:i,environment:s},e.createElement("div",{id:"eps-overflow-menu"},e.createElement(ne,{name:a.switchLanguage,language:l,onLanguageChange:o,setOpen:h}),c&&a.appVersion&&e.createElement(re,{title:a.appVersion,setOpen:h}),u&&a.myProfile&&e.createElement(ae,{name:a.myProfile,setOpen:h,onNavigateToMyProfile:p}),m&&a.cookieSettings&&e.createElement(Q,{name:a.cookieSettings,setOpen:h,onCookieSettingsOpen:v}),e.createElement(te,{name:a.logout,setOpen:h,onLogout:r}))))},exports.featureFlag=A,exports.getColorForEnvironment=B,exports.getHumanReadableEnvironment=I,exports.responsiveProp=x,exports.useEventListener=function(n,t,a){void 0===a&&(a=window);var r=e.useRef();e.useEffect(function(){r.current=t},[t]),e.useEffect(function(){var e;if(null==(e=a)?void 0:e.addEventListener){var t=function(e){return null==r.current?void 0:r.current(e)};return a.addEventListener(n,t),function(){a.removeEventListener(n,t)}}},[n,a])},exports.useFeatureToggle=q;
|
|
2
2
|
//# sourceMappingURL=common.cjs.production.min.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"common.cjs.production.min.js","sources":["../src/FormatDateTime.tsx","../src/Box.tsx","../src/environment.ts","../src/Stack.tsx","../src/ConfirmModal.tsx","../src/EnturPartnerLogo.tsx","../src/ErrorBoundary.tsx","../src/FeatureToggle.tsx","../src/LanguageSelect.tsx","../src/UserMenu/components/CustomOverflowMenuItem.tsx","../src/UserMenu/components/CookieSettingsMenuItem.tsx","../src/UserMenu/useOutsideClick.ts","../src/UserMenu/components/CustomOverflowMenu.tsx","../src/UserMenu/components/LanguageSwitchMenuItem.tsx","../src/UserMenu/components/LogOutMenuItem.tsx","../src/UserMenu/components/UserMenuItem.tsx","../src/UserMenu/components/VersionMenuItem.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/PageTitle.tsx","../src/Pager.tsx","../src/PermissionCheck.tsx","../src/RouteLeavingGuard.tsx","../src/StatusLabel.tsx","../src/Text.tsx","../src/Unbutton.tsx","../src/UserMenu/index.tsx","../src/useEventListener.ts"],"sourcesContent":["import { localeDate, localeDateTime } from \"@entur-partner/util\";\nimport React, { type FC } from \"react\";\n\nexport interface FormatDateTimeProps {\n\tdate: string | Date;\n\tlocale: string;\n\t// biome-ignore lint/suspicious/noExplicitAny: Ignore for now.\n\t[key: string]: any;\n}\n\nexport const FormatDateTime: FC<FormatDateTimeProps> = ({\n\tdate,\n\tlocale,\n\tas: Component = \"main\",\n\thideTime,\n\t...rest\n}) => {\n\treturn (\n\t\t<Component {...rest}>\n\t\t\t{hideTime ? localeDate(date, locale) : localeDateTime(date, locale)}\n\t\t</Component>\n\t);\n};\n","import \"./Box.scss\";\n\nimport cx from \"classnames\";\nimport type { ReactNode } from \"react\";\nimport React from \"react\";\n\ntype StyleSpacing =\n\t| \"none\"\n\t| \"extraSmall2\"\n\t| \"extraSmall\"\n\t| \"small\"\n\t| \"medium\"\n\t| \"large\"\n\t| \"extraLarge\"\n\t| \"extraLarge2\"\n\t| \"extraLarge3\"\n\t| \"extraLarge4\"\n\t| \"extraLarge5\"\n\t| \"extraLarge6\"\n\t| \"extraLarge7\"\n\t| \"extraLarge8\"\n\t| \"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\t| \"none\"\n\t| \"extraSmall\"\n\t| \"small\"\n\t| \"medium\"\n\t| \"large\"\n\t| \"extraLarge\"\n\t| \"extraLarge2\"\n\t| \"extraLarge3\"\n\t| \"extraLarge4\"\n\t| \"extraLarge5\"\n\t| \"extraLarge6\"\n\t| \"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\t| StyleSpacing\n\t| [StyleSpacing?, StyleSpacing?, StyleSpacing?];\nexport type ResponsiveStyleMargin =\n\t| StyleMargin\n\t| [StyleMargin?, StyleMargin?, StyleMargin?];\n\nexport type ResponsiveStyleDisplay =\n\t| StyleDisplay\n\t| [StyleDisplay?, StyleDisplay?, StyleDisplay?];\nexport type ResponsiveStyleJustifyContent =\n\t| StyleJustifyContent\n\t| [StyleJustifyContent?, StyleJustifyContent?, StyleJustifyContent?];\nexport type ResponsiveStyleAlignItems =\n\t| StyleAlignItems\n\t| [StyleAlignItems?, StyleAlignItems?, StyleAlignItems?];\n\nexport type ResponsiveStyleMaxWidth =\n\t| StyleMaxWidth\n\t| [StyleMaxWidth?, StyleMaxWidth?, StyleMaxWidth?];\nexport type ResponsiveStyleWidth =\n\t| StyleWidth\n\t| [StyleWidth?, StyleWidth?, StyleWidth?];\n\nexport type ResponsiveStyleFlexDirection =\n\t| StyleFlexDirection\n\t| [StyleFlexDirection?, StyleFlexDirection?, StyleFlexDirection?];\nexport type ResponsiveStyleFlexWrap =\n\t| StyleFlexWrap\n\t| [StyleFlexWrap?, StyleFlexWrap?, StyleFlexWrap?];\n\nexport interface BoxProps {\n\tclassName?: string;\n\tas?: React.ElementType;\n\t[key: string]: object | string | number | boolean | undefined | ReactNode;\n\tchildren: ReactNode;\n\n\tcontrast?: boolean;\n\n\tpaddingTop?: ResponsiveStyleSpacing;\n\tpaddingRight?: ResponsiveStyleSpacing;\n\tpaddingBottom?: ResponsiveStyleSpacing;\n\tpaddingLeft?: ResponsiveStyleSpacing;\n\tpaddingX?: ResponsiveStyleSpacing;\n\tpaddingY?: ResponsiveStyleSpacing;\n\tpadding?: ResponsiveStyleSpacing;\n\n\tmarginTop?: ResponsiveStyleMargin;\n\tmarginRight?: ResponsiveStyleMargin;\n\tmarginBottom?: ResponsiveStyleMargin;\n\tmarginLeft?: ResponsiveStyleMargin;\n\tmarginX?: ResponsiveStyleMargin;\n\tmarginY?: ResponsiveStyleMargin;\n\tmargin?: ResponsiveStyleMargin;\n\n\tdisplay?: ResponsiveStyleDisplay;\n\tjustifyContent?: ResponsiveStyleJustifyContent;\n\talignItems?: ResponsiveStyleAlignItems;\n\n\tmaxWidth?: ResponsiveStyleMaxWidth;\n\twidth?: ResponsiveStyleWidth;\n\tbackground?: StyleBackground;\n\tcolor?: StyleColor;\n\n\tflexDirection?: ResponsiveStyleFlexDirection;\n\tflexWrap?: ResponsiveStyleFlexWrap;\n}\n\ntype ResponsiveProp = string | [string?, string?, string?];\n\nexport function responsiveProp(prefix: string, prop: ResponsiveProp): string[] {\n\tif (Array.isArray(prop)) {\n\t\tconst classes = [];\n\t\tprop[0] && classes.push(prefix + prop[0]);\n\t\tprop[1] && classes.push(`${prefix}${prop[1]}-lg`);\n\t\tprop[2] && classes.push(`${prefix}${prop[2]}-xl`);\n\t\treturn classes;\n\t}\n\treturn [prefix + prop];\n}\n\nexport const Box = ({\n\tas: Component = \"div\",\n\tchildren,\n\tcontrast,\n\tpaddingTop,\n\tpaddingRight,\n\tpaddingBottom,\n\tpaddingLeft,\n\tpaddingX,\n\tpaddingY,\n\tpadding,\n\tmarginTop,\n\tmarginRight,\n\tmarginBottom,\n\tmarginLeft,\n\tmarginX,\n\tmarginY,\n\tmargin,\n\tdisplay,\n\tjustifyContent,\n\talignItems,\n\tmaxWidth,\n\twidth,\n\tbackground,\n\tcolor,\n\tflexDirection,\n\tflexWrap,\n\tclassName,\n\t...rest\n}: BoxProps) => {\n\tconst classes = [];\n\tconst resolvedPaddingTop = paddingTop || paddingY || padding;\n\tconst resolvedPaddingBottom = paddingBottom || paddingY || padding;\n\tconst resolvedPaddingLeft = paddingLeft || paddingX || padding;\n\tconst resolvedPaddingRight = paddingRight || paddingX || padding;\n\n\tconst resolvedMarginTop = marginTop || marginY || margin;\n\tconst resolvedMarginBottom = marginBottom || marginY || margin;\n\tconst resolvedMarginLeft = marginLeft || marginX || margin;\n\tconst resolvedMarginRight = marginRight || marginX || margin;\n\n\tcontrast && classes.push(\"eds-contrast\");\n\tresolvedPaddingTop &&\n\t\tclasses.push(...responsiveProp(\"eps-pt-\", resolvedPaddingTop));\n\tresolvedPaddingBottom &&\n\t\tclasses.push(...responsiveProp(\"eps-pb-\", resolvedPaddingBottom));\n\tresolvedPaddingLeft &&\n\t\tclasses.push(...responsiveProp(\"eps-pl-\", resolvedPaddingLeft));\n\tresolvedPaddingRight &&\n\t\tclasses.push(...responsiveProp(\"eps-pr-\", resolvedPaddingRight));\n\tresolvedMarginTop &&\n\t\tclasses.push(...responsiveProp(\"eps-mt-\", resolvedMarginTop));\n\tresolvedMarginBottom &&\n\t\tclasses.push(...responsiveProp(\"eps-mb-\", resolvedMarginBottom));\n\tresolvedMarginLeft &&\n\t\tclasses.push(...responsiveProp(\"eps-ml-\", resolvedMarginLeft));\n\tresolvedMarginRight &&\n\t\tclasses.push(...responsiveProp(\"eps-mr-\", resolvedMarginRight));\n\n\tdisplay && classes.push(...responsiveProp(\"eps-\", display));\n\tjustifyContent &&\n\t\tclasses.push(...responsiveProp(\"eps-justify-\", justifyContent));\n\tif (alignItems) {\n\t\tclasses.push(...responsiveProp(\"eps-items-\", alignItems));\n\t}\n\n\tmaxWidth && classes.push(...responsiveProp(\"eps-max-w-\", maxWidth));\n\twidth && classes.push(...responsiveProp(\"eps-w-\", width));\n\n\tcolor && classes.push(`eps-color-${color}`);\n\tbackground && classes.push(`eps-bg-${background}`);\n\n\tflexDirection && classes.push(...responsiveProp(\"eps-flex-\", flexDirection));\n\tflexWrap && classes.push(...responsiveProp(\"eps-flex-wrap-\", flexWrap));\n\n\tconst classList = cx(classes, className);\n\n\treturn (\n\t\t<Component className={classList} {...rest}>\n\t\t\t{children}\n\t\t</Component>\n\t);\n};\n","export enum Environment {\n\tLocal = \"local\",\n\tDevelopment = \"dev\",\n\tStaging = \"staging\",\n\tProduction = \"prod\",\n}\n\nconst environmentColors: Record<\n\tExclude<Environment, Environment.Production>,\n\tstring\n> = {\n\t[Environment.Local]: \"#B482FB\",\n\t[Environment.Development]: \"#5AC39A\",\n\t[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\tenvironment: Exclude<Environment, Environment.Production>,\n) => environmentColors[environment];\n\nconst humanReadableEnvironment: Record<Environment, string> = {\n\t[Environment.Local]: \"Local\",\n\t[Environment.Development]: \"Dev\",\n\t[Environment.Staging]: \"Staging\",\n\t[Environment.Production]: \"Prod\",\n};\n\nexport const getHumanReadableEnvironment = (environment: Environment) =>\n\thumanReadableEnvironment[environment];\n","/** biome-ignore-all lint/suspicious/noArrayIndexKey: Ignore for now. Should be tested properly before doing changes */\nimport React, { Children, type ReactNode } from \"react\";\n\nimport { Box, type ResponsiveStyleSpacing } from \"./Box\";\n\nexport interface StackProps {\n\tclassName?: string;\n\tchildren: ReactNode;\n\tspace: ResponsiveStyleSpacing;\n}\n\nexport const Stack = ({ children, space, className }: StackProps) => {\n\tconst stackItems = Children.toArray(children);\n\tif (stackItems.length <= 1) {\n\t\treturn <>{stackItems}</>;\n\t}\n\n\treturn (\n\t\t<div className={className}>\n\t\t\t{stackItems.map((child, index) =>\n\t\t\t\tindex === stackItems.length - 1 ? (\n\t\t\t\t\t<div key={index}>{child}</div>\n\t\t\t\t) : (\n\t\t\t\t\t<Box paddingBottom={space} key={index}>\n\t\t\t\t\t\t{child}\n\t\t\t\t\t</Box>\n\t\t\t\t),\n\t\t\t)}\n\t\t</div>\n\t);\n};\n","import \"./ConfirmModal.scss\";\n\nimport { ButtonGroup, PrimaryButton, SecondaryButton } from \"@entur/button\";\nimport { Modal, type ModalProps } from \"@entur/modal\";\nimport { Paragraph } from \"@entur/typography\";\nimport { isString } from \"@entur-partner/util\";\nimport type { FC, ReactNode } from \"react\";\nimport React from \"react\";\n\nimport { Box } from \"./Box\";\n\nexport interface BaseConfirmModalProps extends Partial<ModalProps> {\n\ttitle: string;\n\tchildren: React.ReactNode;\n\tcloseLabel: string;\n\n\t/** Deprecated use children prop */\n\tmessage?: ReactNode;\n\t/** Deprecated use open prop */\n\tisOpen?: boolean;\n\t/** Deprecated use onDismiss prop */\n\tonClose?: () => void;\n}\n\ninterface CustomConfirmModalButtons extends BaseConfirmModalProps {\n\tbuttons: ReactNode[];\n}\n\ninterface DefaultConfirmModalHandler extends BaseConfirmModalProps {\n\tonConfirm: () => void;\n\tmessages: {\n\t\tconfirm: string;\n\t\tcancel: string;\n\t};\n}\n\nexport type ConfirmModalProps =\n\t| CustomConfirmModalButtons\n\t| DefaultConfirmModalHandler;\n\nexport const ConfirmModal: FC<ConfirmModalProps> = ({\n\tisOpen = false,\n\tchildren,\n\tmessage,\n\tsize = \"medium\",\n\tbuttons,\n\tonConfirm,\n\tmessages,\n\tonClose,\n\tonDismiss,\n\t...rest\n}) => {\n\tconst childrenToRender = children ? children : message;\n\tconst handleDismiss = onClose ? onClose : onDismiss;\n\treturn (\n\t\t<Modal size={size} open={isOpen} onDismiss={handleDismiss} {...rest}>\n\t\t\t{isString(childrenToRender) ? (\n\t\t\t\t<Paragraph>{childrenToRender}</Paragraph>\n\t\t\t) : (\n\t\t\t\t<Box paddingBottom=\"medium\">{childrenToRender}</Box>\n\t\t\t)}\n\n\t\t\t<ButtonGroup>\n\t\t\t\t{onConfirm ? (\n\t\t\t\t\t<>\n\t\t\t\t\t\t<SecondaryButton\n\t\t\t\t\t\t\tonClick={handleDismiss}\n\t\t\t\t\t\t\tdata-testid=\"cancel-modal-button\"\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{messages.cancel}\n\t\t\t\t\t\t</SecondaryButton>\n\t\t\t\t\t\t<PrimaryButton\n\t\t\t\t\t\t\tonClick={onConfirm}\n\t\t\t\t\t\t\tdata-testid=\"confirm-modal-button\"\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{messages.confirm}\n\t\t\t\t\t\t</PrimaryButton>\n\t\t\t\t\t</>\n\t\t\t\t) : (\n\t\t\t\t\tbuttons\n\t\t\t\t)}\n\t\t\t</ButtonGroup>\n\t\t</Modal>\n\t);\n};\n","import \"./EnturPartnerLogo.scss\";\n\nimport classnames from \"classnames\";\nimport type { FC } from \"react\";\nimport React from \"react\";\n\nimport { Environment, getColorForEnvironment } from \"./environment\";\n\ninterface LogoProps {\n\ttitle: string;\n\tclassName?: string;\n\taccentColor?: string;\n\t[key: string]: object | string | number | boolean | undefined;\n}\n\nexport const EnturPartnerLogoSvg: FC<LogoProps> = ({\n\ttitle,\n\taccentColor = \"#FF5959\",\n\t...rest\n}) => {\n\treturn (\n\t\t<svg width={257} height={37} viewBox=\"0 0 257 37\" {...rest}>\n\t\t\t<title>{title}</title>\n\t\t\t<g fill=\"none\" fillRule=\"evenodd\">\n\t\t\t\t<path\n\t\t\t\t\tfill=\"#FFF\"\n\t\t\t\t\td=\"M0 .231V25.72h18.745v-4.318H4.869v-6.163h12.31v-4.318H4.87V4.55h13.876V.231z\"\n\t\t\t\t/>\n\t\t\t\t<path fill={accentColor} d=\"M0 36.408h45.253v-4.32H0z\" />\n\t\t\t\t<path\n\t\t\t\t\tfill=\"#FFF\"\n\t\t\t\t\td=\"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\t\t\t\t/>\n\t\t\t\t<g fill={accentColor}>\n\t\t\t\t\t<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\t\t\t\t</g>\n\t\t\t</g>\n\t\t</svg>\n\t);\n};\n\ninterface EnturPartnerLogoProps {\n\taltText: string;\n\tas?: \"div\" | React.ElementType;\n\tclassName?: string;\n\tenvironment?: Environment;\n}\n\nexport const EnturPartnerLogo: FC<EnturPartnerLogoProps> = ({\n\tas: Component = \"nav\",\n\tclassName,\n\taltText,\n\tenvironment,\n}) => {\n\tconst classList = classnames([\"eps-logo-wrapper\", className]);\n\n\treturn (\n\t\t<Component className={classList}>\n\t\t\t<EnturPartnerLogoSvg\n\t\t\t\ttitle={altText}\n\t\t\t\tclassName=\"logo\"\n\t\t\t\taccentColor={\n\t\t\t\t\tenvironment !== undefined && environment !== Environment.Production\n\t\t\t\t\t\t? getColorForEnvironment(environment)\n\t\t\t\t\t\t: undefined\n\t\t\t\t}\n\t\t\t/>\n\t\t</Component>\n\t);\n};\n","import { BannerAlertBox } from \"@entur/alert\";\nimport { PrimaryButton } from \"@entur/button\";\nimport { Paragraph } from \"@entur/typography\";\nimport { isFunction } from \"@entur-partner/util\";\nimport React, { Component, type ErrorInfo, type ReactNode } from \"react\";\nimport { Box } from \"./Box\";\n\ntype FallbackOptions = {\n\tretry: () => void;\n\terror: Error;\n};\n\ntype RenderProp = (options: FallbackOptions) => ReactNode;\n\ntype Props = {\n\thandleError?: (error: Error, errorInfo: ErrorInfo) => void;\n\tfallback: ReactNode | RenderProp;\n\tchildren: ReactNode;\n};\n\ntype State = {\n\terror: null | Error;\n};\n\nconst newAppVersionErrorMessage =\n\t\"Failed to execute 'removeChild' on 'Node': The node to be removed is not a child of this node.\";\n\nexport class ErrorBoundary extends Component<Props, State> {\n\tconstructor(props: Props) {\n\t\tsuper(props);\n\t\tthis.state = { error: null };\n\t}\n\n\tstatic getDerivedStateFromError(error: Error): State {\n\t\treturn {\n\t\t\terror,\n\t\t};\n\t}\n\n\tcomponentDidCatch(error: Error, errorInfo: ErrorInfo) {\n\t\t// React always logs in development\n\t\tthis.props.handleError?.(error, errorInfo);\n\t}\n\n\trender() {\n\t\tconst { error } = this.state;\n\t\tconst { fallback, children } = this.props;\n\n\t\tif (error) {\n\t\t\tif (isFunction<RenderProp>(fallback)) {\n\t\t\t\treturn fallback({ retry: () => this.setState({ error: null }), error });\n\t\t\t} else if (\n\t\t\t\terror.name === \"NotFoundError\" &&\n\t\t\t\terror.message === newAppVersionErrorMessage\n\t\t\t) {\n\t\t\t\treturn <RefreshBannerInfo />;\n\t\t\t}\n\n\t\t\treturn fallback;\n\t\t}\n\n\t\treturn children;\n\t}\n}\n\nexport const LANGUAGE_STORAGE_KEY = \"EP::locale\";\n\nfunction RefreshBannerInfo() {\n\t// Taken from ./app-shell/src/storage.ts\n\tconst language = localStorage.getItem(LANGUAGE_STORAGE_KEY);\n\tconst isNorwegian = language === \"nb\" || language === \"nb-NO\";\n\treturn (\n\t\t<Box maxWidth=\"large\">\n\t\t\t<BannerAlertBox\n\t\t\t\tvariant=\"info\"\n\t\t\t\ttitle={\n\t\t\t\t\tisNorwegian\n\t\t\t\t\t\t? \"En ny versjon av nettsiden er tilgjengelig.\"\n\t\t\t\t\t\t: \"A new version of the website is available.\"\n\t\t\t\t}\n\t\t\t>\n\t\t\t\t<Box paddingBottom=\"medium\">\n\t\t\t\t\t<Paragraph margin=\"none\">\n\t\t\t\t\t\t{isNorwegian ? \"Vennligst oppdater.\" : \"Please refresh.\"}\n\t\t\t\t\t</Paragraph>\n\t\t\t\t</Box>\n\t\t\t\t<PrimaryButton onClick={() => window.location.reload()}>\n\t\t\t\t\t{isNorwegian ? \"Oppdater\" : \"Refresh\"}\n\t\t\t\t</PrimaryButton>\n\t\t\t</BannerAlertBox>\n\t\t</Box>\n\t);\n}\n","/// <reference types=\"vite/client\" />\nimport React, { type 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 VITE_APP_ prefix.\n */\nexport function featureFlag(flag: string): boolean {\n\treturn (\n\t\timport.meta.env[`VITE_APP_${flag}`] === \"true\" ||\n\t\twindow.localStorage?.getItem(flag) === \"true\" ||\n\t\twindow.localStorage?.getItem(`VITE_APP_${flag}`) === \"true\"\n\t);\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 VITE_APP_ prefix.\n */\nexport function useFeatureToggle(flag: string): boolean {\n\treturn featureFlag(flag);\n}\n\nexport interface FeatureToggleProps {\n\t/** Visible if flag exist, hidden if not.*/\n\tchildren: ReactNode;\n\t/** Case sensitive flag. If it is an environment variable\n\t * you can drop the VITE_APP_ prefix. */\n\tflag: string;\n}\n\nexport const FeatureToggle = ({ children, flag }: FeatureToggleProps) => {\n\tconst feature = useFeatureToggle(flag);\n\tif (feature) {\n\t\treturn <>{children}</>;\n\t}\n\treturn null;\n};\n","import \"./LanguageSelect.scss\";\n\nimport { SegmentedChoice, SegmentedControl } from \"@entur/form\";\nimport { assertIsDefined } from \"@entur-partner/util\";\nimport cx from \"classnames\";\nimport React, { type FC } from \"react\";\n\nexport type LanguageKey = \"nob\" | \"nno\" | \"eng\";\n\nexport interface LanguageOption {\n\tvalue: LanguageKey;\n\tlabel: string;\n\trequired: boolean;\n}\n\nexport interface LanguageSelectProps {\n\tlanguage: string;\n\toptions: LanguageOption[];\n\tclassName?: string;\n\tonChange: (language: string) => void;\n\t[key: string]: object | string | number | boolean | undefined;\n}\n\nexport const LanguageSelect: FC<LanguageSelectProps> = ({\n\tlanguage,\n\toptions,\n\tclassName,\n\tonChange,\n\t...rest\n}) => {\n\tconst classNames = cx(\"eps-language-select\", className);\n\treturn (\n\t\t<div {...rest} className={classNames}>\n\t\t\t<SegmentedControl\n\t\t\t\tonChange={(language) => {\n\t\t\t\t\tassertIsDefined(language);\n\t\t\t\t\tonChange(language);\n\t\t\t\t}}\n\t\t\t\tselectedValue={language}\n\t\t\t>\n\t\t\t\t{options.map((option) => (\n\t\t\t\t\t<SegmentedChoice key={option.value} value={option.value}>\n\t\t\t\t\t\t{option.label}\n\t\t\t\t\t\t{option.required && <span className=\"asterisk-margin\">{\"*\"}</span>}\n\t\t\t\t\t</SegmentedChoice>\n\t\t\t\t))}\n\t\t\t</SegmentedControl>\n\t\t</div>\n\t);\n};\n","import \"../index.scss\";\n\nimport cx from \"classnames\";\nimport React from \"react\";\n\nexport const CustomOverflowMenuItem: React.FC<\n\tReact.DetailedHTMLProps<\n\t\tReact.ButtonHTMLAttributes<HTMLButtonElement>,\n\t\tHTMLButtonElement\n\t>\n> = (props) => {\n\treturn (\n\t\t<button\n\t\t\tclassName={cx(props.className, \"eps-overflow-menu__item\")}\n\t\t\trole=\"menuitem\"\n\t\t\t{...props}\n\t\t/>\n\t);\n};\n","import \"../index.scss\";\n\nimport { CookieIcon } from \"@entur/icons\";\nimport React from \"react\";\n\nimport { CustomOverflowMenuItem } from \"./CustomOverflowMenuItem\";\n\ntype Props = {\n\tname: string;\n\tsetOpen: (open: boolean) => void;\n\tonCookieSettingsOpen: () => void;\n};\n\nexport const CookieSettingsMenuItem = ({\n\tname,\n\tsetOpen,\n\tonCookieSettingsOpen,\n}: Props) => {\n\treturn (\n\t\t<CustomOverflowMenuItem\n\t\t\tonClick={() => {\n\t\t\t\tonCookieSettingsOpen();\n\t\t\t\tsetOpen(false);\n\t\t\t}}\n\t\t\tclassName=\"eps-overflow-menu__item\"\n\t\t>\n\t\t\t<span aria-hidden={true}>\n\t\t\t\t<CookieIcon size=\"1rem\" inline />\n\t\t\t</span>\n\t\t\t{name}\n\t\t</CustomOverflowMenuItem>\n\t);\n};\n","import React from \"react\";\n\nexport function useOutsideClick(\n\tref: React.RefObject<HTMLDivElement>,\n\tbuttonRef: React.RefObject<HTMLButtonElement>,\n\thandler: () => void,\n) {\n\tReact.useEffect(() => {\n\t\tconst listener = (event: Event) => {\n\t\t\tif (\n\t\t\t\telementContainsEventTarget(ref.current, event) ||\n\t\t\t\telementContainsEventTarget(buttonRef.current, event)\n\t\t\t) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\thandler();\n\t\t};\n\n\t\tdocument.addEventListener(\"mousedown\", listener);\n\t\tdocument.addEventListener(\"touchstart\", listener);\n\n\t\treturn () => {\n\t\t\tdocument.removeEventListener(\"mousedown\", listener);\n\t\t\tdocument.removeEventListener(\"touchstart\", listener);\n\t\t};\n\t}, [ref, buttonRef, handler]);\n}\n\nfunction elementContainsEventTarget(element: HTMLElement | null, event: Event) {\n\tif (!element) {\n\t\treturn false;\n\t}\n\n\tif (element.contains(event.target as Node)) {\n\t\treturn true;\n\t}\n\n\t// For elements inside a Shadow DOM we need to check the composedPath\n\tif (event.composed && event.composedPath) {\n\t\tconst contains = event.composedPath().find((target) => {\n\t\t\tif (target === window) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t\treturn element.contains(target as Node);\n\t\t});\n\t\treturn !!contains;\n\t}\n\n\treturn false;\n}\n","import \"../index.scss\";\n\nimport { SecondaryButton } from \"@entur/button\";\nimport { DownArrowIcon, UserIcon } from \"@entur/icons\";\nimport { Heading6 } from \"@entur/typography\";\nimport cx from \"classnames\";\nimport React from \"react\";\n\nimport {\n\tEnvironment,\n\tgetColorForEnvironment,\n\tgetHumanReadableEnvironment,\n} from \"../../environment\";\nimport { useOutsideClick } from \"../useOutsideClick\";\n\nexport const CustomOverflowMenu: React.FC<{\n\tclassName?: string;\n\tchildren: React.ReactNode;\n\tuserName: string;\n\topen: boolean;\n\tonOpenChange: (open: boolean) => void;\n\tenvironment?: Environment;\n}> = ({\n\tclassName,\n\tchildren,\n\tuserName,\n\topen,\n\tonOpenChange,\n\tenvironment,\n\t...rest\n}) => {\n\tconst overflowItemsClasses = cx(\"eps-overflow-menu__group\", {\n\t\t\"eps-overflow-menu__group--open\": open,\n\t});\n\tconst overflowContentRef = React.useRef<HTMLDivElement>(null);\n\tconst overflowMenuTriggerRef = React.useRef<HTMLButtonElement>(null);\n\tuseOutsideClick(overflowContentRef, overflowMenuTriggerRef, () =>\n\t\tonOpenChange(false),\n\t);\n\treturn (\n\t\t<div>\n\t\t\t<SecondaryButton\n\t\t\t\tclassName={cx(\"eps-overflow-menu__button\", className)}\n\t\t\t\tonClick={() => onOpenChange(!open)}\n\t\t\t\taria-haspopup={true}\n\t\t\t\taria-expanded={open}\n\t\t\t\tref={overflowMenuTriggerRef}\n\t\t\t\t{...rest}\n\t\t\t>\n\t\t\t\t<div className=\"eps-overflow-menu__button-contents\">\n\t\t\t\t\t<span className=\"eds-overflow-menu__user-icon\">\n\t\t\t\t\t\t<UserIcon inline />\n\t\t\t\t\t</span>\n\t\t\t\t\t<Heading6 margin=\"none\" as=\"span\">\n\t\t\t\t\t\t{userName}\n\t\t\t\t\t\t{environment !== undefined &&\n\t\t\t\t\t\t\tenvironment !== Environment.Production && (\n\t\t\t\t\t\t\t\t<span style={{ color: getColorForEnvironment(environment) }}>\n\t\t\t\t\t\t\t\t\t{\" \"}\n\t\t\t\t\t\t\t\t\t({getHumanReadableEnvironment(environment)})\n\t\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t\t)}\n\t\t\t\t\t</Heading6>\n\t\t\t\t\t<span className=\"eps-arrow-icon\">\n\t\t\t\t\t\t<DownArrowIcon inline />\n\t\t\t\t\t</span>\n\t\t\t\t</div>\n\t\t\t</SecondaryButton>\n\t\t\t{open && (\n\t\t\t\t<div\n\t\t\t\t\tclassName={overflowItemsClasses}\n\t\t\t\t\trole=\"menu\"\n\t\t\t\t\tref={overflowContentRef}\n\t\t\t\t>\n\t\t\t\t\t{children}\n\t\t\t\t</div>\n\t\t\t)}\n\t\t</div>\n\t);\n};\n","import \"../index.scss\";\n\nimport { NorwayIcon, UKIcon } from \"@entur/icons\";\nimport React from \"react\";\n\nimport { useFeatureToggle } from \"../../FeatureToggle\";\nimport { CustomOverflowMenuItem } from \"./CustomOverflowMenuItem\";\n\ntype Props = {\n\tlanguage: string;\n\tonLanguageChange: (language: string) => void;\n\tsetOpen: (open: boolean) => void;\n\tname: string;\n};\n\nexport const LanguageSwitchMenuItem = ({\n\tlanguage,\n\tonLanguageChange,\n\tsetOpen,\n\tname,\n}: Props) => {\n\tconst useB47LanguageKey = useFeatureToggle(\"USE_BCP-47_LANGUAGE_KEY\");\n\tconst norwegianLanguageKey = useB47LanguageKey ? \"nb-NO\" : \"nb\";\n\tconst englishLanguageKey = useB47LanguageKey ? \"en-GB\" : \"en\";\n\n\treturn (\n\t\t<>\n\t\t\t{language === englishLanguageKey ? (\n\t\t\t\t<CustomOverflowMenuItem\n\t\t\t\t\tonClick={() => {\n\t\t\t\t\t\tonLanguageChange(norwegianLanguageKey);\n\t\t\t\t\t\tsetOpen(false);\n\t\t\t\t\t}}\n\t\t\t\t\tclassName=\"eps-overflow-menu__item\"\n\t\t\t\t>\n\t\t\t\t\t<span aria-hidden className=\"eps-overflow-menu__icon-margin\">\n\t\t\t\t\t\t<NorwayIcon size=\"1rem\" inline />\n\t\t\t\t\t</span>\n\t\t\t\t\t{name}\n\t\t\t\t</CustomOverflowMenuItem>\n\t\t\t) : (\n\t\t\t\t<CustomOverflowMenuItem\n\t\t\t\t\tonClick={() => {\n\t\t\t\t\t\tonLanguageChange(englishLanguageKey);\n\t\t\t\t\t\tsetOpen(false);\n\t\t\t\t\t}}\n\t\t\t\t\tclassName=\"eps-overflow-menu__item\"\n\t\t\t\t>\n\t\t\t\t\t<span aria-hidden className=\"eps-overflow-menu__icon-margin\">\n\t\t\t\t\t\t<UKIcon size=\"1rem\" inline />\n\t\t\t\t\t</span>\n\t\t\t\t\t{name}\n\t\t\t\t</CustomOverflowMenuItem>\n\t\t\t)}\n\t\t</>\n\t);\n};\n","import \"../index.scss\";\n\nimport { LogOutIcon } from \"@entur/icons\";\nimport React from \"react\";\n\nimport { CustomOverflowMenuItem } from \"./CustomOverflowMenuItem\";\n\ntype Props = {\n\tname: string;\n\tsetOpen: (open: boolean) => void;\n\tonLogout: () => void;\n};\n\nexport const LogOutMenuItem = ({ name, setOpen, onLogout }: Props) => {\n\treturn (\n\t\t<CustomOverflowMenuItem\n\t\t\tonClick={() => {\n\t\t\t\tonLogout();\n\t\t\t\tsetOpen(false);\n\t\t\t}}\n\t\t\tdata-testid=\"user-menu-logout\"\n\t\t\tclassName=\"eps-overflow-menu__item\"\n\t\t>\n\t\t\t<span aria-hidden>\n\t\t\t\t<LogOutIcon size=\"1rem\" inline />\n\t\t\t</span>\n\t\t\t{name}\n\t\t</CustomOverflowMenuItem>\n\t);\n};\n","import \"../index.scss\";\n\nimport { UserIcon } from \"@entur/icons\";\nimport React from \"react\";\nimport { Link } from \"react-router-dom\";\n\nimport { CustomOverflowMenuItem } from \"./CustomOverflowMenuItem\";\n\ntype Props = {\n\tname: string;\n\tsetOpen: (open: boolean) => void;\n\tonNavigateToMyProfile: () => void;\n};\n\nexport const UserMenuItem = ({\n\tname,\n\tsetOpen,\n\tonNavigateToMyProfile,\n}: Props) => {\n\treturn (\n\t\t<Link to=\"/permission-admin/my-profile\" style={{ textDecoration: \"none\" }}>\n\t\t\t<CustomOverflowMenuItem\n\t\t\t\tonClick={() => {\n\t\t\t\t\tsetOpen(false);\n\t\t\t\t\tonNavigateToMyProfile();\n\t\t\t\t}}\n\t\t\t\tclassName=\"eps-overflow-menu__item\"\n\t\t\t>\n\t\t\t\t<span aria-hidden>\n\t\t\t\t\t<UserIcon size=\"1rem\" inline />\n\t\t\t\t</span>\n\t\t\t\t{name}\n\t\t\t</CustomOverflowMenuItem>\n\t\t</Link>\n\t);\n};\n","import { ChannelsIcon } from \"@entur/icons\";\nimport React from \"react\";\nimport { useNavigate } from \"react-router-dom\";\n\nimport { CustomOverflowMenuItem } from \"./CustomOverflowMenuItem\";\n\nexport const VersionMenuItem: React.FC<{\n\ttitle: string;\n\tsetOpen: (isOpen: boolean) => void;\n}> = ({ title, setOpen }) => {\n\tconst navigate = useNavigate(); // Hide useNavigate from standalone micro-frontends because it is not under RouterProvider\n\treturn (\n\t\t<CustomOverflowMenuItem\n\t\t\tonClick={() => {\n\t\t\t\tnavigate(\"/app-version\");\n\t\t\t\tsetOpen(false);\n\t\t\t}}\n\t\t\tclassName=\"eps-overflow-menu__item\"\n\t\t>\n\t\t\t<span aria-hidden>\n\t\t\t\t<ChannelsIcon className=\"eps-version-icon\" size=\"1rem\" inline />\n\t\t\t</span>\n\t\t\t{title}\n\t\t</CustomOverflowMenuItem>\n\t);\n};\n","import \"./ActionBar.scss\";\nimport React, { type ReactNode } from \"react\";\n\nexport interface ActionBarProps {\n\tchildren: ReactNode;\n}\n\nconst ActionBarLeft = ({ children }: ActionBarProps) => {\n\treturn <div className=\"eps-action-bar-left\">{children}</div>;\n};\n\nconst ActionBarRight = ({ children }: ActionBarProps) => {\n\treturn <div className=\"eps-action-bar-right\">{children}</div>;\n};\n\nconst ActionBar = ({ children }: ActionBarProps) => {\n\treturn (\n\t\t<>\n\t\t\t<div className=\"eps-action-bar-padding\" />\n\t\t\t<div className=\"eps-action-bar\">{children}</div>\n\t\t</>\n\t);\n};\n\nexport { ActionBar, ActionBarLeft, ActionBarRight };\n","import \"./AuditInfo.scss\";\n\nimport { isDate, isDateString } from \"@entur-partner/util\";\nimport cx from \"classnames\";\nimport React, { type FC } from \"react\";\n\nimport { FormatDateTime } from \"./FormatDateTime\";\nimport { Stack } from \"./Stack\";\n\ninterface Item {\n\tlabel: string;\n\tvalue: Date | string;\n}\n\nexport interface AuditInfoProps {\n\titems: Item[];\n\tlocale: string;\n\tclassName?: string;\n\t[key: string]: object | string | number | boolean | undefined;\n}\n\nexport const AuditInfo: FC<AuditInfoProps> = ({\n\titems,\n\tlocale,\n\tclassName,\n\t...rest\n}) => {\n\tconst classNames = cx(\"ep-audit-info\", className);\n\treturn (\n\t\t<div className={classNames} {...rest}>\n\t\t\t{items.map(({ label, value }) => (\n\t\t\t\t<Stack space=\"small\" key={value.toString()}>\n\t\t\t\t\t<div className=\"ep-audit-info-label\">{label}</div>\n\t\t\t\t\t<div>\n\t\t\t\t\t\t{isDate(value) || isDateString(value) ? (\n\t\t\t\t\t\t\t<FormatDateTime date={value} locale={locale} />\n\t\t\t\t\t\t) : (\n\t\t\t\t\t\t\t<span>{value}</span>\n\t\t\t\t\t\t)}\n\t\t\t\t\t</div>\n\t\t\t\t</Stack>\n\t\t\t))}\n\t\t</div>\n\t);\n};\n","import \"./Breadcrumbs.scss\";\nimport { BreadcrumbItem, BreadcrumbNavigation } from \"@entur/menu\";\nimport { splitUrlPath } from \"@entur-partner/util\";\nimport React, { type FC, type ReactElement } from \"react\";\nimport { Link } from \"react-router-dom\";\n\nexport interface BreadcrumbsProps {\n\tpathname: string;\n\tonBreadcrumbLookup: (path: string) => string | undefined;\n\tprependBreadcrumbItem?: ReactElement;\n}\n\nexport const Breadcrumbs: FC<BreadcrumbsProps> = ({\n\tprependBreadcrumbItem,\n\tpathname,\n\tonBreadcrumbLookup,\n}) => {\n\tconst paths: string[] = splitUrlPath(pathname);\n\n\tconst breadcrumbs = paths\n\t\t.map((path) => ({ title: onBreadcrumbLookup(path), path }))\n\t\t.filter(({ title }) => title !== undefined);\n\n\tconst breadcrumbElements = breadcrumbs.map(({ title, path }, i) => {\n\t\tconst isLast = i === breadcrumbs.length - 1;\n\t\tif (isLast) {\n\t\t\treturn (\n\t\t\t\t<BreadcrumbItem key={path} as={\"span\"}>\n\t\t\t\t\t{title}\n\t\t\t\t</BreadcrumbItem>\n\t\t\t);\n\t\t}\n\t\treturn (\n\t\t\t<BreadcrumbItem key={path} as={Link} to={path}>\n\t\t\t\t{title}\n\t\t\t</BreadcrumbItem>\n\t\t);\n\t});\n\n\tif (prependBreadcrumbItem) {\n\t\treturn (\n\t\t\t<BreadcrumbNavigation>\n\t\t\t\t{[prependBreadcrumbItem, ...breadcrumbElements]}\n\t\t\t</BreadcrumbNavigation>\n\t\t);\n\t}\n\n\treturn <BreadcrumbNavigation>{breadcrumbElements}</BreadcrumbNavigation>;\n};\n","import \"./Content.scss\";\n\nimport classnames from \"classnames\";\nimport type { FC, ReactNode } from \"react\";\nimport React from \"react\";\n\ninterface ContentProps {\n\tchildren: ReactNode;\n\tas?: \"main\" | React.ElementType;\n\tclassName?: string;\n}\nexport const Content: FC<ContentProps> = ({\n\tas: Component = \"main\",\n\tclassName,\n\tchildren,\n}) => {\n\tconst classList = classnames([\"eps-content\", className]);\n\n\treturn <Component className={classList}>{children}</Component>;\n};\n","import { ExpandablePanel } from \"@entur/expand\";\nimport type { VariantType } from \"@entur/form\";\nimport type { ChangeEvent } from \"react\";\nimport React from \"react\";\n\nimport type { LanguageKey, LanguageOption } from \"./LanguageSelect\";\nimport { Stack } from \"./Stack\";\n\nexport type MultiLanguageValues = Record<LanguageKey, string>;\n\ntype ExpandableMultiLanguageInputProps = {\n\ttitle: string;\n\tinputComponent: React.ElementType;\n\tlanguages: LanguageOption[];\n\tvalues: MultiLanguageValues;\n\tonChange: (values: MultiLanguageValues) => void;\n\tname: string;\n\tvariant?: (lang: LanguageKey) => VariantType;\n\tfeedback?: (lang: LanguageKey) => string;\n\t[key: string]: object | string | number | boolean | undefined;\n};\n\nexport const ExpandableMultiLanguageInput = ({\n\ttitle,\n\tinputComponent: InputComponent,\n\tlanguages,\n\tvalues,\n\tonChange,\n\tname,\n\tvariant,\n\tfeedback,\n\t...rest\n}: ExpandableMultiLanguageInputProps) => {\n\tconst handleOnChange = (language: LanguageKey, value?: string) => {\n\t\tconst changes = { ...values };\n\t\tif (value === \"\" || !value) {\n\t\t\tdelete changes[language];\n\t\t} else {\n\t\t\tchanges[language] = value;\n\t\t}\n\t\tonChange(changes);\n\t};\n\n\treturn (\n\t\t<ExpandablePanel\n\t\t\ttitle={title}\n\t\t\tdefaultOpen\n\t\t\tcontentStyle={{\n\t\t\t\tpadding: \"4px 4px 4px 4px\",\n\t\t\t\tmarginTop: \"16px\",\n\t\t\t\tmarginBottom: \"16px\",\n\t\t\t}}\n\t\t>\n\t\t\t<Stack space=\"medium\">\n\t\t\t\t{languages.map(({ value: langKey, label, required }) => (\n\t\t\t\t\t<InputComponent\n\t\t\t\t\t\tdata-testid={`multi-lang-input-${name}-${langKey}`}\n\t\t\t\t\t\tkey={title + langKey}\n\t\t\t\t\t\tlabel={required ? `${label}*` : label}\n\t\t\t\t\t\tvariant={variant?.(langKey)}\n\t\t\t\t\t\tfeedback={feedback?.(langKey)}\n\t\t\t\t\t\tname={name}\n\t\t\t\t\t\tonChange={(e: ChangeEvent<HTMLInputElement>) => {\n\t\t\t\t\t\t\thandleOnChange(langKey, e.target.value);\n\t\t\t\t\t\t}}\n\t\t\t\t\t\tvalue={values[langKey] || \"\"}\n\t\t\t\t\t\t{...rest}\n\t\t\t\t\t/>\n\t\t\t\t))}\n\t\t\t</Stack>\n\t\t</ExpandablePanel>\n\t);\n};\n","import type { FC } from \"react\";\nimport React from \"react\";\n\nexport interface FormatCurrencyAmountProps {\n\tamount: number | string;\n\tas?: \"span\" | React.ElementType;\n\t[key: string]: object | string | number | boolean | undefined;\n}\n\nexport const FormatCurrencyAmount: FC<FormatCurrencyAmountProps> = ({\n\tamount,\n\tas: Component = \"span\",\n\t...rest\n}) => {\n\tconst parsedAmount = Number(amount) || 0;\n\n\tconst formattedAmount = new Intl.NumberFormat(\"nb-NO\", {\n\t\tmaximumFractionDigits: 2,\n\t\tminimumFractionDigits: 2,\n\t}).format(parsedAmount);\n\n\treturn <Component {...rest}>{formattedAmount}</Component>;\n};\n","import { Link as A } from \"@entur/typography\";\nimport React, { type FC } from \"react\";\nimport { type LinkProps, Link as RouterLink } from \"react-router-dom\";\n\ninterface Props extends LinkProps {}\n\nexport const Link: FC<Props> = (props) => {\n\treturn (\n\t\t<A {...props} as={RouterLink}>\n\t\t\t{props.children}\n\t\t</A>\n\t);\n};\n","import \"./LinkButton.scss\";\n\nimport { Link } from \"@entur/typography\";\nimport cx from \"classnames\";\nimport React, { type ReactNode } from \"react\";\n\nexport interface LinkButtonProps {\n\tchildren: ReactNode;\n\tclassName?: string;\n\t[key: string]: object | string | number | boolean | undefined | ReactNode;\n}\n\nexport const LinkButton = ({\n\tchildren,\n\tclassName,\n\t...rest\n}: LinkButtonProps) => (\n\t<Link {...rest} as=\"button\" className={cx(\"eps-link-button\", className)}>\n\t\t{children}\n\t</Link>\n);\n","import \"./Menu.scss\";\n\nimport classnames from \"classnames\";\nimport type { FC, ReactNode } from \"react\";\nimport React from \"react\";\n\ninterface MenuProps {\n\tchildren: ReactNode;\n\tas?: \"div\" | React.ElementType;\n\tclassName?: string;\n}\nexport const Menu: FC<MenuProps> = ({\n\tas: Component = \"nav\",\n\tclassName,\n\tchildren,\n}) => {\n\tconst classList = classnames([\"eds-contrast\", \"eps-menu\", className]);\n\n\treturn <Component className={classList}>{children}</Component>;\n};\n","import \"./MultiLanguageInput.scss\";\n\nimport type { VariantType } from \"@entur/form\";\nimport cx from \"classnames\";\nimport React, {\n\ttype ChangeEvent,\n\ttype FC,\n\ttype FocusEvent,\n\tuseState,\n} from \"react\";\nimport { type LanguageOption, LanguageSelect } from \"./LanguageSelect\";\nimport { Stack } from \"./Stack\";\n\ntype Values = { [key: string]: string };\n\nexport interface MultiLanguageInputProps {\n\tclassName?: string;\n\tonBlur?: (e: FocusEvent<HTMLDivElement>) => void;\n\tinputComponent: React.ElementType;\n\tvalues: { [key: string]: string };\n\tlanguages: LanguageOption[];\n\tonChange: (values: Values) => void;\n\tname: string;\n\talertLevel?: VariantType;\n\talertLabel?: string;\n\tlabel?: string;\n\tdefaultLanguage?: string;\n\t[key: string]: object | string | number | boolean | undefined;\n}\n/**\n * @deprecated use ExpandableMultiLanguageInput\n */\nexport const MultiLanguageInput: FC<MultiLanguageInputProps> = ({\n\tclassName,\n\tinputComponent: InputComponent,\n\talertLabel,\n\talertLevel,\n\tname,\n\tlanguages,\n\tvalues,\n\tonChange,\n\tdefaultLanguage = \"nob\",\n\tlabel = \"\",\n\tonBlur = () => {},\n\t...rest\n}) => {\n\tconst [language, setLanguage] = useState(defaultLanguage);\n\tconst classNames = cx(\"multi-language-input\", className);\n\tconst currentValue = values[language];\n\n\tconst handleOnBlur = (e: FocusEvent<HTMLDivElement>) => {\n\t\te.persist();\n\t\tconst currentTarget = e.currentTarget;\n\t\tsetTimeout(() => {\n\t\t\tif (currentTarget && !currentTarget.contains(document.activeElement)) {\n\t\t\t\tonBlur(e);\n\t\t\t}\n\t\t}, 0);\n\t};\n\n\tconst handleLanguageChange = (language: string) => {\n\t\tsetLanguage(language);\n\t};\n\n\tconst handleOnChange = (value?: string) => {\n\t\tconst changes = Object.assign({}, values);\n\t\tif (value === \"\" || !value) {\n\t\t\tdelete changes[language];\n\t\t} else {\n\t\t\tchanges[language] = value;\n\t\t}\n\t\tonChange(changes);\n\t};\n\n\treturn (\n\t\t// biome-ignore lint/a11y/noStaticElementInteractions: Legacy component\n\t\t<div\n\t\t\tclassName={classNames}\n\t\t\t// biome-ignore lint/a11y/noNoninteractiveTabindex: Legacy component\n\t\t\ttabIndex={0}\n\t\t\tonBlur={handleOnBlur}\n\t\t\tdata-testid={`multi-lang-input-${name}`}\n\t\t>\n\t\t\t<Stack space=\"extraSmall\">\n\t\t\t\t<LanguageSelect\n\t\t\t\t\tlanguage={language}\n\t\t\t\t\toptions={languages}\n\t\t\t\t\tonChange={(lang) => handleLanguageChange(lang)}\n\t\t\t\t/>\n\t\t\t\t<InputComponent\n\t\t\t\t\tlabel={label}\n\t\t\t\t\tvariant={alertLevel}\n\t\t\t\t\tfeedback={alertLabel}\n\t\t\t\t\tname={name}\n\t\t\t\t\tclassName=\"language-item\"\n\t\t\t\t\tonChange={(e: ChangeEvent<HTMLInputElement>) =>\n\t\t\t\t\t\thandleOnChange(e.target.value)\n\t\t\t\t\t}\n\t\t\t\t\tvalue={currentValue || \"\"}\n\t\t\t\t\t{...rest}\n\t\t\t\t/>\n\t\t\t</Stack>\n\t\t</div>\n\t);\n};\n","import { SearchableDropdown } from \"@entur/dropdown\";\nimport React, { type FC, useEffect, useState } from \"react\";\n\ninterface OrganisationV3 {\n\torganisationId: number;\n\ttradingName: string;\n}\n\ninterface OrganisationDropDownProps {\n\tlabel: string;\n\tonChange: (organisationId: number) => void;\n\torganisations: OrganisationV3[];\n\tselectedOrganisationId?: number;\n\t[key: string]: object | string | number | boolean | undefined;\n}\n\nexport const OrganisationDropDown: FC<OrganisationDropDownProps> = ({\n\tlabel,\n\torganisations,\n\tonChange: handleChange,\n\tselectedOrganisationId,\n\t...rest\n}) => {\n\tconst [selectedOrganisation, setSelectedOrganisation] =\n\t\tuseState<OrganisationV3>();\n\n\tuseEffect(() => {\n\t\tsetSelectedOrganisation(\n\t\t\torganisations.find(\n\t\t\t\t(org) => org.organisationId === selectedOrganisationId,\n\t\t\t),\n\t\t);\n\t}, [selectedOrganisationId, organisations]);\n\n\treturn (\n\t\t<SearchableDropdown\n\t\t\tlabel={label}\n\t\t\titems={[\n\t\t\t\t...organisations\n\t\t\t\t\t.sort((a, b) => a.tradingName.localeCompare(b.tradingName, \"nb\"))\n\t\t\t\t\t.map((organisation) => {\n\t\t\t\t\t\treturn {\n\t\t\t\t\t\t\tvalue: organisation.organisationId,\n\t\t\t\t\t\t\tlabel: organisation.tradingName,\n\t\t\t\t\t\t};\n\t\t\t\t\t}),\n\t\t\t]}\n\t\t\tselectedItem={\n\t\t\t\tselectedOrganisation\n\t\t\t\t\t? {\n\t\t\t\t\t\t\tvalue: selectedOrganisation.organisationId,\n\t\t\t\t\t\t\tlabel: selectedOrganisation.tradingName,\n\t\t\t\t\t\t}\n\t\t\t\t\t: null\n\t\t\t}\n\t\t\tonChange={(selectedValue) => {\n\t\t\t\tif (selectedValue) {\n\t\t\t\t\thandleChange(selectedValue.value);\n\t\t\t\t}\n\t\t\t}}\n\t\t\tclearable={false}\n\t\t\t{...rest}\n\t\t/>\n\t);\n};\n","import { splitUrlPath } from \"@entur-partner/util\";\nimport React from \"react\";\nimport { Helmet } from \"react-helmet-async\";\n\ntype Props = {\n\treadonly pathname: string;\n\treadonly onBreadcrumbLookup: (path: string) => string | undefined;\n};\n\n/**\n * This component changes page title by using helmet and current path. It will translate subpaths, join them with a dash\n * and display it on browser tab.\n *\n * @param Props.pathname - The current path from react-router-dom.useLocation()\n * @param Props.onBreadcrumbLookup - A function that takes a path and returns a i18n translated string or undefined\n * @returns A Helmet component with updated title\n */\nexport function PageTitle({ pathname, onBreadcrumbLookup }: Props) {\n\tconst paths: string[] = splitUrlPath(pathname);\n\n\tconst pageTitles = paths\n\t\t.map((path) => ({ title: onBreadcrumbLookup(path), path }))\n\t\t.filter(({ title }) => title !== undefined)\n\t\t.map(({ title }) => title)\n\t\t.reverse()\n\t\t.join(\" | \");\n\n\treturn (\n\t\t<Helmet>\n\t\t\t<title>{pageTitles} | Entur Partner</title>\n\t\t</Helmet>\n\t);\n}\n","import { Pagination } from \"@entur/menu\";\nimport React, { type FC } from \"react\";\n\nexport interface PagerProps {\n\tcurrentPage: number;\n\tcollectionSize: number;\n\tpageSize: number;\n\tonPageChange: (page: number) => void;\n}\n\nexport const Pager: FC<PagerProps> = ({\n\tcollectionSize,\n\tpageSize,\n\tonPageChange,\n\tcurrentPage,\n}) => {\n\tconst pageCount = Math.ceil(collectionSize / pageSize);\n\treturn (\n\t\t<Pagination\n\t\t\tpageCount={pageCount}\n\t\t\tcurrentPage={currentPage}\n\t\t\tonPageChange={(page) => {\n\t\t\t\tonPageChange(page);\n\t\t\t}}\n\t\t/>\n\t);\n};\n","import type { BusinessCapability } from \"@entur-partner/permission-client-node\";\nimport { hasAllPermissions, hasOneOfPermissions } from \"@entur-partner/util\";\nimport React, { type FC, type ReactNode } from \"react\";\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\tchildren: ReactNode;\n\t/** User permissions to check */\n\tpermissions: BusinessCapability[];\n\t/** Check that at least one of the permissions is present */\n\toneOf?: BusinessCapability[];\n\t/** Check that all of the permissions is present */\n\tall?: BusinessCapability[] | BusinessCapability;\n\t/** Rendered if check fails. Defaults to null */\n\tfallback?: 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\tchildren,\n\tfallback = null,\n\tpermissions,\n\toneOf = [],\n\tall = [],\n}) => {\n\tconst allIsAllowed = hasAllPermissions(all, permissions);\n\n\tconst oneOfIsAllowed = hasOneOfPermissions(oneOf, permissions);\n\n\tconst allowed = allIsAllowed && oneOfIsAllowed;\n\treturn <>{allowed ? children : fallback}</>;\n};\n","import type { ModalProps } from \"@entur/modal\";\nimport { assertIsDefined } from \"@entur-partner/util\";\nimport type { Location } from \"history\";\nimport React, { type FC, type ReactNode } from \"react\";\nimport { useBlocker, useInRouterContext } from \"react-router-dom\";\n\nimport { ConfirmModal } from \"./ConfirmModal\";\n\nexport interface RouteLeavingGuardProps extends Partial<ModalProps> {\n\ttitle: string;\n\tcloseLabel: string;\n\tmessages: {\n\t\tcancel: string;\n\t\tconfirm: string;\n\t};\n\tchildren: ReactNode;\n\tshouldBlockNavigation: (location: Location) => boolean;\n}\n\nexport const RouteLeavingGuard: FC<RouteLeavingGuardProps> = ({\n\tchildren,\n\tshouldBlockNavigation,\n\t...rest\n}) => {\n\tassertIsDefined(\n\t\tuseInRouterContext() ? true : undefined,\n\t\t`RouteLeavingGuard must be used within a data router.`,\n\t);\n\n\tconst blocker = useBlocker(\n\t\t({ currentLocation, nextLocation }) =>\n\t\t\tcurrentLocation.pathname !== nextLocation.pathname &&\n\t\t\tshouldBlockNavigation(nextLocation),\n\t);\n\n\treturn (\n\t\t<ConfirmModal\n\t\t\tonDismiss={() => {\n\t\t\t\tif (blocker.state === \"blocked\") {\n\t\t\t\t\tblocker.reset();\n\t\t\t\t}\n\t\t\t}}\n\t\t\topen={blocker.state === \"blocked\"}\n\t\t\tonConfirm={() => {\n\t\t\t\tif (blocker.state === \"blocked\") {\n\t\t\t\t\tblocker.proceed();\n\t\t\t\t}\n\t\t\t}}\n\t\t\t{...rest}\n\t\t>\n\t\t\t{children}\n\t\t</ConfirmModal>\n\t);\n};\n","import \"./StatusLabel.scss\";\n\nimport cx from \"classnames\";\nimport React, { type FC } from \"react\";\n\ninterface StatusLabelProps {\n\tlabel: string;\n\tactive: boolean;\n\taggressiveInactive?: boolean;\n\tshowBullet?: boolean;\n\tcenter?: boolean;\n}\nexport const StatusLabel: FC<StatusLabelProps> = ({\n\tactive = false,\n\tlabel = \"\",\n\taggressiveInactive,\n\tshowBullet,\n\tcenter,\n}) => {\n\tconst bulletClassNames = cx(\"eps-status-label__bullet\", {\n\t\tactive,\n\t\taggressive: aggressiveInactive,\n\t});\n\tconst statusLabelClassNames = cx(\"eps-status-label\", {\n\t\tcenter,\n\t});\n\treturn (\n\t\t<div className={statusLabelClassNames}>\n\t\t\t{showBullet && <div className={bulletClassNames} />}\n\t\t\t<div>{label}</div>\n\t\t</div>\n\t);\n};\n","import \"./Text.scss\";\n\nimport cx from \"classnames\";\nimport type { ReactNode } from \"react\";\nimport React from \"react\";\n\nimport { Box, responsiveProp, type StyleColor } from \"./Box\";\n\ntype StyleFontSize =\n\t| \"extraSmall\"\n\t| \"small\"\n\t| \"medium\"\n\t| \"large\"\n\t| \"extraLarge\"\n\t| \"extraLarge2\"\n\t| \"extraLarge3\"\n\t| \"extraLarge4\";\n\ntype StyleFontWeight = \"body\" | \"heading\";\n\ntype StyleLineHeight =\n\t| \"extraSmall\"\n\t| \"small\"\n\t| \"medium\"\n\t| \"large\"\n\t| \"extraLarge\"\n\t| \"extraLarge2\"\n\t| \"extraLarge3\"\n\t| \"extraLarge4\"\n\t| \"extraLarge5\"\n\t| \"extraLarge6\"\n\t| \"extraLarge7\";\n\nexport type ResponsiveStyleFontSize =\n\t| StyleFontSize\n\t| [StyleFontSize?, StyleFontSize?, StyleFontSize?];\n\nexport type ResponsiveStyleLineHeight =\n\t| StyleLineHeight\n\t| [StyleLineHeight?, StyleLineHeight?, StyleLineHeight?];\n\nexport interface TextProps {\n\tclassName?: string;\n\tas?: React.ElementType;\n\tchildren: ReactNode;\n\tfontSize?: ResponsiveStyleFontSize;\n\tlineHeight?: ResponsiveStyleLineHeight;\n\tcolor?: StyleColor;\n\tfontWeight?: StyleFontWeight;\n\t// biome-ignore lint/suspicious/noExplicitAny: Ignore for now.\n\t[key: string]: any;\n}\n\nexport const Text = ({\n\tas: component = \"span\",\n\tchildren,\n\tfontSize,\n\tcolor,\n\tlineHeight,\n\tfontWeight,\n\tclassName,\n\t...rest\n}: TextProps) => {\n\tconst classes = [];\n\n\tfontSize && classes.push(...responsiveProp(\"eps-font-size-\", fontSize));\n\tlineHeight && classes.push(...responsiveProp(\"eps-line-height-\", lineHeight));\n\tfontWeight && classes.push(`eps-font-weight-${fontWeight}`);\n\n\tconst classList = cx(classes, className);\n\n\treturn (\n\t\t<Box as={component} color={color} className={classList} {...rest}>\n\t\t\t{children}\n\t\t</Box>\n\t);\n};\n","import \"./Unbutton.scss\";\n\nimport { Button, type ButtonProps } from \"@entur/button\";\nimport cx from \"classnames\";\nimport React, { type FC } from \"react\";\n\ninterface UnbuttonProps extends Omit<ButtonProps<typeof Button>, \"variant\"> {}\n\nexport const Unbutton: FC<UnbuttonProps> = ({\n\tchildren,\n\tclassName,\n\t...rest\n}) => (\n\t<Button variant=\"primary\" {...rest} className={cx(\"eps-unbutton\", className)}>\n\t\t{children}\n\t</Button>\n);\n","import \"./index.scss\";\n\nimport cx from \"classnames\";\nimport React, { type FC, useState } from \"react\";\n\nimport type { Environment } from \"../environment\";\nimport { CookieSettingsMenuItem } from \"./components/CookieSettingsMenuItem\";\nimport { CustomOverflowMenu } from \"./components/CustomOverflowMenu\";\nimport { LanguageSwitchMenuItem } from \"./components/LanguageSwitchMenuItem\";\nimport { LogOutMenuItem } from \"./components/LogOutMenuItem\";\nimport { UserMenuItem } from \"./components/UserMenuItem\";\nimport { VersionMenuItem } from \"./components/VersionMenuItem\";\n\ninterface UserMenuProps {\n\tuserName: string;\n\tmessages: {\n\t\tlogout: string;\n\t\tswitchLanguage: string;\n\t\tappVersion?: string;\n\t\tmyProfile?: string;\n\t\tcookieSettings?: string;\n\t};\n\tonLogout: () => void;\n\tonLanguageChange: (language: string) => void;\n\tlanguage: string;\n\tclassName?: string;\n\tenvironment?: Environment;\n\tshowVersionItem?: boolean;\n\tshowMyProfileItem?: boolean;\n\tshowCookieSettingsItem?: boolean;\n\tonNavigateToMyProfile: () => void;\n\tonCookieSettingsOpen?: () => void;\n}\n\nexport const UserMenu: FC<UserMenuProps> = ({\n\tclassName,\n\tmessages,\n\tonLogout,\n\tonLanguageChange,\n\tuserName,\n\tlanguage,\n\tenvironment,\n\tshowVersionItem,\n\tshowMyProfileItem,\n\tshowCookieSettingsItem,\n\tonNavigateToMyProfile,\n\tonCookieSettingsOpen = () => {},\n}) => {\n\tconst triggerClassList = cx([\"eps-user-menu__trigger-button\", className]);\n\tconst [open, setOpen] = useState(false);\n\n\treturn (\n\t\t<div id=\"eps-user-menu\">\n\t\t\t<CustomOverflowMenu\n\t\t\t\topen={open}\n\t\t\t\tonOpenChange={setOpen}\n\t\t\t\tclassName={triggerClassList}\n\t\t\t\tuserName={userName}\n\t\t\t\tenvironment={environment}\n\t\t\t>\n\t\t\t\t<div id=\"eps-overflow-menu\">\n\t\t\t\t\t<LanguageSwitchMenuItem\n\t\t\t\t\t\tname={messages.switchLanguage}\n\t\t\t\t\t\tlanguage={language}\n\t\t\t\t\t\tonLanguageChange={onLanguageChange}\n\t\t\t\t\t\tsetOpen={setOpen}\n\t\t\t\t\t/>\n\t\t\t\t\t{showVersionItem && messages.appVersion && (\n\t\t\t\t\t\t<VersionMenuItem title={messages.appVersion} setOpen={setOpen} />\n\t\t\t\t\t)}\n\t\t\t\t\t{showMyProfileItem && messages.myProfile && (\n\t\t\t\t\t\t<UserMenuItem\n\t\t\t\t\t\t\tname={messages.myProfile}\n\t\t\t\t\t\t\tsetOpen={setOpen}\n\t\t\t\t\t\t\tonNavigateToMyProfile={onNavigateToMyProfile}\n\t\t\t\t\t\t/>\n\t\t\t\t\t)}\n\t\t\t\t\t{showCookieSettingsItem && messages.cookieSettings && (\n\t\t\t\t\t\t<CookieSettingsMenuItem\n\t\t\t\t\t\t\tname={messages.cookieSettings}\n\t\t\t\t\t\t\tsetOpen={setOpen}\n\t\t\t\t\t\t\tonCookieSettingsOpen={onCookieSettingsOpen}\n\t\t\t\t\t\t/>\n\t\t\t\t\t)}\n\t\t\t\t\t<LogOutMenuItem\n\t\t\t\t\t\tname={messages.logout}\n\t\t\t\t\t\tsetOpen={setOpen}\n\t\t\t\t\t\tonLogout={onLogout}\n\t\t\t\t\t/>\n\t\t\t\t</div>\n\t\t\t</CustomOverflowMenu>\n\t\t</div>\n\t);\n};\n","/*global EventListener WindowEventHandlers*/\nimport { useEffect, useRef } from \"react\";\n\ntype TypedEventListener<T extends Event> = (evt: T) => void;\n\nexport function useEventListener<T extends Event = Event>(\n\teventName: string,\n\thandler: TypedEventListener<T>,\n\telement: WindowEventHandlers = window,\n) {\n\tconst savedHandler = useRef<TypedEventListener<T>>();\n\n\tuseEffect(() => {\n\t\tsavedHandler.current = handler;\n\t}, [handler]);\n\n\tuseEffect(() => {\n\t\tconst isSupported = element?.addEventListener;\n\t\tif (!isSupported) return;\n\n\t\tconst eventListener = ((event: T): void =>\n\t\t\tsavedHandler.current?.(event)) as EventListener;\n\n\t\telement.addEventListener(eventName, eventListener);\n\n\t\treturn () => {\n\t\t\telement.removeEventListener(eventName, eventListener);\n\t\t};\n\t}, [eventName, element]);\n}\n"],"names":["FormatDateTime","_ref","date","locale","_ref$as","as","Component","hideTime","rest","_objectWithoutPropertiesLoose","_excluded","React","createElement","_extends","localeDate","localeDateTime","responsiveProp","prefix","prop","Array","isArray","classes","push","Environment","Box","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","resolvedPaddingTop","resolvedPaddingBottom","resolvedPaddingLeft","resolvedPaddingRight","resolvedMarginTop","resolvedMarginBottom","resolvedMarginLeft","resolvedMarginRight","apply","classList","cx","Stack","space","stackItems","Children","toArray","length","Fragment","map","child","index","key","ConfirmModal","_ref$isOpen","isOpen","message","_ref$size","size","buttons","onConfirm","messages","onClose","onDismiss","childrenToRender","handleDismiss","Modal","open","isString","Paragraph","ButtonGroup","SecondaryButton","onClick","cancel","PrimaryButton","confirm","environmentColors","_environmentColors","Local","Development","Staging","getColorForEnvironment","environment","humanReadableEnvironment","_humanReadableEnviron","Production","getHumanReadableEnvironment","EnturPartnerLogoSvg","title","_ref$accentColor","accentColor","height","viewBox","fill","fillRule","d","ErrorBoundary","_Component","props","_this","call","this","state","error","getDerivedStateFromError","_proto","prototype","componentDidCatch","errorInfo","_this$props$handleErr","_this$props","handleError","render","_this2","_this$props2","fallback","isFunction","retry","setState","name","RefreshBannerInfo","LANGUAGE_STORAGE_KEY","language","localStorage","getItem","isNorwegian","BannerAlertBox","variant","window","location","reload","featureFlag","flag","_window$localStorage","_window$localStorage2","import","useFeatureToggle","LanguageSelect","options","onChange","classNames","SegmentedControl","assertIsDefined","selectedValue","option","SegmentedChoice","value","label","required","CustomOverflowMenuItem","role","CookieSettingsMenuItem","setOpen","onCookieSettingsOpen","CookieIcon","inline","elementContainsEventTarget","element","event","contains","target","composed","composedPath","find","CustomOverflowMenu","ref","buttonRef","handler","userName","onOpenChange","overflowItemsClasses","overflowContentRef","useRef","overflowMenuTriggerRef","useEffect","listener","current","document","addEventListener","removeEventListener","UserIcon","Heading6","undefined","style","DownArrowIcon","LanguageSwitchMenuItem","onLanguageChange","useB47LanguageKey","norwegianLanguageKey","englishLanguageKey","NorwayIcon","UKIcon","LogOutMenuItem","onLogout","LogOutIcon","UserMenuItem","onNavigateToMyProfile","Link","to","textDecoration","VersionMenuItem","navigate","useNavigate","ChannelsIcon","_ref3","_ref2","items","toString","isDate","isDateString","prependBreadcrumbItem","onBreadcrumbLookup","breadcrumbs","splitUrlPath","pathname","path","filter","breadcrumbElements","i","BreadcrumbItem","BreadcrumbNavigation","concat","classnames","_ref2$as","altText","InputComponent","inputComponent","languages","values","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","setSelectedOrganisation","org","organisationId","SearchableDropdown","sort","a","b","tradingName","localeCompare","organisation","selectedItem","clearable","pageTitles","reverse","join","Helmet","onPageChange","currentPage","pageCount","Math","ceil","collectionSize","pageSize","Pagination","page","_ref$fallback","permissions","_ref$oneOf","oneOf","_ref$all","all","allIsAllowed","hasAllPermissions","oneOfIsAllowed","hasOneOfPermissions","shouldBlockNavigation","useInRouterContext","blocker","useBlocker","nextLocation","currentLocation","reset","proceed","_ref$active","active","showBullet","center","bulletClassNames","aggressive","aggressiveInactive","statusLabelClassNames","component","fontSize","lineHeight","fontWeight","Button","showVersionItem","showMyProfileItem","showCookieSettingsItem","_ref$onCookieSettings","triggerClassList","id","switchLanguage","appVersion","myProfile","cookieSettings","logout","eventName","savedHandler","_element","eventListener"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"common.cjs.production.min.js","sources":["../src/FormatDateTime.tsx","../src/Box.tsx","../src/environment.ts","../src/Stack.tsx","../src/ConfirmModal.tsx","../src/EnturPartnerLogo.tsx","../src/ErrorBoundary.tsx","../src/FeatureToggle.tsx","../src/LanguageSelect.tsx","../src/UserMenu/components/CustomOverflowMenuItem.tsx","../src/UserMenu/components/CookieSettingsMenuItem.tsx","../src/UserMenu/useOutsideClick.ts","../src/UserMenu/components/CustomOverflowMenu.tsx","../src/UserMenu/components/LanguageSwitchMenuItem.tsx","../src/UserMenu/components/LogOutMenuItem.tsx","../src/UserMenu/components/UserMenuItem.tsx","../src/UserMenu/components/VersionMenuItem.tsx","../src/ActionBar.tsx","../src/AuditInfo.tsx","../src/Breadcrumbs.tsx","../src/Content.tsx","../src/ExpandableMultiLanguageInput.tsx","../src/FormatCurrencyAmount.tsx","../src/LegacyPageTitle.tsx","../src/Link.tsx","../src/LinkButton.tsx","../src/Menu.tsx","../src/MultiLanguageInput.tsx","../src/OrganisationDropdown.tsx","../src/PageTitle.tsx","../src/Pager.tsx","../src/PermissionCheck.tsx","../src/RouteLeavingGuard.tsx","../src/StatusLabel.tsx","../src/Text.tsx","../src/Unbutton.tsx","../src/UserMenu/index.tsx","../src/useEventListener.ts"],"sourcesContent":["import { localeDate, localeDateTime } from \"@entur-partner/util\";\nimport React, { type FC } from \"react\";\n\nexport interface FormatDateTimeProps {\n\tdate: string | Date;\n\tlocale: string;\n\t// biome-ignore lint/suspicious/noExplicitAny: Ignore for now.\n\t[key: string]: any;\n}\n\nexport const FormatDateTime: FC<FormatDateTimeProps> = ({\n\tdate,\n\tlocale,\n\tas: Component = \"main\",\n\thideTime,\n\t...rest\n}) => {\n\treturn (\n\t\t<Component {...rest}>\n\t\t\t{hideTime ? localeDate(date, locale) : localeDateTime(date, locale)}\n\t\t</Component>\n\t);\n};\n","import \"./Box.scss\";\n\nimport cx from \"classnames\";\nimport type { ReactNode } from \"react\";\nimport React from \"react\";\n\ntype StyleSpacing =\n\t| \"none\"\n\t| \"extraSmall2\"\n\t| \"extraSmall\"\n\t| \"small\"\n\t| \"medium\"\n\t| \"large\"\n\t| \"extraLarge\"\n\t| \"extraLarge2\"\n\t| \"extraLarge3\"\n\t| \"extraLarge4\"\n\t| \"extraLarge5\"\n\t| \"extraLarge6\"\n\t| \"extraLarge7\"\n\t| \"extraLarge8\"\n\t| \"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\t| \"none\"\n\t| \"extraSmall\"\n\t| \"small\"\n\t| \"medium\"\n\t| \"large\"\n\t| \"extraLarge\"\n\t| \"extraLarge2\"\n\t| \"extraLarge3\"\n\t| \"extraLarge4\"\n\t| \"extraLarge5\"\n\t| \"extraLarge6\"\n\t| \"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\t| StyleSpacing\n\t| [StyleSpacing?, StyleSpacing?, StyleSpacing?];\nexport type ResponsiveStyleMargin =\n\t| StyleMargin\n\t| [StyleMargin?, StyleMargin?, StyleMargin?];\n\nexport type ResponsiveStyleDisplay =\n\t| StyleDisplay\n\t| [StyleDisplay?, StyleDisplay?, StyleDisplay?];\nexport type ResponsiveStyleJustifyContent =\n\t| StyleJustifyContent\n\t| [StyleJustifyContent?, StyleJustifyContent?, StyleJustifyContent?];\nexport type ResponsiveStyleAlignItems =\n\t| StyleAlignItems\n\t| [StyleAlignItems?, StyleAlignItems?, StyleAlignItems?];\n\nexport type ResponsiveStyleMaxWidth =\n\t| StyleMaxWidth\n\t| [StyleMaxWidth?, StyleMaxWidth?, StyleMaxWidth?];\nexport type ResponsiveStyleWidth =\n\t| StyleWidth\n\t| [StyleWidth?, StyleWidth?, StyleWidth?];\n\nexport type ResponsiveStyleFlexDirection =\n\t| StyleFlexDirection\n\t| [StyleFlexDirection?, StyleFlexDirection?, StyleFlexDirection?];\nexport type ResponsiveStyleFlexWrap =\n\t| StyleFlexWrap\n\t| [StyleFlexWrap?, StyleFlexWrap?, StyleFlexWrap?];\n\nexport interface BoxProps {\n\tclassName?: string;\n\tas?: React.ElementType;\n\t[key: string]: object | string | number | boolean | undefined | ReactNode;\n\tchildren: ReactNode;\n\n\tcontrast?: boolean;\n\n\tpaddingTop?: ResponsiveStyleSpacing;\n\tpaddingRight?: ResponsiveStyleSpacing;\n\tpaddingBottom?: ResponsiveStyleSpacing;\n\tpaddingLeft?: ResponsiveStyleSpacing;\n\tpaddingX?: ResponsiveStyleSpacing;\n\tpaddingY?: ResponsiveStyleSpacing;\n\tpadding?: ResponsiveStyleSpacing;\n\n\tmarginTop?: ResponsiveStyleMargin;\n\tmarginRight?: ResponsiveStyleMargin;\n\tmarginBottom?: ResponsiveStyleMargin;\n\tmarginLeft?: ResponsiveStyleMargin;\n\tmarginX?: ResponsiveStyleMargin;\n\tmarginY?: ResponsiveStyleMargin;\n\tmargin?: ResponsiveStyleMargin;\n\n\tdisplay?: ResponsiveStyleDisplay;\n\tjustifyContent?: ResponsiveStyleJustifyContent;\n\talignItems?: ResponsiveStyleAlignItems;\n\n\tmaxWidth?: ResponsiveStyleMaxWidth;\n\twidth?: ResponsiveStyleWidth;\n\tbackground?: StyleBackground;\n\tcolor?: StyleColor;\n\n\tflexDirection?: ResponsiveStyleFlexDirection;\n\tflexWrap?: ResponsiveStyleFlexWrap;\n}\n\ntype ResponsiveProp = string | [string?, string?, string?];\n\nexport function responsiveProp(prefix: string, prop: ResponsiveProp): string[] {\n\tif (Array.isArray(prop)) {\n\t\tconst classes = [];\n\t\tprop[0] && classes.push(prefix + prop[0]);\n\t\tprop[1] && classes.push(`${prefix}${prop[1]}-lg`);\n\t\tprop[2] && classes.push(`${prefix}${prop[2]}-xl`);\n\t\treturn classes;\n\t}\n\treturn [prefix + prop];\n}\n\nexport const Box = ({\n\tas: Component = \"div\",\n\tchildren,\n\tcontrast,\n\tpaddingTop,\n\tpaddingRight,\n\tpaddingBottom,\n\tpaddingLeft,\n\tpaddingX,\n\tpaddingY,\n\tpadding,\n\tmarginTop,\n\tmarginRight,\n\tmarginBottom,\n\tmarginLeft,\n\tmarginX,\n\tmarginY,\n\tmargin,\n\tdisplay,\n\tjustifyContent,\n\talignItems,\n\tmaxWidth,\n\twidth,\n\tbackground,\n\tcolor,\n\tflexDirection,\n\tflexWrap,\n\tclassName,\n\t...rest\n}: BoxProps) => {\n\tconst classes = [];\n\tconst resolvedPaddingTop = paddingTop || paddingY || padding;\n\tconst resolvedPaddingBottom = paddingBottom || paddingY || padding;\n\tconst resolvedPaddingLeft = paddingLeft || paddingX || padding;\n\tconst resolvedPaddingRight = paddingRight || paddingX || padding;\n\n\tconst resolvedMarginTop = marginTop || marginY || margin;\n\tconst resolvedMarginBottom = marginBottom || marginY || margin;\n\tconst resolvedMarginLeft = marginLeft || marginX || margin;\n\tconst resolvedMarginRight = marginRight || marginX || margin;\n\n\tcontrast && classes.push(\"eds-contrast\");\n\tresolvedPaddingTop &&\n\t\tclasses.push(...responsiveProp(\"eps-pt-\", resolvedPaddingTop));\n\tresolvedPaddingBottom &&\n\t\tclasses.push(...responsiveProp(\"eps-pb-\", resolvedPaddingBottom));\n\tresolvedPaddingLeft &&\n\t\tclasses.push(...responsiveProp(\"eps-pl-\", resolvedPaddingLeft));\n\tresolvedPaddingRight &&\n\t\tclasses.push(...responsiveProp(\"eps-pr-\", resolvedPaddingRight));\n\tresolvedMarginTop &&\n\t\tclasses.push(...responsiveProp(\"eps-mt-\", resolvedMarginTop));\n\tresolvedMarginBottom &&\n\t\tclasses.push(...responsiveProp(\"eps-mb-\", resolvedMarginBottom));\n\tresolvedMarginLeft &&\n\t\tclasses.push(...responsiveProp(\"eps-ml-\", resolvedMarginLeft));\n\tresolvedMarginRight &&\n\t\tclasses.push(...responsiveProp(\"eps-mr-\", resolvedMarginRight));\n\n\tdisplay && classes.push(...responsiveProp(\"eps-\", display));\n\tjustifyContent &&\n\t\tclasses.push(...responsiveProp(\"eps-justify-\", justifyContent));\n\tif (alignItems) {\n\t\tclasses.push(...responsiveProp(\"eps-items-\", alignItems));\n\t}\n\n\tmaxWidth && classes.push(...responsiveProp(\"eps-max-w-\", maxWidth));\n\twidth && classes.push(...responsiveProp(\"eps-w-\", width));\n\n\tcolor && classes.push(`eps-color-${color}`);\n\tbackground && classes.push(`eps-bg-${background}`);\n\n\tflexDirection && classes.push(...responsiveProp(\"eps-flex-\", flexDirection));\n\tflexWrap && classes.push(...responsiveProp(\"eps-flex-wrap-\", flexWrap));\n\n\tconst classList = cx(classes, className);\n\n\treturn (\n\t\t<Component className={classList} {...rest}>\n\t\t\t{children}\n\t\t</Component>\n\t);\n};\n","export enum Environment {\n\tLocal = \"local\",\n\tDevelopment = \"dev\",\n\tStaging = \"staging\",\n\tProduction = \"prod\",\n}\n\nconst environmentColors: Record<\n\tExclude<Environment, Environment.Production>,\n\tstring\n> = {\n\t[Environment.Local]: \"#B482FB\",\n\t[Environment.Development]: \"#5AC39A\",\n\t[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\tenvironment: Exclude<Environment, Environment.Production>,\n) => environmentColors[environment];\n\nconst humanReadableEnvironment: Record<Environment, string> = {\n\t[Environment.Local]: \"Local\",\n\t[Environment.Development]: \"Dev\",\n\t[Environment.Staging]: \"Staging\",\n\t[Environment.Production]: \"Prod\",\n};\n\nexport const getHumanReadableEnvironment = (environment: Environment) =>\n\thumanReadableEnvironment[environment];\n","/** biome-ignore-all lint/suspicious/noArrayIndexKey: Ignore for now. Should be tested properly before doing changes */\nimport React, { Children, type ReactNode } from \"react\";\n\nimport { Box, type ResponsiveStyleSpacing } from \"./Box\";\n\nexport interface StackProps {\n\tclassName?: string;\n\tchildren: ReactNode;\n\tspace: ResponsiveStyleSpacing;\n}\n\nexport const Stack = ({ children, space, className }: StackProps) => {\n\tconst stackItems = Children.toArray(children);\n\tif (stackItems.length <= 1) {\n\t\treturn <>{stackItems}</>;\n\t}\n\n\treturn (\n\t\t<div className={className}>\n\t\t\t{stackItems.map((child, index) =>\n\t\t\t\tindex === stackItems.length - 1 ? (\n\t\t\t\t\t<div key={index}>{child}</div>\n\t\t\t\t) : (\n\t\t\t\t\t<Box paddingBottom={space} key={index}>\n\t\t\t\t\t\t{child}\n\t\t\t\t\t</Box>\n\t\t\t\t),\n\t\t\t)}\n\t\t</div>\n\t);\n};\n","import \"./ConfirmModal.scss\";\n\nimport { ButtonGroup, PrimaryButton, SecondaryButton } from \"@entur/button\";\nimport { Modal, type ModalProps } from \"@entur/modal\";\nimport { Paragraph } from \"@entur/typography\";\nimport { isString } from \"@entur-partner/util\";\nimport type { FC, ReactNode } from \"react\";\nimport React from \"react\";\n\nimport { Box } from \"./Box\";\n\nexport interface BaseConfirmModalProps extends Partial<ModalProps> {\n\ttitle: string;\n\tchildren: React.ReactNode;\n\tcloseLabel: string;\n\n\t/** Deprecated use children prop */\n\tmessage?: ReactNode;\n\t/** Deprecated use open prop */\n\tisOpen?: boolean;\n\t/** Deprecated use onDismiss prop */\n\tonClose?: () => void;\n}\n\ninterface CustomConfirmModalButtons extends BaseConfirmModalProps {\n\tbuttons: ReactNode[];\n}\n\ninterface DefaultConfirmModalHandler extends BaseConfirmModalProps {\n\tonConfirm: () => void;\n\tmessages: {\n\t\tconfirm: string;\n\t\tcancel: string;\n\t};\n}\n\nexport type ConfirmModalProps =\n\t| CustomConfirmModalButtons\n\t| DefaultConfirmModalHandler;\n\nexport const ConfirmModal: FC<ConfirmModalProps> = ({\n\tisOpen = false,\n\tchildren,\n\tmessage,\n\tsize = \"medium\",\n\tbuttons,\n\tonConfirm,\n\tmessages,\n\tonClose,\n\tonDismiss,\n\t...rest\n}) => {\n\tconst childrenToRender = children ? children : message;\n\tconst handleDismiss = onClose ? onClose : onDismiss;\n\treturn (\n\t\t<Modal size={size} open={isOpen} onDismiss={handleDismiss} {...rest}>\n\t\t\t{isString(childrenToRender) ? (\n\t\t\t\t<Paragraph>{childrenToRender}</Paragraph>\n\t\t\t) : (\n\t\t\t\t<Box paddingBottom=\"medium\">{childrenToRender}</Box>\n\t\t\t)}\n\n\t\t\t<ButtonGroup>\n\t\t\t\t{onConfirm ? (\n\t\t\t\t\t<>\n\t\t\t\t\t\t<SecondaryButton\n\t\t\t\t\t\t\tonClick={handleDismiss}\n\t\t\t\t\t\t\tdata-testid=\"cancel-modal-button\"\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{messages.cancel}\n\t\t\t\t\t\t</SecondaryButton>\n\t\t\t\t\t\t<PrimaryButton\n\t\t\t\t\t\t\tonClick={onConfirm}\n\t\t\t\t\t\t\tdata-testid=\"confirm-modal-button\"\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{messages.confirm}\n\t\t\t\t\t\t</PrimaryButton>\n\t\t\t\t\t</>\n\t\t\t\t) : (\n\t\t\t\t\tbuttons\n\t\t\t\t)}\n\t\t\t</ButtonGroup>\n\t\t</Modal>\n\t);\n};\n","import \"./EnturPartnerLogo.scss\";\n\nimport classnames from \"classnames\";\nimport type { FC } from \"react\";\nimport React from \"react\";\n\nimport { Environment, getColorForEnvironment } from \"./environment\";\n\ninterface LogoProps {\n\ttitle: string;\n\tclassName?: string;\n\taccentColor?: string;\n\t[key: string]: object | string | number | boolean | undefined;\n}\n\nexport const EnturPartnerLogoSvg: FC<LogoProps> = ({\n\ttitle,\n\taccentColor = \"#FF5959\",\n\t...rest\n}) => {\n\treturn (\n\t\t<svg width={257} height={37} viewBox=\"0 0 257 37\" {...rest}>\n\t\t\t<title>{title}</title>\n\t\t\t<g fill=\"none\" fillRule=\"evenodd\">\n\t\t\t\t<path\n\t\t\t\t\tfill=\"#FFF\"\n\t\t\t\t\td=\"M0 .231V25.72h18.745v-4.318H4.869v-6.163h12.31v-4.318H4.87V4.55h13.876V.231z\"\n\t\t\t\t/>\n\t\t\t\t<path fill={accentColor} d=\"M0 36.408h45.253v-4.32H0z\" />\n\t\t\t\t<path\n\t\t\t\t\tfill=\"#FFF\"\n\t\t\t\t\td=\"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\t\t\t\t/>\n\t\t\t\t<g fill={accentColor}>\n\t\t\t\t\t<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\t\t\t\t</g>\n\t\t\t</g>\n\t\t</svg>\n\t);\n};\n\ninterface EnturPartnerLogoProps {\n\taltText: string;\n\tas?: \"div\" | React.ElementType;\n\tclassName?: string;\n\tenvironment?: Environment;\n}\n\nexport const EnturPartnerLogo: FC<EnturPartnerLogoProps> = ({\n\tas: Component = \"nav\",\n\tclassName,\n\taltText,\n\tenvironment,\n}) => {\n\tconst classList = classnames([\"eps-logo-wrapper\", className]);\n\n\treturn (\n\t\t<Component className={classList}>\n\t\t\t<EnturPartnerLogoSvg\n\t\t\t\ttitle={altText}\n\t\t\t\tclassName=\"logo\"\n\t\t\t\taccentColor={\n\t\t\t\t\tenvironment !== undefined && environment !== Environment.Production\n\t\t\t\t\t\t? getColorForEnvironment(environment)\n\t\t\t\t\t\t: undefined\n\t\t\t\t}\n\t\t\t/>\n\t\t</Component>\n\t);\n};\n","import { BannerAlertBox } from \"@entur/alert\";\nimport { PrimaryButton } from \"@entur/button\";\nimport { Paragraph } from \"@entur/typography\";\nimport { isFunction } from \"@entur-partner/util\";\nimport React, { Component, type ErrorInfo, type ReactNode } from \"react\";\nimport { Box } from \"./Box\";\n\ntype FallbackOptions = {\n\tretry: () => void;\n\terror: Error;\n};\n\ntype RenderProp = (options: FallbackOptions) => ReactNode;\n\ntype Props = {\n\thandleError?: (error: Error, errorInfo: ErrorInfo) => void;\n\tfallback: ReactNode | RenderProp;\n\tchildren: ReactNode;\n};\n\ntype State = {\n\terror: null | Error;\n};\n\nconst newAppVersionErrorMessage =\n\t\"Failed to execute 'removeChild' on 'Node': The node to be removed is not a child of this node.\";\n\nexport class ErrorBoundary extends Component<Props, State> {\n\tconstructor(props: Props) {\n\t\tsuper(props);\n\t\tthis.state = { error: null };\n\t}\n\n\tstatic getDerivedStateFromError(error: Error): State {\n\t\treturn {\n\t\t\terror,\n\t\t};\n\t}\n\n\tcomponentDidCatch(error: Error, errorInfo: ErrorInfo) {\n\t\t// React always logs in development\n\t\tthis.props.handleError?.(error, errorInfo);\n\t}\n\n\trender() {\n\t\tconst { error } = this.state;\n\t\tconst { fallback, children } = this.props;\n\n\t\tif (error) {\n\t\t\tif (isFunction<RenderProp>(fallback)) {\n\t\t\t\treturn fallback({ retry: () => this.setState({ error: null }), error });\n\t\t\t} else if (\n\t\t\t\terror.name === \"NotFoundError\" &&\n\t\t\t\terror.message === newAppVersionErrorMessage\n\t\t\t) {\n\t\t\t\treturn <RefreshBannerInfo />;\n\t\t\t}\n\n\t\t\treturn fallback;\n\t\t}\n\n\t\treturn children;\n\t}\n}\n\nexport const LANGUAGE_STORAGE_KEY = \"EP::locale\";\n\nfunction RefreshBannerInfo() {\n\t// Taken from ./app-shell/src/storage.ts\n\tconst language = localStorage.getItem(LANGUAGE_STORAGE_KEY);\n\tconst isNorwegian = language === \"nb\" || language === \"nb-NO\";\n\treturn (\n\t\t<Box maxWidth=\"large\">\n\t\t\t<BannerAlertBox\n\t\t\t\tvariant=\"info\"\n\t\t\t\ttitle={\n\t\t\t\t\tisNorwegian\n\t\t\t\t\t\t? \"En ny versjon av nettsiden er tilgjengelig.\"\n\t\t\t\t\t\t: \"A new version of the website is available.\"\n\t\t\t\t}\n\t\t\t>\n\t\t\t\t<Box paddingBottom=\"medium\">\n\t\t\t\t\t<Paragraph margin=\"none\">\n\t\t\t\t\t\t{isNorwegian ? \"Vennligst oppdater.\" : \"Please refresh.\"}\n\t\t\t\t\t</Paragraph>\n\t\t\t\t</Box>\n\t\t\t\t<PrimaryButton onClick={() => window.location.reload()}>\n\t\t\t\t\t{isNorwegian ? \"Oppdater\" : \"Refresh\"}\n\t\t\t\t</PrimaryButton>\n\t\t\t</BannerAlertBox>\n\t\t</Box>\n\t);\n}\n","/// <reference types=\"vite/client\" />\nimport React, { type 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 VITE_APP_ prefix.\n */\nexport function featureFlag(flag: string): boolean {\n\treturn (\n\t\timport.meta.env[`VITE_APP_${flag}`] === \"true\" ||\n\t\twindow.localStorage?.getItem(flag) === \"true\" ||\n\t\twindow.localStorage?.getItem(`VITE_APP_${flag}`) === \"true\"\n\t);\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 VITE_APP_ prefix.\n */\nexport function useFeatureToggle(flag: string): boolean {\n\treturn featureFlag(flag);\n}\n\nexport interface FeatureToggleProps {\n\t/** Visible if flag exist, hidden if not.*/\n\tchildren: ReactNode;\n\t/** Case sensitive flag. If it is an environment variable\n\t * you can drop the VITE_APP_ prefix. */\n\tflag: string;\n}\n\nexport const FeatureToggle = ({ children, flag }: FeatureToggleProps) => {\n\tconst feature = useFeatureToggle(flag);\n\tif (feature) {\n\t\treturn <>{children}</>;\n\t}\n\treturn null;\n};\n","import \"./LanguageSelect.scss\";\n\nimport { SegmentedChoice, SegmentedControl } from \"@entur/form\";\nimport { assertIsDefined } from \"@entur-partner/util\";\nimport cx from \"classnames\";\nimport React, { type FC } from \"react\";\n\nexport type LanguageKey = \"nob\" | \"nno\" | \"eng\";\n\nexport interface LanguageOption {\n\tvalue: LanguageKey;\n\tlabel: string;\n\trequired: boolean;\n}\n\nexport interface LanguageSelectProps {\n\tlanguage: string;\n\toptions: LanguageOption[];\n\tclassName?: string;\n\tonChange: (language: string) => void;\n\t[key: string]: object | string | number | boolean | undefined;\n}\n\nexport const LanguageSelect: FC<LanguageSelectProps> = ({\n\tlanguage,\n\toptions,\n\tclassName,\n\tonChange,\n\t...rest\n}) => {\n\tconst classNames = cx(\"eps-language-select\", className);\n\treturn (\n\t\t<div {...rest} className={classNames}>\n\t\t\t<SegmentedControl\n\t\t\t\tonChange={(language) => {\n\t\t\t\t\tassertIsDefined(language);\n\t\t\t\t\tonChange(language);\n\t\t\t\t}}\n\t\t\t\tselectedValue={language}\n\t\t\t>\n\t\t\t\t{options.map((option) => (\n\t\t\t\t\t<SegmentedChoice key={option.value} value={option.value}>\n\t\t\t\t\t\t{option.label}\n\t\t\t\t\t\t{option.required && <span className=\"asterisk-margin\">{\"*\"}</span>}\n\t\t\t\t\t</SegmentedChoice>\n\t\t\t\t))}\n\t\t\t</SegmentedControl>\n\t\t</div>\n\t);\n};\n","import \"../index.scss\";\n\nimport cx from \"classnames\";\nimport React from \"react\";\n\nexport const CustomOverflowMenuItem: React.FC<\n\tReact.DetailedHTMLProps<\n\t\tReact.ButtonHTMLAttributes<HTMLButtonElement>,\n\t\tHTMLButtonElement\n\t>\n> = (props) => {\n\treturn (\n\t\t<button\n\t\t\tclassName={cx(props.className, \"eps-overflow-menu__item\")}\n\t\t\trole=\"menuitem\"\n\t\t\t{...props}\n\t\t/>\n\t);\n};\n","import \"../index.scss\";\n\nimport { CookieIcon } from \"@entur/icons\";\nimport React from \"react\";\n\nimport { CustomOverflowMenuItem } from \"./CustomOverflowMenuItem\";\n\ntype Props = {\n\tname: string;\n\tsetOpen: (open: boolean) => void;\n\tonCookieSettingsOpen: () => void;\n};\n\nexport const CookieSettingsMenuItem = ({\n\tname,\n\tsetOpen,\n\tonCookieSettingsOpen,\n}: Props) => {\n\treturn (\n\t\t<CustomOverflowMenuItem\n\t\t\tonClick={() => {\n\t\t\t\tonCookieSettingsOpen();\n\t\t\t\tsetOpen(false);\n\t\t\t}}\n\t\t\tclassName=\"eps-overflow-menu__item\"\n\t\t>\n\t\t\t<span aria-hidden={true}>\n\t\t\t\t<CookieIcon size=\"1rem\" inline />\n\t\t\t</span>\n\t\t\t{name}\n\t\t</CustomOverflowMenuItem>\n\t);\n};\n","import React from \"react\";\n\nexport function useOutsideClick(\n\tref: React.RefObject<HTMLDivElement>,\n\tbuttonRef: React.RefObject<HTMLButtonElement>,\n\thandler: () => void,\n) {\n\tReact.useEffect(() => {\n\t\tconst listener = (event: Event) => {\n\t\t\tif (\n\t\t\t\telementContainsEventTarget(ref.current, event) ||\n\t\t\t\telementContainsEventTarget(buttonRef.current, event)\n\t\t\t) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\thandler();\n\t\t};\n\n\t\tdocument.addEventListener(\"mousedown\", listener);\n\t\tdocument.addEventListener(\"touchstart\", listener);\n\n\t\treturn () => {\n\t\t\tdocument.removeEventListener(\"mousedown\", listener);\n\t\t\tdocument.removeEventListener(\"touchstart\", listener);\n\t\t};\n\t}, [ref, buttonRef, handler]);\n}\n\nfunction elementContainsEventTarget(element: HTMLElement | null, event: Event) {\n\tif (!element) {\n\t\treturn false;\n\t}\n\n\tif (element.contains(event.target as Node)) {\n\t\treturn true;\n\t}\n\n\t// For elements inside a Shadow DOM we need to check the composedPath\n\tif (event.composed && event.composedPath) {\n\t\tconst contains = event.composedPath().find((target) => {\n\t\t\tif (target === window) {\n\t\t\t\treturn false;\n\t\t\t}\n\t\t\treturn element.contains(target as Node);\n\t\t});\n\t\treturn !!contains;\n\t}\n\n\treturn false;\n}\n","import \"../index.scss\";\n\nimport { SecondaryButton } from \"@entur/button\";\nimport { DownArrowIcon, UserIcon } from \"@entur/icons\";\nimport { Heading6 } from \"@entur/typography\";\nimport cx from \"classnames\";\nimport React from \"react\";\n\nimport {\n\tEnvironment,\n\tgetColorForEnvironment,\n\tgetHumanReadableEnvironment,\n} from \"../../environment\";\nimport { useOutsideClick } from \"../useOutsideClick\";\n\nexport const CustomOverflowMenu: React.FC<{\n\tclassName?: string;\n\tchildren: React.ReactNode;\n\tuserName: string;\n\topen: boolean;\n\tonOpenChange: (open: boolean) => void;\n\tenvironment?: Environment;\n}> = ({\n\tclassName,\n\tchildren,\n\tuserName,\n\topen,\n\tonOpenChange,\n\tenvironment,\n\t...rest\n}) => {\n\tconst overflowItemsClasses = cx(\"eps-overflow-menu__group\", {\n\t\t\"eps-overflow-menu__group--open\": open,\n\t});\n\tconst overflowContentRef = React.useRef<HTMLDivElement>(null);\n\tconst overflowMenuTriggerRef = React.useRef<HTMLButtonElement>(null);\n\tuseOutsideClick(overflowContentRef, overflowMenuTriggerRef, () =>\n\t\tonOpenChange(false),\n\t);\n\treturn (\n\t\t<div>\n\t\t\t<SecondaryButton\n\t\t\t\tclassName={cx(\"eps-overflow-menu__button\", className)}\n\t\t\t\tonClick={() => onOpenChange(!open)}\n\t\t\t\taria-haspopup={true}\n\t\t\t\taria-expanded={open}\n\t\t\t\tref={overflowMenuTriggerRef}\n\t\t\t\t{...rest}\n\t\t\t>\n\t\t\t\t<div className=\"eps-overflow-menu__button-contents\">\n\t\t\t\t\t<span className=\"eds-overflow-menu__user-icon\">\n\t\t\t\t\t\t<UserIcon inline />\n\t\t\t\t\t</span>\n\t\t\t\t\t<Heading6 margin=\"none\" as=\"span\">\n\t\t\t\t\t\t{userName}\n\t\t\t\t\t\t{environment !== undefined &&\n\t\t\t\t\t\t\tenvironment !== Environment.Production && (\n\t\t\t\t\t\t\t\t<span style={{ color: getColorForEnvironment(environment) }}>\n\t\t\t\t\t\t\t\t\t{\" \"}\n\t\t\t\t\t\t\t\t\t({getHumanReadableEnvironment(environment)})\n\t\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t\t)}\n\t\t\t\t\t</Heading6>\n\t\t\t\t\t<span className=\"eps-arrow-icon\">\n\t\t\t\t\t\t<DownArrowIcon inline />\n\t\t\t\t\t</span>\n\t\t\t\t</div>\n\t\t\t</SecondaryButton>\n\t\t\t{open && (\n\t\t\t\t<div\n\t\t\t\t\tclassName={overflowItemsClasses}\n\t\t\t\t\trole=\"menu\"\n\t\t\t\t\tref={overflowContentRef}\n\t\t\t\t>\n\t\t\t\t\t{children}\n\t\t\t\t</div>\n\t\t\t)}\n\t\t</div>\n\t);\n};\n","import \"../index.scss\";\n\nimport { NorwayIcon, UKIcon } from \"@entur/icons\";\nimport React from \"react\";\n\nimport { useFeatureToggle } from \"../../FeatureToggle\";\nimport { CustomOverflowMenuItem } from \"./CustomOverflowMenuItem\";\n\ntype Props = {\n\tlanguage: string;\n\tonLanguageChange: (language: string) => void;\n\tsetOpen: (open: boolean) => void;\n\tname: string;\n};\n\nexport const LanguageSwitchMenuItem = ({\n\tlanguage,\n\tonLanguageChange,\n\tsetOpen,\n\tname,\n}: Props) => {\n\tconst useB47LanguageKey = useFeatureToggle(\"USE_BCP-47_LANGUAGE_KEY\");\n\tconst norwegianLanguageKey = useB47LanguageKey ? \"nb-NO\" : \"nb\";\n\tconst englishLanguageKey = useB47LanguageKey ? \"en-GB\" : \"en\";\n\n\treturn (\n\t\t<>\n\t\t\t{language === englishLanguageKey ? (\n\t\t\t\t<CustomOverflowMenuItem\n\t\t\t\t\tonClick={() => {\n\t\t\t\t\t\tonLanguageChange(norwegianLanguageKey);\n\t\t\t\t\t\tsetOpen(false);\n\t\t\t\t\t}}\n\t\t\t\t\tclassName=\"eps-overflow-menu__item\"\n\t\t\t\t>\n\t\t\t\t\t<span aria-hidden className=\"eps-overflow-menu__icon-margin\">\n\t\t\t\t\t\t<NorwayIcon size=\"1rem\" inline />\n\t\t\t\t\t</span>\n\t\t\t\t\t{name}\n\t\t\t\t</CustomOverflowMenuItem>\n\t\t\t) : (\n\t\t\t\t<CustomOverflowMenuItem\n\t\t\t\t\tonClick={() => {\n\t\t\t\t\t\tonLanguageChange(englishLanguageKey);\n\t\t\t\t\t\tsetOpen(false);\n\t\t\t\t\t}}\n\t\t\t\t\tclassName=\"eps-overflow-menu__item\"\n\t\t\t\t>\n\t\t\t\t\t<span aria-hidden className=\"eps-overflow-menu__icon-margin\">\n\t\t\t\t\t\t<UKIcon size=\"1rem\" inline />\n\t\t\t\t\t</span>\n\t\t\t\t\t{name}\n\t\t\t\t</CustomOverflowMenuItem>\n\t\t\t)}\n\t\t</>\n\t);\n};\n","import \"../index.scss\";\n\nimport { LogOutIcon } from \"@entur/icons\";\nimport React from \"react\";\n\nimport { CustomOverflowMenuItem } from \"./CustomOverflowMenuItem\";\n\ntype Props = {\n\tname: string;\n\tsetOpen: (open: boolean) => void;\n\tonLogout: () => void;\n};\n\nexport const LogOutMenuItem = ({ name, setOpen, onLogout }: Props) => {\n\treturn (\n\t\t<CustomOverflowMenuItem\n\t\t\tonClick={() => {\n\t\t\t\tonLogout();\n\t\t\t\tsetOpen(false);\n\t\t\t}}\n\t\t\tdata-testid=\"user-menu-logout\"\n\t\t\tclassName=\"eps-overflow-menu__item\"\n\t\t>\n\t\t\t<span aria-hidden>\n\t\t\t\t<LogOutIcon size=\"1rem\" inline />\n\t\t\t</span>\n\t\t\t{name}\n\t\t</CustomOverflowMenuItem>\n\t);\n};\n","import \"../index.scss\";\n\nimport { UserIcon } from \"@entur/icons\";\nimport React from \"react\";\nimport { Link } from \"react-router-dom\";\n\nimport { CustomOverflowMenuItem } from \"./CustomOverflowMenuItem\";\n\ntype Props = {\n\tname: string;\n\tsetOpen: (open: boolean) => void;\n\tonNavigateToMyProfile: () => void;\n};\n\nexport const UserMenuItem = ({\n\tname,\n\tsetOpen,\n\tonNavigateToMyProfile,\n}: Props) => {\n\treturn (\n\t\t<Link to=\"/permission-admin/my-profile\" style={{ textDecoration: \"none\" }}>\n\t\t\t<CustomOverflowMenuItem\n\t\t\t\tonClick={() => {\n\t\t\t\t\tsetOpen(false);\n\t\t\t\t\tonNavigateToMyProfile();\n\t\t\t\t}}\n\t\t\t\tclassName=\"eps-overflow-menu__item\"\n\t\t\t>\n\t\t\t\t<span aria-hidden>\n\t\t\t\t\t<UserIcon size=\"1rem\" inline />\n\t\t\t\t</span>\n\t\t\t\t{name}\n\t\t\t</CustomOverflowMenuItem>\n\t\t</Link>\n\t);\n};\n","import { ChannelsIcon } from \"@entur/icons\";\nimport React from \"react\";\nimport { useNavigate } from \"react-router-dom\";\n\nimport { CustomOverflowMenuItem } from \"./CustomOverflowMenuItem\";\n\nexport const VersionMenuItem: React.FC<{\n\ttitle: string;\n\tsetOpen: (isOpen: boolean) => void;\n}> = ({ title, setOpen }) => {\n\tconst navigate = useNavigate(); // Hide useNavigate from standalone micro-frontends because it is not under RouterProvider\n\treturn (\n\t\t<CustomOverflowMenuItem\n\t\t\tonClick={() => {\n\t\t\t\tnavigate(\"/app-version\");\n\t\t\t\tsetOpen(false);\n\t\t\t}}\n\t\t\tclassName=\"eps-overflow-menu__item\"\n\t\t>\n\t\t\t<span aria-hidden>\n\t\t\t\t<ChannelsIcon className=\"eps-version-icon\" size=\"1rem\" inline />\n\t\t\t</span>\n\t\t\t{title}\n\t\t</CustomOverflowMenuItem>\n\t);\n};\n","import \"./ActionBar.scss\";\nimport React, { type ReactNode } from \"react\";\n\nexport interface ActionBarProps {\n\tchildren: ReactNode;\n}\n\nconst ActionBarLeft = ({ children }: ActionBarProps) => {\n\treturn <div className=\"eps-action-bar-left\">{children}</div>;\n};\n\nconst ActionBarRight = ({ children }: ActionBarProps) => {\n\treturn <div className=\"eps-action-bar-right\">{children}</div>;\n};\n\nconst ActionBar = ({ children }: ActionBarProps) => {\n\treturn (\n\t\t<>\n\t\t\t<div className=\"eps-action-bar-padding\" />\n\t\t\t<div className=\"eps-action-bar\">{children}</div>\n\t\t</>\n\t);\n};\n\nexport { ActionBar, ActionBarLeft, ActionBarRight };\n","import \"./AuditInfo.scss\";\n\nimport { isDate, isDateString } from \"@entur-partner/util\";\nimport cx from \"classnames\";\nimport React, { type FC } from \"react\";\n\nimport { FormatDateTime } from \"./FormatDateTime\";\nimport { Stack } from \"./Stack\";\n\ninterface Item {\n\tlabel: string;\n\tvalue: Date | string;\n}\n\nexport interface AuditInfoProps {\n\titems: Item[];\n\tlocale: string;\n\tclassName?: string;\n\t[key: string]: object | string | number | boolean | undefined;\n}\n\nexport const AuditInfo: FC<AuditInfoProps> = ({\n\titems,\n\tlocale,\n\tclassName,\n\t...rest\n}) => {\n\tconst classNames = cx(\"ep-audit-info\", className);\n\treturn (\n\t\t<div className={classNames} {...rest}>\n\t\t\t{items.map(({ label, value }) => (\n\t\t\t\t<Stack space=\"small\" key={value.toString()}>\n\t\t\t\t\t<div className=\"ep-audit-info-label\">{label}</div>\n\t\t\t\t\t<div>\n\t\t\t\t\t\t{isDate(value) || isDateString(value) ? (\n\t\t\t\t\t\t\t<FormatDateTime date={value} locale={locale} />\n\t\t\t\t\t\t) : (\n\t\t\t\t\t\t\t<span>{value}</span>\n\t\t\t\t\t\t)}\n\t\t\t\t\t</div>\n\t\t\t\t</Stack>\n\t\t\t))}\n\t\t</div>\n\t);\n};\n","import \"./Breadcrumbs.scss\";\nimport { BreadcrumbItem, BreadcrumbNavigation } from \"@entur/menu\";\nimport { splitUrlPath } from \"@entur-partner/util\";\nimport React, { type FC, type ReactElement } from \"react\";\nimport { Link } from \"react-router-dom\";\n\nexport interface BreadcrumbsProps {\n\tpathname: string;\n\tonBreadcrumbLookup: (path: string) => string | undefined;\n\tprependBreadcrumbItem?: ReactElement;\n}\n\nexport const Breadcrumbs: FC<BreadcrumbsProps> = ({\n\tprependBreadcrumbItem,\n\tpathname,\n\tonBreadcrumbLookup,\n}) => {\n\tconst paths: string[] = splitUrlPath(pathname);\n\n\tconst breadcrumbs = paths\n\t\t.map((path) => ({ title: onBreadcrumbLookup(path), path }))\n\t\t.filter(({ title }) => title !== undefined);\n\n\tconst breadcrumbElements = breadcrumbs.map(({ title, path }, i) => {\n\t\tconst isLast = i === breadcrumbs.length - 1;\n\t\tif (isLast) {\n\t\t\treturn (\n\t\t\t\t<BreadcrumbItem key={path} as={\"span\"}>\n\t\t\t\t\t{title}\n\t\t\t\t</BreadcrumbItem>\n\t\t\t);\n\t\t}\n\t\treturn (\n\t\t\t<BreadcrumbItem key={path} as={Link} to={path}>\n\t\t\t\t{title}\n\t\t\t</BreadcrumbItem>\n\t\t);\n\t});\n\n\tif (prependBreadcrumbItem) {\n\t\treturn (\n\t\t\t<BreadcrumbNavigation>\n\t\t\t\t{[prependBreadcrumbItem, ...breadcrumbElements]}\n\t\t\t</BreadcrumbNavigation>\n\t\t);\n\t}\n\n\treturn <BreadcrumbNavigation>{breadcrumbElements}</BreadcrumbNavigation>;\n};\n","import \"./Content.scss\";\n\nimport classnames from \"classnames\";\nimport type { FC, ReactNode } from \"react\";\nimport React from \"react\";\n\ninterface ContentProps {\n\tchildren: ReactNode;\n\tas?: \"main\" | React.ElementType;\n\tclassName?: string;\n}\nexport const Content: FC<ContentProps> = ({\n\tas: Component = \"main\",\n\tclassName,\n\tchildren,\n}) => {\n\tconst classList = classnames([\"eps-content\", className]);\n\n\treturn <Component className={classList}>{children}</Component>;\n};\n","import { ExpandablePanel } from \"@entur/expand\";\nimport type { VariantType } from \"@entur/form\";\nimport type { ChangeEvent } from \"react\";\nimport React from \"react\";\n\nimport type { LanguageKey, LanguageOption } from \"./LanguageSelect\";\nimport { Stack } from \"./Stack\";\n\nexport type MultiLanguageValues = Record<LanguageKey, string>;\n\ntype ExpandableMultiLanguageInputProps = {\n\ttitle: string;\n\tinputComponent: React.ElementType;\n\tlanguages: LanguageOption[];\n\tvalues: MultiLanguageValues;\n\tonChange: (values: MultiLanguageValues) => void;\n\tname: string;\n\tvariant?: (lang: LanguageKey) => VariantType;\n\tfeedback?: (lang: LanguageKey) => string;\n\t[key: string]: object | string | number | boolean | undefined;\n};\n\nexport const ExpandableMultiLanguageInput = ({\n\ttitle,\n\tinputComponent: InputComponent,\n\tlanguages,\n\tvalues,\n\tonChange,\n\tname,\n\tvariant,\n\tfeedback,\n\t...rest\n}: ExpandableMultiLanguageInputProps) => {\n\tconst handleOnChange = (language: LanguageKey, value?: string) => {\n\t\tconst changes = { ...values };\n\t\tif (value === \"\" || !value) {\n\t\t\tdelete changes[language];\n\t\t} else {\n\t\t\tchanges[language] = value;\n\t\t}\n\t\tonChange(changes);\n\t};\n\n\treturn (\n\t\t<ExpandablePanel\n\t\t\ttitle={title}\n\t\t\tdefaultOpen\n\t\t\tcontentStyle={{\n\t\t\t\tpadding: \"4px 4px 4px 4px\",\n\t\t\t\tmarginTop: \"16px\",\n\t\t\t\tmarginBottom: \"16px\",\n\t\t\t}}\n\t\t>\n\t\t\t<Stack space=\"medium\">\n\t\t\t\t{languages.map(({ value: langKey, label, required }) => (\n\t\t\t\t\t<InputComponent\n\t\t\t\t\t\tdata-testid={`multi-lang-input-${name}-${langKey}`}\n\t\t\t\t\t\tkey={title + langKey}\n\t\t\t\t\t\tlabel={required ? `${label}*` : label}\n\t\t\t\t\t\tvariant={variant?.(langKey)}\n\t\t\t\t\t\tfeedback={feedback?.(langKey)}\n\t\t\t\t\t\tname={name}\n\t\t\t\t\t\tonChange={(e: ChangeEvent<HTMLInputElement>) => {\n\t\t\t\t\t\t\thandleOnChange(langKey, e.target.value);\n\t\t\t\t\t\t}}\n\t\t\t\t\t\tvalue={values[langKey] || \"\"}\n\t\t\t\t\t\t{...rest}\n\t\t\t\t\t/>\n\t\t\t\t))}\n\t\t\t</Stack>\n\t\t</ExpandablePanel>\n\t);\n};\n","import type { FC } from \"react\";\nimport React from \"react\";\n\nexport interface FormatCurrencyAmountProps {\n\tamount: number | string;\n\tas?: \"span\" | React.ElementType;\n\t[key: string]: object | string | number | boolean | undefined;\n}\n\nexport const FormatCurrencyAmount: FC<FormatCurrencyAmountProps> = ({\n\tamount,\n\tas: Component = \"span\",\n\t...rest\n}) => {\n\tconst parsedAmount = Number(amount) || 0;\n\n\tconst formattedAmount = new Intl.NumberFormat(\"nb-NO\", {\n\t\tmaximumFractionDigits: 2,\n\t\tminimumFractionDigits: 2,\n\t}).format(parsedAmount);\n\n\treturn <Component {...rest}>{formattedAmount}</Component>;\n};\n","import { splitUrlPath } from \"@entur-partner/util\";\nimport React from \"react\";\nimport { Helmet } from \"react-helmet-async\";\n\ntype Props = {\n\treadonly pathname: string;\n\treadonly onBreadcrumbLookup: (path: string) => string | undefined;\n};\n\n/**\n * @deprecated Won't work with React 19, because of react-helmet-async\n * This component changes page title by using helmet and current path. It will translate subpaths, join them with a dash\n * and display it on browser tab.\n *\n * @param Props.pathname - The current path from react-router-dom.useLocation()\n * @param Props.onBreadcrumbLookup - A function that takes a path and returns a i18n translated string or undefined\n * @returns A Helmet component with updated title\n */\nexport const LegacyPageTitle = ({ pathname, onBreadcrumbLookup }: Props) => {\n\tconst paths: string[] = splitUrlPath(pathname);\n\n\tconst pageTitles = paths\n\t\t.map((path) => ({ title: onBreadcrumbLookup(path), path }))\n\t\t.filter(({ title }) => title !== undefined)\n\t\t.map(({ title }) => title)\n\t\t.reverse()\n\t\t.join(\" | \");\n\n\treturn (\n\t\t<Helmet>\n\t\t\t<title>{pageTitles} | Entur Partner</title>\n\t\t</Helmet>\n\t);\n};\n","import { Link as A } from \"@entur/typography\";\nimport React, { type FC } from \"react\";\nimport { type LinkProps, Link as RouterLink } from \"react-router-dom\";\n\ninterface Props extends LinkProps {}\n\nexport const Link: FC<Props> = (props) => {\n\treturn (\n\t\t<A {...props} as={RouterLink}>\n\t\t\t{props.children}\n\t\t</A>\n\t);\n};\n","import \"./LinkButton.scss\";\n\nimport { Link } from \"@entur/typography\";\nimport cx from \"classnames\";\nimport React, { type ReactNode } from \"react\";\n\nexport interface LinkButtonProps {\n\tchildren: ReactNode;\n\tclassName?: string;\n\t[key: string]: object | string | number | boolean | undefined | ReactNode;\n}\n\nexport const LinkButton = ({\n\tchildren,\n\tclassName,\n\t...rest\n}: LinkButtonProps) => (\n\t<Link {...rest} as=\"button\" className={cx(\"eps-link-button\", className)}>\n\t\t{children}\n\t</Link>\n);\n","import \"./Menu.scss\";\n\nimport classnames from \"classnames\";\nimport type { FC, ReactNode } from \"react\";\nimport React from \"react\";\n\ninterface MenuProps {\n\tchildren: ReactNode;\n\tas?: \"div\" | React.ElementType;\n\tclassName?: string;\n}\nexport const Menu: FC<MenuProps> = ({\n\tas: Component = \"nav\",\n\tclassName,\n\tchildren,\n}) => {\n\tconst classList = classnames([\"eds-contrast\", \"eps-menu\", className]);\n\n\treturn <Component className={classList}>{children}</Component>;\n};\n","import \"./MultiLanguageInput.scss\";\n\nimport type { VariantType } from \"@entur/form\";\nimport cx from \"classnames\";\nimport React, {\n\ttype ChangeEvent,\n\ttype FC,\n\ttype FocusEvent,\n\tuseState,\n} from \"react\";\nimport { type LanguageOption, LanguageSelect } from \"./LanguageSelect\";\nimport { Stack } from \"./Stack\";\n\ntype Values = { [key: string]: string };\n\nexport interface MultiLanguageInputProps {\n\tclassName?: string;\n\tonBlur?: (e: FocusEvent<HTMLDivElement>) => void;\n\tinputComponent: React.ElementType;\n\tvalues: { [key: string]: string };\n\tlanguages: LanguageOption[];\n\tonChange: (values: Values) => void;\n\tname: string;\n\talertLevel?: VariantType;\n\talertLabel?: string;\n\tlabel?: string;\n\tdefaultLanguage?: string;\n\t[key: string]: object | string | number | boolean | undefined;\n}\n/**\n * @deprecated use ExpandableMultiLanguageInput\n */\nexport const MultiLanguageInput: FC<MultiLanguageInputProps> = ({\n\tclassName,\n\tinputComponent: InputComponent,\n\talertLabel,\n\talertLevel,\n\tname,\n\tlanguages,\n\tvalues,\n\tonChange,\n\tdefaultLanguage = \"nob\",\n\tlabel = \"\",\n\tonBlur = () => {},\n\t...rest\n}) => {\n\tconst [language, setLanguage] = useState(defaultLanguage);\n\tconst classNames = cx(\"multi-language-input\", className);\n\tconst currentValue = values[language];\n\n\tconst handleOnBlur = (e: FocusEvent<HTMLDivElement>) => {\n\t\te.persist();\n\t\tconst currentTarget = e.currentTarget;\n\t\tsetTimeout(() => {\n\t\t\tif (currentTarget && !currentTarget.contains(document.activeElement)) {\n\t\t\t\tonBlur(e);\n\t\t\t}\n\t\t}, 0);\n\t};\n\n\tconst handleLanguageChange = (language: string) => {\n\t\tsetLanguage(language);\n\t};\n\n\tconst handleOnChange = (value?: string) => {\n\t\tconst changes = Object.assign({}, values);\n\t\tif (value === \"\" || !value) {\n\t\t\tdelete changes[language];\n\t\t} else {\n\t\t\tchanges[language] = value;\n\t\t}\n\t\tonChange(changes);\n\t};\n\n\treturn (\n\t\t// biome-ignore lint/a11y/noStaticElementInteractions: Legacy component\n\t\t<div\n\t\t\tclassName={classNames}\n\t\t\t// biome-ignore lint/a11y/noNoninteractiveTabindex: Legacy component\n\t\t\ttabIndex={0}\n\t\t\tonBlur={handleOnBlur}\n\t\t\tdata-testid={`multi-lang-input-${name}`}\n\t\t>\n\t\t\t<Stack space=\"extraSmall\">\n\t\t\t\t<LanguageSelect\n\t\t\t\t\tlanguage={language}\n\t\t\t\t\toptions={languages}\n\t\t\t\t\tonChange={(lang) => handleLanguageChange(lang)}\n\t\t\t\t/>\n\t\t\t\t<InputComponent\n\t\t\t\t\tlabel={label}\n\t\t\t\t\tvariant={alertLevel}\n\t\t\t\t\tfeedback={alertLabel}\n\t\t\t\t\tname={name}\n\t\t\t\t\tclassName=\"language-item\"\n\t\t\t\t\tonChange={(e: ChangeEvent<HTMLInputElement>) =>\n\t\t\t\t\t\thandleOnChange(e.target.value)\n\t\t\t\t\t}\n\t\t\t\t\tvalue={currentValue || \"\"}\n\t\t\t\t\t{...rest}\n\t\t\t\t/>\n\t\t\t</Stack>\n\t\t</div>\n\t);\n};\n","import { SearchableDropdown } from \"@entur/dropdown\";\nimport React, { type FC, useEffect, useState } from \"react\";\n\ninterface OrganisationV3 {\n\torganisationId: number;\n\ttradingName: string;\n}\n\ninterface OrganisationDropDownProps {\n\tlabel: string;\n\tonChange: (organisationId: number) => void;\n\torganisations: OrganisationV3[];\n\tselectedOrganisationId?: number;\n\t[key: string]: object | string | number | boolean | undefined;\n}\n\nexport const OrganisationDropDown: FC<OrganisationDropDownProps> = ({\n\tlabel,\n\torganisations,\n\tonChange: handleChange,\n\tselectedOrganisationId,\n\t...rest\n}) => {\n\tconst [selectedOrganisation, setSelectedOrganisation] =\n\t\tuseState<OrganisationV3>();\n\n\tuseEffect(() => {\n\t\tsetSelectedOrganisation(\n\t\t\torganisations.find(\n\t\t\t\t(org) => org.organisationId === selectedOrganisationId,\n\t\t\t),\n\t\t);\n\t}, [selectedOrganisationId, organisations]);\n\n\treturn (\n\t\t<SearchableDropdown\n\t\t\tlabel={label}\n\t\t\titems={[\n\t\t\t\t...organisations\n\t\t\t\t\t.sort((a, b) => a.tradingName.localeCompare(b.tradingName, \"nb\"))\n\t\t\t\t\t.map((organisation) => {\n\t\t\t\t\t\treturn {\n\t\t\t\t\t\t\tvalue: organisation.organisationId,\n\t\t\t\t\t\t\tlabel: organisation.tradingName,\n\t\t\t\t\t\t};\n\t\t\t\t\t}),\n\t\t\t]}\n\t\t\tselectedItem={\n\t\t\t\tselectedOrganisation\n\t\t\t\t\t? {\n\t\t\t\t\t\t\tvalue: selectedOrganisation.organisationId,\n\t\t\t\t\t\t\tlabel: selectedOrganisation.tradingName,\n\t\t\t\t\t\t}\n\t\t\t\t\t: null\n\t\t\t}\n\t\t\tonChange={(selectedValue) => {\n\t\t\t\tif (selectedValue) {\n\t\t\t\t\thandleChange(selectedValue.value);\n\t\t\t\t}\n\t\t\t}}\n\t\t\tclearable={false}\n\t\t\t{...rest}\n\t\t/>\n\t);\n};\n","import { splitUrlPath } from \"@entur-partner/util\";\nimport { useEffect } from \"react\";\n\ntype Props = {\n\treadonly pathname: string;\n\treadonly onBreadcrumbLookup: (path: string) => string | undefined;\n};\n\nexport const PageTitle = ({ pathname, onBreadcrumbLookup }: Props) => {\n\tconst paths: string[] = splitUrlPath(pathname);\n\n\tconst pageTitles = paths\n\t\t.map((path) => ({ title: onBreadcrumbLookup(path), path }))\n\t\t.filter(({ title }) => title !== undefined)\n\t\t.map(({ title }) => title)\n\t\t.reverse()\n\t\t.join(\" | \");\n\n\tuseEffect(() => {\n\t\tdocument.title = `${pageTitles} | Entur Partner`;\n\t}, [pageTitles]);\n\n\treturn null;\n};\n","import { Pagination } from \"@entur/menu\";\nimport React, { type FC } from \"react\";\n\nexport interface PagerProps {\n\tcurrentPage: number;\n\tcollectionSize: number;\n\tpageSize: number;\n\tonPageChange: (page: number) => void;\n}\n\nexport const Pager: FC<PagerProps> = ({\n\tcollectionSize,\n\tpageSize,\n\tonPageChange,\n\tcurrentPage,\n}) => {\n\tconst pageCount = Math.ceil(collectionSize / pageSize);\n\treturn (\n\t\t<Pagination\n\t\t\tpageCount={pageCount}\n\t\t\tcurrentPage={currentPage}\n\t\t\tonPageChange={(page) => {\n\t\t\t\tonPageChange(page);\n\t\t\t}}\n\t\t/>\n\t);\n};\n","import type { BusinessCapability } from \"@entur-partner/permission-client-node\";\nimport { hasAllPermissions, hasOneOfPermissions } from \"@entur-partner/util\";\nimport React, { type FC, type ReactNode } from \"react\";\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\tchildren: ReactNode;\n\t/** User permissions to check */\n\tpermissions: BusinessCapability[];\n\t/** Check that at least one of the permissions is present */\n\toneOf?: BusinessCapability[];\n\t/** Check that all of the permissions is present */\n\tall?: BusinessCapability[] | BusinessCapability;\n\t/** Rendered if check fails. Defaults to null */\n\tfallback?: 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\tchildren,\n\tfallback = null,\n\tpermissions,\n\toneOf = [],\n\tall = [],\n}) => {\n\tconst allIsAllowed = hasAllPermissions(all, permissions);\n\n\tconst oneOfIsAllowed = hasOneOfPermissions(oneOf, permissions);\n\n\tconst allowed = allIsAllowed && oneOfIsAllowed;\n\treturn <>{allowed ? children : fallback}</>;\n};\n","import type { ModalProps } from \"@entur/modal\";\nimport { assertIsDefined } from \"@entur-partner/util\";\nimport type { Location } from \"history\";\nimport React, { type FC, type ReactNode } from \"react\";\nimport { useBlocker, useInRouterContext } from \"react-router-dom\";\n\nimport { ConfirmModal } from \"./ConfirmModal\";\n\nexport interface RouteLeavingGuardProps extends Partial<ModalProps> {\n\ttitle: string;\n\tcloseLabel: string;\n\tmessages: {\n\t\tcancel: string;\n\t\tconfirm: string;\n\t};\n\tchildren: ReactNode;\n\tshouldBlockNavigation: (location: Location) => boolean;\n}\n\nexport const RouteLeavingGuard: FC<RouteLeavingGuardProps> = ({\n\tchildren,\n\tshouldBlockNavigation,\n\t...rest\n}) => {\n\tassertIsDefined(\n\t\tuseInRouterContext() ? true : undefined,\n\t\t`RouteLeavingGuard must be used within a data router.`,\n\t);\n\n\tconst blocker = useBlocker(\n\t\t({ currentLocation, nextLocation }) =>\n\t\t\tcurrentLocation.pathname !== nextLocation.pathname &&\n\t\t\tshouldBlockNavigation(nextLocation),\n\t);\n\n\treturn (\n\t\t<ConfirmModal\n\t\t\tonDismiss={() => {\n\t\t\t\tif (blocker.state === \"blocked\") {\n\t\t\t\t\tblocker.reset();\n\t\t\t\t}\n\t\t\t}}\n\t\t\topen={blocker.state === \"blocked\"}\n\t\t\tonConfirm={() => {\n\t\t\t\tif (blocker.state === \"blocked\") {\n\t\t\t\t\tblocker.proceed();\n\t\t\t\t}\n\t\t\t}}\n\t\t\t{...rest}\n\t\t>\n\t\t\t{children}\n\t\t</ConfirmModal>\n\t);\n};\n","import \"./StatusLabel.scss\";\n\nimport cx from \"classnames\";\nimport React, { type FC } from \"react\";\n\ninterface StatusLabelProps {\n\tlabel: string;\n\tactive: boolean;\n\taggressiveInactive?: boolean;\n\tshowBullet?: boolean;\n\tcenter?: boolean;\n}\nexport const StatusLabel: FC<StatusLabelProps> = ({\n\tactive = false,\n\tlabel = \"\",\n\taggressiveInactive,\n\tshowBullet,\n\tcenter,\n}) => {\n\tconst bulletClassNames = cx(\"eps-status-label__bullet\", {\n\t\tactive,\n\t\taggressive: aggressiveInactive,\n\t});\n\tconst statusLabelClassNames = cx(\"eps-status-label\", {\n\t\tcenter,\n\t});\n\treturn (\n\t\t<div className={statusLabelClassNames}>\n\t\t\t{showBullet && <div className={bulletClassNames} />}\n\t\t\t<div>{label}</div>\n\t\t</div>\n\t);\n};\n","import \"./Text.scss\";\n\nimport cx from \"classnames\";\nimport type { ReactNode } from \"react\";\nimport React from \"react\";\n\nimport { Box, responsiveProp, type StyleColor } from \"./Box\";\n\ntype StyleFontSize =\n\t| \"extraSmall\"\n\t| \"small\"\n\t| \"medium\"\n\t| \"large\"\n\t| \"extraLarge\"\n\t| \"extraLarge2\"\n\t| \"extraLarge3\"\n\t| \"extraLarge4\";\n\ntype StyleFontWeight = \"body\" | \"heading\";\n\ntype StyleLineHeight =\n\t| \"extraSmall\"\n\t| \"small\"\n\t| \"medium\"\n\t| \"large\"\n\t| \"extraLarge\"\n\t| \"extraLarge2\"\n\t| \"extraLarge3\"\n\t| \"extraLarge4\"\n\t| \"extraLarge5\"\n\t| \"extraLarge6\"\n\t| \"extraLarge7\";\n\nexport type ResponsiveStyleFontSize =\n\t| StyleFontSize\n\t| [StyleFontSize?, StyleFontSize?, StyleFontSize?];\n\nexport type ResponsiveStyleLineHeight =\n\t| StyleLineHeight\n\t| [StyleLineHeight?, StyleLineHeight?, StyleLineHeight?];\n\nexport interface TextProps {\n\tclassName?: string;\n\tas?: React.ElementType;\n\tchildren: ReactNode;\n\tfontSize?: ResponsiveStyleFontSize;\n\tlineHeight?: ResponsiveStyleLineHeight;\n\tcolor?: StyleColor;\n\tfontWeight?: StyleFontWeight;\n\t// biome-ignore lint/suspicious/noExplicitAny: Ignore for now.\n\t[key: string]: any;\n}\n\nexport const Text = ({\n\tas: component = \"span\",\n\tchildren,\n\tfontSize,\n\tcolor,\n\tlineHeight,\n\tfontWeight,\n\tclassName,\n\t...rest\n}: TextProps) => {\n\tconst classes = [];\n\n\tfontSize && classes.push(...responsiveProp(\"eps-font-size-\", fontSize));\n\tlineHeight && classes.push(...responsiveProp(\"eps-line-height-\", lineHeight));\n\tfontWeight && classes.push(`eps-font-weight-${fontWeight}`);\n\n\tconst classList = cx(classes, className);\n\n\treturn (\n\t\t<Box as={component} color={color} className={classList} {...rest}>\n\t\t\t{children}\n\t\t</Box>\n\t);\n};\n","import \"./Unbutton.scss\";\n\nimport { Button, type ButtonProps } from \"@entur/button\";\nimport cx from \"classnames\";\nimport React, { type FC } from \"react\";\n\ninterface UnbuttonProps extends Omit<ButtonProps<typeof Button>, \"variant\"> {}\n\nexport const Unbutton: FC<UnbuttonProps> = ({\n\tchildren,\n\tclassName,\n\t...rest\n}) => (\n\t<Button variant=\"primary\" {...rest} className={cx(\"eps-unbutton\", className)}>\n\t\t{children}\n\t</Button>\n);\n","/** biome-ignore-all lint/correctness/useUniqueElementIds: Ignore unique id for now */\nimport \"./index.scss\";\n\nimport cx from \"classnames\";\nimport React, { type FC, useState } from \"react\";\n\nimport type { Environment } from \"../environment\";\nimport { CookieSettingsMenuItem } from \"./components/CookieSettingsMenuItem\";\nimport { CustomOverflowMenu } from \"./components/CustomOverflowMenu\";\nimport { LanguageSwitchMenuItem } from \"./components/LanguageSwitchMenuItem\";\nimport { LogOutMenuItem } from \"./components/LogOutMenuItem\";\nimport { UserMenuItem } from \"./components/UserMenuItem\";\nimport { VersionMenuItem } from \"./components/VersionMenuItem\";\n\ninterface UserMenuProps {\n\tuserName: string;\n\tmessages: {\n\t\tlogout: string;\n\t\tswitchLanguage: string;\n\t\tappVersion?: string;\n\t\tmyProfile?: string;\n\t\tcookieSettings?: string;\n\t};\n\tonLogout: () => void;\n\tonLanguageChange: (language: string) => void;\n\tlanguage: string;\n\tclassName?: string;\n\tenvironment?: Environment;\n\tshowVersionItem?: boolean;\n\tshowMyProfileItem?: boolean;\n\tshowCookieSettingsItem?: boolean;\n\tonNavigateToMyProfile: () => void;\n\tonCookieSettingsOpen?: () => void;\n}\n\nexport const UserMenu: FC<UserMenuProps> = ({\n\tclassName,\n\tmessages,\n\tonLogout,\n\tonLanguageChange,\n\tuserName,\n\tlanguage,\n\tenvironment,\n\tshowVersionItem,\n\tshowMyProfileItem,\n\tshowCookieSettingsItem,\n\tonNavigateToMyProfile,\n\tonCookieSettingsOpen = () => {},\n}) => {\n\tconst triggerClassList = cx([\"eps-user-menu__trigger-button\", className]);\n\tconst [open, setOpen] = useState(false);\n\n\treturn (\n\t\t<div id=\"eps-user-menu\">\n\t\t\t<CustomOverflowMenu\n\t\t\t\topen={open}\n\t\t\t\tonOpenChange={setOpen}\n\t\t\t\tclassName={triggerClassList}\n\t\t\t\tuserName={userName}\n\t\t\t\tenvironment={environment}\n\t\t\t>\n\t\t\t\t<div id=\"eps-overflow-menu\">\n\t\t\t\t\t<LanguageSwitchMenuItem\n\t\t\t\t\t\tname={messages.switchLanguage}\n\t\t\t\t\t\tlanguage={language}\n\t\t\t\t\t\tonLanguageChange={onLanguageChange}\n\t\t\t\t\t\tsetOpen={setOpen}\n\t\t\t\t\t/>\n\t\t\t\t\t{showVersionItem && messages.appVersion && (\n\t\t\t\t\t\t<VersionMenuItem title={messages.appVersion} setOpen={setOpen} />\n\t\t\t\t\t)}\n\t\t\t\t\t{showMyProfileItem && messages.myProfile && (\n\t\t\t\t\t\t<UserMenuItem\n\t\t\t\t\t\t\tname={messages.myProfile}\n\t\t\t\t\t\t\tsetOpen={setOpen}\n\t\t\t\t\t\t\tonNavigateToMyProfile={onNavigateToMyProfile}\n\t\t\t\t\t\t/>\n\t\t\t\t\t)}\n\t\t\t\t\t{showCookieSettingsItem && messages.cookieSettings && (\n\t\t\t\t\t\t<CookieSettingsMenuItem\n\t\t\t\t\t\t\tname={messages.cookieSettings}\n\t\t\t\t\t\t\tsetOpen={setOpen}\n\t\t\t\t\t\t\tonCookieSettingsOpen={onCookieSettingsOpen}\n\t\t\t\t\t\t/>\n\t\t\t\t\t)}\n\t\t\t\t\t<LogOutMenuItem\n\t\t\t\t\t\tname={messages.logout}\n\t\t\t\t\t\tsetOpen={setOpen}\n\t\t\t\t\t\tonLogout={onLogout}\n\t\t\t\t\t/>\n\t\t\t\t</div>\n\t\t\t</CustomOverflowMenu>\n\t\t</div>\n\t);\n};\n","/*global EventListener WindowEventHandlers*/\nimport { useEffect, useRef } from \"react\";\n\ntype TypedEventListener<T extends Event> = (evt: T) => void;\n\nexport function useEventListener<T extends Event = Event>(\n\teventName: string,\n\thandler: TypedEventListener<T>,\n\telement: WindowEventHandlers = window,\n) {\n\tconst savedHandler = useRef<TypedEventListener<T>>();\n\n\tuseEffect(() => {\n\t\tsavedHandler.current = handler;\n\t}, [handler]);\n\n\tuseEffect(() => {\n\t\tconst isSupported = element?.addEventListener;\n\t\tif (!isSupported) return;\n\n\t\tconst eventListener = ((event: T): void =>\n\t\t\tsavedHandler.current?.(event)) as EventListener;\n\n\t\telement.addEventListener(eventName, eventListener);\n\n\t\treturn () => {\n\t\t\telement.removeEventListener(eventName, eventListener);\n\t\t};\n\t}, [eventName, element]);\n}\n"],"names":["FormatDateTime","_ref","date","locale","_ref$as","as","Component","hideTime","rest","_objectWithoutPropertiesLoose","_excluded","React","createElement","_extends","localeDate","localeDateTime","responsiveProp","prefix","prop","Array","isArray","classes","push","Environment","Box","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","resolvedPaddingTop","resolvedPaddingBottom","resolvedPaddingLeft","resolvedPaddingRight","resolvedMarginTop","resolvedMarginBottom","resolvedMarginLeft","resolvedMarginRight","apply","classList","cx","Stack","space","stackItems","Children","toArray","length","Fragment","map","child","index","key","ConfirmModal","_ref$isOpen","isOpen","message","_ref$size","size","buttons","onConfirm","messages","onClose","onDismiss","childrenToRender","handleDismiss","Modal","open","isString","Paragraph","ButtonGroup","SecondaryButton","onClick","cancel","PrimaryButton","confirm","environmentColors","_environmentColors","Local","Development","Staging","getColorForEnvironment","environment","humanReadableEnvironment","_humanReadableEnviron","Production","getHumanReadableEnvironment","EnturPartnerLogoSvg","title","_ref$accentColor","accentColor","height","viewBox","fill","fillRule","d","ErrorBoundary","_Component","props","_this","call","this","state","error","getDerivedStateFromError","_proto","prototype","componentDidCatch","errorInfo","_this$props$handleErr","_this$props","handleError","render","_this2","_this$props2","fallback","isFunction","retry","setState","name","RefreshBannerInfo","LANGUAGE_STORAGE_KEY","language","localStorage","getItem","isNorwegian","BannerAlertBox","variant","window","location","reload","featureFlag","flag","_window$localStorage","_window$localStorage2","import","useFeatureToggle","LanguageSelect","options","onChange","classNames","SegmentedControl","assertIsDefined","selectedValue","option","SegmentedChoice","value","label","required","CustomOverflowMenuItem","role","CookieSettingsMenuItem","setOpen","onCookieSettingsOpen","CookieIcon","inline","elementContainsEventTarget","element","event","contains","target","composed","composedPath","find","CustomOverflowMenu","ref","buttonRef","handler","userName","onOpenChange","overflowItemsClasses","overflowContentRef","useRef","overflowMenuTriggerRef","useEffect","listener","current","document","addEventListener","removeEventListener","UserIcon","Heading6","undefined","style","DownArrowIcon","LanguageSwitchMenuItem","onLanguageChange","useB47LanguageKey","norwegianLanguageKey","englishLanguageKey","NorwayIcon","UKIcon","LogOutMenuItem","onLogout","LogOutIcon","UserMenuItem","onNavigateToMyProfile","Link","to","textDecoration","VersionMenuItem","navigate","useNavigate","ChannelsIcon","_ref3","_ref2","items","toString","isDate","isDateString","prependBreadcrumbItem","onBreadcrumbLookup","breadcrumbs","splitUrlPath","pathname","path","filter","breadcrumbElements","i","BreadcrumbItem","BreadcrumbNavigation","concat","classnames","_ref2$as","altText","InputComponent","inputComponent","languages","values","feedback","ExpandablePanel","defaultOpen","contentStyle","langKey","e","changes","amount","parsedAmount","Number","formattedAmount","Intl","NumberFormat","maximumFractionDigits","minimumFractionDigits","format","pageTitles","reverse","join","Helmet","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","setSelectedOrganisation","org","organisationId","SearchableDropdown","sort","a","b","tradingName","localeCompare","organisation","selectedItem","clearable","onPageChange","currentPage","pageCount","Math","ceil","collectionSize","pageSize","Pagination","page","_ref$fallback","permissions","_ref$oneOf","oneOf","_ref$all","all","allIsAllowed","hasAllPermissions","oneOfIsAllowed","hasOneOfPermissions","shouldBlockNavigation","useInRouterContext","blocker","useBlocker","nextLocation","currentLocation","reset","proceed","_ref$active","active","showBullet","center","bulletClassNames","aggressive","aggressiveInactive","statusLabelClassNames","component","fontSize","lineHeight","fontWeight","Button","showVersionItem","showMyProfileItem","showCookieSettingsItem","_ref$onCookieSettings","triggerClassList","id","switchLanguage","appVersion","myProfile","cookieSettings","logout","eventName","savedHandler","_element","eventListener"],"mappings":"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"}
|