@stenajs-webui/calendar 23.10.0 → 23.11.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/dist/components/calendar-types/travel-date-calendar/TravelDateCalendar.d.ts +1 -0
- package/dist/components/calendar-types/travel-date-range-calendar/TravelDateRangeCalendar.d.ts +2 -0
- package/dist/components/input-types/travel-date-input/TravelDateInput.d.ts +1 -0
- package/dist/components/input-types/travel-date-range-input/TravelDateRangeInput.d.ts +2 -0
- package/dist/features/travel-calendar/components/TravelDateRangeTextInputFields.d.ts +2 -0
- package/dist/features/travel-calendar/components/TravelDateTextInput.d.ts +1 -0
- package/dist/features/travel-calendar/components/TravelDateTextInputField.d.ts +1 -0
- package/dist/index.es.js +1452 -1431
- package/dist/index.es.js.map +1 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/package.json +8 -8
package/dist/index.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
(function(){"use strict";try{if(typeof document<"u"){var e=document.createElement("style");e.appendChild(document.createTextNode("._calendar_hknk7_1{--swui-calendar-day-width: 48px;--swui-calendar-day-height: 48px;--swui-calendar-day-border-radius: var(--swui-max-border-radius);--swui-calendar-week-number-bg-color: transparent;--swui-calendar-week-number-text-color: var(--lhds-color-ui-500);--swui-calendar-week-number-clickable-text-color: var(--lhds-color-ui-500);--swui-calendar-week-day-text-color: var(--lhds-color-ui-500);--swui-calendar-week-day-clickable-text-color: var(--lhds-color-ui-500);--swui-calendar-wrapper-selected-border: var(--modern-blue);--swui-calendar-wrapper-selected-background: var(--modern-blue);--swui-calendar-wrapper-range-border: var(--lhds-color-blue-100);--swui-calendar-wrapper-range-background: var(--lhds-color-blue-100);--swui-calendar-wrapper-today-border: var(--lhds-color-ui-200);--swui-calendar-wrapper-today-background: var(--lhds-color-ui-50);--swui-calendar-text-selected-color: #fff;--swui-calendar-text-disabled-color: var(--swui-text-disabled-color);--swui-calendar-text-in-other-month-color: var(--swui-text-disabled-color)}._calendar_hknk7_1 table{border-spacing:0 4px}._calendar_hknk7_1 tr td:last-child{border-top-right-radius:var(--swui-calendar-day-border-radius);border-bottom-right-radius:var(--swui-calendar-day-border-radius)}._calendar_hknk7_1._weekNumberVisible_hknk7_41 tr td:nth-child(2),._calendar_hknk7_1:not(._weekNumberVisible_hknk7_41) tr td:first-child{border-top-left-radius:var(--swui-calendar-day-border-radius);border-bottom-left-radius:var(--swui-calendar-day-border-radius)}._calendar_hknk7_1 td{padding:0;width:var(--swui-calendar-day-width);height:var(--swui-calendar-day-height)}._timePicker_1w05d_1{overflow:hidden;width:180px}._timePickerColumn_1w05d_6{overflow-y:hidden;flex:1}._timePickerColumn_1w05d_6:hover{overflow-y:scroll}._travelDateCell_1t2af_1{position:relative}._travelDateCell_1t2af_1._smaller_1t2af_4{width:40px;height:40px}._travelDateCell_1t2af_1._small_1t2af_4{width:44px;height:44px}._travelDateCell_1t2af_1._medium_1t2af_14{width:48px;height:48px}._travelDateCell_1t2af_1._large_1t2af_19{width:56px;height:28px}._travelDateCell_1t2af_1{border-radius:var(--swui-max-border-radius)}._travelDateCell_1t2af_1:focus{outline:none}._travelDateCell_1t2af_1:focus-visible ._outline_1t2af_31{outline:var(--swui-focus-outline);outline-width:var(--swui-focus-outline-width);background:transparent;position:absolute;border-radius:var(--swui-max-border-radius);inset:0;z-index:10}._travelDateCell_1t2af_1:focus-visible ._contentWrapper_1t2af_44._contentWrapper_1t2af_44._contentWrapper_1t2af_44{border-color:transparent}._travelDateCell_1t2af_1 ._contentWrapper_1t2af_44{cursor:pointer;border-radius:var(--swui-max-border-radius);border-width:2px;border-style:solid;border-color:transparent;background:transparent;position:absolute;display:flex;align-items:center;justify-content:center;inset:0}._travelDateCell_1t2af_1 ._contentWrapper_1t2af_44._disabled_1t2af_65{cursor:not-allowed}._travelDateCell_1t2af_1 ._contentWrapper_1t2af_44._isToday_1t2af_68{border-color:var(--lhds-color-ui-400)}._travelDateCell_1t2af_1 ._contentWrapper_1t2af_44._isSelectionStart_1t2af_72,._travelDateCell_1t2af_1 ._contentWrapper_1t2af_44._isSelectionEnd_1t2af_73{border-color:var(--selection-background-color)}._travelDateCell_1t2af_1 ._contentWrapper_1t2af_44._isSelectionStart_1t2af_72{background:var(--selection-background-color)}._travelDateCell_1t2af_1 ._contentWrapper_1t2af_44._isSelectionStart_1t2af_72 span{color:#fff}._travelDateCell_1t2af_1 ._contentWrapper_1t2af_44._isSelectionEnd_1t2af_73:not(._isSelectionStart_1t2af_72){background:#fff}._travelDateCell_1t2af_1 ._contentWrapper_1t2af_44._hover_1t2af_88{border-color:var(--selection-background-color)}._travelDateCell_1t2af_1 ._contentWrapper_1t2af_44._hover_1t2af_88._startSelected_1t2af_91:not(._endSelected_1t2af_91):not(._isSelectionStart_1t2af_72){background:#fff}._travelDateCell_1t2af_1 ._contentWrapper_1t2af_44._hover_1t2af_88._startSelected_1t2af_91:not(._endSelected_1t2af_91):not(._isSelectionStart_1t2af_72) span{color:var(--swui-text-primary-color)}._travelDateCellBackground_45q5d_1._smaller_45q5d_2{width:20px;height:40px}._travelDateCellBackground_45q5d_1._small_45q5d_2{width:22px;height:44px}._travelDateCellBackground_45q5d_1._medium_45q5d_12{width:24px;height:48px}._travelDateCellBackground_45q5d_1._large_45q5d_17{width:28px;height:56px}._travelCalendar_ib2y4_1{border-spacing:0 4px;width:-webkit-fit-content;width:fit-content;--selection-background-color: var( --travel-calendar-selection-background-color, var(--modern-blue) );--selection-range-background-color: var( --travel-calendar-selection-range-background-color, var(--himmel) )}._travelCalendar_ib2y4_1 td{padding:0}._travelDateRangeInput_1j7rp_1 ._overlay_1j7rp_2{transition:opacity var(--swui-animation-time-fast) ease-in-out;opacity:1}._travelDateRangeInput_1j7rp_1 ._overlay_1j7rp_2:not(._travelDateRangeInput_1j7rp_1 ._overlay_1j7rp_2._calendarVisible_1j7rp_6){opacity:0}._travelDateInput_hmfbf_1 ._overlay_hmfbf_2{transition:opacity var(--swui-animation-time-fast) ease-in-out;opacity:1}._travelDateInput_hmfbf_1 ._overlay_hmfbf_2:not(._travelDateInput_hmfbf_1 ._overlay_hmfbf_2._calendarVisible_hmfbf_6){opacity:0}")),document.head.appendChild(e)}}catch(a){console.error("vite-plugin-css-injected-by-js",a)}})();
|
|
2
|
-
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("react/jsx-runtime"),g=require("@stenajs-webui/core"),k=require("@stenajs-webui/elements"),u=require("date-fns"),B=require("date-fns/locale"),le=require("lodash-es"),l=require("react"),Q=require("classnames"),Ae=require("@emotion/styled"),te=require("@stenajs-webui/forms"),ye=require("@stenajs-webui/tooltip"),Ve=require("@stenajs-webui/theme"),zt=require("@stenajs-webui/input-mask"),De=require("react-responsive");function $t(e){const t=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(e){for(const r in e)if(r!=="default"){const n=Object.getOwnPropertyDescriptor(e,r);Object.defineProperty(t,r,n.get?n:{enumerable:!0,get:()=>e[r]})}}return t.default=e,Object.freeze(t)}const qe=$t(l),se={yearAndMonth:"yyyy-MM",fullDate:"yyyy-MM-dd",fullMonthName:"LLLL"},_e=(e={},t,r)=>{if(t&&r&&u.isAfter(r,t))return u.eachDayOfInterval({start:t,end:r}).reduce((a,s)=>{const i=u.isSameDay(s,t),c=u.isSameDay(s,r);return ae(a,s,i?["selected","selectedStart","range"]:c?["selected","selectedEnd","range"]:["range"])},e);let n=e;return t&&(n=ae(n,t,["selected","singleSelected"])),r&&(n=ae(n,r,["selected","singleSelected"])),n},ut=(e={},t,r,n)=>dt(e,t,r,u.startOfMonth(n),u.endOfMonth(n)),dt=(e={},t,r,n,a)=>t&&r?_e(e,u.max([t,u.subDays(n,1)]),u.min([r,u.addDays(a,1)])):_e(e,t,r),Vt=(e,t,r)=>{const n=u.format(t,se.yearAndMonth),a=u.getISOWeek(t),s=u.getDate(t);return{...e,[n]:{...e&&e[n],[a]:{...e&&e[n]&&e[n][a],[s]:{...e&&e[n]&&e[n][a]&&e[n][a][s],...r}}}}},qt=(e,t,r)=>{const n=u.format(t,se.yearAndMonth),a=u.getISOWeek(t),s=u.getDate(t);return{...e,[n]:{...e&&e[n],[a]:{...e&&e[n]&&e[n][a],[s]:{...e&&e[n]&&e[n][a]&&e[n][a][s],...r(e&&e[n]&&e[n][a]&&e[n][a][s])}}}}},ae=(e,t,r)=>{const n=t.getMonth()+1,a=`${t.getFullYear()}-${n<10?"0":""}${n}`,s=u.getISOWeek(t),i=u.getDate(t),c=e&&e[a]&&e[a][s]&&e[a][s][i];return{...e,[a]:{...e&&e[a],[s]:{...e&&e[a]&&e[a][s],[i]:Ke(c,r)}}}},Ke=(e,t)=>({...e,highlights:[...e?.highlights??[],...t]}),Kt=(e,t,r)=>{const n=t.days[0].date,a=n.getMonth()+1,s=`${n.getFullYear()}-${a<10?"0":""}${a}`,i=t.weekNumber;let c=e;t.days.forEach(p=>{c=ae(c,p.date,r)});const d=c&&c[s]?c[s][i]:void 0,f=d&&d.highlights?[...d.highlights,...r]:r,_={...d,highlights:f};return{...c,[s]:{...e&&e[s],[i]:_}}},ft=(e,t)=>{if(!t.days.length)return{...e};const r=t.days[0].date,n=le.last(t.days)?.date;return{..._e(e,r,n)}},Gt=(e,t)=>l.useMemo(()=>e?ae(t,new Date,["today"]):t,[e,t]),Re=e=>e.length===0?e:e.length===1?e.toUpperCase():e.charAt(0).toUpperCase()+e.slice(1);var _t=(e=>(e[e.JANUARY=0]="JANUARY",e[e.FEBRUARY=1]="FEBRUARY",e[e.MARCH=2]="MARCH",e[e.APRIL=3]="APRIL",e[e.MAY=4]="MAY",e[e.JUNE=5]="JUNE",e[e.JULY=6]="JULY",e[e.AUGUST=7]="AUGUST",e[e.SEPTEMBER=8]="SEPTEMBER",e[e.OCTOBER=9]="OCTOBER",e[e.NOVEMBER=10]="NOVEMBER",e[e.DECEMBER=11]="DECEMBER",e))(_t||{}),gt=(e=>(e[e.SUNDAY=0]="SUNDAY",e[e.MONDAY=1]="MONDAY",e[e.TUESDAY=2]="TUESDAY",e[e.WEDNESDAY=3]="WEDNESDAY",e[e.THURSDAY=4]="THURSDAY",e[e.FRIDAY=5]="FRIDAY",e[e.SATURDAY=6]="SATURDAY",e))(gt||{});const Ye=(e,t,r,n)=>{const a=[];for(let s=0;s<r;s++)a.push(ve(e,t+s,n));return a},ve=(e,t,r)=>{if(isNaN(e)||isNaN(t))throw new Error("getMonthInYear() received NaN.");const n=e+Math.floor(t/12),a=t%12,s=new Date(n,a,1);return{monthString:u.format(s,se.yearAndMonth),name:Re(u.format(s,se.fullMonthName,{locale:r})),year:n,monthInYear:a,weeks:ht(n,a,r)}},ht=(e,t,r,n=!0)=>{const a=new Date(e,t,1),s=u.startOfWeek(a,{locale:r}),i=[];for(let c=0;c<6;c++){const d=Ie(u.addWeeks(s,c),r);if(c>0&&d.startMonth!==t&&!n)return i;i.push(d)}return i},Ie=(e,t)=>{const r=u.getMonth(u.addDays(e,7))!==u.getMonth(e);return{weekNumber:u.getWeek(e,{locale:t}),startMonth:u.getMonth(e),startYear:u.getYear(e),endMonth:u.getMonth(u.addDays(e,6)),endYear:u.getYear(u.addDays(e,6)),days:mt(e,t),isLastWeekOfMonth:r}},pt=(e,t)=>{const r=u.getISODay(e);return{date:e,name:u.format(e,"EEE",t?{locale:t}:void 0),fullName:u.format(e,"EEEE",t?{locale:t}:void 0),dateString:u.format(u.addHours(e,12),se.fullDate),weekNumber:u.getWeek(e,{locale:t}),year:u.getYear(e),month:u.getMonth(e),dayOfMonth:u.getDate(e),dayOfWeek:r,isFirstDayOfWeek:r===1,isLastDayOfWeek:r===7,isFirstDayOfMonth:u.isSameDay(u.startOfMonth(e),e),isLastDayOfMonth:u.isSameDay(u.endOfMonth(e),e)}},mt=(e,t)=>u.eachDayOfInterval({start:e,end:u.addDays(e,6)}).map(r=>pt(r,t)),bt=(e,t)=>t>11?{year:e+Math.floor(t/12),month:t%12}:t<0?{year:e+Math.floor(t/12),month:12+t%12}:{year:e,month:t},Jt="_calendar_hknk7_1",Qt="_weekNumberVisible_hknk7_41",nt={calendar:Jt,weekNumberVisible:Qt},yt=(e,t,r)=>!!(t&&t.indexOf(r)>=0||e&&e.highlights&&e.highlights.indexOf(r)>=0),ne=(e,t,r,n,a)=>{if(r.length!==n.length)throw new Error("Select highlight failed, number of values do not equal number of highlights.");if(r.length===0)return a;for(let s=0;s<r.length;s++)if(typeof r[s]=="boolean"&&r[s]||typeof r[s]=="string"&&yt(e,t,r[s]))return n[s];return a},vt=({selectedBackground:e,todayBackground:t,rangeBackground:r,borderColor:n="transparent"})=>(a,s,i,c,d)=>({backgroundColor:ne(s,a,["selected","range","today",i.month===d.monthInYear],[e,r,t,"#fff"],"transparent"),borderWidth:"1px",borderStyle:"solid",borderColor:ne(s,a,["selectedStart","selectedEnd","singleSelected","range","today"],["var(--swui-calendar-wrapper-range-background)","var(--swui-calendar-wrapper-range-background)","var(--swui-calendar-wrapper-range-background)","var(--swui-calendar-wrapper-range-border)","var(--lhds-color-ui-500)"],n),borderTopLeftRadius:ne(s,a,["selectedStart","singleSelected","today"],["var(--swui-calendar-day-border-radius)","var(--swui-calendar-day-border-radius)","var(--swui-calendar-day-border-radius)"],"unset"),borderBottomLeftRadius:ne(s,a,["selectedStart","singleSelected","today"],["var(--swui-calendar-day-border-radius)","var(--swui-calendar-day-border-radius)","var(--swui-calendar-day-border-radius)"],"unset"),borderTopRightRadius:ne(s,a,["selectedEnd","singleSelected","today"],["var(--swui-calendar-day-border-radius)","var(--swui-calendar-day-border-radius)","var(--swui-calendar-day-border-radius)"],"unset"),borderBottomRightRadius:ne(s,a,["selectedEnd","singleSelected","today"],["var(--swui-calendar-day-border-radius)","var(--swui-calendar-day-border-radius)","var(--swui-calendar-day-border-radius)"],"unset"),boxSizing:"border-box"}),xt=({selectedColor:e,disabledColor:t,inOtherMonthColor:r,rangeTextColor:n})=>(a,s,i,c,d)=>{const f=i.month!==d.monthInYear;return{color:ne(s,a,[f,"selected","range","enabled","disabled"],[r,e,n,void 0,t])}},ie={width:"var(--swui-calendar-day-width)",height:"var(--swui-calendar-day-height)",WeekNumber:{backgroundColor:"var(--swui-calendar-week-number-bg-color)",textColor:"var(--swui-calendar-week-number-text-color)",clickableTextColor:"var(--swui-calendar-week-number-clickable-text-color)"},WeekDay:{textColor:"var(--swui-calendar-week-day-text-color)",clickableTextColor:"var(--swui-calendar-week-day-clickable-text-color)"},CalendarDay:{tdStyle:vt({selectedBackground:"var(--swui-calendar-wrapper-selected-background)",rangeBackground:"var(--swui-calendar-wrapper-range-background)",todayBackground:"var(--swui-calendar-wrapper-today-background)"}),textProps:xt({selectedColor:"var(--swui-calendar-text-selected-color)",disabledColor:"var(--swui-calendar-text-disabled-color)",inOtherMonthColor:"var(--swui-calendar-text-in-other-month-color)"})},CalendarMonth:{headerTextColor:"var(--swui-calendar-week-day-text-color)"}},Zt={...ie,width:"37px",height:"37px"},wt=({onClickWeekDay:e,day:t,theme:r})=>{const n=o.jsx(g.Box,{width:r.width,height:r.height,justifyContent:"center",alignItems:"center",children:o.jsx(g.Text,{size:"small",color:e?r.WeekDay.clickableTextColor:r.WeekDay.textColor,children:t.name})});return e?o.jsx(g.Clickable,{borderRadius:"var(--swui-calendar-day-border-radius)",onClick:a=>e(t.dayOfWeek,a),disableFocusHighlight:!e,children:n}):n},Ge=function({day:t,week:r,month:n,dayState:a,userData:s,onClickDay:i,theme:c,extraDayContent:d,defaultHighlights:f,showDatesInOtherMonths:_}){const p=o.jsx(g.Box,{width:"100%",height:"100%",justifyContent:"center",alignItems:"center",children:o.jsx(g.Text,{...c.CalendarDay.textProps&&c.CalendarDay.textProps(f,a,t,r,n,s),children:t.dayOfMonth})}),m=Ae.td({...c.CalendarDay.tdStyle&&c.CalendarDay.tdStyle(f,a,t,r,n,s)}),h=Ae.div({...c.CalendarDay.innerWrapperStyle&&c.CalendarDay.innerWrapperStyle(f,a,t,r,n,s),width:"100%",height:"100%"}),v=Ae.div({...c.CalendarDay.cellWrapperStyle&&c.CalendarDay.cellWrapperStyle(f,a,t,r,n,s),width:"100%",height:"100%",position:"relative"}),w=Xt(f,a);return o.jsx(m,{onClick:w?void 0:C=>i?.(t,s,C),children:o.jsx(h,{children:o.jsx(v,{children:(t.month===n.monthInYear||_)&&o.jsxs(o.Fragment,{children:[d&&o.jsx(d,{week:r,month:n,day:t,dayState:a,theme:c,userData:s}),p]})})})})},Xt=(e,t)=>!!ne(t,e,["enabled","disabled"],[!1,!0],!1),Dt=({onClickWeek:e,theme:t,week:r,background:n,backgroundColor:a,prefix:s})=>{const i=o.jsxs(g.Box,{width:t.width,height:t.height,justifyContent:"center",alignItems:"center",children:[n&&o.jsx(g.Box,{position:"absolute",children:n}),o.jsx(g.Box,{position:"absolute",children:o.jsxs(g.Text,{color:e?t.WeekNumber.clickableTextColor:t.WeekNumber.textColor,children:[s,r.weekNumber]})})]});return o.jsx(g.Box,{background:a||t.WeekNumber.backgroundColor,position:"relative",children:e?o.jsx(g.Clickable,{borderRadius:"var(--swui-calendar-day-border-radius)",onClick:c=>e(r,c),disableFocusHighlight:!e,children:i}):i})},er=(e,t,r)=>t&&u.isBefore(e,t)?u.isSameDay(e,t):r&&u.isAfter(e,r)?u.isSameDay(e,r):!0,tr=function({dayComponent:t,minDate:r,maxDate:n,dayState:a,day:s,...i}){const c=l.useMemo(()=>er(s.date,r,n)?a:Ke(a,["disabled"]),[s.date,a,n,r]);return o.jsx(t,{day:s,...i,dayState:c})};function rr({month:e,dayComponent:t=Ge,statePerWeek:r,userDataPerWeek:n,minDate:a,maxDate:s,onClickDay:i,onClickWeek:c,onClickWeekDay:d,onClickMonth:f,renderWeekNumber:_,renderWeekDay:p,headerRightContent:m,theme:h=ie,extraDayContent:v,defaultHighlights:w,showWeekNumber:C}){return o.jsx(o.Fragment,{children:o.jsxs(g.Box,{alignItems:"stretch",children:[o.jsxs(g.Row,{justifyContent:m?"space-between":"center",alignItems:"center",children:[o.jsx(g.Row,{justifyContent:"center",alignItems:"center",children:f?o.jsx(k.FlatButton,{onClick:()=>f(e),label:e.name+" "+String(e.year),rightIcon:k.stenaAngleDown}):o.jsxs(g.Text,{whiteSpace:"nowrap",children:[e.name," ",e.year]})}),m&&o.jsx(g.Box,{alignItems:"center",children:m})]}),o.jsx("table",{children:o.jsxs("tbody",{children:[o.jsxs("tr",{children:[C&&o.jsx("td",{children:o.jsx(g.Box,{width:h.width,height:h.height})}),e.weeks[0].days.map(D=>o.jsx("td",{children:p?p(D.name,h,d):o.jsx(wt,{day:D,onClickWeekDay:d,theme:h})},D.name))]}),e.weeks.map(D=>o.jsxs("tr",{children:[C&&o.jsx("td",{children:_?_(D,h,c):o.jsx(Dt,{week:D,onClickWeek:c,theme:h})}),D.days.map(y=>o.jsx(tr,{dayComponent:t,day:y,week:D,month:e,dayState:r&&r[D.weekNumber]&&r[D.weekNumber][y.dayOfMonth],userData:n&&n[D.weekNumber]&&n[D.weekNumber][y.dayOfMonth],onClickDay:i,theme:h,extraDayContent:v,defaultHighlights:w,minDate:a,maxDate:s},y.dateString))]},D.weekNumber))]})})]})})}function nr({monthRows:e,dayComponent:t=Ge,userDataPerMonth:r,statePerMonth:n,minDate:a,maxDate:s,onClickDay:i,onClickWeekDay:c,onClickWeek:d,onClickMonth:f,renderWeekDay:_,renderWeekNumber:p,headerRightContent:m,extraDayContent:h,defaultHighlights:v,showWeekNumber:w,theme:C=ie}){const D=l.useMemo(()=>a?u.parse(a,"yyyy-MM-dd",new Date):void 0,[a]),y=l.useMemo(()=>s?u.parse(s,"yyyy-MM-dd",new Date):void 0,[s]);return o.jsx("div",{className:Q(nt.calendar,w&&nt.weekNumberVisible),children:e.map((x,b)=>o.jsx(g.Spacing,{children:o.jsx(g.Row,{gap:2,children:x.map(S=>o.jsx(rr,{month:S,dayComponent:t,userDataPerWeek:r&&r[S.monthString],statePerWeek:n&&n[S.monthString],onClickDay:i,onClickWeekDay:c,onClickWeek:d,onClickMonth:f,theme:C,renderWeekNumber:p,renderWeekDay:_,headerRightContent:m,extraDayContent:h,defaultHighlights:v,minDate:D,maxDate:y,showWeekNumber:w??!1},S.name))})},b))})}function Se(e){const t=ar(e.year,e.month,e.date),{year:r,month:n}=bt(t.year,t.month),a=sr(r,n,e.locale??B.enGB,e.numMonths,e.monthsPerRow),s=Gt(e.highlightToday,e.statePerMonth);return o.jsx(nr,{year:r,month:n,monthRows:a,...e,statePerMonth:s})}const ar=(e,t,r)=>{if(t&&e)return{month:t,year:e};if(r)return{month:u.getMonth(r),year:u.getYear(r)};const n=new Date;return{month:u.getMonth(n),year:u.getYear(n)}},sr=(e,t,r,n,a)=>n==null?[[ve(e,t,r)]]:a==null?[Ye(e,t,n,r)]:le.chunk(Ye(e,t,n,r),a),kt=(e,t)=>`${e.row}-${e.column}-${t}`,or=(e,t,r,n)=>{let a=t;for(let s=0;s<n;s++){a=lr(a,e,n);const i=kt(a,r);if(document.getElementById(i))return i}},lr=(e,t,r)=>{let n=e.row,a=e.column;return t==="ArrowLeft"?a--:t==="ArrowUp"?n--:t==="ArrowRight"?a++:t==="ArrowDown"&&n++,a<0&&(a=r-1,n--),a>r-1&&(a=0,n++),{column:a,row:n}},ge={en:B.enGB,"en-US":B.enUS,"en-GB":B.enGB,"en-IE":B.enIE,"de-AT":B.deAT,"nl-BE":B.nlBE,"nl-NL":B.nl,"de-DE":B.de,"nb-NO":B.nb,"sv-SE":B.sv,"da-DK":B.da,"lv-LV":B.lv,"lt-LT":B.lt,"it-IT":B.it,"et-EE":B.et,"fi-FI":B.fi,"cs-CZ":B.cs,"es-ES":B.es,"fr-FR":B.fr,"pl-PL":B.pl,nl:B.nl,de:B.de,nb:B.nb,sv:B.sv,da:B.da,lv:B.lv,lt:B.lt,it:B.it,et:B.et,fi:B.fi,cs:B.cs,es:B.es,fr:B.fr,pl:B.pl},Je="en-GB",ir="sv",Qe=(e,t,r)=>{if(ge[e])return e;if(t){const n=Ct(e);if(n)return n}return r},ue=e=>ge[e],Ct=e=>{const[t]=e.split("-"),r=Object.keys(ge);for(const n of r)if(n.startsWith(t))return n},cr=()=>ge.sv,St=e=>{const t=Object.keys(ge);for(const r of t)if(ge[r].code===e.code)return r},ur=({month:e,onClick:t,selected:r,localeCode:n,autoFocus:a,monthPickerId:s,position:i,size:c})=>{const d=l.useMemo(()=>ue(n)??ue("en-GB"),[n]),f=l.useMemo(()=>Re(u.format(e,"LLL",{locale:d})),[d,e]),_=l.useMemo(()=>u.format(e,"LLLL",{locale:d}),[d,e]),p=l.useRef(null),m=kt(i,s),h=r?0:-1;l.useEffect(()=>{p.current?.focus()},[]);const v=l.useCallback(w=>{const C=or(w.key,i,s,4);C&&document.getElementById(C)?.focus()},[s,i]);return o.jsx(g.Row,{justifyContent:"center",onKeyDown:v,children:r?o.jsx(k.PrimaryButton,{id:m,"aria-label":_,label:f,onClick:t,"aria-selected":!0,autoFocus:a,ref:p,size:c==="large"?"large":"medium",tabIndex:h}):o.jsx(k.FlatButton,{id:m,label:f,"aria-label":_,onClick:t,size:c==="large"?"large":"medium",tabIndex:h})})},dr=(e,t,r)=>{let n=e.getFullYear(),a=0,s=0,i=e;const c={yearOrder:[],rows:[],years:{},lastMonthColumn:-1,lastMonthRow:-1};for(let d=0;d<t;d++){if(c.years[n]==null&&(c.yearOrder.push(n),c.years[n]={year:n,rows:[]}),c.rows[a]=c.rows[a]??{columns:[],rowIndex:a},c.rows[a].columns[s]={position:{column:s,row:a},month:i},d===t-1){c.years[n].rows.push(a);break}i=u.addMonths(i,1),i.getFullYear()!==n?(c.years[n].rows.push(a),n++,s=0,a++):(s++,s>r-1&&(c.years[n].rows.push(a),s=0,a++))}return c.lastMonthColumn=s,c.lastMonthRow=a,c},he=({value:e,onValueChange:t,firstMonth:r,localeCode:n,numMonths:a,onCancel:s,size:i="medium"})=>{const c=l.useId(),d=g.useToday(),f=a>0?a:12,[_,p]=l.useState(!1),m=dr(r,f,_r(i)),h=l.useMemo(()=>u.addMonths(r,f),[f,r]);l.useEffect(()=>{p(!0)},[]);const v=l.useCallback(w=>{w.key==="Escape"&&(s?.(),w.preventDefault(),w.stopPropagation())},[s]);return o.jsx(g.Column,{gap:1,maxWidth:fr(i),onKeyDown:v,children:m.yearOrder.map((w,C)=>{const{rows:D}=m.years[w];return o.jsxs(qe.Fragment,{children:[(C!==0||w!==d.getFullYear())&&o.jsx(g.Heading,{variant:"h4",children:w}),o.jsx("table",{style:{borderSpacing:"0 8px"},children:o.jsx("tbody",{children:D.map(y=>{const{columns:x}=m.rows[y];return o.jsx("tr",{children:x.map(({month:b,position:S})=>o.jsx("td",{children:o.jsx(ur,{month:b,firstAvailableMonth:r,lastAvailableMonth:h,localeCode:n,selected:e?u.isSameMonth(e,b):!1,autoFocus:_,onClick:()=>t?.(b),monthPickerId:c,position:S,size:i})},b.getMonth()))},y)})})})]},w)})})},fr=e=>{switch(e){case"smaller":return"280px";case"small":return"308px";case"medium":return"336px";case"large":return"448px";default:return g.exhaustSwitchCase(e,"336px")}},_r=e=>{switch(e){case"smaller":case"small":return 3;case"medium":case"large":return 4;default:return g.exhaustSwitchCase(e,4)}},gr=e=>[{label:"Past",presets:[{label:"Last 3 days",startDate:e,endDate:u.subDays(e,2)},{label:"Last 7 days",startDate:e,endDate:u.subDays(e,6)},{label:"Last 30 days",startDate:e,endDate:u.subDays(e,29)},{label:"Last 45 days",startDate:e,endDate:u.subDays(e,44)}]},{label:"Future",presets:[{label:"Next 3 days",startDate:e,endDate:u.addDays(e,2)},{label:"Next 7 days",startDate:e,endDate:u.addDays(e,6)},{label:"Next 30 days",startDate:e,endDate:u.addDays(e,29)},{label:"Next 45 days",startDate:e,endDate:u.addDays(e,44)}]}],jt=({onClickPreset:e})=>{const[t,r]=l.useState(0),n=l.useMemo(()=>gr(new Date),[]),a=n[t]??n[0];return o.jsxs(g.Column,{children:[o.jsxs(g.Row,{justifyContent:"space-between",alignItems:"center",width:"200px",children:[o.jsx(k.FlatButton,{size:"small",leftIcon:k.stenaAngleLeft,disabled:t===0,onClick:()=>r(t-1)}),o.jsx(g.Text,{children:a.label}),o.jsx(k.FlatButton,{size:"small",leftIcon:k.stenaAngleRight,disabled:t===n.length-1,onClick:()=>r(t+1)})]}),o.jsx(g.Space,{}),o.jsx(g.Column,{alignItems:"center",children:a.presets.map(s=>o.jsxs(qe.Fragment,{children:[o.jsx(k.PrimaryButton,{label:s.label,onClick:()=>e(s)}),o.jsx(g.Space,{})]},s.label))})]})},hr=function({locale:t,dateInFocus:r,setDateInFocus:n,currentPanel:a,setCurrentPanel:s,renderMonthPicker:i,firstMonthInMonthPicker:c,numMonthsInMonthPicker:d,...f}){const _=l.useMemo(()=>t==null?"en-GB":St(t)??"en-GB",[t]),p=g.useToday(),m=l.useCallback(v=>{n&&n(v),s("calendar")},[n,s]),h=l.useCallback(()=>{s("month")},[s]);switch(a){case"calendar":return o.jsx(Se,{...f,date:r,onClickMonth:h,locale:t});case"month":return i?i({value:r,onValueChange:m,locale:t,firstMonth:c??p,numMonths:d??24,dateInFocus:r}):o.jsx(he,{value:r,onValueChange:m,localeCode:_,firstMonth:c??p,numMonths:d??24});case"presets":return o.jsx(jt,{onClickPreset:()=>{}});default:return o.jsx(g.Box,{children:o.jsx(k.PrimaryButton,{label:"Show calendar",onClick:()=>s("calendar")})})}},pr=(e,t,r,n)=>{const a=l.useCallback(()=>{const d=u.addMonths(e,r??n??1);t?.(d)},[t,e,r,n]),s=l.useCallback(()=>{const d=u.addYears(e,1);t?.(d)},[t,e]),i=l.useCallback(()=>{const d=u.subMonths(e,r??n??1);t?.(d)},[t,e,r,n]),c=l.useCallback(()=>{const d=u.subYears(e,1);t?.(d)},[t,e]);return{nextMonth:a,prevMonth:i,nextYear:s,prevYear:c}},mr=({children:e,prevMonth:t,nextMonth:r,prevYear:n,nextYear:a})=>o.jsxs("div",{children:[e,o.jsx(g.Indent,{children:o.jsxs(g.Row,{gap:1,children:[o.jsx(k.SecondaryButton,{onClick:n,leftIcon:k.stenaAngleLeftDouble}),o.jsx(k.SecondaryButton,{onClick:t,leftIcon:k.stenaArrowLeft}),o.jsx(g.Indent,{num:2}),o.jsx(k.SecondaryButton,{onClick:r,leftIcon:k.stenaArrowRight}),o.jsx(k.SecondaryButton,{onClick:a,leftIcon:k.stenaAngleRightDouble})]})}),o.jsx(g.Space,{})]}),br=()=>{};function de({monthSwitcherPlacement:e,theme:t=ie,dateInFocus:r,setDateInFocus:n,currentPanel:a,setCurrentPanel:s,onSelectPreset:i=br,renderMonthPicker:c,firstMonthInMonthPicker:d,numMonthsInMonthPicker:f,..._}){const{nextMonth:p,prevMonth:m,nextYear:h,prevYear:v}=pr(r,n,_.monthsPerRow,_.numMonths);switch(yr(e,_.numMonths)){case"below":return o.jsx(mr,{theme:t,nextMonth:p,prevMonth:m,nextYear:h,prevYear:v,children:o.jsx(Se,{..._,theme:t,date:r})});case"header":return o.jsx(g.Column,{children:o.jsx(hr,{..._,theme:t,renderMonthPicker:c,dateInFocus:r,setDateInFocus:n,currentPanel:a,setCurrentPanel:s,onSelectPreset:i,firstMonthInMonthPicker:d,numMonthsInMonthPicker:f,headerRightContent:o.jsxs(g.Row,{alignItems:"center",gap:1,children:[o.jsx(k.SecondaryButton,{onClick:m,leftIcon:k.stenaArrowLeft}),o.jsx(k.SecondaryButton,{onClick:p,leftIcon:k.stenaArrowRight})]})})});default:return o.jsx(Se,{..._,theme:t,date:r})}}const yr=(e,t)=>e||(t||1)>1?"below":"header",Mt=e=>({startDate:e.startDate?u.format(e.startDate,"yyyy-MM-dd"):void 0,endDate:e.endDate?u.format(e.endDate,"yyyy-MM-dd"):void 0}),Bt=({startDate:e,endDate:t})=>{const r=new Date;return{startDate:e?u.parse(e,"yyyy-MM-dd",r):void 0,endDate:t?u.parse(t,"yyyy-MM-dd",r):void 0}},Ze=({startDate:e,endDate:t})=>!!(e&&t&&!u.isSameDay(e,t)&&u.isAfter(e,t)),Xe=e=>Ze(e)?{startDate:e.endDate,endDate:e.startDate}:e,vr=e=>e.startDate&&e.endDate?Mt(Xe(Bt(e))):e,xr=(e,t,r,n)=>l.useCallback(a=>{const s={startDate:r==="startDate"?a.date:e?.startDate,endDate:r==="endDate"?a.date:e?.endDate};Ze(s)||n(r==="startDate"?"endDate":"startDate"),t?.(Xe(s))},[r,t,n,e?.endDate,e?.startDate]),Te=e=>{const[t,r]=l.useState("calendar"),n=l.useCallback(a=>{r(a),e?.(a)},[e]);return{currentPanel:t,setCurrentPanel:n}},Rt=({focusedInput:e,value:t,onValueChange:r,setFocusedInput:n,statePerMonth:a,onChangePanel:s,initialDateInFocus:i})=>{const{currentPanel:c,setCurrentPanel:d}=Te(s),[f,_]=l.useState(()=>i??new Date),p=xr(t,r,e,n),m=l.useMemo(()=>_e(a,t?.startDate,t?.endDate),[a,t?.endDate,t?.startDate]);return{onClickDay:p,statePerMonth:m,currentPanel:c,setCurrentPanel:d,setDateInFocus:_,dateInFocus:f}};function wr(e){const t=Rt(e);return o.jsx(de,{...e,...t})}const Dr=()=>{const[e,t]=l.useState(),[r,n]=l.useState(),[a,s]=l.useState("startDate");return{startDate:e,setStartDate:t,endDate:r,setEndDate:n,focusedInput:a,setFocusedInput:s}},It=({onChange:e,value:t,statePerMonth:r,onChangePanel:n})=>{const{currentPanel:a,setCurrentPanel:s}=Te(n),[i,c]=l.useState(()=>t??new Date),d=l.useCallback(_=>{e&&e(_.date)},[e]),f=l.useMemo(()=>t?ae(r,t,["selected","singleSelected"]):r,[r,t]);return{onClickDay:d,statePerMonth:f,date:t,currentPanel:a,setCurrentPanel:s,dateInFocus:i,setDateInFocus:c}};function et(e){const t=It(e);return o.jsx(de,{...e,...t})}const Tt=({onChange:e,value:t,statePerMonth:r,onChangePanel:n,initialDateInFocus:a})=>{const{currentPanel:s,setCurrentPanel:i}=Te(n),[c,d]=l.useState(a??new Date),f=l.useCallback(p=>{if(!e)return;const m=t&&t.find(h=>u.isSameDay(h,p.date));e(t&&m?t.filter(h=>!u.isSameDay(h,p.date)):[...t||[],p.date])},[e,t]),_=l.useMemo(()=>t?t.reduce((p,m)=>ae(p,m,["selected"]),r):r,[r,t]);return{onClickDay:f,statePerMonth:_,currentPanel:s,setCurrentPanel:i,dateInFocus:c,setDateInFocus:d}};function kr(e){const t=Tt(e);return o.jsx(de,{...e,...t})}const Et=({onChange:e,value:t,statePerMonth:r,onChangePanel:n,locale:a=B.enGB})=>{const[s,i]=l.useState(()=>{const h=Pe(t,a);return h?h.days[0].date:new Date}),{currentPanel:c,setCurrentPanel:d}=Te(n),f=l.useCallback(h=>{e&&e(at(Ie(h.date,a)))},[a,e]),_=l.useCallback(h=>{e&&e(at(h))},[e]),p=l.useMemo(()=>{const h=Pe(t,a);return h?ft(r,h):r},[t,a,r]),m=l.useMemo(()=>{const h=Pe(t,a);return h?h.days[0].date:new Date},[a,t]);return{statePerMonth:p,date:m,dateInFocus:s,setDateInFocus:i,onClickDay:f,onClickWeek:_,currentPanel:c,setCurrentPanel:d}},at=e=>{if(e)return`${e.endYear}-${e.weekNumber}`},Pe=(e,t)=>{if(!e)return;const r=e.split("-"),n=parseInt(r[1],10),a=parseInt(r[0],10),s=new Date;s.setFullYear(a);const i=u.startOfWeek(u.setWeek(s,n),{locale:t});return Ie(i,t)};function Cr(e){const t=Et(e);return o.jsx(de,{...e,...t})}const xe="bottom",Sr=(e,t,r)=>{const[n,a]=l.useState(r||!1),s=l.useCallback(()=>(a(!0),!0),[a]),i=l.useCallback(()=>{a(!1),t&&t()},[a,t]),c=l.useCallback(d=>{e&&e(d),setTimeout(i,150)},[e,i]);return{showCalendar:s,hideCalendar:i,showingCalendar:n,onSelectDate:c}},we="2999-12-31",jr=({displayFormat:e=se.fullDate,placeholder:t="Enter date",value:r,calendarTheme:n=ie,calendarProps:a,openOnMount:s,onClose:i,onChange:c,variant:d,width:f,minDate:_,maxDate:p=we,disabled:m,portalTarget:h,zIndex:v})=>{const{hideCalendar:w,showingCalendar:C,onSelectDate:D,showCalendar:y}=Sr(c,i,s);return o.jsx(g.Box,{width:f,children:o.jsx(ye.ControlledPopover,{hideArrow:!0,open:C,onRequestClose:w,appendTo:h,zIndex:v,renderTrigger:x=>o.jsx(g.Box,{...x,children:o.jsx(te.TextInput,{type:"date",onFocus:y,buttonRight:o.jsx(k.TextInputButton,{onClick:y,icon:k.stenaCalendar}),value:r?u.format(r,e):"",placeholder:t,size:9,disabled:m,autoFocus:s,variant:d,min:_,max:p})}),placement:xe,children:o.jsx(et,{...a,onChange:D,value:r,theme:n,minDate:_,maxDate:p})})})},Mr=(e,t)=>{const r=l.useRef(null),n=l.useRef(null),[a,s]=l.useState(!1),[i,c]=l.useState(void 0),d=l.useCallback(()=>(c("startDate"),s(!0),!0),[c,s]),f=l.useCallback(()=>(c("endDate"),s(!0),!0),[c,s]),_=l.useCallback(()=>{s(!1)},[s]),p=l.useCallback(h=>{i==="startDate"?(t?.({startDate:h.date,endDate:e?.endDate}),e?.endDate?setTimeout(_,150):(c("endDate"),n.current?.focus())):i==="endDate"&&(t?.({startDate:e?.startDate,endDate:h.date}),e?.startDate?setTimeout(_,150):(c("startDate"),r.current?.focus()))},[i,t,c,_,e]),m=l.useMemo(()=>e?.startDate&&e?.endDate&&u.isAfter(e.startDate,e.endDate),[e?.startDate,e?.endDate]);return{showingCalendar:a,hideCalendar:_,showCalendarEndDate:f,showCalendarStartDate:d,focusedInput:i,setFocusedInput:c,startDateInputRef:r,endDateInputRef:n,onClickDay:p,startDateIsAfterEnd:m}};function Br({displayFormat:e=se.fullDate,placeholderStartDate:t="Start date",placeholderEndDate:r="End date",value:n,onValueChange:a,width:s,calendarTheme:i=ie,calendarProps:c,minDate:d,maxDate:f=we,disabled:_,portalTarget:p,zIndex:m}){const[h,v]=l.useState("calendar"),{hideCalendar:w,showCalendarEndDate:C,showCalendarStartDate:D,showingCalendar:y,focusedInput:x,startDateInputRef:b,endDateInputRef:S,onClickDay:T,startDateIsAfterEnd:R}=Mr(n,a),[N,j]=l.useState(()=>(x&&n?.[x])??new Date),M=l.useMemo(()=>_e(void 0,n?.startDate,n?.endDate),[n]);return o.jsx(ye.ControlledPopover,{hideArrow:!0,appendTo:p,zIndex:m,renderTrigger:F=>o.jsxs(g.Row,{alignItems:"center",...F,children:[o.jsx(te.TextInput,{iconLeft:k.stenaCalendar,onFocus:D,value:n?.startDate?u.format(n.startDate,e):"",placeholder:t,width:s,disabled:_,inputRef:b,size:9,variant:R?"error":void 0}),o.jsx(g.Space,{}),o.jsx(k.Icon,{icon:k.stenaArrowWideRight,color:Ve.cssColor("--lhds-color-ui-500"),size:14}),o.jsx(g.Space,{}),o.jsx(te.TextInput,{iconLeft:k.stenaCalendar,onFocus:C,value:n?.endDate?u.format(n.endDate,e):"",placeholder:r,width:s,disabled:_,inputRef:S,size:9,variant:R?"error":void 0})]}),open:y,placement:xe,onRequestClose:w,children:o.jsx(de,{...c,dateInFocus:N,setDateInFocus:j,statePerMonth:M,theme:i,onClickDay:T,currentPanel:h,setCurrentPanel:v,minDate:d,maxDate:f})})}const Rr=({calendarProps:e,closeOnCalendarSelectDate:t=!0,dateFormat:r=se.fullDate,disableCalender:n=!1,onValueChange:a,placeholder:s="yyyy-mm-dd",value:i,width:c="130px",calendarTheme:d=ie,hideCalenderIcon:f=!1,minDate:_,maxDate:p=we,variant:m,portalTarget:h,zIndex:v,...w})=>{const[C,D]=l.useState(!1),y=l.useCallback(()=>{D(!C)},[D,C]),x=l.useCallback(()=>{D(!1)},[D]),b=l.useCallback(M=>{a&&a(M)},[a]),S=l.useCallback(M=>{M&&(b(u.format(M,r)),t&&setTimeout(()=>D(!C),200))},[b,r,t,D,C]),T=!!i&&!/^[-/\\.0-9]+$/.test(i),R=!!i&&u.isValid(u.parse(i,r,new Date)),j=!!i&&i.length>=r.length&&!R||T;return o.jsx(g.Box,{width:c,children:o.jsx(ye.ControlledPopover,{appendTo:h,zIndex:v,renderTrigger:({ref:M,...F})=>o.jsx(te.TextInput,{...w,variant:j?"error":m,disableContentPaddingRight:!0,contentRight:f?void 0:o.jsx(g.Row,{alignItems:"center",indent:.5,children:o.jsx(k.FlatButton,{size:"small",disabled:w.disabled||n,leftIcon:k.stenaCalendar,onClick:y})}),onValueChange:b,placeholder:s,value:i||"",min:_,max:p,size:10,inputRef:M,...F}),hideArrow:!0,open:C,placement:xe,onRequestClose:x,children:o.jsx(et,{...e,onChange:S,value:i&&R?u.parse(i,r,new Date):void 0,minDate:_,maxDate:p,theme:d})})})},je=e=>{if(e==="")return"00";const t=parseInt(e,10);if(isNaN(t))throw new Error("Hours is not a number");if(t<0||t>23)throw new Error("Hours is an invalid number");switch(e.length){case 1:return`0${t}`;case 2:return e;default:throw new Error("Invalid hour string")}},Me=e=>{if(e==="")return"00";const t=parseInt(e,10);if(isNaN(t))throw new Error("Minutes is not a number");if(t<0||t>59)throw new Error("Minutes is an invalid number");switch(e.length){case 1:return`0${t}`;case 2:return e;default:throw new Error("Invalid minute string")}},Ir=e=>{if(!Ue(e))return{time:e,success:!1};const t=e&&e.split(/-|:|,|;|[/]|[.]| /);if(t&&t.length===2)try{const r=je(t[0]),n=Me(t[1]);return{time:`${r}:${n}`,success:!0}}catch{return{time:e,success:!1}}else if(t&&t.length===1){let r=0,n=0;switch(e.length){case 1:return{time:`0${e}:00`,success:!0};case 2:{const a=parseInt(t[0],10);return a>=0&&a<24?{time:`${e}:00`,success:!0}:a>=24&&a<59?{time:`00:${e}`,success:!0}:{time:e,success:!1}}case 3:return n=parseInt(e.substring(1,3),10),n>=0&&n<=59?{time:`0${e.substring(0,1)}:${e.substring(1,3)}`,success:!0}:{time:e,success:!1};case 4:return r=parseInt(e.substring(0,2),10),n=parseInt(e.substring(2,4),10),r<0||r>23?{time:e,success:!1}:n<0||n>59?{time:e,success:!1}:{time:`${e.substring(0,2)}:${e.substring(2,4)}`,success:!0};default:return{time:e,success:!1}}}return{time:e,success:!1}},Ue=e=>e?/^[-:.,/; 0-9]+$/.test(e):!0,Tr=({onValueChange:e,showPlaceholder:t=!0,useIcon:r=!0,value:n,width:a="85px",variant:s,...i})=>{const[c,d]=l.useState(()=>Ue(n)),f="hh:mm",_=l.useCallback(()=>{if(n){const m=Ir(n);d(m.success),m.success&&e&&e(m.time)}},[n,e,d]),p=l.useCallback(m=>{const h=m.target.value,v=Ue(h);d(v&&h.length<=f.length),e&&e(h)},[e,d]);return o.jsx(te.TextInput,{...i,type:"time",variant:c?s:"error",iconLeft:r?k.stenaClock:void 0,value:n,placeholder:t?f:void 0,onChange:p,onBlur:_,width:a})},Nt=({autoFocusLeft:e,autoFocusRight:t,onEsc:r,onEnter:n,onValueChangeLeft:a,onValueChangeRight:s,separatorIcon:i,placeholderLeft:c,placeholderRight:d,typeLeft:f,typeRight:_,onChangeLeft:p,onChangeRight:m,valueLeft:h,valueRight:v,minLeft:w,maxLeft:C,minRight:D,maxRight:y,onClickLeft:x,onClickRight:b,onClickCalendar:S,onClickArrowDown:T,onBlurLeft:R,onBlurRight:N,onFocusLeft:j,onFocusRight:M,inputRefLeft:F,inputRefRight:L,variant:E,variantLeft:U,variantRight:z,onBlur:$,showPresets:I,widthLeft:A,widthRight:O,disabled:P})=>{const W=l.useRef(0),H=l.useMemo(()=>le.debounce(Y=>{Y===0&&$?.()},10),[$]),V=l.useCallback(Y=>{W.current++,H(W.current),j&&j(Y)},[j,W,H]),Z=l.useCallback(Y=>{W.current++,H(W.current),M&&M(Y)},[M,W,H]),q=l.useCallback(Y=>{W.current--,H(W.current),R&&R(Y)},[R,W,H]),G=l.useCallback(Y=>{W.current--,H(W.current),N&&N(Y)},[N,W,H]);return o.jsx(g.Box,{children:o.jsxs(te.TextInputBox,{disableContentPaddingRight:!0,disabled:P,variant:E,contentRight:o.jsxs(g.Row,{alignItems:"center",children:[o.jsx(g.Indent,{num:.5,children:o.jsx(k.FlatButton,{leftIcon:k.stenaCalendar,onClick:S,disabled:P,size:"small"})}),I?o.jsxs(o.Fragment,{children:[o.jsx(g.Row,{height:"22px",children:o.jsx(g.SeparatorLine,{vertical:!0})}),o.jsx(g.Indent,{num:.5,children:o.jsx(k.FlatButton,{leftIcon:k.stenaAngleDown,onClick:T,disabled:P,size:"small"})})]}):null]}),children:[o.jsx(g.Box,{width:A,children:o.jsx(te.TextInput,{onEsc:r,onEnter:n,onClick:x,disabled:P,hideBorder:!0,placeholder:c,value:h,onValueChange:a,onChange:p,onBlur:q,onFocus:V,inputRef:F,variant:U,type:f,autoFocus:e,min:w,max:C})}),o.jsx(g.Row,{indent:.5,alignItems:"center",justifyContent:"center",children:o.jsx(k.Icon,{icon:i,size:12,color:Ve.cssColor("--lhds-color-ui-500")})}),o.jsx(g.Box,{width:O,children:o.jsx(te.TextInput,{onEsc:r,onEnter:n,onClick:b,disabled:P,hideBorder:!0,placeholder:d,value:v,onValueChange:s,onChange:m,onBlur:G,onFocus:Z,inputRef:L,variant:z,type:_,autoFocus:t,min:D,max:y})})]})})},Er=e=>{if(e==null)throw new Error("Time is not set.");if(e==="")throw new Error("Time is empty.");const t=e.split(":");if(t.length!==2)throw new Error("Invalid time.");if(t[1].length!==2)throw new Error("Invalid time.");if(t[0].length<1||t[0].length>2)throw new Error("Invalid time.");const r=parseInt(t[0],10),n=parseInt(t[1],10);if(isNaN(r))throw new Error("Invalid time.");if(isNaN(n))throw new Error("Invalid time.");if(r<0||r>23)throw new Error("Invalid time.");if(n<0||n>59)throw new Error("Invalid time.");return r*100+n},Nr=e=>{try{return Er(e),!0}catch{return!1}},Ce=e=>{if(e&&Nr(e)){const t=e.split(":");return{hour:g.parseIntElseUndefined(t[0]),minute:g.parseIntElseUndefined(t[1])}}return{hour:void 0,minute:void 0}},Fr=e=>`${je(String(e.getHours()))}:${Me(String(e.getMinutes()))}`,Lr="_timePicker_1w05d_1",Ar="_timePickerColumn_1w05d_6",Ft={timePicker:Lr,timePickerColumn:Ar},Pr=({onClick:e,item:t,selected:r,columnRef:n,canScrollRef:a})=>{const s=l.useRef(null);return l.useEffect(function(){if(r&&n.current&&s.current&&a.current){const c=s.current.scrollHeight*Math.max(t-2,0);n.current.scrollTo(0,c),a.current=!1}},[n,t,r,a]),o.jsx(g.Row,{width:"64px",justifyContent:"center",spacing:.5,indent:.5,ref:s,children:r?o.jsx(k.PrimaryButton,{label:le.padStart(String(t),2,"0"),onClick:()=>e&&e(t)}):o.jsx(k.FlatButton,{label:String(t).padStart(2,"0"),onClick:()=>e&&e(t)})})},st=({onClick:e,items:t,selectedItem:r,canScrollRef:n})=>{const a=l.useRef(null);return o.jsx(g.Column,{className:Ft.timePickerColumn,ref:a,children:t.map(s=>o.jsx(Pr,{item:s,onClick:e,selected:s===r,columnRef:a,canScrollRef:n},s))})},Wr=le.range(0,24),Hr=le.range(0,60),Or=({value:e,onValueChange:t})=>{const r=l.useRef(!0),[n,a]=l.useState(void 0),[s,i]=l.useState(void 0);l.useEffect(()=>{if(e){const{minute:f,hour:_}=Ce(e);a(_),i(f)}},[e]);const c=l.useCallback(f=>{a(f),t?.(`${je(String(f??0))}:${Me(String(s??0))}`)},[s,t]),d=l.useCallback(f=>{i(f),t?.(`${je(String(n??0))}:${Me(String(f??0))}`)},[n,t]);return o.jsxs(g.Row,{className:Ft.timePicker,children:[o.jsx(st,{items:Wr,onClick:c,selectedItem:n,canScrollRef:r}),o.jsx(g.Indent,{}),o.jsx(st,{items:Hr,onClick:d,selectedItem:s,canScrollRef:r})]})},Yr=(e,t,r)=>{l.useEffect(function(){e&&t(e)},[e,t]),l.useEffect(function(){r.current&&(e?r.current.valueAsDate=new Date(Date.UTC(e.getFullYear(),e.getMonth(),e.getDate())):r.current.valueAsDate=null)},[e,r])},Ur=(e,t,{setDateInFocus:r,showCalendarInternal:n,hideCalendarInternal:a,setFirstFocusedInput:s,setCurrentPanel:i,localTime:c,setLocalTime:d,localDate:f,setLocalDate:_},p)=>{const m=l.useCallback(y=>{if(!y)return;const x=new Date(y);if(e)x.setHours(e.getHours()),x.setMinutes(e.getMinutes()),t?.(x),_(void 0);else if(c){const{minute:b,hour:S}=Ce(c);x.setHours(S??0),x.setMinutes(b??0),t?.(x),_(void 0)}else _(x);r(x),p.current&&(p.current.valueAsDate=new Date(Date.UTC(x.getFullYear(),x.getMonth(),x.getDate())))},[e,p,c,t,r,_]),h=l.useCallback(y=>{if(y)if(e){const x=Ce(y),b=new Date(e);b.setHours(x.hour||0),b.setMinutes(x.minute||0),t?.(b),d(void 0)}else if(f){const x=Ce(y),b=new Date(f);b.setHours(x.hour||0),b.setMinutes(x.minute||0),t?.(b),d(void 0)}else d(y)},[t,e,f,d]),v=l.useCallback(y=>{y.target.value[0]!=="0"&&m(y.target.valueAsDate)},[m]),w=l.useCallback(y=>h(y.target.value),[h]),C=l.useCallback(()=>{r(e||new Date),i("calendar"),n()},[e,i,n,r]),D=l.useCallback(()=>{s(void 0),a()},[s,a]);return{inputLeftChangeHandler:v,inputRightChangeHandler:w,hideCalendar:D,showCalendar:C,onChangeTime:h,onChangeDate:m}},zr=e=>{const[t,r]=l.useState(void 0),[n,a]=l.useState(void 0),[s,i,c]=g.useBoolean(!1),[d,f,_]=g.useBoolean(!1),[p,m]=l.useState(void 0),[h,v]=l.useState(()=>e??new Date),[w,C]=l.useState("calendar");return{isCalendarVisible:s,showCalendarInternal:i,hideCalendarInternal:c,firstFocusedInput:p,setFirstFocusedInput:m,dateInFocus:h,setDateInFocus:v,currentPanel:w,setCurrentPanel:C,isTimePickerVisible:d,showTimePicker:f,hideTimePicker:_,localDate:t,setLocalDate:r,localTime:n,setLocalTime:a}},$r=(e,t,r,n,{isCalendarVisible:a,setCurrentPanel:s,showTimePicker:i,hideTimePicker:c})=>{const d=l.useCallback(()=>{a||r(),s("calendar"),c()},[c,a,s,r]),f=l.useCallback(()=>{n(),i()},[n,i]),_=l.useCallback(v=>{e(v.date),n(),i()},[e,n,i]),p=l.useCallback(()=>{s("presets"),r()},[s,r]),m=l.useCallback(()=>{a?n():(t.current?.focus(),s("calendar"),r())},[a,n,t,s,r]),h=l.useCallback(v=>{v.key==="Escape"&&n()},[n]);return{onFocusLeft:d,onFocusRight:f,onClickDay:_,onClickArrowButton:p,onClickCalendarButton:m,onKeyDownHandler:h}},Vr=({value:e,onValueChange:t,onEnter:r,onEsc:n,onBlur:a,autoFocus:s,minDate:i,widthLeft:c=128,widthRight:d=80,maxDate:f=we,variant:_,disabled:p,zIndex:m,appendTo:h})=>{const v=l.useRef(null),w=l.useRef(null),C=zr(e),{setCurrentPanel:D,currentPanel:y,isCalendarVisible:x,dateInFocus:b,setDateInFocus:S,isTimePickerVisible:T,hideTimePicker:R,localTime:N,localDate:j}=C,{showCalendar:M,hideCalendar:F,inputLeftChangeHandler:L,inputRightChangeHandler:E,onChangeTime:U,onChangeDate:z}=Ur(e,t,C,v),{onKeyDownHandler:$,onFocusRight:I,onFocusLeft:A,onClickDay:O,onClickCalendarButton:P,onClickArrowButton:W}=$r(z,v,M,F,C);Yr(e,S,v);const H=l.useMemo(()=>{const Y=e||j;return Y?ae(void 0,Y,["singleSelected","selected"]):{}},[j,e]),V=l.useCallback(()=>{F(),R()},[F,R]),Z=l.useMemo(()=>e?Fr(e):N,[e,N]),q=g.useDelayedFalse(x,300),G=g.useDelayedFalse(T,300);return o.jsx(g.Box,{onKeyDown:$,children:o.jsx(ye.ControlledPopover,{hideArrow:!0,zIndex:m,appendTo:h,renderTrigger:Y=>o.jsx(g.Box,{...Y,children:o.jsx(Nt,{autoFocusLeft:s,onEsc:n,onEnter:r,onBlur:a,disabled:p,separatorIcon:k.stenaClock,typeLeft:"date",typeRight:"time",placeholderLeft:"yyyy-mm-dd",placeholderRight:"hh:mm",onChangeLeft:L,onChangeRight:E,onClickArrowDown:W,onClickCalendar:P,onFocusLeft:A,onFocusRight:I,onClickLeft:A,onClickRight:I,inputRefLeft:v,inputRefRight:w,valueRight:Z??"",widthLeft:c,widthRight:d,minLeft:i,maxLeft:f,variant:_})}),placement:xe,open:x||T,onRequestClose:V,children:(q||G)&&o.jsx(g.Column,{children:q?o.jsx(de,{statePerMonth:H,onClickDay:O,dateInFocus:b,setDateInFocus:S,currentPanel:y,setCurrentPanel:D,minDate:i,maxDate:f}):G?o.jsxs(g.Column,{children:[o.jsx(g.Column,{overflow:"hidden",height:"250px",children:o.jsx(Or,{value:Z??"",onValueChange:U})}),o.jsx(g.Space,{}),o.jsx(g.Row,{justifyContent:"flex-end",children:o.jsx(k.PrimaryButton,{label:"Done",onClick:R})})]}):null})})})},qr=({value:e,onValueChange:t,year:r})=>{const n=String(r);return o.jsx(g.Row,{justifyContent:"center",children:e===r?o.jsx(k.PrimaryButton,{label:n,onClick:()=>t?.(r)}):o.jsx(k.FlatButton,{label:n,onClick:()=>t?.(r)})})},Kr=({value:e,onValueChange:t,initialLastYear:r})=>{const[n,a]=l.useState(()=>e?e+4:r??new Date().getFullYear()+4),s=l.useMemo(()=>{const i=n-11;return le.chunk(le.range(i,n+1),3)},[n]);return l.useEffect(()=>{a(i=>Gr(e,i))},[e]),o.jsxs(g.Row,{children:[o.jsx(g.Column,{justifyContent:"center",children:o.jsx(k.FlatButton,{leftIcon:k.stenaArrowLeft,onClick:()=>a(n-3)})}),o.jsx(g.Column,{gap:1,children:s.map(i=>o.jsx(g.Row,{gap:1,children:i.map(c=>o.jsx(qr,{year:c,onValueChange:t,value:e},c))},i[0]))}),o.jsx(g.Column,{justifyContent:"center",children:o.jsx(k.FlatButton,{leftIcon:k.stenaArrowRight,onClick:()=>a(n+3)})})]})},Gr=(e,t)=>{if(e==null)return t;if(e>t){const n=e-t,a=n%3,s=n-a+3;return t+s}const r=t-11;if(e<r){const n=r-e,a=n%3,s=n-a+3;return t-s}return t},Jr=(e,t,r,n,a)=>{l.useEffect(function(){e&&r(e)},[e,r]),l.useEffect(function(){t&&r(t)},[t,r]),l.useEffect(function(){n.current&&(e?n.current.valueAsDate=new Date(Date.UTC(e.getFullYear(),e.getMonth(),e.getDate())):n.current.valueAsDate=null)},[e,n]),l.useEffect(function(){a.current&&(t?a.current.valueAsDate=new Date(Date.UTC(t.getFullYear(),t.getMonth(),t.getDate())):a.current.valueAsDate=null)},[t,a])},Qr=(e,t,r,{setDateInFocus:n,showCalendarInternal:a,hideCalendarInternal:s,setFirstFocusedInput:i,setCurrentPanel:c})=>{const d=l.useCallback(m=>{m.target.value[0]!=="0"&&r?.({startDate:m.target.valueAsDate??void 0,endDate:t})},[r,t]),f=l.useCallback(m=>{m.target.value[0]!=="0"&&r?.({startDate:e,endDate:m.target.valueAsDate??void 0})},[r,e]),_=l.useCallback(m=>{m!=null?n(m):n(e||t||new Date),c("calendar"),a()},[e,t,c,a,n]),p=l.useCallback(()=>{i(void 0),s()},[i,s]);return{inputLeftChangeHandler:d,inputRightChangeHandler:f,hideCalendar:p,setDateInFocus:n,setCurrentPanel:c,showCalendar:_}},Zr=(e,t)=>{const[r,n,a]=g.useBoolean(!1),[s,i]=l.useState(void 0),[c,d]=l.useState("startDate"),[f,_]=l.useState(()=>(c==="startDate"?e:c==="endDate"?t:void 0)??new Date),[p,m]=l.useState("calendar");return{isCalendarVisible:r,showCalendarInternal:n,hideCalendarInternal:a,firstFocusedInput:s,setFirstFocusedInput:i,focusedInput:c,setFocusedInput:d,dateInFocus:f,setDateInFocus:_,currentPanel:p,setCurrentPanel:m}},Xr=(e,t,r,n,a,s,i,{firstFocusedInput:c,setFirstFocusedInput:d,isCalendarVisible:f,setFocusedInput:_,focusedInput:p,setCurrentPanel:m,setDateInFocus:h})=>{const v=l.useCallback(()=>{c==null&&d("startDate"),_("startDate"),f?e!=null&&h(e):s(e)},[c,_,f,e,d,s,h]),w=l.useCallback(()=>{c==null&&d("endDate"),_("endDate"),f?t!=null&&h(t):s(t)},[c,_,f,t,d,s,h]),C=l.useCallback(b=>{p==="startDate"?t!=null&&u.isAfter(b.date,t)?(r?.({startDate:b.date,endDate:void 0}),_("endDate"),a.current?.focus()):(r?.({startDate:b.date,endDate:t}),c==="startDate"?(_("endDate"),a.current?.focus()):setTimeout(i,50)):p==="endDate"&&(e?u.isAfter(e,b.date)?(r?.({startDate:b.date,endDate:void 0}),_("endDate"),a.current?.focus()):(r?.({startDate:e,endDate:b.date}),setTimeout(i,50)):(r?.({startDate:e,endDate:b.date}),_("startDate"),n.current?.focus()))},[p,r,t,c,_,a,i,e,n]),D=l.useCallback(()=>{m("presets"),s()},[m,s]),y=l.useCallback(()=>{f?i():(_("startDate"),d("startDate"),n.current?.focus(),m("calendar"),s())},[f,i,_,d,n,m,s]),x=l.useCallback(b=>{b.key==="Escape"&&i()},[i]);return{onFocusLeft:v,onFocusRight:w,onClickDay:C,onClickArrowButton:D,onClickCalendarButton:y,onKeyDownHandler:x}};function en({value:e,onValueChange:t,autoFocus:r,onBlur:n,onEnter:a,onEsc:s,minDate:i,maxDate:c=we,calendarProps:d,widthLeft:f=128,widthRight:_=128,firstMonthInMonthPicker:p,numMonthsInMonthPicker:m,variant:h,disabled:v,zIndex:w,appendTo:C,renderBelowCalendar:D}){const{startDate:y,endDate:x}=e||{},b=l.useRef(null),S=l.useRef(null),T=Zr(y,x),{dateInFocus:R,setDateInFocus:N,isCalendarVisible:j,currentPanel:M,setCurrentPanel:F}=T,{showCalendar:L,hideCalendar:E,inputLeftChangeHandler:U,inputRightChangeHandler:z}=Qr(y,x,t,T),{onKeyDownHandler:$,onFocusRight:I,onFocusLeft:A,onClickDay:O,onClickCalendarButton:P,onClickArrowButton:W}=Xr(y,x,t,b,S,L,E,T);Jr(y,x,N,b,S);const H=l.useMemo(()=>y&&x&&u.isAfter(y,x),[y,x]),V=l.useMemo(()=>ut(d?.statePerMonth,y,x,R),[d?.statePerMonth,y,x,R]);return o.jsx(g.Box,{onKeyDown:$,children:o.jsx(ye.ControlledPopover,{hideArrow:!0,restoreFocus:!1,returnFocus:!1,zIndex:w,appendTo:C,renderTrigger:Z=>o.jsx(g.Box,{...Z,children:o.jsx(Nt,{autoFocusLeft:r,onEsc:s,onEnter:a,onBlur:n,disabled:v,separatorIcon:k.stenaArrowRight,typeLeft:"date",typeRight:"date",placeholderLeft:"Start date",placeholderRight:"End date",onChangeLeft:U,onChangeRight:z,onClickArrowDown:W,onClickCalendar:P,onFocusLeft:A,onFocusRight:I,onClickLeft:A,onClickRight:I,inputRefLeft:b,inputRefRight:S,variant:H?"error":h,widthLeft:f,widthRight:_,minLeft:i,maxLeft:c,minRight:i,maxRight:c})}),placement:xe,onRequestClose:E,open:j,children:o.jsxs(g.Column,{children:[o.jsx(de,{onClickDay:O,dateInFocus:R,firstMonthInMonthPicker:p,numMonthsInMonthPicker:m,setDateInFocus:N,currentPanel:M,setCurrentPanel:F,minDate:i,maxDate:c,...d,statePerMonth:V}),M==="calendar"&&D]})})})}const ze=({onChange:e,onValueChange:t,readOnly:r,mask:n,ref:a,pipe:s,value:i,guide:c,keepCharPositions:d,placeholderChar:f,showMask:_,calendarSize:p,onFocus:m,onBlur:h,placeholderWhenBlurred:v,placeholder:w,valueWhenBlurred:C,label:D,variant:y,...x})=>{const b=l.useRef(null),[S,T]=l.useState(!1),R=a??b,{onChange:N}=zt.useMaskedInput(R,e,t,n,s,i,c,d,f,_,S),j=l.useCallback(L=>{m?.(L),T(!0)},[m]),M=l.useCallback(L=>{h?.(L),T(!1)},[h]),F=S?w:v??w;return y==="standard"?o.jsx(k.Label,{text:D??"",children:o.jsx(te.TextInput,{...x,readOnly:r,inputMode:"numeric","aria-live":"polite",value:(S?i:C)??"",inputRef:R,placeholder:F,onFocus:j,onBlur:M,onChange:N,width:ot(p),alwaysShowPlaceholder:!0})}):o.jsx(te.LabelledTextInput,{...x,readOnly:r,inputMode:"numeric",label:D,"aria-live":"polite",value:(S?i:C)??"",ref:R,placeholder:F,onFocus:j,onBlur:M,onChange:N,width:ot(p),size:p==="large"?"large":"medium"})},ot=e=>{switch(e){case"smaller":return"140px";case"small":return"154px";case"medium":return"168px";case"large":return"196px";default:return g.exhaustSwitchCase(e,"168px")}},tn=[/[1-2]/,/\d/,/\d/,/\d/],rn=[/[0-1]/,/\d/],nn=[/[0-3]/,/\d/],Lt=e=>sn(e).flatMap(an),an=e=>{switch(e){case"yyyy":return tn;case"mm":case"MM":return rn;case"dd":case"DD":return nn;default:return[e]}},sn=e=>{if(e.length===0)return[];const t=[];let r=e[0];for(let n=1;n<e.length;n++)e[n]!==e[n-1]?(t.push(r),r=e[n]):r+=e[n];return t.push(r),t},fe=e=>{const r=new Intl.DateTimeFormat(e,{dateStyle:"short"}).formatToParts(new Date),n={year:"yyyy",month:"MM",day:"dd"};return r.map(a=>n[a.type]||a.value).join("")},X=(e,t,r)=>{const n=Qe(t,r?.matchLanguage??!1,r?.fallbackLocaleCode??Je),a=ue(n);if(a==null)return;const s=u.parse(e,fe(n),r?.referenceDate??new Date,{locale:a});if(!isNaN(s.getTime()))return s},oe=(e,t,r)=>{const n=Qe(t,r?.matchLanguage??!1,r?.fallbackLocaleCode??Je);return u.format(e,fe(n),{locale:ue(n)})},Be=(e,t)=>{const r=X(e,t);if(r!=null)return oe(r,t)};(function(){try{if(typeof document<"u"){var e=document.createElement("style");e.appendChild(document.createTextNode("._navBar_kzibd_1{--swui-navbar-background-color: var(--lhds-color-ui-50);--swui-navbar-item-background-color-hover: var(--lhds-color-blue-700);--swui-navbar-item-background-color-selected: var(--lhds-color-blue-600);--swui-navbar-item-background-color-selected-hover: var( --lhds-color-blue-700 );--swui-nav-bar-height: 48px;background-color:var(--swui-navbar-background-color);height:var(--swui-nav-bar-height);min-height:var(--swui-nav-bar-height)}._navBarButton_b3x3w_1:hover{background:var(--lhds-color-ui-100)}._navBarButton_b3x3w_1:focus-visible{background:var(--lhds-color-ui-200)}._navBarButton_b3x3w_1:active{background:var(--lhds-color-ui-200)}._navBarButton_b3x3w_1._selected_b3x3w_14{background:var(--lhds-color-blue-200)}._navBarButton_b3x3w_1._selected_b3x3w_14:hover{background:var(--lhds-color-blue-100)}._navBarButton_b3x3w_1._selected_b3x3w_14:focus-visible{background:var(--lhds-color-blue-300)}._navBarButton_b3x3w_1._selected_b3x3w_14:active{background:var(--lhds-color-blue-200)}._navBarNotificationButton_1wt3y_1{--current-background-color: var(--lhds-color-ui-400);--current-outline-color: var(--modern-blue);background-color:var(--current-background-color);border-color:transparent;color:var(--lhds-color-ui-50);--swui-nav-bar-notification-shake-count: 3;transition:.5s width}._navBarNotificationButton_1wt3y_1:hover{--current-background-color: var(--lhds-color-red-500);--current-outline-color: var(--lhds-color-red-500)}._navBarNotificationButton_1wt3y_1:active{--current-background-color: var(--lhds-color-red-600);--current-outline-color: var(--lhds-color-red-600)}._navBarNotificationButton_1wt3y_1._unread_1wt3y_23 ._icon_1wt3y_23{transform-origin:top center;animation:_shake_1wt3y_1 1.5s ease-in-out var(--swui-nav-bar-notification-shake-count)}._navBarNotificationButton_1wt3y_1._unread_1wt3y_23{--current-background-color: var(--lhds-color-red-500);--current-outline-color: var(--lhds-color-red-500)}._navBarNotificationButton_1wt3y_1._unread_1wt3y_23:hover{--current-background-color: var(--lhds-color-red-600);--current-outline-color: var(--lhds-color-red-600)}._navBarNotificationButton_1wt3y_1._unread_1wt3y_23:active{--current-background-color: var(--lhds-color-red-700);--current-outline-color: var(--lhds-color-red-700)}._navBarNotificationButton_1wt3y_1:focus-visible{outline:var(--swui-focus-outline);outline-color:var(--current-outline-color);outline-offset:var(--swui-focus-outline-width)}@keyframes _shake_1wt3y_1{0%{transform:rotate(0)}7%{transform:rotate(20deg)}15%{transform:rotate(-20deg)}22%{transform:rotate(16deg)}30%{transform:rotate(-16deg)}38%{transform:rotate(6deg)}42%{transform:rotate(-6deg)}46%{transform:rotate(2deg)}to{transform:rotate(0)}}._navBarSearchFieldInput_1rp8g_1._navBarSearchFieldInput_1rp8g_1{line-height:2.7rem;color:var(--lhds-color-ui-800)}._navBarSearchFieldInput_1rp8g_1._navBarSearchFieldInput_1rp8g_1::placeholder{color:var(--lhds-color-blue-600)}._navBarSearchFieldInput_1rp8g_1._navBarSearchFieldInput_1rp8g_1{padding:0 var(--swui-metrics-indent)}._navBarSearchFieldWrapper_1rp8g_12._navBarSearchFieldWrapper_1rp8g_12{background:var(--lhds-color-ui-200);border-color:transparent}._navBarSearchFieldWrapper_1rp8g_12._navBarSearchFieldWrapper_1rp8g_12:hover{border-color:transparent}._navBarSearchFieldWrapper_1rp8g_12._navBarSearchFieldWrapper_1rp8g_12{padding:0 var(--swui-metrics-indent);border-radius:var(--swui-max-border-radius)}._navBarSearchFieldWrapper_1rp8g_12._navBarSearchFieldWrapper_1rp8g_12._withButton_1rp8g_24{padding-right:1px}._navBarSearchFieldWrapper_1rp8g_12._navBarSearchFieldWrapper_1rp8g_12:focus-within{color:var(--lhds-color-ui-800);background:var(--lhds-color-ui-50)}._navBarSearchFieldWrapper_1rp8g_12._navBarSearchFieldWrapper_1rp8g_12 ._clearButton_1rp8g_33{border-radius:var(--swui-max-border-radius)}._navBarUserButton_10f9z_1:hover{background:var(--lhds-color-ui-100)}._navBarUserButton_10f9z_1:focus-visible{background:var(--lhds-color-ui-200)}._navBarUserButton_10f9z_1:active{background:var(--lhds-color-ui-200)}._sidebarMenuCollapsibleGroupBox_ikek9_1{background:var(--lhds-color-ui-200);border-radius:var(--swui-border-radius);gap:var(--swui-metrics-space);display:flex;flex-direction:column;padding:var(--swui-metrics-space);--current-text-size: var(--swui-font-size-small)}._selectionRow_1njaw_1{display:flex;flex-direction:row;justify-content:space-between;align-items:center;gap:calc(var(--swui-metrics-space) * 2)}@media (max-width: 370px){._iconColumn_1njaw_9{display:none}}._sidebarMenu_1bx5w_1{--swui-sidebar-menu-separator-color: var(--swui-white);--swui-sidebar-menu-text-color: var(--lhds-color-ui-900);--swui-sidebar-menu-icon-color: var(--lhds-color-ui-900);--swui-sidebar-menu-background-color: transparent;--swui-sidebar-menu-background-color-hover: var(--lhds-color-ui-400);--swui-sidebar-menu-background-color-focus: var(--lhds-color-ui-400);--swui-sidebar-menu-background-color-active: var(--lhds-color-ui-300);--swui-sidebar-menu-background-selected: var(--lhds-color-blue-100);--swui-sidebar-menu-background-selected-hover: var(--lhds-color-blue-200);--swui-sidebar-menu-background-selected-focus: var(--lhds-color-blue-200);--swui-sidebar-menu-background-selected-active: var(--lhds-color-blue-100);--current-background-color: var(--swui-sidebar-menu-background-color);--current-background-color-hover: var( --swui-sidebar-menu-background-color-hover );--current-background-color-focus: var( --swui-sidebar-menu-background-color-focus );--current-background-color-active: var( --swui-sidebar-menu-background-color-active );--current-background-selected: var(--swui-sidebar-menu-background-selected);--current-background-selected-hover: var( --swui-sidebar-menu-background-selected-hover );--current-background-selected-focus: var( --swui-sidebar-menu-background-selected-focus );--current-background-selected-active: var( --swui-sidebar-menu-background-selected-active )}._sidebarMenu_1bx5w_1 ._sidebarItems_1bx5w_38{--current-separator-color: var(--swui-sidebar-menu-separator-color);--current-text-color: var(--swui-sidebar-menu-text-color);--current-icon-color: var(--swui-sidebar-menu-icon-color)}._sidebarMenu_1bx5w_1{background-color:var(--current-background-color);height:100dvh}._sidebarMenu_1bx5w_1 ._scrollContainer_1bx5w_48{background:var(--current-background-color);height:100%;overflow:auto}._stenaFlag_108h7_1{height:32px}._productCard_19x6b_1{max-width:560px}@media (max-width: 768px){._productCard_19x6b_1{max-width:unset}}.yarl__fullsize{height:100%;width:100%}.yarl__relative{position:relative}.yarl__portal{inset:0;opacity:0;overflow:hidden;position:fixed;transition:opacity var(--yarl__fade_animation_duration,.25s) var(--yarl__fade_animation_timing_function,ease);z-index:var(--yarl__portal_zindex,9999)}.yarl__portal_open{opacity:1}.yarl__container{background-color:var(--yarl__container_background_color,var(--yarl__color_backdrop,#000));inset:0;outline:none;overflow:hidden;overscroll-behavior:var(--yarl__controller_overscroll_behavior,contain);position:absolute;touch-action:var(--yarl__controller_touch_action,none);-webkit-user-select:none;user-select:none}.yarl__carousel{align-content:center;align-items:stretch;display:flex;flex:0 0 auto;height:100%;justify-content:center;opacity:var(--yarl__pull_opacity,1);transform:translate(var(--yarl__swipe_offset,0),var(--yarl__pull_offset,0));width:calc(100% + (var(--yarl__carousel_slides_count) - 1)*(100% + var(--yarl__carousel_spacing_px, 0)*1px + var(--yarl__carousel_spacing_percent, 0)*1%))}.yarl__carousel_with_slides{column-gap:calc(var(--yarl__carousel_spacing_px, 0)*1px + 100/(var(--yarl__carousel_slides_count)*100 + (var(--yarl__carousel_slides_count) - 1)*var(--yarl__carousel_spacing_percent, 0))*var(--yarl__carousel_spacing_percent, 0)*1%)}.yarl__flex_center{align-content:center;align-items:center;display:flex;justify-content:center}.yarl__slide{flex:1;overflow:hidden;padding:calc(var(--yarl__carousel_padding_px, 0)*1px + 100/(var(--yarl__carousel_slides_count)*100 + (var(--yarl__carousel_slides_count) - 1)*var(--yarl__carousel_spacing_percent, 0))*var(--yarl__carousel_padding_percent, 0)*1%);position:relative}[dir=rtl] .yarl__slide{--yarl__direction:-1}.yarl__slide_image{max-height:100%;max-width:100%;object-fit:contain;touch-action:var(--yarl__controller_touch_action,none);user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.yarl__slide_image_cover{height:100%;object-fit:cover;width:100%}.yarl__slide_image_loading{opacity:0}@media screen and (min-width:800px){.yarl__slide_wrapper:not(.yarl__slide_wrapper_interactive) .yarl__slide_image{-webkit-backface-visibility:hidden;-webkit-transform:translateZ(0);-webkit-transform-style:preserve-3d}}.yarl__slide_placeholder{left:50%;line-height:0;position:absolute;top:50%;transform:translate(-50%) translateY(-50%)}.yarl__slide_loading{animation:yarl__delayed_fadein 1s linear;color:var(--yarl__slide_icon_loading_color,var(--yarl__color_button,hsla(0,0%,100%,.8)))}.yarl__slide_loading line{animation:yarl__stroke_opacity 1s linear infinite}.yarl__slide_loading line:first-of-type{animation-delay:-1.875s}.yarl__slide_loading line:nth-of-type(2){animation-delay:-1.75s}.yarl__slide_loading line:nth-of-type(3){animation-delay:-1.625s}.yarl__slide_loading line:nth-of-type(4){animation-delay:-1.5s}.yarl__slide_loading line:nth-of-type(5){animation-delay:-1.375s}.yarl__slide_loading line:nth-of-type(6){animation-delay:-1.25s}.yarl__slide_loading line:nth-of-type(7){animation-delay:-1.125s}.yarl__slide_loading line:nth-of-type(8){animation-delay:-1s}.yarl__slide_error{color:var(--yarl__slide_icon_error_color,red);height:var(--yarl__slide_icon_error_size,48px);width:var(--yarl__slide_icon_error_size,48px)}@media (prefers-reduced-motion){.yarl__portal,.yarl__slide{transition:unset}.yarl__slide_loading,.yarl__slide_loading line{animation:unset}}.yarl__toolbar{display:flex;justify-content:flex-end;inset:0 0 auto auto;padding:var(--yarl__toolbar_padding,8px);position:absolute}[dir=rtl] .yarl__toolbar{inset:0 auto auto 0}.yarl__icon{height:var(--yarl__icon_size,32px);width:var(--yarl__icon_size,32px)}.yarl__button{-webkit-appearance:none;appearance:none;background-color:var(--yarl__button_background_color,transparent);border:var(--yarl__button_border,0);color:var(--yarl__color_button,hsla(0,0%,100%,.8));cursor:pointer;filter:var(--yarl__button_filter,drop-shadow(2px 2px 2px rgba(0,0,0,.8)));line-height:0;margin:var(--yarl__button_margin,0);outline:none;padding:var(--yarl__button_padding,8px);-webkit-tap-highlight-color:transparent}.yarl__button:focus{color:var(--yarl__color_button_active,#fff)}.yarl__button:focus:not(:focus-visible){color:var(--yarl__color_button,hsla(0,0%,100%,.8))}.yarl__button:focus-visible{color:var(--yarl__color_button_active,#fff)}@media (hover:hover){.yarl__button:focus-visible:hover,.yarl__button:focus:hover,.yarl__button:hover{color:var(--yarl__color_button_active,#fff)}}.yarl__button:disabled{color:var(--yarl__color_button_disabled,hsla(0,0%,100%,.4));cursor:default}.yarl__navigation_next,.yarl__navigation_prev{padding:var(--yarl__navigation_button_padding,24px 16px);position:absolute;top:50%;transform:translateY(-50%)}.yarl__navigation_prev{left:0}[dir=rtl] .yarl__navigation_prev{left:unset;right:0;transform:translateY(-50%) rotate(180deg)}.yarl__navigation_next{right:0}[dir=rtl] .yarl__navigation_next{left:0;right:unset;transform:translateY(-50%) rotate(180deg)}.yarl__no_scroll{height:100%;overflow:hidden;overscroll-behavior:none}@keyframes yarl__delayed_fadein{0%{opacity:0}80%{opacity:0}to{opacity:1}}@keyframes yarl__stroke_opacity{0%{stroke-opacity:1}to{stroke-opacity:.125}}.yarl__counter{bottom:var(--yarl__counter_bottom,unset);color:var(--yarl__counter_color,var(--yarl__color_button,hsla(0,0%,100%,.8)));filter:var(--yarl__counter_filter,drop-shadow(2px 2px 2px rgba(0,0,0,.8)));left:var(--yarl__counter_left,0);line-height:var(--yarl__counter_line_height,var(--yarl__icon_size,32px));margin:var(--yarl__counter_margin,var(--yarl__toolbar_padding,8px));padding:var(--yarl__counter_padding,var(--yarl__button_padding,8px));position:var(--yarl__counter_position,absolute);right:var(--yarl__counter_right,unset);top:var(--yarl__counter_top,0);-webkit-user-select:var(--yarl__counter_user_select,none);user-select:var(--yarl__counter_user_select,none)}.yarl__slide_captions_container{background:var(--yarl__slide_captions_container_background,rgba(0,0,0,.5));left:var(--yarl__slide_captions_container_left,0);padding:var(--yarl__slide_captions_container_padding,16px);position:absolute;right:var(--yarl__slide_captions_container_right,0);-webkit-transform:translateZ(0)}.yarl__slide_title{color:var(--yarl__slide_title_color,#fff);font-size:var(--yarl__slide_title_font_size,125%);font-weight:var(--yarl__slide_title_font_weight,bolder);max-width:calc(100% - var(--yarl__toolbar_width, 0px));overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.yarl__slide_title_container{top:var(--yarl__slide_title_container_top,0)}.yarl__slide_description{display:-webkit-box;-webkit-hyphens:auto;hyphens:auto;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:var(--yarl__slide_description_max_lines,3);color:var(--yarl__slide_description_color,#fff);text-align:var(--yarl__slide_description_text_align,start)}.yarl__slide_description_container{bottom:var(--yarl__slide_description_container_bottom,0)}.yarl__slide_title.yarl__slide_title.yarl__slide_title{font-family:var(--swui-font-primary);font-size:var(--swui-font-size-large);font-weight:var(--swui-font-weight-text)}.yarl__slide_title_container.yarl__slide_title_container.yarl__slide_title_container{height:48px;margin:calc(var(--swui-metrics-space) * 1);padding:0;display:flex;align-items:center;padding-left:calc(var(--swui-metrics-space) * 10)}.yarl__slide_description.yarl__slide_description.yarl__slide_description{font-family:var(--swui-font-primary);font-size:var(--swui-font-size-large);font-weight:var(--swui-font-weight-text)}.yarl__slide_description_container.yarl__slide_description_container.yarl__slide_description_container{display:flex;align-items:center;padding-left:calc(var(--swui-metrics-space) * 3);padding-bottom:calc(var(--swui-metrics-space) * 4)}.yarl__counter.yarl__counter{height:48px;margin:calc(var(--swui-metrics-space) * 1);display:flex;align-items:center;padding:0;padding-left:calc(var(--swui-metrics-space) * 1);font-family:var(--swui-font-primary);font-size:var(--swui-font-size-large);font-weight:var(--swui-font-weight-text)}")),document.head.appendChild(e)}}catch(t){console.error("vite-plugin-css-injected-by-js",t)}})();const on="_navBarButton_b3x3w_1",ln="_selected_b3x3w_14",lt={navBarButton:on,selected:ln};l.forwardRef(function({selected:e,className:t,...r},n){return o.jsx(k.FlatButton,{...r,ref:n,className:Q(lt.navBarButton,e&<.selected,t)})});const cn="_navBarNotificationButton_1wt3y_1",un="_unread_1wt3y_23",dn="_icon_1wt3y_23",be={navBarNotificationButton:cn,unread:un,icon:dn};l.forwardRef(function({count:e,unread:t=!1,className:r,labelClassName:n,iconClassName:a,icon:s=k.stenaBellFilled,...i},c){const d=e>1;return o.jsx(k.BaseButton,{...i,ref:c,leftIcon:s,className:Q(be.navBarNotificationButton,t&&be.unread,d&&be.hasCount,r),label:d?String(e):void 0,labelClassName:Q(n,be.label),iconClassName:Q(a,be.icon)})});l.forwardRef(({contentLeft:e,contentRight:t,collapsed:r=!1,...n},a)=>o.jsx(k.MenuButton,{ref:a,expandable:!0,expanded:!r,selected:!r,left:e,right:t,...n}));l.createContext(!1);const it=["small-mobile","mobile","tablet","tablet-wide","desktop"],At=()=>{const e=De.useMediaQuery({query:"(max-width: 768px)"}),t=De.useMediaQuery({query:"(max-width: 395px)"}),r=De.useMediaQuery({query:"(max-width: 1024px)"}),n=De.useMediaQuery({query:"(max-width: 1160px)"});return{deviceSize:t?"small-mobile":e?"mobile":r?"tablet":n?"tablet-wide":"desktop"}},Pt=(e,t)=>e===t||it.indexOf(e)>it.indexOf(t),Wt=({value:e,onValueChange:t,localeCode:r,startDateLabel:n="From",endDateLabel:a="To",onFocus:s,onBlur:i,calendarSize:c,startDateRef:d,endDateRef:f,placeholderWhenBlurredStartDate:_,placeholderWhenBlurredEndDate:p,valueWhenBlurredStartDate:m,valueWhenBlurredEndDate:h,variant:v,readOnlyOnMobile:w})=>{const{deviceSize:C}=At(),D=w&&!Pt(C,"tablet"),{mask:y,placeholder:x}=l.useMemo(()=>{const b=fe(r);return{mask:Lt(b),placeholder:b.toLowerCase()}},[r]);return o.jsxs(g.Row,{children:[o.jsx(ze,{mask:y,ref:d,value:e?.startDate,onValueChange:b=>{t?.({startDate:b})},onBlur:b=>{const S=Be(b.target.value,r);S&&S!==e?.startDate&&t?.({startDate:S}),i?.()},onFocus:()=>s?.("startDate"),label:n,borderRadiusVariant:"onlyLeft",placeholder:x,placeholderWhenBlurred:_,valueWhenBlurred:m,calendarSize:c,variant:v,readOnly:D}),o.jsx(ze,{mask:y,ref:f,value:e?.endDate,onValueChange:b=>t?.({endDate:b}),onBlur:b=>{const S=Be(b.target.value,r);S&&S!==e?.endDate&&t?.({endDate:S}),i?.()},onFocus:()=>s?.("endDate"),label:a,borderRadiusVariant:"onlyRight",placeholder:x,placeholderWhenBlurred:p,valueWhenBlurred:h,calendarSize:c,variant:v,readOnly:D})]})},$e=(e,t,r)=>{const n=u.isSameYear(e,t)?"":" y";return r.code.startsWith("en")?u.format(e,"eee MMM d"+n,{locale:r}).replace(".",""):u.format(e,"eee d MMM"+n,{locale:r}).replace(".","")};function fn(e,t,r){if(!e||!t||!r)return!1;const n=r(e),a=r(t);return!n||!a||Number.isNaN(n.getTime())||Number.isNaN(a.getTime())||u.isSameDay(n,a)?!1:u.isAfter(n,a)}function _n(e,t,r){const{startDate:n,endDate:a}=e;return fn(n,a,t)?r==="startDate"?{...e,startDate:n,endDate:n}:{...e,startDate:a,endDate:a}:e}const Ht=(e,t,r,n,a,s,i,c,d)=>{const f=ue(n),_=l.useId(),p=g.useToday(),m=l.useRef(null),h=l.useMemo(()=>fe(r),[r]),v=l.useMemo(()=>e?.startDate?.length===h.length?X(e.startDate,r):void 0,[h.length,r,e?.startDate]),w=l.useMemo(()=>e?.endDate?.length===h.length?X(e.endDate,r):void 0,[h.length,r,e?.endDate]),C=l.useMemo(()=>v!=null?$e(v,p,f):void 0,[f,v,p]),D=l.useMemo(()=>w!=null?$e(w,p,f):void 0,[f,w,p]),[y,x]=l.useState(a??v??new Date),b=l.useCallback(I=>{u.isSameMonth(I,p)||u.isAfter(I,p)?x(I):x(p)},[p]),S=l.useMemo(()=>ve(y.getFullYear(),y.getMonth(),f),[f,y]),T=l.useMemo(()=>Re(u.intlFormat(y,{month:"long",year:"numeric"},{locale:f.code})),[f,y]),R=l.useMemo(()=>u.isSameMonth(p,y),[p,y]),[N,j]=l.useState(),[M,F]=l.useState("calendar"),L=l.useCallback(I=>{const A=I?.startDate?.length===h.length?X(I.startDate,r):void 0,O=I?.endDate?.length===h.length?X(I.endDate,r):void 0;A?b(A):O&&b(O),t?.({...e,...I})},[h.length,r,t,b,e]),E=l.useMemo(()=>v&&w?u.isAfter(w,v)||u.isSameDay(w,v):!1,[w,v]),U=l.useMemo(()=>{const I=s==="startDate"?e?.endDate:e?.startDate;return I?X(I,r):void 0},[s,r,e?.endDate,e?.startDate]),z=l.useMemo(()=>{if(N&&U){if(s==="endDate")return"right";if(s==="startDate")return"left"}},[s,U,N]);return{onClickDate:I=>{if(!(I.getFullYear()===y.getFullYear()&&I.getMonth()===y.getMonth()))return;const O=(P,W)=>t?.(_n(P,H=>X(H,r),W));s==="startDate"?(O({startDate:oe(I,r),endDate:e?.endDate},"startDate"),e?.endDate?(d?.(),i(void 0),j(void 0)):c("endDate")):s==="endDate"?(O({startDate:e?.startDate,endDate:oe(I,r)},"endDate"),d?.(),i(void 0),j(void 0)):v&&w==null?u.isBefore(I,v)?(t?.({startDate:oe(I,r),endDate:void 0}),c("endDate")):(t?.({startDate:e?.startDate,endDate:oe(I,r)}),d?.(),i(void 0),j(void 0)):(O({startDate:oe(I,r),endDate:void 0},"startDate"),c("endDate"))},onValueChangeByInputs:L,isValidDateRange:E,monthPickerButtonRef:m,calendarId:_,monthPickerButtonLabel:T,visiblePanel:M,setVisiblePanel:F,setVisibleMonth:x,visibleMonthData:S,todayIsInVisibleMonth:R,hoverDate:N,setHoverDate:j,hoverAnchor:U,hoverHighlightDirection:z,selectedStartDate:v,selectedEndDate:w,today:p,visibleMonth:y,valueWhenBlurredStartDate:C,valueWhenBlurredEndDate:D}},Ee=({previousMonthButtonAriaLabel:e,nextMonthButtonAriaLabel:t,monthPickerButtonLabel:r,visiblePanel:n,setVisiblePanel:a,monthPickerButtonRef:s,setVisibleMonth:i,visibleMonth:c,prevMonthDisabled:d,nextMonthDisabled:f,calendarSize:_,previousMonthButtonTestId:p,nextMonthButtonTestId:m})=>{const h=_==="smaller"||_==="small"?"medium":"large";return o.jsxs(g.Row,{alignSelf:"center",justifyContent:"space-between",width:"100%",children:[o.jsx(k.FlatButton,{"aria-live":"polite",label:r,rightIcon:n==="calendar"?k.stenaAngleDown:k.stenaAngleUp,onClick:()=>a(n==="calendar"?"month-picker":"calendar"),ref:s,size:h}),o.jsxs(g.Row,{alignItems:"center",gap:2,children:[o.jsx(k.SecondaryButton,{leftIcon:k.stenaArrowLeft,onClick:()=>i(u.subMonths(c,1)),disabled:d?.(c),"aria-label":e,size:h,"data-testid":p}),o.jsx(k.SecondaryButton,{leftIcon:k.stenaArrowRight,onClick:()=>i(u.addMonths(c,1)),disabled:f?.(c),"aria-label":t,size:h,"data-testid":m})]})]})},gn="_travelDateCell_1t2af_1",hn="_smaller_1t2af_4",pn="_small_1t2af_4",mn="_medium_1t2af_14",bn="_large_1t2af_19",yn="_outline_1t2af_31",vn="_contentWrapper_1t2af_44",xn="_disabled_1t2af_65",wn="_isToday_1t2af_68",Dn="_isSelectionStart_1t2af_72",kn="_isSelectionEnd_1t2af_73",Cn="_hover_1t2af_88",Sn="_startSelected_1t2af_91",jn="_endSelected_1t2af_91",J={travelDateCell:gn,smaller:hn,small:pn,medium:mn,large:bn,outline:yn,contentWrapper:vn,disabled:xn,isToday:wn,isSelectionStart:Dn,isSelectionEnd:kn,hover:Cn,startSelected:Sn,endSelected:jn},ee="var(--selection-range-background-color)",Mn=(e,t,r,n,a,s,i,c)=>i?t&&r&&!c?{left:"transparent",right:"transparent"}:a&&s&&n?Rn(e,n,a,s):a?{left:"transparent",right:"transparent"}:Bn(e,t,r,a):{left:"transparent",right:"transparent"},Bn=(e,t,r,n)=>{if(t&&r&&u.isSameDay(t,r))return{left:"transparent",right:"transparent"};if(t&&r?u.isAfter(e,t)&&u.isBefore(e,r)&&!u.isSameDay(e,t)&&!u.isSameDay(e,r):!1)return{left:ee,right:ee};if(t&&r)return u.isSameDay(e,t)?{left:"transparent",right:ee}:u.isSameDay(e,r)?{left:ee,right:"transparent"}:{left:"transparent",right:"transparent"};if(t&&n&&u.isAfter(n,t)){if(u.isSameDay(e,t))return{left:"transparent",right:ee};if(u.isSameDay(e,n))return{left:ee,right:"transparent"}}return{left:"transparent",right:"transparent"}},Rn=(e,t,r,n)=>{const a=u.isAfter(r,n),s=u.isWithinInterval(e,{start:u.min([r,n]),end:u.max([r,n])}),i=u.isSameDay(e,r),c=u.isSameDay(e,n);return t==="right"&&u.isBefore(r,n)?{left:"transparent",right:"transparent"}:t==="left"&&u.isAfter(r,n)?{left:"transparent",right:"transparent"}:i&&c?{left:"transparent",right:"transparent"}:i?ct(a,{left:"transparent",right:ee}):c?ct(a,{left:ee,right:"transparent"}):s?{left:ee,right:ee}:{left:"transparent",right:"transparent"}},ct=(e,{left:t,right:r})=>e?{left:r,right:t}:{left:t,right:r},In=(e,t)=>{switch(t){case"PageUp":return u.subMonths(e,1);case"PageDown":return u.addMonths(e,1);case"Home":return u.startOfWeek(e);case"End":return u.addDays(u.startOfWeek(e),6);case"ArrowLeft":return u.subDays(e,1);case"ArrowUp":return u.subDays(e,7);case"ArrowRight":return u.addDays(e,1);case"ArrowDown":return u.addDays(e,7);default:return}},We=(e,t)=>u.format(u.addHours(e,12),se.fullDate)+t,Tn="_travelDateCellBackground_45q5d_1",En="_smaller_45q5d_2",Nn="_small_45q5d_2",Fn="_medium_45q5d_12",Ln="_large_45q5d_17",ke={travelDateCellBackground:Tn,smaller:En,small:Nn,medium:Fn,large:Ln},An=({calendarSize:e,bgColorLeft:t,bgColorRight:r})=>o.jsxs(g.Row,{children:[o.jsx(g.Box,{className:Q(ke.travelDateCellBackground,ke[e]),background:t}),o.jsx(g.Box,{className:Q(ke.travelDateCellBackground,ke[e]),background:r})]}),Pn=({onClick:e,visibleMonth:t,onChangeVisibleMonth:r,day:n,isValidDateRange:a,selectedStartDate:s,selectedEndDate:i,onStartHover:c,onEndHover:d,hoverDate:f,hoverAnchor:_,today:p,todayIsInVisibleMonth:m,calendarId:h,isDateDisabled:v,size:w,dateTestId:C,hoverHighlightDirection:D})=>{const y=l.useCallback(async L=>{const E=In(n.date,L.key),U=(E&&v?.(E))??!1;E&&!U&&(c(E),u.isSameMonth(n.date,E)?document.getElementById(We(E,h))?.focus():(r(E),setTimeout(()=>{document.getElementById(We(E,h))?.focus()},10))),(L.key==="Enter"||L.code==="Space")&&e(n.date)},[h,n.date,v,r,e,c]),x=n.month===t.getMonth(),b=v?.(n.date)??!1,S=f&&_?u.isAfter(f,_):!1,T=f&&_?u.isSameDay(S?_:f,n.date):!1,R=f&&_?u.isSameDay(S?f:_,n.date):!1,N=!f&&s?u.isSameDay(s,n.date):!1,j=!f&&i?u.isSameDay(i,n.date):!1,M=u.isSameDay(n.date,p),F=Mn(n.date,s,i,D,f,_,x,a);return o.jsxs("td",{className:Q(J.travelDateCell,J[w]),onClick:b?void 0:()=>e(n.date),onMouseOver:b?void 0:()=>x&&c(n.date),onMouseOut:b?void 0:()=>x&&d(n.date),tabIndex:b?void 0:Wn(n,s,M,t,m),id:b?void 0:We(n.date,h),onKeyDown:b?void 0:y,...b?void 0:{"aria-selected":N||j},"data-testid":C?.(n.date),children:[o.jsx("div",{className:J.outline}),o.jsx(An,{calendarSize:w,bgColorLeft:F.left,bgColorRight:F.right}),x&&o.jsx("div",{className:Q(J.contentWrapper,M?J.isToday:void 0,s?J.startSelected:void 0,i?J.endSelected:void 0,f&&u.isSameDay(f,n.date)?J.hover:void 0,(N||T)&&J.isSelectionStart,(j||R)&&J.isSelectionEnd,b&&J.disabled),children:o.jsx(g.Text,{variant:"bold",color:b?Ve.cssColor("--lhds-color-ui-500"):void 0,children:n.dayOfMonth})})]})},Wn=(e,t,r,n,a)=>{const s=t?u.isSameMonth(t,n):!1;return(t&&s?u.isSameDay(e.date,t):r)||!s&&!a&&e.date.getDate()===1?0:-1},Hn="_travelCalendar_ib2y4_1",On={travelCalendar:Hn},Ne=({visibleMonthData:e,onClickDate:t,setHoverDate:r,setVisibleMonth:n,visibleMonth:a,isValidDateRange:s,selectedStartDate:i,selectedEndDate:c,hoverDate:d,hoverAnchor:f,today:_,calendarId:p,isDateDisabled:m,todayIsInVisibleMonth:h,size:v="medium",multiSelectable:w,dateTestId:C,hoverHighlightDirection:D})=>o.jsx("table",{className:On.travelCalendar,role:"grid",...w?{"aria-multiselectable":!0}:void 0,children:o.jsxs("tbody",{children:[o.jsx("tr",{children:e.weeks[0].days.map(y=>o.jsx("th",{abbr:y.fullName,children:o.jsx(g.Text,{children:y.name})},y.name))}),e.weeks.map(y=>o.jsx(qe.Fragment,{children:o.jsx("tr",{children:y.days.map(x=>o.jsx(Pn,{size:v,onClick:b=>t(b),visibleMonth:a,onChangeVisibleMonth:n,isValidDateRange:s,day:x,onStartHover:b=>r(b),onEndHover:b=>r(S=>S&&u.isSameDay(S,b)?void 0:S),selectedStartDate:i,selectedEndDate:c,hoverDate:d,hoverAnchor:f,today:_,todayIsInVisibleMonth:h,calendarId:p,isDateDisabled:m,dateTestId:C,hoverHighlightDirection:D},x.dateString))},y.weekNumber)},y.weekNumber))]})}),Yn="_travelDateRangeInput_1j7rp_1",Un="_overlay_1j7rp_2",zn="_calendarVisible_1j7rp_6",He={travelDateRangeInput:Yn,overlay:Un,calendarVisible:zn},$n=({value:e,onValueChange:t,startDateLabel:r,endDateLabel:n,localeCode:a="sv",languageLocaleCode:s=a,initialMonthInFocus:i,previousMonthButtonAriaLabel:c="Previous month",nextMonthButtonAriaLabel:d="Next month",placeholderWhenBlurredStartDate:f,placeholderWhenBlurredEndDate:_,heading:p,headingLevel:m,numMonthsInMonthPicker:h=12,isDateDisabled:v,prevMonthDisabled:w,nextMonthDisabled:C,firstMonthInMonthPicker:D=new Date,zIndex:y=1e3,zIndexWhenClosed:x,onHideCalendar:b,renderBelowCalendar:S,size:T="medium",dateTestId:R,previousMonthButtonTestId:N,nextMonthButtonTestId:j,textInputVariant:M="standard"})=>{const[F,L]=l.useState(!1),[E,U]=l.useState(!1),[z,$]=l.useState({width:336,height:66}),[I,A]=l.useState(void 0),O=l.useRef(null),P=l.useRef(null),W=K=>{K==="startDate"?O.current?.focus():K==="endDate"&&P.current?.focus()},H=T==="large"?"8.8rem":"6.6rem",V=l.useRef(!1),Z=l.useCallback(K=>{A(K),V.current=!0,U(!0),setTimeout(()=>{L(!0)},10)},[]),q=l.useCallback(()=>{E&&(L(!1),V.current=!1,b?.(),setTimeout(()=>{V.current||U(!1)},120))},[E,b]),G=l.useRef(null),Y=l.useRef(null);g.useOnClickOutside(G,q),l.useLayoutEffect(()=>{const K=Y.current?.offsetWidth,Le=Y.current?.offsetHeight;K!=null&&Le!=null&&(z.height!==Le||z.width!==K)&&$({width:K,height:Le})},[z.height,z.width]);const ce=Ht(e,t,a,s,i,I,A,W,q),{visiblePanel:pe,visibleMonth:Fe,onValueChangeByInputs:re,setVisibleMonth:me,setVisiblePanel:tt,monthPickerButtonRef:rt}=ce,Ut=l.useCallback(K=>{K.key==="Escape"&&q()},[q]);return o.jsxs(g.Box,{position:"relative",className:He.travelDateRangeInput,ref:G,onKeyDown:Ut,height:z.height,width:z.width,children:[o.jsx(g.Box,{position:"absolute",ref:Y,zIndex:E?y:x,children:o.jsx(Wt,{...ce,value:e,onValueChange:re,startDateRef:O,endDateRef:P,localeCode:a,startDateLabel:r,endDateLabel:n,onFocus:Z,calendarSize:T,placeholderWhenBlurredStartDate:f,placeholderWhenBlurredEndDate:_,variant:M,readOnlyOnMobile:!0})}),E&&o.jsx(g.Box,{position:"absolute",zIndex:y-1,left:"-2.4rem",top:p?"-8.0rem":"-2.4rem",className:Q(He.overlay,F&&He.calendarVisible),children:o.jsx(g.Box,{background:"white",shadow:"popover",borderRadius:"var(--swui-border-radius-large)",children:o.jsxs(k.CardBody,{gap:3,children:[p&&o.jsx(g.Heading,{variant:"h2",as:m,children:p}),o.jsx(g.Box,{height:H}),o.jsx(Ee,{...ce,previousMonthButtonAriaLabel:c,nextMonthButtonAriaLabel:d,calendarSize:T,prevMonthDisabled:w,nextMonthDisabled:C,previousMonthButtonTestId:N,nextMonthButtonTestId:j}),pe==="calendar"&&o.jsx(Ne,{...ce,size:T,multiSelectable:!0,isDateDisabled:v,dateTestId:R}),pe==="month-picker"&&o.jsx(he,{firstMonth:D,numMonths:h,value:Fe,size:T,localeCode:s,onValueChange:K=>{me(K),tt("calendar"),rt.current?.focus()},onCancel:()=>{tt("calendar"),rt.current?.focus()}}),S?.({hideCalendar:q})]})})})]})},Vn="_travelDateInput_hmfbf_1",qn="_overlay_hmfbf_2",Kn="_calendarVisible_hmfbf_6",Oe={travelDateInput:Vn,overlay:qn,calendarVisible:Kn},Ot=({value:e,onValueChange:t,label:r="Date",localeCode:n,onFocus:a,calendarSize:s,placeholderWhenBlurred:i,valueWhenBlurred:c,variant:d,readOnlyOnMobile:f})=>{const{deviceSize:_}=At(),p=f&&!Pt(_,"tablet"),{mask:m,placeholder:h}=l.useMemo(()=>{const v=fe(n);return{mask:Lt(v),placeholder:v.toLowerCase()}},[n]);return o.jsx(g.Row,{children:o.jsx(ze,{mask:m,value:e,onValueChange:t,onBlur:v=>{const w=Be(v.target.value,n);w&&w!==e&&t?.(w)},readOnly:p,onFocus:a,label:r,placeholder:h,calendarSize:s,placeholderWhenBlurred:i,valueWhenBlurred:c,variant:d})})},Yt=(e,t,r,n,a,s)=>{const i=ue(n),c=l.useId(),d=g.useToday(),f=l.useRef(null),_=l.useMemo(()=>fe(r),[r]),p=l.useMemo(()=>e?.length===_.length?X(e,r):void 0,[_.length,r,e]),m=l.useMemo(()=>p!=null?$e(p,d,i):void 0,[i,p,d]),[h,v]=l.useState(a??p??new Date),w=l.useCallback(j=>{u.isSameMonth(j,d)||u.isAfter(j,d)?v(j):v(d)},[d]),C=l.useMemo(()=>ve(h.getFullYear(),h.getMonth(),i),[i,h]),D=l.useMemo(()=>Re(u.intlFormat(h,{month:"long",year:"numeric"},{locale:i.code})),[i,h]),y=l.useMemo(()=>u.isSameMonth(d,h),[d,h]),[x,b]=l.useState(),[S,T]=l.useState("calendar"),R=l.useCallback(j=>{const M=j?.length===_.length?X(j,r):void 0;M&&w(M),t?.(j)},[_.length,r,t,w]);return{onClickDate:j=>{t?.(oe(j,r)),s?.(j)},onValueChangeByInputs:R,monthPickerButtonRef:f,calendarId:c,monthPickerButtonLabel:D,visiblePanel:S,setVisiblePanel:T,setVisibleMonth:v,visibleMonthData:C,todayIsInVisibleMonth:y,hoverDate:x,hoverAnchor:void 0,setHoverDate:b,selectedDate:p,today:d,visibleMonth:h,valueWhenBlurred:m}},Gn=({value:e,onValueChange:t,label:r,localeCode:n="sv",languageLocaleCode:a=n,initialMonthInFocus:s,previousMonthButtonAriaLabel:i="Previous month",nextMonthButtonAriaLabel:c="Next month",placeholderWhenBlurred:d,heading:f,headingLevel:_,numMonthsInMonthPicker:p=12,isDateDisabled:m,prevMonthDisabled:h,nextMonthDisabled:v,firstMonthInMonthPicker:w=new Date,zIndex:C=1e3,zIndexWhenClosed:D,onHideCalendar:y,renderBelowCalendar:x,size:b="medium",dateTestId:S,previousMonthButtonTestId:T,nextMonthButtonTestId:R,textInputVariant:N="standard"})=>{const[j,M]=l.useState(!1),[F,L]=l.useState(!1),[E,U]=l.useState({width:336,height:66}),z=b==="large"?"8.8rem":"6.6rem",$=l.useRef(!1),I=l.useCallback(()=>{$.current=!0,L(!0),setTimeout(()=>{M(!0)},10)},[]),A=l.useCallback(()=>{F&&(M(!1),$.current=!1,y?.(),setTimeout(()=>{$.current||L(!1)},120))},[F,y]),O=l.useCallback(()=>{setTimeout(()=>{A()},250)},[A]),P=l.useRef(null),W=l.useRef(null);g.useOnClickOutside(P,A),l.useLayoutEffect(()=>{const re=W.current?.offsetWidth,me=W.current?.offsetHeight;re!=null&&me!=null&&(E.height!==me||E.width!==re)&&U({width:re,height:me})},[E.height,E.width]);const H=Yt(e,t,n,a,s,O),{visiblePanel:V,visibleMonth:Z,onValueChangeByInputs:q,selectedDate:G,setVisibleMonth:Y,setVisiblePanel:ce,monthPickerButtonRef:pe}=H,Fe=l.useCallback(re=>{re.key==="Escape"&&A()},[A]);return o.jsxs(g.Box,{position:"relative",className:Oe.travelDateInput,ref:P,onKeyDown:Fe,height:E.height,width:E.width,children:[o.jsx(g.Box,{position:"absolute",ref:W,zIndex:F?C:D,children:o.jsx(Ot,{...H,value:e,onValueChange:q,localeCode:n,label:r,onFocus:I,calendarSize:b,placeholderWhenBlurred:d,variant:N,readOnlyOnMobile:!0})}),F&&o.jsx(g.Box,{position:"absolute",zIndex:C-1,left:"-2.4rem",top:f?"-8.0rem":"-2.4rem",className:Q(Oe.overlay,j&&Oe.calendarVisible),children:o.jsx(g.Box,{background:"white",shadow:"popover",borderRadius:"var(--swui-border-radius-large)",children:o.jsxs(k.CardBody,{gap:3,children:[f&&o.jsx(g.Heading,{variant:"h2",as:_,children:f}),o.jsx(g.Box,{height:z}),o.jsx(Ee,{...H,previousMonthButtonAriaLabel:i,nextMonthButtonAriaLabel:c,calendarSize:b,prevMonthDisabled:h,nextMonthDisabled:v,previousMonthButtonTestId:T,nextMonthButtonTestId:R}),V==="calendar"&&o.jsx(Ne,{...H,size:b,isValidDateRange:!!G,selectedStartDate:G,selectedEndDate:G,multiSelectable:!1,isDateDisabled:m,dateTestId:S,hoverHighlightDirection:void 0}),V==="month-picker"&&o.jsx(he,{firstMonth:w,numMonths:p,value:Z,size:b,localeCode:n,onValueChange:re=>{Y(re),ce("calendar"),pe.current?.focus()},onCancel:()=>{ce("calendar"),pe.current?.focus()}}),x?.({hideCalendar:A})]})})})]})},Jn=({value:e,onValueChange:t,label:r,localeCode:n="sv",languageLocaleCode:a=n,initialMonthInFocus:s,previousMonthButtonAriaLabel:i="Previous month",nextMonthButtonAriaLabel:c="Next month",placeholderWhenBlurred:d,heading:f,headingLevel:_,numMonthsInMonthPicker:p=12,isDateDisabled:m,prevMonthDisabled:h,nextMonthDisabled:v,firstMonthInMonthPicker:w=new Date,dateTestId:C,size:D="medium",previousMonthButtonTestId:y,nextMonthButtonTestId:x,textInputVariant:b="standard"})=>{const S=Yt(e,t,n,a,s),{visiblePanel:T,visibleMonth:R,onValueChangeByInputs:N,setVisibleMonth:j,setVisiblePanel:M,monthPickerButtonRef:F,selectedDate:L}=S;return o.jsxs(g.Column,{gap:3,children:[f&&o.jsx(g.Heading,{variant:"h2",as:_,children:f}),o.jsx(Ot,{...S,value:e,onValueChange:N,localeCode:n,label:r,calendarSize:D,placeholderWhenBlurred:d,variant:b,readOnlyOnMobile:!1}),o.jsx(Ee,{...S,previousMonthButtonAriaLabel:i,nextMonthButtonAriaLabel:c,calendarSize:D,prevMonthDisabled:h,nextMonthDisabled:v,previousMonthButtonTestId:y,nextMonthButtonTestId:x}),T==="calendar"&&o.jsx(Ne,{...S,size:D,selectedStartDate:L,selectedEndDate:L,isValidDateRange:!!L,isDateDisabled:m,multiSelectable:!1,dateTestId:C,hoverHighlightDirection:void 0}),T==="month-picker"&&o.jsx(he,{firstMonth:w,numMonths:p,value:R,localeCode:a,size:D,onValueChange:E=>{j(E),M("calendar"),F.current?.focus()},onCancel:()=>{M("calendar"),F.current?.focus()}})]})},Qn=({value:e,onValueChange:t,startDateLabel:r,endDateLabel:n,localeCode:a="sv",languageLocaleCode:s=a,initialMonthInFocus:i,previousMonthButtonAriaLabel:c="Previous month",nextMonthButtonAriaLabel:d="Next month",heading:f,headingLevel:_,numMonthsInMonthPicker:p=12,isDateDisabled:m,prevMonthDisabled:h,nextMonthDisabled:v,firstMonthInMonthPicker:w=new Date,size:C="medium",dateTestId:D,previousMonthButtonTestId:y,nextMonthButtonTestId:x,placeholderWhenBlurredStartDate:b,placeholderWhenBlurredEndDate:S,textInputVariant:T="standard"})=>{const[R,N]=l.useState(void 0),j=l.useRef(null),M=l.useRef(null),F=l.useCallback(P=>{P==="startDate"?j.current?.focus():P==="endDate"&&M.current?.focus()},[]),L=Ht(e,t,a,s,i,R,N,F,void 0),E=l.useCallback(P=>{N(P)},[]),{visiblePanel:U,visibleMonth:z,onValueChangeByInputs:$,setVisibleMonth:I,setVisiblePanel:A,monthPickerButtonRef:O}=L;return o.jsxs(g.Column,{gap:3,children:[f&&o.jsx(g.Heading,{variant:"h2",as:_,children:f}),o.jsx(Wt,{...L,value:e,onValueChange:$,startDateRef:j,endDateRef:M,localeCode:a,startDateLabel:r,endDateLabel:n,onFocus:E,calendarSize:C,placeholderWhenBlurredStartDate:b,placeholderWhenBlurredEndDate:S,variant:T,readOnlyOnMobile:!1}),o.jsx(Ee,{...L,previousMonthButtonAriaLabel:c,nextMonthButtonAriaLabel:d,calendarSize:C,prevMonthDisabled:h,nextMonthDisabled:v,previousMonthButtonTestId:y,nextMonthButtonTestId:x}),U==="calendar"&&o.jsx(Ne,{...L,size:C,multiSelectable:!0,isDateDisabled:m,dateTestId:D}),U==="month-picker"&&o.jsx(he,{firstMonth:w,numMonths:p,value:z,size:C,localeCode:s,onValueChange:P=>{I(P),A("calendar"),O.current?.focus()},onCancel:()=>{A("calendar"),O.current?.focus()}})]})},Zn=()=>{const e=g.useToday();return l.useCallback(t=>!u.isSameDay(t,e)&&u.isBefore(t,e),[e])},Xn=()=>{const e=g.useToday();return l.useCallback(t=>u.isSameMonth(e,t)||u.isBefore(t,e),[e])};exports.Calendar=Se;exports.CalendarDay=Ge;exports.DateInput=jr;exports.DateRangeCalendar=wr;exports.DateRangeDualTextInput=en;exports.DateRangeInput=Br;exports.DateTextInput=Rr;exports.DateTimeInput=Vr;exports.Month=_t;exports.MonthPicker=he;exports.MultiDateCalendar=kr;exports.PresetPicker=jt;exports.SingleDateCalendar=et;exports.SingleWeekCalendar=Cr;exports.TimeTextInput=Tr;exports.TravelDateCalendar=Jn;exports.TravelDateInput=Gn;exports.TravelDateRangeCalendar=Qn;exports.TravelDateRangeInput=$n;exports.WeekDay=gt;exports.WeekDayCell=wt;exports.WeekNumberCell=Dt;exports.YearPicker=Kr;exports.addDayStateHighlights=ae;exports.addDayStateHighlightsOnSingleDay=Ke;exports.addWeekRangeHighlights=ft;exports.addWeekStateHighlights=Kt;exports.buildDayStateForDateRange=_e;exports.buildDayStateForRange=dt;exports.buildDayStateForSingleMonth=ut;exports.calculateOverflowingMonth=bt;exports.createDay=pt;exports.dateRangeToStrings=Mt;exports.dayHasHighlight=yt;exports.dayHighlightSelect=ne;exports.defaultCalendarTheme=ie;exports.defaultTextPropsProvider=xt;exports.defaultWrapperStyleProvider=vt;exports.extranetCalendarTheme=Zt;exports.fallbackLocaleCode=Je;exports.fallbackLocaleCodeForFormatting=ir;exports.formatLocalizedDate=oe;exports.getDateFormatForLocaleCode=fe;exports.getDaysForWeekForDate=mt;exports.getDefaultLocaleForFormatting=cr;exports.getLocaleCodeForLocale=St;exports.getLocaleForLocaleCode=ue;exports.getMonthInYear=ve;exports.getMonthsInYear=Ye;exports.getSupportedLocaleCode=Qe;exports.getSupportedLocaleCodeMatchingLanguage=Ct;exports.getWeekForDate=Ie;exports.getWeeksForMonth=ht;exports.isDateRangeInvalid=Ze;exports.parseLocalizedDateString=X;exports.reformatLocalizedDateString=Be;exports.setDayStateValue=Vt;exports.setDayStateValueFunction=qt;exports.stringsToDateRange=Bt;exports.toggleDateStringsIfEndIsEarlierThanStart=vr;exports.toggleDatesIfEndIsEarlierThanStart=Xe;exports.useDateRangeCalendarState=Dr;exports.useDateRangeSelection=Rt;exports.useDisabledBeforeToday=Zn;exports.useMultiDateSelection=Tt;exports.usePrevMonthDisabledBeforeToday=Xn;exports.useSingleDateSelection=It;exports.useSingleWeekSelection=Et;
|
|
2
|
+
"use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("react/jsx-runtime"),g=require("@stenajs-webui/core"),C=require("@stenajs-webui/elements"),u=require("date-fns"),T=require("date-fns/locale"),le=require("lodash-es"),l=require("react"),J=require("classnames"),Pe=require("@emotion/styled"),ee=require("@stenajs-webui/forms"),ye=require("@stenajs-webui/tooltip"),qe=require("@stenajs-webui/theme"),Vt=require("@stenajs-webui/input-mask"),Ce=require("react-responsive");function qt(e){const t=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(e){for(const r in e)if(r!=="default"){const n=Object.getOwnPropertyDescriptor(e,r);Object.defineProperty(t,r,n.get?n:{enumerable:!0,get:()=>e[r]})}}return t.default=e,Object.freeze(t)}const Ke=qt(l),ae={yearAndMonth:"yyyy-MM",fullDate:"yyyy-MM-dd",fullMonthName:"LLLL"},ge=(e={},t,r)=>{if(t&&r&&u.isAfter(r,t))return u.eachDayOfInterval({start:t,end:r}).reduce((a,s)=>{const i=u.isSameDay(s,t),c=u.isSameDay(s,r);return ne(a,s,i?["selected","selectedStart","range"]:c?["selected","selectedEnd","range"]:["range"])},e);let n=e;return t&&(n=ne(n,t,["selected","singleSelected"])),r&&(n=ne(n,r,["selected","singleSelected"])),n},dt=(e={},t,r,n)=>ft(e,t,r,u.startOfMonth(n),u.endOfMonth(n)),ft=(e={},t,r,n,a)=>t&&r?ge(e,u.max([t,u.subDays(n,1)]),u.min([r,u.addDays(a,1)])):ge(e,t,r),Kt=(e,t,r)=>{const n=u.format(t,ae.yearAndMonth),a=u.getISOWeek(t),s=u.getDate(t);return{...e,[n]:{...e&&e[n],[a]:{...e&&e[n]&&e[n][a],[s]:{...e&&e[n]&&e[n][a]&&e[n][a][s],...r}}}}},Gt=(e,t,r)=>{const n=u.format(t,ae.yearAndMonth),a=u.getISOWeek(t),s=u.getDate(t);return{...e,[n]:{...e&&e[n],[a]:{...e&&e[n]&&e[n][a],[s]:{...e&&e[n]&&e[n][a]&&e[n][a][s],...r(e&&e[n]&&e[n][a]&&e[n][a][s])}}}}},ne=(e,t,r)=>{const n=t.getMonth()+1,a=`${t.getFullYear()}-${n<10?"0":""}${n}`,s=u.getISOWeek(t),i=u.getDate(t),c=e&&e[a]&&e[a][s]&&e[a][s][i];return{...e,[a]:{...e&&e[a],[s]:{...e&&e[a]&&e[a][s],[i]:Ge(c,r)}}}},Ge=(e,t)=>({...e,highlights:[...e?.highlights??[],...t]}),Jt=(e,t,r)=>{const n=t.days[0].date,a=n.getMonth()+1,s=`${n.getFullYear()}-${a<10?"0":""}${a}`,i=t.weekNumber;let c=e;t.days.forEach(p=>{c=ne(c,p.date,r)});const d=c&&c[s]?c[s][i]:void 0,f=d&&d.highlights?[...d.highlights,...r]:r,_={...d,highlights:f};return{...c,[s]:{...e&&e[s],[i]:_}}},_t=(e,t)=>{if(!t.days.length)return{...e};const r=t.days[0].date,n=le.last(t.days)?.date;return{...ge(e,r,n)}},Qt=(e,t)=>l.useMemo(()=>e?ne(t,new Date,["today"]):t,[e,t]),Te=e=>e.length===0?e:e.length===1?e.toUpperCase():e.charAt(0).toUpperCase()+e.slice(1);var gt=(e=>(e[e.JANUARY=0]="JANUARY",e[e.FEBRUARY=1]="FEBRUARY",e[e.MARCH=2]="MARCH",e[e.APRIL=3]="APRIL",e[e.MAY=4]="MAY",e[e.JUNE=5]="JUNE",e[e.JULY=6]="JULY",e[e.AUGUST=7]="AUGUST",e[e.SEPTEMBER=8]="SEPTEMBER",e[e.OCTOBER=9]="OCTOBER",e[e.NOVEMBER=10]="NOVEMBER",e[e.DECEMBER=11]="DECEMBER",e))(gt||{}),ht=(e=>(e[e.SUNDAY=0]="SUNDAY",e[e.MONDAY=1]="MONDAY",e[e.TUESDAY=2]="TUESDAY",e[e.WEDNESDAY=3]="WEDNESDAY",e[e.THURSDAY=4]="THURSDAY",e[e.FRIDAY=5]="FRIDAY",e[e.SATURDAY=6]="SATURDAY",e))(ht||{});const Ue=(e,t,r,n)=>{const a=[];for(let s=0;s<r;s++)a.push(ve(e,t+s,n));return a},ve=(e,t,r)=>{if(isNaN(e)||isNaN(t))throw new Error("getMonthInYear() received NaN.");const n=e+Math.floor(t/12),a=t%12,s=new Date(n,a,1);return{monthString:u.format(s,ae.yearAndMonth),name:Te(u.format(s,ae.fullMonthName,{locale:r})),year:n,monthInYear:a,weeks:pt(n,a,r)}},pt=(e,t,r,n=!0)=>{const a=new Date(e,t,1),s=u.startOfWeek(a,{locale:r}),i=[];for(let c=0;c<6;c++){const d=Ee(u.addWeeks(s,c),r);if(c>0&&d.startMonth!==t&&!n)return i;i.push(d)}return i},Ee=(e,t)=>{const r=u.getMonth(u.addDays(e,7))!==u.getMonth(e);return{weekNumber:u.getWeek(e,{locale:t}),startMonth:u.getMonth(e),startYear:u.getYear(e),endMonth:u.getMonth(u.addDays(e,6)),endYear:u.getYear(u.addDays(e,6)),days:bt(e,t),isLastWeekOfMonth:r}},mt=(e,t)=>{const r=u.getISODay(e);return{date:e,name:u.format(e,"EEE",t?{locale:t}:void 0),fullName:u.format(e,"EEEE",t?{locale:t}:void 0),dateString:u.format(u.addHours(e,12),ae.fullDate),weekNumber:u.getWeek(e,{locale:t}),year:u.getYear(e),month:u.getMonth(e),dayOfMonth:u.getDate(e),dayOfWeek:r,isFirstDayOfWeek:r===1,isLastDayOfWeek:r===7,isFirstDayOfMonth:u.isSameDay(u.startOfMonth(e),e),isLastDayOfMonth:u.isSameDay(u.endOfMonth(e),e)}},bt=(e,t)=>u.eachDayOfInterval({start:e,end:u.addDays(e,6)}).map(r=>mt(r,t)),yt=(e,t)=>t>11?{year:e+Math.floor(t/12),month:t%12}:t<0?{year:e+Math.floor(t/12),month:12+t%12}:{year:e,month:t},Zt="_calendar_hknk7_1",Xt="_weekNumberVisible_hknk7_41",at={calendar:Zt,weekNumberVisible:Xt},vt=(e,t,r)=>!!(t&&t.indexOf(r)>=0||e&&e.highlights&&e.highlights.indexOf(r)>=0),re=(e,t,r,n,a)=>{if(r.length!==n.length)throw new Error("Select highlight failed, number of values do not equal number of highlights.");if(r.length===0)return a;for(let s=0;s<r.length;s++)if(typeof r[s]=="boolean"&&r[s]||typeof r[s]=="string"&&vt(e,t,r[s]))return n[s];return a},xt=({selectedBackground:e,todayBackground:t,rangeBackground:r,borderColor:n="transparent"})=>(a,s,i,c,d)=>({backgroundColor:re(s,a,["selected","range","today",i.month===d.monthInYear],[e,r,t,"#fff"],"transparent"),borderWidth:"1px",borderStyle:"solid",borderColor:re(s,a,["selectedStart","selectedEnd","singleSelected","range","today"],["var(--swui-calendar-wrapper-range-background)","var(--swui-calendar-wrapper-range-background)","var(--swui-calendar-wrapper-range-background)","var(--swui-calendar-wrapper-range-border)","var(--lhds-color-ui-500)"],n),borderTopLeftRadius:re(s,a,["selectedStart","singleSelected","today"],["var(--swui-calendar-day-border-radius)","var(--swui-calendar-day-border-radius)","var(--swui-calendar-day-border-radius)"],"unset"),borderBottomLeftRadius:re(s,a,["selectedStart","singleSelected","today"],["var(--swui-calendar-day-border-radius)","var(--swui-calendar-day-border-radius)","var(--swui-calendar-day-border-radius)"],"unset"),borderTopRightRadius:re(s,a,["selectedEnd","singleSelected","today"],["var(--swui-calendar-day-border-radius)","var(--swui-calendar-day-border-radius)","var(--swui-calendar-day-border-radius)"],"unset"),borderBottomRightRadius:re(s,a,["selectedEnd","singleSelected","today"],["var(--swui-calendar-day-border-radius)","var(--swui-calendar-day-border-radius)","var(--swui-calendar-day-border-radius)"],"unset"),boxSizing:"border-box"}),wt=({selectedColor:e,disabledColor:t,inOtherMonthColor:r,rangeTextColor:n})=>(a,s,i,c,d)=>{const f=i.month!==d.monthInYear;return{color:re(s,a,[f,"selected","range","enabled","disabled"],[r,e,n,void 0,t])}},ie={width:"var(--swui-calendar-day-width)",height:"var(--swui-calendar-day-height)",WeekNumber:{backgroundColor:"var(--swui-calendar-week-number-bg-color)",textColor:"var(--swui-calendar-week-number-text-color)",clickableTextColor:"var(--swui-calendar-week-number-clickable-text-color)"},WeekDay:{textColor:"var(--swui-calendar-week-day-text-color)",clickableTextColor:"var(--swui-calendar-week-day-clickable-text-color)"},CalendarDay:{tdStyle:xt({selectedBackground:"var(--swui-calendar-wrapper-selected-background)",rangeBackground:"var(--swui-calendar-wrapper-range-background)",todayBackground:"var(--swui-calendar-wrapper-today-background)"}),textProps:wt({selectedColor:"var(--swui-calendar-text-selected-color)",disabledColor:"var(--swui-calendar-text-disabled-color)",inOtherMonthColor:"var(--swui-calendar-text-in-other-month-color)"})},CalendarMonth:{headerTextColor:"var(--swui-calendar-week-day-text-color)"}},er={...ie,width:"37px",height:"37px"},Dt=({onClickWeekDay:e,day:t,theme:r})=>{const n=o.jsx(g.Box,{width:r.width,height:r.height,justifyContent:"center",alignItems:"center",children:o.jsx(g.Text,{size:"small",color:e?r.WeekDay.clickableTextColor:r.WeekDay.textColor,children:t.name})});return e?o.jsx(g.Clickable,{borderRadius:"var(--swui-calendar-day-border-radius)",onClick:a=>e(t.dayOfWeek,a),disableFocusHighlight:!e,children:n}):n},Je=function({day:t,week:r,month:n,dayState:a,userData:s,onClickDay:i,theme:c,extraDayContent:d,defaultHighlights:f,showDatesInOtherMonths:_}){const p=o.jsx(g.Box,{width:"100%",height:"100%",justifyContent:"center",alignItems:"center",children:o.jsx(g.Text,{...c.CalendarDay.textProps&&c.CalendarDay.textProps(f,a,t,r,n,s),children:t.dayOfMonth})}),m=Pe.td({...c.CalendarDay.tdStyle&&c.CalendarDay.tdStyle(f,a,t,r,n,s)}),h=Pe.div({...c.CalendarDay.innerWrapperStyle&&c.CalendarDay.innerWrapperStyle(f,a,t,r,n,s),width:"100%",height:"100%"}),y=Pe.div({...c.CalendarDay.cellWrapperStyle&&c.CalendarDay.cellWrapperStyle(f,a,t,r,n,s),width:"100%",height:"100%",position:"relative"}),w=tr(f,a);return o.jsx(m,{onClick:w?void 0:D=>i?.(t,s,D),children:o.jsx(h,{children:o.jsx(y,{children:(t.month===n.monthInYear||_)&&o.jsxs(o.Fragment,{children:[d&&o.jsx(d,{week:r,month:n,day:t,dayState:a,theme:c,userData:s}),p]})})})})},tr=(e,t)=>!!re(t,e,["enabled","disabled"],[!1,!0],!1),kt=({onClickWeek:e,theme:t,week:r,background:n,backgroundColor:a,prefix:s})=>{const i=o.jsxs(g.Box,{width:t.width,height:t.height,justifyContent:"center",alignItems:"center",children:[n&&o.jsx(g.Box,{position:"absolute",children:n}),o.jsx(g.Box,{position:"absolute",children:o.jsxs(g.Text,{color:e?t.WeekNumber.clickableTextColor:t.WeekNumber.textColor,children:[s,r.weekNumber]})})]});return o.jsx(g.Box,{background:a||t.WeekNumber.backgroundColor,position:"relative",children:e?o.jsx(g.Clickable,{borderRadius:"var(--swui-calendar-day-border-radius)",onClick:c=>e(r,c),disableFocusHighlight:!e,children:i}):i})},rr=(e,t,r)=>t&&u.isBefore(e,t)?u.isSameDay(e,t):r&&u.isAfter(e,r)?u.isSameDay(e,r):!0,nr=function({dayComponent:t,minDate:r,maxDate:n,dayState:a,day:s,...i}){const c=l.useMemo(()=>rr(s.date,r,n)?a:Ge(a,["disabled"]),[s.date,a,n,r]);return o.jsx(t,{day:s,...i,dayState:c})};function ar({month:e,dayComponent:t=Je,statePerWeek:r,userDataPerWeek:n,minDate:a,maxDate:s,onClickDay:i,onClickWeek:c,onClickWeekDay:d,onClickMonth:f,renderWeekNumber:_,renderWeekDay:p,headerRightContent:m,theme:h=ie,extraDayContent:y,defaultHighlights:w,showWeekNumber:D}){return o.jsx(o.Fragment,{children:o.jsxs(g.Box,{alignItems:"stretch",children:[o.jsxs(g.Row,{justifyContent:m?"space-between":"center",alignItems:"center",children:[o.jsx(g.Row,{justifyContent:"center",alignItems:"center",children:f?o.jsx(C.FlatButton,{onClick:()=>f(e),label:e.name+" "+String(e.year),rightIcon:C.stenaAngleDown}):o.jsxs(g.Text,{whiteSpace:"nowrap",children:[e.name," ",e.year]})}),m&&o.jsx(g.Box,{alignItems:"center",children:m})]}),o.jsx("table",{children:o.jsxs("tbody",{children:[o.jsxs("tr",{children:[D&&o.jsx("td",{children:o.jsx(g.Box,{width:h.width,height:h.height})}),e.weeks[0].days.map(k=>o.jsx("td",{children:p?p(k.name,h,d):o.jsx(Dt,{day:k,onClickWeekDay:d,theme:h})},k.name))]}),e.weeks.map(k=>o.jsxs("tr",{children:[D&&o.jsx("td",{children:_?_(k,h,c):o.jsx(kt,{week:k,onClickWeek:c,theme:h})}),k.days.map(b=>o.jsx(nr,{dayComponent:t,day:b,week:k,month:e,dayState:r&&r[k.weekNumber]&&r[k.weekNumber][b.dayOfMonth],userData:n&&n[k.weekNumber]&&n[k.weekNumber][b.dayOfMonth],onClickDay:i,theme:h,extraDayContent:y,defaultHighlights:w,minDate:a,maxDate:s},b.dateString))]},k.weekNumber))]})})]})})}function sr({monthRows:e,dayComponent:t=Je,userDataPerMonth:r,statePerMonth:n,minDate:a,maxDate:s,onClickDay:i,onClickWeekDay:c,onClickWeek:d,onClickMonth:f,renderWeekDay:_,renderWeekNumber:p,headerRightContent:m,extraDayContent:h,defaultHighlights:y,showWeekNumber:w,theme:D=ie}){const k=l.useMemo(()=>a?u.parse(a,"yyyy-MM-dd",new Date):void 0,[a]),b=l.useMemo(()=>s?u.parse(s,"yyyy-MM-dd",new Date):void 0,[s]);return o.jsx("div",{className:J(at.calendar,w&&at.weekNumberVisible),children:e.map((x,v)=>o.jsx(g.Spacing,{children:o.jsx(g.Row,{gap:2,children:x.map(S=>o.jsx(ar,{month:S,dayComponent:t,userDataPerWeek:r&&r[S.monthString],statePerWeek:n&&n[S.monthString],onClickDay:i,onClickWeekDay:c,onClickWeek:d,onClickMonth:f,theme:D,renderWeekNumber:p,renderWeekDay:_,headerRightContent:m,extraDayContent:h,defaultHighlights:y,minDate:k,maxDate:b,showWeekNumber:w??!1},S.name))})},v))})}function Me(e){const t=or(e.year,e.month,e.date),{year:r,month:n}=yt(t.year,t.month),a=lr(r,n,e.locale??T.enGB,e.numMonths,e.monthsPerRow),s=Qt(e.highlightToday,e.statePerMonth);return o.jsx(sr,{year:r,month:n,monthRows:a,...e,statePerMonth:s})}const or=(e,t,r)=>{if(t&&e)return{month:t,year:e};if(r)return{month:u.getMonth(r),year:u.getYear(r)};const n=new Date;return{month:u.getMonth(n),year:u.getYear(n)}},lr=(e,t,r,n,a)=>n==null?[[ve(e,t,r)]]:a==null?[Ue(e,t,n,r)]:le.chunk(Ue(e,t,n,r),a),Ct=(e,t)=>`${e.row}-${e.column}-${t}`,ir=(e,t,r,n)=>{let a=t;for(let s=0;s<n;s++){a=cr(a,e,n);const i=Ct(a,r);if(document.getElementById(i))return i}},cr=(e,t,r)=>{let n=e.row,a=e.column;return t==="ArrowLeft"?a--:t==="ArrowUp"?n--:t==="ArrowRight"?a++:t==="ArrowDown"&&n++,a<0&&(a=r-1,n--),a>r-1&&(a=0,n++),{column:a,row:n}},he={en:T.enGB,"en-US":T.enUS,"en-GB":T.enGB,"en-IE":T.enIE,"de-AT":T.deAT,"nl-BE":T.nlBE,"nl-NL":T.nl,"de-DE":T.de,"nb-NO":T.nb,"sv-SE":T.sv,"da-DK":T.da,"lv-LV":T.lv,"lt-LT":T.lt,"it-IT":T.it,"et-EE":T.et,"fi-FI":T.fi,"cs-CZ":T.cs,"es-ES":T.es,"fr-FR":T.fr,"pl-PL":T.pl,nl:T.nl,de:T.de,nb:T.nb,sv:T.sv,da:T.da,lv:T.lv,lt:T.lt,it:T.it,et:T.et,fi:T.fi,cs:T.cs,es:T.es,fr:T.fr,pl:T.pl},Qe="en-GB",ur="sv",Ze=(e,t,r)=>{if(he[e])return e;if(t){const n=St(e);if(n)return n}return r},ue=e=>he[e],St=e=>{const[t]=e.split("-"),r=Object.keys(he);for(const n of r)if(n.startsWith(t))return n},dr=()=>he.sv,jt=e=>{const t=Object.keys(he);for(const r of t)if(he[r].code===e.code)return r},fr=({month:e,onClick:t,selected:r,localeCode:n,autoFocus:a,monthPickerId:s,position:i,size:c})=>{const d=l.useMemo(()=>ue(n)??ue("en-GB"),[n]),f=l.useMemo(()=>Te(u.format(e,"LLL",{locale:d})),[d,e]),_=l.useMemo(()=>u.format(e,"LLLL",{locale:d}),[d,e]),p=l.useRef(null),m=Ct(i,s),h=r?0:-1;l.useEffect(()=>{p.current?.focus()},[]);const y=l.useCallback(w=>{const D=ir(w.key,i,s,4);D&&document.getElementById(D)?.focus()},[s,i]);return o.jsx(g.Row,{justifyContent:"center",onKeyDown:y,children:r?o.jsx(C.PrimaryButton,{id:m,"aria-label":_,label:f,onClick:t,"aria-selected":!0,autoFocus:a,ref:p,size:c==="large"?"large":"medium",tabIndex:h}):o.jsx(C.FlatButton,{id:m,label:f,"aria-label":_,onClick:t,size:c==="large"?"large":"medium",tabIndex:h})})},_r=(e,t,r)=>{let n=e.getFullYear(),a=0,s=0,i=e;const c={yearOrder:[],rows:[],years:{},lastMonthColumn:-1,lastMonthRow:-1};for(let d=0;d<t;d++){if(c.years[n]==null&&(c.yearOrder.push(n),c.years[n]={year:n,rows:[]}),c.rows[a]=c.rows[a]??{columns:[],rowIndex:a},c.rows[a].columns[s]={position:{column:s,row:a},month:i},d===t-1){c.years[n].rows.push(a);break}i=u.addMonths(i,1),i.getFullYear()!==n?(c.years[n].rows.push(a),n++,s=0,a++):(s++,s>r-1&&(c.years[n].rows.push(a),s=0,a++))}return c.lastMonthColumn=s,c.lastMonthRow=a,c},pe=({value:e,onValueChange:t,firstMonth:r,localeCode:n,numMonths:a,onCancel:s,size:i="medium"})=>{const c=l.useId(),d=g.useToday(),f=a>0?a:12,[_,p]=l.useState(!1),m=_r(r,f,hr(i)),h=l.useMemo(()=>u.addMonths(r,f),[f,r]);l.useEffect(()=>{p(!0)},[]);const y=l.useCallback(w=>{w.key==="Escape"&&(s?.(),w.preventDefault(),w.stopPropagation())},[s]);return o.jsx(g.Column,{gap:1,maxWidth:gr(i),onKeyDown:y,children:m.yearOrder.map((w,D)=>{const{rows:k}=m.years[w];return o.jsxs(Ke.Fragment,{children:[(D!==0||w!==d.getFullYear())&&o.jsx(g.Heading,{variant:"h4",children:w}),o.jsx("table",{style:{borderSpacing:"0 8px"},children:o.jsx("tbody",{children:k.map(b=>{const{columns:x}=m.rows[b];return o.jsx("tr",{children:x.map(({month:v,position:S})=>o.jsx("td",{children:o.jsx(fr,{month:v,firstAvailableMonth:r,lastAvailableMonth:h,localeCode:n,selected:e?u.isSameMonth(e,v):!1,autoFocus:_,onClick:()=>t?.(v),monthPickerId:c,position:S,size:i})},v.getMonth()))},b)})})})]},w)})})},gr=e=>{switch(e){case"smaller":return"280px";case"small":return"308px";case"medium":return"336px";case"large":return"448px";default:return g.exhaustSwitchCase(e,"336px")}},hr=e=>{switch(e){case"smaller":case"small":return 3;case"medium":case"large":return 4;default:return g.exhaustSwitchCase(e,4)}},pr=e=>[{label:"Past",presets:[{label:"Last 3 days",startDate:e,endDate:u.subDays(e,2)},{label:"Last 7 days",startDate:e,endDate:u.subDays(e,6)},{label:"Last 30 days",startDate:e,endDate:u.subDays(e,29)},{label:"Last 45 days",startDate:e,endDate:u.subDays(e,44)}]},{label:"Future",presets:[{label:"Next 3 days",startDate:e,endDate:u.addDays(e,2)},{label:"Next 7 days",startDate:e,endDate:u.addDays(e,6)},{label:"Next 30 days",startDate:e,endDate:u.addDays(e,29)},{label:"Next 45 days",startDate:e,endDate:u.addDays(e,44)}]}],Mt=({onClickPreset:e})=>{const[t,r]=l.useState(0),n=l.useMemo(()=>pr(new Date),[]),a=n[t]??n[0];return o.jsxs(g.Column,{children:[o.jsxs(g.Row,{justifyContent:"space-between",alignItems:"center",width:"200px",children:[o.jsx(C.FlatButton,{size:"small",leftIcon:C.stenaAngleLeft,disabled:t===0,onClick:()=>r(t-1)}),o.jsx(g.Text,{children:a.label}),o.jsx(C.FlatButton,{size:"small",leftIcon:C.stenaAngleRight,disabled:t===n.length-1,onClick:()=>r(t+1)})]}),o.jsx(g.Space,{}),o.jsx(g.Column,{alignItems:"center",children:a.presets.map(s=>o.jsxs(Ke.Fragment,{children:[o.jsx(C.PrimaryButton,{label:s.label,onClick:()=>e(s)}),o.jsx(g.Space,{})]},s.label))})]})},mr=function({locale:t,dateInFocus:r,setDateInFocus:n,currentPanel:a,setCurrentPanel:s,renderMonthPicker:i,firstMonthInMonthPicker:c,numMonthsInMonthPicker:d,...f}){const _=l.useMemo(()=>t==null?"en-GB":jt(t)??"en-GB",[t]),p=g.useToday(),m=l.useCallback(y=>{n&&n(y),s("calendar")},[n,s]),h=l.useCallback(()=>{s("month")},[s]);switch(a){case"calendar":return o.jsx(Me,{...f,date:r,onClickMonth:h,locale:t});case"month":return i?i({value:r,onValueChange:m,locale:t,firstMonth:c??p,numMonths:d??24,dateInFocus:r}):o.jsx(pe,{value:r,onValueChange:m,localeCode:_,firstMonth:c??p,numMonths:d??24});case"presets":return o.jsx(Mt,{onClickPreset:()=>{}});default:return o.jsx(g.Box,{children:o.jsx(C.PrimaryButton,{label:"Show calendar",onClick:()=>s("calendar")})})}},br=(e,t,r,n)=>{const a=l.useCallback(()=>{const d=u.addMonths(e,r??n??1);t?.(d)},[t,e,r,n]),s=l.useCallback(()=>{const d=u.addYears(e,1);t?.(d)},[t,e]),i=l.useCallback(()=>{const d=u.subMonths(e,r??n??1);t?.(d)},[t,e,r,n]),c=l.useCallback(()=>{const d=u.subYears(e,1);t?.(d)},[t,e]);return{nextMonth:a,prevMonth:i,nextYear:s,prevYear:c}},yr=({children:e,prevMonth:t,nextMonth:r,prevYear:n,nextYear:a})=>o.jsxs("div",{children:[e,o.jsx(g.Indent,{children:o.jsxs(g.Row,{gap:1,children:[o.jsx(C.SecondaryButton,{onClick:n,leftIcon:C.stenaAngleLeftDouble}),o.jsx(C.SecondaryButton,{onClick:t,leftIcon:C.stenaArrowLeft}),o.jsx(g.Indent,{num:2}),o.jsx(C.SecondaryButton,{onClick:r,leftIcon:C.stenaArrowRight}),o.jsx(C.SecondaryButton,{onClick:a,leftIcon:C.stenaAngleRightDouble})]})}),o.jsx(g.Space,{})]}),vr=()=>{};function de({monthSwitcherPlacement:e,theme:t=ie,dateInFocus:r,setDateInFocus:n,currentPanel:a,setCurrentPanel:s,onSelectPreset:i=vr,renderMonthPicker:c,firstMonthInMonthPicker:d,numMonthsInMonthPicker:f,..._}){const{nextMonth:p,prevMonth:m,nextYear:h,prevYear:y}=br(r,n,_.monthsPerRow,_.numMonths);switch(xr(e,_.numMonths)){case"below":return o.jsx(yr,{theme:t,nextMonth:p,prevMonth:m,nextYear:h,prevYear:y,children:o.jsx(Me,{..._,theme:t,date:r})});case"header":return o.jsx(g.Column,{children:o.jsx(mr,{..._,theme:t,renderMonthPicker:c,dateInFocus:r,setDateInFocus:n,currentPanel:a,setCurrentPanel:s,onSelectPreset:i,firstMonthInMonthPicker:d,numMonthsInMonthPicker:f,headerRightContent:o.jsxs(g.Row,{alignItems:"center",gap:1,children:[o.jsx(C.SecondaryButton,{onClick:m,leftIcon:C.stenaArrowLeft}),o.jsx(C.SecondaryButton,{onClick:p,leftIcon:C.stenaArrowRight})]})})});default:return o.jsx(Me,{..._,theme:t,date:r})}}const xr=(e,t)=>e||(t||1)>1?"below":"header",Bt=e=>({startDate:e.startDate?u.format(e.startDate,"yyyy-MM-dd"):void 0,endDate:e.endDate?u.format(e.endDate,"yyyy-MM-dd"):void 0}),Rt=({startDate:e,endDate:t})=>{const r=new Date;return{startDate:e?u.parse(e,"yyyy-MM-dd",r):void 0,endDate:t?u.parse(t,"yyyy-MM-dd",r):void 0}},Xe=({startDate:e,endDate:t})=>!!(e&&t&&!u.isSameDay(e,t)&&u.isAfter(e,t)),et=e=>Xe(e)?{startDate:e.endDate,endDate:e.startDate}:e,wr=e=>e.startDate&&e.endDate?Bt(et(Rt(e))):e,Dr=(e,t,r,n)=>l.useCallback(a=>{const s={startDate:r==="startDate"?a.date:e?.startDate,endDate:r==="endDate"?a.date:e?.endDate};Xe(s)||n(r==="startDate"?"endDate":"startDate"),t?.(et(s))},[r,t,n,e?.endDate,e?.startDate]),Ne=e=>{const[t,r]=l.useState("calendar"),n=l.useCallback(a=>{r(a),e?.(a)},[e]);return{currentPanel:t,setCurrentPanel:n}},It=({focusedInput:e,value:t,onValueChange:r,setFocusedInput:n,statePerMonth:a,onChangePanel:s,initialDateInFocus:i})=>{const{currentPanel:c,setCurrentPanel:d}=Ne(s),[f,_]=l.useState(()=>i??new Date),p=Dr(t,r,e,n),m=l.useMemo(()=>ge(a,t?.startDate,t?.endDate),[a,t?.endDate,t?.startDate]);return{onClickDay:p,statePerMonth:m,currentPanel:c,setCurrentPanel:d,setDateInFocus:_,dateInFocus:f}};function kr(e){const t=It(e);return o.jsx(de,{...e,...t})}const Cr=()=>{const[e,t]=l.useState(),[r,n]=l.useState(),[a,s]=l.useState("startDate");return{startDate:e,setStartDate:t,endDate:r,setEndDate:n,focusedInput:a,setFocusedInput:s}},Tt=({onChange:e,value:t,statePerMonth:r,onChangePanel:n})=>{const{currentPanel:a,setCurrentPanel:s}=Ne(n),[i,c]=l.useState(()=>t??new Date),d=l.useCallback(_=>{e&&e(_.date)},[e]),f=l.useMemo(()=>t?ne(r,t,["selected","singleSelected"]):r,[r,t]);return{onClickDay:d,statePerMonth:f,date:t,currentPanel:a,setCurrentPanel:s,dateInFocus:i,setDateInFocus:c}};function tt(e){const t=Tt(e);return o.jsx(de,{...e,...t})}const Et=({onChange:e,value:t,statePerMonth:r,onChangePanel:n,initialDateInFocus:a})=>{const{currentPanel:s,setCurrentPanel:i}=Ne(n),[c,d]=l.useState(a??new Date),f=l.useCallback(p=>{if(!e)return;const m=t&&t.find(h=>u.isSameDay(h,p.date));e(t&&m?t.filter(h=>!u.isSameDay(h,p.date)):[...t||[],p.date])},[e,t]),_=l.useMemo(()=>t?t.reduce((p,m)=>ne(p,m,["selected"]),r):r,[r,t]);return{onClickDay:f,statePerMonth:_,currentPanel:s,setCurrentPanel:i,dateInFocus:c,setDateInFocus:d}};function Sr(e){const t=Et(e);return o.jsx(de,{...e,...t})}const Nt=({onChange:e,value:t,statePerMonth:r,onChangePanel:n,locale:a=T.enGB})=>{const[s,i]=l.useState(()=>{const h=We(t,a);return h?h.days[0].date:new Date}),{currentPanel:c,setCurrentPanel:d}=Ne(n),f=l.useCallback(h=>{e&&e(st(Ee(h.date,a)))},[a,e]),_=l.useCallback(h=>{e&&e(st(h))},[e]),p=l.useMemo(()=>{const h=We(t,a);return h?_t(r,h):r},[t,a,r]),m=l.useMemo(()=>{const h=We(t,a);return h?h.days[0].date:new Date},[a,t]);return{statePerMonth:p,date:m,dateInFocus:s,setDateInFocus:i,onClickDay:f,onClickWeek:_,currentPanel:c,setCurrentPanel:d}},st=e=>{if(e)return`${e.endYear}-${e.weekNumber}`},We=(e,t)=>{if(!e)return;const r=e.split("-"),n=parseInt(r[1],10),a=parseInt(r[0],10),s=new Date;s.setFullYear(a);const i=u.startOfWeek(u.setWeek(s,n),{locale:t});return Ee(i,t)};function jr(e){const t=Nt(e);return o.jsx(de,{...e,...t})}const xe="bottom",Mr=(e,t,r)=>{const[n,a]=l.useState(r||!1),s=l.useCallback(()=>(a(!0),!0),[a]),i=l.useCallback(()=>{a(!1),t&&t()},[a,t]),c=l.useCallback(d=>{e&&e(d),setTimeout(i,150)},[e,i]);return{showCalendar:s,hideCalendar:i,showingCalendar:n,onSelectDate:c}},we="2999-12-31",Br=({displayFormat:e=ae.fullDate,placeholder:t="Enter date",value:r,calendarTheme:n=ie,calendarProps:a,openOnMount:s,onClose:i,onChange:c,variant:d,width:f,minDate:_,maxDate:p=we,disabled:m,portalTarget:h,zIndex:y})=>{const{hideCalendar:w,showingCalendar:D,onSelectDate:k,showCalendar:b}=Mr(c,i,s);return o.jsx(g.Box,{width:f,children:o.jsx(ye.ControlledPopover,{hideArrow:!0,open:D,onRequestClose:w,appendTo:h,zIndex:y,renderTrigger:x=>o.jsx(g.Box,{...x,children:o.jsx(ee.TextInput,{type:"date",onFocus:b,buttonRight:o.jsx(C.TextInputButton,{onClick:b,icon:C.stenaCalendar}),value:r?u.format(r,e):"",placeholder:t,size:9,disabled:m,autoFocus:s,variant:d,min:_,max:p})}),placement:xe,children:o.jsx(tt,{...a,onChange:k,value:r,theme:n,minDate:_,maxDate:p})})})},Rr=(e,t)=>{const r=l.useRef(null),n=l.useRef(null),[a,s]=l.useState(!1),[i,c]=l.useState(void 0),d=l.useCallback(()=>(c("startDate"),s(!0),!0),[c,s]),f=l.useCallback(()=>(c("endDate"),s(!0),!0),[c,s]),_=l.useCallback(()=>{s(!1)},[s]),p=l.useCallback(h=>{i==="startDate"?(t?.({startDate:h.date,endDate:e?.endDate}),e?.endDate?setTimeout(_,150):(c("endDate"),n.current?.focus())):i==="endDate"&&(t?.({startDate:e?.startDate,endDate:h.date}),e?.startDate?setTimeout(_,150):(c("startDate"),r.current?.focus()))},[i,t,c,_,e]),m=l.useMemo(()=>e?.startDate&&e?.endDate&&u.isAfter(e.startDate,e.endDate),[e?.startDate,e?.endDate]);return{showingCalendar:a,hideCalendar:_,showCalendarEndDate:f,showCalendarStartDate:d,focusedInput:i,setFocusedInput:c,startDateInputRef:r,endDateInputRef:n,onClickDay:p,startDateIsAfterEnd:m}};function Ir({displayFormat:e=ae.fullDate,placeholderStartDate:t="Start date",placeholderEndDate:r="End date",value:n,onValueChange:a,width:s,calendarTheme:i=ie,calendarProps:c,minDate:d,maxDate:f=we,disabled:_,portalTarget:p,zIndex:m}){const[h,y]=l.useState("calendar"),{hideCalendar:w,showCalendarEndDate:D,showCalendarStartDate:k,showingCalendar:b,focusedInput:x,startDateInputRef:v,endDateInputRef:S,onClickDay:j,startDateIsAfterEnd:M}=Rr(n,a),[E,B]=l.useState(()=>(x&&n?.[x])??new Date),I=l.useMemo(()=>ge(void 0,n?.startDate,n?.endDate),[n]);return o.jsx(ye.ControlledPopover,{hideArrow:!0,appendTo:p,zIndex:m,renderTrigger:F=>o.jsxs(g.Row,{alignItems:"center",...F,children:[o.jsx(ee.TextInput,{iconLeft:C.stenaCalendar,onFocus:k,value:n?.startDate?u.format(n.startDate,e):"",placeholder:t,width:s,disabled:_,inputRef:v,size:9,variant:M?"error":void 0}),o.jsx(g.Space,{}),o.jsx(C.Icon,{icon:C.stenaArrowWideRight,color:qe.cssColor("--lhds-color-ui-500"),size:14}),o.jsx(g.Space,{}),o.jsx(ee.TextInput,{iconLeft:C.stenaCalendar,onFocus:D,value:n?.endDate?u.format(n.endDate,e):"",placeholder:r,width:s,disabled:_,inputRef:S,size:9,variant:M?"error":void 0})]}),open:b,placement:xe,onRequestClose:w,children:o.jsx(de,{...c,dateInFocus:E,setDateInFocus:B,statePerMonth:I,theme:i,onClickDay:j,currentPanel:h,setCurrentPanel:y,minDate:d,maxDate:f})})}const Tr=({calendarProps:e,closeOnCalendarSelectDate:t=!0,dateFormat:r=ae.fullDate,disableCalender:n=!1,onValueChange:a,placeholder:s="yyyy-mm-dd",value:i,width:c="130px",calendarTheme:d=ie,hideCalenderIcon:f=!1,minDate:_,maxDate:p=we,variant:m,portalTarget:h,zIndex:y,...w})=>{const[D,k]=l.useState(!1),b=l.useCallback(()=>{k(!D)},[k,D]),x=l.useCallback(()=>{k(!1)},[k]),v=l.useCallback(I=>{a&&a(I)},[a]),S=l.useCallback(I=>{I&&(v(u.format(I,r)),t&&setTimeout(()=>k(!D),200))},[v,r,t,k,D]),j=!!i&&!/^[-/\\.0-9]+$/.test(i),M=!!i&&u.isValid(u.parse(i,r,new Date)),B=!!i&&i.length>=r.length&&!M||j;return o.jsx(g.Box,{width:c,children:o.jsx(ye.ControlledPopover,{appendTo:h,zIndex:y,renderTrigger:({ref:I,...F})=>o.jsx(ee.TextInput,{...w,variant:B?"error":m,disableContentPaddingRight:!0,contentRight:f?void 0:o.jsx(g.Row,{alignItems:"center",indent:.5,children:o.jsx(C.FlatButton,{size:"small",disabled:w.disabled||n,leftIcon:C.stenaCalendar,onClick:b})}),onValueChange:v,placeholder:s,value:i||"",min:_,max:p,size:10,inputRef:I,...F}),hideArrow:!0,open:D,placement:xe,onRequestClose:x,children:o.jsx(tt,{...e,onChange:S,value:i&&M?u.parse(i,r,new Date):void 0,minDate:_,maxDate:p,theme:d})})})},Be=e=>{if(e==="")return"00";const t=parseInt(e,10);if(isNaN(t))throw new Error("Hours is not a number");if(t<0||t>23)throw new Error("Hours is an invalid number");switch(e.length){case 1:return`0${t}`;case 2:return e;default:throw new Error("Invalid hour string")}},Re=e=>{if(e==="")return"00";const t=parseInt(e,10);if(isNaN(t))throw new Error("Minutes is not a number");if(t<0||t>59)throw new Error("Minutes is an invalid number");switch(e.length){case 1:return`0${t}`;case 2:return e;default:throw new Error("Invalid minute string")}},Er=e=>{if(!ze(e))return{time:e,success:!1};const t=e&&e.split(/-|:|,|;|[/]|[.]| /);if(t&&t.length===2)try{const r=Be(t[0]),n=Re(t[1]);return{time:`${r}:${n}`,success:!0}}catch{return{time:e,success:!1}}else if(t&&t.length===1){let r=0,n=0;switch(e.length){case 1:return{time:`0${e}:00`,success:!0};case 2:{const a=parseInt(t[0],10);return a>=0&&a<24?{time:`${e}:00`,success:!0}:a>=24&&a<59?{time:`00:${e}`,success:!0}:{time:e,success:!1}}case 3:return n=parseInt(e.substring(1,3),10),n>=0&&n<=59?{time:`0${e.substring(0,1)}:${e.substring(1,3)}`,success:!0}:{time:e,success:!1};case 4:return r=parseInt(e.substring(0,2),10),n=parseInt(e.substring(2,4),10),r<0||r>23?{time:e,success:!1}:n<0||n>59?{time:e,success:!1}:{time:`${e.substring(0,2)}:${e.substring(2,4)}`,success:!0};default:return{time:e,success:!1}}}return{time:e,success:!1}},ze=e=>e?/^[-:.,/; 0-9]+$/.test(e):!0,Nr=({onValueChange:e,showPlaceholder:t=!0,useIcon:r=!0,value:n,width:a="85px",variant:s,...i})=>{const[c,d]=l.useState(()=>ze(n)),f="hh:mm",_=l.useCallback(()=>{if(n){const m=Er(n);d(m.success),m.success&&e&&e(m.time)}},[n,e,d]),p=l.useCallback(m=>{const h=m.target.value,y=ze(h);d(y&&h.length<=f.length),e&&e(h)},[e,d]);return o.jsx(ee.TextInput,{...i,type:"time",variant:c?s:"error",iconLeft:r?C.stenaClock:void 0,value:n,placeholder:t?f:void 0,onChange:p,onBlur:_,width:a})},Ft=({autoFocusLeft:e,autoFocusRight:t,onEsc:r,onEnter:n,onValueChangeLeft:a,onValueChangeRight:s,separatorIcon:i,placeholderLeft:c,placeholderRight:d,typeLeft:f,typeRight:_,onChangeLeft:p,onChangeRight:m,valueLeft:h,valueRight:y,minLeft:w,maxLeft:D,minRight:k,maxRight:b,onClickLeft:x,onClickRight:v,onClickCalendar:S,onClickArrowDown:j,onBlurLeft:M,onBlurRight:E,onFocusLeft:B,onFocusRight:I,inputRefLeft:F,inputRefRight:P,variant:N,variantLeft:L,variantRight:z,onBlur:$,showPresets:R,widthLeft:U,widthRight:O,disabled:Y})=>{const W=l.useRef(0),A=l.useMemo(()=>le.debounce(H=>{H===0&&$?.()},10),[$]),V=l.useCallback(H=>{W.current++,A(W.current),B&&B(H)},[B,W,A]),K=l.useCallback(H=>{W.current++,A(W.current),I&&I(H)},[I,W,A]),Q=l.useCallback(H=>{W.current--,A(W.current),M&&M(H)},[M,W,A]),se=l.useCallback(H=>{W.current--,A(W.current),E&&E(H)},[E,W,A]);return o.jsx(g.Box,{children:o.jsxs(ee.TextInputBox,{disableContentPaddingRight:!0,disabled:Y,variant:N,contentRight:o.jsxs(g.Row,{alignItems:"center",children:[o.jsx(g.Indent,{num:.5,children:o.jsx(C.FlatButton,{leftIcon:C.stenaCalendar,onClick:S,disabled:Y,size:"small"})}),R?o.jsxs(o.Fragment,{children:[o.jsx(g.Row,{height:"22px",children:o.jsx(g.SeparatorLine,{vertical:!0})}),o.jsx(g.Indent,{num:.5,children:o.jsx(C.FlatButton,{leftIcon:C.stenaAngleDown,onClick:j,disabled:Y,size:"small"})})]}):null]}),children:[o.jsx(g.Box,{width:U,children:o.jsx(ee.TextInput,{onEsc:r,onEnter:n,onClick:x,disabled:Y,hideBorder:!0,placeholder:c,value:h,onValueChange:a,onChange:p,onBlur:Q,onFocus:V,inputRef:F,variant:L,type:f,autoFocus:e,min:w,max:D})}),o.jsx(g.Row,{indent:.5,alignItems:"center",justifyContent:"center",children:o.jsx(C.Icon,{icon:i,size:12,color:qe.cssColor("--lhds-color-ui-500")})}),o.jsx(g.Box,{width:O,children:o.jsx(ee.TextInput,{onEsc:r,onEnter:n,onClick:v,disabled:Y,hideBorder:!0,placeholder:d,value:y,onValueChange:s,onChange:m,onBlur:se,onFocus:K,inputRef:P,variant:z,type:_,autoFocus:t,min:k,max:b})})]})})},Fr=e=>{if(e==null)throw new Error("Time is not set.");if(e==="")throw new Error("Time is empty.");const t=e.split(":");if(t.length!==2)throw new Error("Invalid time.");if(t[1].length!==2)throw new Error("Invalid time.");if(t[0].length<1||t[0].length>2)throw new Error("Invalid time.");const r=parseInt(t[0],10),n=parseInt(t[1],10);if(isNaN(r))throw new Error("Invalid time.");if(isNaN(n))throw new Error("Invalid time.");if(r<0||r>23)throw new Error("Invalid time.");if(n<0||n>59)throw new Error("Invalid time.");return r*100+n},Lr=e=>{try{return Fr(e),!0}catch{return!1}},je=e=>{if(e&&Lr(e)){const t=e.split(":");return{hour:g.parseIntElseUndefined(t[0]),minute:g.parseIntElseUndefined(t[1])}}return{hour:void 0,minute:void 0}},Ar=e=>`${Be(String(e.getHours()))}:${Re(String(e.getMinutes()))}`,Pr="_timePicker_1w05d_1",Wr="_timePickerColumn_1w05d_6",Lt={timePicker:Pr,timePickerColumn:Wr},Hr=({onClick:e,item:t,selected:r,columnRef:n,canScrollRef:a})=>{const s=l.useRef(null);return l.useEffect(function(){if(r&&n.current&&s.current&&a.current){const c=s.current.scrollHeight*Math.max(t-2,0);n.current.scrollTo(0,c),a.current=!1}},[n,t,r,a]),o.jsx(g.Row,{width:"64px",justifyContent:"center",spacing:.5,indent:.5,ref:s,children:r?o.jsx(C.PrimaryButton,{label:le.padStart(String(t),2,"0"),onClick:()=>e&&e(t)}):o.jsx(C.FlatButton,{label:String(t).padStart(2,"0"),onClick:()=>e&&e(t)})})},ot=({onClick:e,items:t,selectedItem:r,canScrollRef:n})=>{const a=l.useRef(null);return o.jsx(g.Column,{className:Lt.timePickerColumn,ref:a,children:t.map(s=>o.jsx(Hr,{item:s,onClick:e,selected:s===r,columnRef:a,canScrollRef:n},s))})},Or=le.range(0,24),Yr=le.range(0,60),Ur=({value:e,onValueChange:t})=>{const r=l.useRef(!0),[n,a]=l.useState(void 0),[s,i]=l.useState(void 0);l.useEffect(()=>{if(e){const{minute:f,hour:_}=je(e);a(_),i(f)}},[e]);const c=l.useCallback(f=>{a(f),t?.(`${Be(String(f??0))}:${Re(String(s??0))}`)},[s,t]),d=l.useCallback(f=>{i(f),t?.(`${Be(String(n??0))}:${Re(String(f??0))}`)},[n,t]);return o.jsxs(g.Row,{className:Lt.timePicker,children:[o.jsx(ot,{items:Or,onClick:c,selectedItem:n,canScrollRef:r}),o.jsx(g.Indent,{}),o.jsx(ot,{items:Yr,onClick:d,selectedItem:s,canScrollRef:r})]})},zr=(e,t,r)=>{l.useEffect(function(){e&&t(e)},[e,t]),l.useEffect(function(){r.current&&(e?r.current.valueAsDate=new Date(Date.UTC(e.getFullYear(),e.getMonth(),e.getDate())):r.current.valueAsDate=null)},[e,r])},$r=(e,t,{setDateInFocus:r,showCalendarInternal:n,hideCalendarInternal:a,setFirstFocusedInput:s,setCurrentPanel:i,localTime:c,setLocalTime:d,localDate:f,setLocalDate:_},p)=>{const m=l.useCallback(b=>{if(!b)return;const x=new Date(b);if(e)x.setHours(e.getHours()),x.setMinutes(e.getMinutes()),t?.(x),_(void 0);else if(c){const{minute:v,hour:S}=je(c);x.setHours(S??0),x.setMinutes(v??0),t?.(x),_(void 0)}else _(x);r(x),p.current&&(p.current.valueAsDate=new Date(Date.UTC(x.getFullYear(),x.getMonth(),x.getDate())))},[e,p,c,t,r,_]),h=l.useCallback(b=>{if(b)if(e){const x=je(b),v=new Date(e);v.setHours(x.hour||0),v.setMinutes(x.minute||0),t?.(v),d(void 0)}else if(f){const x=je(b),v=new Date(f);v.setHours(x.hour||0),v.setMinutes(x.minute||0),t?.(v),d(void 0)}else d(b)},[t,e,f,d]),y=l.useCallback(b=>{b.target.value[0]!=="0"&&m(b.target.valueAsDate)},[m]),w=l.useCallback(b=>h(b.target.value),[h]),D=l.useCallback(()=>{r(e||new Date),i("calendar"),n()},[e,i,n,r]),k=l.useCallback(()=>{s(void 0),a()},[s,a]);return{inputLeftChangeHandler:y,inputRightChangeHandler:w,hideCalendar:k,showCalendar:D,onChangeTime:h,onChangeDate:m}},Vr=e=>{const[t,r]=l.useState(void 0),[n,a]=l.useState(void 0),[s,i,c]=g.useBoolean(!1),[d,f,_]=g.useBoolean(!1),[p,m]=l.useState(void 0),[h,y]=l.useState(()=>e??new Date),[w,D]=l.useState("calendar");return{isCalendarVisible:s,showCalendarInternal:i,hideCalendarInternal:c,firstFocusedInput:p,setFirstFocusedInput:m,dateInFocus:h,setDateInFocus:y,currentPanel:w,setCurrentPanel:D,isTimePickerVisible:d,showTimePicker:f,hideTimePicker:_,localDate:t,setLocalDate:r,localTime:n,setLocalTime:a}},qr=(e,t,r,n,{isCalendarVisible:a,setCurrentPanel:s,showTimePicker:i,hideTimePicker:c})=>{const d=l.useCallback(()=>{a||r(),s("calendar"),c()},[c,a,s,r]),f=l.useCallback(()=>{n(),i()},[n,i]),_=l.useCallback(y=>{e(y.date),n(),i()},[e,n,i]),p=l.useCallback(()=>{s("presets"),r()},[s,r]),m=l.useCallback(()=>{a?n():(t.current?.focus(),s("calendar"),r())},[a,n,t,s,r]),h=l.useCallback(y=>{y.key==="Escape"&&n()},[n]);return{onFocusLeft:d,onFocusRight:f,onClickDay:_,onClickArrowButton:p,onClickCalendarButton:m,onKeyDownHandler:h}},Kr=({value:e,onValueChange:t,onEnter:r,onEsc:n,onBlur:a,autoFocus:s,minDate:i,widthLeft:c=128,widthRight:d=80,maxDate:f=we,variant:_,disabled:p,zIndex:m,appendTo:h})=>{const y=l.useRef(null),w=l.useRef(null),D=Vr(e),{setCurrentPanel:k,currentPanel:b,isCalendarVisible:x,dateInFocus:v,setDateInFocus:S,isTimePickerVisible:j,hideTimePicker:M,localTime:E,localDate:B}=D,{showCalendar:I,hideCalendar:F,inputLeftChangeHandler:P,inputRightChangeHandler:N,onChangeTime:L,onChangeDate:z}=$r(e,t,D,y),{onKeyDownHandler:$,onFocusRight:R,onFocusLeft:U,onClickDay:O,onClickCalendarButton:Y,onClickArrowButton:W}=qr(z,y,I,F,D);zr(e,S,y);const A=l.useMemo(()=>{const H=e||B;return H?ne(void 0,H,["singleSelected","selected"]):{}},[B,e]),V=l.useCallback(()=>{F(),M()},[F,M]),K=l.useMemo(()=>e?Ar(e):E,[e,E]),Q=g.useDelayedFalse(x,300),se=g.useDelayedFalse(j,300);return o.jsx(g.Box,{onKeyDown:$,children:o.jsx(ye.ControlledPopover,{hideArrow:!0,zIndex:m,appendTo:h,renderTrigger:H=>o.jsx(g.Box,{...H,children:o.jsx(Ft,{autoFocusLeft:s,onEsc:n,onEnter:r,onBlur:a,disabled:p,separatorIcon:C.stenaClock,typeLeft:"date",typeRight:"time",placeholderLeft:"yyyy-mm-dd",placeholderRight:"hh:mm",onChangeLeft:P,onChangeRight:N,onClickArrowDown:W,onClickCalendar:Y,onFocusLeft:U,onFocusRight:R,onClickLeft:U,onClickRight:R,inputRefLeft:y,inputRefRight:w,valueRight:K??"",widthLeft:c,widthRight:d,minLeft:i,maxLeft:f,variant:_})}),placement:xe,open:x||j,onRequestClose:V,children:(Q||se)&&o.jsx(g.Column,{children:Q?o.jsx(de,{statePerMonth:A,onClickDay:O,dateInFocus:v,setDateInFocus:S,currentPanel:b,setCurrentPanel:k,minDate:i,maxDate:f}):se?o.jsxs(g.Column,{children:[o.jsx(g.Column,{overflow:"hidden",height:"250px",children:o.jsx(Ur,{value:K??"",onValueChange:L})}),o.jsx(g.Space,{}),o.jsx(g.Row,{justifyContent:"flex-end",children:o.jsx(C.PrimaryButton,{label:"Done",onClick:M})})]}):null})})})},Gr=({value:e,onValueChange:t,year:r})=>{const n=String(r);return o.jsx(g.Row,{justifyContent:"center",children:e===r?o.jsx(C.PrimaryButton,{label:n,onClick:()=>t?.(r)}):o.jsx(C.FlatButton,{label:n,onClick:()=>t?.(r)})})},Jr=({value:e,onValueChange:t,initialLastYear:r})=>{const[n,a]=l.useState(()=>e?e+4:r??new Date().getFullYear()+4),s=l.useMemo(()=>{const i=n-11;return le.chunk(le.range(i,n+1),3)},[n]);return l.useEffect(()=>{a(i=>Qr(e,i))},[e]),o.jsxs(g.Row,{children:[o.jsx(g.Column,{justifyContent:"center",children:o.jsx(C.FlatButton,{leftIcon:C.stenaArrowLeft,onClick:()=>a(n-3)})}),o.jsx(g.Column,{gap:1,children:s.map(i=>o.jsx(g.Row,{gap:1,children:i.map(c=>o.jsx(Gr,{year:c,onValueChange:t,value:e},c))},i[0]))}),o.jsx(g.Column,{justifyContent:"center",children:o.jsx(C.FlatButton,{leftIcon:C.stenaArrowRight,onClick:()=>a(n+3)})})]})},Qr=(e,t)=>{if(e==null)return t;if(e>t){const n=e-t,a=n%3,s=n-a+3;return t+s}const r=t-11;if(e<r){const n=r-e,a=n%3,s=n-a+3;return t-s}return t},Zr=(e,t,r,n,a)=>{l.useEffect(function(){e&&r(e)},[e,r]),l.useEffect(function(){t&&r(t)},[t,r]),l.useEffect(function(){n.current&&(e?n.current.valueAsDate=new Date(Date.UTC(e.getFullYear(),e.getMonth(),e.getDate())):n.current.valueAsDate=null)},[e,n]),l.useEffect(function(){a.current&&(t?a.current.valueAsDate=new Date(Date.UTC(t.getFullYear(),t.getMonth(),t.getDate())):a.current.valueAsDate=null)},[t,a])},Xr=(e,t,r,{setDateInFocus:n,showCalendarInternal:a,hideCalendarInternal:s,setFirstFocusedInput:i,setCurrentPanel:c})=>{const d=l.useCallback(m=>{m.target.value[0]!=="0"&&r?.({startDate:m.target.valueAsDate??void 0,endDate:t})},[r,t]),f=l.useCallback(m=>{m.target.value[0]!=="0"&&r?.({startDate:e,endDate:m.target.valueAsDate??void 0})},[r,e]),_=l.useCallback(m=>{m!=null?n(m):n(e||t||new Date),c("calendar"),a()},[e,t,c,a,n]),p=l.useCallback(()=>{i(void 0),s()},[i,s]);return{inputLeftChangeHandler:d,inputRightChangeHandler:f,hideCalendar:p,setDateInFocus:n,setCurrentPanel:c,showCalendar:_}},en=(e,t)=>{const[r,n,a]=g.useBoolean(!1),[s,i]=l.useState(void 0),[c,d]=l.useState("startDate"),[f,_]=l.useState(()=>(c==="startDate"?e:c==="endDate"?t:void 0)??new Date),[p,m]=l.useState("calendar");return{isCalendarVisible:r,showCalendarInternal:n,hideCalendarInternal:a,firstFocusedInput:s,setFirstFocusedInput:i,focusedInput:c,setFocusedInput:d,dateInFocus:f,setDateInFocus:_,currentPanel:p,setCurrentPanel:m}},tn=(e,t,r,n,a,s,i,{firstFocusedInput:c,setFirstFocusedInput:d,isCalendarVisible:f,setFocusedInput:_,focusedInput:p,setCurrentPanel:m,setDateInFocus:h})=>{const y=l.useCallback(()=>{c==null&&d("startDate"),_("startDate"),f?e!=null&&h(e):s(e)},[c,_,f,e,d,s,h]),w=l.useCallback(()=>{c==null&&d("endDate"),_("endDate"),f?t!=null&&h(t):s(t)},[c,_,f,t,d,s,h]),D=l.useCallback(v=>{p==="startDate"?t!=null&&u.isAfter(v.date,t)?(r?.({startDate:v.date,endDate:void 0}),_("endDate"),a.current?.focus()):(r?.({startDate:v.date,endDate:t}),c==="startDate"?(_("endDate"),a.current?.focus()):setTimeout(i,50)):p==="endDate"&&(e?u.isAfter(e,v.date)?(r?.({startDate:v.date,endDate:void 0}),_("endDate"),a.current?.focus()):(r?.({startDate:e,endDate:v.date}),setTimeout(i,50)):(r?.({startDate:e,endDate:v.date}),_("startDate"),n.current?.focus()))},[p,r,t,c,_,a,i,e,n]),k=l.useCallback(()=>{m("presets"),s()},[m,s]),b=l.useCallback(()=>{f?i():(_("startDate"),d("startDate"),n.current?.focus(),m("calendar"),s())},[f,i,_,d,n,m,s]),x=l.useCallback(v=>{v.key==="Escape"&&i()},[i]);return{onFocusLeft:y,onFocusRight:w,onClickDay:D,onClickArrowButton:k,onClickCalendarButton:b,onKeyDownHandler:x}};function rn({value:e,onValueChange:t,autoFocus:r,onBlur:n,onEnter:a,onEsc:s,minDate:i,maxDate:c=we,calendarProps:d,widthLeft:f=128,widthRight:_=128,firstMonthInMonthPicker:p,numMonthsInMonthPicker:m,variant:h,disabled:y,zIndex:w,appendTo:D,renderBelowCalendar:k}){const{startDate:b,endDate:x}=e||{},v=l.useRef(null),S=l.useRef(null),j=en(b,x),{dateInFocus:M,setDateInFocus:E,isCalendarVisible:B,currentPanel:I,setCurrentPanel:F}=j,{showCalendar:P,hideCalendar:N,inputLeftChangeHandler:L,inputRightChangeHandler:z}=Xr(b,x,t,j),{onKeyDownHandler:$,onFocusRight:R,onFocusLeft:U,onClickDay:O,onClickCalendarButton:Y,onClickArrowButton:W}=tn(b,x,t,v,S,P,N,j);Zr(b,x,E,v,S);const A=l.useMemo(()=>b&&x&&u.isAfter(b,x),[b,x]),V=l.useMemo(()=>dt(d?.statePerMonth,b,x,M),[d?.statePerMonth,b,x,M]);return o.jsx(g.Box,{onKeyDown:$,children:o.jsx(ye.ControlledPopover,{hideArrow:!0,restoreFocus:!1,returnFocus:!1,zIndex:w,appendTo:D,renderTrigger:K=>o.jsx(g.Box,{...K,children:o.jsx(Ft,{autoFocusLeft:r,onEsc:s,onEnter:a,onBlur:n,disabled:y,separatorIcon:C.stenaArrowRight,typeLeft:"date",typeRight:"date",placeholderLeft:"Start date",placeholderRight:"End date",onChangeLeft:L,onChangeRight:z,onClickArrowDown:W,onClickCalendar:Y,onFocusLeft:U,onFocusRight:R,onClickLeft:U,onClickRight:R,inputRefLeft:v,inputRefRight:S,variant:A?"error":h,widthLeft:f,widthRight:_,minLeft:i,maxLeft:c,minRight:i,maxRight:c})}),placement:xe,onRequestClose:N,open:B,children:o.jsxs(g.Column,{children:[o.jsx(de,{onClickDay:O,dateInFocus:M,firstMonthInMonthPicker:p,numMonthsInMonthPicker:m,setDateInFocus:E,currentPanel:I,setCurrentPanel:F,minDate:i,maxDate:c,...d,statePerMonth:V}),I==="calendar"&&k]})})})}const $e=({onChange:e,onValueChange:t,readOnly:r,mask:n,ref:a,pipe:s,value:i,guide:c,keepCharPositions:d,placeholderChar:f,showMask:_,calendarSize:p,onFocus:m,onBlur:h,placeholderWhenBlurred:y,placeholder:w,valueWhenBlurred:D,label:k,variant:b,autoFocus:x,...v})=>{const S=l.useRef(null),[j,M]=l.useState(!1),E=a??S,{onChange:B}=Vt.useMaskedInput(E,e,t,n,s,i,c,d,f,_,j),I=l.useCallback(N=>{m?.(N),M(!0)},[m]),F=l.useCallback(N=>{h?.(N),M(!1)},[h]),P=j?w:y??w;return b==="standard"?o.jsx(C.Label,{text:k??"",children:o.jsx(ee.TextInput,{...v,autoFocus:x,readOnly:r,inputMode:"numeric","aria-live":"polite",value:(j?i:D)??"",inputRef:E,placeholder:P,onFocus:I,onBlur:F,onChange:B,width:lt(p),alwaysShowPlaceholder:!0})}):o.jsx(ee.LabelledTextInput,{...v,autoFocus:x,readOnly:r,inputMode:"numeric",label:k,"aria-live":"polite",value:(j?i:D)??"",ref:E,placeholder:P,onFocus:I,onBlur:F,onChange:B,width:lt(p),size:p==="large"?"large":"medium"})},lt=e=>{switch(e){case"smaller":return"140px";case"small":return"154px";case"medium":return"168px";case"large":return"196px";default:return g.exhaustSwitchCase(e,"168px")}},nn=[/[1-2]/,/\d/,/\d/,/\d/],an=[/[0-1]/,/\d/],sn=[/[0-3]/,/\d/],At=e=>ln(e).flatMap(on),on=e=>{switch(e){case"yyyy":return nn;case"mm":case"MM":return an;case"dd":case"DD":return sn;default:return[e]}},ln=e=>{if(e.length===0)return[];const t=[];let r=e[0];for(let n=1;n<e.length;n++)e[n]!==e[n-1]?(t.push(r),r=e[n]):r+=e[n];return t.push(r),t},fe=e=>{const r=new Intl.DateTimeFormat(e,{dateStyle:"short"}).formatToParts(new Date),n={year:"yyyy",month:"MM",day:"dd"};return r.map(a=>n[a.type]||a.value).join("")},Z=(e,t,r)=>{const n=Ze(t,r?.matchLanguage??!1,r?.fallbackLocaleCode??Qe),a=ue(n);if(a==null)return;const s=u.parse(e,fe(n),r?.referenceDate??new Date,{locale:a});if(!isNaN(s.getTime()))return s},oe=(e,t,r)=>{const n=Ze(t,r?.matchLanguage??!1,r?.fallbackLocaleCode??Qe);return u.format(e,fe(n),{locale:ue(n)})},Ie=(e,t)=>{const r=Z(e,t);if(r!=null)return oe(r,t)};(function(){try{if(typeof document<"u"){var e=document.createElement("style");e.appendChild(document.createTextNode("._navBar_kzibd_1{--swui-navbar-background-color: var(--lhds-color-ui-50);--swui-navbar-item-background-color-hover: var(--lhds-color-blue-700);--swui-navbar-item-background-color-selected: var(--lhds-color-blue-600);--swui-navbar-item-background-color-selected-hover: var( --lhds-color-blue-700 );--swui-nav-bar-height: 48px;background-color:var(--swui-navbar-background-color);height:var(--swui-nav-bar-height);min-height:var(--swui-nav-bar-height)}._navBarButton_b3x3w_1:hover{background:var(--lhds-color-ui-100)}._navBarButton_b3x3w_1:focus-visible{background:var(--lhds-color-ui-200)}._navBarButton_b3x3w_1:active{background:var(--lhds-color-ui-200)}._navBarButton_b3x3w_1._selected_b3x3w_14{background:var(--lhds-color-blue-200)}._navBarButton_b3x3w_1._selected_b3x3w_14:hover{background:var(--lhds-color-blue-100)}._navBarButton_b3x3w_1._selected_b3x3w_14:focus-visible{background:var(--lhds-color-blue-300)}._navBarButton_b3x3w_1._selected_b3x3w_14:active{background:var(--lhds-color-blue-200)}._navBarNotificationButton_1wt3y_1{--current-background-color: var(--lhds-color-ui-400);--current-outline-color: var(--modern-blue);background-color:var(--current-background-color);border-color:transparent;color:var(--lhds-color-ui-50);--swui-nav-bar-notification-shake-count: 3;transition:.5s width}._navBarNotificationButton_1wt3y_1:hover{--current-background-color: var(--lhds-color-red-500);--current-outline-color: var(--lhds-color-red-500)}._navBarNotificationButton_1wt3y_1:active{--current-background-color: var(--lhds-color-red-600);--current-outline-color: var(--lhds-color-red-600)}._navBarNotificationButton_1wt3y_1._unread_1wt3y_23 ._icon_1wt3y_23{transform-origin:top center;animation:_shake_1wt3y_1 1.5s ease-in-out var(--swui-nav-bar-notification-shake-count)}._navBarNotificationButton_1wt3y_1._unread_1wt3y_23{--current-background-color: var(--lhds-color-red-500);--current-outline-color: var(--lhds-color-red-500)}._navBarNotificationButton_1wt3y_1._unread_1wt3y_23:hover{--current-background-color: var(--lhds-color-red-600);--current-outline-color: var(--lhds-color-red-600)}._navBarNotificationButton_1wt3y_1._unread_1wt3y_23:active{--current-background-color: var(--lhds-color-red-700);--current-outline-color: var(--lhds-color-red-700)}._navBarNotificationButton_1wt3y_1:focus-visible{outline:var(--swui-focus-outline);outline-color:var(--current-outline-color);outline-offset:var(--swui-focus-outline-width)}@keyframes _shake_1wt3y_1{0%{transform:rotate(0)}7%{transform:rotate(20deg)}15%{transform:rotate(-20deg)}22%{transform:rotate(16deg)}30%{transform:rotate(-16deg)}38%{transform:rotate(6deg)}42%{transform:rotate(-6deg)}46%{transform:rotate(2deg)}to{transform:rotate(0)}}._navBarSearchFieldInput_1rp8g_1._navBarSearchFieldInput_1rp8g_1{line-height:2.7rem;color:var(--lhds-color-ui-800)}._navBarSearchFieldInput_1rp8g_1._navBarSearchFieldInput_1rp8g_1::placeholder{color:var(--lhds-color-blue-600)}._navBarSearchFieldInput_1rp8g_1._navBarSearchFieldInput_1rp8g_1{padding:0 var(--swui-metrics-indent)}._navBarSearchFieldWrapper_1rp8g_12._navBarSearchFieldWrapper_1rp8g_12{background:var(--lhds-color-ui-200);border-color:transparent}._navBarSearchFieldWrapper_1rp8g_12._navBarSearchFieldWrapper_1rp8g_12:hover{border-color:transparent}._navBarSearchFieldWrapper_1rp8g_12._navBarSearchFieldWrapper_1rp8g_12{padding:0 var(--swui-metrics-indent);border-radius:var(--swui-max-border-radius)}._navBarSearchFieldWrapper_1rp8g_12._navBarSearchFieldWrapper_1rp8g_12._withButton_1rp8g_24{padding-right:1px}._navBarSearchFieldWrapper_1rp8g_12._navBarSearchFieldWrapper_1rp8g_12:focus-within{color:var(--lhds-color-ui-800);background:var(--lhds-color-ui-50)}._navBarSearchFieldWrapper_1rp8g_12._navBarSearchFieldWrapper_1rp8g_12 ._clearButton_1rp8g_33{border-radius:var(--swui-max-border-radius)}._navBarUserButton_10f9z_1:hover{background:var(--lhds-color-ui-100)}._navBarUserButton_10f9z_1:focus-visible{background:var(--lhds-color-ui-200)}._navBarUserButton_10f9z_1:active{background:var(--lhds-color-ui-200)}._sidebarMenuCollapsibleGroupBox_ikek9_1{background:var(--lhds-color-ui-200);border-radius:var(--swui-border-radius);gap:var(--swui-metrics-space);display:flex;flex-direction:column;padding:var(--swui-metrics-space);--current-text-size: var(--swui-font-size-small)}._selectionRow_1njaw_1{display:flex;flex-direction:row;justify-content:space-between;align-items:center;gap:calc(var(--swui-metrics-space) * 2)}@media (max-width: 370px){._iconColumn_1njaw_9{display:none}}._sidebarMenu_1bx5w_1{--swui-sidebar-menu-separator-color: var(--swui-white);--swui-sidebar-menu-text-color: var(--lhds-color-ui-900);--swui-sidebar-menu-icon-color: var(--lhds-color-ui-900);--swui-sidebar-menu-background-color: transparent;--swui-sidebar-menu-background-color-hover: var(--lhds-color-ui-400);--swui-sidebar-menu-background-color-focus: var(--lhds-color-ui-400);--swui-sidebar-menu-background-color-active: var(--lhds-color-ui-300);--swui-sidebar-menu-background-selected: var(--lhds-color-blue-100);--swui-sidebar-menu-background-selected-hover: var(--lhds-color-blue-200);--swui-sidebar-menu-background-selected-focus: var(--lhds-color-blue-200);--swui-sidebar-menu-background-selected-active: var(--lhds-color-blue-100);--current-background-color: var(--swui-sidebar-menu-background-color);--current-background-color-hover: var( --swui-sidebar-menu-background-color-hover );--current-background-color-focus: var( --swui-sidebar-menu-background-color-focus );--current-background-color-active: var( --swui-sidebar-menu-background-color-active );--current-background-selected: var(--swui-sidebar-menu-background-selected);--current-background-selected-hover: var( --swui-sidebar-menu-background-selected-hover );--current-background-selected-focus: var( --swui-sidebar-menu-background-selected-focus );--current-background-selected-active: var( --swui-sidebar-menu-background-selected-active )}._sidebarMenu_1bx5w_1 ._sidebarItems_1bx5w_38{--current-separator-color: var(--swui-sidebar-menu-separator-color);--current-text-color: var(--swui-sidebar-menu-text-color);--current-icon-color: var(--swui-sidebar-menu-icon-color)}._sidebarMenu_1bx5w_1{background-color:var(--current-background-color);height:100dvh}._sidebarMenu_1bx5w_1 ._scrollContainer_1bx5w_48{background:var(--current-background-color);height:100%;overflow:auto}._stenaFlag_108h7_1{height:32px}._productCard_19x6b_1{max-width:560px}@media (max-width: 768px){._productCard_19x6b_1{max-width:unset}}.yarl__fullsize{height:100%;width:100%}.yarl__relative{position:relative}.yarl__portal{inset:0;opacity:0;overflow:hidden;position:fixed;transition:opacity var(--yarl__fade_animation_duration,.25s) var(--yarl__fade_animation_timing_function,ease);z-index:var(--yarl__portal_zindex,9999)}.yarl__portal_open{opacity:1}.yarl__container{background-color:var(--yarl__container_background_color,var(--yarl__color_backdrop,#000));inset:0;outline:none;overflow:hidden;overscroll-behavior:var(--yarl__controller_overscroll_behavior,contain);position:absolute;touch-action:var(--yarl__controller_touch_action,none);-webkit-user-select:none;user-select:none}.yarl__carousel{align-content:center;align-items:stretch;display:flex;flex:0 0 auto;height:100%;justify-content:center;opacity:var(--yarl__pull_opacity,1);transform:translate(var(--yarl__swipe_offset,0),var(--yarl__pull_offset,0));width:calc(100% + (var(--yarl__carousel_slides_count) - 1)*(100% + var(--yarl__carousel_spacing_px, 0)*1px + var(--yarl__carousel_spacing_percent, 0)*1%))}.yarl__carousel_with_slides{column-gap:calc(var(--yarl__carousel_spacing_px, 0)*1px + 100/(var(--yarl__carousel_slides_count)*100 + (var(--yarl__carousel_slides_count) - 1)*var(--yarl__carousel_spacing_percent, 0))*var(--yarl__carousel_spacing_percent, 0)*1%)}.yarl__flex_center{align-content:center;align-items:center;display:flex;justify-content:center}.yarl__slide{flex:1;overflow:hidden;padding:calc(var(--yarl__carousel_padding_px, 0)*1px + 100/(var(--yarl__carousel_slides_count)*100 + (var(--yarl__carousel_slides_count) - 1)*var(--yarl__carousel_spacing_percent, 0))*var(--yarl__carousel_padding_percent, 0)*1%);position:relative}[dir=rtl] .yarl__slide{--yarl__direction:-1}.yarl__slide_image{max-height:100%;max-width:100%;object-fit:contain;touch-action:var(--yarl__controller_touch_action,none);user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.yarl__slide_image_cover{height:100%;object-fit:cover;width:100%}.yarl__slide_image_loading{opacity:0}@media screen and (min-width:800px){.yarl__slide_wrapper:not(.yarl__slide_wrapper_interactive) .yarl__slide_image{-webkit-backface-visibility:hidden;-webkit-transform:translateZ(0);-webkit-transform-style:preserve-3d}}.yarl__slide_placeholder{left:50%;line-height:0;position:absolute;top:50%;transform:translate(-50%) translateY(-50%)}.yarl__slide_loading{animation:yarl__delayed_fadein 1s linear;color:var(--yarl__slide_icon_loading_color,var(--yarl__color_button,hsla(0,0%,100%,.8)))}.yarl__slide_loading line{animation:yarl__stroke_opacity 1s linear infinite}.yarl__slide_loading line:first-of-type{animation-delay:-1.875s}.yarl__slide_loading line:nth-of-type(2){animation-delay:-1.75s}.yarl__slide_loading line:nth-of-type(3){animation-delay:-1.625s}.yarl__slide_loading line:nth-of-type(4){animation-delay:-1.5s}.yarl__slide_loading line:nth-of-type(5){animation-delay:-1.375s}.yarl__slide_loading line:nth-of-type(6){animation-delay:-1.25s}.yarl__slide_loading line:nth-of-type(7){animation-delay:-1.125s}.yarl__slide_loading line:nth-of-type(8){animation-delay:-1s}.yarl__slide_error{color:var(--yarl__slide_icon_error_color,red);height:var(--yarl__slide_icon_error_size,48px);width:var(--yarl__slide_icon_error_size,48px)}@media (prefers-reduced-motion){.yarl__portal,.yarl__slide{transition:unset}.yarl__slide_loading,.yarl__slide_loading line{animation:unset}}.yarl__toolbar{display:flex;justify-content:flex-end;inset:0 0 auto auto;padding:var(--yarl__toolbar_padding,8px);position:absolute}[dir=rtl] .yarl__toolbar{inset:0 auto auto 0}.yarl__icon{height:var(--yarl__icon_size,32px);width:var(--yarl__icon_size,32px)}.yarl__button{-webkit-appearance:none;appearance:none;background-color:var(--yarl__button_background_color,transparent);border:var(--yarl__button_border,0);color:var(--yarl__color_button,hsla(0,0%,100%,.8));cursor:pointer;filter:var(--yarl__button_filter,drop-shadow(2px 2px 2px rgba(0,0,0,.8)));line-height:0;margin:var(--yarl__button_margin,0);outline:none;padding:var(--yarl__button_padding,8px);-webkit-tap-highlight-color:transparent}.yarl__button:focus{color:var(--yarl__color_button_active,#fff)}.yarl__button:focus:not(:focus-visible){color:var(--yarl__color_button,hsla(0,0%,100%,.8))}.yarl__button:focus-visible{color:var(--yarl__color_button_active,#fff)}@media (hover:hover){.yarl__button:focus-visible:hover,.yarl__button:focus:hover,.yarl__button:hover{color:var(--yarl__color_button_active,#fff)}}.yarl__button:disabled{color:var(--yarl__color_button_disabled,hsla(0,0%,100%,.4));cursor:default}.yarl__navigation_next,.yarl__navigation_prev{padding:var(--yarl__navigation_button_padding,24px 16px);position:absolute;top:50%;transform:translateY(-50%)}.yarl__navigation_prev{left:0}[dir=rtl] .yarl__navigation_prev{left:unset;right:0;transform:translateY(-50%) rotate(180deg)}.yarl__navigation_next{right:0}[dir=rtl] .yarl__navigation_next{left:0;right:unset;transform:translateY(-50%) rotate(180deg)}.yarl__no_scroll{height:100%;overflow:hidden;overscroll-behavior:none}@keyframes yarl__delayed_fadein{0%{opacity:0}80%{opacity:0}to{opacity:1}}@keyframes yarl__stroke_opacity{0%{stroke-opacity:1}to{stroke-opacity:.125}}.yarl__counter{bottom:var(--yarl__counter_bottom,unset);color:var(--yarl__counter_color,var(--yarl__color_button,hsla(0,0%,100%,.8)));filter:var(--yarl__counter_filter,drop-shadow(2px 2px 2px rgba(0,0,0,.8)));left:var(--yarl__counter_left,0);line-height:var(--yarl__counter_line_height,var(--yarl__icon_size,32px));margin:var(--yarl__counter_margin,var(--yarl__toolbar_padding,8px));padding:var(--yarl__counter_padding,var(--yarl__button_padding,8px));position:var(--yarl__counter_position,absolute);right:var(--yarl__counter_right,unset);top:var(--yarl__counter_top,0);-webkit-user-select:var(--yarl__counter_user_select,none);user-select:var(--yarl__counter_user_select,none)}.yarl__slide_captions_container{background:var(--yarl__slide_captions_container_background,rgba(0,0,0,.5));left:var(--yarl__slide_captions_container_left,0);padding:var(--yarl__slide_captions_container_padding,16px);position:absolute;right:var(--yarl__slide_captions_container_right,0);-webkit-transform:translateZ(0)}.yarl__slide_title{color:var(--yarl__slide_title_color,#fff);font-size:var(--yarl__slide_title_font_size,125%);font-weight:var(--yarl__slide_title_font_weight,bolder);max-width:calc(100% - var(--yarl__toolbar_width, 0px));overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.yarl__slide_title_container{top:var(--yarl__slide_title_container_top,0)}.yarl__slide_description{display:-webkit-box;-webkit-hyphens:auto;hyphens:auto;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:var(--yarl__slide_description_max_lines,3);color:var(--yarl__slide_description_color,#fff);text-align:var(--yarl__slide_description_text_align,start)}.yarl__slide_description_container{bottom:var(--yarl__slide_description_container_bottom,0)}.yarl__slide_title.yarl__slide_title.yarl__slide_title{font-family:var(--swui-font-primary);font-size:var(--swui-font-size-large);font-weight:var(--swui-font-weight-text)}.yarl__slide_title_container.yarl__slide_title_container.yarl__slide_title_container{height:48px;margin:calc(var(--swui-metrics-space) * 1);padding:0;display:flex;align-items:center;padding-left:calc(var(--swui-metrics-space) * 10)}.yarl__slide_description.yarl__slide_description.yarl__slide_description{font-family:var(--swui-font-primary);font-size:var(--swui-font-size-large);font-weight:var(--swui-font-weight-text)}.yarl__slide_description_container.yarl__slide_description_container.yarl__slide_description_container{display:flex;align-items:center;padding-left:calc(var(--swui-metrics-space) * 3);padding-bottom:calc(var(--swui-metrics-space) * 4)}.yarl__counter.yarl__counter{height:48px;margin:calc(var(--swui-metrics-space) * 1);display:flex;align-items:center;padding:0;padding-left:calc(var(--swui-metrics-space) * 1);font-family:var(--swui-font-primary);font-size:var(--swui-font-size-large);font-weight:var(--swui-font-weight-text)}")),document.head.appendChild(e)}}catch(t){console.error("vite-plugin-css-injected-by-js",t)}})();const cn="_navBarButton_b3x3w_1",un="_selected_b3x3w_14",it={navBarButton:cn,selected:un};l.forwardRef(function({selected:e,className:t,...r},n){return o.jsx(C.FlatButton,{...r,ref:n,className:J(it.navBarButton,e&&it.selected,t)})});const dn="_navBarNotificationButton_1wt3y_1",fn="_unread_1wt3y_23",_n="_icon_1wt3y_23",be={navBarNotificationButton:dn,unread:fn,icon:_n};l.forwardRef(function({count:e,unread:t=!1,className:r,labelClassName:n,iconClassName:a,icon:s=C.stenaBellFilled,...i},c){const d=e>1;return o.jsx(C.BaseButton,{...i,ref:c,leftIcon:s,className:J(be.navBarNotificationButton,t&&be.unread,d&&be.hasCount,r),label:d?String(e):void 0,labelClassName:J(n,be.label),iconClassName:J(a,be.icon)})});l.forwardRef(({contentLeft:e,contentRight:t,collapsed:r=!1,...n},a)=>o.jsx(C.MenuButton,{ref:a,expandable:!0,expanded:!r,selected:!r,left:e,right:t,...n}));l.createContext(!1);const ct=["small-mobile","mobile","tablet","tablet-wide","desktop"],Pt=()=>{const e=Ce.useMediaQuery({query:"(max-width: 768px)"}),t=Ce.useMediaQuery({query:"(max-width: 395px)"}),r=Ce.useMediaQuery({query:"(max-width: 1024px)"}),n=Ce.useMediaQuery({query:"(max-width: 1160px)"});return{deviceSize:t?"small-mobile":e?"mobile":r?"tablet":n?"tablet-wide":"desktop"}},Wt=(e,t)=>e===t||ct.indexOf(e)>ct.indexOf(t),Ht=({value:e,onValueChange:t,localeCode:r,startDateLabel:n="From",endDateLabel:a="To",onFocus:s,onBlur:i,calendarSize:c,startDateRef:d,endDateRef:f,placeholderWhenBlurredStartDate:_,placeholderWhenBlurredEndDate:p,valueWhenBlurredStartDate:m,valueWhenBlurredEndDate:h,variant:y,readOnlyOnMobile:w,autoFocusStartDate:D,autoFocusEndDate:k})=>{const{deviceSize:b}=Pt(),x=w&&!Wt(b,"tablet"),{mask:v,placeholder:S}=l.useMemo(()=>{const j=fe(r);return{mask:At(j),placeholder:j.toLowerCase()}},[r]);return o.jsxs(g.Row,{children:[o.jsx($e,{mask:v,ref:d,value:e?.startDate,onValueChange:j=>{t?.({startDate:j})},onBlur:j=>{const M=Ie(j.target.value,r);M&&M!==e?.startDate&&t?.({startDate:M}),i?.()},onFocus:()=>s?.("startDate"),autoFocus:D,label:n,borderRadiusVariant:"onlyLeft",placeholder:S,placeholderWhenBlurred:_,valueWhenBlurred:m,calendarSize:c,variant:y,readOnly:x}),o.jsx($e,{mask:v,ref:f,value:e?.endDate,onValueChange:j=>t?.({endDate:j}),onBlur:j=>{const M=Ie(j.target.value,r);M&&M!==e?.endDate&&t?.({endDate:M}),i?.()},onFocus:()=>s?.("endDate"),autoFocus:k,label:a,borderRadiusVariant:"onlyRight",placeholder:S,placeholderWhenBlurred:p,valueWhenBlurred:h,calendarSize:c,variant:y,readOnly:x})]})},Ve=(e,t,r)=>{const n=u.isSameYear(e,t)?"":" y";return r.code.startsWith("en")?u.format(e,"eee MMM d"+n,{locale:r}).replace(".",""):u.format(e,"eee d MMM"+n,{locale:r}).replace(".","")};function gn(e,t,r){if(!e||!t||!r)return!1;const n=r(e),a=r(t);return!n||!a||Number.isNaN(n.getTime())||Number.isNaN(a.getTime())||u.isSameDay(n,a)?!1:u.isAfter(n,a)}function hn(e,t,r){const{startDate:n,endDate:a}=e;return gn(n,a,t)?r==="startDate"?{...e,startDate:n,endDate:n}:{...e,startDate:a,endDate:a}:e}const Ot=(e,t,r,n,a,s,i,c,d)=>{const f=ue(n),_=l.useId(),p=g.useToday(),m=l.useRef(null),h=l.useMemo(()=>fe(r),[r]),y=l.useMemo(()=>e?.startDate?.length===h.length?Z(e.startDate,r):void 0,[h.length,r,e?.startDate]),w=l.useMemo(()=>e?.endDate?.length===h.length?Z(e.endDate,r):void 0,[h.length,r,e?.endDate]),D=l.useMemo(()=>y!=null?Ve(y,p,f):void 0,[f,y,p]),k=l.useMemo(()=>w!=null?Ve(w,p,f):void 0,[f,w,p]),[b,x]=l.useState(a??y??new Date),v=l.useCallback(R=>{u.isSameMonth(R,p)||u.isAfter(R,p)?x(R):x(p)},[p]),S=l.useMemo(()=>ve(b.getFullYear(),b.getMonth(),f),[f,b]),j=l.useMemo(()=>Te(u.intlFormat(b,{month:"long",year:"numeric"},{locale:f.code})),[f,b]),M=l.useMemo(()=>u.isSameMonth(p,b),[p,b]),[E,B]=l.useState(),[I,F]=l.useState("calendar"),P=l.useCallback(R=>{const U=R?.startDate?.length===h.length?Z(R.startDate,r):void 0,O=R?.endDate?.length===h.length?Z(R.endDate,r):void 0;U?v(U):O&&v(O),t?.({...e,...R})},[h.length,r,t,v,e]),N=l.useMemo(()=>y&&w?u.isAfter(w,y)||u.isSameDay(w,y):!1,[w,y]),L=l.useMemo(()=>{const R=s==="startDate"?e?.endDate:e?.startDate;return R?Z(R,r):void 0},[s,r,e?.endDate,e?.startDate]),z=l.useMemo(()=>{if(E&&L){if(s==="endDate")return"right";if(s==="startDate")return"left"}},[s,L,E]);return{onClickDate:R=>{if(!(R.getFullYear()===b.getFullYear()&&R.getMonth()===b.getMonth()))return;const O=(Y,W)=>t?.(hn(Y,A=>Z(A,r),W));s==="startDate"?(O({startDate:oe(R,r),endDate:e?.endDate},"startDate"),e?.endDate?(d?.(),i(void 0),B(void 0)):c("endDate")):s==="endDate"?(O({startDate:e?.startDate,endDate:oe(R,r)},"endDate"),d?.(),i(void 0),B(void 0)):y&&w==null?u.isBefore(R,y)?(t?.({startDate:oe(R,r),endDate:void 0}),c("endDate")):(t?.({startDate:e?.startDate,endDate:oe(R,r)}),d?.(),i(void 0),B(void 0)):(O({startDate:oe(R,r),endDate:void 0},"startDate"),c("endDate"))},onValueChangeByInputs:P,isValidDateRange:N,monthPickerButtonRef:m,calendarId:_,monthPickerButtonLabel:j,visiblePanel:I,setVisiblePanel:F,setVisibleMonth:x,visibleMonthData:S,todayIsInVisibleMonth:M,hoverDate:E,setHoverDate:B,hoverAnchor:L,hoverHighlightDirection:z,selectedStartDate:y,selectedEndDate:w,today:p,visibleMonth:b,valueWhenBlurredStartDate:D,valueWhenBlurredEndDate:k}},Fe=({previousMonthButtonAriaLabel:e,nextMonthButtonAriaLabel:t,monthPickerButtonLabel:r,visiblePanel:n,setVisiblePanel:a,monthPickerButtonRef:s,setVisibleMonth:i,visibleMonth:c,prevMonthDisabled:d,nextMonthDisabled:f,calendarSize:_,previousMonthButtonTestId:p,nextMonthButtonTestId:m})=>{const h=_==="smaller"||_==="small"?"medium":"large";return o.jsxs(g.Row,{alignSelf:"center",justifyContent:"space-between",width:"100%",children:[o.jsx(C.FlatButton,{"aria-live":"polite",label:r,rightIcon:n==="calendar"?C.stenaAngleDown:C.stenaAngleUp,onClick:()=>a(n==="calendar"?"month-picker":"calendar"),ref:s,size:h}),o.jsxs(g.Row,{alignItems:"center",gap:2,children:[o.jsx(C.SecondaryButton,{leftIcon:C.stenaArrowLeft,onClick:()=>i(u.subMonths(c,1)),disabled:d?.(c),"aria-label":e,size:h,"data-testid":p}),o.jsx(C.SecondaryButton,{leftIcon:C.stenaArrowRight,onClick:()=>i(u.addMonths(c,1)),disabled:f?.(c),"aria-label":t,size:h,"data-testid":m})]})]})},pn="_travelDateCell_1t2af_1",mn="_smaller_1t2af_4",bn="_small_1t2af_4",yn="_medium_1t2af_14",vn="_large_1t2af_19",xn="_outline_1t2af_31",wn="_contentWrapper_1t2af_44",Dn="_disabled_1t2af_65",kn="_isToday_1t2af_68",Cn="_isSelectionStart_1t2af_72",Sn="_isSelectionEnd_1t2af_73",jn="_hover_1t2af_88",Mn="_startSelected_1t2af_91",Bn="_endSelected_1t2af_91",G={travelDateCell:pn,smaller:mn,small:bn,medium:yn,large:vn,outline:xn,contentWrapper:wn,disabled:Dn,isToday:kn,isSelectionStart:Cn,isSelectionEnd:Sn,hover:jn,startSelected:Mn,endSelected:Bn},X="var(--selection-range-background-color)",Rn=(e,t,r,n,a,s,i,c)=>i?t&&r&&!c?{left:"transparent",right:"transparent"}:a&&s&&n?Tn(e,n,a,s):a?{left:"transparent",right:"transparent"}:In(e,t,r,a):{left:"transparent",right:"transparent"},In=(e,t,r,n)=>{if(t&&r&&u.isSameDay(t,r))return{left:"transparent",right:"transparent"};if(t&&r?u.isAfter(e,t)&&u.isBefore(e,r)&&!u.isSameDay(e,t)&&!u.isSameDay(e,r):!1)return{left:X,right:X};if(t&&r)return u.isSameDay(e,t)?{left:"transparent",right:X}:u.isSameDay(e,r)?{left:X,right:"transparent"}:{left:"transparent",right:"transparent"};if(t&&n&&u.isAfter(n,t)){if(u.isSameDay(e,t))return{left:"transparent",right:X};if(u.isSameDay(e,n))return{left:X,right:"transparent"}}return{left:"transparent",right:"transparent"}},Tn=(e,t,r,n)=>{const a=u.isAfter(r,n),s=u.isWithinInterval(e,{start:u.min([r,n]),end:u.max([r,n])}),i=u.isSameDay(e,r),c=u.isSameDay(e,n);return t==="right"&&u.isBefore(r,n)?{left:"transparent",right:"transparent"}:t==="left"&&u.isAfter(r,n)?{left:"transparent",right:"transparent"}:i&&c?{left:"transparent",right:"transparent"}:i?ut(a,{left:"transparent",right:X}):c?ut(a,{left:X,right:"transparent"}):s?{left:X,right:X}:{left:"transparent",right:"transparent"}},ut=(e,{left:t,right:r})=>e?{left:r,right:t}:{left:t,right:r},En=(e,t)=>{switch(t){case"PageUp":return u.subMonths(e,1);case"PageDown":return u.addMonths(e,1);case"Home":return u.startOfWeek(e);case"End":return u.addDays(u.startOfWeek(e),6);case"ArrowLeft":return u.subDays(e,1);case"ArrowUp":return u.subDays(e,7);case"ArrowRight":return u.addDays(e,1);case"ArrowDown":return u.addDays(e,7);default:return}},He=(e,t)=>u.format(u.addHours(e,12),ae.fullDate)+t,Nn="_travelDateCellBackground_45q5d_1",Fn="_smaller_45q5d_2",Ln="_small_45q5d_2",An="_medium_45q5d_12",Pn="_large_45q5d_17",Se={travelDateCellBackground:Nn,smaller:Fn,small:Ln,medium:An,large:Pn},Wn=({calendarSize:e,bgColorLeft:t,bgColorRight:r})=>o.jsxs(g.Row,{children:[o.jsx(g.Box,{className:J(Se.travelDateCellBackground,Se[e]),background:t}),o.jsx(g.Box,{className:J(Se.travelDateCellBackground,Se[e]),background:r})]}),Hn=({onClick:e,visibleMonth:t,onChangeVisibleMonth:r,day:n,isValidDateRange:a,selectedStartDate:s,selectedEndDate:i,onStartHover:c,onEndHover:d,hoverDate:f,hoverAnchor:_,today:p,todayIsInVisibleMonth:m,calendarId:h,isDateDisabled:y,size:w,dateTestId:D,hoverHighlightDirection:k})=>{const b=l.useCallback(async P=>{const N=En(n.date,P.key),L=(N&&y?.(N))??!1;N&&!L&&(c(N),u.isSameMonth(n.date,N)?document.getElementById(He(N,h))?.focus():(r(N),setTimeout(()=>{document.getElementById(He(N,h))?.focus()},10))),(P.key==="Enter"||P.code==="Space")&&e(n.date)},[h,n.date,y,r,e,c]),x=n.month===t.getMonth(),v=y?.(n.date)??!1,S=f&&_?u.isAfter(f,_):!1,j=f&&_?u.isSameDay(S?_:f,n.date):!1,M=f&&_?u.isSameDay(S?f:_,n.date):!1,E=!f&&s?u.isSameDay(s,n.date):!1,B=!f&&i?u.isSameDay(i,n.date):!1,I=u.isSameDay(n.date,p),F=Rn(n.date,s,i,k,f,_,x,a);return o.jsxs("td",{className:J(G.travelDateCell,G[w]),onClick:v?void 0:()=>e(n.date),onMouseOver:v?void 0:()=>x&&c(n.date),onMouseOut:v?void 0:()=>x&&d(n.date),tabIndex:v?void 0:On(n,s,I,t,m),id:v?void 0:He(n.date,h),onKeyDown:v?void 0:b,...v?void 0:{"aria-selected":E||B},"data-testid":D?.(n.date),children:[o.jsx("div",{className:G.outline}),o.jsx(Wn,{calendarSize:w,bgColorLeft:F.left,bgColorRight:F.right}),x&&o.jsx("div",{className:J(G.contentWrapper,I?G.isToday:void 0,s?G.startSelected:void 0,i?G.endSelected:void 0,f&&u.isSameDay(f,n.date)?G.hover:void 0,(E||j)&&G.isSelectionStart,(B||M)&&G.isSelectionEnd,v&&G.disabled),children:o.jsx(g.Text,{variant:"bold",color:v?qe.cssColor("--lhds-color-ui-500"):void 0,children:n.dayOfMonth})})]})},On=(e,t,r,n,a)=>{const s=t?u.isSameMonth(t,n):!1;return(t&&s?u.isSameDay(e.date,t):r)||!s&&!a&&e.date.getDate()===1?0:-1},Yn="_travelCalendar_ib2y4_1",Un={travelCalendar:Yn},Le=({visibleMonthData:e,onClickDate:t,setHoverDate:r,setVisibleMonth:n,visibleMonth:a,isValidDateRange:s,selectedStartDate:i,selectedEndDate:c,hoverDate:d,hoverAnchor:f,today:_,calendarId:p,isDateDisabled:m,todayIsInVisibleMonth:h,size:y="medium",multiSelectable:w,dateTestId:D,hoverHighlightDirection:k})=>o.jsx("table",{className:Un.travelCalendar,role:"grid",...w?{"aria-multiselectable":!0}:void 0,children:o.jsxs("tbody",{children:[o.jsx("tr",{children:e.weeks[0].days.map(b=>o.jsx("th",{abbr:b.fullName,children:o.jsx(g.Text,{children:b.name})},b.name))}),e.weeks.map(b=>o.jsx(Ke.Fragment,{children:o.jsx("tr",{children:b.days.map(x=>o.jsx(Hn,{size:y,onClick:v=>t(v),visibleMonth:a,onChangeVisibleMonth:n,isValidDateRange:s,day:x,onStartHover:v=>r(v),onEndHover:v=>r(S=>S&&u.isSameDay(S,v)?void 0:S),selectedStartDate:i,selectedEndDate:c,hoverDate:d,hoverAnchor:f,today:_,todayIsInVisibleMonth:h,calendarId:p,isDateDisabled:m,dateTestId:D,hoverHighlightDirection:k},x.dateString))},b.weekNumber)},b.weekNumber))]})}),zn="_travelDateRangeInput_1j7rp_1",$n="_overlay_1j7rp_2",Vn="_calendarVisible_1j7rp_6",Oe={travelDateRangeInput:zn,overlay:$n,calendarVisible:Vn},qn=({value:e,onValueChange:t,startDateLabel:r,endDateLabel:n,localeCode:a="sv",languageLocaleCode:s=a,initialMonthInFocus:i,previousMonthButtonAriaLabel:c="Previous month",nextMonthButtonAriaLabel:d="Next month",placeholderWhenBlurredStartDate:f,placeholderWhenBlurredEndDate:_,heading:p,headingLevel:m,numMonthsInMonthPicker:h=12,isDateDisabled:y,prevMonthDisabled:w,nextMonthDisabled:D,firstMonthInMonthPicker:k=new Date,zIndex:b=1e3,zIndexWhenClosed:x,onHideCalendar:v,renderBelowCalendar:S,size:j="medium",dateTestId:M,previousMonthButtonTestId:E,nextMonthButtonTestId:B,textInputVariant:I="standard",autoFocusStartDate:F,autoFocusEndDate:P})=>{const[N,L]=l.useState(!1),[z,$]=l.useState(!1),[R,U]=l.useState({width:336,height:66}),[O,Y]=l.useState(void 0),W=l.useRef(null),A=l.useRef(null),V=q=>{q==="startDate"?W.current?.focus():q==="endDate"&&A.current?.focus()},K=j==="large"?"8.8rem":"6.6rem",Q=l.useRef(!1),se=l.useCallback(q=>{Y(q),Q.current=!0,$(!0),setTimeout(()=>{L(!0)},10)},[]),H=l.useCallback(()=>{z&&(L(!1),Q.current=!1,v?.(),setTimeout(()=>{Q.current||$(!1)},120))},[z,v]),De=l.useRef(null),_e=l.useRef(null);g.useOnClickOutside(De,H),l.useLayoutEffect(()=>{const q=_e.current?.offsetWidth,Ae=_e.current?.offsetHeight;q!=null&&Ae!=null&&(R.height!==Ae||R.width!==q)&&U({width:q,height:Ae})},[R.height,R.width]);const ce=Ot(e,t,a,s,i,O,Y,V,H),{visiblePanel:ke,visibleMonth:te,onValueChangeByInputs:me,setVisibleMonth:zt,setVisiblePanel:rt,monthPickerButtonRef:nt}=ce,$t=l.useCallback(q=>{q.key==="Escape"&&H()},[H]);return o.jsxs(g.Box,{position:"relative",className:Oe.travelDateRangeInput,ref:De,onKeyDown:$t,height:R.height,width:R.width,children:[o.jsx(g.Box,{position:"absolute",ref:_e,zIndex:z?b:x,children:o.jsx(Ht,{...ce,value:e,onValueChange:me,startDateRef:W,endDateRef:A,localeCode:a,startDateLabel:r,endDateLabel:n,onFocus:se,calendarSize:j,placeholderWhenBlurredStartDate:f,placeholderWhenBlurredEndDate:_,variant:I,autoFocusStartDate:F,autoFocusEndDate:P,readOnlyOnMobile:!0})}),z&&o.jsx(g.Box,{position:"absolute",zIndex:b-1,left:"-2.4rem",top:p?"-8.0rem":"-2.4rem",className:J(Oe.overlay,N&&Oe.calendarVisible),children:o.jsx(g.Box,{background:"white",shadow:"popover",borderRadius:"var(--swui-border-radius-large)",children:o.jsxs(C.CardBody,{gap:3,children:[p&&o.jsx(g.Heading,{variant:"h2",as:m,children:p}),o.jsx(g.Box,{height:K}),o.jsx(Fe,{...ce,previousMonthButtonAriaLabel:c,nextMonthButtonAriaLabel:d,calendarSize:j,prevMonthDisabled:w,nextMonthDisabled:D,previousMonthButtonTestId:E,nextMonthButtonTestId:B}),ke==="calendar"&&o.jsx(Le,{...ce,size:j,multiSelectable:!0,isDateDisabled:y,dateTestId:M}),ke==="month-picker"&&o.jsx(pe,{firstMonth:k,numMonths:h,value:te,size:j,localeCode:s,onValueChange:q=>{zt(q),rt("calendar"),nt.current?.focus()},onCancel:()=>{rt("calendar"),nt.current?.focus()}}),S?.({hideCalendar:H})]})})})]})},Kn="_travelDateInput_hmfbf_1",Gn="_overlay_hmfbf_2",Jn="_calendarVisible_hmfbf_6",Ye={travelDateInput:Kn,overlay:Gn,calendarVisible:Jn},Yt=({value:e,onValueChange:t,label:r="Date",localeCode:n,autoFocus:a,onFocus:s,calendarSize:i,placeholderWhenBlurred:c,valueWhenBlurred:d,variant:f,readOnlyOnMobile:_})=>{const{deviceSize:p}=Pt(),m=_&&!Wt(p,"tablet"),{mask:h,placeholder:y}=l.useMemo(()=>{const w=fe(n);return{mask:At(w),placeholder:w.toLowerCase()}},[n]);return o.jsx(g.Row,{children:o.jsx($e,{mask:h,value:e,onValueChange:t,onBlur:w=>{const D=Ie(w.target.value,n);D&&D!==e&&t?.(D)},readOnly:m,onFocus:s,autoFocus:a,label:r,placeholder:y,calendarSize:i,placeholderWhenBlurred:c,valueWhenBlurred:d,variant:f})})},Ut=(e,t,r,n,a,s)=>{const i=ue(n),c=l.useId(),d=g.useToday(),f=l.useRef(null),_=l.useMemo(()=>fe(r),[r]),p=l.useMemo(()=>e?.length===_.length?Z(e,r):void 0,[_.length,r,e]),m=l.useMemo(()=>p!=null?Ve(p,d,i):void 0,[i,p,d]),[h,y]=l.useState(a??p??new Date),w=l.useCallback(B=>{u.isSameMonth(B,d)||u.isAfter(B,d)?y(B):y(d)},[d]),D=l.useMemo(()=>ve(h.getFullYear(),h.getMonth(),i),[i,h]),k=l.useMemo(()=>Te(u.intlFormat(h,{month:"long",year:"numeric"},{locale:i.code})),[i,h]),b=l.useMemo(()=>u.isSameMonth(d,h),[d,h]),[x,v]=l.useState(),[S,j]=l.useState("calendar"),M=l.useCallback(B=>{const I=B?.length===_.length?Z(B,r):void 0;I&&w(I),t?.(B)},[_.length,r,t,w]);return{onClickDate:B=>{t?.(oe(B,r)),s?.(B)},onValueChangeByInputs:M,monthPickerButtonRef:f,calendarId:c,monthPickerButtonLabel:k,visiblePanel:S,setVisiblePanel:j,setVisibleMonth:y,visibleMonthData:D,todayIsInVisibleMonth:b,hoverDate:x,hoverAnchor:void 0,setHoverDate:v,selectedDate:p,today:d,visibleMonth:h,valueWhenBlurred:m}},Qn=({value:e,onValueChange:t,label:r,localeCode:n="sv",languageLocaleCode:a=n,initialMonthInFocus:s,previousMonthButtonAriaLabel:i="Previous month",nextMonthButtonAriaLabel:c="Next month",placeholderWhenBlurred:d,autoFocus:f,heading:_,headingLevel:p,numMonthsInMonthPicker:m=12,isDateDisabled:h,prevMonthDisabled:y,nextMonthDisabled:w,firstMonthInMonthPicker:D=new Date,zIndex:k=1e3,zIndexWhenClosed:b,onHideCalendar:x,renderBelowCalendar:v,size:S="medium",dateTestId:j,previousMonthButtonTestId:M,nextMonthButtonTestId:E,textInputVariant:B="standard"})=>{const[I,F]=l.useState(!1),[P,N]=l.useState(!1),[L,z]=l.useState({width:336,height:66}),$=S==="large"?"8.8rem":"6.6rem",R=l.useRef(!1),U=l.useCallback(()=>{R.current=!0,N(!0),setTimeout(()=>{F(!0)},10)},[]),O=l.useCallback(()=>{P&&(F(!1),R.current=!1,x?.(),setTimeout(()=>{R.current||N(!1)},120))},[P,x]),Y=l.useCallback(()=>{setTimeout(()=>{O()},250)},[O]),W=l.useRef(null),A=l.useRef(null);g.useOnClickOutside(W,O),l.useLayoutEffect(()=>{const te=A.current?.offsetWidth,me=A.current?.offsetHeight;te!=null&&me!=null&&(L.height!==me||L.width!==te)&&z({width:te,height:me})},[L.height,L.width]);const V=Ut(e,t,n,a,s,Y),{visiblePanel:K,visibleMonth:Q,onValueChangeByInputs:se,selectedDate:H,setVisibleMonth:De,setVisiblePanel:_e,monthPickerButtonRef:ce}=V,ke=l.useCallback(te=>{te.key==="Escape"&&O()},[O]);return o.jsxs(g.Box,{position:"relative",className:Ye.travelDateInput,ref:W,onKeyDown:ke,height:L.height,width:L.width,children:[o.jsx(g.Box,{position:"absolute",ref:A,zIndex:P?k:b,children:o.jsx(Yt,{...V,autoFocus:f,value:e,onValueChange:se,localeCode:n,label:r,onFocus:U,calendarSize:S,placeholderWhenBlurred:d,variant:B,readOnlyOnMobile:!0})}),P&&o.jsx(g.Box,{position:"absolute",zIndex:k-1,left:"-2.4rem",top:_?"-8.0rem":"-2.4rem",className:J(Ye.overlay,I&&Ye.calendarVisible),children:o.jsx(g.Box,{background:"white",shadow:"popover",borderRadius:"var(--swui-border-radius-large)",children:o.jsxs(C.CardBody,{gap:3,children:[_&&o.jsx(g.Heading,{variant:"h2",as:p,children:_}),o.jsx(g.Box,{height:$}),o.jsx(Fe,{...V,previousMonthButtonAriaLabel:i,nextMonthButtonAriaLabel:c,calendarSize:S,prevMonthDisabled:y,nextMonthDisabled:w,previousMonthButtonTestId:M,nextMonthButtonTestId:E}),K==="calendar"&&o.jsx(Le,{...V,size:S,isValidDateRange:!!H,selectedStartDate:H,selectedEndDate:H,multiSelectable:!1,isDateDisabled:h,dateTestId:j,hoverHighlightDirection:void 0}),K==="month-picker"&&o.jsx(pe,{firstMonth:D,numMonths:m,value:Q,size:S,localeCode:n,onValueChange:te=>{De(te),_e("calendar"),ce.current?.focus()},onCancel:()=>{_e("calendar"),ce.current?.focus()}}),v?.({hideCalendar:O})]})})})]})},Zn=({value:e,onValueChange:t,label:r,localeCode:n="sv",languageLocaleCode:a=n,initialMonthInFocus:s,previousMonthButtonAriaLabel:i="Previous month",nextMonthButtonAriaLabel:c="Next month",placeholderWhenBlurred:d,heading:f,headingLevel:_,numMonthsInMonthPicker:p=12,isDateDisabled:m,prevMonthDisabled:h,nextMonthDisabled:y,firstMonthInMonthPicker:w=new Date,dateTestId:D,size:k="medium",previousMonthButtonTestId:b,nextMonthButtonTestId:x,textInputVariant:v="standard",autoFocus:S})=>{const j=Ut(e,t,n,a,s),{visiblePanel:M,visibleMonth:E,onValueChangeByInputs:B,setVisibleMonth:I,setVisiblePanel:F,monthPickerButtonRef:P,selectedDate:N}=j;return o.jsxs(g.Column,{gap:3,children:[f&&o.jsx(g.Heading,{variant:"h2",as:_,children:f}),o.jsx(Yt,{...j,value:e,onValueChange:B,localeCode:n,label:r,calendarSize:k,placeholderWhenBlurred:d,variant:v,readOnlyOnMobile:!1,autoFocus:S}),o.jsx(Fe,{...j,previousMonthButtonAriaLabel:i,nextMonthButtonAriaLabel:c,calendarSize:k,prevMonthDisabled:h,nextMonthDisabled:y,previousMonthButtonTestId:b,nextMonthButtonTestId:x}),M==="calendar"&&o.jsx(Le,{...j,size:k,selectedStartDate:N,selectedEndDate:N,isValidDateRange:!!N,isDateDisabled:m,multiSelectable:!1,dateTestId:D,hoverHighlightDirection:void 0}),M==="month-picker"&&o.jsx(pe,{firstMonth:w,numMonths:p,value:E,localeCode:a,size:k,onValueChange:L=>{I(L),F("calendar"),P.current?.focus()},onCancel:()=>{F("calendar"),P.current?.focus()}})]})},Xn=({value:e,onValueChange:t,startDateLabel:r,endDateLabel:n,localeCode:a="sv",languageLocaleCode:s=a,initialMonthInFocus:i,previousMonthButtonAriaLabel:c="Previous month",nextMonthButtonAriaLabel:d="Next month",heading:f,headingLevel:_,numMonthsInMonthPicker:p=12,isDateDisabled:m,prevMonthDisabled:h,nextMonthDisabled:y,firstMonthInMonthPicker:w=new Date,size:D="medium",dateTestId:k,previousMonthButtonTestId:b,nextMonthButtonTestId:x,placeholderWhenBlurredStartDate:v,placeholderWhenBlurredEndDate:S,textInputVariant:j="standard",autoFocusStartDate:M,autoFocusEndDate:E})=>{const[B,I]=l.useState(void 0),F=l.useRef(null),P=l.useRef(null),N=l.useCallback(A=>{A==="startDate"?F.current?.focus():A==="endDate"&&P.current?.focus()},[]),L=Ot(e,t,a,s,i,B,I,N,void 0),z=l.useCallback(A=>{I(A)},[]),{visiblePanel:$,visibleMonth:R,onValueChangeByInputs:U,setVisibleMonth:O,setVisiblePanel:Y,monthPickerButtonRef:W}=L;return o.jsxs(g.Column,{gap:3,children:[f&&o.jsx(g.Heading,{variant:"h2",as:_,children:f}),o.jsx(Ht,{...L,value:e,onValueChange:U,startDateRef:F,endDateRef:P,localeCode:a,startDateLabel:r,endDateLabel:n,onFocus:z,calendarSize:D,placeholderWhenBlurredStartDate:v,placeholderWhenBlurredEndDate:S,variant:j,autoFocusStartDate:M,autoFocusEndDate:E,readOnlyOnMobile:!1}),o.jsx(Fe,{...L,previousMonthButtonAriaLabel:c,nextMonthButtonAriaLabel:d,calendarSize:D,prevMonthDisabled:h,nextMonthDisabled:y,previousMonthButtonTestId:b,nextMonthButtonTestId:x}),$==="calendar"&&o.jsx(Le,{...L,size:D,multiSelectable:!0,isDateDisabled:m,dateTestId:k}),$==="month-picker"&&o.jsx(pe,{firstMonth:w,numMonths:p,value:R,size:D,localeCode:s,onValueChange:A=>{O(A),Y("calendar"),W.current?.focus()},onCancel:()=>{Y("calendar"),W.current?.focus()}})]})},ea=()=>{const e=g.useToday();return l.useCallback(t=>!u.isSameDay(t,e)&&u.isBefore(t,e),[e])},ta=()=>{const e=g.useToday();return l.useCallback(t=>u.isSameMonth(e,t)||u.isBefore(t,e),[e])};exports.Calendar=Me;exports.CalendarDay=Je;exports.DateInput=Br;exports.DateRangeCalendar=kr;exports.DateRangeDualTextInput=rn;exports.DateRangeInput=Ir;exports.DateTextInput=Tr;exports.DateTimeInput=Kr;exports.Month=gt;exports.MonthPicker=pe;exports.MultiDateCalendar=Sr;exports.PresetPicker=Mt;exports.SingleDateCalendar=tt;exports.SingleWeekCalendar=jr;exports.TimeTextInput=Nr;exports.TravelDateCalendar=Zn;exports.TravelDateInput=Qn;exports.TravelDateRangeCalendar=Xn;exports.TravelDateRangeInput=qn;exports.WeekDay=ht;exports.WeekDayCell=Dt;exports.WeekNumberCell=kt;exports.YearPicker=Jr;exports.addDayStateHighlights=ne;exports.addDayStateHighlightsOnSingleDay=Ge;exports.addWeekRangeHighlights=_t;exports.addWeekStateHighlights=Jt;exports.buildDayStateForDateRange=ge;exports.buildDayStateForRange=ft;exports.buildDayStateForSingleMonth=dt;exports.calculateOverflowingMonth=yt;exports.createDay=mt;exports.dateRangeToStrings=Bt;exports.dayHasHighlight=vt;exports.dayHighlightSelect=re;exports.defaultCalendarTheme=ie;exports.defaultTextPropsProvider=wt;exports.defaultWrapperStyleProvider=xt;exports.extranetCalendarTheme=er;exports.fallbackLocaleCode=Qe;exports.fallbackLocaleCodeForFormatting=ur;exports.formatLocalizedDate=oe;exports.getDateFormatForLocaleCode=fe;exports.getDaysForWeekForDate=bt;exports.getDefaultLocaleForFormatting=dr;exports.getLocaleCodeForLocale=jt;exports.getLocaleForLocaleCode=ue;exports.getMonthInYear=ve;exports.getMonthsInYear=Ue;exports.getSupportedLocaleCode=Ze;exports.getSupportedLocaleCodeMatchingLanguage=St;exports.getWeekForDate=Ee;exports.getWeeksForMonth=pt;exports.isDateRangeInvalid=Xe;exports.parseLocalizedDateString=Z;exports.reformatLocalizedDateString=Ie;exports.setDayStateValue=Kt;exports.setDayStateValueFunction=Gt;exports.stringsToDateRange=Rt;exports.toggleDateStringsIfEndIsEarlierThanStart=wr;exports.toggleDatesIfEndIsEarlierThanStart=et;exports.useDateRangeCalendarState=Cr;exports.useDateRangeSelection=It;exports.useDisabledBeforeToday=ea;exports.useMultiDateSelection=Et;exports.usePrevMonthDisabledBeforeToday=ta;exports.useSingleDateSelection=Tt;exports.useSingleWeekSelection=Nt;
|
|
3
3
|
//# sourceMappingURL=index.js.map
|