@entur-partner/common 4.1.0 → 4.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +6 -0
- package/dist/FeatureToggle.d.ts +8 -0
- package/dist/common.cjs.development.js +13 -5
- 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 +13 -6
- package/dist/common.esm.js.map +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/styles.css +26 -26
- package/package.json +2 -2
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),t=require("classnames"),a=require("@entur/typography"),n=require("@entur/icons"),r=require("@entur/button"),l=require("@entur/dropdown"),u=require("@entur/form"),o=require("@entur-partner/util"),i=require("@entur/expand"),s=require("@entur/modal"),c=require("react-router-dom"),d=require("@entur/menu");function m(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var p=m(e),f=m(t);function v(){return v=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var a=arguments[t];for(var n in a)Object.prototype.hasOwnProperty.call(a,n)&&(e[n]=a[n])}return e},v.apply(this,arguments)}function g(e,t){return g=Object.setPrototypeOf||function(e,t){return e.__proto__=t,e},g(e,t)}function h(e,t){if(null==e)return{};var a,n,r={},l=Object.keys(e);for(n=0;n<l.length;n++)t.indexOf(a=l[n])>=0||(r[a]=e[a]);return r}var E=["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 b(e,t){if(Array.isArray(t)){var a=[];return t[0]&&a.push(e+t[0]),t[1]&&a.push(""+e+t[1]+"-lg"),t[2]&&a.push(""+e+t[2]+"-xl"),a}return[e+t]}var N=function(e){var t=e.as,a=void 0===t?"div":t,n=e.children,r=e.contrast,l=e.paddingTop,u=e.paddingRight,o=e.paddingBottom,i=e.paddingLeft,s=e.paddingX,c=e.paddingY,d=e.padding,m=e.marginTop,g=e.marginRight,N=e.marginBottom,x=e.marginLeft,y=e.marginX,C=e.marginY,L=e.margin,w=e.display,k=e.justifyContent,_=e.alignItems,B=e.maxWidth,O=e.width,z=e.background,P=e.color,S=e.flexDirection,F=e.flexWrap,D=e.className,I=h(e,E),M=[],A=l||c||d,R=o||c||d,T=i||s||d,V=u||s||d,j=m||C||L,q=N||C||L,H=x||y||L,W=g||y||L;r&&M.push("eds-contrast"),A&&M.push.apply(M,b("eps-pt-",A)),R&&M.push.apply(M,b("eps-pb-",R)),T&&M.push.apply(M,b("eps-pl-",T)),V&&M.push.apply(M,b("eps-pr-",V)),j&&M.push.apply(M,b("eps-mt-",j)),q&&M.push.apply(M,b("eps-mb-",q)),H&&M.push.apply(M,b("eps-ml-",H)),W&&M.push.apply(M,b("eps-mr-",W)),w&&M.push.apply(M,b("eps-",w)),k&&M.push.apply(M,b("eps-justify-",k)),_&&M.push.apply(M,b("eps-items-",_)),B&&M.push.apply(M,b("eps-max-w-",B)),O&&M.push.apply(M,b("eps-w-",O)),P&&M.push("eps-color-"+P),z&&M.push("eps-bg-"+z),S&&M.push.apply(M,b("eps-flex-",S)),F&&M.push.apply(M,b("eps-flex-wrap-",F));var U=f.default(M,D);return p.default.createElement(a,v({className:U},I),n)},x=function(t){var a=t.space,n=t.className,r=e.Children.toArray(t.children);return r.length<=1?p.default.createElement(p.default.Fragment,null,r):p.default.createElement("div",{className:n},r.map((function(e,t){return t===r.length-1?p.default.createElement("div",{key:t},e):p.default.createElement(N,{paddingBottom:a,key:t},e)})))},y=["children","className"];function C(e){var t,a;return"true"===process.env["REACT_APP_"+e]||"true"===(null==(t=window.localStorage)?void 0:t.getItem(e))||"true"===(null==(a=window.localStorage)?void 0:a.getItem("REACT_APP_"+e))}var L=["title"],w=function(e){var t=e.title,a=h(e,L);return p.default.createElement("svg",v({width:257,height:37,viewBox:"0 0 257 37"},a),p.default.createElement("title",null,t),p.default.createElement("g",{fill:"none",fillRule:"evenodd"},p.default.createElement("path",{fill:"#FFF",d:"M0 .231V25.72h18.745v-4.318H4.869v-6.163h12.31v-4.318H4.87V4.55h13.876V.231z"}),p.default.createElement("path",{fill:"#FF5959",d:"M0 36.408h45.253v-4.32H0z"}),p.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"}),p.default.createElement("g",{fill:"#FF5959"},p.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"}))))},k=["className","children","userName","open","onOpenChange"],_=function(e){var t,l,u,o=e.className,i=e.children,s=e.userName,c=e.open,d=e.onOpenChange,m=h(e,k),g=f.default("eps-overflow-menu__group",{"eps-overflow-menu__group--open":c}),E=p.default.useRef(null),b=p.default.useRef(null);return p.default.useEffect((function(){var e=function(e){O(t.current,e)||O(l.current,e)||u()};return document.addEventListener("mousedown",e),document.addEventListener("touchstart",e),function(){document.removeEventListener("mousedown",e),document.removeEventListener("touchstart",e)}}),[t=E,l=b,u=function(){return d(!1)}]),p.default.createElement("div",null,p.default.createElement(r.SecondaryButton,v({className:f.default("eps-overflow-menu__button",o),onClick:function(){return d(!c)},"aria-haspopup":!0,role:"button","aria-expanded":c,ref:b},m),p.default.createElement("div",{className:"eps-overflow-menu__button-contents"},p.default.createElement("span",{className:"eds-overflow-menu__user-icon"},p.default.createElement(n.UserIcon,{inline:!0})),p.default.createElement(a.Heading6,{margin:"none",as:"span"},s),p.default.createElement("span",{className:"eps-arrow-icon"},p.default.createElement(n.DownArrowIcon,{inline:!0})))),c&&p.default.createElement("div",{className:g,role:"menu",ref:E},i))},B=function(e){return p.default.createElement("button",v({className:f.default(e.className,"eps-overflow-menu__item"),role:"menuitem"},e))};function O(e,t){return!(!e||!(e.contains(t.target)||t.composed&&t.composedPath&&t.composedPath().find((function(t){return t!==window&&e.contains(t)}))))}var z=["label","organisations","onChange","selectedOrganisationId"],P=["language","options","className","onChange"],S=function(e){var t=e.language,a=e.options,n=e.className,r=e.onChange,l=h(e,P),i=f.default("eps-language-select",n);return p.default.createElement("div",v({},l,{className:i}),p.default.createElement(u.SegmentedControl,{onChange:function(e){o.assertIsDefined(e),r(e)},selectedValue:t},a.map((function(e){return p.default.createElement(u.SegmentedChoice,{key:e.value,value:e.value},e.label,e.required&&p.default.createElement("span",{className:"asterisk-margin"},"*"))}))))},F=["title","inputComponent","languages","values","onChange","name","variant","feedback"],D=["className","inputComponent","alertLabel","alertLevel","name","languages","values","onChange","defaultLanguage","label","onBlur"],I=["children","className"],M=function(e){var t,a;function n(t){var a;return(a=e.call(this,t)||this).state={error:null},a}a=e,(t=n).prototype=Object.create(a.prototype),t.prototype.constructor=t,g(t,a),n.getDerivedStateFromError=function(e){return{error:e}};var r=n.prototype;return r.componentDidCatch=function(e,t){var a,n;null==(a=(n=this.props).handleError)||a.call(n,e,t)},r.render=function(){var e,t=this,a=this.state.error,n=this.props,r=n.fallback,l=n.children;return a?(e=r)&&"[object Function]"==={}.toString.call(e)?r({retry:function(){return t.setState({error:null})},error:a}):r:l},n}(e.Component),A=["date","locale","as","hideTime"],R=function(e){var t=e.date,a=e.locale,n=e.as,r=void 0===n?"main":n,l=e.hideTime,u=h(e,A);return p.default.createElement(r,v({},u),l?o.localeDate(t,a):o.localeDateTime(t,a))},T=["amount","as"],V=["items","locale","className"],j=["isOpen","children","message","size","buttons","onConfirm","messages","onClose","onDismiss"],q=function(e){var t=e.isOpen,n=void 0!==t&&t,l=e.children,u=e.message,i=e.size,c=void 0===i?"medium":i,d=e.buttons,m=e.onConfirm,f=e.messages,g=e.onClose,E=e.onDismiss,b=h(e,j),x=l||u,y=g||E;return p.default.createElement(s.Modal,v({size:c,open:n,onDismiss:y},b),o.isString(x)?p.default.createElement(a.Paragraph,null,x):p.default.createElement(N,{paddingBottom:"medium"},x),p.default.createElement(r.ButtonGroup,null,m?p.default.createElement(p.default.Fragment,null,p.default.createElement(r.SecondaryButton,{onClick:y,"data-testid":"cancel-modal-button"},f.cancel),p.default.createElement(r.PrimaryButton,{onClick:m,"data-testid":"confirm-modal-button"},f.confirm)):d))},H=["children","shouldBlockNavigation"],W=function(e){var t=e.children,a=e.fallback,n=void 0===a?null:a,r=e.permissions,l=e.oneOf,u=void 0===l?[]:l,i=e.all,s=o.hasAllPermissions(void 0===i?[]:i,r),c=o.hasOneOfPermissions(u,r);return p.default.createElement(p.default.Fragment,null,s&&c?t:n)},U=["children","actualPermissions","all","oneOf","onReject"],X=["as","children","fontSize","color","lineHeight","fontWeight","className"];exports.ActionBar=function(e){var t=e.children;return p.default.createElement(p.default.Fragment,null,p.default.createElement("div",{className:"eps-action-bar-padding"}),p.default.createElement("div",{className:"eps-action-bar"},t))},exports.ActionBarLeft=function(e){return p.default.createElement("div",{className:"eps-action-bar-left"},e.children)},exports.ActionBarRight=function(e){return p.default.createElement("div",{className:"eps-action-bar-right"},e.children)},exports.AuditInfo=function(e){var t=e.items,a=e.locale,n=e.className,r=h(e,V),l=f.default("ep-audit-info",n);return p.default.createElement("div",v({className:l},r),t.map((function(e,t){var n=e.value;return p.default.createElement(x,{space:"small",key:t},p.default.createElement("div",{className:"ep-audit-info-label"},e.label),p.default.createElement("div",null,o.isDate(n)||o.isDateString(n)?p.default.createElement(R,{date:n,locale:a}):p.default.createElement("span",null,n)))})))},exports.Box=N,exports.Breadcrumbs=function(e){var t=e.prependBreadcrumbItem,a=e.pathname,n=e.onBreadcrumbLookup,r="/"===a?[]:["/"];(a.length>1?a.replace(/\/$/,""):a).split("/").reduce((function(e,t){var a=e+"/"+t;return r.push(a),a}));var l=r.map((function(e){return{title:n(e),path:e}})).filter((function(e){return void 0!==e.title})),u=l.map((function(e,t){var a=e.path;return p.default.createElement(d.BreadcrumbItem,t===l.length-1?{key:a,as:"span"}:{key:a,as:c.Link,to:a},e.title)}));return p.default.createElement(d.BreadcrumbNavigation,null,t?[t].concat(u):u)},exports.ConfirmModal=q,exports.Content=function(e){var t=e.as,a=void 0===t?"main":t,n=e.children,r=f.default(["eps-content",e.className]);return p.default.createElement(a,{className:r},n)},exports.EnturPartnerLogo=function(e){var t=e.as,a=void 0===t?"nav":t,n=e.altText,r=f.default(["eps-logo-wrapper",e.className]);return p.default.createElement(a,{className:r},p.default.createElement(w,{title:n,className:"logo"}))},exports.EnturPartnerLogoSvg=w,exports.ErrorBoundary=M,exports.ExpandableMultiLanguageInput=function(e){var t=e.title,a=e.inputComponent,n=e.languages,r=e.values,l=e.onChange,u=e.name,o=e.variant,s=e.feedback,c=h(e,F);return p.default.createElement(i.ExpandablePanel,{title:t,defaultOpen:!0,contentStyle:{padding:"4px 4px 4px 4px",marginTop:"16px",marginBottom:"16px"}},p.default.createElement(x,{space:"medium"},n.map((function(e){var n=e.value,i=e.label;return p.default.createElement(a,v({"data-testid":"multi-lang-input-"+u+"-"+n,key:t+n,label:e.required?i+"*":i,variant:o&&o(n),feedback:s&&s(n),name:u,onChange:function(e){var t,a,u;t=n,a=e.target.value,u=v({},r),""!==a&&a?u[t]=a:delete u[t],l(u)},value:r[n]||""},c))}))))},exports.FeatureToggle=function(e){var t=e.children;return C(e.flag)?p.default.createElement(p.default.Fragment,null,t):null},exports.FormatCurrencyAmount=function(e){var t=e.amount,a=e.as,n=void 0===a?"span":a,r=h(e,T),l=Number(t)||0,u=new Intl.NumberFormat("nb-NO",{maximumFractionDigits:2,minimumFractionDigits:2}).format(l);return p.default.createElement(n,v({},r),u)},exports.FormatDateTime=R,exports.LanguageSelect=S,exports.Link=function(e){return p.default.createElement(a.Link,v({},e,{as:c.Link}),e.children)},exports.LinkButton=function(e){var t=e.children,n=e.className,r=h(e,y);return p.default.createElement(a.Link,v({},r,{as:"button",className:f.default("eps-link-button",n)}),t)},exports.Menu=function(e){var t=e.as,a=void 0===t?"nav":t,n=e.children,r=f.default(["eds-contrast","eps-menu",e.className]);return p.default.createElement(a,{className:r},n)},exports.MultiLanguageInput=function(t){var a=t.className,n=t.inputComponent,r=t.alertLabel,l=t.alertLevel,u=t.name,o=t.languages,i=t.values,s=t.onChange,c=t.defaultLanguage,d=void 0===c?"nob":c,m=t.label,g=void 0===m?"":m,E=t.onBlur,b=void 0===E?function(){}:E,N=h(t,D),y=e.useState(d),C=y[0],L=y[1],w=f.default("multi-language-input",a),k=i[C];return p.default.createElement("div",{className:w,tabIndex:0,onBlur:function(e){e.persist();var t=e.currentTarget;setTimeout((function(){t&&!t.contains(document.activeElement)&&b(e)}),0)},"data-testid":"multi-lang-input-"+u},p.default.createElement(x,{space:"extraSmall"},p.default.createElement(S,{language:C,options:o,onChange:function(e){return function(e){L(e)}(e)}}),p.default.createElement(n,v({label:g,variant:l,feedback:r,name:u,className:"language-item",onChange:function(e){return t=e.target.value,a=Object.assign({},i),""!==t&&t?a[C]=t:delete a[C],void s(a);var t,a},value:k||""},N))))},exports.OrganisationDropDown=function(e){var t=e.label,a=e.organisations,n=e.onChange,r=e.selectedOrganisationId,u=h(e,z),o=a.find((function(e){return e.id===r}));return p.default.createElement(l.Dropdown,v({label:t,searchable:!0,clearable:!0,className:"eds-contrast",items:[].concat(a.sort((function(e,t){return e.name.localeCompare(t.name,"nb")})).map((function(e){return{value:e.id,label:e.name}}))),initialSelectedItem:o?{value:o.id,label:o.name}:null,onChange:function(e){e&&n(e.value)}},u))},exports.Pager=function(e){var t=e.onPageChange,a=e.currentPage,n=Math.ceil(e.collectionSize/e.pageSize);return p.default.createElement(d.Pagination,{pageCount:n,currentPage:a,onPageChange:function(e){t(e)}})},exports.PermissionCheck=W,exports.PermissionCheckedRoute=function(e){var t=e.children,a=e.actualPermissions,n=e.all,r=e.oneOf,l=e.onReject,u=h(e,U),o=p.default.createElement(c.Redirect,{to:{pathname:"/unauthorized",state:{from:u.location}}});return p.default.createElement(W,{permissions:a,all:n,oneOf:r,fallback:l||o},p.default.createElement(c.Route,v({},u),t))},exports.RouteLeavingGuard=function(t){var a=t.children,n=t.shouldBlockNavigation,r=h(t,H),l=c.useHistory(),u=e.useState("ALLOW"),o=u[0],i=u[1],s=e.useState(l.location),d=s[0],m=s[1];return p.default.createElement(p.default.Fragment,null,p.default.createElement(c.Prompt,{message:function(e){return!n(e)||"ALLOW"!==o||(i("BLOCKED"),m(e),!1)}}),p.default.createElement(q,v({onDismiss:function(){i("ALLOW")},open:"BLOCKED"===o,onConfirm:function(){l.push(d.pathname)}},r),a))},exports.Stack=x,exports.StatusLabel=function(e){var t=e.active,a=e.label,n=void 0===a?"":a,r=e.showBullet,l=e.center,u=f.default("eps-status-label__bullet",{active:void 0!==t&&t,aggressive:e.aggressiveInactive}),o=f.default("eps-status-label",{center:l});return p.default.createElement("div",{className:o},r&&p.default.createElement("div",{className:u}),p.default.createElement("div",null,n))},exports.Text=function(e){var t=e.as,a=void 0===t?"span":t,n=e.children,r=e.fontSize,l=e.color,u=e.lineHeight,o=e.fontWeight,i=e.className,s=h(e,X),c=[];r&&c.push.apply(c,b("eps-font-size-",r)),u&&c.push.apply(c,b("eps-line-height-",u)),o&&c.push("eps-font-weight-"+o);var d=f.default(c,i);return p.default.createElement(N,v({as:a,color:l,className:d},s),n)},exports.Unbutton=function(e){var t=e.children,a=e.className,n=h(e,I);return p.default.createElement(r.Button,v({variant:"primary"},n,{className:f.default("eps-unbutton",a)}),t)},exports.UserMenu=function(t){var a=t.messages,r=t.onLogout,l=t.onLanguageChange,u=t.onShowGdprDialog,o=t.userName,i=t.language,s=f.default(["eps-user-menu__trigger-button",t.className]),c=e.useState(!1),d=c[1];return p.default.createElement("div",{id:"eps-user-menu"},p.default.createElement(_,{open:c[0],onOpenChange:d,className:s,userName:o},p.default.createElement("div",{id:"eps-overflow-menu"},p.default.createElement(B,{onClick:function(){u(),d(!1)},className:"eps-overflow-menu__item"},p.default.createElement("span",{"aria-hidden":!0},p.default.createElement(n.PrivacyIcon,{size:"1rem",inline:!0})),a.termsAndConditions),"en"===i?p.default.createElement(B,{onClick:function(){l("nb"),d(!1)},className:"eps-overflow-menu__item"},p.default.createElement("span",{"aria-hidden":!0,className:"eps-overflow-menu__icon-margin"},p.default.createElement(n.NorwayIcon,{size:"1rem",inline:!0})),a.switchLanguage):p.default.createElement(B,{onClick:function(){l("en"),d(!1)},className:"eps-overflow-menu__item"},p.default.createElement("span",{"aria-hidden":!0,className:"eps-overflow-menu__icon-margin"},p.default.createElement(n.UKIcon,{size:"1rem",inline:!0})),a.switchLanguage),p.default.createElement(B,{onClick:function(){r(),d(!1)},"data-testid":"user-menu-logout",className:"eps-overflow-menu__item"},p.default.createElement("span",{"aria-hidden":!0},p.default.createElement(n.UploadIcon,{size:"1rem",inline:!0,style:{transform:"rotate(90deg)"}})),a.logout))))},exports.responsiveProp=b,exports.useEventListener=function(t,a,n){void 0===n&&(n=window);var r=e.useRef();e.useEffect((function(){r.current=a}),[a]),e.useEffect((function(){if(n&&n.addEventListener){var e=function(e){return null==r.current?void 0:r.current(e)};return n.addEventListener(t,e),function(){n.removeEventListener(t,e)}}}),[t,n])},exports.useFeatureToggle=C;
|
|
1
|
+
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("react"),t=require("classnames"),a=require("@entur/typography"),n=require("@entur/icons"),r=require("@entur/button"),l=require("@entur/dropdown"),u=require("@entur/form"),o=require("@entur-partner/util"),i=require("@entur/expand"),s=require("@entur/modal"),c=require("react-router-dom"),d=require("@entur/menu");function m(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}var p=m(e),f=m(t);function v(){return v=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var a=arguments[t];for(var n in a)Object.prototype.hasOwnProperty.call(a,n)&&(e[n]=a[n])}return e},v.apply(this,arguments)}function g(e,t){return g=Object.setPrototypeOf||function(e,t){return e.__proto__=t,e},g(e,t)}function h(e,t){if(null==e)return{};var a,n,r={},l=Object.keys(e);for(n=0;n<l.length;n++)t.indexOf(a=l[n])>=0||(r[a]=e[a]);return r}var E=["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 b(e,t){if(Array.isArray(t)){var a=[];return t[0]&&a.push(e+t[0]),t[1]&&a.push(""+e+t[1]+"-lg"),t[2]&&a.push(""+e+t[2]+"-xl"),a}return[e+t]}var N=function(e){var t=e.as,a=void 0===t?"div":t,n=e.children,r=e.contrast,l=e.paddingTop,u=e.paddingRight,o=e.paddingBottom,i=e.paddingLeft,s=e.paddingX,c=e.paddingY,d=e.padding,m=e.marginTop,g=e.marginRight,N=e.marginBottom,x=e.marginLeft,y=e.marginX,C=e.marginY,L=e.margin,w=e.display,k=e.justifyContent,_=e.alignItems,B=e.maxWidth,O=e.width,z=e.background,P=e.color,S=e.flexDirection,F=e.flexWrap,D=e.className,I=h(e,E),M=[],A=l||c||d,R=o||c||d,T=i||s||d,V=u||s||d,j=m||C||L,q=N||C||L,H=x||y||L,W=g||y||L;r&&M.push("eds-contrast"),A&&M.push.apply(M,b("eps-pt-",A)),R&&M.push.apply(M,b("eps-pb-",R)),T&&M.push.apply(M,b("eps-pl-",T)),V&&M.push.apply(M,b("eps-pr-",V)),j&&M.push.apply(M,b("eps-mt-",j)),q&&M.push.apply(M,b("eps-mb-",q)),H&&M.push.apply(M,b("eps-ml-",H)),W&&M.push.apply(M,b("eps-mr-",W)),w&&M.push.apply(M,b("eps-",w)),k&&M.push.apply(M,b("eps-justify-",k)),_&&M.push.apply(M,b("eps-items-",_)),B&&M.push.apply(M,b("eps-max-w-",B)),O&&M.push.apply(M,b("eps-w-",O)),P&&M.push("eps-color-"+P),z&&M.push("eps-bg-"+z),S&&M.push.apply(M,b("eps-flex-",S)),F&&M.push.apply(M,b("eps-flex-wrap-",F));var U=f.default(M,D);return p.default.createElement(a,v({className:U},I),n)},x=function(t){var a=t.space,n=t.className,r=e.Children.toArray(t.children);return r.length<=1?p.default.createElement(p.default.Fragment,null,r):p.default.createElement("div",{className:n},r.map((function(e,t){return t===r.length-1?p.default.createElement("div",{key:t},e):p.default.createElement(N,{paddingBottom:a,key:t},e)})))},y=["children","className"];function C(e){var t,a;return"true"===process.env["REACT_APP_"+e]||"true"===(null==(t=window.localStorage)?void 0:t.getItem(e))||"true"===(null==(a=window.localStorage)?void 0:a.getItem("REACT_APP_"+e))}function L(e){return C(e)}var w=["title"],k=function(e){var t=e.title,a=h(e,w);return p.default.createElement("svg",v({width:257,height:37,viewBox:"0 0 257 37"},a),p.default.createElement("title",null,t),p.default.createElement("g",{fill:"none",fillRule:"evenodd"},p.default.createElement("path",{fill:"#FFF",d:"M0 .231V25.72h18.745v-4.318H4.869v-6.163h12.31v-4.318H4.87V4.55h13.876V.231z"}),p.default.createElement("path",{fill:"#FF5959",d:"M0 36.408h45.253v-4.32H0z"}),p.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"}),p.default.createElement("g",{fill:"#FF5959"},p.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"}))))},_=["className","children","userName","open","onOpenChange"],B=function(e){var t,l,u,o=e.className,i=e.children,s=e.userName,c=e.open,d=e.onOpenChange,m=h(e,_),g=f.default("eps-overflow-menu__group",{"eps-overflow-menu__group--open":c}),E=p.default.useRef(null),b=p.default.useRef(null);return p.default.useEffect((function(){var e=function(e){z(t.current,e)||z(l.current,e)||u()};return document.addEventListener("mousedown",e),document.addEventListener("touchstart",e),function(){document.removeEventListener("mousedown",e),document.removeEventListener("touchstart",e)}}),[t=E,l=b,u=function(){return d(!1)}]),p.default.createElement("div",null,p.default.createElement(r.SecondaryButton,v({className:f.default("eps-overflow-menu__button",o),onClick:function(){return d(!c)},"aria-haspopup":!0,role:"button","aria-expanded":c,ref:b},m),p.default.createElement("div",{className:"eps-overflow-menu__button-contents"},p.default.createElement("span",{className:"eds-overflow-menu__user-icon"},p.default.createElement(n.UserIcon,{inline:!0})),p.default.createElement(a.Heading6,{margin:"none",as:"span"},s),p.default.createElement("span",{className:"eps-arrow-icon"},p.default.createElement(n.DownArrowIcon,{inline:!0})))),c&&p.default.createElement("div",{className:g,role:"menu",ref:E},i))},O=function(e){return p.default.createElement("button",v({className:f.default(e.className,"eps-overflow-menu__item"),role:"menuitem"},e))};function z(e,t){return!(!e||!(e.contains(t.target)||t.composed&&t.composedPath&&t.composedPath().find((function(t){return t!==window&&e.contains(t)}))))}var P=["label","organisations","onChange","selectedOrganisationId"],S=["language","options","className","onChange"],F=function(e){var t=e.language,a=e.options,n=e.className,r=e.onChange,l=h(e,S),i=f.default("eps-language-select",n);return p.default.createElement("div",v({},l,{className:i}),p.default.createElement(u.SegmentedControl,{onChange:function(e){o.assertIsDefined(e),r(e)},selectedValue:t},a.map((function(e){return p.default.createElement(u.SegmentedChoice,{key:e.value,value:e.value},e.label,e.required&&p.default.createElement("span",{className:"asterisk-margin"},"*"))}))))},D=["title","inputComponent","languages","values","onChange","name","variant","feedback"],I=["className","inputComponent","alertLabel","alertLevel","name","languages","values","onChange","defaultLanguage","label","onBlur"],M=["children","className"],A=function(e){var t,a;function n(t){var a;return(a=e.call(this,t)||this).state={error:null},a}a=e,(t=n).prototype=Object.create(a.prototype),t.prototype.constructor=t,g(t,a),n.getDerivedStateFromError=function(e){return{error:e}};var r=n.prototype;return r.componentDidCatch=function(e,t){var a,n;null==(a=(n=this.props).handleError)||a.call(n,e,t)},r.render=function(){var e,t=this,a=this.state.error,n=this.props,r=n.fallback,l=n.children;return a?(e=r)&&"[object Function]"==={}.toString.call(e)?r({retry:function(){return t.setState({error:null})},error:a}):r:l},n}(e.Component),R=["date","locale","as","hideTime"],T=function(e){var t=e.date,a=e.locale,n=e.as,r=void 0===n?"main":n,l=e.hideTime,u=h(e,R);return p.default.createElement(r,v({},u),l?o.localeDate(t,a):o.localeDateTime(t,a))},V=["amount","as"],j=["items","locale","className"],q=["isOpen","children","message","size","buttons","onConfirm","messages","onClose","onDismiss"],H=function(e){var t=e.isOpen,n=void 0!==t&&t,l=e.children,u=e.message,i=e.size,c=void 0===i?"medium":i,d=e.buttons,m=e.onConfirm,f=e.messages,g=e.onClose,E=e.onDismiss,b=h(e,q),x=l||u,y=g||E;return p.default.createElement(s.Modal,v({size:c,open:n,onDismiss:y},b),o.isString(x)?p.default.createElement(a.Paragraph,null,x):p.default.createElement(N,{paddingBottom:"medium"},x),p.default.createElement(r.ButtonGroup,null,m?p.default.createElement(p.default.Fragment,null,p.default.createElement(r.SecondaryButton,{onClick:y,"data-testid":"cancel-modal-button"},f.cancel),p.default.createElement(r.PrimaryButton,{onClick:m,"data-testid":"confirm-modal-button"},f.confirm)):d))},W=["children","shouldBlockNavigation"],U=function(e){var t=e.children,a=e.fallback,n=void 0===a?null:a,r=e.permissions,l=e.oneOf,u=void 0===l?[]:l,i=e.all,s=o.hasAllPermissions(void 0===i?[]:i,r),c=o.hasOneOfPermissions(u,r);return p.default.createElement(p.default.Fragment,null,s&&c?t:n)},X=["children","actualPermissions","all","oneOf","onReject"],Y=["as","children","fontSize","color","lineHeight","fontWeight","className"];exports.ActionBar=function(e){var t=e.children;return p.default.createElement(p.default.Fragment,null,p.default.createElement("div",{className:"eps-action-bar-padding"}),p.default.createElement("div",{className:"eps-action-bar"},t))},exports.ActionBarLeft=function(e){return p.default.createElement("div",{className:"eps-action-bar-left"},e.children)},exports.ActionBarRight=function(e){return p.default.createElement("div",{className:"eps-action-bar-right"},e.children)},exports.AuditInfo=function(e){var t=e.items,a=e.locale,n=e.className,r=h(e,j),l=f.default("ep-audit-info",n);return p.default.createElement("div",v({className:l},r),t.map((function(e,t){var n=e.value;return p.default.createElement(x,{space:"small",key:t},p.default.createElement("div",{className:"ep-audit-info-label"},e.label),p.default.createElement("div",null,o.isDate(n)||o.isDateString(n)?p.default.createElement(T,{date:n,locale:a}):p.default.createElement("span",null,n)))})))},exports.Box=N,exports.Breadcrumbs=function(e){var t=e.prependBreadcrumbItem,a=e.pathname,n=e.onBreadcrumbLookup,r="/"===a?[]:["/"];(a.length>1?a.replace(/\/$/,""):a).split("/").reduce((function(e,t){var a=e+"/"+t;return r.push(a),a}));var l=r.map((function(e){return{title:n(e),path:e}})).filter((function(e){return void 0!==e.title})),u=l.map((function(e,t){var a=e.path;return p.default.createElement(d.BreadcrumbItem,t===l.length-1?{key:a,as:"span"}:{key:a,as:c.Link,to:a},e.title)}));return p.default.createElement(d.BreadcrumbNavigation,null,t?[t].concat(u):u)},exports.ConfirmModal=H,exports.Content=function(e){var t=e.as,a=void 0===t?"main":t,n=e.children,r=f.default(["eps-content",e.className]);return p.default.createElement(a,{className:r},n)},exports.EnturPartnerLogo=function(e){var t=e.as,a=void 0===t?"nav":t,n=e.altText,r=f.default(["eps-logo-wrapper",e.className]);return p.default.createElement(a,{className:r},p.default.createElement(k,{title:n,className:"logo"}))},exports.EnturPartnerLogoSvg=k,exports.ErrorBoundary=A,exports.ExpandableMultiLanguageInput=function(e){var t=e.title,a=e.inputComponent,n=e.languages,r=e.values,l=e.onChange,u=e.name,o=e.variant,s=e.feedback,c=h(e,D);return p.default.createElement(i.ExpandablePanel,{title:t,defaultOpen:!0,contentStyle:{padding:"4px 4px 4px 4px",marginTop:"16px",marginBottom:"16px"}},p.default.createElement(x,{space:"medium"},n.map((function(e){var n=e.value,i=e.label;return p.default.createElement(a,v({"data-testid":"multi-lang-input-"+u+"-"+n,key:t+n,label:e.required?i+"*":i,variant:o&&o(n),feedback:s&&s(n),name:u,onChange:function(e){var t,a,u;t=n,a=e.target.value,u=v({},r),""!==a&&a?u[t]=a:delete u[t],l(u)},value:r[n]||""},c))}))))},exports.FeatureToggle=function(e){var t=e.children;return L(e.flag)?p.default.createElement(p.default.Fragment,null,t):null},exports.FormatCurrencyAmount=function(e){var t=e.amount,a=e.as,n=void 0===a?"span":a,r=h(e,V),l=Number(t)||0,u=new Intl.NumberFormat("nb-NO",{maximumFractionDigits:2,minimumFractionDigits:2}).format(l);return p.default.createElement(n,v({},r),u)},exports.FormatDateTime=T,exports.LanguageSelect=F,exports.Link=function(e){return p.default.createElement(a.Link,v({},e,{as:c.Link}),e.children)},exports.LinkButton=function(e){var t=e.children,n=e.className,r=h(e,y);return p.default.createElement(a.Link,v({},r,{as:"button",className:f.default("eps-link-button",n)}),t)},exports.Menu=function(e){var t=e.as,a=void 0===t?"nav":t,n=e.children,r=f.default(["eds-contrast","eps-menu",e.className]);return p.default.createElement(a,{className:r},n)},exports.MultiLanguageInput=function(t){var a=t.className,n=t.inputComponent,r=t.alertLabel,l=t.alertLevel,u=t.name,o=t.languages,i=t.values,s=t.onChange,c=t.defaultLanguage,d=void 0===c?"nob":c,m=t.label,g=void 0===m?"":m,E=t.onBlur,b=void 0===E?function(){}:E,N=h(t,I),y=e.useState(d),C=y[0],L=y[1],w=f.default("multi-language-input",a),k=i[C];return p.default.createElement("div",{className:w,tabIndex:0,onBlur:function(e){e.persist();var t=e.currentTarget;setTimeout((function(){t&&!t.contains(document.activeElement)&&b(e)}),0)},"data-testid":"multi-lang-input-"+u},p.default.createElement(x,{space:"extraSmall"},p.default.createElement(F,{language:C,options:o,onChange:function(e){return function(e){L(e)}(e)}}),p.default.createElement(n,v({label:g,variant:l,feedback:r,name:u,className:"language-item",onChange:function(e){return t=e.target.value,a=Object.assign({},i),""!==t&&t?a[C]=t:delete a[C],void s(a);var t,a},value:k||""},N))))},exports.OrganisationDropDown=function(e){var t=e.label,a=e.organisations,n=e.onChange,r=e.selectedOrganisationId,u=h(e,P),o=a.find((function(e){return e.id===r}));return p.default.createElement(l.Dropdown,v({label:t,searchable:!0,clearable:!0,className:"eds-contrast",items:[].concat(a.sort((function(e,t){return e.name.localeCompare(t.name,"nb")})).map((function(e){return{value:e.id,label:e.name}}))),initialSelectedItem:o?{value:o.id,label:o.name}:null,onChange:function(e){e&&n(e.value)}},u))},exports.Pager=function(e){var t=e.onPageChange,a=e.currentPage,n=Math.ceil(e.collectionSize/e.pageSize);return p.default.createElement(d.Pagination,{pageCount:n,currentPage:a,onPageChange:function(e){t(e)}})},exports.PermissionCheck=U,exports.PermissionCheckedRoute=function(e){var t=e.children,a=e.actualPermissions,n=e.all,r=e.oneOf,l=e.onReject,u=h(e,X),o=p.default.createElement(c.Redirect,{to:{pathname:"/unauthorized",state:{from:u.location}}});return p.default.createElement(U,{permissions:a,all:n,oneOf:r,fallback:l||o},p.default.createElement(c.Route,v({},u),t))},exports.RouteLeavingGuard=function(t){var a=t.children,n=t.shouldBlockNavigation,r=h(t,W),l=c.useHistory(),u=e.useState("ALLOW"),o=u[0],i=u[1],s=e.useState(l.location),d=s[0],m=s[1];return p.default.createElement(p.default.Fragment,null,p.default.createElement(c.Prompt,{message:function(e){return!n(e)||"ALLOW"!==o||(i("BLOCKED"),m(e),!1)}}),p.default.createElement(H,v({onDismiss:function(){i("ALLOW")},open:"BLOCKED"===o,onConfirm:function(){l.push(d.pathname)}},r),a))},exports.Stack=x,exports.StatusLabel=function(e){var t=e.active,a=e.label,n=void 0===a?"":a,r=e.showBullet,l=e.center,u=f.default("eps-status-label__bullet",{active:void 0!==t&&t,aggressive:e.aggressiveInactive}),o=f.default("eps-status-label",{center:l});return p.default.createElement("div",{className:o},r&&p.default.createElement("div",{className:u}),p.default.createElement("div",null,n))},exports.Text=function(e){var t=e.as,a=void 0===t?"span":t,n=e.children,r=e.fontSize,l=e.color,u=e.lineHeight,o=e.fontWeight,i=e.className,s=h(e,Y),c=[];r&&c.push.apply(c,b("eps-font-size-",r)),u&&c.push.apply(c,b("eps-line-height-",u)),o&&c.push("eps-font-weight-"+o);var d=f.default(c,i);return p.default.createElement(N,v({as:a,color:l,className:d},s),n)},exports.Unbutton=function(e){var t=e.children,a=e.className,n=h(e,M);return p.default.createElement(r.Button,v({variant:"primary"},n,{className:f.default("eps-unbutton",a)}),t)},exports.UserMenu=function(t){var a=t.messages,r=t.onLogout,l=t.onLanguageChange,u=t.onShowGdprDialog,o=t.userName,i=t.language,s=f.default(["eps-user-menu__trigger-button",t.className]),c=e.useState(!1),d=c[1];return p.default.createElement("div",{id:"eps-user-menu"},p.default.createElement(B,{open:c[0],onOpenChange:d,className:s,userName:o},p.default.createElement("div",{id:"eps-overflow-menu"},p.default.createElement(O,{onClick:function(){u(),d(!1)},className:"eps-overflow-menu__item"},p.default.createElement("span",{"aria-hidden":!0},p.default.createElement(n.PrivacyIcon,{size:"1rem",inline:!0})),a.termsAndConditions),"en"===i?p.default.createElement(O,{onClick:function(){l("nb"),d(!1)},className:"eps-overflow-menu__item"},p.default.createElement("span",{"aria-hidden":!0,className:"eps-overflow-menu__icon-margin"},p.default.createElement(n.NorwayIcon,{size:"1rem",inline:!0})),a.switchLanguage):p.default.createElement(O,{onClick:function(){l("en"),d(!1)},className:"eps-overflow-menu__item"},p.default.createElement("span",{"aria-hidden":!0,className:"eps-overflow-menu__icon-margin"},p.default.createElement(n.UKIcon,{size:"1rem",inline:!0})),a.switchLanguage),p.default.createElement(O,{onClick:function(){r(),d(!1)},"data-testid":"user-menu-logout",className:"eps-overflow-menu__item"},p.default.createElement("span",{"aria-hidden":!0},p.default.createElement(n.UploadIcon,{size:"1rem",inline:!0,style:{transform:"rotate(90deg)"}})),a.logout))))},exports.featureFlag=C,exports.responsiveProp=b,exports.useEventListener=function(t,a,n){void 0===n&&(n=window);var r=e.useRef();e.useEffect((function(){r.current=a}),[a]),e.useEffect((function(){if(n&&n.addEventListener){var e=function(e){return null==r.current?void 0:r.current(e)};return n.addEventListener(t,e),function(){n.removeEventListener(t,e)}}}),[t,n])},exports.useFeatureToggle=L;
|
|
2
2
|
//# sourceMappingURL=common.cjs.production.min.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"common.cjs.production.min.js","sources":["../src/Box.tsx","../src/Stack.tsx","../src/FeatureToggle.tsx","../src/EnturPartnerLogo.tsx","../src/UserMenu.tsx","../src/LanguageSelect.tsx","../src/ErrorBoundary.tsx","../src/helpers.ts","../src/FormatDateTime.tsx","../src/ConfirmModal.tsx","../src/PermissionCheck.tsx","../src/ActionBar.tsx","../src/AuditInfo.tsx","../src/Breadcrumbs.tsx","../src/Content.tsx","../src/ExpandableMultiLanguageInput.tsx","../src/FormatCurrencyAmount.tsx","../src/Link.tsx","../src/LinkButton.tsx","../src/Menu.tsx","../src/MultiLanguageInput.tsx","../src/OrganisationDropdown.tsx","../src/Pager.tsx","../src/PermissionCheckedRoute.tsx","../src/RouteLeavingGuard.tsx","../src/StatusLabel.tsx","../src/Text.tsx","../src/Unbutton.tsx","../src/useEventListener.ts"],"sourcesContent":["import './Box.scss';\n\nimport React, { ReactNode } from 'react';\nimport cx from 'classnames';\n\ntype StyleSpacing =\n | 'none'\n | 'extraSmall2'\n | 'extraSmall'\n | 'small'\n | 'medium'\n | 'large'\n | 'extraLarge'\n | 'extraLarge2'\n | 'extraLarge3'\n | 'extraLarge4'\n | 'extraLarge5'\n | 'extraLarge6'\n | 'extraLarge7'\n | 'extraLarge8'\n | 'extraLarge9';\n\ntype StyleMargin = StyleSpacing | 'auto';\n\ntype StyleDisplay = 'block' | 'flex' | 'inline' | 'inline-block';\ntype StyleJustifyContent = 'center' | 'space-between' | 'start' | 'end';\ntype StyleAlignItems = 'center' | 'start' | 'end' | 'stretch' | 'baseline';\n\ntype StyleMaxWidth =\n | 'none'\n | 'extraSmall'\n | 'small'\n | 'medium'\n | 'large'\n | 'extraLarge'\n | 'extraLarge2'\n | 'extraLarge3'\n | 'extraLarge4'\n | 'extraLarge5'\n | 'extraLarge6'\n | 'full';\ntype StyleWidth = 'auto' | 'full';\n\nexport type StyleBackground = 'blue' | 'lavender' | 'white' | 'blue70';\nexport type StyleColor = 'blue' | 'lavender' | 'white' | 'black';\n\ntype StyleFlexDirection = 'row' | 'column' | 'row-reverse' | 'column-reverse';\ntype StyleFlexWrap = 'wrap' | 'nowrap' | 'wrap-reverse';\n\nexport type ResponsiveStyleSpacing =\n | StyleSpacing\n | [StyleSpacing?, StyleSpacing?, StyleSpacing?];\nexport type ResponsiveStyleMargin =\n | StyleMargin\n | [StyleMargin?, StyleMargin?, StyleMargin?];\n\nexport type ResponsiveStyleDisplay =\n | StyleDisplay\n | [StyleDisplay?, StyleDisplay?, StyleDisplay?];\nexport type ResponsiveStyleJustifyContent =\n | StyleJustifyContent\n | [StyleJustifyContent?, StyleJustifyContent?, StyleJustifyContent?];\nexport type ResponsiveStyleAlignItems =\n | StyleAlignItems\n | [StyleAlignItems?, StyleAlignItems?, StyleAlignItems?];\n\nexport type ResponsiveStyleMaxWidth =\n | StyleMaxWidth\n | [StyleMaxWidth?, StyleMaxWidth?, StyleMaxWidth?];\nexport type ResponsiveStyleWidth =\n | StyleWidth\n | [StyleWidth?, StyleWidth?, StyleWidth?];\n\nexport type ResponsiveStyleFlexDirection =\n | StyleFlexDirection\n | [StyleFlexDirection?, StyleFlexDirection?, StyleFlexDirection?];\nexport type ResponsiveStyleFlexWrap =\n | StyleFlexWrap\n | [StyleFlexWrap?, StyleFlexWrap?, StyleFlexWrap?];\n\nexport interface BoxProps {\n className?: string;\n as?: React.ElementType;\n [key: string]: any;\n children: ReactNode;\n\n contrast?: boolean;\n\n paddingTop?: ResponsiveStyleSpacing;\n paddingRight?: ResponsiveStyleSpacing;\n paddingBottom?: ResponsiveStyleSpacing;\n paddingLeft?: ResponsiveStyleSpacing;\n paddingX?: ResponsiveStyleSpacing;\n paddingY?: ResponsiveStyleSpacing;\n padding?: ResponsiveStyleSpacing;\n\n marginTop?: ResponsiveStyleMargin;\n marginRight?: ResponsiveStyleMargin;\n marginBottom?: ResponsiveStyleMargin;\n marginLeft?: ResponsiveStyleMargin;\n marginX?: ResponsiveStyleMargin;\n marginY?: ResponsiveStyleMargin;\n margin?: ResponsiveStyleMargin;\n\n display?: ResponsiveStyleDisplay;\n justifyContent?: ResponsiveStyleJustifyContent;\n alignItems?: ResponsiveStyleAlignItems;\n\n maxWidth?: ResponsiveStyleMaxWidth;\n width?: ResponsiveStyleWidth;\n background?: StyleBackground;\n color?: StyleColor;\n\n flexDirection?: ResponsiveStyleFlexDirection;\n flexWrap?: ResponsiveStyleFlexWrap;\n}\n\ntype ResponsiveProp = string | [string?, string?, string?];\n\nexport function responsiveProp(prefix: string, prop: ResponsiveProp): string[] {\n if (Array.isArray(prop)) {\n const classes = [];\n prop[0] && classes.push(prefix + prop[0]);\n prop[1] && classes.push(`${prefix}${prop[1]}-lg`);\n prop[2] && classes.push(`${prefix}${prop[2]}-xl`);\n return classes;\n }\n return [prefix + prop];\n}\n\nexport const Box = ({\n as: Component = 'div',\n children,\n contrast,\n paddingTop,\n paddingRight,\n paddingBottom,\n paddingLeft,\n paddingX,\n paddingY,\n padding,\n marginTop,\n marginRight,\n marginBottom,\n marginLeft,\n marginX,\n marginY,\n margin,\n display,\n justifyContent,\n alignItems,\n maxWidth,\n width,\n background,\n color,\n flexDirection,\n flexWrap,\n className,\n ...rest\n}: BoxProps) => {\n const classes = [];\n const resolvedPaddingTop = paddingTop || paddingY || padding;\n const resolvedPaddingBottom = paddingBottom || paddingY || padding;\n const resolvedPaddingLeft = paddingLeft || paddingX || padding;\n const resolvedPaddingRight = paddingRight || paddingX || padding;\n\n const resolvedMarginTop = marginTop || marginY || margin;\n const resolvedMarginBottom = marginBottom || marginY || margin;\n const resolvedMarginLeft = marginLeft || marginX || margin;\n const resolvedMarginRight = marginRight || marginX || margin;\n\n contrast && classes.push('eds-contrast');\n resolvedPaddingTop &&\n classes.push(...responsiveProp('eps-pt-', resolvedPaddingTop));\n resolvedPaddingBottom &&\n classes.push(...responsiveProp('eps-pb-', resolvedPaddingBottom));\n resolvedPaddingLeft &&\n classes.push(...responsiveProp('eps-pl-', resolvedPaddingLeft));\n resolvedPaddingRight &&\n classes.push(...responsiveProp('eps-pr-', resolvedPaddingRight));\n resolvedMarginTop &&\n classes.push(...responsiveProp('eps-mt-', resolvedMarginTop));\n resolvedMarginBottom &&\n classes.push(...responsiveProp('eps-mb-', resolvedMarginBottom));\n resolvedMarginLeft &&\n classes.push(...responsiveProp('eps-ml-', resolvedMarginLeft));\n resolvedMarginRight &&\n classes.push(...responsiveProp('eps-mr-', resolvedMarginRight));\n\n display && classes.push(...responsiveProp('eps-', display));\n justifyContent &&\n classes.push(...responsiveProp('eps-justify-', justifyContent));\n if (alignItems) {\n classes.push(...responsiveProp('eps-items-', alignItems));\n }\n\n maxWidth && classes.push(...responsiveProp('eps-max-w-', maxWidth));\n width && classes.push(...responsiveProp('eps-w-', width));\n\n color && classes.push(`eps-color-${color}`);\n background && classes.push(`eps-bg-${background}`);\n\n flexDirection && classes.push(...responsiveProp('eps-flex-', flexDirection));\n flexWrap && classes.push(...responsiveProp('eps-flex-wrap-', flexWrap));\n\n const classList = cx(classes, className);\n\n return (\n <Component className={classList} {...rest}>\n {children}\n </Component>\n );\n};\n","import React, { ReactNode, Children } from 'react';\n\nimport { ResponsiveStyleSpacing, Box } from './Box';\n\nexport interface StackProps {\n className?: string;\n children: ReactNode;\n space: ResponsiveStyleSpacing;\n}\n\nexport const Stack = ({ children, space, className }: StackProps) => {\n const stackItems = Children.toArray(children);\n if (stackItems.length <= 1) {\n return <>{stackItems}</>;\n }\n\n return (\n <div className={className}>\n {stackItems.map((child, index) =>\n index === stackItems.length - 1 ? (\n <div key={index}>{child}</div>\n ) : (\n <Box paddingBottom={space} key={index}>\n {child}\n </Box>\n )\n )}\n </div>\n );\n};\n","import React, { ReactNode } from 'react';\n\n/**\n * Returns true if the provided flag exist in localStorage\n * or is set as an environment variable.\n *\n * @param flag case sensitive flag. If it is an environment variable\n * you can drop the REACT_APP_ prefix.\n */\nexport function useFeatureToggle(flag: string): boolean {\n if (\n process.env[`REACT_APP_${flag}`] === 'true' ||\n window.localStorage?.getItem(flag) === 'true' ||\n window.localStorage?.getItem(`REACT_APP_${flag}`) === 'true'\n ) {\n return true;\n }\n return false;\n}\n\nexport interface FeatureToggleProps {\n /** Visible if flag exist, hidden if not.*/\n children: ReactNode;\n /** Case sensitive flag. If it is an environment variable\n * you can drop the REACT_APP_ prefix. */\n flag: string;\n}\n\nexport const FeatureToggle = ({ children, flag }: FeatureToggleProps) => {\n const feature = useFeatureToggle(flag);\n if (feature) {\n return <>{children}</>;\n }\n return null;\n};\n","import './EnturPartnerLogo.scss';\n\nimport React, { FC } from 'react';\nimport classnames from 'classnames';\n\ninterface LogoProps {\n title: string;\n className?: string;\n [key: string]: any;\n}\n\nexport const EnturPartnerLogoSvg: FC<LogoProps> = ({ title, ...rest }) => {\n return (\n <svg width={257} height={37} viewBox=\"0 0 257 37\" {...rest}>\n <title>{title}</title>\n <g fill=\"none\" fillRule=\"evenodd\">\n <path\n fill=\"#FFF\"\n d=\"M0 .231V25.72h18.745v-4.318H4.869v-6.163h12.31v-4.318H4.87V4.55h13.876V.231z\"\n />\n <path fill=\"#FF5959\" d=\"M0 36.408h45.253v-4.32H0z\" />\n <path\n fill=\"#FFF\"\n d=\"M40.384.231v15.425L23.656.231h-.521V25.72h4.869V10.573L44.732 25.72h.521V.23zM69.25 15.238h-7.267v21.17h-4.87v-21.17H49.81V10.92h19.44zM83.863 36.86c-1.646 0-3.142-.255-4.486-.765-1.345-.51-2.493-1.23-3.443-2.159-.95-.928-1.687-2.054-2.208-3.378-.522-1.323-.783-2.797-.783-4.422V10.92h4.869v15.216c0 1.277.209 2.333.626 3.169.417.836.933 1.497 1.548 1.985a5.346 5.346 0 001.982 1.01c.707.186 1.339.278 1.895.278.557 0 1.188-.092 1.896-.279a5.35 5.35 0 001.982-1.01c.614-.487 1.13-1.148 1.548-1.984.417-.836.625-1.892.625-3.169V10.92h4.87v15.216c0 1.625-.256 3.1-.766 4.422-.51 1.324-1.24 2.45-2.19 3.378-.952.929-2.1 1.648-3.444 2.159-1.344.51-2.851.766-4.52.766M104.21 24.047h5.546c1.016 0 1.854-.127 2.513-.383.658-.255 1.179-.592 1.56-1.01.381-.418.641-.888.78-1.41.138-.522.208-1.05.208-1.584 0-.627-.099-1.207-.295-1.741a3.718 3.718 0 00-.901-1.393c-.405-.394-.924-.708-1.56-.94-.636-.232-1.404-.348-2.305-.348h-5.546v8.81zm0 4.248v8.113h-4.87V10.92h11.567c1.3 0 2.49.215 3.57.644 1.08.43 2.004 1.033 2.77 1.81a8.287 8.287 0 011.794 2.787c.43 1.079.645 2.257.645 3.534 0 .952-.128 1.874-.383 2.768-.256.894-.61 1.7-1.063 2.42a7.32 7.32 0 01-1.672 1.863 5.929 5.929 0 01-2.178 1.096l6.339 8.566h-5.808l-5.893-8.113h-4.818z\"\n />\n <g fill=\"#FF5959\">\n <path d=\"M141.051 23.448h5.628c4.185 0 5.989-1.984 5.989-4.942 0-2.742-1.515-4.618-5.989-4.618h-5.628v9.56zm0 3.067v9.776h-3.571V10.75h9.632c6.674 0 9.127 3.211 9.127 7.54 0 4.979-3.102 8.226-9.2 8.226h-5.988zM169.695 28.715c-1.371-.288-2.958-.505-4.401-.505-2.85 0-4.041 1.263-4.041 3.139s1.407 2.706 3.463 2.706c2.49 0 4.979-1.443 4.979-4.221v-1.119zm-4.293-2.958c1.551 0 3.174.253 4.293.469v-.83c0-2.525-1.154-3.896-4.33-3.896-2.164 0-3.824.866-4.942 2.092l-2.02-2.272c1.732-1.66 3.644-2.598 7.07-2.598 5.052 0 7.469 1.876 7.469 7.215v10.354h-3.211V34.02h-.108c-1.082 1.767-3.211 2.705-5.592 2.705-3.32 0-6.241-1.66-6.241-5.303 0-3.103 1.912-5.664 7.612-5.664zM178.965 19.191h3.211v2.886h.108c.938-1.984 2.922-3.355 5.231-3.355.47 0 .938.036 1.335.144l-.144 3.14a6.77 6.77 0 00-1.552-.181c-3.246 0-4.798 2.633-4.798 5.483v8.983h-3.39v-17.1zM199.961 36.291h-1.912c-4.004 0-5.988-.938-5.988-5.772v-8.55h-2.778V19.19h2.778v-4.654h3.355v4.654h4.473v2.778h-4.473v7.973c0 3.427 1.587 3.535 3.319 3.535h1.226v2.814zM219.767 36.291h-3.391V26.84c0-2.778-1.083-5.375-4.257-5.375-3.14 0-5.268 2.597-5.268 6.169v8.658h-3.391v-17.1h3.32v2.814h.143c.794-1.623 3.067-3.283 5.99-3.283 4.941 0 6.854 3.644 6.854 8.081v9.488zM227.847 26.262h10.57c0-2.597-2.272-4.726-5.087-4.726-2.922 0-5.014 1.948-5.483 4.726zm-.036 2.453c.397 3.355 2.633 5.195 5.844 5.195 2.778 0 4.618-1.623 5.484-2.67l2.164 1.804c-1.37 1.913-4.365 3.716-8.045 3.716-4.942 0-8.73-3.535-8.73-8.55 0-5.195 3.752-9.488 8.983-9.488 5.303 0 8.009 4.365 8.009 8.19 0 .649-.036 1.226-.072 1.803H227.81zM246.245 19.191h3.21v2.886h.109c.938-1.984 2.922-3.355 5.231-3.355.469 0 .938.036 1.335.144l-.145 3.14a6.77 6.77 0 00-1.551-.181c-3.247 0-4.798 2.633-4.798 5.483v8.983h-3.391v-17.1z\" />\n </g>\n </g>\n </svg>\n );\n};\n\ninterface EnturPartnerLogoProps {\n altText: string;\n as?: 'div' | React.ElementType;\n className?: string;\n}\n\nexport const EnturPartnerLogo: FC<EnturPartnerLogoProps> = ({\n as: Component = 'nav',\n className,\n altText,\n}) => {\n const classList = classnames(['eps-logo-wrapper', className]);\n\n return (\n <Component className={classList}>\n <EnturPartnerLogoSvg title={altText} className=\"logo\" />\n </Component>\n );\n};\n","import './UserMenu.scss';\n\nimport React, { FC, useState } from 'react';\nimport cx from 'classnames';\nimport {\n UserIcon,\n UploadIcon,\n PrivacyIcon,\n DownArrowIcon,\n UKIcon,\n NorwayIcon,\n} from '@entur/icons';\nimport { SecondaryButton } from '@entur/button';\nimport { Heading6 } from '@entur/typography';\n\ninterface UserMenuProps {\n userName: string;\n messages: {\n logout: string;\n termsAndConditions: string;\n switchLanguage: string;\n };\n onLogout: () => void;\n onShowGdprDialog: () => void;\n onLanguageChange: (language: string) => void;\n language: string;\n className?: string;\n}\n\nexport const UserMenu: FC<UserMenuProps> = ({\n className,\n messages,\n onLogout,\n onLanguageChange,\n onShowGdprDialog,\n userName,\n language,\n}) => {\n const triggerClassList = cx(['eps-user-menu__trigger-button', className]);\n const [open, setOpen] = useState(false);\n\n return (\n <div id=\"eps-user-menu\">\n <CustomOverflowMenu\n open={open}\n onOpenChange={setOpen}\n className={triggerClassList}\n userName={userName}\n >\n <div id=\"eps-overflow-menu\">\n <CustomOverflowMenuItem\n onClick={() => {\n onShowGdprDialog();\n setOpen(false);\n }}\n className=\"eps-overflow-menu__item\"\n >\n <span aria-hidden>\n <PrivacyIcon size=\"1rem\" inline />\n </span>\n {messages.termsAndConditions}\n </CustomOverflowMenuItem>\n {language === 'en' ? (\n <CustomOverflowMenuItem\n onClick={() => {\n onLanguageChange('nb');\n setOpen(false);\n }}\n className=\"eps-overflow-menu__item\"\n >\n <span aria-hidden className=\"eps-overflow-menu__icon-margin\">\n <NorwayIcon size=\"1rem\" inline />\n </span>\n {messages.switchLanguage}\n </CustomOverflowMenuItem>\n ) : (\n <CustomOverflowMenuItem\n onClick={() => {\n onLanguageChange('en');\n setOpen(false);\n }}\n className=\"eps-overflow-menu__item\"\n >\n <span aria-hidden className=\"eps-overflow-menu__icon-margin\">\n <UKIcon size=\"1rem\" inline />\n </span>\n {messages.switchLanguage}\n </CustomOverflowMenuItem>\n )}\n <CustomOverflowMenuItem\n onClick={() => {\n onLogout();\n setOpen(false);\n }}\n data-testid=\"user-menu-logout\"\n className=\"eps-overflow-menu__item\"\n >\n <span aria-hidden>\n <UploadIcon\n size=\"1rem\"\n inline\n style={{ transform: 'rotate(90deg)' }}\n />\n </span>\n {messages.logout}\n </CustomOverflowMenuItem>\n </div>\n </CustomOverflowMenu>\n </div>\n );\n};\n\nconst CustomOverflowMenu: React.FC<{\n className?: string;\n children: React.ReactNode;\n userName: string;\n open: boolean;\n onOpenChange: (open: boolean) => void;\n}> = ({ className, children, userName, open, onOpenChange, ...rest }) => {\n const overflowItemsClasses = cx('eps-overflow-menu__group', {\n 'eps-overflow-menu__group--open': open,\n });\n const overflowContentRef = React.useRef<HTMLDivElement>(null);\n const overflowMenuTriggerRef = React.useRef<HTMLButtonElement>(null);\n useOutsideClick(overflowContentRef, overflowMenuTriggerRef, () =>\n onOpenChange(false)\n );\n return (\n <div>\n <SecondaryButton\n className={cx('eps-overflow-menu__button', className)}\n onClick={() => onOpenChange(open ? false : true)}\n aria-haspopup={true}\n role=\"button\"\n aria-expanded={open}\n ref={overflowMenuTriggerRef}\n {...rest}\n >\n <div className=\"eps-overflow-menu__button-contents\">\n <span className=\"eds-overflow-menu__user-icon\">\n <UserIcon inline />\n </span>\n <Heading6 margin=\"none\" as=\"span\">\n {userName}\n </Heading6>\n <span className=\"eps-arrow-icon\">\n <DownArrowIcon inline />\n </span>\n </div>\n </SecondaryButton>\n {open && (\n <div\n className={overflowItemsClasses}\n role=\"menu\"\n ref={overflowContentRef}\n >\n {children}\n </div>\n )}\n </div>\n );\n};\n\nconst CustomOverflowMenuItem: React.FC<\n React.DetailedHTMLProps<\n React.ButtonHTMLAttributes<HTMLButtonElement>,\n HTMLButtonElement\n >\n> = (props) => {\n return (\n <button\n className={cx(props.className, 'eps-overflow-menu__item')}\n role=\"menuitem\"\n {...props}\n />\n );\n};\n\nfunction elementContainsEventTarget(element: HTMLElement | null, event: Event) {\n if (!element) {\n return false;\n }\n\n if (element.contains(event.target as Node)) {\n return true;\n }\n\n // For elements inside a Shadow DOM we need to check the composedPath\n if (event.composed && event.composedPath) {\n const contains = event.composedPath().find((target) => {\n if (target === window) {\n return false;\n }\n return element.contains(target as Node);\n });\n return contains ? true : false;\n }\n\n return false;\n}\n\nfunction useOutsideClick(\n ref: React.RefObject<HTMLDivElement>,\n buttonRef: React.RefObject<HTMLButtonElement>,\n handler: () => void\n) {\n React.useEffect(() => {\n const listener = (event: Event) => {\n if (\n elementContainsEventTarget(ref.current, event) ||\n elementContainsEventTarget(buttonRef.current, event)\n ) {\n return;\n }\n\n handler();\n };\n\n document.addEventListener('mousedown', listener);\n document.addEventListener('touchstart', listener);\n\n return () => {\n document.removeEventListener('mousedown', listener);\n document.removeEventListener('touchstart', listener);\n };\n }, [ref, buttonRef, handler]);\n}\n","import './LanguageSelect.scss';\n\nimport React, { FC } from 'react';\nimport { SegmentedControl, SegmentedChoice } from '@entur/form';\nimport cx from 'classnames';\nimport { assertIsDefined } from '@entur-partner/util';\n\nexport type LanguageKey = 'nob' | 'nno' | 'eng';\n\nexport interface LanguageOption {\n value: LanguageKey;\n label: string;\n required: boolean;\n}\n\nexport interface LanguageSelectProps {\n language: string;\n options: LanguageOption[];\n className?: string;\n onChange: (language: string) => void;\n [key: string]: any;\n}\n\nexport const LanguageSelect: FC<LanguageSelectProps> = ({\n language,\n options,\n className,\n onChange,\n ...rest\n}) => {\n const classNames = cx('eps-language-select', className);\n return (\n <div {...rest} className={classNames}>\n <SegmentedControl\n onChange={(language) => {\n assertIsDefined(language);\n onChange(language);\n }}\n selectedValue={language}\n >\n {options.map((option) => (\n <SegmentedChoice key={option.value} value={option.value}>\n {option.label}\n {option.required && <span className=\"asterisk-margin\">{'*'}</span>}\n </SegmentedChoice>\n ))}\n </SegmentedControl>\n </div>\n );\n};\n","import { ReactNode, Component, ErrorInfo } from 'react';\n\nimport { isFunction } from './helpers';\n\ntype FallbackOptions = {\n retry: () => void;\n error: Error;\n};\n\ntype RenderProp = (options: FallbackOptions) => ReactNode;\n\ntype Props = {\n handleError?: (error: Error, errorInfo: ErrorInfo) => void;\n fallback: ReactNode | RenderProp;\n children: ReactNode;\n};\n\ntype State = {\n error: null | Error;\n};\n\nexport class ErrorBoundary extends Component<Props, State> {\n constructor(props: Props) {\n super(props);\n this.state = { error: null };\n }\n\n static getDerivedStateFromError(error: Error): State {\n return {\n error,\n };\n }\n\n componentDidCatch(error: Error, errorInfo: ErrorInfo) {\n // React always logs in development\n this.props.handleError?.(error, errorInfo);\n }\n\n render() {\n const { error } = this.state;\n const { fallback, children } = this.props;\n\n if (error) {\n if (isFunction<RenderProp>(fallback)) {\n return fallback({ retry: () => this.setState({ error: null }), error });\n }\n return fallback;\n }\n\n return children;\n }\n}\n","export function isFunction<T>(functionToCheck: any): functionToCheck is T {\n return (\n functionToCheck && {}.toString.call(functionToCheck) === '[object Function]'\n );\n}\n","import React, { FC } from 'react';\nimport { localeDate, localeDateTime } from '@entur-partner/util';\n\nexport interface FormatDateTimeProps {\n date: string | Date;\n locale: string;\n [key: string]: any;\n}\n\nexport const FormatDateTime: FC<FormatDateTimeProps> = ({\n date,\n locale,\n as: Component = 'main',\n hideTime,\n ...rest\n}) => {\n return (\n <Component {...rest}>\n {hideTime ? localeDate(date, locale) : localeDateTime(date, locale)}\n </Component>\n );\n};\n","import './ConfirmModal.scss';\n\nimport React, { ReactNode, FC } from 'react';\nimport { Modal, ModalProps } from '@entur/modal';\nimport { Paragraph } from '@entur/typography';\nimport { isString } from '@entur-partner/util';\nimport { ButtonGroup, SecondaryButton, PrimaryButton } from '@entur/button';\n\nimport { Box } from './Box';\n\nexport interface BaseConfirmModalProps extends Partial<ModalProps> {\n title: string;\n children: React.ReactNode;\n closeLabel: string;\n\n /** Deprecated use children prop */\n message?: ReactNode;\n /** Deprecated use open prop */\n isOpen?: boolean;\n /** Deprecated use onDismiss prop */\n onClose?: () => void;\n}\n\ninterface CustomConfirmModalButtons extends BaseConfirmModalProps {\n buttons: ReactNode[];\n}\n\ninterface DefaultConfirmModalHandler extends BaseConfirmModalProps {\n onConfirm: () => void;\n messages: {\n confirm: string;\n cancel: string;\n };\n}\n\nexport type ConfirmModalProps =\n | CustomConfirmModalButtons\n | DefaultConfirmModalHandler;\n\nexport const ConfirmModal: FC<ConfirmModalProps> = ({\n isOpen = false,\n children,\n message,\n size = 'medium',\n buttons,\n onConfirm,\n messages,\n onClose,\n onDismiss,\n ...rest\n}) => {\n const childrenToRender = children ? children : message;\n const handleDismiss = onClose ? onClose : onDismiss;\n return (\n <Modal size={size} open={isOpen} onDismiss={handleDismiss} {...rest}>\n {isString(childrenToRender) ? (\n <Paragraph>{childrenToRender}</Paragraph>\n ) : (\n <Box paddingBottom=\"medium\">{childrenToRender}</Box>\n )}\n\n <ButtonGroup>\n {onConfirm ? (\n <>\n <SecondaryButton\n onClick={handleDismiss}\n data-testid=\"cancel-modal-button\"\n >\n {messages.cancel}\n </SecondaryButton>\n <PrimaryButton\n onClick={onConfirm}\n data-testid=\"confirm-modal-button\"\n >\n {messages.confirm}\n </PrimaryButton>\n </>\n ) : (\n buttons\n )}\n </ButtonGroup>\n </Modal>\n );\n};\n","import React, { ReactNode, FC } from 'react';\nimport { BusinessCapability } from '@entur-partner/permission-client-node';\nimport { hasAllPermissions, hasOneOfPermissions } from '@entur-partner/util';\n\n/**\n * Note: We use BusinessCapability here, not because we only want to check\n * BusinessCapabilities but because it represents a minimal subset of what we\n * need to check.\n */\nexport interface PermissionCheckProps {\n children: ReactNode;\n /** User permissions to check */\n permissions: BusinessCapability[];\n /** Check that at least one of the permissions is present */\n oneOf?: BusinessCapability[];\n /** Check that all of the permissions is present */\n all?: BusinessCapability[] | BusinessCapability;\n /** Rendered if check fails. Defaults to null */\n fallback?: ReactNode;\n}\n\n/**\n * Note: This component uses BusinessCapability, not because we only want to\n * check BusinessCapabilities but because it represents a minimal subset of\n * what we need to check.\n */\nexport const PermissionCheck: FC<PermissionCheckProps> = ({\n children,\n fallback = null,\n permissions,\n oneOf = [],\n all = [],\n}) => {\n const allIsAllowed = hasAllPermissions(all, permissions);\n\n const oneOfIsAllowed = hasOneOfPermissions(oneOf, permissions);\n\n const allowed = allIsAllowed && oneOfIsAllowed;\n return <>{allowed ? children : fallback}</>;\n};\n","import './ActionBar.scss';\nimport React, { ReactNode } from 'react';\n\nexport interface ActionBarProps {\n children: ReactNode;\n}\n\nconst ActionBarLeft = ({ children }: ActionBarProps) => {\n return <div className=\"eps-action-bar-left\">{children}</div>;\n};\n\nconst ActionBarRight = ({ children }: ActionBarProps) => {\n return <div className=\"eps-action-bar-right\">{children}</div>;\n};\n\nconst ActionBar = ({ children }: ActionBarProps) => {\n return (\n <>\n <div className=\"eps-action-bar-padding\" />\n <div className=\"eps-action-bar\">{children}</div>\n </>\n );\n};\n\nexport { ActionBar, ActionBarLeft, ActionBarRight };\n","import './AuditInfo.scss';\n\nimport React, { FC } from 'react';\nimport cx from 'classnames';\nimport { isDateString, isDate } from '@entur-partner/util';\n\nimport { FormatDateTime } from './FormatDateTime';\nimport { Stack } from './Stack';\n\ninterface Item {\n label: string;\n value: Date | string;\n}\n\nexport interface AuditInfoProps {\n items: Item[];\n locale: string;\n className?: string;\n [key: string]: any;\n}\n\nexport const AuditInfo: FC<AuditInfoProps> = ({\n items,\n locale,\n className,\n ...rest\n}) => {\n const classNames = cx('ep-audit-info', className);\n return (\n <div className={classNames} {...rest}>\n {items.map(({ label, value }, i) => (\n <Stack space=\"small\" key={i}>\n <div className=\"ep-audit-info-label\">{label}</div>\n <div>\n {isDate(value) || isDateString(value) ? (\n <FormatDateTime date={value} locale={locale} />\n ) : (\n <span>{value}</span>\n )}\n </div>\n </Stack>\n ))}\n </div>\n );\n};\n","import './Breadcrumbs.scss';\nimport React, { FC, ReactElement } from 'react';\nimport { Link } from 'react-router-dom';\nimport { BreadcrumbNavigation, BreadcrumbItem } from '@entur/menu';\n\nexport interface BreadcrumbsProps {\n pathname: string;\n onBreadcrumbLookup: (path: string) => string | undefined;\n prependBreadcrumbItem?: ReactElement;\n}\n\nexport const Breadcrumbs: FC<BreadcrumbsProps> = ({\n prependBreadcrumbItem,\n pathname,\n onBreadcrumbLookup,\n}) => {\n const paths: string[] = pathname === '/' ? [] : ['/'];\n\n // support paths with and without trailing slash, except root\n const adjustedPathname =\n pathname.length > 1 ? pathname.replace(/\\/$/, '') : pathname;\n\n adjustedPathname.split('/').reduce((prev, curr) => {\n const path = `${prev}/${curr}`;\n paths.push(path);\n return path;\n });\n\n const breadcrumbs = paths\n .map((path) => ({ title: onBreadcrumbLookup(path), path }))\n .filter(({ title }) => title !== undefined);\n\n const breadcrumbElements = breadcrumbs.map(({ title, path }, i) => {\n const isLast = i === breadcrumbs.length - 1;\n if (isLast) {\n return (\n <BreadcrumbItem key={path} as={'span'}>\n {title}\n </BreadcrumbItem>\n );\n }\n return (\n <BreadcrumbItem key={path} as={Link} to={path}>\n {title}\n </BreadcrumbItem>\n );\n });\n\n if (prependBreadcrumbItem) {\n return (\n <BreadcrumbNavigation>\n {[prependBreadcrumbItem, ...breadcrumbElements]}\n </BreadcrumbNavigation>\n );\n }\n\n return <BreadcrumbNavigation>{breadcrumbElements}</BreadcrumbNavigation>;\n};\n","import './Content.scss';\n\nimport React, { FC, ReactNode } from 'react';\nimport classnames from 'classnames';\n\ninterface ContentProps {\n children: ReactNode;\n as?: 'main' | React.ElementType;\n className?: string;\n}\nexport const Content: FC<ContentProps> = ({\n as: Component = 'main',\n className,\n children,\n}) => {\n const classList = classnames(['eps-content', className]);\n\n return <Component className={classList}>{children}</Component>;\n};\n","import React, { ChangeEvent } from 'react';\nimport { VariantType } from '@entur/form';\nimport { ExpandablePanel } from '@entur/expand';\n\nimport { LanguageKey, LanguageOption } from './LanguageSelect';\nimport { Stack } from './Stack';\n\nexport type MultiLanguageValues = Record<LanguageKey, string>;\n\ntype ExpandableMultiLanguageInputProps = {\n title: string;\n inputComponent: React.ElementType;\n languages: LanguageOption[];\n values: MultiLanguageValues;\n onChange: (values: MultiLanguageValues) => void;\n name: string;\n variant?: (lang: LanguageKey) => VariantType;\n feedback?: (lang: LanguageKey) => string;\n [key: string]: any;\n};\n\nexport const ExpandableMultiLanguageInput = ({\n title,\n inputComponent: InputComponent,\n languages,\n values,\n onChange,\n name,\n variant,\n feedback,\n ...rest\n}: ExpandableMultiLanguageInputProps) => {\n const handleOnChange = (language: LanguageKey, value?: string) => {\n const changes = { ...values };\n if (value === '' || !value) {\n delete changes[language];\n } else {\n changes[language] = value;\n }\n onChange(changes);\n };\n\n return (\n <ExpandablePanel\n title={title}\n defaultOpen\n contentStyle={{\n padding: '4px 4px 4px 4px',\n marginTop: '16px',\n marginBottom: '16px',\n }}\n >\n <Stack space=\"medium\">\n {languages.map(({ value: langKey, label, required }) => (\n <InputComponent\n data-testid={`multi-lang-input-${name}-${langKey}`}\n key={title + langKey}\n label={required ? label + '*' : label}\n variant={variant && variant(langKey)}\n feedback={feedback && feedback(langKey)}\n name={name}\n onChange={(e: ChangeEvent<HTMLInputElement>) => {\n handleOnChange(langKey, e.target.value);\n }}\n value={values[langKey] || ''}\n {...rest}\n />\n ))}\n </Stack>\n </ExpandablePanel>\n );\n};\n","import React, { FC } from 'react';\n\nexport interface FormatCurrencyAmountProps {\n amount: number | string;\n as?: 'span' | React.ElementType;\n [key: string]: any;\n}\n\nexport const FormatCurrencyAmount: FC<FormatCurrencyAmountProps> = ({\n amount,\n as: Component = 'span',\n ...rest\n}) => {\n const parsedAmount = Number(amount) || 0;\n\n const formattedAmount = new Intl.NumberFormat('nb-NO', {\n maximumFractionDigits: 2,\n minimumFractionDigits: 2,\n }).format(parsedAmount);\n\n return <Component {...rest}>{formattedAmount}</Component>;\n};\n","import React, { FC } from 'react';\nimport { Link as RouterLink, LinkProps } from 'react-router-dom';\nimport { Link as A } from '@entur/typography';\n\ninterface Props extends LinkProps {}\n\nexport const Link: FC<Props> = (props) => {\n return (\n <A {...props} as={RouterLink}>\n {props.children}\n </A>\n );\n};\n","import './LinkButton.scss';\n\nimport React, { ReactNode } from 'react';\nimport { Link } from '@entur/typography';\nimport cx from 'classnames';\n\nexport interface LinkButtonProps {\n children: ReactNode;\n className?: string;\n [key: string]: any;\n}\n\nexport const LinkButton = ({\n children,\n className,\n ...rest\n}: LinkButtonProps) => (\n <Link {...rest} as=\"button\" className={cx('eps-link-button', className)}>\n {children}\n </Link>\n);\n","import './Menu.scss';\n\nimport React, { FC, ReactNode } from 'react';\nimport classnames from 'classnames';\n\ninterface MenuProps {\n children: ReactNode;\n as?: 'div' | React.ElementType;\n className?: string;\n}\nexport const Menu: FC<MenuProps> = ({\n as: Component = 'nav',\n className,\n children,\n}) => {\n const classList = classnames(['eds-contrast', 'eps-menu', className]);\n\n return <Component className={classList}>{children}</Component>;\n};\n","import './MultiLanguageInput.scss';\n\nimport React, { FC, useState, ChangeEvent, FocusEvent } from 'react';\nimport cx from 'classnames';\nimport { VariantType } from '@entur/form';\n\nimport { Stack } from './Stack';\nimport { LanguageSelect, LanguageOption } from './LanguageSelect';\n\ntype Values = { [key: string]: string };\n\nexport interface MultiLanguageInputProps {\n className?: string;\n onBlur?: (e: FocusEvent<HTMLDivElement>) => void;\n inputComponent: React.ElementType;\n values: { [key: string]: string };\n languages: LanguageOption[];\n onChange: (values: Values) => void;\n name: string;\n alertLevel?: VariantType;\n alertLabel?: string;\n label?: string;\n defaultLanguage?: string;\n [key: string]: any;\n}\n/**\n * @deprecated use ExpandableMultiLanguageInput\n */\nexport const MultiLanguageInput: FC<MultiLanguageInputProps> = ({\n className,\n inputComponent: InputComponent,\n alertLabel,\n alertLevel,\n name,\n languages,\n values,\n onChange,\n defaultLanguage = 'nob',\n label = '',\n onBlur = () => {},\n ...rest\n}) => {\n const [language, setLanguage] = useState(defaultLanguage);\n const classNames = cx('multi-language-input', className);\n const currentValue = values[language];\n\n const handleOnBlur = (e: FocusEvent<HTMLDivElement>) => {\n e.persist();\n const currentTarget = e.currentTarget;\n setTimeout(() => {\n if (currentTarget && !currentTarget.contains(document.activeElement)) {\n onBlur(e);\n }\n }, 0);\n };\n\n const handleLanguageChange = (language: string) => {\n setLanguage(language);\n };\n\n const handleOnChange = (value?: string) => {\n const changes = Object.assign({}, values);\n if (value === '' || !value) {\n delete changes[language];\n } else {\n changes[language] = value;\n }\n onChange(changes);\n };\n\n return (\n <div\n className={classNames}\n tabIndex={0}\n onBlur={handleOnBlur}\n data-testid={`multi-lang-input-${name}`}\n >\n <Stack space=\"extraSmall\">\n <LanguageSelect\n language={language}\n options={languages}\n onChange={(lang) => handleLanguageChange(lang)}\n />\n <InputComponent\n label={label}\n variant={alertLevel}\n feedback={alertLabel}\n name={name}\n className=\"language-item\"\n onChange={(e: ChangeEvent<HTMLInputElement>) =>\n handleOnChange(e.target.value)\n }\n value={currentValue || ''}\n {...rest}\n />\n </Stack>\n </div>\n );\n};\n","import React, { FC } from 'react';\nimport { Dropdown } from '@entur/dropdown';\n\ninterface Organisation {\n name: string;\n id: string;\n}\n\ninterface OrganisationDropDownProps {\n label: string;\n onChange: (id: string) => void;\n organisations: Organisation[];\n selectedOrganisationId?: string;\n [key: string]: any;\n}\n\nexport const OrganisationDropDown: FC<OrganisationDropDownProps> = ({\n label,\n organisations,\n onChange: handleChange,\n selectedOrganisationId,\n ...rest\n}) => {\n const selectedOrganisation = organisations.find(\n (org) => org.id === selectedOrganisationId\n );\n\n return (\n <Dropdown\n label={label}\n searchable={true}\n clearable={true}\n className=\"eds-contrast\"\n items={[\n ...organisations\n .sort((a, b) => a.name.localeCompare(b.name, 'nb'))\n .map((organisation) => {\n return {\n value: organisation.id,\n label: organisation.name,\n };\n }),\n ]}\n initialSelectedItem={\n selectedOrganisation\n ? {\n value: selectedOrganisation.id,\n label: selectedOrganisation.name,\n }\n : null\n }\n onChange={(selectedValue) => {\n if (selectedValue) {\n handleChange(selectedValue.value);\n }\n }}\n {...rest}\n />\n );\n};\n","import React, { FC } from 'react';\nimport { Pagination } from '@entur/menu';\n\nexport interface PagerProps {\n currentPage: number;\n collectionSize: number;\n pageSize: number;\n onPageChange: (page: number) => void;\n}\n\nexport const Pager: FC<PagerProps> = ({\n collectionSize,\n pageSize,\n onPageChange,\n currentPage,\n}) => {\n const pageCount = Math.ceil(collectionSize / pageSize);\n return (\n <Pagination\n pageCount={pageCount}\n currentPage={currentPage}\n onPageChange={(page) => {\n onPageChange(page);\n }}\n />\n );\n};\n","import { BusinessCapability } from '@entur-partner/permission-client-node';\nimport React from 'react';\nimport {\n Route,\n Redirect,\n RouteComponentProps,\n RouteProps,\n} from 'react-router-dom';\n\nimport { PermissionCheck } from './PermissionCheck';\n\ninterface PermissionCheckedRouteProps\n extends RouteComponentProps,\n Omit<RouteProps, 'location'> {\n actualPermissions: BusinessCapability[];\n all?: BusinessCapability[];\n oneOf?: BusinessCapability[];\n onReject?: React.ReactNode;\n}\n\nexport const PermissionCheckedRoute = ({\n children,\n actualPermissions,\n all,\n oneOf,\n onReject,\n ...props\n}: PermissionCheckedRouteProps) => {\n const redirect = (\n <Redirect\n to={{\n pathname: '/unauthorized',\n state: { from: props.location },\n }}\n />\n );\n return (\n <PermissionCheck\n permissions={actualPermissions}\n all={all}\n oneOf={oneOf}\n fallback={onReject ? onReject : redirect}\n >\n <Route {...props}>{children}</Route>\n </PermissionCheck>\n );\n};\n","import React, { useState, FC, ReactNode } from 'react';\nimport { Prompt, useHistory } from 'react-router-dom';\nimport { Location } from 'history';\nimport { ModalProps } from '@entur/modal';\n\nimport { ConfirmModal } from './ConfirmModal';\n\nexport interface RouteLeavingGuardProps extends Partial<ModalProps> {\n title: string;\n closeLabel: string;\n messages: {\n cancel: string;\n confirm: string;\n };\n children: ReactNode;\n shouldBlockNavigation: (location: Location) => boolean;\n}\n\ntype Status = 'BLOCKED' | 'ALLOW';\n\nexport const RouteLeavingGuard: FC<RouteLeavingGuardProps> = ({\n children,\n shouldBlockNavigation,\n ...rest\n}) => {\n const history = useHistory();\n\n const [status, setStatus] = useState<Status>('ALLOW');\n const [lastLocation, setLastLocation] = useState(history.location);\n\n const closeModal = () => {\n setStatus('ALLOW');\n };\n\n const allowNavigation = (nextLocation: Location): boolean => {\n if (shouldBlockNavigation(nextLocation) && status === 'ALLOW') {\n setStatus('BLOCKED');\n setLastLocation(nextLocation);\n return false;\n }\n return true;\n };\n\n const handleConfirm = () => {\n history.push(lastLocation.pathname);\n };\n\n return (\n <>\n <Prompt message={allowNavigation} />\n <ConfirmModal\n onDismiss={closeModal}\n open={status === 'BLOCKED'}\n onConfirm={handleConfirm}\n {...rest}\n >\n {children}\n </ConfirmModal>\n </>\n );\n};\n","import './StatusLabel.scss';\n\nimport React, { FC } from 'react';\nimport cx from 'classnames';\n\ninterface StatusLabelProps {\n label: string;\n active: boolean;\n aggressiveInactive?: boolean;\n showBullet?: boolean;\n center?: boolean;\n}\nexport const StatusLabel: FC<StatusLabelProps> = ({\n active = false,\n label = '',\n aggressiveInactive,\n showBullet,\n center,\n}) => {\n const bulletClassNames = cx('eps-status-label__bullet', {\n active,\n aggressive: aggressiveInactive,\n });\n const statusLabelClassNames = cx('eps-status-label', {\n center,\n });\n return (\n <div className={statusLabelClassNames}>\n {showBullet && <div className={bulletClassNames} />}\n <div>{label}</div>\n </div>\n );\n};\n","import './Text.scss';\n\nimport React, { ReactNode } from 'react';\nimport cx from 'classnames';\n\nimport { StyleColor, responsiveProp, Box } from './Box';\n\ntype StyleFontSize =\n | 'extraSmall'\n | 'small'\n | 'medium'\n | 'large'\n | 'extraLarge'\n | 'extraLarge2'\n | 'extraLarge3'\n | 'extraLarge4';\n\ntype StyleFontWeight = 'body' | 'heading';\n\ntype StyleLineHeight =\n | 'extraSmall'\n | 'small'\n | 'medium'\n | 'large'\n | 'extraLarge'\n | 'extraLarge2'\n | 'extraLarge3'\n | 'extraLarge4'\n | 'extraLarge5'\n | 'extraLarge6'\n | 'extraLarge7';\n\nexport type ResponsiveStyleFontSize =\n | StyleFontSize\n | [StyleFontSize?, StyleFontSize?, StyleFontSize?];\n\nexport type ResponsiveStyleLineHeight =\n | StyleLineHeight\n | [StyleLineHeight?, StyleLineHeight?, StyleLineHeight?];\n\nexport interface TextProps {\n className?: string;\n as?: React.ElementType;\n children: ReactNode;\n\n fontSize?: ResponsiveStyleFontSize;\n lineHeight?: ResponsiveStyleLineHeight;\n color?: StyleColor;\n fontWeight?: StyleFontWeight;\n\n [key: string]: any;\n}\n\nexport const Text = ({\n as: component = 'span',\n children,\n fontSize,\n color,\n lineHeight,\n fontWeight,\n className,\n ...rest\n}: TextProps) => {\n const classes = [];\n\n fontSize && classes.push(...responsiveProp('eps-font-size-', fontSize));\n lineHeight && classes.push(...responsiveProp('eps-line-height-', lineHeight));\n fontWeight && classes.push('eps-font-weight-' + fontWeight);\n\n const classList = cx(classes, className);\n\n return (\n <Box as={component} color={color} className={classList} {...rest}>\n {children}\n </Box>\n );\n};\n","import './Unbutton.scss';\n\nimport React, { FC } from 'react';\nimport { Button, ButtonProps } from '@entur/button';\nimport cx from 'classnames';\n\ninterface UnbuttonProps extends Omit<ButtonProps, 'variant'> {}\n\nexport const Unbutton: FC<UnbuttonProps> = ({\n children,\n className,\n ...rest\n}) => (\n <Button variant=\"primary\" {...rest} className={cx('eps-unbutton', className)}>\n {children}\n </Button>\n);\n","/*global EventListener WindowEventHandlers*/\nimport { useEffect, useRef } from 'react';\n\ninterface TypedEventListener<T extends Event> {\n (evt: T): void;\n}\n\nexport function useEventListener<T extends Event = Event>(\n eventName: string,\n handler: TypedEventListener<T>,\n element: WindowEventHandlers = window\n) {\n const savedHandler = useRef<TypedEventListener<T>>();\n\n useEffect(() => {\n savedHandler.current = handler;\n }, [handler]);\n\n useEffect(() => {\n const isSupported = element && element.addEventListener;\n if (!isSupported) return;\n\n const eventListener = ((event: T): void =>\n savedHandler.current?.(event)) as EventListener;\n\n element.addEventListener(eventName, eventListener);\n\n return () => {\n element.removeEventListener(eventName, eventListener);\n };\n }, [eventName, element]);\n}\n"],"names":["responsiveProp","prefix","prop","Array","isArray","classes","push","Box","_ref","_ref$as","as","Component","children","contrast","paddingTop","paddingRight","paddingBottom","paddingLeft","paddingX","paddingY","padding","marginTop","marginRight","marginBottom","marginLeft","marginX","marginY","margin","display","justifyContent","alignItems","maxWidth","width","background","color","flexDirection","flexWrap","className","rest","_objectWithoutPropertiesLoose","_excluded","resolvedPaddingTop","resolvedPaddingBottom","resolvedPaddingLeft","resolvedPaddingRight","resolvedMarginTop","resolvedMarginBottom","resolvedMarginLeft","resolvedMarginRight","apply","classList","cx","React","createElement","_extends","Stack","space","stackItems","Children","toArray","length","Fragment","map","child","index","key","useFeatureToggle","flag","_window$localStorage","_window$localStorage2","process","env","getItem","window","localStorage","FeatureToggle","EnturPartnerLogoSvg","title","height","viewBox","fill","fillRule","d","CustomOverflowMenu","_ref2","ref","buttonRef","handler","userName","open","onOpenChange","overflowItemsClasses","overflowContentRef","useRef","overflowMenuTriggerRef","useEffect","listener","event","elementContainsEventTarget","current","document","addEventListener","removeEventListener","SecondaryButton","onClick","role","UserIcon","inline","Heading6","DownArrowIcon","CustomOverflowMenuItem","props","element","contains","target","composed","composedPath","find","LanguageSelect","language","options","onChange","classNames","SegmentedControl","assertIsDefined","selectedValue","option","SegmentedChoice","value","label","required","ErrorBoundary","_Component","_this","call","this","state","error","getDerivedStateFromError","_proto","prototype","componentDidCatch","errorInfo","_this$props$handleErr","_this$props","handleError","render","functionToCheck","_this2","_this$props2","fallback","toString","retry","setState","FormatDateTime","date","locale","hideTime","localeDate","localeDateTime","ConfirmModal","_ref$isOpen","isOpen","message","_ref$size","size","buttons","onConfirm","messages","onClose","onDismiss","childrenToRender","handleDismiss","Modal","isString","Paragraph","ButtonGroup","cancel","PrimaryButton","confirm","PermissionCheck","_ref$fallback","permissions","_ref$oneOf","oneOf","_ref$all","all","allIsAllowed","hasAllPermissions","oneOfIsAllowed","hasOneOfPermissions","_ref3","items","i","isDate","isDateString","prependBreadcrumbItem","pathname","onBreadcrumbLookup","paths","replace","split","reduce","prev","curr","path","breadcrumbs","filter","undefined","breadcrumbElements","BreadcrumbItem","Link","to","BreadcrumbNavigation","classnames","_ref2$as","altText","InputComponent","inputComponent","languages","values","name","variant","feedback","ExpandablePanel","defaultOpen","contentStyle","langKey","e","changes","amount","parsedAmount","Number","formattedAmount","Intl","NumberFormat","maximumFractionDigits","minimumFractionDigits","format","A","RouterLink","alertLabel","alertLevel","_ref$defaultLanguage","defaultLanguage","_ref$label","_ref$onBlur","onBlur","useState","_useState","setLanguage","currentValue","tabIndex","persist","currentTarget","setTimeout","activeElement","lang","handleLanguageChange","Object","assign","organisations","handleChange","selectedOrganisationId","selectedOrganisation","org","id","Dropdown","searchable","clearable","sort","a","b","localeCompare","organisation","initialSelectedItem","collectionSize","onPageChange","currentPage","pageCount","Math","ceil","pageSize","Pagination","page","actualPermissions","onReject","redirect","Redirect","from","location","Route","shouldBlockNavigation","history","useHistory","status","setStatus","_useState2","lastLocation","setLastLocation","Prompt","nextLocation","_ref$active","active","showBullet","center","bulletClassNames","aggressive","aggressiveInactive","statusLabelClassNames","component","fontSize","lineHeight","fontWeight","Button","onLogout","onLanguageChange","onShowGdprDialog","triggerClassList","setOpen","PrivacyIcon","termsAndConditions","NorwayIcon","switchLanguage","UKIcon","UploadIcon","style","transform","logout","eventName","savedHandler","eventListener"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"common.cjs.production.min.js","sources":["../src/Box.tsx","../src/Stack.tsx","../src/FeatureToggle.tsx","../src/EnturPartnerLogo.tsx","../src/UserMenu.tsx","../src/LanguageSelect.tsx","../src/ErrorBoundary.tsx","../src/helpers.ts","../src/FormatDateTime.tsx","../src/ConfirmModal.tsx","../src/PermissionCheck.tsx","../src/ActionBar.tsx","../src/AuditInfo.tsx","../src/Breadcrumbs.tsx","../src/Content.tsx","../src/ExpandableMultiLanguageInput.tsx","../src/FormatCurrencyAmount.tsx","../src/Link.tsx","../src/LinkButton.tsx","../src/Menu.tsx","../src/MultiLanguageInput.tsx","../src/OrganisationDropdown.tsx","../src/Pager.tsx","../src/PermissionCheckedRoute.tsx","../src/RouteLeavingGuard.tsx","../src/StatusLabel.tsx","../src/Text.tsx","../src/Unbutton.tsx","../src/useEventListener.ts"],"sourcesContent":["import './Box.scss';\n\nimport React, { ReactNode } from 'react';\nimport cx from 'classnames';\n\ntype StyleSpacing =\n | 'none'\n | 'extraSmall2'\n | 'extraSmall'\n | 'small'\n | 'medium'\n | 'large'\n | 'extraLarge'\n | 'extraLarge2'\n | 'extraLarge3'\n | 'extraLarge4'\n | 'extraLarge5'\n | 'extraLarge6'\n | 'extraLarge7'\n | 'extraLarge8'\n | 'extraLarge9';\n\ntype StyleMargin = StyleSpacing | 'auto';\n\ntype StyleDisplay = 'block' | 'flex' | 'inline' | 'inline-block';\ntype StyleJustifyContent = 'center' | 'space-between' | 'start' | 'end';\ntype StyleAlignItems = 'center' | 'start' | 'end' | 'stretch' | 'baseline';\n\ntype StyleMaxWidth =\n | 'none'\n | 'extraSmall'\n | 'small'\n | 'medium'\n | 'large'\n | 'extraLarge'\n | 'extraLarge2'\n | 'extraLarge3'\n | 'extraLarge4'\n | 'extraLarge5'\n | 'extraLarge6'\n | 'full';\ntype StyleWidth = 'auto' | 'full';\n\nexport type StyleBackground = 'blue' | 'lavender' | 'white' | 'blue70';\nexport type StyleColor = 'blue' | 'lavender' | 'white' | 'black';\n\ntype StyleFlexDirection = 'row' | 'column' | 'row-reverse' | 'column-reverse';\ntype StyleFlexWrap = 'wrap' | 'nowrap' | 'wrap-reverse';\n\nexport type ResponsiveStyleSpacing =\n | StyleSpacing\n | [StyleSpacing?, StyleSpacing?, StyleSpacing?];\nexport type ResponsiveStyleMargin =\n | StyleMargin\n | [StyleMargin?, StyleMargin?, StyleMargin?];\n\nexport type ResponsiveStyleDisplay =\n | StyleDisplay\n | [StyleDisplay?, StyleDisplay?, StyleDisplay?];\nexport type ResponsiveStyleJustifyContent =\n | StyleJustifyContent\n | [StyleJustifyContent?, StyleJustifyContent?, StyleJustifyContent?];\nexport type ResponsiveStyleAlignItems =\n | StyleAlignItems\n | [StyleAlignItems?, StyleAlignItems?, StyleAlignItems?];\n\nexport type ResponsiveStyleMaxWidth =\n | StyleMaxWidth\n | [StyleMaxWidth?, StyleMaxWidth?, StyleMaxWidth?];\nexport type ResponsiveStyleWidth =\n | StyleWidth\n | [StyleWidth?, StyleWidth?, StyleWidth?];\n\nexport type ResponsiveStyleFlexDirection =\n | StyleFlexDirection\n | [StyleFlexDirection?, StyleFlexDirection?, StyleFlexDirection?];\nexport type ResponsiveStyleFlexWrap =\n | StyleFlexWrap\n | [StyleFlexWrap?, StyleFlexWrap?, StyleFlexWrap?];\n\nexport interface BoxProps {\n className?: string;\n as?: React.ElementType;\n [key: string]: any;\n children: ReactNode;\n\n contrast?: boolean;\n\n paddingTop?: ResponsiveStyleSpacing;\n paddingRight?: ResponsiveStyleSpacing;\n paddingBottom?: ResponsiveStyleSpacing;\n paddingLeft?: ResponsiveStyleSpacing;\n paddingX?: ResponsiveStyleSpacing;\n paddingY?: ResponsiveStyleSpacing;\n padding?: ResponsiveStyleSpacing;\n\n marginTop?: ResponsiveStyleMargin;\n marginRight?: ResponsiveStyleMargin;\n marginBottom?: ResponsiveStyleMargin;\n marginLeft?: ResponsiveStyleMargin;\n marginX?: ResponsiveStyleMargin;\n marginY?: ResponsiveStyleMargin;\n margin?: ResponsiveStyleMargin;\n\n display?: ResponsiveStyleDisplay;\n justifyContent?: ResponsiveStyleJustifyContent;\n alignItems?: ResponsiveStyleAlignItems;\n\n maxWidth?: ResponsiveStyleMaxWidth;\n width?: ResponsiveStyleWidth;\n background?: StyleBackground;\n color?: StyleColor;\n\n flexDirection?: ResponsiveStyleFlexDirection;\n flexWrap?: ResponsiveStyleFlexWrap;\n}\n\ntype ResponsiveProp = string | [string?, string?, string?];\n\nexport function responsiveProp(prefix: string, prop: ResponsiveProp): string[] {\n if (Array.isArray(prop)) {\n const classes = [];\n prop[0] && classes.push(prefix + prop[0]);\n prop[1] && classes.push(`${prefix}${prop[1]}-lg`);\n prop[2] && classes.push(`${prefix}${prop[2]}-xl`);\n return classes;\n }\n return [prefix + prop];\n}\n\nexport const Box = ({\n as: Component = 'div',\n children,\n contrast,\n paddingTop,\n paddingRight,\n paddingBottom,\n paddingLeft,\n paddingX,\n paddingY,\n padding,\n marginTop,\n marginRight,\n marginBottom,\n marginLeft,\n marginX,\n marginY,\n margin,\n display,\n justifyContent,\n alignItems,\n maxWidth,\n width,\n background,\n color,\n flexDirection,\n flexWrap,\n className,\n ...rest\n}: BoxProps) => {\n const classes = [];\n const resolvedPaddingTop = paddingTop || paddingY || padding;\n const resolvedPaddingBottom = paddingBottom || paddingY || padding;\n const resolvedPaddingLeft = paddingLeft || paddingX || padding;\n const resolvedPaddingRight = paddingRight || paddingX || padding;\n\n const resolvedMarginTop = marginTop || marginY || margin;\n const resolvedMarginBottom = marginBottom || marginY || margin;\n const resolvedMarginLeft = marginLeft || marginX || margin;\n const resolvedMarginRight = marginRight || marginX || margin;\n\n contrast && classes.push('eds-contrast');\n resolvedPaddingTop &&\n classes.push(...responsiveProp('eps-pt-', resolvedPaddingTop));\n resolvedPaddingBottom &&\n classes.push(...responsiveProp('eps-pb-', resolvedPaddingBottom));\n resolvedPaddingLeft &&\n classes.push(...responsiveProp('eps-pl-', resolvedPaddingLeft));\n resolvedPaddingRight &&\n classes.push(...responsiveProp('eps-pr-', resolvedPaddingRight));\n resolvedMarginTop &&\n classes.push(...responsiveProp('eps-mt-', resolvedMarginTop));\n resolvedMarginBottom &&\n classes.push(...responsiveProp('eps-mb-', resolvedMarginBottom));\n resolvedMarginLeft &&\n classes.push(...responsiveProp('eps-ml-', resolvedMarginLeft));\n resolvedMarginRight &&\n classes.push(...responsiveProp('eps-mr-', resolvedMarginRight));\n\n display && classes.push(...responsiveProp('eps-', display));\n justifyContent &&\n classes.push(...responsiveProp('eps-justify-', justifyContent));\n if (alignItems) {\n classes.push(...responsiveProp('eps-items-', alignItems));\n }\n\n maxWidth && classes.push(...responsiveProp('eps-max-w-', maxWidth));\n width && classes.push(...responsiveProp('eps-w-', width));\n\n color && classes.push(`eps-color-${color}`);\n background && classes.push(`eps-bg-${background}`);\n\n flexDirection && classes.push(...responsiveProp('eps-flex-', flexDirection));\n flexWrap && classes.push(...responsiveProp('eps-flex-wrap-', flexWrap));\n\n const classList = cx(classes, className);\n\n return (\n <Component className={classList} {...rest}>\n {children}\n </Component>\n );\n};\n","import React, { ReactNode, Children } from 'react';\n\nimport { ResponsiveStyleSpacing, Box } from './Box';\n\nexport interface StackProps {\n className?: string;\n children: ReactNode;\n space: ResponsiveStyleSpacing;\n}\n\nexport const Stack = ({ children, space, className }: StackProps) => {\n const stackItems = Children.toArray(children);\n if (stackItems.length <= 1) {\n return <>{stackItems}</>;\n }\n\n return (\n <div className={className}>\n {stackItems.map((child, index) =>\n index === stackItems.length - 1 ? (\n <div key={index}>{child}</div>\n ) : (\n <Box paddingBottom={space} key={index}>\n {child}\n </Box>\n )\n )}\n </div>\n );\n};\n","import React, { ReactNode } from 'react';\n\n/**\n * Returns true if the provided flag exist in localStorage\n * or is set as an environment variable.\n *\n * @param flag case sensitive flag. If it is an environment variable\n * you can drop the REACT_APP_ prefix.\n */\nexport function featureFlag(flag: string): boolean {\n return (\n process.env[`REACT_APP_${flag}`] === 'true' ||\n window.localStorage?.getItem(flag) === 'true' ||\n window.localStorage?.getItem(`REACT_APP_${flag}`) === 'true'\n );\n}\n\n/**\n * Returns true if the provided flag exist in localStorage\n * or is set as an environment variable.\n *\n * @param flag case sensitive flag. If it is an environment variable\n * you can drop the REACT_APP_ prefix.\n */\nexport function useFeatureToggle(flag: string): boolean {\n return featureFlag(flag);\n}\n\nexport interface FeatureToggleProps {\n /** Visible if flag exist, hidden if not.*/\n children: ReactNode;\n /** Case sensitive flag. If it is an environment variable\n * you can drop the REACT_APP_ prefix. */\n flag: string;\n}\n\nexport const FeatureToggle = ({ children, flag }: FeatureToggleProps) => {\n const feature = useFeatureToggle(flag);\n if (feature) {\n return <>{children}</>;\n }\n return null;\n};\n","import './EnturPartnerLogo.scss';\n\nimport React, { FC } from 'react';\nimport classnames from 'classnames';\n\ninterface LogoProps {\n title: string;\n className?: string;\n [key: string]: any;\n}\n\nexport const EnturPartnerLogoSvg: FC<LogoProps> = ({ title, ...rest }) => {\n return (\n <svg width={257} height={37} viewBox=\"0 0 257 37\" {...rest}>\n <title>{title}</title>\n <g fill=\"none\" fillRule=\"evenodd\">\n <path\n fill=\"#FFF\"\n d=\"M0 .231V25.72h18.745v-4.318H4.869v-6.163h12.31v-4.318H4.87V4.55h13.876V.231z\"\n />\n <path fill=\"#FF5959\" d=\"M0 36.408h45.253v-4.32H0z\" />\n <path\n fill=\"#FFF\"\n d=\"M40.384.231v15.425L23.656.231h-.521V25.72h4.869V10.573L44.732 25.72h.521V.23zM69.25 15.238h-7.267v21.17h-4.87v-21.17H49.81V10.92h19.44zM83.863 36.86c-1.646 0-3.142-.255-4.486-.765-1.345-.51-2.493-1.23-3.443-2.159-.95-.928-1.687-2.054-2.208-3.378-.522-1.323-.783-2.797-.783-4.422V10.92h4.869v15.216c0 1.277.209 2.333.626 3.169.417.836.933 1.497 1.548 1.985a5.346 5.346 0 001.982 1.01c.707.186 1.339.278 1.895.278.557 0 1.188-.092 1.896-.279a5.35 5.35 0 001.982-1.01c.614-.487 1.13-1.148 1.548-1.984.417-.836.625-1.892.625-3.169V10.92h4.87v15.216c0 1.625-.256 3.1-.766 4.422-.51 1.324-1.24 2.45-2.19 3.378-.952.929-2.1 1.648-3.444 2.159-1.344.51-2.851.766-4.52.766M104.21 24.047h5.546c1.016 0 1.854-.127 2.513-.383.658-.255 1.179-.592 1.56-1.01.381-.418.641-.888.78-1.41.138-.522.208-1.05.208-1.584 0-.627-.099-1.207-.295-1.741a3.718 3.718 0 00-.901-1.393c-.405-.394-.924-.708-1.56-.94-.636-.232-1.404-.348-2.305-.348h-5.546v8.81zm0 4.248v8.113h-4.87V10.92h11.567c1.3 0 2.49.215 3.57.644 1.08.43 2.004 1.033 2.77 1.81a8.287 8.287 0 011.794 2.787c.43 1.079.645 2.257.645 3.534 0 .952-.128 1.874-.383 2.768-.256.894-.61 1.7-1.063 2.42a7.32 7.32 0 01-1.672 1.863 5.929 5.929 0 01-2.178 1.096l6.339 8.566h-5.808l-5.893-8.113h-4.818z\"\n />\n <g fill=\"#FF5959\">\n <path d=\"M141.051 23.448h5.628c4.185 0 5.989-1.984 5.989-4.942 0-2.742-1.515-4.618-5.989-4.618h-5.628v9.56zm0 3.067v9.776h-3.571V10.75h9.632c6.674 0 9.127 3.211 9.127 7.54 0 4.979-3.102 8.226-9.2 8.226h-5.988zM169.695 28.715c-1.371-.288-2.958-.505-4.401-.505-2.85 0-4.041 1.263-4.041 3.139s1.407 2.706 3.463 2.706c2.49 0 4.979-1.443 4.979-4.221v-1.119zm-4.293-2.958c1.551 0 3.174.253 4.293.469v-.83c0-2.525-1.154-3.896-4.33-3.896-2.164 0-3.824.866-4.942 2.092l-2.02-2.272c1.732-1.66 3.644-2.598 7.07-2.598 5.052 0 7.469 1.876 7.469 7.215v10.354h-3.211V34.02h-.108c-1.082 1.767-3.211 2.705-5.592 2.705-3.32 0-6.241-1.66-6.241-5.303 0-3.103 1.912-5.664 7.612-5.664zM178.965 19.191h3.211v2.886h.108c.938-1.984 2.922-3.355 5.231-3.355.47 0 .938.036 1.335.144l-.144 3.14a6.77 6.77 0 00-1.552-.181c-3.246 0-4.798 2.633-4.798 5.483v8.983h-3.39v-17.1zM199.961 36.291h-1.912c-4.004 0-5.988-.938-5.988-5.772v-8.55h-2.778V19.19h2.778v-4.654h3.355v4.654h4.473v2.778h-4.473v7.973c0 3.427 1.587 3.535 3.319 3.535h1.226v2.814zM219.767 36.291h-3.391V26.84c0-2.778-1.083-5.375-4.257-5.375-3.14 0-5.268 2.597-5.268 6.169v8.658h-3.391v-17.1h3.32v2.814h.143c.794-1.623 3.067-3.283 5.99-3.283 4.941 0 6.854 3.644 6.854 8.081v9.488zM227.847 26.262h10.57c0-2.597-2.272-4.726-5.087-4.726-2.922 0-5.014 1.948-5.483 4.726zm-.036 2.453c.397 3.355 2.633 5.195 5.844 5.195 2.778 0 4.618-1.623 5.484-2.67l2.164 1.804c-1.37 1.913-4.365 3.716-8.045 3.716-4.942 0-8.73-3.535-8.73-8.55 0-5.195 3.752-9.488 8.983-9.488 5.303 0 8.009 4.365 8.009 8.19 0 .649-.036 1.226-.072 1.803H227.81zM246.245 19.191h3.21v2.886h.109c.938-1.984 2.922-3.355 5.231-3.355.469 0 .938.036 1.335.144l-.145 3.14a6.77 6.77 0 00-1.551-.181c-3.247 0-4.798 2.633-4.798 5.483v8.983h-3.391v-17.1z\" />\n </g>\n </g>\n </svg>\n );\n};\n\ninterface EnturPartnerLogoProps {\n altText: string;\n as?: 'div' | React.ElementType;\n className?: string;\n}\n\nexport const EnturPartnerLogo: FC<EnturPartnerLogoProps> = ({\n as: Component = 'nav',\n className,\n altText,\n}) => {\n const classList = classnames(['eps-logo-wrapper', className]);\n\n return (\n <Component className={classList}>\n <EnturPartnerLogoSvg title={altText} className=\"logo\" />\n </Component>\n );\n};\n","import './UserMenu.scss';\n\nimport React, { FC, useState } from 'react';\nimport cx from 'classnames';\nimport {\n UserIcon,\n UploadIcon,\n PrivacyIcon,\n DownArrowIcon,\n UKIcon,\n NorwayIcon,\n} from '@entur/icons';\nimport { SecondaryButton } from '@entur/button';\nimport { Heading6 } from '@entur/typography';\n\ninterface UserMenuProps {\n userName: string;\n messages: {\n logout: string;\n termsAndConditions: string;\n switchLanguage: string;\n };\n onLogout: () => void;\n onShowGdprDialog: () => void;\n onLanguageChange: (language: string) => void;\n language: string;\n className?: string;\n}\n\nexport const UserMenu: FC<UserMenuProps> = ({\n className,\n messages,\n onLogout,\n onLanguageChange,\n onShowGdprDialog,\n userName,\n language,\n}) => {\n const triggerClassList = cx(['eps-user-menu__trigger-button', className]);\n const [open, setOpen] = useState(false);\n\n return (\n <div id=\"eps-user-menu\">\n <CustomOverflowMenu\n open={open}\n onOpenChange={setOpen}\n className={triggerClassList}\n userName={userName}\n >\n <div id=\"eps-overflow-menu\">\n <CustomOverflowMenuItem\n onClick={() => {\n onShowGdprDialog();\n setOpen(false);\n }}\n className=\"eps-overflow-menu__item\"\n >\n <span aria-hidden>\n <PrivacyIcon size=\"1rem\" inline />\n </span>\n {messages.termsAndConditions}\n </CustomOverflowMenuItem>\n {language === 'en' ? (\n <CustomOverflowMenuItem\n onClick={() => {\n onLanguageChange('nb');\n setOpen(false);\n }}\n className=\"eps-overflow-menu__item\"\n >\n <span aria-hidden className=\"eps-overflow-menu__icon-margin\">\n <NorwayIcon size=\"1rem\" inline />\n </span>\n {messages.switchLanguage}\n </CustomOverflowMenuItem>\n ) : (\n <CustomOverflowMenuItem\n onClick={() => {\n onLanguageChange('en');\n setOpen(false);\n }}\n className=\"eps-overflow-menu__item\"\n >\n <span aria-hidden className=\"eps-overflow-menu__icon-margin\">\n <UKIcon size=\"1rem\" inline />\n </span>\n {messages.switchLanguage}\n </CustomOverflowMenuItem>\n )}\n <CustomOverflowMenuItem\n onClick={() => {\n onLogout();\n setOpen(false);\n }}\n data-testid=\"user-menu-logout\"\n className=\"eps-overflow-menu__item\"\n >\n <span aria-hidden>\n <UploadIcon\n size=\"1rem\"\n inline\n style={{ transform: 'rotate(90deg)' }}\n />\n </span>\n {messages.logout}\n </CustomOverflowMenuItem>\n </div>\n </CustomOverflowMenu>\n </div>\n );\n};\n\nconst CustomOverflowMenu: React.FC<{\n className?: string;\n children: React.ReactNode;\n userName: string;\n open: boolean;\n onOpenChange: (open: boolean) => void;\n}> = ({ className, children, userName, open, onOpenChange, ...rest }) => {\n const overflowItemsClasses = cx('eps-overflow-menu__group', {\n 'eps-overflow-menu__group--open': open,\n });\n const overflowContentRef = React.useRef<HTMLDivElement>(null);\n const overflowMenuTriggerRef = React.useRef<HTMLButtonElement>(null);\n useOutsideClick(overflowContentRef, overflowMenuTriggerRef, () =>\n onOpenChange(false)\n );\n return (\n <div>\n <SecondaryButton\n className={cx('eps-overflow-menu__button', className)}\n onClick={() => onOpenChange(open ? false : true)}\n aria-haspopup={true}\n role=\"button\"\n aria-expanded={open}\n ref={overflowMenuTriggerRef}\n {...rest}\n >\n <div className=\"eps-overflow-menu__button-contents\">\n <span className=\"eds-overflow-menu__user-icon\">\n <UserIcon inline />\n </span>\n <Heading6 margin=\"none\" as=\"span\">\n {userName}\n </Heading6>\n <span className=\"eps-arrow-icon\">\n <DownArrowIcon inline />\n </span>\n </div>\n </SecondaryButton>\n {open && (\n <div\n className={overflowItemsClasses}\n role=\"menu\"\n ref={overflowContentRef}\n >\n {children}\n </div>\n )}\n </div>\n );\n};\n\nconst CustomOverflowMenuItem: React.FC<\n React.DetailedHTMLProps<\n React.ButtonHTMLAttributes<HTMLButtonElement>,\n HTMLButtonElement\n >\n> = (props) => {\n return (\n <button\n className={cx(props.className, 'eps-overflow-menu__item')}\n role=\"menuitem\"\n {...props}\n />\n );\n};\n\nfunction elementContainsEventTarget(element: HTMLElement | null, event: Event) {\n if (!element) {\n return false;\n }\n\n if (element.contains(event.target as Node)) {\n return true;\n }\n\n // For elements inside a Shadow DOM we need to check the composedPath\n if (event.composed && event.composedPath) {\n const contains = event.composedPath().find((target) => {\n if (target === window) {\n return false;\n }\n return element.contains(target as Node);\n });\n return contains ? true : false;\n }\n\n return false;\n}\n\nfunction useOutsideClick(\n ref: React.RefObject<HTMLDivElement>,\n buttonRef: React.RefObject<HTMLButtonElement>,\n handler: () => void\n) {\n React.useEffect(() => {\n const listener = (event: Event) => {\n if (\n elementContainsEventTarget(ref.current, event) ||\n elementContainsEventTarget(buttonRef.current, event)\n ) {\n return;\n }\n\n handler();\n };\n\n document.addEventListener('mousedown', listener);\n document.addEventListener('touchstart', listener);\n\n return () => {\n document.removeEventListener('mousedown', listener);\n document.removeEventListener('touchstart', listener);\n };\n }, [ref, buttonRef, handler]);\n}\n","import './LanguageSelect.scss';\n\nimport React, { FC } from 'react';\nimport { SegmentedControl, SegmentedChoice } from '@entur/form';\nimport cx from 'classnames';\nimport { assertIsDefined } from '@entur-partner/util';\n\nexport type LanguageKey = 'nob' | 'nno' | 'eng';\n\nexport interface LanguageOption {\n value: LanguageKey;\n label: string;\n required: boolean;\n}\n\nexport interface LanguageSelectProps {\n language: string;\n options: LanguageOption[];\n className?: string;\n onChange: (language: string) => void;\n [key: string]: any;\n}\n\nexport const LanguageSelect: FC<LanguageSelectProps> = ({\n language,\n options,\n className,\n onChange,\n ...rest\n}) => {\n const classNames = cx('eps-language-select', className);\n return (\n <div {...rest} className={classNames}>\n <SegmentedControl\n onChange={(language) => {\n assertIsDefined(language);\n onChange(language);\n }}\n selectedValue={language}\n >\n {options.map((option) => (\n <SegmentedChoice key={option.value} value={option.value}>\n {option.label}\n {option.required && <span className=\"asterisk-margin\">{'*'}</span>}\n </SegmentedChoice>\n ))}\n </SegmentedControl>\n </div>\n );\n};\n","import { ReactNode, Component, ErrorInfo } from 'react';\n\nimport { isFunction } from './helpers';\n\ntype FallbackOptions = {\n retry: () => void;\n error: Error;\n};\n\ntype RenderProp = (options: FallbackOptions) => ReactNode;\n\ntype Props = {\n handleError?: (error: Error, errorInfo: ErrorInfo) => void;\n fallback: ReactNode | RenderProp;\n children: ReactNode;\n};\n\ntype State = {\n error: null | Error;\n};\n\nexport class ErrorBoundary extends Component<Props, State> {\n constructor(props: Props) {\n super(props);\n this.state = { error: null };\n }\n\n static getDerivedStateFromError(error: Error): State {\n return {\n error,\n };\n }\n\n componentDidCatch(error: Error, errorInfo: ErrorInfo) {\n // React always logs in development\n this.props.handleError?.(error, errorInfo);\n }\n\n render() {\n const { error } = this.state;\n const { fallback, children } = this.props;\n\n if (error) {\n if (isFunction<RenderProp>(fallback)) {\n return fallback({ retry: () => this.setState({ error: null }), error });\n }\n return fallback;\n }\n\n return children;\n }\n}\n","export function isFunction<T>(functionToCheck: any): functionToCheck is T {\n return (\n functionToCheck && {}.toString.call(functionToCheck) === '[object Function]'\n );\n}\n","import React, { FC } from 'react';\nimport { localeDate, localeDateTime } from '@entur-partner/util';\n\nexport interface FormatDateTimeProps {\n date: string | Date;\n locale: string;\n [key: string]: any;\n}\n\nexport const FormatDateTime: FC<FormatDateTimeProps> = ({\n date,\n locale,\n as: Component = 'main',\n hideTime,\n ...rest\n}) => {\n return (\n <Component {...rest}>\n {hideTime ? localeDate(date, locale) : localeDateTime(date, locale)}\n </Component>\n );\n};\n","import './ConfirmModal.scss';\n\nimport React, { ReactNode, FC } from 'react';\nimport { Modal, ModalProps } from '@entur/modal';\nimport { Paragraph } from '@entur/typography';\nimport { isString } from '@entur-partner/util';\nimport { ButtonGroup, SecondaryButton, PrimaryButton } from '@entur/button';\n\nimport { Box } from './Box';\n\nexport interface BaseConfirmModalProps extends Partial<ModalProps> {\n title: string;\n children: React.ReactNode;\n closeLabel: string;\n\n /** Deprecated use children prop */\n message?: ReactNode;\n /** Deprecated use open prop */\n isOpen?: boolean;\n /** Deprecated use onDismiss prop */\n onClose?: () => void;\n}\n\ninterface CustomConfirmModalButtons extends BaseConfirmModalProps {\n buttons: ReactNode[];\n}\n\ninterface DefaultConfirmModalHandler extends BaseConfirmModalProps {\n onConfirm: () => void;\n messages: {\n confirm: string;\n cancel: string;\n };\n}\n\nexport type ConfirmModalProps =\n | CustomConfirmModalButtons\n | DefaultConfirmModalHandler;\n\nexport const ConfirmModal: FC<ConfirmModalProps> = ({\n isOpen = false,\n children,\n message,\n size = 'medium',\n buttons,\n onConfirm,\n messages,\n onClose,\n onDismiss,\n ...rest\n}) => {\n const childrenToRender = children ? children : message;\n const handleDismiss = onClose ? onClose : onDismiss;\n return (\n <Modal size={size} open={isOpen} onDismiss={handleDismiss} {...rest}>\n {isString(childrenToRender) ? (\n <Paragraph>{childrenToRender}</Paragraph>\n ) : (\n <Box paddingBottom=\"medium\">{childrenToRender}</Box>\n )}\n\n <ButtonGroup>\n {onConfirm ? (\n <>\n <SecondaryButton\n onClick={handleDismiss}\n data-testid=\"cancel-modal-button\"\n >\n {messages.cancel}\n </SecondaryButton>\n <PrimaryButton\n onClick={onConfirm}\n data-testid=\"confirm-modal-button\"\n >\n {messages.confirm}\n </PrimaryButton>\n </>\n ) : (\n buttons\n )}\n </ButtonGroup>\n </Modal>\n );\n};\n","import React, { ReactNode, FC } from 'react';\nimport { BusinessCapability } from '@entur-partner/permission-client-node';\nimport { hasAllPermissions, hasOneOfPermissions } from '@entur-partner/util';\n\n/**\n * Note: We use BusinessCapability here, not because we only want to check\n * BusinessCapabilities but because it represents a minimal subset of what we\n * need to check.\n */\nexport interface PermissionCheckProps {\n children: ReactNode;\n /** User permissions to check */\n permissions: BusinessCapability[];\n /** Check that at least one of the permissions is present */\n oneOf?: BusinessCapability[];\n /** Check that all of the permissions is present */\n all?: BusinessCapability[] | BusinessCapability;\n /** Rendered if check fails. Defaults to null */\n fallback?: ReactNode;\n}\n\n/**\n * Note: This component uses BusinessCapability, not because we only want to\n * check BusinessCapabilities but because it represents a minimal subset of\n * what we need to check.\n */\nexport const PermissionCheck: FC<PermissionCheckProps> = ({\n children,\n fallback = null,\n permissions,\n oneOf = [],\n all = [],\n}) => {\n const allIsAllowed = hasAllPermissions(all, permissions);\n\n const oneOfIsAllowed = hasOneOfPermissions(oneOf, permissions);\n\n const allowed = allIsAllowed && oneOfIsAllowed;\n return <>{allowed ? children : fallback}</>;\n};\n","import './ActionBar.scss';\nimport React, { ReactNode } from 'react';\n\nexport interface ActionBarProps {\n children: ReactNode;\n}\n\nconst ActionBarLeft = ({ children }: ActionBarProps) => {\n return <div className=\"eps-action-bar-left\">{children}</div>;\n};\n\nconst ActionBarRight = ({ children }: ActionBarProps) => {\n return <div className=\"eps-action-bar-right\">{children}</div>;\n};\n\nconst ActionBar = ({ children }: ActionBarProps) => {\n return (\n <>\n <div className=\"eps-action-bar-padding\" />\n <div className=\"eps-action-bar\">{children}</div>\n </>\n );\n};\n\nexport { ActionBar, ActionBarLeft, ActionBarRight };\n","import './AuditInfo.scss';\n\nimport React, { FC } from 'react';\nimport cx from 'classnames';\nimport { isDateString, isDate } from '@entur-partner/util';\n\nimport { FormatDateTime } from './FormatDateTime';\nimport { Stack } from './Stack';\n\ninterface Item {\n label: string;\n value: Date | string;\n}\n\nexport interface AuditInfoProps {\n items: Item[];\n locale: string;\n className?: string;\n [key: string]: any;\n}\n\nexport const AuditInfo: FC<AuditInfoProps> = ({\n items,\n locale,\n className,\n ...rest\n}) => {\n const classNames = cx('ep-audit-info', className);\n return (\n <div className={classNames} {...rest}>\n {items.map(({ label, value }, i) => (\n <Stack space=\"small\" key={i}>\n <div className=\"ep-audit-info-label\">{label}</div>\n <div>\n {isDate(value) || isDateString(value) ? (\n <FormatDateTime date={value} locale={locale} />\n ) : (\n <span>{value}</span>\n )}\n </div>\n </Stack>\n ))}\n </div>\n );\n};\n","import './Breadcrumbs.scss';\nimport React, { FC, ReactElement } from 'react';\nimport { Link } from 'react-router-dom';\nimport { BreadcrumbNavigation, BreadcrumbItem } from '@entur/menu';\n\nexport interface BreadcrumbsProps {\n pathname: string;\n onBreadcrumbLookup: (path: string) => string | undefined;\n prependBreadcrumbItem?: ReactElement;\n}\n\nexport const Breadcrumbs: FC<BreadcrumbsProps> = ({\n prependBreadcrumbItem,\n pathname,\n onBreadcrumbLookup,\n}) => {\n const paths: string[] = pathname === '/' ? [] : ['/'];\n\n // support paths with and without trailing slash, except root\n const adjustedPathname =\n pathname.length > 1 ? pathname.replace(/\\/$/, '') : pathname;\n\n adjustedPathname.split('/').reduce((prev, curr) => {\n const path = `${prev}/${curr}`;\n paths.push(path);\n return path;\n });\n\n const breadcrumbs = paths\n .map((path) => ({ title: onBreadcrumbLookup(path), path }))\n .filter(({ title }) => title !== undefined);\n\n const breadcrumbElements = breadcrumbs.map(({ title, path }, i) => {\n const isLast = i === breadcrumbs.length - 1;\n if (isLast) {\n return (\n <BreadcrumbItem key={path} as={'span'}>\n {title}\n </BreadcrumbItem>\n );\n }\n return (\n <BreadcrumbItem key={path} as={Link} to={path}>\n {title}\n </BreadcrumbItem>\n );\n });\n\n if (prependBreadcrumbItem) {\n return (\n <BreadcrumbNavigation>\n {[prependBreadcrumbItem, ...breadcrumbElements]}\n </BreadcrumbNavigation>\n );\n }\n\n return <BreadcrumbNavigation>{breadcrumbElements}</BreadcrumbNavigation>;\n};\n","import './Content.scss';\n\nimport React, { FC, ReactNode } from 'react';\nimport classnames from 'classnames';\n\ninterface ContentProps {\n children: ReactNode;\n as?: 'main' | React.ElementType;\n className?: string;\n}\nexport const Content: FC<ContentProps> = ({\n as: Component = 'main',\n className,\n children,\n}) => {\n const classList = classnames(['eps-content', className]);\n\n return <Component className={classList}>{children}</Component>;\n};\n","import React, { ChangeEvent } from 'react';\nimport { VariantType } from '@entur/form';\nimport { ExpandablePanel } from '@entur/expand';\n\nimport { LanguageKey, LanguageOption } from './LanguageSelect';\nimport { Stack } from './Stack';\n\nexport type MultiLanguageValues = Record<LanguageKey, string>;\n\ntype ExpandableMultiLanguageInputProps = {\n title: string;\n inputComponent: React.ElementType;\n languages: LanguageOption[];\n values: MultiLanguageValues;\n onChange: (values: MultiLanguageValues) => void;\n name: string;\n variant?: (lang: LanguageKey) => VariantType;\n feedback?: (lang: LanguageKey) => string;\n [key: string]: any;\n};\n\nexport const ExpandableMultiLanguageInput = ({\n title,\n inputComponent: InputComponent,\n languages,\n values,\n onChange,\n name,\n variant,\n feedback,\n ...rest\n}: ExpandableMultiLanguageInputProps) => {\n const handleOnChange = (language: LanguageKey, value?: string) => {\n const changes = { ...values };\n if (value === '' || !value) {\n delete changes[language];\n } else {\n changes[language] = value;\n }\n onChange(changes);\n };\n\n return (\n <ExpandablePanel\n title={title}\n defaultOpen\n contentStyle={{\n padding: '4px 4px 4px 4px',\n marginTop: '16px',\n marginBottom: '16px',\n }}\n >\n <Stack space=\"medium\">\n {languages.map(({ value: langKey, label, required }) => (\n <InputComponent\n data-testid={`multi-lang-input-${name}-${langKey}`}\n key={title + langKey}\n label={required ? label + '*' : label}\n variant={variant && variant(langKey)}\n feedback={feedback && feedback(langKey)}\n name={name}\n onChange={(e: ChangeEvent<HTMLInputElement>) => {\n handleOnChange(langKey, e.target.value);\n }}\n value={values[langKey] || ''}\n {...rest}\n />\n ))}\n </Stack>\n </ExpandablePanel>\n );\n};\n","import React, { FC } from 'react';\n\nexport interface FormatCurrencyAmountProps {\n amount: number | string;\n as?: 'span' | React.ElementType;\n [key: string]: any;\n}\n\nexport const FormatCurrencyAmount: FC<FormatCurrencyAmountProps> = ({\n amount,\n as: Component = 'span',\n ...rest\n}) => {\n const parsedAmount = Number(amount) || 0;\n\n const formattedAmount = new Intl.NumberFormat('nb-NO', {\n maximumFractionDigits: 2,\n minimumFractionDigits: 2,\n }).format(parsedAmount);\n\n return <Component {...rest}>{formattedAmount}</Component>;\n};\n","import React, { FC } from 'react';\nimport { Link as RouterLink, LinkProps } from 'react-router-dom';\nimport { Link as A } from '@entur/typography';\n\ninterface Props extends LinkProps {}\n\nexport const Link: FC<Props> = (props) => {\n return (\n <A {...props} as={RouterLink}>\n {props.children}\n </A>\n );\n};\n","import './LinkButton.scss';\n\nimport React, { ReactNode } from 'react';\nimport { Link } from '@entur/typography';\nimport cx from 'classnames';\n\nexport interface LinkButtonProps {\n children: ReactNode;\n className?: string;\n [key: string]: any;\n}\n\nexport const LinkButton = ({\n children,\n className,\n ...rest\n}: LinkButtonProps) => (\n <Link {...rest} as=\"button\" className={cx('eps-link-button', className)}>\n {children}\n </Link>\n);\n","import './Menu.scss';\n\nimport React, { FC, ReactNode } from 'react';\nimport classnames from 'classnames';\n\ninterface MenuProps {\n children: ReactNode;\n as?: 'div' | React.ElementType;\n className?: string;\n}\nexport const Menu: FC<MenuProps> = ({\n as: Component = 'nav',\n className,\n children,\n}) => {\n const classList = classnames(['eds-contrast', 'eps-menu', className]);\n\n return <Component className={classList}>{children}</Component>;\n};\n","import './MultiLanguageInput.scss';\n\nimport React, { FC, useState, ChangeEvent, FocusEvent } from 'react';\nimport cx from 'classnames';\nimport { VariantType } from '@entur/form';\n\nimport { Stack } from './Stack';\nimport { LanguageSelect, LanguageOption } from './LanguageSelect';\n\ntype Values = { [key: string]: string };\n\nexport interface MultiLanguageInputProps {\n className?: string;\n onBlur?: (e: FocusEvent<HTMLDivElement>) => void;\n inputComponent: React.ElementType;\n values: { [key: string]: string };\n languages: LanguageOption[];\n onChange: (values: Values) => void;\n name: string;\n alertLevel?: VariantType;\n alertLabel?: string;\n label?: string;\n defaultLanguage?: string;\n [key: string]: any;\n}\n/**\n * @deprecated use ExpandableMultiLanguageInput\n */\nexport const MultiLanguageInput: FC<MultiLanguageInputProps> = ({\n className,\n inputComponent: InputComponent,\n alertLabel,\n alertLevel,\n name,\n languages,\n values,\n onChange,\n defaultLanguage = 'nob',\n label = '',\n onBlur = () => {},\n ...rest\n}) => {\n const [language, setLanguage] = useState(defaultLanguage);\n const classNames = cx('multi-language-input', className);\n const currentValue = values[language];\n\n const handleOnBlur = (e: FocusEvent<HTMLDivElement>) => {\n e.persist();\n const currentTarget = e.currentTarget;\n setTimeout(() => {\n if (currentTarget && !currentTarget.contains(document.activeElement)) {\n onBlur(e);\n }\n }, 0);\n };\n\n const handleLanguageChange = (language: string) => {\n setLanguage(language);\n };\n\n const handleOnChange = (value?: string) => {\n const changes = Object.assign({}, values);\n if (value === '' || !value) {\n delete changes[language];\n } else {\n changes[language] = value;\n }\n onChange(changes);\n };\n\n return (\n <div\n className={classNames}\n tabIndex={0}\n onBlur={handleOnBlur}\n data-testid={`multi-lang-input-${name}`}\n >\n <Stack space=\"extraSmall\">\n <LanguageSelect\n language={language}\n options={languages}\n onChange={(lang) => handleLanguageChange(lang)}\n />\n <InputComponent\n label={label}\n variant={alertLevel}\n feedback={alertLabel}\n name={name}\n className=\"language-item\"\n onChange={(e: ChangeEvent<HTMLInputElement>) =>\n handleOnChange(e.target.value)\n }\n value={currentValue || ''}\n {...rest}\n />\n </Stack>\n </div>\n );\n};\n","import React, { FC } from 'react';\nimport { Dropdown } from '@entur/dropdown';\n\ninterface Organisation {\n name: string;\n id: string;\n}\n\ninterface OrganisationDropDownProps {\n label: string;\n onChange: (id: string) => void;\n organisations: Organisation[];\n selectedOrganisationId?: string;\n [key: string]: any;\n}\n\nexport const OrganisationDropDown: FC<OrganisationDropDownProps> = ({\n label,\n organisations,\n onChange: handleChange,\n selectedOrganisationId,\n ...rest\n}) => {\n const selectedOrganisation = organisations.find(\n (org) => org.id === selectedOrganisationId\n );\n\n return (\n <Dropdown\n label={label}\n searchable={true}\n clearable={true}\n className=\"eds-contrast\"\n items={[\n ...organisations\n .sort((a, b) => a.name.localeCompare(b.name, 'nb'))\n .map((organisation) => {\n return {\n value: organisation.id,\n label: organisation.name,\n };\n }),\n ]}\n initialSelectedItem={\n selectedOrganisation\n ? {\n value: selectedOrganisation.id,\n label: selectedOrganisation.name,\n }\n : null\n }\n onChange={(selectedValue) => {\n if (selectedValue) {\n handleChange(selectedValue.value);\n }\n }}\n {...rest}\n />\n );\n};\n","import React, { FC } from 'react';\nimport { Pagination } from '@entur/menu';\n\nexport interface PagerProps {\n currentPage: number;\n collectionSize: number;\n pageSize: number;\n onPageChange: (page: number) => void;\n}\n\nexport const Pager: FC<PagerProps> = ({\n collectionSize,\n pageSize,\n onPageChange,\n currentPage,\n}) => {\n const pageCount = Math.ceil(collectionSize / pageSize);\n return (\n <Pagination\n pageCount={pageCount}\n currentPage={currentPage}\n onPageChange={(page) => {\n onPageChange(page);\n }}\n />\n );\n};\n","import { BusinessCapability } from '@entur-partner/permission-client-node';\nimport React from 'react';\nimport {\n Route,\n Redirect,\n RouteComponentProps,\n RouteProps,\n} from 'react-router-dom';\n\nimport { PermissionCheck } from './PermissionCheck';\n\ninterface PermissionCheckedRouteProps\n extends RouteComponentProps,\n Omit<RouteProps, 'location'> {\n actualPermissions: BusinessCapability[];\n all?: BusinessCapability[];\n oneOf?: BusinessCapability[];\n onReject?: React.ReactNode;\n}\n\nexport const PermissionCheckedRoute = ({\n children,\n actualPermissions,\n all,\n oneOf,\n onReject,\n ...props\n}: PermissionCheckedRouteProps) => {\n const redirect = (\n <Redirect\n to={{\n pathname: '/unauthorized',\n state: { from: props.location },\n }}\n />\n );\n return (\n <PermissionCheck\n permissions={actualPermissions}\n all={all}\n oneOf={oneOf}\n fallback={onReject ? onReject : redirect}\n >\n <Route {...props}>{children}</Route>\n </PermissionCheck>\n );\n};\n","import React, { useState, FC, ReactNode } from 'react';\nimport { Prompt, useHistory } from 'react-router-dom';\nimport { Location } from 'history';\nimport { ModalProps } from '@entur/modal';\n\nimport { ConfirmModal } from './ConfirmModal';\n\nexport interface RouteLeavingGuardProps extends Partial<ModalProps> {\n title: string;\n closeLabel: string;\n messages: {\n cancel: string;\n confirm: string;\n };\n children: ReactNode;\n shouldBlockNavigation: (location: Location) => boolean;\n}\n\ntype Status = 'BLOCKED' | 'ALLOW';\n\nexport const RouteLeavingGuard: FC<RouteLeavingGuardProps> = ({\n children,\n shouldBlockNavigation,\n ...rest\n}) => {\n const history = useHistory();\n\n const [status, setStatus] = useState<Status>('ALLOW');\n const [lastLocation, setLastLocation] = useState(history.location);\n\n const closeModal = () => {\n setStatus('ALLOW');\n };\n\n const allowNavigation = (nextLocation: Location): boolean => {\n if (shouldBlockNavigation(nextLocation) && status === 'ALLOW') {\n setStatus('BLOCKED');\n setLastLocation(nextLocation);\n return false;\n }\n return true;\n };\n\n const handleConfirm = () => {\n history.push(lastLocation.pathname);\n };\n\n return (\n <>\n <Prompt message={allowNavigation} />\n <ConfirmModal\n onDismiss={closeModal}\n open={status === 'BLOCKED'}\n onConfirm={handleConfirm}\n {...rest}\n >\n {children}\n </ConfirmModal>\n </>\n );\n};\n","import './StatusLabel.scss';\n\nimport React, { FC } from 'react';\nimport cx from 'classnames';\n\ninterface StatusLabelProps {\n label: string;\n active: boolean;\n aggressiveInactive?: boolean;\n showBullet?: boolean;\n center?: boolean;\n}\nexport const StatusLabel: FC<StatusLabelProps> = ({\n active = false,\n label = '',\n aggressiveInactive,\n showBullet,\n center,\n}) => {\n const bulletClassNames = cx('eps-status-label__bullet', {\n active,\n aggressive: aggressiveInactive,\n });\n const statusLabelClassNames = cx('eps-status-label', {\n center,\n });\n return (\n <div className={statusLabelClassNames}>\n {showBullet && <div className={bulletClassNames} />}\n <div>{label}</div>\n </div>\n );\n};\n","import './Text.scss';\n\nimport React, { ReactNode } from 'react';\nimport cx from 'classnames';\n\nimport { StyleColor, responsiveProp, Box } from './Box';\n\ntype StyleFontSize =\n | 'extraSmall'\n | 'small'\n | 'medium'\n | 'large'\n | 'extraLarge'\n | 'extraLarge2'\n | 'extraLarge3'\n | 'extraLarge4';\n\ntype StyleFontWeight = 'body' | 'heading';\n\ntype StyleLineHeight =\n | 'extraSmall'\n | 'small'\n | 'medium'\n | 'large'\n | 'extraLarge'\n | 'extraLarge2'\n | 'extraLarge3'\n | 'extraLarge4'\n | 'extraLarge5'\n | 'extraLarge6'\n | 'extraLarge7';\n\nexport type ResponsiveStyleFontSize =\n | StyleFontSize\n | [StyleFontSize?, StyleFontSize?, StyleFontSize?];\n\nexport type ResponsiveStyleLineHeight =\n | StyleLineHeight\n | [StyleLineHeight?, StyleLineHeight?, StyleLineHeight?];\n\nexport interface TextProps {\n className?: string;\n as?: React.ElementType;\n children: ReactNode;\n\n fontSize?: ResponsiveStyleFontSize;\n lineHeight?: ResponsiveStyleLineHeight;\n color?: StyleColor;\n fontWeight?: StyleFontWeight;\n\n [key: string]: any;\n}\n\nexport const Text = ({\n as: component = 'span',\n children,\n fontSize,\n color,\n lineHeight,\n fontWeight,\n className,\n ...rest\n}: TextProps) => {\n const classes = [];\n\n fontSize && classes.push(...responsiveProp('eps-font-size-', fontSize));\n lineHeight && classes.push(...responsiveProp('eps-line-height-', lineHeight));\n fontWeight && classes.push('eps-font-weight-' + fontWeight);\n\n const classList = cx(classes, className);\n\n return (\n <Box as={component} color={color} className={classList} {...rest}>\n {children}\n </Box>\n );\n};\n","import './Unbutton.scss';\n\nimport React, { FC } from 'react';\nimport { Button, ButtonProps } from '@entur/button';\nimport cx from 'classnames';\n\ninterface UnbuttonProps extends Omit<ButtonProps, 'variant'> {}\n\nexport const Unbutton: FC<UnbuttonProps> = ({\n children,\n className,\n ...rest\n}) => (\n <Button variant=\"primary\" {...rest} className={cx('eps-unbutton', className)}>\n {children}\n </Button>\n);\n","/*global EventListener WindowEventHandlers*/\nimport { useEffect, useRef } from 'react';\n\ninterface TypedEventListener<T extends Event> {\n (evt: T): void;\n}\n\nexport function useEventListener<T extends Event = Event>(\n eventName: string,\n handler: TypedEventListener<T>,\n element: WindowEventHandlers = window\n) {\n const savedHandler = useRef<TypedEventListener<T>>();\n\n useEffect(() => {\n savedHandler.current = handler;\n }, [handler]);\n\n useEffect(() => {\n const isSupported = element && element.addEventListener;\n if (!isSupported) return;\n\n const eventListener = ((event: T): void =>\n savedHandler.current?.(event)) as EventListener;\n\n element.addEventListener(eventName, eventListener);\n\n return () => {\n element.removeEventListener(eventName, eventListener);\n };\n }, [eventName, element]);\n}\n"],"names":["responsiveProp","prefix","prop","Array","isArray","classes","push","Box","_ref","_ref$as","as","Component","children","contrast","paddingTop","paddingRight","paddingBottom","paddingLeft","paddingX","paddingY","padding","marginTop","marginRight","marginBottom","marginLeft","marginX","marginY","margin","display","justifyContent","alignItems","maxWidth","width","background","color","flexDirection","flexWrap","className","rest","_objectWithoutPropertiesLoose","_excluded","resolvedPaddingTop","resolvedPaddingBottom","resolvedPaddingLeft","resolvedPaddingRight","resolvedMarginTop","resolvedMarginBottom","resolvedMarginLeft","resolvedMarginRight","apply","classList","cx","React","createElement","_extends","Stack","space","stackItems","Children","toArray","length","Fragment","map","child","index","key","featureFlag","flag","_window$localStorage","_window$localStorage2","process","env","getItem","window","localStorage","useFeatureToggle","FeatureToggle","EnturPartnerLogoSvg","title","height","viewBox","fill","fillRule","d","CustomOverflowMenu","_ref2","ref","buttonRef","handler","userName","open","onOpenChange","overflowItemsClasses","overflowContentRef","useRef","overflowMenuTriggerRef","useEffect","listener","event","elementContainsEventTarget","current","document","addEventListener","removeEventListener","SecondaryButton","onClick","role","UserIcon","inline","Heading6","DownArrowIcon","CustomOverflowMenuItem","props","element","contains","target","composed","composedPath","find","LanguageSelect","language","options","onChange","classNames","SegmentedControl","assertIsDefined","selectedValue","option","SegmentedChoice","value","label","required","ErrorBoundary","_Component","_this","call","this","state","error","getDerivedStateFromError","_proto","prototype","componentDidCatch","errorInfo","_this$props$handleErr","_this$props","handleError","render","functionToCheck","_this2","_this$props2","fallback","toString","retry","setState","FormatDateTime","date","locale","hideTime","localeDate","localeDateTime","ConfirmModal","_ref$isOpen","isOpen","message","_ref$size","size","buttons","onConfirm","messages","onClose","onDismiss","childrenToRender","handleDismiss","Modal","isString","Paragraph","ButtonGroup","cancel","PrimaryButton","confirm","PermissionCheck","_ref$fallback","permissions","_ref$oneOf","oneOf","_ref$all","all","allIsAllowed","hasAllPermissions","oneOfIsAllowed","hasOneOfPermissions","_ref3","items","i","isDate","isDateString","prependBreadcrumbItem","pathname","onBreadcrumbLookup","paths","replace","split","reduce","prev","curr","path","breadcrumbs","filter","undefined","breadcrumbElements","BreadcrumbItem","Link","to","BreadcrumbNavigation","classnames","_ref2$as","altText","InputComponent","inputComponent","languages","values","name","variant","feedback","ExpandablePanel","defaultOpen","contentStyle","langKey","e","changes","amount","parsedAmount","Number","formattedAmount","Intl","NumberFormat","maximumFractionDigits","minimumFractionDigits","format","A","RouterLink","alertLabel","alertLevel","_ref$defaultLanguage","defaultLanguage","_ref$label","_ref$onBlur","onBlur","useState","_useState","setLanguage","currentValue","tabIndex","persist","currentTarget","setTimeout","activeElement","lang","handleLanguageChange","Object","assign","organisations","handleChange","selectedOrganisationId","selectedOrganisation","org","id","Dropdown","searchable","clearable","sort","a","b","localeCompare","organisation","initialSelectedItem","collectionSize","onPageChange","currentPage","pageCount","Math","ceil","pageSize","Pagination","page","actualPermissions","onReject","redirect","Redirect","from","location","Route","shouldBlockNavigation","history","useHistory","status","setStatus","_useState2","lastLocation","setLastLocation","Prompt","nextLocation","_ref$active","active","showBullet","center","bulletClassNames","aggressive","aggressiveInactive","statusLabelClassNames","component","fontSize","lineHeight","fontWeight","Button","onLogout","onLanguageChange","onShowGdprDialog","triggerClassList","setOpen","PrivacyIcon","termsAndConditions","NorwayIcon","switchLanguage","UKIcon","UploadIcon","style","transform","logout","eventName","savedHandler","eventListener"],"mappings":"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"}
|
package/dist/common.esm.js
CHANGED
|
@@ -205,14 +205,21 @@ var LinkButton = function LinkButton(_ref) {
|
|
|
205
205
|
* you can drop the REACT_APP_ prefix.
|
|
206
206
|
*/
|
|
207
207
|
|
|
208
|
-
function
|
|
208
|
+
function featureFlag(flag) {
|
|
209
209
|
var _window$localStorage, _window$localStorage2;
|
|
210
210
|
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
211
|
+
return process.env["REACT_APP_" + flag] === 'true' || ((_window$localStorage = window.localStorage) == null ? void 0 : _window$localStorage.getItem(flag)) === 'true' || ((_window$localStorage2 = window.localStorage) == null ? void 0 : _window$localStorage2.getItem("REACT_APP_" + flag)) === 'true';
|
|
212
|
+
}
|
|
213
|
+
/**
|
|
214
|
+
* Returns true if the provided flag exist in localStorage
|
|
215
|
+
* or is set as an environment variable.
|
|
216
|
+
*
|
|
217
|
+
* @param flag case sensitive flag. If it is an environment variable
|
|
218
|
+
* you can drop the REACT_APP_ prefix.
|
|
219
|
+
*/
|
|
214
220
|
|
|
215
|
-
|
|
221
|
+
function useFeatureToggle(flag) {
|
|
222
|
+
return featureFlag(flag);
|
|
216
223
|
}
|
|
217
224
|
var FeatureToggle = function FeatureToggle(_ref) {
|
|
218
225
|
var children = _ref.children,
|
|
@@ -1045,5 +1052,5 @@ var Text = function Text(_ref) {
|
|
|
1045
1052
|
}, rest), children);
|
|
1046
1053
|
};
|
|
1047
1054
|
|
|
1048
|
-
export { ActionBar, ActionBarLeft, ActionBarRight, AuditInfo, Box, Breadcrumbs, ConfirmModal, Content, EnturPartnerLogo, EnturPartnerLogoSvg, ErrorBoundary, ExpandableMultiLanguageInput, FeatureToggle, FormatCurrencyAmount, FormatDateTime, LanguageSelect, Link, LinkButton, Menu, MultiLanguageInput, OrganisationDropDown, Pager, PermissionCheck, PermissionCheckedRoute, RouteLeavingGuard, Stack, StatusLabel, Text, Unbutton, UserMenu, responsiveProp, useEventListener, useFeatureToggle };
|
|
1055
|
+
export { ActionBar, ActionBarLeft, ActionBarRight, AuditInfo, Box, Breadcrumbs, ConfirmModal, Content, EnturPartnerLogo, EnturPartnerLogoSvg, ErrorBoundary, ExpandableMultiLanguageInput, FeatureToggle, FormatCurrencyAmount, FormatDateTime, LanguageSelect, Link, LinkButton, Menu, MultiLanguageInput, OrganisationDropDown, Pager, PermissionCheck, PermissionCheckedRoute, RouteLeavingGuard, Stack, StatusLabel, Text, Unbutton, UserMenu, featureFlag, responsiveProp, useEventListener, useFeatureToggle };
|
|
1049
1056
|
//# sourceMappingURL=common.esm.js.map
|