timepicker-ui 3.1.3 → 4.0.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/LICENSE +1 -1
- package/README.md +402 -56
- package/dist/css/index.css +1 -1
- package/dist/css/main.css +1 -1
- package/dist/css/themes/theme-ai.css +1 -1
- package/dist/css/themes/theme-crane-straight.css +1 -0
- package/dist/css/themes/theme-crane.css +1 -1
- package/dist/css/themes/theme-cyberpunk.css +1 -1
- package/dist/css/themes/theme-dark.css +1 -1
- package/dist/css/themes/theme-glassmorphic.css +1 -1
- package/dist/css/themes/theme-m2.css +1 -0
- package/dist/css/themes/theme-m3-green.css +1 -0
- package/dist/css/themes/theme-pastel.css +1 -1
- package/dist/index.cjs +1 -77
- package/dist/index.d.cts +439 -668
- package/dist/index.d.ts +439 -668
- package/dist/index.js +1 -77
- package/dist/index.umd.js +1 -1
- package/package.json +5 -5
- package/dist/css/themes/theme-custom.css +0 -1
- package/dist/css/themes/theme-m3.css +0 -1
package/dist/index.cjs
CHANGED
|
@@ -1,77 +1 @@
|
|
|
1
|
-
"use strict";var Te=Object.defineProperty;var Fe=Object.getOwnPropertyDescriptor;var Oe=Object.getOwnPropertyNames;var Pe=Object.prototype.hasOwnProperty;var Ne=(n,e)=>()=>(n&&(e=n(n=0)),e);var _e=(n,e)=>{for(var t in e)Te(n,t,{get:e[t],enumerable:!0})},We=(n,e,t,i)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of Oe(e))!Pe.call(n,r)&&r!==t&&Te(n,r,{get:()=>e[r],enumerable:!(i=Fe(e,r))||i.enumerable});return n};var He=n=>We(Te({},"__esModule",{value:!0}),n);var Se={};_e(Se,{getMobileModalTemplate:()=>Ke,getModalTemplate:()=>Re,getNumberOfHours12:()=>B,getNumberOfHours24:()=>q,getNumberOfMinutes:()=>R});var q,B,R,Re,Ke,fe=Ne(()=>{"use strict";q=["00","13","14","15","16","17","18","19","20","21","22","23"],B=["12","1","2","3","4","5","6","7","8","9","10","11"],R=["00","05","10","15","20","25","30","35","40","45","50","55"],Re=(n,e)=>{let{iconTemplate:t,timeLabel:i,amLabel:r,pmLabel:s,cancelLabel:a,okLabel:o,enableSwitchIcon:c,animation:p,clockType:T,editable:l,theme:h}=n;return`
|
|
2
|
-
<div class="timepicker-ui-modal normalize ${h}" role="dialog" aria-modal="true" aria-labelledby="timepicker-ui-label-${e}" data-owner-id="${e}" style='transition:${p?"opacity 0.15s linear":"none"}'>
|
|
3
|
-
<div class="timepicker-ui-wrapper" tabindex="0">
|
|
4
|
-
<div class="timepicker-ui-header">
|
|
5
|
-
<div class="timepicker-ui-select-time" id="timepicker-ui-label-${e}">${i}</div>
|
|
6
|
-
<div class="timepicker-ui-wrapper-time ${T==="24h"?"timepicker-ui-wrapper-time-24h":""}" role="group" aria-label="${i}">
|
|
7
|
-
<input name="hour" ${l?"":"readonly"} class="timepicker-ui-hour" tabindex="0" type="number" min="0" max="${T==="12h"?"12":"23"}" aria-label="Hour" role="spinbutton" aria-valuenow="12" />
|
|
8
|
-
<div class="timepicker-ui-dots" aria-hidden="true">
|
|
9
|
-
<span></span>
|
|
10
|
-
<span></span>
|
|
11
|
-
</div>
|
|
12
|
-
<input name="minutes" ${l?"":"readonly"} class="timepicker-ui-minutes" tabindex="0" type="number" min="0" max="59" aria-label="Minute" role="spinbutton" aria-valuenow="0" />
|
|
13
|
-
</div>
|
|
14
|
-
${T!=="24h"?`
|
|
15
|
-
<div class="timepicker-ui-wrapper-type-time" role="group" aria-label="Time period">
|
|
16
|
-
<div class="timepicker-ui-type-mode timepicker-ui-am" tabindex="0" role="button" aria-label="${r}" aria-pressed="false" data-type="AM">${r}</div>
|
|
17
|
-
<div class="timepicker-ui-type-mode timepicker-ui-pm" tabindex="0" role="button" aria-label="${s}" aria-pressed="false" data-type="PM">${s}</div>
|
|
18
|
-
</div>
|
|
19
|
-
`:""}
|
|
20
|
-
</div>
|
|
21
|
-
<div class="timepicker-ui-wrapper-landspace">
|
|
22
|
-
<div class="timepicker-ui-body">
|
|
23
|
-
<div class="timepicker-ui-clock-face" role="group" aria-label="Clock face">
|
|
24
|
-
<div class="timepicker-ui-dot" aria-hidden="true"></div>
|
|
25
|
-
<div class="timepicker-ui-clock-hand" aria-hidden="true">
|
|
26
|
-
<div class="timepicker-ui-circle-hand"></div>
|
|
27
|
-
</div>
|
|
28
|
-
<div class="timepicker-ui-tips-wrapper" role="listbox" aria-label="Time values"></div>
|
|
29
|
-
${T==="24h"?'<div class="timepicker-ui-tips-wrapper-24h" role="listbox" aria-label="24-hour time values"></div>':""}
|
|
30
|
-
</div>
|
|
31
|
-
</div>
|
|
32
|
-
<div class="timepicker-ui-footer">
|
|
33
|
-
${c?`
|
|
34
|
-
<div class="timepicker-ui-keyboard-icon-wrapper" tabindex="0" role="button" aria-pressed="false" aria-label="Toggle keyboard mode" data-view="desktop">
|
|
35
|
-
${t}
|
|
36
|
-
</div>`:""}
|
|
37
|
-
<div class="timepicker-ui-wrapper-btn" >
|
|
38
|
-
<div class="timepicker-ui-cancel-btn" tabindex="0" role="button" aria-pressed="false" aria-label="${a}">${a}</div>
|
|
39
|
-
<div class="timepicker-ui-ok-btn" tabindex="0" role="button" aria-pressed="false" aria-label="${o}">${o}</div>
|
|
40
|
-
</div>
|
|
41
|
-
</div>
|
|
42
|
-
</div>
|
|
43
|
-
</div>
|
|
44
|
-
<div class="timepicker-announcer sr-only" role="status" aria-live="polite" aria-atomic="true"></div>
|
|
45
|
-
</div>`},Ke=(n,e)=>{let{mobileTimeLabel:t,amLabel:i,pmLabel:r,cancelLabel:s,okLabel:a,iconTemplateMobile:o,minuteMobileLabel:c,hourMobileLabel:p,enableSwitchIcon:T,animation:l,clockType:h,theme:f}=n;return`
|
|
46
|
-
<div class="timepicker-ui-modal normalize mobile ${f}" role="dialog" aria-modal="true" aria-labelledby="timepicker-ui-label-mobile-${e}" data-owner-id="${e}" style='transition:${l?"opacity 0.15s linear":"none"}'>
|
|
47
|
-
<div class="timepicker-ui-wrapper mobile" tabindex="0">
|
|
48
|
-
<div class="timepicker-ui-header mobile">
|
|
49
|
-
<div class="timepicker-ui-select-time mobile" id="timepicker-ui-label-mobile-${e}">${t}</div>
|
|
50
|
-
<div class="timepicker-ui-wrapper-time mobile" role="group" aria-label="${t}">
|
|
51
|
-
<input class="timepicker-ui-hour mobile" tabindex="0" type="number" min="0" max="${h==="12h"?"12":"23"}" aria-label="${p}" role="spinbutton" aria-valuenow="12" />
|
|
52
|
-
<div class="timepicker-ui-hour-text mobile">${p}</div>
|
|
53
|
-
<div class="timepicker-ui-dots mobile" aria-hidden="true">
|
|
54
|
-
<span></span>
|
|
55
|
-
<span></span>
|
|
56
|
-
</div>
|
|
57
|
-
<div class="timepicker-ui-minute-text mobile">${c}</div>
|
|
58
|
-
<input class="timepicker-ui-minutes mobile" tabindex="0" type="number" min="0" max="59" aria-label="${c}" role="spinbutton" aria-valuenow="0" />
|
|
59
|
-
</div>
|
|
60
|
-
${h!=="24h"?`<div class="timepicker-ui-wrapper-type-time mobile" role="group" aria-label="Time period">
|
|
61
|
-
<div class="timepicker-ui-type-mode timepicker-ui-am mobile" data-type="AM" tabindex="0" role="button" aria-label="${i}" aria-pressed="false">${i}</div>
|
|
62
|
-
<div class="timepicker-ui-type-mode timepicker-ui-pm mobile" data-type="PM" tabindex="0" role="button" aria-label="${r}" aria-pressed="false">${r}</div>
|
|
63
|
-
</div>`:""}
|
|
64
|
-
</div>
|
|
65
|
-
<div class="timepicker-ui-footer mobile" data-view="mobile">
|
|
66
|
-
${T?`
|
|
67
|
-
<div class="timepicker-ui-keyboard-icon-wrapper mobile" role="button" aria-pressed="false" aria-label="Toggle keyboard mode" data-view="desktop" tabindex="0">
|
|
68
|
-
${o}
|
|
69
|
-
</div>`:""}
|
|
70
|
-
<div class="timepicker-ui-wrapper-btn mobile">
|
|
71
|
-
<div class="timepicker-ui-cancel-btn mobile" role="button" aria-pressed="false" aria-label="${s}" tabindex="0">${s}</div>
|
|
72
|
-
<div class="timepicker-ui-ok-btn mobile" role="button" aria-pressed="false" aria-label="${a}" tabindex="0">${a}</div>
|
|
73
|
-
</div>
|
|
74
|
-
</div>
|
|
75
|
-
</div>
|
|
76
|
-
<div class="timepicker-announcer sr-only" role="status" aria-live="polite" aria-atomic="true"></div>
|
|
77
|
-
</div>`}});var je={};_e(je,{EventEmitter:()=>W,TimepickerUI:()=>U,default:()=>ze});module.exports=He(je);var Ie=(n,e)=>({...e,...n}),Ce=()=>{let n=document.createElement("div");n.className="timepicker-ui-measure",document.body.appendChild(n);let e=n.getBoundingClientRect().width-n.clientWidth;return document.body.removeChild(n),e},Le=n=>n*(Math.PI/180),be=(n,e)=>{let{touches:t}=n,{clientX:i,clientY:r}=n;if(!e)return;let{left:s,top:a}=e.getBoundingClientRect(),o={x:0,y:0};if(t===void 0)o={x:i-s,y:r-a};else if(t!==void 0&&t.length>0&&Object.keys(t).length>0){let{clientX:c,clientY:p}=t[0];o={x:c-s,y:p-a}}if(!(Object.keys(o).length===0&&o.constructor===Object))return o},Ve=(n,e)=>Math.round(n/e)*e,m=(n,e)=>n?n.classList.contains(e):!1;var _=(n,e,t,i,r,s)=>{if(!n)return;let a=new CustomEvent(t,{detail:i,bubbles:!0,cancelable:!0});try{if(n.dispatchEvent(a)&&e!==t){let c=new CustomEvent(e,{detail:i,bubbles:!0,cancelable:!0});n.dispatchEvent(c)}if(s&&"emit"in s&&typeof s.emit=="function"){let c=t.replace("timepicker:","").replace(/-/g,":");s.emit(c,i)}}catch(o){console.warn(`TimepickerUI: Error dispatching event ${t}:`,o)}if(r&&typeof r=="function")try{r(i)}catch(o){console.warn(`TimepickerUI: Error in ${t} callback:`,o)}},we=()=>/Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent),ue=(n,e,t)=>Ve(n,e*t),Ae=n=>{if(!n)return;let e=JSON.parse(JSON.stringify(n)),t=Object.keys(e);return Object.values(e).reduce((i,r,s)=>(Number(r)?i[t[s]]=Number(r):r==="true"||r==="false"?i[t[s]]=JSON.parse(r):(typeof r=="string"||typeof r=="number"||typeof r=="boolean")&&(i[t[s]]=r),i),{})},V=(n,e)=>Array.from({length:Number(e)-Number(n)+1},(t,i)=>Number(n)+i),de=(n,e)=>Array.from({length:Number(e)-Number(n)+1},(t,i)=>Number(e)-i).reverse(),P=n=>{n&&typeof n=="function"&&n()},F=(n="")=>{let e=n.replace(/(AM|PM|am|pm)/,s=>` ${s}`),t=new Date(`September 20, 2000 ${e}`),i=t.getHours().toString().padStart(2,"0"),r=t.getMinutes().toString().padStart(2,"0");return`${i}:${r}`},O=n=>{let[e,t]=n.split(":"),i=Number(e),r=Number(t);return`${i<=9?"0"+i:i}:${r<=9?"0"+r:r}`},he=(n,e)=>{if(n.length<2)return!1;let t=n.map(i=>{let[r,s]=i.trim().split("-"),a,o;if(e==="12h"){if(!/\s?(AM|PM|am|pm)\s?$/.test(r.trim())||!/\s?(AM|PM|am|pm)\s?$/.test(s.trim()))throw new Error(`Invalid 12h format in interval: "${i}". AM/PM is required for 12h clock type.`);a=F(r.trim()),o=F(s.trim())}else{if(/\s?(AM|PM|am|pm)\s?/.test(r.trim())||/\s?(AM|PM|am|pm)\s?/.test(s.trim()))throw new Error(`Invalid 24h format in interval: "${i}". AM/PM is not allowed for 24h clock type.`);a=O(r.trim()),o=O(s.trim())}return{start:a,end:o,original:i}});for(let i=0;i<t.length;i++)for(let r=i+1;r<t.length;r++){let s=t[i],a=t[r];if(s.start<=a.end&&s.end>=a.start||a.start<=s.end&&a.end>=s.start)throw new Error(`Overlapping time intervals detected: "${s.original}" overlaps with "${a.original}"`)}return!1},xe=()=>typeof window<"u"&&window.crypto&&typeof window.crypto.randomUUID=="function"?window.crypto.randomUUID():"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,n=>{let e=Math.random()*16|0;return(n==="x"?e:e&3|8).toString(16)});var ke=n=>n.replace(/[^0-9:APMapm\s]/g,"");var ve=(n,e)=>{let t;return(...i)=>{clearTimeout(t),t=setTimeout(()=>{n(...i)},e)}};var ye="timepicker-ui",qe="mousedown mouseup mousemove mouseleave mouseover",Be="touchstart touchmove touchend",De=`${qe} ${Be}`,H="active";fe();var C=(n,e,t,i)=>{let r={hour:"12",minutes:"00",type:e==="24h"?void 0:"PM"};if(!n)return r;let s=n.value.trim();if(!t&&s==="")return r;if(typeof t=="boolean"&&t){let k=new Date,[u,b]=k.toLocaleTimeString().split(":"),d=Number(u)<=9?`0${Number(u)}`:u;if(/[a-z]/i.test(b)&&e==="12h"){let[v,M]=b.split(" ");return{hour:d,minutes:v,type:M}}return{hour:d,minutes:b,type:void 0}}if(typeof t=="object"){let{time:k,locales:u,preventClockType:b}=t,d=k??new Date;if(b&&i){let[g,E]=new Date(d).toLocaleTimeString().split(":");if(/[a-z]/i.test(E)){let[L,x]=E.split(" ");return{hour:g,minutes:L,type:x}}return{hour:Number(g)<=9?`0${Number(g)}`:g,minutes:E,type:void 0}}let[v,M]=new Date(d).toLocaleTimeString(u,{timeStyle:"short"}).split(":"),I=Number(v)<=9?`0${Number(v)}`:v;if(/[a-z]/i.test(M)&&e==="12h"){let[g,E]=M.split(" ");return{hour:I,minutes:g,type:E}}if(e==="12h"){let[g,E]=new Date(`1970-01-01T${v}:${M}Z`).toLocaleTimeString("en-US",{timeZone:"UTC",hour12:!0,hour:"numeric",minute:"numeric"}).split(":"),[A,L]=E.split(" ");return{hour:Number(g)<=9?`0${Number(g)}`:g,minutes:A,type:L}}return{hour:I,minutes:M,type:void 0}}let[a,o]=s.split(" "),[c="",p=""]=a.split(":"),T=c.replace(/\D/g,""),l=p.replace(/\D/g,""),h={hour:T.padStart(2,"0"),minutes:l.padStart(2,"0"),type:e==="12h"?o:void 0};if(T.length>2||l.length>2)return{...h,error:"Invalid input: too many digits.",currentHour:c,currentMin:p};if(/[a-z]/i.test(a))return{...h,error:"Input contains invalid letters."};if(s.includes(" ")&&(!o||s.length>8||o!=="AM"&&o!=="PM"))return{...h,error:"Invalid AM/PM format or length.",currentLength:s.length,currentType:o};let f=Number(T),y=Number(l);if(e==="12h"){if(f<1||f>12||y<0||y>59||o!=="AM"&&o!=="PM")return{...h,error:"Invalid 12h time.",currentHour:f,currentMin:y,currentType:o}}else if(f<0||f>23||y<0||y>59)return{...h,error:"Invalid 24h time.",currentHour:f,currentMin:y};return h},D=(n,e,t)=>{let i=Number(n);if(Number.isNaN(i))return!1;switch(e){case"hour":return t==="24h"?i>=0&&i<=23:i>0&&i<=12;case"minutes":return i>=0&&i<=59;default:return}};var Me={amLabel:"AM",animation:!0,appendModalSelector:"",backdrop:!0,cancelLabel:"CANCEL",editable:!1,enableScrollbar:!1,enableSwitchIcon:!1,mobileTimeLabel:"Enter Time",focusInputAfterCloseModal:!1,hourMobileLabel:"Hour",iconTemplate:'<i class="material-icons timepicker-ui-keyboard-icon">keyboard</i>',iconTemplateMobile:'<i class="material-icons timepicker-ui-keyboard-icon">schedule</i>',incrementHours:1,incrementMinutes:1,minuteMobileLabel:"Minute",mobile:!1,okLabel:"OK",pmLabel:"PM",timeLabel:"Select Time",switchToMinutesAfterSelectHour:!1,theme:"basic",clockType:"12h",disabledTime:void 0,currentTime:void 0,focusTrap:!0,delayHandler:300,inline:void 0,cssClass:void 0};var $e=n=>{if(!n)return;let{disabledTime:e,clockType:t}=n;if(!e||Object.keys(e).length<=0||e.constructor.name!=="Object")return;let{hours:i,minutes:r,interval:s}=e;if(s){delete e.hours,delete e.minutes;let a=Array.isArray(s)?s:[s];if(!t)throw new Error("clockType is required when using disabledTime.interval");try{he(a,t)}catch(p){throw p}return{value:a.map(p=>{let[T,l]=p.trim().split("-"),{hour:h,minutes:f,type:y}=C({value:T.trim()},t),{hour:k,minutes:u,type:b}=C({value:l.trim()},t),d=V(h,k).map(g=>g==="00"||Number(g)===0?`0${Number(g)}`:`${Number(g)}`),v=[],M=Number(f),I=Number(u);if(b===y)return M>0&&I<=0?(v.push(d[0],d[d.length-1]),d=d.slice(1,-1)):I<59&&I>0&&M<=0?(v.push(void 0,d[d.length-1]),d=d.slice(0,-1)):I>0&&M>0?(v.push(d[0],d[d.length-1]),d=d.slice(1,-1)):I===0&&M===0&&(v.push(void 0,d[d.length-1]),d.pop()),{removedStartedHour:v[0]!==void 0&&Number(v[0])<=9?`0${v[0]}`:v[0],removedEndHour:v[1]!==void 0&&Number(v[1])<=9?`0${v[1]}`:v[1],rangeArrHour:d,startMinutes:V(f,59).map(g=>Number(g)<=9?`0${g}`:`${g}`),endMinutes:de(0,u).map(g=>Number(g)<=9?`0${g}`:`${g}`),startType:y,endType:b};{let g=V(h,12).map(String),E=de(1,k).map(String),A=[],L=[];return M>0&&I<=0?(L.push(E[E.length-1]),A.push(g[0]),E.pop(),g.shift()):I<59&&I>0&&M<=0?(A.push(g[0]),L.push(E[E.length-1]),E.pop()):I>0&&M>0?(L.push(E[E.length-1]),A.push(g[0]),E.pop(),g.shift()):I===0&&M===0&&(L.push(E[E.length-1]),A.push(g[0]),E.pop()),{startType:y,endType:b,amHours:g,pmHours:E,removedAmHour:A[0]&&Number(A[0])<=9?`0${A[0]}`:A[0],removedPmHour:L[0]&&Number(L[0])<=9?`0${L[0]}`:L[0],startMinutes:Number(f)===0?[]:V(f,59).map(x=>Number(x)<=9?`0${x}`:`${x}`),endMinutes:de(0,u).map(x=>Number(x)<=9?`0${x}`:`${x}`)}}}).reduce((p,T)=>(Object.entries(T).forEach(([l,h])=>{Array.isArray(h)?p[l]=Array.isArray(p[l])?[...p[l],...h]:[...h]:p[l]=h}),p),{isInterval:!0,clockType:t,intervals:a})}}return i?.forEach(a=>{if(t==="12h"&&Number(a)>12)throw new Error("The disabled hours value has to be less than 13");if(t==="24h"&&Number(a)>23)throw new Error("The disabled hours value has to be less than 24")}),r?.forEach(a=>{if(Number(a)>59)throw new Error("The disabled minutes value has to be less than 60")}),{value:{hours:i?.map(a=>a==="00"||Number(a)===0?`0${Number(a)}`:`${Number(a)}`),minutes:r?.map(a=>Number(a)<=9?`0${a}`:`${a}`)}}},N=(n,e,t,i)=>{if(n){if(Array.isArray(n)&&n.length>0)return!n.map(s=>D(s,e,t)).some(s=>s===!1);if(typeof n=="string"||typeof n=="number"){let r=D(n,e,t),s=i?.map(Number).includes(Number(n));return!!(r&&!s)}}},w=(n,e,t,i,r)=>{if(!n||!e||!i||!r)return!1;let s=r==="12h"?F(`${n}:${e} ${t||""}`.trim()):O(`${n}:${e}`),a=Array.isArray(i)?i:[i];for(let o of a){let[c,p]=o.trim().split("-"),T,l;if(r==="12h"){let h=c.trim(),f=p.trim();if(!/\s?(AM|PM|am|pm)\s?$/.test(h)||!/\s?(AM|PM|am|pm)\s?$/.test(f)){console.warn(`Invalid 12h format in interval: "${o}". AM/PM is required for 12h clock type.`);continue}T=F(h),l=F(f)}else{let h=c.trim(),f=p.trim();if(/\s?(AM|PM|am|pm)\s?/.test(h)||/\s?(AM|PM|am|pm)\s?/.test(f)){console.warn(`Invalid 24h format in interval: "${o}". AM/PM is not allowed for 24h clock type.`);continue}T=O(h),l=O(f)}if(s>=T&&s<=l)return!1}return!0};var K=class{array;classToAdd;clockFace;tipsWrapper;theme;clockType;disabledTime;hour;activeTypeMode;_tipsCache=new Map;constructor(e){Object.assign(this,e)}clean=()=>{let e=this.tipsWrapper?.querySelectorAll("span.timepicker-ui-hour-time-12"),t=this.tipsWrapper?.querySelectorAll("span.timepicker-ui-minutes-time");this._removeClasses(e),this._removeClasses(t)};create=()=>{if(!this.clockFace||!this.array||!this.classToAdd||!this.tipsWrapper)return;let e=(this.clockFace.offsetWidth-32)/2,t=(this.clockFace.offsetHeight-32)/2,i=e-9,r=new Set(this._tipsCache.keys()),s=document.createDocumentFragment();this.array.forEach((a,o,c)=>{let p=`${this.classToAdd}-${a}-${this.theme||"default"}`;r.delete(p);let T=this._tipsCache.get(p);T||(T=this._createTip(a),this._tipsCache.set(p,T));let{wrapper:l,tip:h}=T;this._updateTipState(l,h,a);let f=Le(o*(360/c.length));l.style.left=`${e+Math.sin(f)*i}px`,l.style.bottom=`${t+Math.cos(f)*i}px`,s.appendChild(l)}),r.forEach(a=>this._tipsCache.delete(a)),this.tipsWrapper.innerHTML="",this.tipsWrapper.appendChild(s)};_createTip(e){let t=document.createElement("span"),i=document.createElement("span");i.innerHTML=e,i.setAttribute("role","option"),i.setAttribute("aria-selected","false"),i.tabIndex=0;let r=this.clockType==="24h"?"timepicker-ui-value-tips-24h":"timepicker-ui-value-tips";return i.classList.add(r),t.classList.add(this.classToAdd||""),this.theme&&(t.classList.add(this.theme),i.classList.add(this.theme)),t.appendChild(i),{wrapper:t,tip:i}}_updateTipState(e,t,i){if(e.classList.remove("timepicker-ui-tips-disabled"),t.classList.remove("timepicker-ui-tips-disabled"),t.removeAttribute("aria-disabled"),t.tabIndex=0,this.disabledTime&&(Array.isArray(this.disabledTime)&&this.disabledTime.includes(i)&&(t.classList.add("timepicker-ui-tips-disabled"),e.classList.add("timepicker-ui-tips-disabled"),t.setAttribute("aria-disabled","true")),this.disabledTime.isInterval&&this.disabledTime.clockType)){let r=this.classToAdd?.includes("minutes"),s=this.classToAdd?.includes("hour");if(r&&this.hour)!w(this.hour,i,this.activeTypeMode||"",this.disabledTime.intervals||[],this.disabledTime.clockType)&&(t.classList.add("timepicker-ui-tips-disabled"),e.classList.add("timepicker-ui-tips-disabled"),t.tabIndex=-1,t.setAttribute("aria-disabled","true"));else if(s){let a=!0;for(let o=0;o<60;o++){let c=o.toString().padStart(2,"0");if(w(i,c,this.activeTypeMode||"",this.disabledTime.intervals||[],this.disabledTime.clockType)){a=!1;break}}a&&(t.classList.add("timepicker-ui-tips-disabled"),e.classList.add("timepicker-ui-tips-disabled"),t.tabIndex=-1,t.setAttribute("aria-disabled","true"))}}}updateDisable=(e,t)=>{let i=this.tipsWrapper?.querySelectorAll("span.timepicker-ui-hour-time-12"),r=this.tipsWrapper?.querySelectorAll("span.timepicker-ui-minutes-time");if(this._removeClasses(i),this._removeClasses(r),!this.disabledTime?.isInterval||!this.disabledTime?.intervals)return;let s=this.disabledTime.intervals,a=this.disabledTime.clockType,o=t||this.activeTypeMode||"";i?.forEach(c=>{let p=c.querySelector(".timepicker-ui-value-tips");if(!p)return;let T=p.innerHTML,l=!0;for(let h=0;h<60;h++){let f=h.toString().padStart(2,"0");if(w(T,f,o,s,a)){l=!1;break}}l&&(c.classList.add("timepicker-ui-tips-disabled"),p.classList.add("timepicker-ui-tips-disabled"),p.setAttribute("aria-disabled","true"),p.tabIndex=-1)}),r&&e&&r.forEach(c=>{let p=c.querySelector(".timepicker-ui-value-tips");if(!p)return;let T=p.innerHTML;!w(e,T,o,s,a)&&(c.classList.add("timepicker-ui-tips-disabled"),p.classList.add("timepicker-ui-tips-disabled"),p.setAttribute("aria-disabled","true"),p.tabIndex=-1)})};_removeClasses=e=>{e?.forEach(t=>{let i=t.children[0];t.classList.remove("timepicker-ui-tips-disabled"),i&&(i.classList.remove("timepicker-ui-tips-disabled"),i.removeAttribute("aria-disabled"),i.tabIndex=0)})};destroy(){this.tipsWrapper&&(this.tipsWrapper.innerHTML=""),this._tipsCache.clear(),this.array=this.classToAdd=this.theme=this.clockType=void 0,this.disabledTime=this.hour=this.activeTypeMode=void 0,this.clockFace=this.tipsWrapper=void 0}};var z=class{pool=[];maxSize=5;acquire(e){let t=this.pool.pop();return t?(Object.assign(t,e),t):new K(e)}release(e){this.pool.length<this.maxSize&&this.pool.push(e)}clear(){this.pool=[]}};var j=class{timepicker;cleanupHandlers;constructor(e,t){this.timepicker=e,this.cleanupHandlers=t}handleCancelButton=()=>{let e=()=>{let t=C(this.timepicker.input,this.timepicker._options.clockType);_(this.timepicker._element,"cancel","timepicker:cancel",{...t,hourNotAccepted:this.timepicker.hour.value,minutesNotAccepted:this.timepicker.minutes.value,type:this.timepicker.activeTypeMode?.dataset.type,degreesHours:this.timepicker._degreesHours,degreesMinutes:this.timepicker._degreesMinutes},this.timepicker._options.onCancel,this.timepicker),this.timepicker.close()()};this.timepicker.cancelButton.addEventListener("click",e),this.cleanupHandlers.push(()=>{this.timepicker.cancelButton?.removeEventListener("click",e)})};handleOkButton=()=>{let e=()=>{let{clockType:t,disabledTime:i}=this.timepicker._options,r=D(this.timepicker.hour.value,"hour",t),s=D(this.timepicker.minutes.value,"minutes",t),a,o=N(this.timepicker.hour.value,"hour",t,i?.hours),c=N(this.timepicker.minutes.value,"minutes",t,i?.minutes);if(i?.interval&&(a=w(this.timepicker.hour.value,this.timepicker.minutes.value,this.timepicker.activeTypeMode?.textContent||"",i.interval,t)),a===!1||r===!1||s===!1||o===!1||c===!1){(a===!1||!s||!c)&&this.timepicker.minutes.classList.add("invalid-value"),(a===!1||!r||!o)&&this.timepicker.hour.classList.add("invalid-value");return}this.timepicker.input.value=`${this.timepicker.hour.value}:${this.timepicker.minutes.value} ${this.timepicker._options.clockType==="24h"?"":this.timepicker.activeTypeMode?.dataset.type}`.trimEnd(),_(this.timepicker._element,"","timepicker:confirm",{hour:this.timepicker.hour.value,minutes:this.timepicker.minutes.value,type:this.timepicker.activeTypeMode?.dataset.type,degreesHours:this.timepicker._degreesHours,degreesMinutes:this.timepicker._degreesMinutes},this.timepicker._options.onConfirm,this.timepicker),this.timepicker.close()()};this.timepicker.okButton?.addEventListener("click",e),this.cleanupHandlers.push(()=>{this.timepicker.okButton?.removeEventListener("click",e)})};handleBackdropClick=()=>{let e=t=>{let i=t.target;if(!m(i,"timepicker-ui-modal"))return;let r=C(this.timepicker.input,this.timepicker._options.clockType);_(this.timepicker._element,"","timepicker:cancel",{...r,hourNotAccepted:this.timepicker.hour.value,minutesNotAccepted:this.timepicker.minutes.value,type:this.timepicker.activeTypeMode?.dataset.type,degreesHours:this.timepicker._degreesHours,degreesMinutes:this.timepicker._degreesMinutes},this.timepicker._options.onCancel,this.timepicker),this.timepicker.close()()};this.timepicker.modalElement?.addEventListener("click",e),this.cleanupHandlers.push(()=>{this.timepicker.modalElement?.removeEventListener("click",e)})}};var Y=class{timepicker;_isDragging=!1;_animationFrameId=null;_pendingUpdate=!1;updateHandPosition;constructor(e,t){this.timepicker=e,this.updateHandPosition=t}get isDragging(){return this._isDragging}get animationFrameId(){return this._animationFrameId}cleanup(){document.removeEventListener("mousedown",this._onDragStart,!1),document.removeEventListener("touchstart",this._onDragStart),document.removeEventListener("mousemove",this._onDragMove,!1),document.removeEventListener("mouseup",this._onDragEnd,!1),document.removeEventListener("touchmove",this._onDragMove),document.removeEventListener("touchend",this._onDragEnd,!1),document.removeEventListener("mouseleave",this._onDragEnd,!1),this._animationFrameId&&(cancelAnimationFrame(this._animationFrameId),this._animationFrameId=null),this._isDragging=!1,this._pendingUpdate=!1}_onDragStart=e=>{let t=e.target;(m(t,"timepicker-ui-clock-face")||m(t,"timepicker-ui-circle-hand")||m(t,"timepicker-ui-hour-time-12")||m(t,"timepicker-ui-minutes-time")||m(t,"timepicker-ui-clock-hand")||m(t,"timepicker-ui-value-tips")||m(t,"timepicker-ui-value-tips-24h")||m(t,"timepicker-ui-tips-wrapper")||m(t,"timepicker-ui-tips-wrapper-24h"))&&!m(t,"timepicker-ui-tips-disabled")&&(e.preventDefault(),this._isDragging=!0,this.timepicker._isTouchMouseMove=!0,document.addEventListener("mousemove",this._onDragMove,!1),document.addEventListener("mouseup",this._onDragEnd,!1),document.addEventListener("touchmove",this._onDragMove,{passive:!1}),document.addEventListener("touchend",this._onDragEnd,!1),document.addEventListener("mouseleave",this._onDragEnd,!1),this._scheduleUpdate(e))};_onDragMove=e=>{this._isDragging&&(e.preventDefault(),this._scheduleUpdate(e))};_onDragEnd=e=>{if(!this._isDragging)return;this._isDragging=!1,this.timepicker._isTouchMouseMove=!1,document.removeEventListener("mousemove",this._onDragMove,!1),document.removeEventListener("mouseup",this._onDragEnd,!1),document.removeEventListener("touchmove",this._onDragMove),document.removeEventListener("touchend",this._onDragEnd,!1),document.removeEventListener("mouseleave",this._onDragEnd,!1),this._animationFrameId&&(cancelAnimationFrame(this._animationFrameId),this._animationFrameId=null,this._pendingUpdate=!1);let t=e.target,{switchToMinutesAfterSelectHour:i}=this.timepicker._options;i&&(m(t,"timepicker-ui-value-tips")||m(t,"timepicker-ui-value-tips-24h")||m(t,"timepicker-ui-tips-wrapper"))&&this.timepicker.minutes.click()};_scheduleUpdate=e=>{this._pendingUpdate||(this._pendingUpdate=!0,this._animationFrameId=requestAnimationFrame(()=>{this._pendingUpdate=!1,this.updateHandPosition(e)}))};handleEventToMoveHand=e=>{let{type:t}=e;t==="mousedown"||t==="touchstart"?this._onDragStart(e):t==="mouseup"||t==="touchend"?this._onDragEnd(e):(t==="mousemove"||t==="touchmove")&&this._isDragging&&this._onDragMove(e)};handleMoveHand=()=>{this.timepicker._options.mobile||this.timepicker._isMobileView||(document.addEventListener("mousedown",this._onDragStart,!1),document.addEventListener("touchstart",this._onDragStart,{passive:!1}))}};var S=(n,e)=>{if(!n)return;let t=n.querySelector(".timepicker-announcer");t&&(t.textContent="",setTimeout(()=>{t.textContent=e},100))},Z=(n,e)=>{n&&n.setAttribute("aria-pressed",String(e))};var J=class{timepicker;cleanupHandlers;constructor(e,t){this.timepicker=e,this.cleanupHandlers=t}handleAmClick=()=>{this.timepicker._clickTouchEvents.forEach(e=>{let t=i=>{let r=i.target;r.classList.add(H),this.timepicker.PM.classList.remove(H),Z(r,!0),Z(this.timepicker.PM,!1),S(this.timepicker.modalElement,"AM selected"),this.timepicker._options.clockType==="12h"&&this.timepicker._options.disabledTime?.interval&&setTimeout(()=>{let s=this.timepicker.clockFacePool.acquire({clockFace:this.timepicker.clockFace,tipsWrapper:this.timepicker.tipsWrapper,disabledTime:this.timepicker._disabledTime?.value,clockType:this.timepicker._options.clockType,activeTypeMode:"AM"});s.updateDisable(this.timepicker.hour.value,"AM"),this.timepicker.clockFacePool.release(s)},300),_(this.timepicker._element,"","timepicker:select-am",{hour:this.timepicker.hour.value,minutes:this.timepicker.minutes.value,type:this.timepicker.activeTypeMode?.dataset.type,degreesHours:this.timepicker._degreesHours,degreesMinutes:this.timepicker._degreesMinutes},this.timepicker._options.onSelectAM,this.timepicker)};this.timepicker.AM.addEventListener(e,t),this.cleanupHandlers.push(()=>{this.timepicker.AM?.removeEventListener(e,t)})})};handlePmClick=()=>{this.timepicker._clickTouchEvents.forEach(e=>{let t=i=>{let r=i.target;r.classList.add(H),this.timepicker.AM.classList.remove(H),Z(r,!0),Z(this.timepicker.AM,!1),S(this.timepicker.modalElement,"PM selected"),this.timepicker._options.clockType==="12h"&&this.timepicker._options.disabledTime?.interval&&setTimeout(()=>{let s=this.timepicker.clockFacePool.acquire({clockFace:this.timepicker.clockFace,tipsWrapper:this.timepicker.tipsWrapper,disabledTime:this.timepicker._disabledTime?.value,clockType:this.timepicker._options.clockType,activeTypeMode:"PM"});s.updateDisable(this.timepicker.hour.value,"PM"),this.timepicker.clockFacePool.release(s)},300),_(this.timepicker._element,"","timepicker:select-pm",{hour:this.timepicker.hour.value,minutes:this.timepicker.minutes.value,type:this.timepicker.activeTypeMode?.dataset.type,degreesHours:this.timepicker._degreesHours,degreesMinutes:this.timepicker._degreesMinutes},this.timepicker._options.onSelectPM,this.timepicker)};this.timepicker.PM.addEventListener(e,t),this.cleanupHandlers.push(()=>{this.timepicker.PM?.removeEventListener(e,t)})})}};var X=class{timepicker;cleanupHandlers;constructor(e,t){this.timepicker=e,this.cleanupHandlers=t}handleClasses24h=(e,t,i=!1)=>{let r=e.target,s=e.relatedTarget;this.timepicker.hourTips&&this.timepicker._options.clockType==="24h"&&(Number(r.textContent)>12||Number(r.textContent)===0?this.timepicker.clockManager&&this.timepicker.clockManager.setCircleClockClasses24h():this.timepicker.clockManager&&this.timepicker.clockManager.removeCircleClockClasses24h(),this.timepicker._options.mobile||this.timepicker.tipsWrapperFor24h?.classList.remove("timepicker-ui-tips-wrapper-24h-disabled")),!(!r||!t)&&(t.value=ke(r.value.replace(/\D+/g,"")),i&&s?s.classList.contains("timepicker-ui-am")||s.classList.contains("timepicker-ui-pm")||t.click():i&&t.click())};handleHourEvents=()=>{this.timepicker._inputEvents.forEach(i=>{let r=s=>{let a=s.target;this.timepicker.clockFace!==null&&this.timepicker.animationManager&&this.timepicker.animationManager.handleAnimationSwitchTipsMode(),this.timepicker._options.clockType==="24h"&&this.timepicker.clockFace!==null&&(Number(this.timepicker.hour.value)>12||this.timepicker.hour.value==="00"?this.timepicker.clockManager&&this.timepicker.clockManager.setCircleClockClasses24h():this.timepicker.clockManager&&this.timepicker.clockManager.removeCircleClockClasses24h(),this.timepicker._options.mobile||this.timepicker.tipsWrapperFor24h?.classList.remove("timepicker-ui-tips-wrapper-24h-disabled")),this.timepicker.clockManager&&this.timepicker.clockManager.setHoursToClock(a.value),this.timepicker.minutes.classList.remove(H),this.timepicker.hour.classList.add(H),this.timepicker._options.clockType==="12h"&&this.timepicker._options.disabledTime?.interval&&setTimeout(()=>{let o=this.timepicker.clockFacePool.acquire({clockFace:this.timepicker.clockFace,tipsWrapper:this.timepicker.tipsWrapper,disabledTime:this.timepicker._disabledTime?.value,clockType:this.timepicker._options.clockType,activeTypeMode:this.timepicker.activeTypeMode?.textContent||""});o.updateDisable(this.timepicker.hour.value,this.timepicker.activeTypeMode?.textContent||""),this.timepicker.clockFacePool.release(o)},300),_(this.timepicker._element,"","timepicker:select-hour",{hour:this.timepicker.hour.value,minutes:this.timepicker.minutes.value,type:this.timepicker.activeTypeMode?.dataset.type,degreesHours:this.timepicker._degreesHours,degreesMinutes:this.timepicker._degreesMinutes},this.timepicker._options.onSelectHour,this.timepicker),this.timepicker.clockFace!==null&&this.timepicker.circle.classList.remove("small-circle")};this.timepicker.hour?.addEventListener(i,r),this.cleanupHandlers.push(()=>{this.timepicker.hour?.removeEventListener(i,r)})});let e=i=>this.handleClasses24h(i,this.timepicker.hour,!0),t=i=>this.handleClasses24h(i,this.timepicker.hour,!1);this.timepicker.hour?.addEventListener("blur",e),this.timepicker.hour?.addEventListener("focus",t),this.cleanupHandlers.push(()=>{this.timepicker.hour?.removeEventListener("blur",e),this.timepicker.hour?.removeEventListener("focus",t)})};handleMinutesEvents=()=>{this.timepicker._inputEvents.forEach(i=>{let r=s=>{let a=s.target;this.timepicker.clockFace!==null&&(this.timepicker.animationManager&&this.timepicker.animationManager.handleAnimationSwitchTipsMode(),this.timepicker.clockManager&&this.timepicker.clockManager.setMinutesToClock(a.value)),this.timepicker._options.clockType==="24h"&&(this.timepicker.clockManager&&this.timepicker.clockManager.removeCircleClockClasses24h(),this.timepicker._options.mobile||this.timepicker.tipsWrapperFor24h?.classList.add("timepicker-ui-tips-wrapper-24h-disabled")),this.timepicker.hour.classList.remove(H),this.timepicker.minutes.classList.add(H),this.timepicker._options.clockType==="12h"&&this.timepicker._options.disabledTime?.interval&&setTimeout(()=>{let o=this.timepicker.clockFacePool.acquire({clockFace:this.timepicker.clockFace,tipsWrapper:this.timepicker.tipsWrapper,disabledTime:this.timepicker._disabledTime?.value,clockType:this.timepicker._options.clockType,activeTypeMode:this.timepicker.activeTypeMode?.textContent||""});o.updateDisable(this.timepicker.hour.value,this.timepicker.activeTypeMode?.textContent||""),this.timepicker.clockFacePool.release(o)},300),_(this.timepicker._element,"","timepicker:select-minute",{hour:this.timepicker.hour.value,minutes:this.timepicker.minutes.value,type:this.timepicker.activeTypeMode?.dataset.type,degreesHours:this.timepicker._degreesHours,degreesMinutes:this.timepicker._degreesMinutes},this.timepicker._options.onSelectMinute,this.timepicker)};this.timepicker.minutes.addEventListener(i,r),this.cleanupHandlers.push(()=>{this.timepicker.minutes?.removeEventListener(i,r)})});let e=i=>this.handleClasses24h(i,this.timepicker.minutes,!0),t=i=>this.handleClasses24h(i,this.timepicker.minutes,!1);this.timepicker.minutes?.addEventListener("blur",e),this.timepicker.minutes?.addEventListener("focus",t),this.cleanupHandlers.push(()=>{this.timepicker.minutes?.removeEventListener("blur",e),this.timepicker.minutes?.removeEventListener("focus",t)})}};var G=class{timepicker;constructor(e){this.timepicker=e}updateHandPosition=e=>{let{target:t,type:i}=e,r=t,{incrementMinutes:s,incrementHours:a}=this.timepicker._options;if(!be(e,this.timepicker.clockFace))return;let o=be(e,this.timepicker.clockFace),c=this.timepicker.clockFace.offsetWidth/2,p=o&&Math.atan2(o.y-c,o.x-c);if(this.timepicker.minutesTips!==null){this.timepicker.minutes.classList.add(H);let f=p&&ue(Math.trunc(p*180/Math.PI)+90,s??1,6);if(f===void 0)return;let y;if(f<0?(y=Math.round(360+f/6)%60,f=360+Math.round(f/6)*6):(y=Math.round(f/6)%60,f=Math.round(f/6)*6),this.timepicker?._disabledTime?.value?.isInterval){let k=y<=9?`0${y}`:`${y}`,u=this.timepicker.hour.value,b=this.timepicker.activeTypeMode?.textContent||"";if(!w(u,k,b,this.timepicker._disabledTime.value.intervals,this.timepicker._options.clockType))return}else{let k=this.timepicker._disabledTime?.value?.minutes;if(k&&Array.isArray(k)&&k.includes(y<=9?`0${y}`:`${y}`))return}this.timepicker.minutes.value=y>=10?`${y}`:`0${y}`,this.timepicker.domBatcher.schedule(()=>{this.timepicker.minutes.setAttribute("aria-valuenow",this.timepicker.minutes.value),this.timepicker.clockHand.style.transform=`rotateZ(${f}deg)`}),this.timepicker._degreesMinutes=f,this.timepicker.clockManager&&(this.timepicker.clockManager.toggleClassActiveToValueTips(this.timepicker.minutes.value),this.timepicker.clockManager.removeBgColorToCirleWithMinutesTips(),this.timepicker.clockManager.setBgColorToCircleWithMinutesTips()),S(this.timepicker.modalElement,`Minute ${this.timepicker.minutes.value}`),_(this.timepicker._element,"update","timepicker:update",{...C(this.timepicker.input,this.timepicker._options.clockType),degreesHours:this.timepicker._degreesHours,degreesMinutes:this.timepicker._degreesMinutes,eventType:i,type:this.timepicker.activeTypeMode?.dataset.type},this.timepicker._options.onUpdate,this.timepicker)}let T=e.touches,l=T?T[0]:void 0,h=T&&l?document.elementFromPoint(l.clientX,l.clientY):null;if(this.timepicker.hourTips!==null){this.timepicker.hour?.classList.add(H);let f=this.timepicker._options.clockType==="24h",y=!1;if(f){let k=this.timepicker.clockFace.offsetWidth/2,u=o?Math.sqrt(Math.pow(o.x-k,2)+Math.pow(o.y-k,2)):0,b=k*.6;y=u<b}if(!m(h||r,"timepicker-ui-tips-disabled")&&(!f||!y)&&(m(h||r,"timepicker-ui-value-tips")||m(h||r,"timepicker-ui-tips-wrapper")||m(h||r,"timepicker-ui-value-tips-24h")||m(h||r,"timepicker-ui-tips-wrapper-24h"))){let k=p&&ue(Math.trunc(p*180/Math.PI)+90,a??1,30);if(this.timepicker._degreesHours=k,k===void 0)return;let u;if(k<0?(u=Math.round(360+k/30)%12,k=360+k):(u=Math.round(k/30)%12,(u===0||u>12)&&(u=12)),this.timepicker._disabledTime?.value?.isInterval){let b=u>9?`${u}`:`0${u}`,d=this.timepicker.activeTypeMode?.textContent||"",v=!0;for(let M=0;M<60;M++){let I=M<=9?`0${M}`:`${M}`;if(w(b,I,d,this.timepicker._disabledTime.value.intervals,this.timepicker._options.clockType)){v=!1;break}}if(v)return}else{let b=this.timepicker._disabledTime?.value?.hours;if(b&&Array.isArray(b)&&b.includes(u.toString()))return}this.timepicker.clockHand.style.transform=`rotateZ(${k}deg)`,this.timepicker.hour.value=u>9?`${u}`:`0${u}`,this.timepicker.hour.setAttribute("aria-valuenow",this.timepicker.hour.value),this.timepicker.clockManager&&(this.timepicker.clockManager.removeCircleClockClasses24h(),this.timepicker.clockManager.toggleClassActiveToValueTips(u)),S(this.timepicker.modalElement,`Hour ${this.timepicker.hour.value}`)}if(f&&!m(h||r,"timepicker-ui-tips-disabled")&&y&&(m(h||r,"timepicker-ui-value-tips-24h")||m(h||r,"timepicker-ui-tips-wrapper-24h")||m(h||r,"timepicker-ui-value-tips")||m(h||r,"timepicker-ui-tips-wrapper"))){let k=p&&ue(Math.trunc(p*180/Math.PI)+90,a??1,30);this.timepicker._degreesHours=k;let u;if(k===void 0)return;if(k<0?(u=Math.round(360+k/30)%24,k=360+k):(u=Math.round(k/30)+12,u===12&&(u="00")),this.timepicker._disabledTime?.value?.isInterval){let b=typeof u=="number"?u<=9?`0${u}`:`${u}`:u,d=!0;for(let v=0;v<60;v++){let M=v<=9?`0${v}`:`${v}`;if(w(b,M,"",this.timepicker._disabledTime.value.intervals,this.timepicker._options.clockType)){d=!1;break}}if(d)return}else{let b=this.timepicker._disabledTime?.value?.hours;if(b&&Array.isArray(b)&&b.includes(u.toString()))return}this.timepicker.clockManager&&this.timepicker.clockManager.setCircleClockClasses24h(),this.timepicker.clockHand.style.transform=`rotateZ(${k}deg)`,this.timepicker.hour.value=`${u}`,this.timepicker.hour.setAttribute("aria-valuenow",this.timepicker.hour.value),this.timepicker.clockManager&&this.timepicker.clockManager.toggleClassActiveToValueTips(u),S(this.timepicker.modalElement,`Hour ${this.timepicker.hour.value}`)}_(this.timepicker._element,"","timepicker:update",{...C(this.timepicker.input,this.timepicker._options.clockType),degreesHours:this.timepicker._degreesHours,degreesMinutes:this.timepicker._degreesMinutes,eventType:i,type:this.timepicker.activeTypeMode?.dataset.type},this.timepicker._options.onUpdate,this.timepicker)}}};var Q=class{timepicker;cleanupHandlers;constructor(e,t){this.timepicker=e,this.cleanupHandlers=t}handleOpenOnClick=()=>{this.timepicker.openElement.forEach(e=>{let t=()=>this.timepicker._eventsBundle();e?.addEventListener("click",t),this.cleanupHandlers.push(()=>{e?.removeEventListener("click",t)})})};handleOpenOnEnterFocus=()=>{let e=({target:t,key:i})=>{t.disabled||i==="Enter"&&this.timepicker.open()};this.timepicker.input.addEventListener("keydown",e),this.cleanupHandlers.push(()=>{this.timepicker.input.removeEventListener("keydown",e)})};handleClickOnHourMobile=()=>{document.addEventListener("mousedown",this.timepicker._eventsClickMobileHandler),document.addEventListener("touchstart",this.timepicker._eventsClickMobileHandler),this.cleanupHandlers.push(()=>{document.removeEventListener("mousedown",this.timepicker._eventsClickMobileHandler),document.removeEventListener("touchstart",this.timepicker._eventsClickMobileHandler)})};handlerClickHourMinutes=async e=>{if(!this.timepicker.modalElement)return;let{clockType:t,editable:i}=this.timepicker._options,r=e.target,s=D(this.timepicker.hour.value,"hour",t),a=D(this.timepicker.minutes.value,"minutes",t);i&&(!m(r,"timepicker-ui-hour")&&!m(r,"timepicker-ui-minutes")?s===!0&&a===!0&&(a&&this.timepicker.minutes.classList.remove("invalid-value"),s&&this.timepicker.hour?.classList.remove("invalid-value")):(s===!1||a===!1)&&(a||this.timepicker.minutes.classList.add("invalid-value"),s||this.timepicker.hour?.classList.add("invalid-value")))};handleIconChangeView=async()=>{if(this.timepicker._options.enableSwitchIcon&&this.timepicker.configManager){let e=this.timepicker.configManager.handlerViewChange();we()?(this.timepicker.keyboardClockIcon.addEventListener("touchstart",e),this.cleanupHandlers.push(()=>{this.timepicker.keyboardClockIcon?.removeEventListener("touchstart",e)})):(this.timepicker.keyboardClockIcon.addEventListener("click",e),this.cleanupHandlers.push(()=>{this.timepicker.keyboardClockIcon?.removeEventListener("click",e)}))}};handleKeyPress=e=>{if(e.key==="Escape"&&this.timepicker.modalElement){let t=C(this.timepicker.input,this.timepicker._options.clockType);_(this.timepicker._element,"","timepicker:cancel",{...t,hourNotAccepted:this.timepicker.hour.value,minutesNotAccepted:this.timepicker.minutes.value,type:this.timepicker.activeTypeMode?.dataset.type,degreesHours:this.timepicker._degreesHours,degreesMinutes:this.timepicker._degreesMinutes},this.timepicker._options.onCancel,this.timepicker),this.timepicker.close()()}};handleEscClick=()=>{document.addEventListener("keydown",this.handleKeyPress),this.cleanupHandlers.push(()=>{document.removeEventListener("keydown",this.handleKeyPress)})};focusTrapHandler=()=>{setTimeout(()=>{let e=this.timepicker.wrapper?.querySelectorAll('div[tabindex="0"]:not([disabled])'),t=this.timepicker.wrapper?.querySelectorAll('input[tabindex="0"]:not([disabled])');if(!e||e.length<=0||t.length<=0)return;let i=[...t,...e],r=i[0],s=i[i.length-1];this.timepicker.wrapper.focus();let a=o=>{let{key:c,shiftKey:p,target:T}=o,l=T;if(c==="Tab"&&(p?document.activeElement===r&&(s.focus(),o.preventDefault()):document.activeElement===s&&(r.focus(),o.preventDefault())),c==="ArrowUp"||c==="ArrowDown"||c==="ArrowLeft"||c==="ArrowRight"){let h=m(l,"timepicker-ui-value-tips")||m(l,"timepicker-ui-value-tips-24h"),f=m(l,"timepicker-ui-hour"),y=m(l,"timepicker-ui-minutes");if(h){let k=l.parentElement,u=m(k,"timepicker-ui-minutes-time"),b=m(k,"timepicker-ui-hour-time-12")||m(k,"timepicker-ui-hour-time-24");if(u){let d=parseInt(this.timepicker.minutes.value||"0"),v=d;c==="ArrowUp"||c==="ArrowRight"?v=d>=59?0:d+1:(c==="ArrowDown"||c==="ArrowLeft")&&(v=d<=0?59:d-1);let M=v<10?`0${v}`:`${v}`,I=this.timepicker.hour.value,g=this.timepicker.activeTypeMode?.textContent||"";if(this.timepicker._disabledTime?.value?.isInterval&&this.timepicker._disabledTime?.value?.intervals&&!w(I,M,g,this.timepicker._disabledTime.value.intervals,this.timepicker._options.clockType))return;this.timepicker.minutes.value=M,this.timepicker.minutes.setAttribute("aria-valuenow",this.timepicker.minutes.value),this.timepicker.clockManager&&(this.timepicker.clockManager.setTransformToCircleWithSwitchesMinutes(this.timepicker.minutes.value),this.timepicker.clockManager.toggleClassActiveToValueTips(v))}else if(b){let d=parseInt(this.timepicker.hour.value||"0"),v=this.timepicker._options.clockType==="24h",M=v?23:12,I=v?0:1,g=d;c==="ArrowUp"||c==="ArrowRight"?g=d>=M?I:d+1:(c==="ArrowDown"||c==="ArrowLeft")&&(g=d<=I?M:d-1);let E=g<10?`0${g}`:`${g}`,A=this.timepicker.activeTypeMode?.textContent||"";if(this.timepicker._disabledTime?.value?.isInterval&&this.timepicker._disabledTime?.value?.intervals){let L=!0;for(let x=0;x<60;x++){let Ue=x.toString().padStart(2,"0");if(w(E,Ue,A,this.timepicker._disabledTime.value.intervals,this.timepicker._options.clockType)){L=!1;break}}if(L)return}this.timepicker.hour.value=E,this.timepicker.hour.setAttribute("aria-valuenow",this.timepicker.hour.value),this.timepicker.clockManager&&(this.timepicker.clockManager.setTransformToCircleWithSwitchesHour(this.timepicker.hour.value),this.timepicker.clockManager.toggleClassActiveToValueTips(g))}}if(f||y){let k=parseInt(l.value)||0,u=f,b=u?this.timepicker._options.clockType==="12h"?12:23:59,d=u&&this.timepicker._options.clockType==="12h"?1:0,v=k;c==="ArrowUp"?v=k>=b?d:k+1:c==="ArrowDown"&&(v=k<=d?b:k-1),l.value=v<10?`0${v}`:`${v}`,l.setAttribute("aria-valuenow",l.value)}}(c==="a"||c==="A")&&this.timepicker.AM&&!m(l,"timepicker-ui-hour")&&!m(l,"timepicker-ui-minutes")&&this.timepicker.AM.click(),(c==="p"||c==="P")&&this.timepicker.PM&&!m(l,"timepicker-ui-hour")&&!m(l,"timepicker-ui-minutes")&&this.timepicker.PM.click(),c==="Enter"&&(m(l,"timepicker-ui-minutes")&&this.timepicker.minutes.click(),m(l,"timepicker-ui-hour")&&this.timepicker.hour.click(),m(l,"timepicker-ui-am")&&this.timepicker.AM.click(),m(l,"timepicker-ui-pm")&&this.timepicker.PM.click(),m(l,"timepicker-ui-ok-btn")&&this.timepicker.okButton.click(),m(l,"timepicker-ui-cancel-btn")&&this.timepicker.cancelButton.click(),m(l,"timepicker-ui-keyboard-icon-wrapper")&&this.timepicker.keyboardClockIcon.click())};this.timepicker.wrapper.addEventListener("keydown",a),this.cleanupHandlers.push(()=>{this.timepicker.wrapper?.removeEventListener("keydown",a)})},100)}};var ee=class{timepicker;cleanupHandlers;constructor(e,t){this.timepicker=e,this.cleanupHandlers=t}handleInlineAutoUpdate=()=>{if(!this.timepicker._options.inline?.enabled||this.timepicker._options.inline.autoUpdate===!1)return;let e=()=>{let r=this.timepicker.hour?.value,s=this.timepicker.minutes?.value,a=this.timepicker.activeTypeMode?.textContent;if(r&&s){let o="";if(this.timepicker._options.clockType==="24h"){let c=r.padStart(2,"0"),p=s.padStart(2,"0");o=`${c}:${p}`}else{let c=r,p=s.padStart(2,"0");o=`${c}:${p} ${a||"AM"}`}if(this.timepicker.input){this.timepicker.input.value=o;let c=new Event("change",{bubbles:!0});this.timepicker.input.dispatchEvent(c),_(this.timepicker._element,"","timepicker:confirm",{hour:r,minutes:s,type:a,degreesHours:this.timepicker._degreesHours,degreesMinutes:this.timepicker._degreesMinutes},this.timepicker._options.onConfirm,this.timepicker)}}};["input","change"].forEach(r=>{let s=()=>setTimeout(e,50),a=()=>setTimeout(e,50);this.timepicker.hour?.addEventListener(r,s),this.timepicker.minutes?.addEventListener(r,a),this.cleanupHandlers.push(()=>{this.timepicker.hour?.removeEventListener(r,s),this.timepicker.minutes?.removeEventListener(r,a)})}),this.timepicker._options.clockType!=="24h"&&this.timepicker._clickTouchEvents.forEach(r=>{let s=()=>setTimeout(e,50),a=()=>setTimeout(e,50);this.timepicker.AM?.addEventListener(r,s),this.timepicker.PM?.addEventListener(r,a),this.cleanupHandlers.push(()=>{this.timepicker.AM?.removeEventListener(r,s),this.timepicker.PM?.removeEventListener(r,a)})});let i=()=>setTimeout(e,100);this.timepicker.clockFace?.addEventListener("click",i),this.cleanupHandlers.push(()=>{this.timepicker.clockFace?.removeEventListener("click",i)})}};var te=class{_cleanupHandlers=[];buttonHandlers;dragHandlers;typeModeHandlers;inputHandlers;clockHandPositionUpdater;miscHandlers;inlineHandlers;constructor(e){this.clockHandPositionUpdater=new G(e),this.dragHandlers=new Y(e,this.clockHandPositionUpdater.updateHandPosition),this.buttonHandlers=new j(e,this._cleanupHandlers),this.typeModeHandlers=new J(e,this._cleanupHandlers),this.inputHandlers=new X(e,this._cleanupHandlers),this.miscHandlers=new Q(e,this._cleanupHandlers),this.inlineHandlers=new ee(e,this._cleanupHandlers)}destroy(){this._cleanupHandlers.forEach(e=>{try{e()}catch(t){console.error("EventManager cleanup error:",t)}}),this._cleanupHandlers=[],this.dragHandlers.cleanup()}handleOpenOnClick=()=>this.miscHandlers.handleOpenOnClick();handleOpenOnEnterFocus=()=>this.miscHandlers.handleOpenOnEnterFocus();handleCancelButton=()=>this.buttonHandlers.handleCancelButton();handleOkButton=()=>this.buttonHandlers.handleOkButton();handleBackdropClick=()=>this.buttonHandlers.handleBackdropClick();handleAmClick=()=>this.typeModeHandlers.handleAmClick();handlePmClick=()=>this.typeModeHandlers.handlePmClick();handleHourEvents=()=>this.inputHandlers.handleHourEvents();handleMinutesEvents=()=>this.inputHandlers.handleMinutesEvents();handleEventToMoveHand=e=>this.dragHandlers.handleEventToMoveHand(e);handleMoveHand=()=>this.dragHandlers.handleMoveHand();handleClickOnHourMobile=()=>this.miscHandlers.handleClickOnHourMobile();handlerClickHourMinutes=e=>this.miscHandlers.handlerClickHourMinutes(e);handleIconChangeView=()=>this.miscHandlers.handleIconChangeView();handleEscClick=()=>this.miscHandlers.handleEscClick();focusTrapHandler=()=>this.miscHandlers.focusTrapHandler();handleInlineAutoUpdate=()=>this.inlineHandlers.handleInlineAutoUpdate();get _isDragging(){return this.dragHandlers.isDragging}get _animationFrameId(){return this.dragHandlers.animationFrameId}_onDragStart=e=>this.dragHandlers._onDragStart(e);_onDragMove=e=>this.dragHandlers._onDragMove(e);_onDragEnd=e=>this.dragHandlers._onDragEnd(e)};var ie=class{timepicker;timeouts=[];originalOverflow;originalPaddingRight;constructor(e){this.timepicker=e}runWithTimeout(e,t=300){let i=setTimeout(e,t);this.timeouts.push(i)}clearAllTimeouts(){this.timeouts.forEach(clearTimeout),this.timeouts=[]}clearExistingModal(){let e=document.querySelector(".timepicker-ui-modal");e&&e.remove()}setModalTemplate=()=>{if(!this.timepicker._options)return;if(this.clearExistingModal(),this.timepicker._options.inline?.enabled){let t=document.getElementById(this.timepicker._options.inline.containerId);if(!t)return;t.innerHTML="",t.insertAdjacentHTML("beforeend",this.timepicker.modalTemplate);let i=t.querySelector(".timepicker-ui-modal");if(i){i.classList.add("timepicker-ui--inline");let{showButtons:r}=this.timepicker._options.inline;(r===!1||r===void 0)&&i.querySelectorAll(".timepicker-ui-wrapper-btn, .timepicker-ui-wrapper-btn.mobile").forEach(s=>s.style.display="none")}return}let{appendModalSelector:e}=this.timepicker._options;e?document.querySelector(e)?.insertAdjacentHTML("beforeend",this.timepicker.modalTemplate):document.body.insertAdjacentHTML("beforeend",this.timepicker.modalTemplate)};setScrollbarOrNot=()=>{this.timepicker._options.inline?.enabled||(this.timepicker._options.enableScrollbar?this.runWithTimeout(()=>{document.body.style.overflowY=this.originalOverflow||"",document.body.style.paddingRight=this.originalPaddingRight||""},400):(this.originalOverflow=document.body.style.overflowY,this.originalPaddingRight=document.body.style.paddingRight,document.body.style.paddingRight=`${Ce()}px`,document.body.style.overflowY="hidden"))};removeBackdrop=()=>{this.timepicker._options.inline?.enabled||this.timepicker._options.backdrop||(this.timepicker.modalElement?.classList.add("removed"),this.timepicker.openElement.forEach(e=>e?.classList.add("disabled")))};setNormalizeClass=()=>{let e=this.timepicker.modalElement;if(!e)return;e.classList.add("timepicker-ui-normalize"),e.querySelectorAll(":scope > div").forEach(i=>i.classList.add("timepicker-ui-normalize"))};setShowClassToBackdrop=()=>{if(this.timepicker._options.inline?.enabled){this.timepicker.modalElement?.classList.add("show");return}this.timepicker._options.backdrop&&this.runWithTimeout(()=>{this.timepicker.modalElement?.classList.add("show")},300)};setFlexEndToFooterIfNoKeyboardIcon=()=>{!this.timepicker._options.enableSwitchIcon&&this.timepicker.footer&&(this.timepicker.footer.style.justifyContent="flex-end")};destroy(){this.clearAllTimeouts(),this.timepicker._options.inline?.enabled||(document.body.style.overflowY=this.originalOverflow||"",document.body.style.paddingRight=this.originalPaddingRight||""),this.clearExistingModal()}};var Ee={MODAL:150,CLOCK:600,TIPS:401},re=class{timepicker;timeouts=[];constructor(e){this.timepicker=e}runWithAnimation(e,t=Ee.MODAL){if(this.timepicker._options.animation){let i=setTimeout(e,t);this.timeouts.push(i)}else e()}clearAllTimeouts(){this.timeouts.forEach(clearTimeout),this.timeouts=[]}setAnimationToOpen(){this.clearAllTimeouts(),this.timepicker.modalElement?.classList.add("opacity"),this.runWithAnimation(()=>{this.timepicker.modalElement?.classList.add("show")})}removeAnimationToClose(){this.clearAllTimeouts(),this.timepicker.modalElement&&this.runWithAnimation(()=>{this.timepicker.modalElement?.classList.remove("show"),this.timepicker.modalElement?.classList.remove("opacity")})}handleAnimationClock(){this.timepicker._options.animation&&this.runWithAnimation(()=>{this.timepicker.clockFace?.classList.add("timepicker-ui-clock-animation");let e=setTimeout(()=>{this.timepicker.clockFace?.classList.remove("timepicker-ui-clock-animation")},Ee.CLOCK);this.timeouts.push(e)})}handleAnimationSwitchTipsMode(){let{clockHand:e}=this.timepicker;if(!e)return;e.classList.add("timepicker-ui-tips-animation");let t=setTimeout(()=>{e.classList.remove("timepicker-ui-tips-animation")},Ee.TIPS);this.timeouts.push(t)}destroy(){this.clearAllTimeouts()}};fe();var se=class{timepicker;constructor(e){this.timepicker=e}removeCircleClockClasses24h(){this.timepicker.circle?.classList.remove("timepicker-ui-circle-hand-24h"),this.timepicker.clockHand?.classList.remove("timepicker-ui-clock-hand-24h")}setCircleClockClasses24h(){this.timepicker.circle&&this.timepicker.circle?.classList.add("timepicker-ui-circle-hand-24h"),this.timepicker.clockHand&&this.timepicker.clockHand?.classList.add("timepicker-ui-clock-hand-24h")}setOnStartCSSClassesIfClockType24h(){if(this.timepicker._options.clockType==="24h"){let t=this.timepicker?.configManager?.getInputValue(this.timepicker.input,this.timepicker._options.clockType,this.timepicker._options.currentTime)?.hour;this.timepicker.input.value.length>0&&(t=this.timepicker.input.value.split(":")[0]),(Number(t)>12||Number(t)===0)&&this.setCircleClockClasses24h()}}setBgColorToCircleWithMinutesTips=()=>{if(this.timepicker.minutes.value&&R.includes(this.timepicker.minutes.value)){let e=getComputedStyle(this.timepicker.circle).getPropertyValue("--timepicker-primary").trim();e&&(this.timepicker.circle.style.backgroundColor=e),this.timepicker.circle.classList.remove("small-circle")}};removeBgColorToCirleWithMinutesTips=()=>{this.timepicker.minutes.value&&R.includes(this.timepicker.minutes.value)||(this.timepicker.circle.style.backgroundColor="",this.timepicker.circle.classList.add("small-circle"))};setClassActiveToHourOnOpen=()=>{this.timepicker._options.mobile||this.timepicker._isMobileView||this.timepicker.hour?.classList.add(H)};setMinutesToClock=e=>{this.timepicker.clockFace!==null&&this.setTransformToCircleWithSwitchesMinutes(e),this.removeBgColorToCirleWithMinutesTips();let t=this.timepicker._disabledTime?.value||null,i=this.timepicker.clockFacePool.acquire({array:R,classToAdd:"timepicker-ui-minutes-time",clockFace:this.timepicker.clockFace,tipsWrapper:this.timepicker.tipsWrapper,theme:this.timepicker._options.theme,disabledTime:t,hour:this.timepicker.hour.value,clockType:this.timepicker._options.clockType});i.create(),this.timepicker._options.clockType==="12h"&&i.updateDisable(),this.timepicker.clockFacePool.release(i),this.toggleClassActiveToValueTips(e),this.timepicker._options.clockType==="24h"&&(this.timepicker.tipsWrapperFor24h.innerHTML="")};setHoursToClock=e=>{if(this.timepicker.clockFace!==null){this.setTransformToCircleWithSwitchesHour(e);let t=this.timepicker._disabledTime?.value||null,i=this.timepicker.clockFacePool.acquire({array:B,classToAdd:"timepicker-ui-hour-time-12",clockFace:this.timepicker.clockFace,tipsWrapper:this.timepicker.tipsWrapper,theme:this.timepicker._options.theme,disabledTime:t,clockType:"12h",hour:this.timepicker.hour.value});if(i.create(),this.timepicker._options.clockType==="24h"){let r=this.timepicker.clockFacePool.acquire({array:q,classToAdd:"timepicker-ui-hour-time-24",clockFace:this.timepicker.tipsWrapperFor24h,tipsWrapper:this.timepicker.tipsWrapperFor24h,theme:this.timepicker._options.theme,clockType:"24h",disabledTime:t,hour:this.timepicker.hour.value});r.create(),this.timepicker.clockFacePool.release(r)}else i.updateDisable();this.timepicker.clockFacePool.release(i),this.toggleClassActiveToValueTips(e)}};setTransformToCircleWithSwitchesHour=e=>{if(!this.timepicker.clockHand)return;let t=Number(e),i=t>12?t*30-360:t*30;i===360&&(i=0),!(i>360)&&(this.timepicker.clockHand.style.transform=`rotateZ(${i}deg)`)};setTransformToCircleWithSwitchesMinutes=e=>{if(!this.timepicker.clockHand)return;let t=Number(e)*6;t>360||(this.timepicker.clockHand.style.transform=`rotateZ(${t}deg)`)};toggleClassActiveToValueTips=e=>{let t=this.timepicker.allValueTips.find(i=>Number(i.innerText)===Number(e));this.timepicker.allValueTips.map(i=>{i.classList.remove(H),i.setAttribute("aria-selected","false")}),t!==void 0&&(t.classList.add(H),t.setAttribute("aria-selected","true"))}};var ne=class{timepicker;constructor(e){this.timepicker=e}setErrorHandler(){let e=this.timepicker.input;if(!e)return;let{error:t,currentHour:i,currentMin:r,currentType:s,currentLength:a}=C(e,this.timepicker._options.clockType);if(this.removeErrorHandler(),t){let o=document.createElement("div");return o.classList.add("timepicker-ui-invalid-text"),o.innerHTML="<b>Invalid Time Format</b>",e.classList.add("timepicker-ui-invalid-format"),e.nextElementSibling?.classList.contains("timepicker-ui-invalid-text")||e.after(o),_(this.timepicker._element,"","timepicker:error",{error:t,currentHour:i,currentMin:r,currentType:s,currentLength:a},this.timepicker._options.onError,this.timepicker),console.error(`Invalid Time Format: ${t}`),!1}return!0}removeErrorHandler(){let e=this.timepicker.input;if(!e)return;e.classList.remove("timepicker-ui-invalid-format");let t=e.nextElementSibling;t?.classList.contains("timepicker-ui-invalid-text")&&t.remove()}checkDisabledValuesOnStart(){if(!this.timepicker._options.disabledTime)return;let{disabledTime:e,clockType:t}=this.timepicker._options;if(e.interval){if(!t)throw new Error("clockType is required when using disabledTime.interval");let o=Array.isArray(e.interval)?e.interval:[e.interval];try{he(o,t)}catch(c){throw new Error(`Invalid disabledTime.interval: ${c.message}`)}return}let{hours:i,minutes:r}=e,s=i?N(i,"hour",t):!0,a=r?N(r,"minutes",t):!0;if(!s||!a)throw new Error("You set wrong hours or minutes in disabled option")}destroy(){this.removeErrorHandler()}};var oe={"crane-straight":["crane-straight"],"crane-radius":["crane-straight","radius"],m3:["m3"],dark:["dark"],glassmorphic:["glassmorphic"],pastel:["pastel"],ai:["ai"],cyberpunk:["cyberpunk"],custom:["custom"]};var ae=class{timepicker;constructor(e){this.timepicker=e}setTheme=()=>{let e=this.timepicker.modalElement;if(!e||!this.timepicker._options)return;let{theme:t}=this.timepicker._options;if(!t||!oe[t])return;e.querySelectorAll("input, div").forEach(r=>{Object.values(oe).forEach(s=>r.classList.remove(...s)),r.classList.add(...oe[t])})};setInputClassToInputElement=()=>{let e=this.timepicker.input;e&&(m(e,"timepicker-ui-input")||e.classList.add("timepicker-ui-input"))};setDataOpenToInputIfDoesntExistInWrapper=()=>{this.timepicker.openElementData===null&&this.timepicker.input&&this.timepicker.input.setAttribute("data-open","timepicker-ui-input")};setClassTopOpenElement=()=>{for(let e of this.timepicker.openElement)e&&e.classList.add("timepicker-ui-open-element")};setTimepickerClassToElement=()=>{let e=this.timepicker._element;if(!e)return;e.classList.add(ye);let t=this.timepicker._options?.cssClass;t&&t!==ye&&e.classList.add(t)};destroy(){let e=this.timepicker.modalElement;if(!e)return;e.querySelectorAll("input, div").forEach(i=>{Object.values(oe).forEach(r=>i.classList.remove(...r))})}};var ce=class{timepicker;timeouts=[];debouncedHandler;constructor(e){this.timepicker=e}clearAllTimeouts(){this.timeouts.forEach(clearTimeout),this.timeouts=[]}runWithTimeout(e,t){let i=setTimeout(e,t);this.timeouts.push(i)}isCurrentTimeEnabled(e){let t=this.timepicker._options?.currentTime;return typeof t=="boolean"?t:!!t?.[e]}preventClockTypeByCurrentTime=()=>{if(!this.isCurrentTimeEnabled("preventClockType"))return;let{currentTime:e,clockType:t}=this.timepicker._options,{type:i}=C(this.timepicker.input,t,e,!0);this.timepicker._options.clockType=i?"12h":"24h"};updateInputValueWithCurrentTimeOnStart=()=>{if(!this.isCurrentTimeEnabled("updateInput"))return;let{hour:e,minutes:t,type:i}=C(this.timepicker.input,this.timepicker._options.clockType,this.timepicker._options.currentTime);this.timepicker.input.value=i?`${e}:${t} ${i}`:`${e}:${t}`};checkMobileOption(){this.timepicker._isMobileView=!!this.timepicker._options.mobile,this.timepicker._options.mobile&&(this.timepicker._options.editable=!0)}getDisableTime(){let e=$e(this.timepicker._options);this.timepicker._disabledTime=e||null}getInputValueOnOpenAndSet=()=>{let e=C(this.timepicker.input,this.timepicker._options.clockType,this.timepicker._options.currentTime);if(e===void 0){this.timepicker.hour.value="12",this.timepicker.minutes.value="00",_(this.timepicker._element,"show","timepicker:open",{hour:this.timepicker.hour.value,minutes:this.timepicker.minutes.value,type:this.timepicker.activeTypeMode?.dataset.type,degreesHours:this.timepicker._degreesHours,degreesMinutes:this.timepicker._degreesMinutes},this.timepicker._options.onOpen),this.timepicker._options.clockType!=="24h"&&this.timepicker.AM.classList.add(H);return}let[t,i,r]=this.timepicker.input.value.split(":").join(" ").split(" ");this.timepicker.input.value.length===0&&(t=e.hour,i=e.minutes,r=e.type),this.timepicker.hour.value=t,this.timepicker.minutes.value=i;let s=this.timepicker.modalElement?.querySelector(`[data-type='${r}']`);this.timepicker._options.clockType!=="24h"&&s&&s.classList.add(H),_(this.timepicker._element,"show","timepicker:open",{...e,type:this.timepicker.activeTypeMode?.dataset.type,degreesHours:this.timepicker._degreesHours,degreesMinutes:this.timepicker._degreesMinutes},this.timepicker._options.onOpen)};handleModeSwitch(e){this.clearAllTimeouts();let t=this.timepicker.hour.value,i=this.timepicker.minutes.value,r=this.timepicker.activeTypeMode?.dataset.type;this.timepicker.close()(),this.timepicker._isMobileView=e,this.timepicker._options.mobile=e,this.runWithTimeout(()=>{this.timepicker.update({options:{mobile:e}}),this.runWithTimeout(()=>{if(this.timepicker.open(),this.timepicker.hour.value=t,this.timepicker.minutes.value=i,this.timepicker._options.clockType==="12h"){let s=r==="PM"?"PM":"AM",a=r==="PM"?"AM":"PM";this.timepicker[s].classList.add(H),this.timepicker[a].classList.remove(H)}this.timepicker.clockManager&&(this.timepicker.clockManager.setTransformToCircleWithSwitchesHour(this.timepicker.hour.value),this.timepicker.clockManager.toggleClassActiveToValueTips(this.timepicker.hour.value),Number(this.timepicker.hour.value)>12||Number(this.timepicker.hour.value)===0?this.timepicker.clockManager.setCircleClockClasses24h():this.timepicker.clockManager.removeCircleClockClasses24h())},300)},300)}handlerViewChange=()=>{let e=this.timepicker._options.delayHandler||300;return this.debouncedHandler=ve(()=>{let{clockType:t}=this.timepicker._options;if(!this.timepicker.modalElement?.classList.contains("mobile"))this.handleModeSwitch(!0);else{let i=D(this.timepicker.hour.value,"hour",t),r=D(this.timepicker.minutes.value,"minutes",t);if(!i||!r){r||this.timepicker.minutes.classList.add("invalid-value"),i||this.timepicker.hour.classList.add("invalid-value");return}this.timepicker.minutes.classList.remove("invalid-value"),this.timepicker.hour.classList.remove("invalid-value"),this.handleModeSwitch(!1)}},e),this.debouncedHandler};getInputValue=C;destroy(){this.clearAllTimeouts(),this.debouncedHandler&&"cancel"in this.debouncedHandler&&this.debouncedHandler.cancel?.()}};var W=class{events=new Map;on(e,t){this.events.has(e)||this.events.set(e,new Set),this.events.get(e).add(t)}once(e,t){let i=r=>{t(r),this.off(e,i)};this.on(e,i)}off(e,t){t?this.events.get(e)?.delete(t):this.events.delete(e)}emit(e,t){this.events.get(e)?.forEach(i=>{try{i(t)}catch(r){console.error(`EventEmitter: Error in handler for "${String(e)}":`,r)}})}clear(){this.events.clear()}hasListeners(e){return(this.events.get(e)?.size??0)>0}};var ge=class{updates=[];rafId=null;schedule(e){this.updates.push(e),this.rafId||(this.rafId=requestAnimationFrame(()=>this.flush()))}flush(){this.updates.forEach(e=>e()),this.updates=[],this.rafId=null}destroy(){this.rafId&&(cancelAnimationFrame(this.rafId),this.rafId=null),this.updates=[]}};var le=class{_degreesHours=null;_degreesMinutes=null;_options;_eventsClickMobile=()=>Promise.resolve();_eventsClickMobileHandler=()=>{};_mutliEventsMove=()=>{};_mutliEventsMoveHandler;_clickTouchEvents;_element;_instanceId;_isMobileView;_isTouchMouseMove;_disabledTime;_cloned;_inputEvents;_isModalRemove;_isInitialized=!1;_customId;_eventHandlersRegistered=!1;_isDestroyed=!1;_pendingThemeConfig;clockFacePool;eventManager;modalManager;animationManager;clockManager;validationManager;themeManager;configManager;domBatcher;_eventEmitter;constructor(e,t){if(typeof window>"u")throw new Error("TimepickerUI: Cannot initialize in non-browser environment (SSR/Node.js)");this._eventEmitter=new W,this.domBatcher=new ge;let i=t?.id;this._customId=i,this._instanceId=i||`timepicker-ui-${xe()}`;let r=null;if(typeof e=="string"){if(r=document.querySelector(e),!r){console.error(`TimepickerUI: Element with selector "${e}" not found`),this._isDestroyed=!0;return}}else if(e instanceof HTMLElement)r=e;else{console.error("TimepickerUI: First parameter must be a string selector or HTMLElement"),this._isDestroyed=!0;return}let s=null;if(r.tagName==="INPUT"?s=r:s=r.querySelector("input"),!s){let o=typeof e=="string"?`selector "${e}"`:"provided element";throw new Error(`TimepickerUI: No input element found for ${o}`)}if(r.tagName==="INPUT"){let o=document.createElement("div");o.className="timepicker-ui",r.parentNode?.insertBefore(o,r),o.appendChild(r),this._element=o}else this._element=r,this._element.classList.contains("timepicker-ui")||this._element.classList.add("timepicker-ui");this._cloned=null;let a=Ae(this._element?.dataset);if(this._options={...Ie({...Me,...t,...a},Me)},this._options.inline?.enabled&&typeof t?.focusTrap>"u"&&(this._options.focusTrap=!1),this._isTouchMouseMove=!1,this._degreesHours=Number(C(this._element?.querySelector("input"),this._options.clockType).hour)*30,this._degreesMinutes=Number(C(this._element?.querySelector("input"),this._options.clockType).minutes)*6,this._isMobileView=!1,this._mutliEventsMove=o=>this.eventManager.handleEventToMoveHand(o),this._mutliEventsMoveHandler=this._mutliEventsMove.bind(this),this._eventsClickMobile=o=>this.eventManager.handlerClickHourMinutes(o),this._eventsClickMobileHandler=this._eventsClickMobile.bind(this),this.clockFacePool=new z,this.eventManager=new te(this),this.modalManager=new ie(this),this.animationManager=new re(this),this.clockManager=new se(this),this.validationManager=new ne(this),this.themeManager=new ae(this),this.configManager=new ce(this),this.configManager.checkMobileOption(),this._clickTouchEvents=["click","mousedown","touchstart"],this._inputEvents=["change",...this._clickTouchEvents],this._disabledTime=null,this.configManager.preventClockTypeByCurrentTime(),this._isModalRemove=!0,this._isInitialized=!1,this._options.inline?.enabled){if(!this._options.inline.containerId)throw console.error("TimepickerUI: containerId is required when inline mode is enabled"),new Error("TimepickerUI: containerId is required when inline mode is enabled");if(!document.getElementById(this._options.inline.containerId))throw console.error(`TimepickerUI: Container element with ID "${this._options.inline.containerId}" not found`),new Error(`TimepickerUI: Container element with ID "${this._options.inline.containerId}" not found`)}}get modalTemplate(){let{getMobileModalTemplate:e,getModalTemplate:t}=(fe(),He(Se));return!this._options.mobile||!this._isMobileView?t(this._options,this._instanceId):e(this._options,this._instanceId)}get modalElement(){return document.querySelector(`[data-owner-id="${this._instanceId}"]`)}get clockFace(){return this.modalElement?.querySelector(".timepicker-ui-clock-face")}get input(){return this._element?.querySelector("input")}get clockHand(){return this.modalElement?.querySelector(".timepicker-ui-clock-hand")}get circle(){return this.modalElement?.querySelector(".timepicker-ui-circle-hand")}get tipsWrapper(){return this.modalElement?.querySelector(".timepicker-ui-tips-wrapper")}get tipsWrapperFor24h(){return this.modalElement?.querySelector(".timepicker-ui-tips-wrapper-24h")}get minutes(){return this.modalElement?.querySelector(".timepicker-ui-minutes")}get hour(){return this.modalElement?.querySelector(".timepicker-ui-hour")}get AM(){return this.modalElement?.querySelector(".timepicker-ui-am")}get PM(){return this.modalElement?.querySelector(".timepicker-ui-pm")}get minutesTips(){return this.modalElement?.querySelector(".timepicker-ui-minutes-time")}get hourTips(){return this.modalElement?.querySelector(".timepicker-ui-hour-time-12")}get allValueTips(){let e=this.modalElement;return e?[...e.querySelectorAll(".timepicker-ui-value-tips"),...e.querySelectorAll(".timepicker-ui-value-tips-24h")]:[]}get openElementData(){let e=this._element?.querySelectorAll("[data-open]");if(e?.length>0){let t=[];return e.forEach(({dataset:i})=>t.push(i.open??"")),[...new Set(t)]}return null}get openElement(){return this.openElementData===null?(this.input?.setAttribute("data-open","timepicker-ui-input"),[this.input]):this.openElementData.map(e=>this._element?.querySelectorAll(`[data-open='${e}']`))[0]??""}get cancelButton(){return this.modalElement?.querySelector(".timepicker-ui-cancel-btn")}get okButton(){return this.modalElement?.querySelector(".timepicker-ui-ok-btn")}get activeTypeMode(){return this.modalElement?.querySelector(".timepicker-ui-type-mode.active")}get keyboardClockIcon(){return this.modalElement?.querySelector(".timepicker-ui-keyboard-icon-wrapper")}get footer(){return this.modalElement?.querySelector(".timepicker-ui-footer")}get wrapper(){return this.modalElement?.querySelector(".timepicker-ui-wrapper")}getElement(){return this._element}on(e,t){if(this._isDestroyed){console.warn("TimepickerUI: Cannot add event listener - instance failed to initialize");return}this._eventEmitter.on(e,t)}once(e,t){if(this._isDestroyed){console.warn("TimepickerUI: Cannot add event listener - instance failed to initialize");return}this._eventEmitter.once(e,t)}off(e,t){if(this._isDestroyed){console.warn("TimepickerUI: Cannot remove event listener - instance failed to initialize");return}this._eventEmitter.off(e,t)}emit(e,t){this._eventEmitter.emit(e,t)}_applyThemeToWrapper(e){if(!this._pendingThemeConfig)return;let t={primaryColor:"--timepicker-primary",backgroundColor:"--timepicker-bg",surfaceColor:"--timepicker-surface",surfaceHoverColor:"--timepicker-surface-hover",textColor:"--timepicker-text",secondaryTextColor:"--timepicker-secondary-text",disabledTextColor:"--timepicker-disabled-text",onPrimaryColor:"--timepicker-on-primary",borderColor:"--timepicker-border",shadow:"--timepicker-shadow",borderRadius:"--timepicker-border-radius",fontFamily:"--timepicker-font-family"};Object.entries(this._pendingThemeConfig).forEach(([i,r])=>{r&&t[i]&&e.style.setProperty(t[i],r)})}};var pe=class extends le{create=()=>{if(this._isDestroyed){console.warn("TimepickerUI: Cannot create - instance failed to initialize");return}if(this._isInitialized){console.warn("TimepickerUI: Instance is already initialized");return}this.configManager.updateInputValueWithCurrentTimeOnStart(),this.validationManager.checkDisabledValuesOnStart(),this.themeManager.setTimepickerClassToElement(),this.themeManager.setInputClassToInputElement(),this.themeManager.setDataOpenToInputIfDoesntExistInWrapper(),this.themeManager.setClassTopOpenElement(),this._options.inline?.enabled?(this.eventManager.handleOpenOnEnterFocus(),this._eventsBundle()):(this.eventManager.handleOpenOnEnterFocus(),this.eventManager.handleOpenOnClick()),this.configManager.getDisableTime(),this._isInitialized=!0};open=e=>{if(this._isDestroyed){console.warn("TimepickerUI: Cannot open - instance failed to initialize");return}this._isInitialized||this.create(),this._eventsBundle(),P(e)};close=()=>ve((...e)=>{if(e.length>2||!this.modalElement)return;let[t]=e.filter(r=>typeof r=="boolean"),[i]=e.filter(r=>typeof r=="function");t&&(this.eventManager.handleOkButton(),this.okButton?.click()),this._isTouchMouseMove=!1,document.removeEventListener("mousedown",this.eventManager._onDragStart,!1),document.removeEventListener("touchstart",this.eventManager._onDragStart),document.removeEventListener("mousemove",this.eventManager._onDragMove,!1),document.removeEventListener("mouseup",this.eventManager._onDragEnd,!1),document.removeEventListener("touchmove",this.eventManager._onDragMove),document.removeEventListener("touchend",this.eventManager._onDragEnd,!1),document.removeEventListener("mouseleave",this.eventManager._onDragEnd,!1),document.removeEventListener("mousedown",this._eventsClickMobileHandler),document.removeEventListener("touchstart",this._eventsClickMobileHandler),document.removeEventListener("keypress",this.eventManager.handleEscClick),this.wrapper.removeEventListener("keydown",this.eventManager.focusTrapHandler),this._options.enableSwitchIcon&&(this.keyboardClockIcon.removeEventListener("touchstart",this.configManager.handlerViewChange()),this.keyboardClockIcon.removeEventListener("mousedown",this.configManager.handlerViewChange())),this.animationManager.removeAnimationToClose(),this.openElement.forEach(r=>r?.classList.remove("disabled")),setTimeout(()=>{document.body.style.overflowY="",document.body.style.paddingRight=""},400),this.openElement.forEach(r=>r?.classList.remove("disabled")),setTimeout(()=>{this._options.focusInputAfterCloseModal&&this.input?.focus(),this.modalElement!==null&&(this.modalElement.remove(),this._isModalRemove=!0)},300),P(i)},this._options.delayHandler||300);destroy=e=>{if(this._isDestroyed){console.warn("TimepickerUI: Instance is already destroyed");return}let t=typeof e=="function"?{callback:e}:e||{},{keepInputValue:i=!1,callback:r}=t,s=i?this.input?.value:null;this.clockFacePool.clear(),this.domBatcher.destroy(),De.split(" ").forEach(o=>{document.removeEventListener(o,this._mutliEventsMoveHandler,!1)}),document.removeEventListener("mousedown",this.eventManager._onDragStart,!1),document.removeEventListener("touchstart",this.eventManager._onDragStart),document.removeEventListener("mousemove",this.eventManager._onDragMove,!1),document.removeEventListener("mouseup",this.eventManager._onDragEnd,!1),document.removeEventListener("touchmove",this.eventManager._onDragMove),document.removeEventListener("touchend",this.eventManager._onDragEnd,!1),document.removeEventListener("mouseleave",this.eventManager._onDragEnd,!1),document.removeEventListener("mousedown",this._eventsClickMobileHandler),document.removeEventListener("touchstart",this._eventsClickMobileHandler),this.modalElement?.remove(),this.openElement?.forEach(o=>{o&&(o.classList.remove("disabled","active","timepicker-ui-open-element"),o.classList.remove("basic","crane-straight","crane-radius","m3"))}),this.input&&(this.input.classList.remove("timepicker-ui-invalid-format","invalid-value","error","active","timepicker-ui-input"),this.input.removeAttribute("data-open"),this.input.removeAttribute("data-owner-id"),i&&s!==null&&(this.input.value=s)),this._element&&(this._element.classList.remove("basic","crane-straight","crane-radius","m3"),this._element.classList.remove("error","active","disabled"),this._element.removeAttribute("data-owner-id"),this._element.removeAttribute("data-open"),this._options.cssClass&&this._element.classList.remove(this._options.cssClass)),this._element?.querySelectorAll(".timepicker-ui-invalid-text")?.forEach(o=>o.remove()),this._mutliEventsMoveHandler=()=>{},this._eventsClickMobileHandler=()=>{},this._mutliEventsMove=()=>{},this._eventsClickMobile=()=>Promise.resolve(),this._isModalRemove=!0,this._isTouchMouseMove=!1,this._disabledTime=null,this._cloned=null,this._degreesHours=null,this._degreesMinutes=null,this._isInitialized=!1,this._isDestroyed=!0,typeof document<"u"&&(document.body.style.overflowY="",document.body.style.paddingRight=""),this.onDestroy?.(),P(r)};onDestroy;_eventsBundle=()=>{if(this._isDestroyed){console.warn("TimepickerUI: Instance is destroyed");return}if(this._isModalRemove){if(this._options.inline?.enabled||this.eventManager.handleEscClick(),this.validationManager.setErrorHandler(),this.validationManager.removeErrorHandler(),this._options.inline?.enabled||(this.openElement.forEach(e=>e?.classList.add("disabled")),this.input?.blur()),this.modalManager.setScrollbarOrNot(),this.modalManager.setModalTemplate(),this.modalManager.setNormalizeClass(),this.modalManager.removeBackdrop(),this.clockManager.setOnStartCSSClassesIfClockType24h(),this.clockManager.setClassActiveToHourOnOpen(),this.clockFace!==null){let e=this.clockFacePool.acquire({array:B,classToAdd:"timepicker-ui-hour-time-12",clockFace:this.clockFace,tipsWrapper:this.tipsWrapper,theme:this._options.theme,disabledTime:this._disabledTime?.value?.isInterval?this._disabledTime?.value:this._disabledTime?.value?.hours,clockType:this._options.clockType,hour:this.hour.value,activeTypeMode:this.activeTypeMode?.textContent||""});if(e.create(),this._options.clockType==="24h"){let t=this.clockFacePool.acquire({array:q,classToAdd:"timepicker-ui-hour-time-24",clockFace:this.tipsWrapperFor24h,tipsWrapper:this.tipsWrapperFor24h,theme:this._options.theme,clockType:"24h",disabledTime:this._disabledTime?.value?.isInterval?this._disabledTime?.value:this._disabledTime?.value?.hours,hour:this.hour.value});t.create(),this.clockFacePool.release(t)}else this._options.clockType==="12h"&&this._disabledTime?.value?.isInterval&&setTimeout(()=>{e.updateDisable(this.hour.value,this.activeTypeMode?.textContent||"")},300);this.clockFacePool.release(e)}this.modalManager.setFlexEndToFooterIfNoKeyboardIcon(),setTimeout(()=>{this.themeManager.setTheme();let e=this.modalElement?.querySelector(".timepicker-ui-wrapper");e&&(this._options.cssClass&&e.classList.add(this._options.cssClass),this._pendingThemeConfig&&this._applyThemeToWrapper(e))},0),this.animationManager.setAnimationToOpen(),this.configManager.getInputValueOnOpenAndSet(),this.clockManager.toggleClassActiveToValueTips(this.hour.value),this._isMobileView||(this.clockManager.setTransformToCircleWithSwitchesHour(this.hour.value),this.animationManager.handleAnimationClock()),this.eventManager.handleMinutesEvents(),this.eventManager.handleHourEvents(),this._options.clockType!=="24h"&&(this.eventManager.handleAmClick(),this.eventManager.handlePmClick()),this.clockFace&&this.eventManager.handleMoveHand(),this.eventManager.handleCancelButton(),this.eventManager.handleOkButton(),this.modalElement&&(this.modalManager.setShowClassToBackdrop(),this._options.inline?.enabled||this.eventManager.handleBackdropClick()),this.eventManager.handleIconChangeView(),this.eventManager.handleClickOnHourMobile(),this._options.focusTrap&&this.eventManager.focusTrapHandler(),this._options.inline?.enabled&&this._options.inline.autoUpdate!==!1&&this.eventManager.handleInlineAutoUpdate()}}};var me=class extends pe{getValue=()=>{if(this._isDestroyed)return console.warn("TimepickerUI: Instance is destroyed"),{hour:"",minutes:"",time:"",degreesHours:null,degreesMinutes:null};let e=this.hour?.value||"12",t=this.minutes?.value||"00",i=this._options.clockType==="24h"?void 0:this.activeTypeMode?.textContent||"AM",r="";return this._options.clockType==="24h"?r=`${e.padStart(2,"0")}:${t.padStart(2,"0")}`:r=`${e}:${t.padStart(2,"0")} ${i}`,{hour:e,minutes:t,type:i,time:r,degreesHours:this._degreesHours,degreesMinutes:this._degreesMinutes}};setValue=(e,t=!0)=>{if(this._isDestroyed){console.warn("TimepickerUI: Instance is destroyed");return}if(!e||typeof e!="string")throw new Error("TimepickerUI: setValue requires a valid time string");let i=ke(e.trim()),r="12",s="00",a="AM";try{if(this._options.clockType==="24h"){let o=i.match(/^([0-1]?[0-9]|2[0-3]):([0-5][0-9])$/);if(!o)throw new Error("Invalid 24h format. Expected HH:MM");r=o[1].padStart(2,"0"),s=o[2]}else{let o=i.match(/^(1[0-2]|[1-9]):([0-5][0-9])\s*(AM|PM)$/i);if(!o)throw new Error("Invalid 12h format. Expected HH:MM AM/PM");r=o[1],s=o[2],a=o[3].toUpperCase()}this.hour&&(this.hour.value=r,this.hour.setAttribute("aria-valuenow",r),this._degreesHours=Number(r)*30),this.minutes&&(this.minutes.value=s,this.minutes.setAttribute("aria-valuenow",s),this._degreesMinutes=Number(s)*6),this._options.clockType!=="24h"&&this.AM&&this.PM&&(a==="AM"?(this.AM.classList.add("active"),this.PM.classList.remove("active")):(this.PM.classList.add("active"),this.AM.classList.remove("active"))),t&&this.input&&(this.input.value=i),this.clockHand&&(this.clockHand.style.transform=`rotateZ(${this._degreesHours||0}deg)`)}catch(o){throw new Error(`TimepickerUI: ${o instanceof Error?o.message:"Invalid time format"}`)}};update=(e,t)=>{if(this._isDestroyed){console.warn("TimepickerUI: Instance is destroyed");return}this._options={...this._options,...e.options},this.configManager.checkMobileOption(),e.create&&this.create(),P(t)};setTheme(e){if(this._isDestroyed){console.warn("TimepickerUI: Cannot set theme on destroyed instance");return}this._pendingThemeConfig=e;let t=this.modalElement?.querySelector(".timepicker-ui-wrapper");t&&this._applyThemeToWrapper(t)}};var $=new Map,U=class extends me{constructor(e,t){if(super(e,t),this._isDestroyed)return;let i=t?.id;if(i&&$.has(i)){console.error(`TimepickerUI: Instance with ID "${i}" already exists`),this._isDestroyed=!0;return}$.set(this._instanceId,this),this.onDestroy=()=>{$.delete(this._instanceId)}}static getById(e){return $.get(e)}static getAllInstances(){return Array.from($.values())}static isAvailable(e){return typeof window>"u"?!1:typeof e=="string"?document.querySelector(e)!==null:e instanceof HTMLElement?document.contains(e):!1}static destroyAll(){Array.from($.values()).forEach(t=>t.destroy()),$.clear()}};var ze=U;0&&(module.exports={EventEmitter,TimepickerUI});
|
|
1
|
+
"use strict";var ue=Object.defineProperty;var De=Object.getOwnPropertyDescriptor;var xe=Object.getOwnPropertyNames;var Oe=Object.prototype.hasOwnProperty;var Pe=(a,e)=>{for(var t in e)ue(a,t,{get:e[t],enumerable:!0})},Ne=(a,e,t,i)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of xe(e))!Oe.call(a,n)&&n!==t&&ue(a,n,{get:()=>e[n],enumerable:!(i=De(e,n))||i.enumerable});return a};var Re=a=>Ne(ue({},"__esModule",{value:!0}),a);var Ue={};Pe(Ue,{EventEmitter:()=>$,TimepickerUI:()=>ce,default:()=>We});module.exports=Re(Ue);var A=()=>typeof window>"u",v=()=>typeof document<"u";var J=class{state;constructor(e,t,i,n){this.state={degreesHours:null,degreesMinutes:null,options:t,element:e,instanceId:i,isMobileView:!1,isTouchMouseMove:!1,disabledTime:null,cloned:null,isModalRemove:!0,isInitialized:!1,customId:n,eventHandlersRegistered:!1,isDestroyed:!1}}get degreesHours(){return this.state.degreesHours}get degreesMinutes(){return this.state.degreesMinutes}get options(){return this.state.options}get element(){return this.state.element}get instanceId(){return this.state.instanceId}get isMobileView(){return this.state.isMobileView}get isTouchMouseMove(){return this.state.isTouchMouseMove}get disabledTime(){return this.state.disabledTime}get cloned(){return this.state.cloned}get isModalRemove(){return this.state.isModalRemove}get isInitialized(){return this.state.isInitialized}get customId(){return this.state.customId}get eventHandlersRegistered(){return this.state.eventHandlersRegistered}get isDestroyed(){return this.state.isDestroyed}setDegreesHours(e){this.state={...this.state,degreesHours:e}}setDegreesMinutes(e){this.state={...this.state,degreesMinutes:e}}setOptions(e){this.state={...this.state,options:e}}setIsMobileView(e){this.state={...this.state,isMobileView:e}}setIsTouchMouseMove(e){this.state={...this.state,isTouchMouseMove:e}}setDisabledTime(e){this.state={...this.state,disabledTime:e}}setCloned(e){this.state={...this.state,cloned:e}}setIsModalRemove(e){this.state={...this.state,isModalRemove:e}}setIsInitialized(e){this.state={...this.state,isInitialized:e}}setEventHandlersRegistered(e){this.state={...this.state,eventHandlersRegistered:e}}setIsDestroyed(e){this.state={...this.state,isDestroyed:e}}updateOptions(e){this.state={...this.state,options:{...this.state.options,clock:{...this.state.options.clock,...e.clock||{}},ui:{...this.state.options.ui,...e.ui||{}},labels:{...this.state.options.labels,...e.labels||{}},behavior:{...this.state.options.behavior,...e.behavior||{}},callbacks:{...this.state.options.callbacks,...e.callbacks||{}}}}}reset(){this.state={...this.state,degreesHours:null,degreesMinutes:null,isTouchMouseMove:!1,disabledTime:null,cloned:null,isModalRemove:!0,isInitialized:!1,isDestroyed:!0,eventHandlersRegistered:!1}}getModalElement(){return v()===!1?null:document.querySelector(`[data-owner-id="${this.state.instanceId}"]`)}getInput(){return this.state.element?.querySelector("input")}getClockFace(){let e=this.getModalElement();return e?this.state.isMobileView?e.querySelector(".tp-ui-clock-face.mobile"):e.querySelector(".tp-ui-clock-face:not(.mobile)"):null}getClockHand(){let e=this.getModalElement();return e?this.state.isMobileView?e.querySelector(".tp-ui-mobile-clock-wrapper .tp-ui-clock-hand"):e.querySelector(".tp-ui-clock-hand:not(.mobile)"):null}getCircle(){let e=this.getModalElement();return e?this.state.isMobileView?e.querySelector(".tp-ui-mobile-clock-wrapper .tp-ui-circle-hand"):e.querySelector(".tp-ui-circle-hand:not(.mobile)"):null}getTipsWrapper(){let e=this.getModalElement();return e?this.state.isMobileView?e.querySelector(".tp-ui-mobile-clock-wrapper .tp-ui-tips-wrapper"):e.querySelector(".tp-ui-tips-wrapper:not(.mobile)"):null}getTipsWrapperFor24h(){let e=this.getModalElement();return e?this.state.isMobileView?e.querySelector(".tp-ui-mobile-clock-wrapper .tp-ui-tips-wrapper-24h"):e.querySelector(".tp-ui-tips-wrapper-24h:not(.mobile)"):null}getMinutes(){return this.getModalElement()?.querySelector(".tp-ui-minutes")||null}getHour(){return this.getModalElement()?.querySelector(".tp-ui-hour")||null}getAM(){return this.getModalElement()?.querySelector(".tp-ui-am")||null}getPM(){return this.getModalElement()?.querySelector(".tp-ui-pm")||null}getHourText(){return this.getModalElement()?.querySelector(".tp-ui-hour-text")||null}getMinutesText(){return this.getModalElement()?.querySelector(".tp-ui-minute-text")||null}getHeader(){return this.getModalElement()?.querySelector(".tp-ui-header")||null}getInputWrappers(){return this.getModalElement()?.querySelectorAll(".tp-ui-input-wrapper")||null}getDots(){return this.getModalElement()?.querySelector(".tp-ui-dots")||null}getMinutesTips(){return this.getModalElement()?.querySelector(".tp-ui-minutes-time")||null}getHourTips(){return this.getModalElement()?.querySelector(".tp-ui-hour-time-12")||null}getAllValueTips(){let e=this.getModalElement();return e?[...e.querySelectorAll(".tp-ui-value-tips"),...e.querySelectorAll(".tp-ui-value-tips-24h")]:[]}getOpenElementData(){let e=this.state.element?.querySelectorAll("[data-open]");if(e?.length>0){let t=[];return e.forEach(({dataset:i})=>t.push(i.open??"")),[...new Set(t)]}return null}getOpenElement(){let e=this.getInput(),t=this.getOpenElementData();return t===null?(e?.setAttribute("data-open","tp-ui-input"),[e]):t.map(i=>this.state.element?.querySelectorAll(`[data-open='${i}']`))[0]??""}getCancelButton(){return this.getModalElement()?.querySelector(".tp-ui-cancel-btn")||null}getOkButton(){return this.getModalElement()?.querySelector(".tp-ui-ok-btn")||null}getActiveTypeMode(){return this.getModalElement()?.querySelector(".tp-ui-type-mode.active")||null}getKeyboardClockIcon(){return this.getModalElement()?.querySelector(".tp-ui-keyboard-icon-wrapper")||null}getFooter(){return this.getModalElement()?.querySelector(".tp-ui-footer")||null}getWrapper(){return this.getModalElement()?.querySelector(".tp-ui-wrapper")||null}};var k={DEFAULT_DELAY:300,MODAL_ANIMATION:150,SCROLLBAR_RESTORE:400,MODAL_REMOVE:300,CLOCK_ANIMATION:600,TIPS_ANIMATION:401,MOBILE_TOGGLE:450,CLOCK_SCALE_DELAY:150};var F=class{core;emitter;timeouts=[];constructor(e,t){this.core=e,this.emitter=t,this.setupEventListeners()}setupEventListeners(){this.emitter.on("animation:clock",()=>{this.handleAnimationSwitchTipsMode()})}runWithAnimation(e,t=k.MODAL_ANIMATION){if(this.core.options.ui.animation){let i=setTimeout(e,t);this.timeouts.push(i)}else e()}clearAllTimeouts(){this.timeouts.forEach(clearTimeout),this.timeouts=[]}setAnimationToOpen(){this.clearAllTimeouts(),this.core.getModalElement()?.classList.add("opacity"),this.runWithAnimation(()=>{this.core.getModalElement()?.classList.add("show")})}removeAnimationToClose(){this.clearAllTimeouts(),this.core.getModalElement()&&this.runWithAnimation(()=>{let t=this.core.getModalElement();t?.classList.remove("show"),t?.classList.remove("opacity")})}handleAnimationClock(){this.core.options.ui.animation&&this.runWithAnimation(()=>{this.core.getClockFace()?.classList.add("tp-ui-clock-animation");let t=setTimeout(()=>{this.core.getClockFace()?.classList.remove("tp-ui-clock-animation")},k.CLOCK_ANIMATION);this.timeouts.push(t)})}handleAnimationSwitchTipsMode(){let e=this.core.getClockHand();if(!e)return;e.classList.add("tp-ui-tips-animation");let t=setTimeout(()=>{this.core.getClockHand()?.classList.remove("tp-ui-tips-animation")},k.TIPS_ANIMATION);this.timeouts.push(t)}destroy(){this.clearAllTimeouts()}};var Ee=()=>{if(v()===!1)return 0;let a=document.createElement("div");a.className="tp-ui-measure",document.body.appendChild(a);let e=a.getBoundingClientRect().width-a.clientWidth;return document.body.removeChild(a),e};var be=(a,e)=>a?a.classList.contains(e):!1,_=(a,e)=>Array.from({length:Number(e)-Number(a)+1},(t,i)=>Number(a)+i),Q=(a,e)=>Array.from({length:Number(e)-Number(a)+1},(t,i)=>Number(e)-i).reverse();var de=(a="")=>{let e=a.replace(/(AM|PM|am|pm)/,r=>` ${r}`),t=new Date(`September 20, 2000 ${e}`),i=t.getHours().toString().padStart(2,"0"),n=t.getMinutes().toString().padStart(2,"0");return`${i}:${n}`},me=a=>{let[e,t]=a.split(":");return`${e.padStart(2,"0")}:${t.padStart(2,"0")}`},ee=(a,e)=>{if(a.length<2)return!1;let t=a.map(i=>{let[n,r]=i.trim().split("-"),s,o;if(e==="12h"){if(!/\s?(AM|PM|am|pm)\s?$/.test(n.trim())||!/\s?(AM|PM|am|pm)\s?$/.test(r.trim()))throw new Error(`Invalid 12h format: "${i}"`);s=de(n.trim()),o=de(r.trim())}else{if(/\s?(AM|PM|am|pm)\s?/.test(n.trim())||/\s?(AM|PM|am|pm)\s?/.test(r.trim()))throw new Error(`Invalid 24h format: "${i}"`);s=me(n.trim()),o=me(r.trim())}return{start:s,end:o,original:i}});for(let i=0;i<t.length;i++)for(let n=i+1;n<t.length;n++){let r=t[i],s=t[n];if(r.start<=s.end&&r.end>=s.start||s.start<=r.end&&s.end>=r.start)throw new Error(`Overlapping intervals: "${r.original}" and "${s.original}"`)}return!1},Te=()=>typeof window<"u"&&window.crypto&&typeof window.crypto.randomUUID=="function"?window.crypto.randomUUID():"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/g,a=>{let e=Math.random()*16|0;return(a==="x"?e:e&3|8).toString(16)});var ye='<svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 -960 960 960" width="24px" fill="#e3e3e3"><path d="M160-200q-33 0-56.5-23.5T80-280v-400q0-33 23.5-56.5T160-760h640q33 0 56.5 23.5T880-680v400q0 33-23.5 56.5T800-200H160Zm0-80h640v-400H160v400Zm160-40h320v-80H320v80ZM200-440h80v-80h-80v80Zm120 0h80v-80h-80v80Zm120 0h80v-80h-80v80Zm120 0h80v-80h-80v80Zm120 0h80v-80h-80v80ZM200-560h80v-80h-80v80Zm120 0h80v-80h-80v80Zm120 0h80v-80h-80v80Zm120 0h80v-80h-80v80Zm120 0h80v-80h-80v80ZM160-280v-400 400Z"/></svg>';var Me='<svg xmlns="http://www.w3.org/2000/svg" height="24px" viewBox="0 -960 960 960" width="24px" fill="#e3e3e3"><path d="m612-292 56-56-148-148v-184h-80v216l172 172ZM480-80q-83 0-156-31.5T197-197q-54-54-85.5-127T80-480q0-83 31.5-156T197-763q54-54 127-85.5T480-880q83 0 156 31.5T763-763q54 54 85.5 127T880-480q0 83-31.5 156T763-197q-54 54-127 85.5T480-80Zm0-400Zm0 320q133 0 226.5-93.5T800-480q0-133-93.5-226.5T480-800q-133 0-226.5 93.5T160-480q0 133 93.5 226.5T480-160Z"/></svg>';var ke=["00","13","14","15","16","17","18","19","20","21","22","23"],pe=["12","1","2","3","4","5","6","7","8","9","10","11"],B=["00","05","10","15","20","25","30","35","40","45","50","55"],Ce=(a,e)=>{let{ui:{iconTemplate:t,enableSwitchIcon:i,animation:n,theme:r,mobile:s,editable:o,iconTemplateMobile:u},labels:{time:l,mobileTime:d,am:m,pm:p,cancel:E,ok:T,mobileMinute:w,mobileHour:C},clock:{type:y}}=a,c=s?"mobile":"",f=`<button aria-label="Keyboard" type="button" class="tp-ui-keyboard-icon">${t||ye}</button>`,g=u||`<button aria-label="Clock" type="button" class="tp-ui-keyboard-icon">${u||Me}</button>`;return`<div class="tp-ui-modal normalize ${c}" data-theme="${r}" role="dialog" aria-modal="true" aria-labelledby="tp-ui-label-${e}" data-owner-id="${e}" style='transition:${n?"opacity 0.15s linear":"none"}'><div class="tp-ui-wrapper ${c}" tabindex="0"><div class="tp-ui-select-time ${c}" id="tp-ui-label-${e}">${c?d:l}</div><div class="tp-ui-header ${c}"><div class="tp-ui-wrapper-time ${c} ${y==="24h"?"tp-ui-wrapper-time-24h":""}" role="group" aria-label="${c?d:l}"><div class="tp-ui-input-wrapper ${c}"><div class="tp-ui-input-ripple-wrapper ${c}" data-md3-ripple><input name="hour" ${!o&&!c?"readonly":""} class="tp-ui-hour ${c}" tabindex="0" type="number" min="0" max="${y==="12h"?"12":"23"}" aria-label="${c?C:"Hour"}" role="spinbutton" aria-valuenow="12"></div><div class="tp-ui-hour-text ${c}">${C}</div></div><div class="tp-ui-dots ${c}" aria-hidden="true"><span></span><span></span></div><div class="tp-ui-input-wrapper ${c}"><div class="tp-ui-input-ripple-wrapper ${c}" data-md3-ripple><input name="minutes" ${!o&&!c?"readonly":""} class="tp-ui-minutes ${c}" tabindex="0" type="number" min="0" max="59" aria-label="${c?w:"Minute"}" role="spinbutton" aria-valuenow="0"></div><div class="tp-ui-minute-text ${c}">${w}</div></div></div>${y!=="24h"?`<div class="tp-ui-wrapper-type-time ${c}" role="group" aria-label="Period"><div class="tp-ui-type-mode tp-ui-am ${c?"mobile":"tp-ui-ripple"}" data-md3-ripple tabindex="0" role="button" aria-label="${m}" aria-pressed="false" data-type="AM">${m}</div><div class="tp-ui-type-mode tp-ui-pm ${c?"mobile":"tp-ui-ripple"}" data-md3-ripple tabindex="0" role="button" aria-label="${p}" aria-pressed="false" data-type="PM">${p}</div></div>`:""}</div><div class="tp-ui-mobile-clock-wrapper ${c}"><div class="tp-ui-body ${c}"><div class="tp-ui-clock-face ${c}" role="group" aria-label="Clock"><div class="tp-ui-dot ${c}" aria-hidden="true"></div><div class="tp-ui-clock-hand ${c}" aria-hidden="true"><div class="tp-ui-circle-hand ${c}"></div></div><div class="tp-ui-tips-wrapper ${c}" role="listbox" aria-label="Time"></div>${y==="24h"?`<div class="tp-ui-tips-wrapper-24h ${c}" role="listbox" aria-label="24h"></div>`:""}</div></div></div><div class="tp-ui-footer ${c}" ${c?'data-view="mobile"':""}>${i?`<div class="tp-ui-keyboard-icon-wrapper ${c}" tabindex="0" role="button" aria-pressed="false" aria-label="Toggle" data-view="desktop">${c?g:f}</div>`:""}<div class="tp-ui-wrapper-btn ${c}"><div class="tp-ui-cancel-btn ${c}" data-md3-ripple tabindex="0" role="button" aria-pressed="false" aria-label="${E}">${E}</div><div class="tp-ui-ok-btn ${c}" data-md3-ripple tabindex="0" role="button" aria-pressed="false" aria-label="${T}">${T}</div></div></div></div><div class="timepicker-announcer sr-only" role="status" aria-live="polite" aria-atomic="true"></div></div>`};var W=class{core;emitter;timeouts=[];originalOverflow;originalPaddingRight;constructor(e,t){this.core=e,this.emitter=t}runWithTimeout(e,t=k.DEFAULT_DELAY){let i=setTimeout(e,t);this.timeouts.push(i)}clearAllTimeouts(){this.timeouts.forEach(clearTimeout),this.timeouts=[]}clearExistingModal(){if(v()===!1)return;let e=document.querySelector(".tp-ui-modal");e&&e.remove()}setModalTemplate(){if(v()===!1)return;this.clearExistingModal();let e=Ce(this.core.options,this.core.instanceId);if(this.core.options.ui.inline?.enabled){let i=document.getElementById(this.core.options.ui.inline.containerId);if(!i)return;i.innerHTML="",i.insertAdjacentHTML("beforeend",e);let n=i.querySelector(".tp-ui-modal");if(n){n.classList.add("tp-ui--inline");let{showButtons:r}=this.core.options.ui.inline;(r===!1||r===void 0)&&n.querySelectorAll(".tp-ui-wrapper-btn, .tp-ui-wrapper-btn.mobile").forEach(s=>s.style.display="none")}return}let{appendModalSelector:t}=this.core.options.ui;t?document.querySelector(t)?.insertAdjacentHTML("beforeend",e):document.body.insertAdjacentHTML("beforeend",e)}setScrollbarOrNot(){v()!==!1&&(this.core.options.ui.inline?.enabled||(this.core.options.ui.enableScrollbar?this.runWithTimeout(()=>{A()||this.runWithTimeout(()=>{typeof document<"u"&&(document.body.style.overflowY=this.originalOverflow||"",document.body.style.paddingRight=this.originalPaddingRight||"")},k.SCROLLBAR_RESTORE)},400):(this.originalOverflow=document.body.style.overflowY,this.originalPaddingRight=document.body.style.paddingRight,document.body.style.paddingRight=`${Ee()}px`,document.body.style.overflowY="hidden")))}removeBackdrop(){if(this.core.options.ui.inline?.enabled||this.core.options.ui.backdrop)return;let e=this.core.getModalElement(),t=this.core.getOpenElement();e?.classList.add("removed"),t.forEach(i=>i?.classList.add("disabled"))}setNormalizeClass(){let e=this.core.getModalElement();if(!e)return;e.classList.add("tp-ui-normalize"),e.querySelectorAll(":scope > div").forEach(i=>i.classList.add("tp-ui-normalize"))}setShowClassToBackdrop(){if(this.core.options.ui.inline?.enabled){this.core.getModalElement()?.classList.add("show"),this.setInitialFocus();return}this.core.options.ui.backdrop&&this.runWithTimeout(()=>{this.core.getModalElement()?.classList.add("show"),this.setInitialFocus()},k.MODAL_ANIMATION)}setInitialFocus(){if(!this.core.options.behavior.focusTrap)return;let e=this.core.getWrapper();e&&typeof requestAnimationFrame<"u"&&requestAnimationFrame(()=>{e.focus()})}setFlexEndToFooterIfNoKeyboardIcon(){let e=this.core.getFooter();!this.core.options.ui.enableSwitchIcon&&e&&(e.style.justifyContent="flex-end")}destroy(){this.clearAllTimeouts(),!A()&&!this.core.options.ui.inline?.enabled&&(document.body.style.overflowY=this.originalOverflow||"",document.body.style.paddingRight=this.originalPaddingRight||""),this.clearExistingModal()}};var H=(a,e,t,i)=>{let n={hour:"12",minutes:"00",type:e==="24h"?void 0:"PM"};if(!a)return n;let r=a.value.trim();if(!t&&!r)return n;if(typeof t=="boolean"&&t){let w=new Date,[C,y]=w.toLocaleTimeString().split(":"),c=C.padStart(2,"0");if(/[a-z]/i.test(y)&&e==="12h"){let[f,g]=y.split(" ");return{hour:c,minutes:f,type:g}}return{hour:c,minutes:y,type:void 0}}if(typeof t=="object"){let{time:w,locales:C,preventClockType:y}=t,c=w??new Date;if(y&&i){let[h,b]=new Date(c).toLocaleTimeString().split(":");if(/[a-z]/i.test(b)){let[L,D]=b.split(" ");return{hour:h,minutes:L,type:D}}return{hour:h.padStart(2,"0"),minutes:b,type:void 0}}let f=new Date(c).toLocaleTimeString(C||"en-US",{hour:"2-digit",minute:"2-digit",hour12:e==="12h"}),[g,M]=f.split(":");if(e==="12h"&&/[a-z]/i.test(M)){let h=M.trim().split(" "),b=h[0],L=h[1]||"AM";return{hour:g,minutes:b,type:L}}return{hour:g,minutes:M.replace(/\D/g,""),type:void 0}}let[s,o]=r.split(" "),[u="",l=""]=s.split(":"),d=u.replace(/\D/g,""),m=l.replace(/\D/g,""),p={hour:d.padStart(2,"0"),minutes:m.padStart(2,"0"),type:e==="12h"?o:void 0};if(d.length>2||m.length>2)return{...p,error:"Invalid input: too many digits.",currentHour:u,currentMin:l};if(/[a-z]/i.test(s))return{...p,error:"Input contains invalid letters."};if(r.includes(" ")&&(!o||r.length>8||o!=="AM"&&o!=="PM"))return{...p,error:"Invalid AM/PM format or length.",currentLength:r.length,currentType:o};let E=Number(d),T=Number(m);if(e==="12h"){if(E<1||E>12||T<0||T>59||o!=="AM"&&o!=="PM")return{...p,error:"Invalid 12h time.",currentHour:E,currentMin:T,currentType:o}}else if(E<0||E>23||T<0||T>59)return{...p,error:"Invalid 24h time.",currentHour:E,currentMin:T};return p},he=(a,e,t)=>{let i=Number(a);if(Number.isNaN(i))return!1;switch(e){case"hour":return t==="24h"?i>=0&&i<=23:i>0&&i<=12;case"minutes":return i>=0&&i<=59;default:return}};var Le=a=>{if(!a)return;let{disabledTime:e,type:t}=a.clock;if(!e||!Object.keys(e).length)return;let{hours:i,minutes:n,interval:r}=e;if(r){delete e.hours,delete e.minutes;let s=Array.isArray(r)?r:[r];if(!t)throw new Error("clockType required for interval");return ee(s,t),{value:s.map(l=>{let[d,m]=l.trim().split("-"),{hour:p,minutes:E,type:T}=H({value:d.trim()},t),{hour:w,minutes:C,type:y}=H({value:m.trim()},t),c=_(p,w).map(h=>Number(h)===0?"00":String(Number(h))),f=[],g=Number(E),M=Number(C);if(y===T)return g>0&&M<=0?(f.push(c[0],c[c.length-1]),c=c.slice(1,-1)):M<59&&M>0&&g<=0?(f.push(void 0,c[c.length-1]),c=c.slice(0,-1)):M>0&&g>0?(f.push(c[0],c[c.length-1]),c=c.slice(1,-1)):M===0&&g===0&&(f.push(void 0,c[c.length-1]),c.pop()),{removedStartedHour:f[0]!==void 0&&Number(f[0])<=9?`0${f[0]}`:f[0],removedEndHour:f[1]!==void 0&&Number(f[1])<=9?`0${f[1]}`:f[1],rangeArrHour:c,startMinutes:_(E,59).map(h=>Number(h)<=9?`0${h}`:`${h}`),endMinutes:Q(0,C).map(h=>Number(h)<=9?`0${h}`:`${h}`),startType:T,endType:y};{let h=_(p,12).map(String),b=Q(1,w).map(String),L=[],D=[];return g>0&&M<=0?(D.push(b[b.length-1]),L.push(h[0]),b.pop(),h.shift()):M<59&&M>0&&g<=0?(L.push(h[0]),D.push(b[b.length-1]),b.pop()):M>0&&g>0?(D.push(b[b.length-1]),L.push(h[0]),b.pop(),h.shift()):M===0&&g===0&&(D.push(b[b.length-1]),L.push(h[0]),b.pop()),{startType:T,endType:y,amHours:h,pmHours:b,removedAmHour:L[0]&&Number(L[0])<=9?`0${L[0]}`:L[0],removedPmHour:D[0]&&Number(D[0])<=9?`0${D[0]}`:D[0],startMinutes:Number(E)===0?[]:_(E,59).map(O=>Number(O)<=9?`0${O}`:`${O}`),endMinutes:Q(0,C).map(O=>Number(O)<=9?`0${O}`:`${O}`)}}}).reduce((l,d)=>(Object.entries(d).forEach(([m,p])=>{Array.isArray(p)?l[m]=Array.isArray(l[m])?[...l[m],...p]:[...p]:l[m]=p}),l),{isInterval:!0,clockType:t,intervals:s})}}return i?.forEach(s=>{if(t==="12h"&&Number(s)>12)throw new Error("The disabled hours value has to be less than 13");if(t==="24h"&&Number(s)>23)throw new Error("The disabled hours value has to be less than 24")}),n?.forEach(s=>{if(Number(s)>59)throw new Error("The disabled minutes value has to be less than 60")}),{value:{hours:i?.map(s=>s==="00"||Number(s)===0?`0${Number(s)}`:`${Number(s)}`),minutes:n?.map(s=>Number(s)<=9?`0${s}`:`${s}`)}}},ve=(a,e,t,i)=>{if(a){if(Array.isArray(a)&&a.length>0)return!a.map(r=>he(r,e,t)).some(r=>r===!1);if(typeof a=="string"||typeof a=="number"){let n=he(a,e,t),r=i?.map(Number).includes(Number(a));return!!(n&&!r)}}};var fe="tp-ui",qe="mousedown mouseup mousemove mouseleave mouseover",Fe="touchstart touchmove touchend",Ae=`${qe} ${Fe}`,P="active";var U=class{core;emitter;isAnimating=!1;constructor(e,t){this.core=e,this.emitter=t,this.setupEventListeners()}setupEventListeners(){this.emitter.on("switch:view",()=>{this.toggleMobileClockFace()})}isCurrentTimeEnabled(e){let t=this.core.options.clock.currentTime;return typeof t=="boolean"?t:!!t?.[e]}preventClockTypeByCurrentTime(){if(!this.isCurrentTimeEnabled("preventClockType"))return;let e=this.core.getInput();if(!e)return;let{currentTime:t,clockType:i}={currentTime:this.core.options.clock.currentTime,clockType:this.core.options.clock.type},{type:n}=H(e,i,t,!0);this.core.updateOptions({clock:{type:n?"12h":"24h"}})}updateInputValueWithCurrentTimeOnStart(){if(!this.isCurrentTimeEnabled("updateInput"))return;let e=this.core.getInput();if(!e)return;let{hour:t,minutes:i,type:n}=H(e,this.core.options.clock.type,this.core.options.clock.currentTime);e.value=n?`${t}:${i} ${n}`:`${t}:${i}`}checkMobileOption(){this.core.setIsMobileView(!!this.core.options.ui.mobile),this.core.options.ui.mobile&&this.core.updateOptions({ui:{editable:!0}})}getDisableTime(){let e=Le(this.core.options);this.core.setDisabledTime(e||null)}getInputValueOnOpenAndSet(){let e=this.core.getInput();if(!e)return;let t=H(e,this.core.options.clock.type,this.core.options.clock.currentTime),i=this.core.getHour(),n=this.core.getMinutes(),r=this.core.getActiveTypeMode(),s=this.core.getAM();if(t===void 0){i&&(i.value="12"),n&&(n.value="00");let E={hour:i?.value||"12",minutes:n?.value||"00",type:r?.dataset.type,degreesHours:this.core.degreesHours,degreesMinutes:this.core.degreesMinutes};this.emitter.emit("open",E),this.core.options.clock.type!=="24h"&&s&&s.classList.add(P);return}let[o,u,l]=e.value.split(":").join(" ").split(" ");e.value.length===0&&(o=t.hour,u=t.minutes,l=t.type),i&&(i.value=o.padStart(2,"0")),n&&(n.value=u.padStart(2,"0"));let m=this.core.getModalElement()?.querySelector(`[data-type='${l}']`);this.core.options.clock.type!=="24h"&&m&&m.classList.add(P);let p={...t,type:r?.dataset.type,degreesHours:this.core.degreesHours,degreesMinutes:this.core.degreesMinutes};this.emitter.emit("open",p)}getInputValue(e,t,i){return H(e,t,i)}toggleMobileClockFace(){if(this.isAnimating)return;let e=this.core.getModalElement();if(!e)return;let t=e.querySelector(".tp-ui-wrapper"),i=this.core.getKeyboardClockIcon(),n=e.querySelector(".tp-ui-mobile-clock-wrapper"),r=e.querySelectorAll("*"),s=e.querySelector(".tp-ui-select-time"),o=this.core.getHour(),u=this.core.getMinutes(),l=this.core.getClockFace();if(!t)return;let d=t.classList.contains("expanded"),m=this.core.isMobileView;d?this.collapseClockFace(t,n,r,i,s,o,u,l,m):this.expandClockFace(t,n,r,i,s,o,u,l)}collapseClockFace(e,t,i,n,r,s,o,u,l){this.isAnimating=!0,this.switchView(r,n,s,o,!0),i.forEach(d=>{d!==t&&d!==e&&d!==r&&(d.classList.remove("expanded"),l&&d.classList.add("mobile"))}),r&&(r.classList.remove("expanded"),l&&r.classList.add("mobile")),typeof requestAnimationFrame<"u"?requestAnimationFrame(()=>{t?.classList.remove("expanded"),l&&t?.classList.add("mobile"),e?.classList.remove("expanded"),l&&e?.classList.add("mobile"),l?u?.classList.remove("scale-in"):u?.classList.add("scale-in"),setTimeout(()=>{this.isAnimating=!1},k.MOBILE_TOGGLE)}):this.isAnimating=!1,n?.setAttribute("aria-label","Show clock face"),n?.setAttribute("aria-pressed","false")}expandClockFace(e,t,i,n,r,s,o,u){this.isAnimating=!0,o?.classList.contains("active")&&o?this.emitter.emit("select:minute",{minutes:o.value}):s&&this.emitter.emit("select:hour",{hour:s.value}),i.forEach(d=>{d!==t&&d!==e&&d!==r&&(d.classList.remove("mobile"),d.classList.add("expanded"))}),r&&(r.classList.remove("mobile"),r.classList.add("expanded")),this.switchView(r,n,s,o,!1),typeof requestAnimationFrame<"u"?requestAnimationFrame(()=>{e.classList.remove("mobile"),e.classList.add("expanded"),requestAnimationFrame(()=>{t&&(t.classList.remove("mobile"),t.classList.add("expanded")),u&&u.classList.remove("scale-in"),setTimeout(()=>{u&&u.classList.add("scale-in")},k.CLOCK_SCALE_DELAY),setTimeout(()=>{this.isAnimating=!1},k.MOBILE_TOGGLE)})}):this.isAnimating=!1,n?.setAttribute("aria-label","Hide clock face"),n?.setAttribute("aria-pressed","true")}switchView(e,t,i,n,r){r?(e?.classList.remove("mobile"),t?.classList.remove("mobile"),i?.classList.remove("mobile"),n?.classList.remove("mobile"),this.updateClockFaceAccessibility(!1)):(e?.classList.add("mobile"),t?.classList.add("mobile"),i?.classList.add("mobile"),n?.classList.add("mobile"),this.updateClockFaceAccessibility(!0))}updateClockFaceAccessibility(e){let t=this.core.getClockFace();if(!t)return;let i=t.querySelector(".tp-ui-tips-wrapper"),n=t.querySelector(".tp-ui-tips-wrapper-24h"),r=t.querySelectorAll(".tp-ui-tip");e?(t.setAttribute("aria-hidden","true"),i?.setAttribute("aria-hidden","true"),n?.setAttribute("aria-hidden","true"),r.forEach(s=>{s.setAttribute("tabindex","-1"),s.setAttribute("aria-hidden","true")})):(t.removeAttribute("aria-hidden"),i?.removeAttribute("aria-hidden"),n?.removeAttribute("aria-hidden"),r.forEach(s=>{s.setAttribute("tabindex","0"),s.removeAttribute("aria-hidden")}))}destroy(){}};var z=class{core;emitter;constructor(e,t){this.core=e,this.emitter=t}setTheme(){let e=this.core.getModalElement();if(!e)return;let{theme:t}=this.core.options.ui;t&&e.setAttribute("data-theme",t)}setInputClassToInputElement(){let e=this.core.getInput();e&&(be(e,"tp-ui-input")||e.classList.add("tp-ui-input"))}setDataOpenToInputIfDoesntExistInWrapper(){let e=this.core.getOpenElementData(),t=this.core.getInput();e===null&&t&&t.setAttribute("data-open","tp-ui-input")}setClassTopOpenElement(){let e=this.core.getOpenElement();for(let t of e)t&&t.classList.add("tp-ui-open-element")}setTimepickerClassToElement(){let e=this.core.element;if(!e)return;e.classList.add(fe);let t=this.core.options.ui.cssClass;t&&t!==fe&&e.classList.add(t)}destroy(){let e=this.core.getModalElement();e&&e.removeAttribute("data-theme")}};var N=class a extends Error{constructor(t,i){super(`[TimepickerUI] ${t}`);this.code=i;this.name="TimepickerError",Object.setPrototypeOf(this,a.prototype)}},te={ELEMENT_NOT_FOUND:"ELEMENT_NOT_FOUND",INVALID_PARAMETER:"INVALID_PARAMETER",NO_INPUT_ELEMENT:"NO_INPUT_ELEMENT",INSTANCE_DESTROYED:"INSTANCE_DESTROYED",NOT_INITIALIZED:"NOT_INITIALIZED",INVALID_TIME_FORMAT:"INVALID_TIME_FORMAT",INLINE_CONFIG_ERROR:"INLINE_CONFIG_ERROR",CONTAINER_NOT_FOUND:"CONTAINER_NOT_FOUND",SSR_ENVIRONMENT:"SSR_ENVIRONMENT"};var K=class{core;emitter;constructor(e,t){this.core=e,this.emitter=t}setErrorHandler(){let e=this.core.getInput();if(!e)return!0;let{error:t,currentHour:i,currentMin:n,currentType:r,currentLength:s}=H(e,this.core.options.clock.type);if(this.removeErrorHandler(),t){if(v()===!1)return!1;let o=document.createElement("div");o.classList.add("tp-ui-invalid-text"),o.innerHTML="<b>Invalid Time Format</b>",e.classList.add("tp-ui-invalid-format"),e.nextElementSibling?.classList.contains("tp-ui-invalid-text")||e.after(o);let u={error:t,rejectedHour:void 0,rejectedMinute:void 0,inputHour:i,inputMinute:n,inputType:r,inputLength:s};return this.emitter.emit("error",u),!1}return!0}removeErrorHandler(){let e=this.core.getInput();if(!e)return;e.classList.remove("tp-ui-invalid-format");let t=e.nextElementSibling;t?.classList.contains("tp-ui-invalid-text")&&t.remove()}checkDisabledValuesOnStart(){if(!this.core.options.clock.disabledTime)return;let{disabledTime:e,type:t}=this.core.options.clock;if(e.interval){if(!t)throw new N("clockType is required when using disabledTime.interval",te.INVALID_PARAMETER);let o=Array.isArray(e.interval)?e.interval:[e.interval];try{ee(o,t)}catch(u){throw new N(`Invalid disabledTime.interval: ${u.message}`,te.INVALID_PARAMETER)}return}let{hours:i,minutes:n}=e,r=i?ve(i,"hour",t):!0,s=n?ve(n,"minutes",t):!0;if(!r||!s)throw new N("Invalid hours or minutes in disabledTime option",te.INVALID_PARAMETER)}destroy(){this.removeErrorHandler()}};var Z=class{core;emitter;cleanupHandlers=[];constructor(e,t){this.core=e,this.emitter=t}handleOpenOnClick(){let e=this.core.getOpenElement();if(!e)return;let t=()=>{this.core.isDestroyed||this.emitter.emit("show",{})};e.forEach(i=>{i.addEventListener("click",t),this.cleanupHandlers.push(()=>i.removeEventListener("click",t))})}handleOpenOnEnterFocus(){let e=this.core.getInput();if(!e)return;let t=i=>{i.key==="Enter"&&!this.core.isDestroyed&&this.emitter.emit("show",{})};e.addEventListener("keydown",t),this.cleanupHandlers.push(()=>e.removeEventListener("keydown",t))}handleCancelButton(){let e=this.core.getCancelButton();if(!e)return;let t=()=>{this.core.isDestroyed||this.emitter.emit("cancel",{})};e.addEventListener("click",t),this.cleanupHandlers.push(()=>e.removeEventListener("click",t))}handleOkButton(){let e=this.core.getOkButton();if(!e)return;let t=()=>{if(this.core.isDestroyed)return;let i=this.core.getHour(),n=this.core.getMinutes(),r=this.core.getActiveTypeMode();this.emitter.emit("confirm",{hour:i?.value,minutes:n?.value,type:r?.textContent||void 0})};e.addEventListener("click",t),this.cleanupHandlers.push(()=>e.removeEventListener("click",t))}handleBackdropClick(){let e=this.core.getModalElement();if(!e)return;let t=i=>{this.core.isDestroyed||i.target===e&&this.emitter.emit("cancel",{})};e.addEventListener("click",t),this.cleanupHandlers.push(()=>e.removeEventListener("click",t))}handleEscClick(){if(v()===!1)return;let e=t=>{this.core.isDestroyed||t.key==="Escape"&&this.emitter.emit("cancel",{})};document.addEventListener("keydown",e),this.cleanupHandlers.push(()=>document.removeEventListener("keydown",e))}handleAmClick(){let e=this.core.getAM();if(!e)return;let t=()=>{if(this.core.isDestroyed)return;let i=this.core.getPM();e.classList.add("active"),i?.classList.remove("active"),this.emitter.emit("select:am",{})};e.addEventListener("click",t),this.cleanupHandlers.push(()=>e.removeEventListener("click",t))}handlePmClick(){let e=this.core.getPM();if(!e)return;let t=()=>{if(this.core.isDestroyed)return;let i=this.core.getAM();e.classList.add("active"),i?.classList.remove("active"),this.emitter.emit("select:pm",{})};e.addEventListener("click",t),this.cleanupHandlers.push(()=>e.removeEventListener("click",t))}handleHourEvents(){let e=this.core.getHour();if(!e)return;let t=()=>{if(this.core.isDestroyed)return;e.classList.add("active"),this.core.getMinutes()?.classList.remove("active"),this.emitter.emit("select:hour",{hour:e.value})};if(e.addEventListener("click",t),this.cleanupHandlers.push(()=>e.removeEventListener("click",t)),this.core.options.ui.editable){let i=e.value,n=()=>{this.core.isDestroyed||e.value!==i&&(i=e.value,this.emitter.emit("animation:clock",{}),this.emitter.emit("select:hour",{hour:e.value}))};e.addEventListener("blur",n),this.cleanupHandlers.push(()=>e.removeEventListener("blur",n))}}handleMinutesEvents(){let e=this.core.getMinutes();if(!e)return;let t=()=>{if(this.core.isDestroyed)return;e.classList.add("active"),this.core.getHour()?.classList.remove("active"),this.emitter.emit("select:minute",{minutes:e.value})};e.addEventListener("click",t),this.cleanupHandlers.push(()=>e.removeEventListener("click",t))}handleKeyboardInput(){let e=this.core.getHour(),t=this.core.getMinutes();if(e){let i=n=>{if(this.core.isDestroyed||n.key!=="ArrowUp"&&n.key!=="ArrowDown")return;n.preventDefault();let r=parseInt(e.value)||0,s=parseInt(e.getAttribute("max")||"23"),o=parseInt(e.getAttribute("min")||"0"),u=this.core.options.clock.type==="12h",l;n.key==="ArrowUp"?u?l=r>=12?1:r+1:l=r>=s?0:r+1:u?l=r<=1?12:r-1:l=r<=0?s:r-1,e.value=l.toString().padStart(2,"0"),this.emitter.emit("animation:clock",{}),this.emitter.emit("select:hour",{hour:e.value})};e.addEventListener("keydown",i),this.cleanupHandlers.push(()=>e.removeEventListener("keydown",i))}if(t){let i=n=>{if(this.core.isDestroyed||n.key!=="ArrowUp"&&n.key!=="ArrowDown")return;n.preventDefault();let r=parseInt(t.value)||0,s=59,o=0,u;n.key==="ArrowUp"?u=r>=s?o:r+1:u=r<=o?s:r-1,t.value=u.toString().padStart(2,"0"),this.emitter.emit("animation:clock",{}),this.emitter.emit("select:minute",{minutes:t.value})};t.addEventListener("keydown",i),this.cleanupHandlers.push(()=>t.removeEventListener("keydown",i))}}focusTrapHandler(){if(v()===!1)return;let e=this.core.getWrapper();if(!e)return;let t=i=>{if(this.core.isDestroyed||i.key!=="Tab")return;let n=e.querySelectorAll('button, [href], input, select, textarea, [tabindex]:not([tabindex="-1"])'),r=n[0],s=n[n.length-1];i.shiftKey&&document.activeElement===r?(s?.focus(),i.preventDefault()):!i.shiftKey&&document.activeElement===s&&(r?.focus(),i.preventDefault())};e.addEventListener("keydown",t),this.cleanupHandlers.push(()=>e.removeEventListener("keydown",t))}handleMoveHand(){if(v()===!1)return;let e=t=>{this.core.isDestroyed||t.preventDefault()};document.addEventListener("mousedown",e,!1),document.addEventListener("touchstart",e,{passive:!1}),this.cleanupHandlers.push(()=>{document.removeEventListener("mousedown",e),document.removeEventListener("touchstart",e)})}handleSwitchViewButton(){let e=this.core.getKeyboardClockIcon();if(!e)return;let t=()=>{this.core.isDestroyed||this.emitter.emit("switch:view",{})};e.addEventListener("click",t),this.cleanupHandlers.push(()=>e.removeEventListener("click",t))}destroy(){this.cleanupHandlers.forEach(e=>e()),this.cleanupHandlers=[]}};var S=class{static angleToIndex(e,t,i){let n=Math.round(e/30)%12;if(t==="24h")if(i){let r=n+12;return r===12?0:r}else return n===0?12:n;return n===0?12:n}static indexToValue(e,t,i){if(t==="24h")return e.toString().padStart(2,"0");let n=e;return n===0&&(n=12),n>12&&(n=n-12),n.toString().padStart(2,"0")}static indexToAngle(e,t){return t==="24h"?e>=12?(e-12)%12*30:e%12*30:(e===0?12:e)%12*30}static isDisabled(e,t,i){return i?i.isInterval&&i.intervals&&i.clockType?this.isDisabledByInterval(e,t,i):i.hours?i.hours.some(n=>String(n)===e||Number(n)===Number(e)||n===e):!1:!1}static isDisabledByInterval(e,t,i){if(!i.intervals)return!1;for(let n=0;n<60;n++){let r=n.toString().padStart(2,"0");if(!this.isTimeInIntervals(e,r,t,i.intervals,i.clockType))return!1}return!0}static isTimeInIntervals(e,t,i,n,r){let s=r==="12h"?`${e}:${t} ${i}`:`${e}:${t}`;for(let o of n){let[u,l]=o.split("-").map(d=>d.trim());if(this.isTimeBetween(s,u,l,r))return!0}return!1}static isTimeBetween(e,t,i,n){let r=this.timeToMinutes(e,n),s=this.timeToMinutes(t,n),o=this.timeToMinutes(i,n);return r>=s&&r<=o}static timeToMinutes(e,t){if(t==="12h"){let i=e.match(/(\d{1,2}):(\d{2})\s*(AM|PM)/i);if(!i)return 0;let n=parseInt(i[1]),r=parseInt(i[2]),s=i[3].toUpperCase();return s==="PM"&&n!==12&&(n+=12),s==="AM"&&n===12&&(n=0),n*60+r}else{let[i,n]=e.split(":").map(Number);return i*60+n}}static findNearestValid(e,t,i,n,r){let s=t==="24h"?23:12;for(let o=0;o<=s;o++){let u=o===0?[e]:[e+o,e-o];for(let l of u){let d=l;d<0&&(d+=s+1),d>s&&(d=d%(s+1));let m=this.indexToValue(d,t,i);if(!this.isDisabled(m,i,n))return d}}return e}};var I=class{static angleToIndex(e){return Math.round(e/6)%60}static indexToValue(e){return e.toString().padStart(2,"0")}static indexToAngle(e){return e%60*6}static isDisabled(e,t,i,n,r){return n?n.isInterval&&n.intervals?this.isDisabledByInterval(e,t,i,n,r):n.minutes?n.minutes.some(s=>String(s)===e||Number(s)===Number(e)||s===e):!1:!1}static isDisabledByInterval(e,t,i,n,r){if(!n.intervals)return!1;let s=r==="12h"?`${t}:${e} ${i}`:`${t}:${e}`;for(let o of n.intervals){let[u,l]=o.split("-").map(d=>d.trim());if(this.isTimeBetween(s,u,l,r))return!0}return!1}static isTimeBetween(e,t,i,n){let r=this.timeToMinutes(e,n),s=this.timeToMinutes(t,n),o=this.timeToMinutes(i,n);return r>=s&&r<=o}static timeToMinutes(e,t){if(t==="12h"){let i=e.match(/(\d{1,2}):(\d{2})\s*(AM|PM)/i);if(!i)return 0;let n=parseInt(i[1]),r=parseInt(i[2]),s=i[3].toUpperCase();return s==="PM"&&n!==12&&(n+=12),s==="AM"&&n===12&&(n=0),n*60+r}else{let[i,n]=e.split(":").map(Number);return i*60+n}}static findNearestValid(e,t,i,n,r){for(let s=0;s<60;s++){let o=s===0?[e]:[e+s,e-s];for(let u of o){let l=u;l<0&&(l+=60),l>=60&&(l=l%60);let d=this.indexToValue(l);if(!this.isDisabled(d,t,i,n,r))return l}}return e}};var x=class{static normalizeAngle(e){let t=e%360;return t<0&&(t+=360),t}static calculateRawAngle(e,t){let i=e.x-t.x,n=e.y-t.y,s=Math.atan2(n,i)*180/Math.PI+90;return this.normalizeAngle(s)}static snapToIncrement(e,t){let i=Math.round(e/t)*t;return this.normalizeAngle(i)}static calculateDistance(e,t){let i=e.x-t.x,n=e.y-t.y;return Math.sqrt(i*i+n*n)}static isInnerCircle(e,t){return e<t*.6}static calculateShortestPath(e,t){let i=this.normalizeAngle(e),r=this.normalizeAngle(t)-i,s=r>=0?r:r+360,o=r<=0?r:r-360,u=Math.abs(s)<Math.abs(o)?s:o;return e+u}};var ie=class{config;currentAngle=0;tipsCache=new Map;cachedDimensions=new Map;constructor(e){this.config=e}getCachedDimensions(e){let t=this.cachedDimensions.get(e);if(!t){let i=(e.offsetWidth-32)/2,n=(e.offsetHeight-32)/2,r=i-9;t={width:i,height:n,radius:r},this.cachedDimensions.set(e,t)}return t}setHandAngle(e){if(Math.abs(this.currentAngle-e)<.1)return;let t=x.calculateShortestPath(this.currentAngle,e);this.currentAngle=t,this.config.clockHand.style.transform=`rotateZ(${t}deg)`}setActiveValue(e){let t=[this.config.tipsWrapper];this.config.tipsWrapperFor24h&&t.push(this.config.tipsWrapperFor24h),t.forEach(i=>{i.querySelectorAll(".tp-ui-value-tips, .tp-ui-value-tips-24h").forEach(r=>{let s=r;s.textContent===e||Number(s.textContent)===Number(e)?(s.classList.add("active"),s.setAttribute("aria-selected","true")):(s.classList.remove("active"),s.setAttribute("aria-selected","false"))})})}renderTips(e,t,i,n,r,s=!0,o,u="",l="12"){if(v()===!1)return;let d=o||this.config.tipsWrapper;s&&(d.innerHTML="",this.tipsCache.clear());let{width:m,height:p,radius:E}=this.getCachedDimensions(d),T=document.createDocumentFragment(),w=`${t}-${this.config.theme||"default"}`;e.forEach((C,y)=>{let c=`${w}-${C}`,f=this.tipsCache.get(c);f||(f=this.createTip(C,t,r),this.tipsCache.set(c,f));let{wrapper:g,tip:M}=f;this.updateTipState(g,M,C,i,n,r,u,l);let h=y*(360/e.length)*(Math.PI/180);g.style.left=`${m+Math.sin(h)*E}px`,g.style.bottom=`${p+Math.cos(h)*E}px`,T.appendChild(g)}),d.appendChild(T)}createTip(e,t,i){if(v()===!1){let o={};return{wrapper:o,tip:o}}let n=document.createElement("span"),r=document.createElement("span");r.textContent=e,r.setAttribute("role","option"),r.setAttribute("aria-selected","false"),r.tabIndex=0;let s=i==="24h"&&t.includes("24")?"tp-ui-value-tips-24h":"tp-ui-value-tips";return r.classList.add(s),n.classList.add(t),this.config.theme&&(n.classList.add(this.config.theme),r.classList.add(this.config.theme)),n.appendChild(r),{wrapper:n,tip:r}}updateTipState(e,t,i,n,r,s,o,u){e.classList.remove("tp-ui-tips-disabled"),t.classList.remove("tp-ui-tips-disabled"),t.removeAttribute("aria-disabled"),t.tabIndex=0,this.checkIfDisabled(i,n,r,s,o,u)&&(e.classList.add("tp-ui-tips-disabled"),t.classList.add("tp-ui-tips-disabled"),t.setAttribute("aria-disabled","true"),t.tabIndex=-1)}checkIfDisabled(e,t,i,n,r,s){return i?t==="hours"?S.isDisabled(e,r,i):t==="minutes"?I.isDisabled(e,s,r,i,n):!1:!1}setCircleSize(e){e?this.config.circle.classList.remove("small-circle"):this.config.circle.classList.add("small-circle")}setCircle24hMode(e){e?(this.config.circle.classList.add("tp-ui-circle-hand-24h"),this.config.clockHand.classList.add("tp-ui-clock-hand-24h")):(this.config.circle.classList.remove("tp-ui-circle-hand-24h"),this.config.clockHand.classList.remove("tp-ui-clock-hand-24h"))}destroy(){this.tipsCache.clear(),this.cachedDimensions.clear(),this.config.tipsWrapper.innerHTML=""}};var Y=class{static processPointerInput(e){let t=x.calculateRawAngle(e.pointerPosition,e.clockCenter);return e.mode==="hours"?this.processHours(t,e):this.processMinutes(t,e)}static processHours(e,t){let i=t.incrementHours*30,n=x.snapToIncrement(e,i),r=x.calculateDistance(t.pointerPosition,t.clockCenter),s=t.clockType==="24h"&&x.isInnerCircle(r,t.clockRadius),o=S.angleToIndex(n,t.clockType,s),u=S.indexToValue(o,t.clockType,t.amPm),l=S.isDisabled(u,t.amPm,t.disabledTime);l&&(o=S.findNearestValid(o,t.clockType,t.amPm,t.disabledTime,s));let d=S.indexToValue(o,t.clockType,t.amPm);return{angle:S.indexToAngle(o,t.clockType),value:d,index:o,isValid:!l,isInnerCircle:t.clockType==="24h"?s:void 0}}static processMinutes(e,t){let i=t.incrementMinutes*6,n=x.snapToIncrement(e,i),r=I.angleToIndex(n),s=I.indexToValue(r),o=t.currentHour||"00",u=I.isDisabled(s,o,t.amPm,t.disabledTime,t.clockType);u&&(r=I.findNearestValid(r,o,t.amPm,t.disabledTime,t.clockType));let l=I.indexToValue(r);return{angle:I.indexToAngle(r),value:l,index:r,isValid:!u}}static valueToAngle(e,t,i){let n=parseInt(e,10);return t==="hours"?S.indexToAngle(n,i):I.indexToAngle(n)}};var ne=class{state;renderer;clockType;disabledTime;incrementHours;incrementMinutes;isDragging=!1;callbacks;constructor(e,t,i,n,r=1,s=1,o={}){this.renderer=e,this.state={...t},this.clockType=i,this.disabledTime=n,this.incrementHours=r,this.incrementMinutes=s,this.callbacks=o}handlePointerMove(e,t,i){this.isDragging=!0;let n={pointerPosition:e,clockCenter:t,clockRadius:i,mode:this.state.mode,clockType:this.clockType,amPm:this.state.amPm,disabledTime:this.disabledTime,incrementHours:this.incrementHours,incrementMinutes:this.incrementMinutes,currentHour:this.state.hour},r=Y.processPointerInput(n);r.isValid&&(this.state.mode==="hours"?(this.state.hour=r.value,this.state.hourAngle=r.angle,this.clockType==="24h"&&r.isInnerCircle!==void 0&&(this.renderer.setCircleSize(!0),this.renderer.setCircle24hMode(r.isInnerCircle)),this.callbacks.onHourChange&&this.callbacks.onHourChange(r.value)):(this.state.minute=r.value,this.state.minuteAngle=r.angle,this.renderer.setCircleSize(!0),this.renderer.setCircle24hMode(!1),this.callbacks.onMinuteChange&&this.callbacks.onMinuteChange(r.value)),this.renderer.setHandAngle(r.angle),this.renderer.setActiveValue(r.value))}handlePointerUp(){this.isDragging=!1}switchMode(e){let t=this.state.mode===e;this.state.mode=e;let i=e==="hours"?this.state.hourAngle:this.state.minuteAngle,n=e==="hours"?this.state.hour:this.state.minute;if(e==="hours"&&this.clockType==="24h"){let r=parseInt(n,10),s=r===0||r>=13;this.renderer.setCircleSize(!0),this.renderer.setCircle24hMode(s)}else this.renderer.setCircleSize(!0),this.renderer.setCircle24hMode(!1);this.renderer.setHandAngle(i),this.renderer.setActiveValue(n)}setValue(e,t){let i=Y.valueToAngle(t,e,this.clockType);if(e==="hours")if(this.state.hour=t,this.state.hourAngle=i,this.clockType==="24h"){let n=parseInt(t,10),r=n===0||n>=13;this.renderer.setCircleSize(!0),this.renderer.setCircle24hMode(r)}else this.renderer.setCircle24hMode(!1);else this.state.minute=t,this.state.minuteAngle=i,this.renderer.setCircleSize(!0),this.renderer.setCircle24hMode(!1);this.state.mode===e&&(this.renderer.setHandAngle(i),this.renderer.setActiveValue(t))}setAmPm(e){this.state.amPm=e}getState(){return{...this.state}}getHour(){return this.state.hour}getMinute(){return this.state.minute}getAmPm(){return this.state.amPm}updateDisabledTime(e){this.disabledTime=e}destroy(){this.renderer.destroy()}};var re=class{controller;clockFace;isActive=!1;config;cachedRect=null;cachedCenter=null;cachedRadius=null;constructor(e,t,i={}){this.controller=e,this.clockFace=t,this.config=i}attach(){this.clockFace.addEventListener("mousedown",this.handlePointerDown),this.clockFace.addEventListener("touchstart",this.handlePointerDown,{passive:!1})}detach(){this.clockFace.removeEventListener("mousedown",this.handlePointerDown),this.clockFace.removeEventListener("touchstart",this.handlePointerDown),this.removeGlobalListeners()}handlePointerDown=e=>{if(A())return;let t=e.target;t&&t.classList&&t.classList.contains("tp-ui-tips-disabled")||(e.preventDefault(),this.isActive=!0,this.cachedRect=this.clockFace.getBoundingClientRect(),this.cachedCenter=this.getClockCenter(),this.cachedRadius=this.getClockRadius(),this.processPointerEvent(e),document.addEventListener("mousemove",this.handlePointerMove),document.addEventListener("touchmove",this.handlePointerMove,{passive:!1}),document.addEventListener("mouseup",this.handlePointerUp),document.addEventListener("touchend",this.handlePointerUp))};handlePointerMove=e=>{if(!this.isActive)return;let t=this.getTargetElement(e);t&&t.classList&&t.classList.contains("tp-ui-tips-disabled")||(e.preventDefault(),this.processPointerEvent(e))};handlePointerUp=()=>{if(!this.isActive)return;this.isActive=!1,this.cachedRect=null,this.cachedCenter=null,this.cachedRadius=null,this.controller.handlePointerUp(),this.removeGlobalListeners();let{autoSwitchToMinutes:e,isMobileView:t,hourElement:i,minutesElement:n}=this.config;e&&i?.classList.contains("active")&&!t&&(n?.click(),n?.focus())};processPointerEvent(e){let t=this.getPointerPosition(e),i=this.cachedCenter||this.getClockCenter(),n=this.cachedRadius||this.getClockRadius();this.controller.handlePointerMove(t,i,n)}getPointerPosition(e){let t=this.cachedRect||this.clockFace.getBoundingClientRect();if(e instanceof TouchEvent){let i=e.touches[0]||e.changedTouches[0];return{x:i.clientX-t.left,y:i.clientY-t.top}}else return{x:e.clientX-t.left,y:e.clientY-t.top}}getTargetElement(e){if(e instanceof TouchEvent){let t=e.touches[0]||e.changedTouches[0];if(t&&!A())return document.elementFromPoint(t.clientX,t.clientY)}return e.target}getClockCenter(){let e=this.clockFace.offsetWidth,t=this.clockFace.offsetHeight;return{x:e/2,y:t/2}}getClockRadius(){return this.clockFace.offsetWidth/2}removeGlobalListeners(){v()!==!1&&(document.removeEventListener("mousemove",this.handlePointerMove),document.removeEventListener("touchmove",this.handlePointerMove),document.removeEventListener("mouseup",this.handlePointerUp),document.removeEventListener("touchend",this.handlePointerUp))}};var G=class{renderer;controller;dragHandlers;clockType;disabledTime;tipsWrapper;tipsWrapperFor24h;constructor(e){this.clockType=e.clockType,this.disabledTime=e.disabledTime,this.tipsWrapper=e.tipsWrapper,this.tipsWrapperFor24h=e.tipsWrapperFor24h;let t={clockFace:e.clockFace,tipsWrapper:e.tipsWrapper,tipsWrapperFor24h:e.tipsWrapperFor24h,clockHand:e.clockHand,circle:e.circle,theme:e.theme};this.renderer=new ie(t);let i={hour:e.initialHour,minute:e.initialMinute,amPm:e.initialAmPm,hourAngle:this.calculateInitialAngle("hours",e.initialHour),minuteAngle:this.calculateInitialAngle("minutes",e.initialMinute),mode:"hours"},n={onHourChange:e.onHourChange,onMinuteChange:e.onMinuteChange};this.controller=new ne(this.renderer,i,e.clockType,e.disabledTime,e.incrementHours||1,e.incrementMinutes||1,n),this.dragHandlers=new re(this.controller,e.clockFace,e.dragConfig||{})}initialize(){this.dragHandlers.attach(),this.switchToHours()}switchToHours(){this.controller.switchMode("hours"),this.clockType==="24h"&&this.tipsWrapperFor24h&&this.tipsWrapperFor24h.classList.remove("none"),this.renderHourTips();let e=this.controller.getState();this.renderer.setActiveValue(e.hour)}switchToMinutes(){this.controller.switchMode("minutes"),this.tipsWrapperFor24h&&this.tipsWrapperFor24h.classList.add("none"),this.renderMinuteTips();let e=this.controller.getState();this.renderer.setActiveValue(e.minute)}setHour(e){this.controller.setValue("hours",e)}setMinute(e){this.controller.setValue("minutes",e)}setAmPm(e){this.controller.setAmPm(e);let t=this.controller.getState();t.mode==="hours"?(this.renderHourTips(),this.renderer.setHandAngle(t.hourAngle),this.renderer.setActiveValue(t.hour)):(this.renderMinuteTips(),this.renderer.setHandAngle(t.minuteAngle),this.renderer.setActiveValue(t.minute))}getHour(){return this.controller.getHour()}getMinute(){return this.controller.getMinute()}getAmPm(){return this.controller.getAmPm()}updateDisabledTime(e){this.controller.updateDisabledTime(e),this.controller.getState().mode==="hours"?this.renderHourTips():this.renderMinuteTips()}renderHourTips(){let t=this.controller.getState().amPm;this.clockType==="24h"?(this.renderer.renderTips(pe,"tp-ui-hour-time-12","hours",this.disabledTime,this.clockType,!0,this.tipsWrapper,t),this.tipsWrapperFor24h&&this.renderer.renderTips(ke,"tp-ui-hour-time-24","hours",this.disabledTime,this.clockType,!0,this.tipsWrapperFor24h,t)):this.renderer.renderTips(pe,"tp-ui-hour-time-12","hours",this.disabledTime,this.clockType,!0,void 0,t)}renderMinuteTips(){let e=this.controller.getState(),t=e.amPm,i=e.hour;this.renderer.renderTips(B,"tp-ui-minutes-time","minutes",this.disabledTime,this.clockType,!0,void 0,t,i)}calculateInitialAngle(e,t){let i=parseInt(t,10);return e==="hours"?i%12*30:i*6}destroy(){this.dragHandlers.detach(),this.controller.destroy()}};var j=class{core;emitter;clockSystem=null;constructor(e,t){this.core=e,this.emitter=t,this.setupEventListeners()}setupEventListeners(){this.emitter.on("select:hour",({hour:e})=>{this.emitter.emit("animation:clock",{}),this.setHoursToClock(e||null)}),this.emitter.on("select:minute",({minutes:e})=>{this.emitter.emit("animation:clock",{}),this.setMinutesToClock(e||null)}),this.emitter.on("select:am",()=>{this.updateAmPm()}),this.emitter.on("select:pm",()=>{this.updateAmPm()})}initializeClockSystem(){let e=this.core.getClockFace(),t=this.core.getClockHand(),i=this.core.getCircle();if(!e||!t||!i)return;let n=this.core.options.clock.type==="24h",r=this.core.getTipsWrapper();if(!r)return;let s=this.core.getHour(),o=this.core.getMinutes(),u={clockFace:e,tipsWrapper:r,tipsWrapperFor24h:n&&this.core.getTipsWrapperFor24h()||void 0,clockHand:t,circle:i,clockType:this.core.options.clock.type||"12h",disabledTime:this.convertDisabledTime(),initialHour:s?.value||"12",initialMinute:o?.value||"00",initialAmPm:this.getAmPmValue(),theme:this.core.options.ui.theme,incrementHours:this.core.options.clock.incrementHours||1,incrementMinutes:this.core.options.clock.incrementMinutes||1,timepicker:null,dragConfig:{autoSwitchToMinutes:this.core.options.clock.autoSwitchToMinutes,isMobileView:this.core.isMobileView,hourElement:s,minutesElement:o},onHourChange:l=>{let d=this.core.getHour();d&&(d.value=l)},onMinuteChange:l=>{let d=this.core.getMinutes();d&&(d.value=l)}};this.clockSystem=new G(u),this.clockSystem.initialize()}convertDisabledTime(){let e=this.core.disabledTime?.value;if(!e)return null;let t;return e.intervals&&(t=Array.isArray(e.intervals)?e.intervals:[e.intervals]),{hours:e.hours,minutes:e.minutes,isInterval:e.isInterval,intervals:t,clockType:e.clockType}}getAmPmValue(){if(this.core.options.clock.type==="24h")return"";let e=this.core.getActiveTypeMode();if(e){let i=e.textContent?.trim();if(i==="AM"||i==="PM")return i}return this.core.getAM()?.classList.contains("active")?"AM":"PM"}destroyClockSystem(){this.clockSystem&&(this.clockSystem.destroy(),this.clockSystem=null)}removeCircleClockClasses24h(){let e=this.core.getCircle(),t=this.core.getClockHand();e?.classList.remove("tp-ui-circle-hand-24h"),t?.classList.remove("tp-ui-clock-hand-24h")}setCircleClockClasses24h(){let e=this.core.getCircle(),t=this.core.getClockHand();e&&e.classList.add("tp-ui-circle-hand-24h"),t&&t.classList.add("tp-ui-clock-hand-24h")}setOnStartCSSClassesIfClockType24h(){if(this.core.options.clock.type==="24h"){let e=this.core.getInput();if(!e)return;let t;e.value.length>0&&(t=e.value.split(":")[0]),t&&(Number(t)>12||Number(t)===0)&&this.setCircleClockClasses24h()}}setBgColorToCircleWithMinutesTips=()=>{let e=this.core.getMinutes(),t=this.core.getCircle();if(!(!e||!t)&&e.value&&B.includes(e.value)){let i=getComputedStyle(t).getPropertyValue("--timepicker-primary").trim();i&&(t.style.backgroundColor=i),t.classList.remove("small-circle")}};removeBgColorToCirleWithMinutesTips=()=>{let e=this.core.getMinutes(),t=this.core.getCircle();!e||!t||e.value&&B.includes(e.value)||(t.style.backgroundColor="",t.classList.add("small-circle"))};setClassActiveToHourOnOpen=()=>{if(this.core.options.ui.mobile||this.core.isMobileView)return;this.core.getHour()?.classList.add(P)};setMinutesToClock=e=>{this.clockSystem&&(this.removeBgColorToCirleWithMinutesTips(),e&&this.clockSystem.setMinute(e),this.clockSystem.switchToMinutes())};setHoursToClock=e=>{this.clockSystem&&(e&&this.clockSystem.setHour(e),this.clockSystem.switchToHours())};setTransformToCircleWithSwitchesHour=e=>{!this.clockSystem||!e||this.clockSystem.setHour(e)};setTransformToCircleWithSwitchesMinutes=e=>{!this.clockSystem||!e||this.clockSystem.setMinute(e)};updateAmPm=()=>{if(!this.clockSystem||this.core.options.clock.type==="24h")return;let e=this.getAmPmValue();e!==""&&this.clockSystem.setAmPm(e)};toggleClassActiveToValueTips=e=>{if(this.clockSystem)return;let t=this.core.getAllValueTips();if(!t)return;let i=t.find(n=>Number(n.innerText)===Number(e));t.forEach(n=>{n.classList.remove(P),n.setAttribute("aria-selected","false")}),i!==void 0&&(i.classList.add(P),i.setAttribute("aria-selected","true"))};destroy(){this.destroyClockSystem()}};var se=class{animation;modal;config;theme;validation;events;clock;constructor(e,t){this.animation=new F(e,t),this.modal=new W(e,t),this.config=new U(e,t),this.theme=new z(e,t),this.validation=new K(e,t),this.events=new Z(e,t),this.clock=new j(e,t)}destroy(){this.animation.destroy(),this.modal.destroy(),this.config.destroy(),this.theme.destroy(),this.validation.destroy(),this.events.destroy(),this.clock.destroy()}};var oe="is-rippling",ae="ripple-hold",R=null;function _e(a){let e=a.target,t=e.hasAttribute("data-md3-ripple")?e:e.closest("[data-md3-ripple]");if(!t||a.button!==0&&a.pointerType==="mouse")return;let i=t.getBoundingClientRect(),r=Math.max(i.width,i.height)*2,s=a.clientX-i.left,o=a.clientY-i.top;t.style.setProperty("--ripple-size",`${r}px`),t.style.setProperty("--ripple-x",`${s}px`),t.style.setProperty("--ripple-y",`${o}px`),t.classList.remove(oe,ae),t.offsetWidth,t.classList.add(oe,ae),t._rippleHold=!0,R=t}function He(a){let e=a.target,i=(e.hasAttribute("data-md3-ripple")?e:e.closest("[data-md3-ripple]"))||R;i&&(i._rippleHold=!1,i.classList.remove(ae),setTimeout(()=>{i.classList.remove(oe),R===i&&(R=null)},1e3))}function Be(a){let e=a.currentTarget;!e||!e._rippleHold||(e._rippleHold=!1,e.classList.remove(ae),setTimeout(()=>{e.classList.remove(oe),R===e&&(R=null)},1e3))}function Se(a){if(v()===!1)return;let e=a||document;e.addEventListener("pointerdown",_e),e.addEventListener("pointerup",He),e.addEventListener("pointercancel",He),e.querySelectorAll("[data-md3-ripple]").forEach(i=>{i.addEventListener("mouseleave",Be)})}var Ie=(a,e)=>{let t;return(...i)=>{clearTimeout(t),t=setTimeout(()=>{a(...i)},e)}};var le=class{core;managers;emitter;eventsClickMobileHandler=()=>{};mutliEventsMoveHandler=()=>{};constructor(e,t,i){this.core=e,this.managers=t,this.emitter=i}init(){if(!this.core.isDestroyed&&!this.core.isInitialized){try{this.managers.config.updateInputValueWithCurrentTimeOnStart(),this.managers.validation.checkDisabledValuesOnStart()}catch{this.core.setIsDestroyed(!0);return}this.managers.theme.setTimepickerClassToElement(),this.managers.theme.setInputClassToInputElement(),this.managers.theme.setDataOpenToInputIfDoesntExistInWrapper(),this.managers.theme.setClassTopOpenElement(),this.managers.config.getDisableTime(),this.core.options.ui.inline?.enabled||this.managers.events.handleOpenOnClick(),this.managers.events.handleOpenOnEnterFocus(),this.setupCallbackBridge(),this.core.setIsInitialized(!0)}}setupCallbackBridge(){let{callbacks:e}=this.core.options;e.onOpen&&this.emitter.on("open",e.onOpen),e.onCancel&&this.emitter.on("cancel",e.onCancel),e.onConfirm&&this.emitter.on("confirm",e.onConfirm),e.onUpdate&&this.emitter.on("update",e.onUpdate),e.onSelectHour&&this.emitter.on("select:hour",e.onSelectHour),e.onSelectMinute&&this.emitter.on("select:minute",e.onSelectMinute),e.onSelectAM&&this.emitter.on("select:am",e.onSelectAM),e.onSelectPM&&this.emitter.on("select:pm",e.onSelectPM),e.onError&&this.emitter.on("error",e.onError)}mount(){this.core.isDestroyed||(this.core.isInitialized||this.init(),this.eventsBundle())}unmount(e){let t=Ie((...i)=>{if(i.length>2||!this.core.getModalElement())return;let[n]=i.filter(o=>typeof o=="boolean"),[r]=i.filter(o=>typeof o=="function");this.core.setIsMobileView(!!this.core.options.ui.mobile),n&&this.core.getOkButton()?.click(),this.core.setIsTouchMouseMove(!1),this.removeEventListeners(),this.managers.animation.removeAnimationToClose(),this.core.getOpenElement().forEach(o=>o?.classList.remove("disabled")),setTimeout(()=>{typeof document<"u"&&(document.body.style.overflowY="",document.body.style.paddingRight="")},k.SCROLLBAR_RESTORE),setTimeout(()=>{let o=this.core.getInput();this.core.options.behavior.focusInputAfterClose&&o?.focus();let u=this.core.getModalElement();u!==null&&(u.remove(),this.core.setIsModalRemove(!0))},k.MODAL_REMOVE),r&&r()},this.core.options.behavior.delayHandler||k.DEFAULT_DELAY);e?t(e):t()}destroy(e){if(this.core.isDestroyed)return;let t=typeof e=="function"?{callback:e}:e||{},{keepInputValue:i=!1,callback:n}=t,r=this.core.getInput(),s=i?r?.value:null;this.removeEventListeners(),this.core.getModalElement()?.remove(),this.core.getOpenElement()?.forEach(m=>{m&&(m.classList.remove("disabled","active","tp-ui-open-element"),m.classList.remove("basic","crane-straight","crane","m2","m3-green"))}),r&&(r.classList.remove("tp-ui-invalid-format","invalid-value","error","active","tp-ui-input"),r.removeAttribute("data-open"),r.removeAttribute("data-owner-id"),i&&s&&(r.value=s));let l=this.core.element;l&&(l.classList.remove("basic","crane-straight","crane","m2","m3-green"),l.classList.remove("error","active","disabled"),l.removeAttribute("data-owner-id"),l.removeAttribute("data-open"),this.core.options.ui.cssClass&&l.classList.remove(this.core.options.ui.cssClass)),l?.querySelectorAll(".tp-ui-invalid-text")?.forEach(m=>m.remove()),this.mutliEventsMoveHandler=()=>{},this.eventsClickMobileHandler=()=>{},this.core.reset(),this.managers.destroy(),this.emitter.clear(),A()||(document.body.style.overflowY="",document.body.style.paddingRight=""),n&&n()}eventsBundle(){if(this.core.isDestroyed||!this.core.isModalRemove)return;if(this.managers.validation.setErrorHandler(),this.managers.validation.removeErrorHandler(),!this.core.options.ui.inline?.enabled){let i=this.core.getOpenElement(),n=this.core.getInput();i.forEach(r=>r?.classList.add("disabled")),n?.blur()}if(this.managers.modal.setScrollbarOrNot(),this.managers.modal.setModalTemplate(),this.managers.modal.setNormalizeClass(),this.managers.modal.removeBackdrop(),this.core.isMobileView)this.managers.config.updateClockFaceAccessibility(!0);else{let i=this.core.getModalElement(),n=i?.querySelector(".tp-ui-mobile-clock-wrapper"),r=i?.querySelector(".tp-ui-wrapper"),s=i?.querySelectorAll("*");n?.classList.add("expanded"),r?.classList.add("expanded"),s?.forEach(o=>{!o.classList.contains("tp-ui-select-time")&&!o.classList.contains("tp-ui-mobile-clock-wrapper")&&!o.classList.contains("tp-ui-wrapper")&&o.classList.add("expanded")})}this.managers.modal.setFlexEndToFooterIfNoKeyboardIcon(),setTimeout(()=>{this.managers.theme.setTheme();let i=this.core.getWrapper();i&&this.core.options.ui.cssClass&&i.classList.add(this.core.options.ui.cssClass)},0),this.managers.animation.setAnimationToOpen(),this.managers.config.getInputValueOnOpenAndSet(),this.managers.clock.initializeClockSystem(),this.managers.clock.setOnStartCSSClassesIfClockType24h(),this.managers.clock.setClassActiveToHourOnOpen(),this.managers.events.handleCancelButton(),this.managers.events.handleOkButton(),this.managers.events.handleHourEvents(),this.managers.events.handleMinutesEvents(),this.managers.events.handleKeyboardInput(),this.core.options.ui.enableSwitchIcon&&this.managers.events.handleSwitchViewButton(),this.core.options.clock.type!=="24h"&&(this.managers.events.handleAmClick(),this.managers.events.handlePmClick()),this.core.options.behavior.focusTrap&&this.managers.events.focusTrapHandler(),this.core.options.ui.inline?.enabled||(this.managers.events.handleEscClick(),this.managers.events.handleBackdropClick());let e=this.core.getModalElement();e&&Se(e);let t=this.core.getClockFace();t&&typeof requestAnimationFrame<"u"&&requestAnimationFrame(()=>{requestAnimationFrame(()=>{t?.classList.add("scale-in")})}),this.managers.modal.setShowClassToBackdrop()}removeEventListeners(){if(v()===!1)return;Ae.split(" ").forEach(t=>{document.removeEventListener(t,this.mutliEventsMoveHandler,!1)}),document.removeEventListener("mousedown",this.eventsClickMobileHandler)}};var $=class{events=new Map;on(e,t){this.events.has(e)||this.events.set(e,new Set),this.events.get(e).add(t)}once(e,t){let i=n=>{t(n),this.off(e,i)};this.on(e,i)}off(e,t){t?this.events.get(e)?.delete(t):this.events.delete(e)}emit(e,t){this.events.get(e)?.forEach(i=>{i(t)})}clear(){this.events.clear()}hasListeners(e){return(this.events.get(e)?.size??0)>0}};var V={clock:{type:"12h",incrementHours:1,incrementMinutes:1,autoSwitchToMinutes:!1,disabledTime:void 0,currentTime:void 0},ui:{theme:"basic",animation:!0,backdrop:!0,mobile:!1,enableSwitchIcon:!1,editable:!1,enableScrollbar:!1,cssClass:void 0,appendModalSelector:"",iconTemplate:"",iconTemplateMobile:"",inline:void 0},labels:{am:"AM",pm:"PM",ok:"OK",cancel:"Cancel",time:"Select time",mobileTime:"Enter Time",mobileHour:"Hour",mobileMinute:"Minute"},behavior:{focusInputAfterClose:!1,focusTrap:!0,delayHandler:300,id:void 0},callbacks:{onOpen:void 0,onCancel:void 0,onConfirm:void 0,onUpdate:void 0,onSelectHour:void 0,onSelectMinute:void 0,onSelectAM:void 0,onSelectPM:void 0,onError:void 0}};function ge(a={}){return{clock:{...V.clock,...a.clock||{}},ui:{...V.ui,...a.ui||{}},labels:{...V.labels,...a.labels||{}},behavior:{...V.behavior,...a.behavior||{}},callbacks:{...V.callbacks,...a.callbacks||{}}}}var we=a=>a.replace(/[^0-9:APMapm\s]/g,"");var q=new Map,X=class{core;managers;lifecycle;emitter;constructor(e,t){if(A())throw new Error("TimepickerUI requires browser environment");let i=this.resolveInputElement(e);if(!i)throw new Error("Input element not found");let n=t?.behavior?.id,r=n||`tp-ui-${Te()}`,s=this.createWrapperElement(i),o=ge(t||{});if(o.ui.inline?.enabled&&typeof t?.behavior?.focusTrap>"u"&&(o.behavior.focusTrap=!1),o.ui.inline?.enabled){if(!o.ui.inline.containerId)throw new Error("inline.containerId is required when inline mode is enabled");if(!A()&&!document.getElementById(o.ui.inline.containerId))throw new Error(`Container element with id "${o.ui.inline.containerId}" not found`)}this.emitter=new $,this.core=new J(s,o,r,n);let u=this.core.getInput();if(u){let l=H(u,o.clock.type),d=Number(l.hour)*30,m=Number(l.minutes)*6;this.core.setDegreesHours(d),this.core.setDegreesMinutes(m)}this.managers=new se(this.core,this.emitter),this.lifecycle=new le(this.core,this.managers,this.emitter),this.managers.config.checkMobileOption(),this.managers.config.preventClockTypeByCurrentTime(),this.setupInternalEventListeners(),q.set(this.core.instanceId,this)}setupInternalEventListeners(){this.emitter.on("show",()=>{this.core.isDestroyed||this.lifecycle.mount()}),this.emitter.on("cancel",()=>{this.core.isDestroyed||this.lifecycle.unmount()}),this.emitter.on("confirm",e=>{if(!this.core.isDestroyed){let t=this.core.getInput();if(t&&e.hour&&e.minutes){let i=e.type?` ${e.type}`:"";t.value=`${e.hour}:${e.minutes}${i}`}this.lifecycle.unmount()}})}create(){this.lifecycle.init(),this.core.options.ui.inline?.enabled&&this.lifecycle.mount()}open(e){this.lifecycle.mount(),e&&e()}close(e,t){this.lifecycle.unmount(e?t:void 0),!e&&t&&t()}destroy(e){q.delete(this.core.instanceId),this.lifecycle.destroy(e)}update(e,t){this.core.isDestroyed||(this.core.updateOptions(e.options),this.managers.config.checkMobileOption(),e.create&&this.create(),t&&t())}getValue(){if(this.core.isDestroyed)return{hour:"",minutes:"",type:void 0,time:"",degreesHours:null,degreesMinutes:null};let e=this.core.getHour(),t=this.core.getMinutes(),i=this.core.getActiveTypeMode(),n=e?.value||"12",r=t?.value||"00",s=this.core.options.clock.type==="24h"?void 0:i?.textContent||"AM",o="";return this.core.options.clock.type==="24h"?o=`${n.padStart(2,"0")}:${r.padStart(2,"0")}`:o=`${n}:${r.padStart(2,"0")} ${s}`,{hour:n,minutes:r,type:s,time:o,degreesHours:this.core.degreesHours,degreesMinutes:this.core.degreesMinutes}}setValue(e,t=!0){if(this.core.isDestroyed||!e||typeof e!="string")return;this.core.isInitialized||this.create();let i=we(e.trim()),n="12",r="00",s="AM";try{if(this.core.options.clock.type==="24h"){let p=i.match(/^([0-1]?[0-9]|2[0-3]):([0-5][0-9])$/);if(!p)throw new Error("Invalid 24h format. Expected HH:MM");n=p[1].padStart(2,"0"),r=p[2]}else{let p=i.match(/^(1[0-2]|[1-9]):([0-5][0-9])\s*(AM|PM)$/i);if(!p)throw new Error("Invalid 12h format. Expected HH:MM AM/PM");n=p[1],r=p[2],s=p[3].toUpperCase()}let o=this.core.getHour(),u=this.core.getMinutes(),l=this.core.getAM(),d=this.core.getPM();if(o&&(o.value=n,o.setAttribute("aria-valuenow",n),this.core.setDegreesHours(Number(n)*30)),u&&(u.value=r,u.setAttribute("aria-valuenow",r),this.core.setDegreesMinutes(Number(r)*6)),this.core.options.clock.type!=="24h"&&l&&d&&(s==="AM"?(l.classList.add("active"),d.classList.remove("active")):(d.classList.add("active"),l.classList.remove("active"))),t){let p=this.core.getInput();p&&(p.value=i)}let m=this.core.getClockHand();m&&(m.style.transform=`rotateZ(${this.core.degreesHours||0}deg)`)}catch{return}}getElement(){return this.core.element}get instanceId(){return this.core.instanceId}get options(){return this.core.options}get isInitialized(){return this.core.isInitialized}get isDestroyed(){return this.core.isDestroyed}get hour(){return this.core.getHour()}get minutes(){return this.core.getMinutes()}get okButton(){return this.core.getOkButton()}get cancelButton(){return this.core.getCancelButton()}get clockHand(){return this.core.getClockHand()}on(e,t){this.core.isDestroyed||this.emitter.on(e,t)}once(e,t){this.core.isDestroyed||this.emitter.once(e,t)}off(e,t){this.core.isDestroyed||this.emitter.off(e,t)}resolveInputElement(e){if(v()===!1)return null;let t=null;if(typeof e=="string"){if(t=document.querySelector(e),!t)return null}else if(e instanceof HTMLElement)t=e;else return null;return t.tagName==="INPUT"?t:t.querySelector("input")}createWrapperElement(e){if(v()===!1)return e;let t=e.parentElement;if(e.tagName==="INPUT"&&!t?.classList.contains("tp-ui")){let i=document.createElement("div");return i.className="tp-ui",e.parentNode?.insertBefore(i,e),i.appendChild(e),i}return t&&!t.classList.contains("tp-ui")&&t.classList.add("tp-ui"),t||e}static getById(e){return q.get(e)}static getAllInstances(){return Array.from(q.values())}static isAvailable(e){return A()?!1:typeof e=="string"?document.querySelector(e)!==null:e instanceof HTMLElement?document.contains(e):!1}static destroyAll(){Array.from(q.values()).forEach(t=>t.destroy()),q.clear()}};var ce=X;var We=ce;0&&(module.exports={EventEmitter,TimepickerUI});
|