@optionfactory/ful 0.17.0 → 0.19.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,2 +1,2 @@
1
- var ful=function(e){"use strict";function t(e,t,r,s,i){const o=e[t.dataset.bindMutator]||e[t.dataset.bindProvide];o?o(t,r,s,i):"radio"!==t.getAttribute("type")?"checkbox"!==t.getAttribute("type")?t.value=r:t.checked=r:t.checked=t.getAttribute("value")===r}class r{static encode(e,t){const s=t||r.URL_SAFE,i=e.byteLength,o=new Uint8Array(e);let n="";for(let e=0;e<i;e+=3){n+=s[o[e]>>2]+s[(3&o[e])<<4|o[e+1]>>4]+s[(15&o[e+1])<<2|o[e+2]>>6]+s[63&o[e+2]]}return i%3==2?n=n.substring(0,n.length-1):i%3==1&&(n=n.substring(0,n.length-2)),n}static decode(e,t){const s=t||r.URL_SAFE;let i=Math.floor(.75*e.length);for(let t=0;t!==e.length&&"="===e[e.length-t-1];++t)--i;const o=new Uint8Array(i);let n=0,a=0;for(;n<.75*e.length;){const t=s.indexOf(e.charAt(a++)),r=s.indexOf(e.charAt(a++)),i=s.indexOf(e.charAt(a++)),c=s.indexOf(e.charAt(a++));o[n++]=t<<2|r>>4,o[n++]=(15&r)<<4|i>>2,o[n++]=(3&i)<<6|c}return o.buffer}}r.STANDARD="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",r.URL_SAFE="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_";class s{constructor(e,t,{globalErrorsEl:r,fieldContainerSelector:i,errorClass:o,hideClass:n}){this.el=e,this.bindings=t,this.globalErrorsEl=r,this.fieldContainerSelector=void 0!==i?i:s.DEFAULT_FIELD_CONTAINER_SELECTOR,this.errorClass=o||s.DEFAULT_ERROR_CLASS,this.hideClass=n||s.DEFAULT_HIDE_CLASS}setValues(e){return this.bindings.setValues(this.el,e)}getValues(){return this.bindings.getValues(this.el)}setErrors(e,t,r){if(this.clearErrors(),e.map(this.mapError?this.mapError:e=>e).filter((e=>"FIELD_ERROR"===e.type||"INVALID_FORMAT"===e.type)).forEach((e=>{const t=e.context.replace("[",".").replace("].",".");Array.from(this.el.querySelectorAll(`[name='${CSS.escape(t)}']`)).map((e=>this.fieldContainerSelector?e.closest(this.fieldContainerSelector):e)).filter((e=>null!==e)).forEach((t=>{t.classList.add(this.errorClass),t.dataset.error=e.reason}))})),this.globalErrorsEl){const t=e.filter((e=>"FIELD_ERROR"!==e.type&&"INVALID_FORMAT"!==e.type));this.globalErrorsEl.innerHTML=t.map((e=>e.reason)).join("\n"),0!==t.length&&this.globalErrorsEl.classList.remove(this.hideClass)}if(!t)return;const s=Array.from(this.el.querySelectorAll(".${CSS.escape(this.errorClass)}")).map((e=>e.getBoundingClientRect().y+window.scrollY)),i=Math.min(...s);i!==1/0&&window.scroll(window.scrollX,i>100?i-100:0)}clearErrors(){this.el.querySelectorAll(`.${CSS.escape(this.errorClass)}`).forEach((e=>e.classList.remove(this.errorClass))),this.globalErrorsEl&&(this.globalErrorsEl.innerHTML="",this.globalErrorsEl.classList.add(this.hideClass))}}s.DEFAULT_FIELD_CONTAINER_SELECTOR="label",s.DEFAULT_ERROR_CLASS="has-error",s.DEFAULT_HIDE_CLASS="d-none";class i{constructor(){const e=document.querySelector("meta[name='context']").getAttribute("content");this.context=e.endsWith("/")?e.substring(0,e.length-1):e}before(e){const t=e.resource.startsWith("/")?"":"/";e.resource=this.context+t+e.resource}}class o{constructor(){this.k=document.querySelector("meta[name='_csrf_header']").getAttribute("content"),this.v=document.querySelector("meta[name='_csrf']").getAttribute("content")}before(e){const t=new Headers(e.options.headers);t.set(this.k,this.v),e.options.headers=t}}class n{constructor(e){this.redirectUri=e}after(e,t){401===t.status&&(window.location.href=redirectUri)}}class a extends Error{static parseProblems(e,t){const r=[{type:"GENERIC_PROBLEM",context:null,reason:`${e}: ${t}`,details:null}];try{return t?JSON.parse(t):r}catch(e){return r}}static fromResponse(e,t){return new a(e,a.parseProblems(e,t))}constructor(e,t){super(JSON.stringify(t)),this.name=`Failure:${e}`,this.status=e,this.problems=t}}class c{constructor(){this.interceptors=[]}withContext(){return this.interceptors.push(new i),this}withCsrfToken(){return this.interceptors.push(new o),this}withRedirectOnUnauthorized(e){return this.interceptors.push(new n(e)),this}withInterceptors(...e){return this.interceptors.push(...e),this}build(){const e=this.interceptors;return new l({interceptors:e})}}class l{static builder(){return new c}constructor({interceptors:e}){this.interceptors=e||[]}async fetch(e,t){const r=this.interceptors.concat(t.interceptors||[]),s={resource:e,options:t};await r.forEach((async e=>{e.before&&await e.before(s)}));const i=await fetch(s.resource,s.options);return await r.forEach((async e=>{e.after&&await e.after(s,i)})),i}async json(e,t){try{const r=await this.fetch(e,t);if(!r.ok){const e=await r.text();throw a.fromResponse(r.status,e)}const s=await r.text();return s?JSON.parse(s):void 0}catch(e){if(e instanceof a)throw e;throw new a(0,[{type:"CONNECTION_PROBLEM",context:null,reason:e.message,details:null}])}}async form(e,t,r){const s=r||{};s.buttons?.forEach((e=>{e.setAttribute("disabled","disabled"),s.loader&&(e.dataset.oldContent=e.innerHTML,e.innerHTML=s.loader)}));try{const r=await this.json(e,t);return s.form?.clearErrors(),r}catch(e){throw s.form?.setErrors(e.problems),e}finally{s.buttons?.forEach((e=>{e.removeAttribute("disabled"),e.innerHTML=e.dataset.oldContent,delete e.dataset.oldContent}))}}}class h{constructor(e,t){this.prefix=e,this.storage=t}save(e,t){this.storage.setItem(`${this.prefix}-${e}`,JSON.stringify(t))}load(e){const t=this.storage.getItem(`${this.prefix}-${e}`);return void 0===t?void 0:JSON.parse(t)}remove(e){this.storage.removeItem(`${this.prefix}-${e}`)}pop(e){const t=this.load(e);return this.remove(e),t}}class u extends h{constructor(e){super(e,sessionStorage)}}class d{static forKeycloak(e,t,r){const s=new URL("protocol/openid-connect/auth",t),i=new URL("protocol/openid-connect/token",t),o=new URL("protocol/openid-connect/logout",t);return new d(e,"openid profile",s,i,o,r)}constructor(e,t,r,s,i,o){this.clientId=e,this.scope=t,this.authUri=r,this.tokenUri=s,this.logoutUri=i,this.redirectUri=o,this.storage=new u(e)}async _auth(){const e=r.encode(crypto.getRandomValues(new Uint8Array(32)).buffer),t=r.encode(await crypto.subtle.digest("SHA-256",(new TextEncoder).encode(e))),s=this.clientId+r.encode(crypto.getRandomValues(new Uint8Array(16)).buffer);this.storage.save(d.PKCE_AND_STATE_KEY,{state:s,verifier:e});const i=new URL(this.authUri);i.searchParams.set("client_id",this.clientId),i.searchParams.set("redirect_uri",this.redirectUri),i.searchParams.set("response_type","code"),i.searchParams.set("scope",this.scope),i.searchParams.set("state",s),i.searchParams.set("code_challenge",t),i.searchParams.set("code_challenge_method","S256"),window.location=i}async _tokenExchange(e,t){window.history.replaceState("","",this.redirectUri);const r=this.storage.pop(d.PKCE_AND_STATE_KEY);if(r.state!==t)throw new Error("State mismatch");const s=await fetch(this.tokenUri,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams([["client_id",this.clientId],["code",e],["grant_type","authorization_code"],["code_verifier",r.verifier],["state",r.state],["redirect_uri",this.redirectUri]])});if(!s.ok){const e=await s.text();throw new Error("Error:"+s.status+": "+e)}const i=await s.json();return new f(this.clientId,i,this.tokenUri,this.logoutUri,this.redirectUri)}async ensureLoggedIn(){const e=new URL(window.location.href),t=e.searchParams.get("code");if(t){const r=e.searchParams.get("state");return await this._tokenExchange(t,r)}return await this._auth(),null}}d.PKCE_AND_STATE_KEY="state-and-verifier";class f{static parseToken(e){const[t,r,s]=e.split(".");return{header:JSON.parse(atob(t)),payload:JSON.parse(atob(r)),signature:s}}constructor(e,t,r,s,i){this.clientId=e,this.token=t,this.tokenUri=r,this.logoutUri=s,this.redirectUri=i,this.accessToken=f.parseToken(t.access_token),this.refreshToken=f.parseToken(t.refresh_token),this.refreshCallback=null}onRefresh(e){this.refreshCallback=e}async refresh(){const e=await fetch(this.tokenUri,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams([["client_id",this.clientId],["grant_type","refresh_token"],["refresh_token",this.token.refresh_token]])});if(!e.ok)throw new Error("Error:"+e.code+": "+e.text());const t=await e.json();this.token=t,this.accessToken=this._parseToken(t.access_token),this.refreshToken=this._parseToken(t.refresh_token),this.refreshCallback&&this.refreshCallback(this.token,this.accessToken,this.refreshToken)}shouldBeRefreshed(e){const t=(new Date).getTime(),r=1e3*this.refreshToken.payload.exp;return!(t>r)&&t-e>r}async refreshIf(e){this.shouldBeRefreshed(e)&&await this.refresh()}logout(){const e=new URL(this.logoutUri);e.searchParams.set("post_logout_redirect_uri",this.redirectUri),e.searchParams.set("id_token_hint",this.token.id_token),window.location=e}bearerToken(){return`Bearer ${this.token.access_token}`}interceptor(e,t){return new p(this,e,t)}}class p{constructor(e,t,r){this.session=e,this.gracePeriodBefore=t||2e3,this.gracePeriodAfter=r||3e4}async before(e){await this.session.refreshIf(this.gracePeriodBefore);return new Headers(e.options.headers).set("Authorization",this.session.bearerToken()),e}async after(e,t){return await this.session.refreshIf(this.gracePeriodAfter),t}}const E={sleep:e=>new Promise((t=>setTimeout(t,e))),DEBOUNCE_DEFAULT:0,DEBOUNCE_IMMEDIATE:1,debounce(e,t,r){let s=null,i=[],o=0,n=r||E.DEBOUNCE_DEFAULT;const a=()=>{const r=(new Date).getTime()-o;e>r?s=setTimeout(a,e-r):(s=null,n!==E.DEBOUNCE_IMMEDIATE&&t(...i),null===s&&(i=[]))};return function(){i=arguments,o=(new Date).getTime(),null===s&&(s=setTimeout(a,e),n===E.DEBOUNCE_IMMEDIATE&&t(...i))}},THROTTLE_DEFAULT:0,THROTTLE_NO_LEADING:1,THROTTLE_NO_TRAILING:2,throttle(e,t,r){let s=null,i=[],o=0,n=r||E.THROTTLE_DEFAULT;const a=()=>{o=n&E.THROTTLE_NO_LEADING?0:(new Date).getTime(),s=null,t(...i),null===s&&(i=[])};return function(){const r=(new Date).getTime();!o&&n&E.THROTTLE_NO_LEADING&&(o=r);const c=e-(r-o);i=arguments,c<=0||c>e?(null!==s&&(clearTimeout(s),s=null),o=r,t(...i),null===s&&(i=[])):null!==s||n&E.THROTTLE_NO_TRAILING||(s=setTimeout(a,c))}}};return e.App=class{constructor(){this.configurers=[],this.initializers=[],this.handlers=[],this.running=!1,document.addEventListener("DOMContentLoaded",(async()=>{await Promise.all(this.configurers),await Promise.all(this.initializers.map((e=>Promise.resolve(e())))),await Promise.all(this.handlers.map((e=>Promise.resolve(e()))))}))}configure(e){return this.configurers.push(Promise.resolve(e())),this}initialize(e){return this.initializers.push(e),this}ready(e){return this.handlers.push(e),this}},e.AuthorizationCodeFlow=d,e.AuthorizationCodeFlowInterceptor=p,e.AuthorizationCodeFlowSession=f,e.Base64=r,e.Bindings=class{constructor({extractors:e,mutators:t,ignoredChildrenSelector:r,valueHoldersSelector:s}){this.extractors=e||{},this.mutators=t||{},this.valueHoldersSelector=s||"input[name], select[name], textarea[name]",this.ignoredChildrenSelector=r||".d-none"}setValues(e,r){for(let s in r)r.hasOwnProperty(s)&&Array.from(e.querySelectorAll(`[name='${CSS.escape(s)}']`)).forEach((e=>{t(this.mutators,e,r[s],s,r)}))}getValues(e){return Array.from(e.querySelectorAll(this.valueHoldersSelector)).filter((e=>"never"!==e.dataset.bindInclude&&("always"===e.dataset.bindInclude||null===e.closest(this.ignoredChildrenSelector)))).reduce(((e,t)=>function(e,t,r){const s=t.split(".").map((e=>e.match(/^[0-9]+$/)?+e:e));let i=e,o=null;for(let t=0;;++t){const n=s[t],a=s[t-1];if(Number.isInteger(n)&&!Array.isArray(i)&&(null!==o?o[a]=i=[]:e=i=[]),t===s.length-1)return i[n]=void 0!==r?r:n in i?i[n]:null,e;void 0===i[n]&&(i[n]={}),o=i,i=i[n]}}(e,t.getAttribute("name"),function(e,t){const r=e[t.dataset.bindExtractor]||e[t.dataset.bindProvide];if(r)return r(t);if("radio"===t.getAttribute("type")){if(!t.checked)return;return"boolean"===t.dataset.bindType?"true"===t.value:t.value}return"checkbox"===t.getAttribute("type")?t.checked:"boolean"===t.dataset.bindType?t.value?"true"===t.value:null:t.value||null}(this.extractors,t))),{})}},e.Failure=a,e.Form=s,e.Hex=class{static decode(e){if(e.length%2!=0)throw new Error("invalid length");const t=e.length/2;return new Uint8Array(t).map(((t,r)=>{const s=2*r,i=e.substring(s,s+2);return parseInt(i,16)}))}static encode(e,t){return Array.from(e).map((e=>e.toString(16))).map((e=>t?e.toUpperCase():e)).map((e=>e.padStart(2,0))).join("")}},e.HttpClient=l,e.LocalStorage=class extends h{constructor(e){super(e,localStorage)}},e.SessionStorage=u,e.VersionedStorage=class{constructor(e,t,r){this.storage=e,this.key=t,this.dataSupplier=r,this.cache=null}async load(e){const t=this.storage.load(this.key);if(t&&t.revision===e)return void(this.cache=t.value);const r=await this.dataSupplier(e,this.key);this.storage.save(this.key,{revision:e,value:r}),this.cache=r}data(){return this.cache}},e.Wizard=class{constructor(e){if(this.el=e,this.progress=[...e.children].filter((e=>e.matches("header,ol,ul"))),this.progress.forEach((e=>{const t=[...e.children];void 0===t.filter((e=>e.matches(".active")))[0]&&t.length>0&&t[0].classList.add("active")})),null===this.el.querySelector("section.current")){const e=this.el.querySelector("section:first-of-type");null!==e&&e.classList.add("current")}}next(){this.progress.forEach((e=>{const t=[...e.children].filter((e=>e.matches(".active")))[0];t?.classList.remove("active"),t?.nextElementSibling?.classList.add("active")}));const e=this.el.querySelector("section.current");e.classList.remove("current"),e.nextElementSibling.classList.add("current"),this.el.dispatchEvent(new CustomEvent("wizard:activate",{bubbles:!0,cancelable:!0}))}prev(){this.progress.forEach((e=>{const t=[...e.children].filter((e=>e.matches(".active")))[0];t?.classList.remove("active"),t?.previousElementSibling?.classList.add("active")}));const e=this.el.querySelector("section.current");e.classList.remove("current"),e.previousElementSibling.classList.add("current"),this.el.dispatchEvent(new CustomEvent("wizard:activate",{bubbles:!0,cancelable:!0}))}moveTo=function(e){this.progress.forEach((t=>{[...t.children].filter((e=>e.matches(".active")))[0]?.classList.remove("active"),t.children[+e]?.classList.add("active")}));this.el.querySelector("section.current")?.classList.remove("current");this.el.querySelector(`section:nth-child(${+e})`).classList.add("current"),this.el.dispatchEvent(new CustomEvent("wizard:activate",{bubbles:!0,cancelable:!0}))}},e.timing=E,Object.defineProperty(e,"__esModule",{value:!0}),e}({});
1
+ var ful=function(e){"use strict";function t(e,t,r,s,i){const n=e[t.dataset.bindMutator]||e[t.dataset.bindProvide];n?n(t,r,s,i):"radio"!==t.getAttribute("type")?"checkbox"!==t.getAttribute("type")?t.value=r:t.checked=r:t.checked=t.getAttribute("value")===r}class r{static encode(e,t){const s=t||r.URL_SAFE,i=e.byteLength,n=new Uint8Array(e);let o="";for(let e=0;e<i;e+=3){o+=s[n[e]>>2]+s[(3&n[e])<<4|n[e+1]>>4]+s[(15&n[e+1])<<2|n[e+2]>>6]+s[63&n[e+2]]}return i%3==2?o=o.substring(0,o.length-1):i%3==1&&(o=o.substring(0,o.length-2)),o}static decode(e,t){const s=t||r.URL_SAFE;let i=Math.floor(.75*e.length);for(let t=0;t!==e.length&&"="===e[e.length-t-1];++t)--i;const n=new Uint8Array(i);let o=0,a=0;for(;o<.75*e.length;){const t=s.indexOf(e.charAt(a++)),r=s.indexOf(e.charAt(a++)),i=s.indexOf(e.charAt(a++)),c=s.indexOf(e.charAt(a++));n[o++]=t<<2|r>>4,n[o++]=(15&r)<<4|i>>2,n[o++]=(3&i)<<6|c}return n.buffer}}r.STANDARD="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",r.URL_SAFE="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_";class s{constructor(e,t,{globalErrorsEl:r,fieldContainerSelector:i,errorClass:n,hideClass:o}){this.el=e,this.bindings=t,this.globalErrorsEl=r,this.fieldContainerSelector=void 0!==i?i:s.DEFAULT_FIELD_CONTAINER_SELECTOR,this.errorClass=n||s.DEFAULT_ERROR_CLASS,this.hideClass=o||s.DEFAULT_HIDE_CLASS}setValues(e){return this.bindings.setValues(this.el,e)}getValues(){return this.bindings.getValues(this.el)}setErrors(e,t,r){if(this.clearErrors(),e.map(this.mapError?this.mapError:e=>e).filter((e=>"FIELD_ERROR"===e.type||"INVALID_FORMAT"===e.type)).forEach((e=>{const t=e.context.replace("[",".").replace("].",".");Array.from(this.el.querySelectorAll(`[name='${CSS.escape(t)}']`)).map((e=>this.fieldContainerSelector?e.closest(this.fieldContainerSelector):e)).filter((e=>null!==e)).forEach((t=>{t.classList.add(this.errorClass),t.dataset.error=e.reason}))})),this.globalErrorsEl){const t=e.filter((e=>"FIELD_ERROR"!==e.type&&"INVALID_FORMAT"!==e.type));this.globalErrorsEl.innerHTML=t.map((e=>e.reason)).join("\n"),0!==t.length&&this.globalErrorsEl.classList.remove(this.hideClass)}if(!t)return;const s=Array.from(this.el.querySelectorAll(".${CSS.escape(this.errorClass)}")).map((e=>e.getBoundingClientRect().y+window.scrollY)),i=Math.min(...s);i!==1/0&&window.scroll(window.scrollX,i>100?i-100:0)}clearErrors(){this.el.querySelectorAll(`.${CSS.escape(this.errorClass)}`).forEach((e=>e.classList.remove(this.errorClass))),this.globalErrorsEl&&(this.globalErrorsEl.innerHTML="",this.globalErrorsEl.classList.add(this.hideClass))}}s.DEFAULT_FIELD_CONTAINER_SELECTOR="label",s.DEFAULT_ERROR_CLASS="has-error",s.DEFAULT_HIDE_CLASS="d-none";class i{constructor(){const e=document.querySelector("meta[name='context']").getAttribute("content");this.context=e.endsWith("/")?e.substring(0,e.length-1):e}async intercept(e,t){const r=e.resource.startsWith("/")?"":"/";return e.resource=this.context+r+e.resource,await t.proceed(e)}}class n{constructor(){this.k=document.querySelector("meta[name='_csrf_header']").getAttribute("content"),this.v=document.querySelector("meta[name='_csrf']").getAttribute("content")}async intercept(e,t){const r=new Headers(e.options.headers);return r.set(this.k,this.v),e.options.headers=r,await t.proceed(e)}}class o{constructor(e){this.redirectUri=e}async intercept(e,t){const r=await t.proceed(e);if(401!==r.status)return r;window.location.href=redirectUri}}class a extends Error{static parseProblems(e,t){const r=[{type:"GENERIC_PROBLEM",context:null,reason:`${e}: ${t}`,details:null}];try{return t?JSON.parse(t):r}catch(e){return r}}static fromResponse(e,t){return new a(e,a.parseProblems(e,t))}constructor(e,t){super(JSON.stringify(t)),this.name=`Failure:${e}`,this.status=e,this.problems=t}}class c{constructor(){this.interceptors=[]}withContext(){return this.interceptors.push(new i),this}withCsrfToken(){return this.interceptors.push(new n),this}withRedirectOnUnauthorized(e){return this.interceptors.push(new o(e)),this}withInterceptors(...e){return this.interceptors.push(...e),this}build(){const e=this.interceptors;return new u({interceptors:e})}}class l{async intercept(e,t){return await fetch(e.resource,e.options)}}class h{constructor(e,t){this.interceptors=e,this.current=t}async proceed(e){const t=this.interceptors[this.current];return await t.intercept(e,new h(this.interceptors,this.current+1))}}class u{static builder(){return new c}constructor({interceptors:e}){this.interceptors=e||[]}async fetch(e,t){const r=[...this.interceptors,...t.interceptors||[],new l],s=new h(r,0);return await s.proceed({resource:e,options:t})}async json(e,t){try{const r=await this.fetch(e,t);if(!r.ok){const e=await r.text();throw a.fromResponse(r.status,e)}const s=await r.text();return s?JSON.parse(s):void 0}catch(e){if(e instanceof a)throw e;throw new a(0,[{type:"CONNECTION_PROBLEM",context:null,reason:e.message,details:null}])}}async form(e,t,r){const s=r||{};s.buttons?.forEach((e=>{e.setAttribute("disabled","disabled"),s.loader&&(e.dataset.oldContent=e.innerHTML,e.innerHTML=s.loader)}));try{const r=await this.json(e,t);return s.form?.clearErrors(),r}catch(e){throw s.form?.setErrors(e.problems),e}finally{s.buttons?.forEach((e=>{e.removeAttribute("disabled"),e.innerHTML=e.dataset.oldContent,delete e.dataset.oldContent}))}}}class d{constructor(e,t){this.prefix=e,this.storage=t}save(e,t){this.storage.setItem(`${this.prefix}-${e}`,JSON.stringify(t))}load(e){const t=this.storage.getItem(`${this.prefix}-${e}`);return void 0===t?void 0:JSON.parse(t)}remove(e){this.storage.removeItem(`${this.prefix}-${e}`)}pop(e){const t=this.load(e);return this.remove(e),t}}class p extends d{constructor(e){super(e,sessionStorage)}}class f{static forKeycloak(e,t,r){return new f(e,"openid profile",{auth:new URL("protocol/openid-connect/auth",t),token:new URL("protocol/openid-connect/token",t),logout:new URL("protocol/openid-connect/logout",t),registration:new URL("protocol/openid-connect/registrations",t),redirect:r})}constructor(e,t,{auth:r,token:s,registration:i,logout:n,redirect:o}){this.storage=new p(e),this.clientId=e,this.scope=t,this.uri={auth:r,token:s,registration:i,logout:n,redirect:o}}async action(e,t){const s=r.encode(crypto.getRandomValues(new Uint8Array(32)).buffer),i=r.encode(await crypto.subtle.digest("SHA-256",(new TextEncoder).encode(s))),n=this.clientId+r.encode(crypto.getRandomValues(new Uint8Array(16)).buffer);this.storage.save(f.PKCE_AND_STATE_KEY,{state:n,verifier:s});const o=new URL(e);o.searchParams.set("client_id",this.clientId),o.searchParams.set("redirect_uri",this.uri.redirect),o.searchParams.set("response_type","code"),o.searchParams.set("scope",this.scope),o.searchParams.set("state",n),o.searchParams.set("code_challenge",i),o.searchParams.set("code_challenge_method","S256"),Object.entries(t||{}).forEach((e=>{o.searchParams.set(e[0],e[1])})),window.location=o}async registration(e){await this.action(this.uri.registration,e)}async applicationInitiatedAction(e){await this.action(this.uri.auth,{kc_action:e})}async _tokenExchange(e,t){window.history.replaceState("","",this.uri.redirect);const r=this.storage.pop(f.PKCE_AND_STATE_KEY);if(r.state!==t)throw new Error("State mismatch");const s=await fetch(this.uri.token,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams([["client_id",this.clientId],["code",e],["grant_type","authorization_code"],["code_verifier",r.verifier],["state",r.state],["redirect_uri",this.uri.redirect]])});if(!s.ok){const e=await s.text();throw new Error("Error:"+s.status+": "+e)}const i=await s.json();return new E(this.clientId,i,this.uri)}async ensureLoggedIn(){const e=new URL(window.location.href),t=e.searchParams.get("code");if(t&&this.storage.load(f.PKCE_AND_STATE_KEY)){const r=e.searchParams.get("state");return await this._tokenExchange(t,r)}return await this.action(this.uri.auth,{}),null}}f.PKCE_AND_STATE_KEY="state-and-verifier";class E{static parseToken(e){const[t,s,i]=e.split("."),n=new TextDecoder("utf-8");return{header:JSON.parse(n.decode(r.decode(t,r.STANDARD))),payload:JSON.parse(n.decode(r.decode(s,r.STANDARD))),signature:i}}constructor(e,t,{token:r,logout:s,redirect:i}){this.clientId=e,this.token=t,this.accessToken=E.parseToken(t.access_token),this.refreshToken=E.parseToken(t.refresh_token),this.uri={token:r,logout:s,redirect:i},this.refreshCallback=null}onRefresh(e){this.refreshCallback=e}async refresh(){const e=await fetch(this.uri.token,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams([["client_id",this.clientId],["grant_type","refresh_token"],["refresh_token",this.token.refresh_token]])});if(!e.ok)throw new Error("Error:"+e.code+": "+e.text());const t=await e.json();this.token=t,this.accessToken=this._parseToken(t.access_token),this.refreshToken=this._parseToken(t.refresh_token),this.refreshCallback&&this.refreshCallback(this.token,this.accessToken,this.refreshToken)}shouldBeRefreshed(e){const t=(new Date).getTime(),r=1e3*this.refreshToken.payload.exp;return!(t>r)&&t-e>r}async refreshIf(e){this.shouldBeRefreshed(e)&&await this.refresh()}logout(){const e=new URL(this.uri.logout);e.searchParams.set("post_logout_redirect_uri",this.uri.redirect),e.searchParams.set("id_token_hint",this.token.id_token),window.location=e}bearerToken(){return`Bearer ${this.token.access_token}`}interceptor(e,t){return new g(this,e,t)}}class g{constructor(e,t,r){this.session=e,this.gracePeriodBefore=t||2e3,this.gracePeriodAfter=r||3e4}async intercept(e,t){await this.session.refreshIf(this.gracePeriodBefore);const r=new Headers(e.options.headers);r.set("Authorization",this.session.bearerToken()),e.options.headers=r;const s=await t.proceed(e);return await this.session.refreshIf(this.gracePeriodAfter),s}}const m={sleep:e=>new Promise((t=>setTimeout(t,e))),DEBOUNCE_DEFAULT:0,DEBOUNCE_IMMEDIATE:1,debounce(e,t,r){let s=null,i=[],n=0,o=r||m.DEBOUNCE_DEFAULT;const a=()=>{const r=(new Date).getTime()-n;e>r?s=setTimeout(a,e-r):(s=null,o!==m.DEBOUNCE_IMMEDIATE&&t(...i),null===s&&(i=[]))};return function(){i=arguments,n=(new Date).getTime(),null===s&&(s=setTimeout(a,e),o===m.DEBOUNCE_IMMEDIATE&&t(...i))}},THROTTLE_DEFAULT:0,THROTTLE_NO_LEADING:1,THROTTLE_NO_TRAILING:2,throttle(e,t,r){let s=null,i=[],n=0,o=r||m.THROTTLE_DEFAULT;const a=()=>{n=o&m.THROTTLE_NO_LEADING?0:(new Date).getTime(),s=null,t(...i),null===s&&(i=[])};return function(){const r=(new Date).getTime();!n&&o&m.THROTTLE_NO_LEADING&&(n=r);const c=e-(r-n);i=arguments,c<=0||c>e?(null!==s&&(clearTimeout(s),s=null),n=r,t(...i),null===s&&(i=[])):null!==s||o&m.THROTTLE_NO_TRAILING||(s=setTimeout(a,c))}}};return e.App=class{constructor(){this.configurers=[],this.initializers=[],this.handlers=[],this.running=!1,document.addEventListener("DOMContentLoaded",(async()=>{await Promise.all(this.configurers),await Promise.all(this.initializers.map((e=>Promise.resolve(e())))),await Promise.all(this.handlers.map((e=>Promise.resolve(e()))))}))}configure(e){return this.configurers.push(Promise.resolve(e())),this}initialize(e){return this.initializers.push(e),this}ready(e){return this.handlers.push(e),this}},e.AuthorizationCodeFlow=f,e.AuthorizationCodeFlowInterceptor=g,e.AuthorizationCodeFlowSession=E,e.Base64=r,e.Bindings=class{constructor({extractors:e,mutators:t,ignoredChildrenSelector:r,valueHoldersSelector:s}){this.extractors=e||{},this.mutators=t||{},this.valueHoldersSelector=s||"input[name], select[name], textarea[name]",this.ignoredChildrenSelector=r||".d-none"}setValues(e,r){for(let s in r)r.hasOwnProperty(s)&&Array.from(e.querySelectorAll(`[name='${CSS.escape(s)}']`)).forEach((e=>{t(this.mutators,e,r[s],s,r)}))}getValues(e){return Array.from(e.querySelectorAll(this.valueHoldersSelector)).filter((e=>"never"!==e.dataset.bindInclude&&("always"===e.dataset.bindInclude||null===e.closest(this.ignoredChildrenSelector)))).reduce(((e,t)=>function(e,t,r){const s=t.split(".").map((e=>e.match(/^[0-9]+$/)?+e:e));let i=e,n=null;for(let t=0;;++t){const o=s[t],a=s[t-1];if(Number.isInteger(o)&&!Array.isArray(i)&&(null!==n?n[a]=i=[]:e=i=[]),t===s.length-1)return i[o]=void 0!==r?r:o in i?i[o]:null,e;void 0===i[o]&&(i[o]={}),n=i,i=i[o]}}(e,t.getAttribute("name"),function(e,t){const r=e[t.dataset.bindExtractor]||e[t.dataset.bindProvide];if(r)return r(t);if("radio"===t.getAttribute("type")){if(!t.checked)return;return"boolean"===t.dataset.bindType?"true"===t.value:t.value}return"checkbox"===t.getAttribute("type")?t.checked:"boolean"===t.dataset.bindType?t.value?"true"===t.value:null:t.value||null}(this.extractors,t))),{})}},e.Failure=a,e.Form=s,e.Hex=class{static decode(e){if(e.length%2!=0)throw new Error("invalid length");const t=e.length/2;return new Uint8Array(t).map(((t,r)=>{const s=2*r,i=e.substring(s,s+2);return parseInt(i,16)}))}static encode(e,t){return Array.from(e).map((e=>e.toString(16))).map((e=>t?e.toUpperCase():e)).map((e=>e.padStart(2,0))).join("")}},e.HttpClient=u,e.LocalStorage=class extends d{constructor(e){super(e,localStorage)}},e.SessionStorage=p,e.VersionedStorage=class{constructor(e,t,r){this.storage=e,this.key=t,this.dataSupplier=r,this.cache=null}async load(e){const t=this.storage.load(this.key);if(t&&t.revision===e)return void(this.cache=t.value);const r=await this.dataSupplier(e,this.key);this.storage.save(this.key,{revision:e,value:r}),this.cache=r}data(){return this.cache}},e.Wizard=class{constructor(e){if(this.el=e,this.progress=[...e.children].filter((e=>e.matches("header,ol,ul"))),this.progress.forEach((e=>{const t=[...e.children];void 0===t.filter((e=>e.matches(".active")))[0]&&t.length>0&&t[0].classList.add("active")})),null===this.el.querySelector("section.current")){const e=this.el.querySelector("section:first-of-type");null!==e&&e.classList.add("current")}}next(){this.progress.forEach((e=>{const t=[...e.children].filter((e=>e.matches(".active")))[0];t?.classList.remove("active"),t?.nextElementSibling?.classList.add("active")}));const e=this.el.querySelector("section.current");e.classList.remove("current"),e.nextElementSibling.classList.add("current"),this.el.dispatchEvent(new CustomEvent("wizard:activate",{bubbles:!0,cancelable:!0}))}prev(){this.progress.forEach((e=>{const t=[...e.children].filter((e=>e.matches(".active")))[0];t?.classList.remove("active"),t?.previousElementSibling?.classList.add("active")}));const e=this.el.querySelector("section.current");e.classList.remove("current"),e.previousElementSibling.classList.add("current"),this.el.dispatchEvent(new CustomEvent("wizard:activate",{bubbles:!0,cancelable:!0}))}moveTo=function(e){this.progress.forEach((t=>{[...t.children].filter((e=>e.matches(".active")))[0]?.classList.remove("active"),t.children[+e]?.classList.add("active")}));this.el.querySelector("section.current")?.classList.remove("current");this.el.querySelector(`section:nth-child(${+e})`).classList.add("current"),this.el.dispatchEvent(new CustomEvent("wizard:activate",{bubbles:!0,cancelable:!0}))}},e.timing=m,Object.defineProperty(e,"__esModule",{value:!0}),e}({});
2
2
  //# sourceMappingURL=ful.iife.min.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"ful.iife.min.js","sources":["../src/bindings.mjs","../src/encodings.mjs","../src/forms.mjs","../src/http-client.mjs","../src/storage.mjs","../src/oauth-authorization-code.mjs","../src/timing.mjs","../src/app.mjs","../src/wizard.mjs"],"sourcesContent":["/* global CSS */\n\nfunction extract(extractors, el) {\n const maybeExtractor = extractors[el.dataset['bindExtractor']] || extractors[el.dataset['bindProvide']];\n if (maybeExtractor) {\n return maybeExtractor(el);\n }\n if (el.getAttribute('type') === 'radio') {\n if (!el.checked) {\n return undefined;\n }\n return el.dataset['bindType'] === 'boolean' ? el.value === 'true' : el.value;\n }\n if (el.getAttribute('type') === 'checkbox') {\n return el.checked;\n }\n if (el.dataset['bindType'] === 'boolean') {\n return !el.value ? null : el.value === 'true';\n }\n return el.value || null;\n}\n\nfunction mutate(mutators, el, raw, key, values) {\n const maybeMutator = mutators[el.dataset['bindMutator']] || mutators[el.dataset['bindProvide']];\n if (maybeMutator) {\n maybeMutator(el, raw, key, values);\n return;\n }\n if (el.getAttribute('type') === 'radio') {\n el.checked = el.getAttribute('value') === raw;\n return;\n }\n if (el.getAttribute('type') === 'checkbox') {\n el.checked = raw;\n return;\n }\n el.value = raw;\n}\n\n\nfunction providePath(result, path, value) {\n const keys = path.split(\".\").map((k) => k.match(/^[0-9]+$/) ? +k : k);\n let current = result;\n let previous = null;\n for (let i = 0; ; ++i) {\n const ckey = keys[i];\n const pkey = keys[i - 1];\n if (Number.isInteger(ckey) && !Array.isArray(current)) {\n if (previous !== null) {\n previous[pkey] = current = [];\n } else {\n result = current = [];\n }\n }\n if (i === keys.length - 1) {\n //when value is undefined we only want to define the property if it's not defined \n current[ckey] = value !== undefined ? value : (ckey in current ? current[ckey] : null);\n return result;\n }\n if (current[ckey] === undefined) {\n current[ckey] = {};\n }\n previous = current;\n current = current[ckey];\n }\n}\n\nclass Bindings {\n\n constructor( {extractors, mutators, ignoredChildrenSelector, valueHoldersSelector}) {\n this.extractors = extractors || {};\n this.mutators = mutators || {};\n this.valueHoldersSelector = valueHoldersSelector || 'input[name], select[name], textarea[name]';\n this.ignoredChildrenSelector = ignoredChildrenSelector || '.d-none';\n }\n setValues(el, values) {\n for (let k in values) {\n if (!values.hasOwnProperty(k)) {\n continue;\n }\n Array.from(el.querySelectorAll(`[name='${CSS.escape(k)}']`)).forEach((el) => {\n mutate(this.mutators, el, values[k], k, values);\n });\n }\n }\n getValues(el) {\n return Array.from(el.querySelectorAll(this.valueHoldersSelector))\n .filter((el) => {\n if (el.dataset['bindInclude'] === 'never') {\n return false;\n }\n return el.dataset['bindInclude'] === 'always' || el.closest(this.ignoredChildrenSelector) === null;\n })\n .reduce((result, el) => {\n return providePath(result, el.getAttribute('name'), extract(this.extractors, el));\n }, {});\n }\n}\n\n\n\nexport { Bindings };","\n\nclass Base64 {\n static encode(arrayBuffer, dialect) {\n const d = dialect || Base64.URL_SAFE;\n const len = arrayBuffer.byteLength;\n const view = new Uint8Array(arrayBuffer);\n let res = '';\n for (let i = 0; i < len; i += 3) {\n const v1 = d[view[i] >> 2];\n const v2 = d[((view[i] & 3) << 4) | (view[i + 1] >> 4)];\n const v3 = d[((view[i + 1] & 15) << 2) | (view[i + 2] >> 6)];\n const v4 = d[view[i + 2] & 63];\n res += v1 + v2 + v3 + v4;\n }\n if (len % 3 === 2) {\n res = res.substring(0, res.length - 1);\n } else if (len % 3 === 1) {\n res = res.substring(0, res.length - 2);\n }\n return res;\n }\n static decode(str, dialect) {\n const d = dialect || Base64.URL_SAFE;\n let nbytes = Math.floor(str.length * 0.75);\n for (let i = 0; i !== str.length; ++i) {\n if (str[str.length - i - 1] !== '=') {\n break;\n }\n --nbytes;\n }\n const view = new Uint8Array(nbytes);\n\n let vi = 0;\n let si = 0;\n while (vi < str.length * 0.75) {\n const v1 = d.indexOf(str.charAt(si++));\n const v2 = d.indexOf(str.charAt(si++));\n const v3 = d.indexOf(str.charAt(si++));\n const v4 = d.indexOf(str.charAt(si++));\n view[vi++] = (v1 << 2) | (v2 >> 4);\n view[vi++] = ((v2 & 15) << 4) | (v3 >> 2);\n view[vi++] = ((v3 & 3) << 6) | v4;\n }\n\n return view.buffer;\n }\n}\n\nBase64.STANDARD = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/';\nBase64.URL_SAFE = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_';\n\n\nclass Hex {\n static decode(hex) {\n if (hex.length % 2 !== 0) {\n throw new Error(\"invalid length\");\n }\n const lenInBytes = hex.length / 2;\n return new Uint8Array(lenInBytes).map((e, i) => {\n const offset = i * 2;\n const octet = hex.substring(offset, offset + 2);\n return parseInt(octet, 16);\n });\n }\n static encode(bytes, upper) {\n return Array.from(bytes)\n .map(b => b.toString(16))\n .map(b => upper ? b.toUpperCase() : b)\n .map(o => o.padStart(2, 0))\n .join('');\n }\n}\n\nexport { Base64, Hex };","/* global Infinity, CSS */\n\n\nclass Form {\n constructor(el, bindings, {globalErrorsEl, fieldContainerSelector, errorClass, hideClass}) {\n this.el = el;\n this.bindings = bindings;\n this.globalErrorsEl = globalErrorsEl;\n this.fieldContainerSelector = fieldContainerSelector !== undefined ? fieldContainerSelector : Form.DEFAULT_FIELD_CONTAINER_SELECTOR;\n this.errorClass = errorClass || Form.DEFAULT_ERROR_CLASS;\n this.hideClass = hideClass || Form.DEFAULT_HIDE_CLASS;\n }\n setValues(values) {\n return this.bindings.setValues(this.el, values);\n }\n getValues() {\n return this.bindings.getValues(this.el);\n }\n setErrors(errors, scrollFirstErrorIntoView, context) {\n\n this.clearErrors();\n errors\n .map(this.mapError ? this.mapError : (e) => e)\n .filter((e) => e.type === 'FIELD_ERROR' || e.type === 'INVALID_FORMAT')\n .forEach((e) => {\n const name = e.context.replace(\"[\", \".\").replace(\"].\", \".\");\n Array.from(this.el.querySelectorAll(`[name='${CSS.escape(name)}']`))\n .map(el => this.fieldContainerSelector ? el.closest(this.fieldContainerSelector) : el)\n .filter(el => el !== null)\n .forEach(label => {\n label.classList.add(this.errorClass);\n label.dataset['error'] = e.reason;\n });\n });\n if (this.globalErrorsEl) {\n const globalErrors = errors.filter((e) => e.type !== 'FIELD_ERROR' && e.type !== 'INVALID_FORMAT');\n this.globalErrorsEl.innerHTML = globalErrors.map(e => e.reason).join(\"\\n\");\n if (globalErrors.length !== 0) {\n this.globalErrorsEl.classList.remove(this.hideClass);\n }\n }\n if (!scrollFirstErrorIntoView) {\n return;\n }\n const yOffsets = Array.from(this.el.querySelectorAll('.${CSS.escape(this.errorClass)}'))\n .map((label) => label.getBoundingClientRect().y + window.scrollY);\n const firstErrorScrollY = Math.min(...yOffsets);\n if (firstErrorScrollY !== Infinity) {\n window.scroll(window.scrollX, firstErrorScrollY > 100 ? firstErrorScrollY - 100 : 0);\n }\n }\n clearErrors() {\n this.el.querySelectorAll(`.${CSS.escape(this.errorClass)}`).forEach(l => l.classList.remove(this.errorClass));\n if (this.globalErrorsEl) {\n this.globalErrorsEl.innerHTML = '';\n this.globalErrorsEl.classList.add(this.hideClass);\n }\n }\n}\n\nForm.DEFAULT_FIELD_CONTAINER_SELECTOR = 'label';\nForm.DEFAULT_ERROR_CLASS = 'has-error';\nForm.DEFAULT_HIDE_CLASS = 'd-none';\n\n\n/*\n export function forms() {\n }\n \n forms.dropContext = function (context) {\n return function (e) {\n if (e.context && e.context.indexOf(context) === 0) {\n e.context = e.context.substring(context.length);\n }\n return e;\n };\n };\n \n \n Dom.ready(() => {\n document.querySelectorAll('label:not([data-error])').forEach(el => {\n el.dataset['error'] = \"Il valore inserito non è valido\";\n });\n });\n \n Dom.ready(() => {\n Dom.on(document.body, 'change', '[data-pattern]', {}, evt => {\n const el = evt.srcElement;\n const pattern = el.dataset['pattern'];\n const matches = el.value.match(pattern);\n const label = el.closest('label');\n if(label === null){\n return;\n }\n label.classList[matches ? 'remove' : 'add']('has-error'); \n });\n });\n */\nexport { Form };","class ContextInterceptor {\n constructor() {\n const context = document.querySelector(\"meta[name='context']\").getAttribute(\"content\");\n this.context = context.endsWith(\"/\") ? context.substring(0, context.length - 1) : context;\n }\n before(request) {\n const separator = request.resource.startsWith(\"/\") ? \"\" : \"/\";\n request.resource = this.context + separator + request.resource;\n }\n}\n\nclass CsrfTokenInterceptor {\n constructor() {\n this.k = document.querySelector(\"meta[name='_csrf_header']\").getAttribute(\"content\");\n this.v = document.querySelector(\"meta[name='_csrf']\").getAttribute(\"content\");\n }\n before(request) {\n const headers = new Headers(request.options.headers);\n headers.set(this.k, this.v);\n request.options.headers = headers;\n }\n}\n\nclass RedirectOnUnauthorizedInterceptor {\n constructor(redirectUri) {\n this.redirectUri = redirectUri;\n }\n after(request, response) {\n if (response.status !== 401) {\n return;\n }\n window.location.href = redirectUri;\n }\n}\n\nclass Failure extends Error {\n static parseProblems(status, text) {\n const def = [{\n type: \"GENERIC_PROBLEM\",\n context: null,\n reason: `${status}: ${text}`,\n details: null\n }];\n try {\n return text ? JSON.parse(text) : def;\n } catch (e) {\n return def;\n }\n }\n static fromResponse(status, text) {\n return new Failure(status, Failure.parseProblems(status, text));\n }\n constructor(status, problems) {\n super(JSON.stringify(problems));\n this.name = `Failure:${status}`;\n this.status = status;\n this.problems = problems;\n }\n}\n\nclass HttpClientBuilder {\n constructor() {\n this.interceptors = [];\n }\n withContext() {\n this.interceptors.push(new ContextInterceptor());\n return this;\n }\n withCsrfToken() {\n this.interceptors.push(new CsrfTokenInterceptor());\n return this;\n }\n withRedirectOnUnauthorized(redirectUri) {\n this.interceptors.push(new RedirectOnUnauthorizedInterceptor(redirectUri));\n return this;\n }\n withInterceptors(...interceptors) {\n this.interceptors.push(...interceptors);\n return this;\n }\n build() {\n const interceptors = this.interceptors;\n return new HttpClient({interceptors});\n }\n}\n\nclass HttpClient {\n static builder() {\n return new HttpClientBuilder();\n }\n constructor( {interceptors}){\n this.interceptors = interceptors || [];\n }\n async fetch(resource, options) {\n const is = this.interceptors.concat(options.interceptors || []);\n const request = {resource, options};\n await is.forEach(async (i) => {\n if (!i.before) {\n return;\n }\n await i.before(request);\n });\n const response = await fetch(request.resource, request.options);\n await is.forEach(async (i) => {\n if (!i.after) {\n return;\n }\n await i.after(request, response);\n });\n\n return response;\n }\n async json(resource, options) {\n try {\n const response = await this.fetch(resource, options);\n if (!response.ok) {\n const message = await response.text();\n throw Failure.fromResponse(response.status, message);\n }\n const text = await response.text();\n return text ? JSON.parse(text) : undefined;\n } catch (e) {\n if (e instanceof Failure) {\n throw e;\n }\n throw new Failure(0, [{\n type: \"CONNECTION_PROBLEM\",\n context: null,\n reason: e.message,\n details: null\n }]);\n }\n }\n async form(resource, options, uiOptions) {\n const ui = uiOptions || {};\n ui.buttons?.forEach(el => {\n el.setAttribute(\"disabled\", \"disabled\");\n if (ui.loader) {\n el.dataset['oldContent'] = el.innerHTML;\n el.innerHTML = ui.loader;\n }\n });\n try {\n const r = await this.json(resource, options);\n ui.form?.clearErrors();\n return r;\n } catch (e) {\n ui.form?.setErrors(e.problems);\n throw e;\n } finally {\n ui.buttons?.forEach(el => {\n el.removeAttribute(\"disabled\");\n el.innerHTML = el.dataset['oldContent'];\n delete el.dataset['oldContent'];\n });\n }\n }\n}\n\n\n\nexport { HttpClient, Failure };\n","\nclass Storage {\n constructor(prefix, storage) {\n this.prefix = prefix;\n this.storage = storage;\n }\n save(k, v) {\n this.storage.setItem(`${this.prefix}-${k}`, JSON.stringify(v));\n }\n load(k) {\n const got = this.storage.getItem(`${this.prefix}-${k}`);\n return got === undefined ? undefined : JSON.parse(got);\n }\n remove(k) {\n this.storage.removeItem(`${this.prefix}-${k}`);\n }\n pop(k) {\n const decoded = this.load(k);\n this.remove(k);\n return decoded;\n }\n}\n\nclass LocalStorage extends Storage {\n constructor(prefix) {\n super(prefix, localStorage);\n }\n}\n\nclass SessionStorage extends Storage {\n constructor(prefix) {\n super(prefix, sessionStorage);\n }\n}\n\nclass VersionedStorage {\n constructor(storage, key, dataSupplier){\n this.storage = storage;\n this.key = key;\n this.dataSupplier = dataSupplier;\n this.cache = null;\n \n }\n async load(revision){\n const saved = this.storage.load(this.key);\n if (!!saved && saved.revision === revision) {\n this.cache = saved.value;\n return;\n }\n const freshData = await this.dataSupplier(revision, this.key);\n this.storage.save(this.key, {\n revision: revision,\n value: freshData\n });\n this.cache = freshData;\n }\n data(){\n return this.cache;\n }\n}\n\n\n\nexport {LocalStorage, SessionStorage, VersionedStorage};","import { Base64 } from \"./encodings.mjs\";\nimport { SessionStorage } from \"./storage.mjs\";\n\n\nclass AuthorizationCodeFlow {\n static forKeycloak(clientId, realmBaseUrl, redirectUri){\n const authUri = new URL(\"protocol/openid-connect/auth\", realmBaseUrl);\n const tokenUri = new URL(\"protocol/openid-connect/token\", realmBaseUrl);\n const logoutUri = new URL(\"protocol/openid-connect/logout\", realmBaseUrl);\n const scope = \"openid profile\";\n return new AuthorizationCodeFlow(clientId, scope, authUri, tokenUri, logoutUri, redirectUri); \n }\n constructor(clientId, scope, authUri, tokenUri, logoutUri, redirectUri) {\n this.clientId = clientId;\n this.scope = scope;\n this.authUri = authUri;\n this.tokenUri = tokenUri;\n this.logoutUri = logoutUri;\n this.redirectUri = redirectUri;\n this.storage = new SessionStorage(clientId);\n }\n async _auth() {\n const pkceVerifier = Base64.encode(crypto.getRandomValues(new Uint8Array(32)).buffer);\n const pkceChallenge = Base64.encode(await crypto.subtle.digest(\"SHA-256\", new TextEncoder().encode(pkceVerifier)));\n const state = this.clientId + Base64.encode(crypto.getRandomValues(new Uint8Array(16)).buffer);\n this.storage.save(AuthorizationCodeFlow.PKCE_AND_STATE_KEY, {\n state: state,\n verifier: pkceVerifier\n });\n const url = new URL(this.authUri);\n url.searchParams.set(\"client_id\", this.clientId);\n url.searchParams.set(\"redirect_uri\", this.redirectUri);\n url.searchParams.set(\"response_type\", 'code');\n url.searchParams.set(\"scope\", this.scope);\n url.searchParams.set(\"state\", state);\n url.searchParams.set(\"code_challenge\", pkceChallenge);\n url.searchParams.set(\"code_challenge_method\", 'S256');\n window.location = url;\n }\n async _tokenExchange(code, state) {\n window.history.replaceState('', \"\", this.redirectUri);\n const stateAndVerifier = this.storage.pop(AuthorizationCodeFlow.PKCE_AND_STATE_KEY);\n if (stateAndVerifier.state !== state) {\n throw new Error(\"State mismatch\");\n }\n const response = await fetch(this.tokenUri, {\n method: \"POST\",\n headers: {\n \"Content-Type\": 'application/x-www-form-urlencoded'\n },\n body: new URLSearchParams([\n [\"client_id\", this.clientId],\n [\"code\", code],\n [\"grant_type\", \"authorization_code\"],\n [\"code_verifier\", stateAndVerifier.verifier],\n [\"state\", stateAndVerifier.state],\n [\"redirect_uri\", this.redirectUri]\n ])\n });\n if (!response.ok) {\n const text = await response.text();\n throw new Error(\"Error:\" + response.status + \": \" + text);\n }\n const token = await response.json();\n return new AuthorizationCodeFlowSession(this.clientId, token, this.tokenUri, this.logoutUri, this.redirectUri);\n }\n\n async ensureLoggedIn() {\n const url = new URL(window.location.href);\n const code = url.searchParams.get(\"code\");\n if (code) {\n //if callback from keycloak\n const state = url.searchParams.get(\"state\");\n return await this._tokenExchange(code, state);\n }\n //if not authorized\n await this._auth();\n return null;\n }\n}\nAuthorizationCodeFlow.PKCE_AND_STATE_KEY = \"state-and-verifier\";\n\nclass AuthorizationCodeFlowSession {\n static parseToken(token) {\n const [rawHeader, rawPayload, signature] = token.split(\".\");\n return {\n header: JSON.parse(atob(rawHeader)),\n payload: JSON.parse(atob(rawPayload)),\n signature: signature\n };\n } \n constructor(clientId, token, tokenUri, logoutUri, redirectUri) {\n this.clientId = clientId;\n this.token = token;\n this.tokenUri = tokenUri;\n this.logoutUri = logoutUri;\n this.redirectUri = redirectUri;\n this.accessToken = AuthorizationCodeFlowSession.parseToken(token.access_token);\n this.refreshToken = AuthorizationCodeFlowSession.parseToken(token.refresh_token);\n this.refreshCallback = null;\n }\n onRefresh(callback) {\n this.refreshCallback = callback;\n }\n async refresh() {\n const response = await fetch(this.tokenUri, {\n method: \"POST\",\n headers: {\n \"Content-Type\": 'application/x-www-form-urlencoded'\n },\n body: new URLSearchParams([\n [\"client_id\", this.clientId],\n [\"grant_type\", \"refresh_token\"],\n [\"refresh_token\", this.token.refresh_token]\n ])\n });\n if (!response.ok) {\n throw new Error(\"Error:\" + response.code + \": \" + response.text());\n }\n const token = await response.json();\n this.token = token;\n this.accessToken = this._parseToken(token.access_token);\n this.refreshToken = this._parseToken(token.refresh_token);\n if (this.refreshCallback) {\n this.refreshCallback(this.token, this.accessToken, this.refreshToken);\n }\n }\n shouldBeRefreshed(gracePeriod) {\n const now = new Date().getTime();\n const refreshTokenExpiresAt = this.refreshToken.payload.exp * 1000;\n const expired = now > refreshTokenExpiresAt;\n const shouldRefresh = now - gracePeriod > refreshTokenExpiresAt;\n return !expired && shouldRefresh;\n }\n async refreshIf(gracePeriod) {\n if (!this.shouldBeRefreshed(gracePeriod)) {\n return;\n }\n await this.refresh();\n }\n logout() {\n const url = new URL(this.logoutUri);\n url.searchParams.set(\"post_logout_redirect_uri\", this.redirectUri);\n url.searchParams.set(\"id_token_hint\", this.token.id_token);\n window.location = url;\n }\n\n bearerToken() {\n return `Bearer ${this.token.access_token}`;\n }\n \n interceptor(gracePeriodBefore, gracePeriodAfter){\n return new AuthorizationCodeFlowInterceptor(this, gracePeriodBefore, gracePeriodAfter); \n }\n}\n\nclass AuthorizationCodeFlowInterceptor {\n constructor(session, gracePeriodBefore, gracePeriodAfter) {\n this.session = session;\n this.gracePeriodBefore = gracePeriodBefore || 2000;\n this.gracePeriodAfter = gracePeriodAfter || 30000;\n }\n async before(request) {\n await this.session.refreshIf(this.gracePeriodBefore);\n const headers = new Headers(request.options.headers);\n headers.set(\"Authorization\", this.session.bearerToken());\n return request;\n }\n async after(request, response) {\n await this.session.refreshIf(this.gracePeriodAfter);\n return response;\n }\n}\n\n\nexport {AuthorizationCodeFlow, AuthorizationCodeFlowSession, AuthorizationCodeFlowInterceptor };","\nconst timing = {\n sleep(ms) {\n return new Promise(resolve => setTimeout(resolve, ms));\n },\n DEBOUNCE_DEFAULT: 0,\n DEBOUNCE_IMMEDIATE: 1,\n debounce(timeoutMs, func, options) {\n let tid = null;\n let args = [];\n let previousTimestamp = 0;\n let opts = options || timing.DEBOUNCE_DEFAULT;\n\n const later = () => {\n const elapsed = new Date().getTime() - previousTimestamp;\n if (timeoutMs > elapsed) {\n tid = setTimeout(later, timeoutMs - elapsed);\n return;\n }\n tid = null;\n if (opts !== timing.DEBOUNCE_IMMEDIATE) {\n func(...args);\n }\n // This check is needed because `func` can recursively invoke `debounced`.\n if (tid === null) {\n args = [];\n }\n };\n\n return function () {\n args = arguments;\n previousTimestamp = new Date().getTime();\n if (tid === null) {\n tid = setTimeout(later, timeoutMs);\n if (opts === timing.DEBOUNCE_IMMEDIATE) {\n func(...args);\n }\n }\n };\n },\n THROTTLE_DEFAULT: 0,\n THROTTLE_NO_LEADING: 1,\n THROTTLE_NO_TRAILING: 2,\n throttle(timeoutMs, func, options) {\n let tid = null;\n let args = [];\n let previousTimestamp = 0;\n let opts = options || timing.THROTTLE_DEFAULT;\n\n const later = () => {\n previousTimestamp = (opts & timing.THROTTLE_NO_LEADING) ? 0 : new Date().getTime();\n tid = null;\n func(...args);\n if (tid === null) {\n args = [];\n }\n };\n\n return function () {\n const now = new Date().getTime();\n if (!previousTimestamp && (opts & timing.THROTTLE_NO_LEADING)) {\n previousTimestamp = now;\n }\n const remaining = timeoutMs - (now - previousTimestamp);\n args = arguments;\n if (remaining <= 0 || remaining > timeoutMs) {\n if (tid !== null) {\n clearTimeout(tid);\n tid = null;\n }\n previousTimestamp = now;\n func(...args);\n if (tid === null) {\n args = [];\n }\n } else if (tid === null && !(opts & timing.THROTTLE_NO_TRAILING)) {\n tid = setTimeout(later, remaining);\n }\n };\n\n }\n};\n\n\nexport { timing };","class App {\n constructor() {\n this.configurers = [];\n this.initializers = [];\n this.handlers = [];\n this.running = false;\n document.addEventListener(\"DOMContentLoaded\", async () => {\n await Promise.all(this.configurers);\n await Promise.all(this.initializers.map(h => Promise.resolve(h())));\n await Promise.all(this.handlers.map(h => Promise.resolve(h())));\n });\n }\n configure(cb) {\n this.configurers.push(Promise.resolve(cb()));\n return this;\n }\n initialize(cb) {\n this.initializers.push(cb);\n return this;\n }\n ready(cb) {\n this.handlers.push(cb);\n return this;\n }\n}\n\nexport { App };\n","class Wizard {\n constructor(el) {\n this.el = el;\n this.progress = [...el.children].filter(e => e.matches(\"header,ol,ul\"));\n\n this.progress.forEach(p => {\n const children = [...p.children];\n const current = children.filter(e => e.matches(\".active\"))[0];\n if (current === undefined && children.length > 0) {\n children[0].classList.add('active');\n }\n });\n if (this.el.querySelector('section.current') === null) {\n const firstSection = this.el.querySelector('section:first-of-type');\n if (firstSection !== null) {\n firstSection.classList.add('current');\n }\n }\n }\n next() {\n this.progress.forEach(p => {\n const children = [...p.children];\n const current = children.filter(e => e.matches(\".active\"))[0];\n current?.classList.remove('active');\n current?.nextElementSibling?.classList.add('active');\n });\n const currentSection = this.el.querySelector('section.current');\n currentSection.classList.remove(\"current\");\n currentSection.nextElementSibling.classList.add('current');\n\n this.el.dispatchEvent(new CustomEvent('wizard:activate', {\n bubbles: true,\n cancelable: true\n }));\n\n }\n prev() {\n this.progress.forEach(p => {\n const children = [...p.children];\n const current = children.filter(e => e.matches(\".active\"))[0];\n current?.classList.remove('active');\n current?.previousElementSibling?.classList.add('active');\n });\n const currentSection = this.el.querySelector('section.current');\n currentSection.classList.remove(\"current\");\n currentSection.previousElementSibling.classList.add('current');\n this.el.dispatchEvent(new CustomEvent('wizard:activate', {\n bubbles: true,\n cancelable: true\n }));\n }\n moveTo = function (n) {\n this.progress.forEach(p => {\n const children = [...p.children];\n const current = children.filter(e => e.matches(\".active\"))[0];\n current?.classList.remove('active');\n p.children[+n]?.classList.add('active');\n });\n const currentSection = this.el.querySelector('section.current');\n currentSection?.classList.remove(\"current\");\n const nthSection = this.el.querySelector(`section:nth-child(${+n})`);\n nthSection.classList.add('current');\n this.el.dispatchEvent(new CustomEvent('wizard:activate', {\n bubbles: true,\n cancelable: true\n }));\n }\n}\n\n\n\n\nexport { Wizard };\n"],"names":["mutate","mutators","el","raw","key","values","maybeMutator","dataset","getAttribute","value","checked","Base64","static","arrayBuffer","dialect","d","URL_SAFE","len","byteLength","view","Uint8Array","res","i","substring","length","str","nbytes","Math","floor","vi","si","v1","indexOf","charAt","v2","v3","v4","buffer","STANDARD","Form","constructor","bindings","globalErrorsEl","fieldContainerSelector","errorClass","hideClass","this","undefined","DEFAULT_FIELD_CONTAINER_SELECTOR","DEFAULT_ERROR_CLASS","DEFAULT_HIDE_CLASS","setValues","getValues","setErrors","errors","scrollFirstErrorIntoView","context","clearErrors","map","mapError","e","filter","type","forEach","name","replace","Array","from","querySelectorAll","CSS","escape","closest","label","classList","add","reason","globalErrors","innerHTML","join","remove","yOffsets","getBoundingClientRect","y","window","scrollY","firstErrorScrollY","min","Infinity","scroll","scrollX","l","ContextInterceptor","document","querySelector","endsWith","before","request","separator","resource","startsWith","CsrfTokenInterceptor","k","v","headers","Headers","options","set","RedirectOnUnauthorizedInterceptor","redirectUri","after","response","status","location","href","Failure","Error","text","def","details","JSON","parse","parseProblems","problems","super","stringify","HttpClientBuilder","interceptors","withContext","push","withCsrfToken","withRedirectOnUnauthorized","withInterceptors","build","HttpClient","async","is","concat","fetch","ok","message","fromResponse","uiOptions","ui","buttons","setAttribute","loader","r","json","form","removeAttribute","Storage","prefix","storage","save","setItem","load","got","getItem","removeItem","pop","decoded","SessionStorage","sessionStorage","AuthorizationCodeFlow","clientId","realmBaseUrl","authUri","URL","tokenUri","logoutUri","scope","pkceVerifier","encode","crypto","getRandomValues","pkceChallenge","subtle","digest","TextEncoder","state","PKCE_AND_STATE_KEY","verifier","url","searchParams","code","history","replaceState","stateAndVerifier","method","body","URLSearchParams","token","AuthorizationCodeFlowSession","get","_tokenExchange","_auth","rawHeader","rawPayload","signature","split","header","atob","payload","accessToken","parseToken","access_token","refreshToken","refresh_token","refreshCallback","onRefresh","callback","_parseToken","shouldBeRefreshed","gracePeriod","now","Date","getTime","refreshTokenExpiresAt","exp","refresh","logout","id_token","bearerToken","interceptor","gracePeriodBefore","gracePeriodAfter","AuthorizationCodeFlowInterceptor","session","refreshIf","timing","sleep","ms","Promise","resolve","setTimeout","DEBOUNCE_DEFAULT","DEBOUNCE_IMMEDIATE","debounce","timeoutMs","func","tid","args","previousTimestamp","opts","later","elapsed","arguments","THROTTLE_DEFAULT","THROTTLE_NO_LEADING","THROTTLE_NO_TRAILING","throttle","remaining","clearTimeout","configurers","initializers","handlers","running","addEventListener","all","h","configure","cb","initialize","ready","extractors","ignoredChildrenSelector","valueHoldersSelector","hasOwnProperty","reduce","result","path","keys","match","current","previous","ckey","pkey","Number","isInteger","isArray","providePath","maybeExtractor","extract","hex","lenInBytes","offset","octet","parseInt","bytes","upper","b","toString","toUpperCase","o","padStart","localStorage","dataSupplier","cache","revision","saved","freshData","data","progress","children","matches","p","firstSection","next","nextElementSibling","currentSection","dispatchEvent","CustomEvent","bubbles","cancelable","prev","previousElementSibling","moveTo","n"],"mappings":"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"}
1
+ {"version":3,"file":"ful.iife.min.js","sources":["../src/bindings.mjs","../src/encodings.mjs","../src/forms.mjs","../src/http-client.mjs","../src/storage.mjs","../src/oauth-authorization-code.mjs","../src/timing.mjs","../src/app.mjs","../src/wizard.mjs"],"sourcesContent":["/* global CSS */\n\nfunction extract(extractors, el) {\n const maybeExtractor = extractors[el.dataset['bindExtractor']] || extractors[el.dataset['bindProvide']];\n if (maybeExtractor) {\n return maybeExtractor(el);\n }\n if (el.getAttribute('type') === 'radio') {\n if (!el.checked) {\n return undefined;\n }\n return el.dataset['bindType'] === 'boolean' ? el.value === 'true' : el.value;\n }\n if (el.getAttribute('type') === 'checkbox') {\n return el.checked;\n }\n if (el.dataset['bindType'] === 'boolean') {\n return !el.value ? null : el.value === 'true';\n }\n return el.value || null;\n}\n\nfunction mutate(mutators, el, raw, key, values) {\n const maybeMutator = mutators[el.dataset['bindMutator']] || mutators[el.dataset['bindProvide']];\n if (maybeMutator) {\n maybeMutator(el, raw, key, values);\n return;\n }\n if (el.getAttribute('type') === 'radio') {\n el.checked = el.getAttribute('value') === raw;\n return;\n }\n if (el.getAttribute('type') === 'checkbox') {\n el.checked = raw;\n return;\n }\n el.value = raw;\n}\n\n\nfunction providePath(result, path, value) {\n const keys = path.split(\".\").map((k) => k.match(/^[0-9]+$/) ? +k : k);\n let current = result;\n let previous = null;\n for (let i = 0; ; ++i) {\n const ckey = keys[i];\n const pkey = keys[i - 1];\n if (Number.isInteger(ckey) && !Array.isArray(current)) {\n if (previous !== null) {\n previous[pkey] = current = [];\n } else {\n result = current = [];\n }\n }\n if (i === keys.length - 1) {\n //when value is undefined we only want to define the property if it's not defined \n current[ckey] = value !== undefined ? value : (ckey in current ? current[ckey] : null);\n return result;\n }\n if (current[ckey] === undefined) {\n current[ckey] = {};\n }\n previous = current;\n current = current[ckey];\n }\n}\n\nclass Bindings {\n\n constructor( {extractors, mutators, ignoredChildrenSelector, valueHoldersSelector}) {\n this.extractors = extractors || {};\n this.mutators = mutators || {};\n this.valueHoldersSelector = valueHoldersSelector || 'input[name], select[name], textarea[name]';\n this.ignoredChildrenSelector = ignoredChildrenSelector || '.d-none';\n }\n setValues(el, values) {\n for (let k in values) {\n if (!values.hasOwnProperty(k)) {\n continue;\n }\n Array.from(el.querySelectorAll(`[name='${CSS.escape(k)}']`)).forEach((el) => {\n mutate(this.mutators, el, values[k], k, values);\n });\n }\n }\n getValues(el) {\n return Array.from(el.querySelectorAll(this.valueHoldersSelector))\n .filter((el) => {\n if (el.dataset['bindInclude'] === 'never') {\n return false;\n }\n return el.dataset['bindInclude'] === 'always' || el.closest(this.ignoredChildrenSelector) === null;\n })\n .reduce((result, el) => {\n return providePath(result, el.getAttribute('name'), extract(this.extractors, el));\n }, {});\n }\n}\n\n\n\nexport { Bindings };","\n\nclass Base64 {\n static encode(arrayBuffer, dialect) {\n const d = dialect || Base64.URL_SAFE;\n const len = arrayBuffer.byteLength;\n const view = new Uint8Array(arrayBuffer);\n let res = '';\n for (let i = 0; i < len; i += 3) {\n const v1 = d[view[i] >> 2];\n const v2 = d[((view[i] & 3) << 4) | (view[i + 1] >> 4)];\n const v3 = d[((view[i + 1] & 15) << 2) | (view[i + 2] >> 6)];\n const v4 = d[view[i + 2] & 63];\n res += v1 + v2 + v3 + v4;\n }\n if (len % 3 === 2) {\n res = res.substring(0, res.length - 1);\n } else if (len % 3 === 1) {\n res = res.substring(0, res.length - 2);\n }\n return res;\n }\n static decode(str, dialect) {\n const d = dialect || Base64.URL_SAFE;\n let nbytes = Math.floor(str.length * 0.75);\n for (let i = 0; i !== str.length; ++i) {\n if (str[str.length - i - 1] !== '=') {\n break;\n }\n --nbytes;\n }\n const view = new Uint8Array(nbytes);\n\n let vi = 0;\n let si = 0;\n while (vi < str.length * 0.75) {\n const v1 = d.indexOf(str.charAt(si++));\n const v2 = d.indexOf(str.charAt(si++));\n const v3 = d.indexOf(str.charAt(si++));\n const v4 = d.indexOf(str.charAt(si++));\n view[vi++] = (v1 << 2) | (v2 >> 4);\n view[vi++] = ((v2 & 15) << 4) | (v3 >> 2);\n view[vi++] = ((v3 & 3) << 6) | v4;\n }\n\n return view.buffer;\n }\n}\n\nBase64.STANDARD = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/';\nBase64.URL_SAFE = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_';\n\n\nclass Hex {\n static decode(hex) {\n if (hex.length % 2 !== 0) {\n throw new Error(\"invalid length\");\n }\n const lenInBytes = hex.length / 2;\n return new Uint8Array(lenInBytes).map((e, i) => {\n const offset = i * 2;\n const octet = hex.substring(offset, offset + 2);\n return parseInt(octet, 16);\n });\n }\n static encode(bytes, upper) {\n return Array.from(bytes)\n .map(b => b.toString(16))\n .map(b => upper ? b.toUpperCase() : b)\n .map(o => o.padStart(2, 0))\n .join('');\n }\n}\n\nexport { Base64, Hex };","/* global Infinity, CSS */\n\n\nclass Form {\n constructor(el, bindings, {globalErrorsEl, fieldContainerSelector, errorClass, hideClass}) {\n this.el = el;\n this.bindings = bindings;\n this.globalErrorsEl = globalErrorsEl;\n this.fieldContainerSelector = fieldContainerSelector !== undefined ? fieldContainerSelector : Form.DEFAULT_FIELD_CONTAINER_SELECTOR;\n this.errorClass = errorClass || Form.DEFAULT_ERROR_CLASS;\n this.hideClass = hideClass || Form.DEFAULT_HIDE_CLASS;\n }\n setValues(values) {\n return this.bindings.setValues(this.el, values);\n }\n getValues() {\n return this.bindings.getValues(this.el);\n }\n setErrors(errors, scrollFirstErrorIntoView, context) {\n\n this.clearErrors();\n errors\n .map(this.mapError ? this.mapError : (e) => e)\n .filter((e) => e.type === 'FIELD_ERROR' || e.type === 'INVALID_FORMAT')\n .forEach((e) => {\n const name = e.context.replace(\"[\", \".\").replace(\"].\", \".\");\n Array.from(this.el.querySelectorAll(`[name='${CSS.escape(name)}']`))\n .map(el => this.fieldContainerSelector ? el.closest(this.fieldContainerSelector) : el)\n .filter(el => el !== null)\n .forEach(label => {\n label.classList.add(this.errorClass);\n label.dataset['error'] = e.reason;\n });\n });\n if (this.globalErrorsEl) {\n const globalErrors = errors.filter((e) => e.type !== 'FIELD_ERROR' && e.type !== 'INVALID_FORMAT');\n this.globalErrorsEl.innerHTML = globalErrors.map(e => e.reason).join(\"\\n\");\n if (globalErrors.length !== 0) {\n this.globalErrorsEl.classList.remove(this.hideClass);\n }\n }\n if (!scrollFirstErrorIntoView) {\n return;\n }\n const yOffsets = Array.from(this.el.querySelectorAll('.${CSS.escape(this.errorClass)}'))\n .map((label) => label.getBoundingClientRect().y + window.scrollY);\n const firstErrorScrollY = Math.min(...yOffsets);\n if (firstErrorScrollY !== Infinity) {\n window.scroll(window.scrollX, firstErrorScrollY > 100 ? firstErrorScrollY - 100 : 0);\n }\n }\n clearErrors() {\n this.el.querySelectorAll(`.${CSS.escape(this.errorClass)}`).forEach(l => l.classList.remove(this.errorClass));\n if (this.globalErrorsEl) {\n this.globalErrorsEl.innerHTML = '';\n this.globalErrorsEl.classList.add(this.hideClass);\n }\n }\n}\n\nForm.DEFAULT_FIELD_CONTAINER_SELECTOR = 'label';\nForm.DEFAULT_ERROR_CLASS = 'has-error';\nForm.DEFAULT_HIDE_CLASS = 'd-none';\n\n\n/*\n export function forms() {\n }\n \n forms.dropContext = function (context) {\n return function (e) {\n if (e.context && e.context.indexOf(context) === 0) {\n e.context = e.context.substring(context.length);\n }\n return e;\n };\n };\n \n \n Dom.ready(() => {\n document.querySelectorAll('label:not([data-error])').forEach(el => {\n el.dataset['error'] = \"Il valore inserito non è valido\";\n });\n });\n \n Dom.ready(() => {\n Dom.on(document.body, 'change', '[data-pattern]', {}, evt => {\n const el = evt.srcElement;\n const pattern = el.dataset['pattern'];\n const matches = el.value.match(pattern);\n const label = el.closest('label');\n if(label === null){\n return;\n }\n label.classList[matches ? 'remove' : 'add']('has-error'); \n });\n });\n */\nexport { Form };","class ContextInterceptor {\n constructor() {\n const context = document.querySelector(\"meta[name='context']\").getAttribute(\"content\");\n this.context = context.endsWith(\"/\") ? context.substring(0, context.length - 1) : context;\n }\n async intercept(request, chain){\n const separator = request.resource.startsWith(\"/\") ? \"\" : \"/\";\n request.resource = this.context + separator + request.resource;\n return await chain.proceed(request);\n }\n}\n\nclass CsrfTokenInterceptor {\n constructor() {\n this.k = document.querySelector(\"meta[name='_csrf_header']\").getAttribute(\"content\");\n this.v = document.querySelector(\"meta[name='_csrf']\").getAttribute(\"content\");\n }\n async intercept(request, chain){\n const headers = new Headers(request.options.headers);\n headers.set(this.k, this.v);\n request.options.headers = headers;\n return await chain.proceed(request);\n }\n}\n\nclass RedirectOnUnauthorizedInterceptor {\n constructor(redirectUri) {\n this.redirectUri = redirectUri;\n }\n async intercept(request, chain){\n const response = await chain.proceed(request);\n if (response.status !== 401) {\n return response;\n }\n window.location.href = redirectUri;\n }\n}\n\nclass Failure extends Error {\n static parseProblems(status, text) {\n const def = [{\n type: \"GENERIC_PROBLEM\",\n context: null,\n reason: `${status}: ${text}`,\n details: null\n }];\n try {\n return text ? JSON.parse(text) : def;\n } catch (e) {\n return def;\n }\n }\n static fromResponse(status, text) {\n return new Failure(status, Failure.parseProblems(status, text));\n }\n constructor(status, problems) {\n super(JSON.stringify(problems));\n this.name = `Failure:${status}`;\n this.status = status;\n this.problems = problems;\n }\n}\n\nclass HttpClientBuilder {\n constructor() {\n this.interceptors = [];\n }\n withContext() {\n this.interceptors.push(new ContextInterceptor());\n return this;\n }\n withCsrfToken() {\n this.interceptors.push(new CsrfTokenInterceptor());\n return this;\n }\n withRedirectOnUnauthorized(redirectUri) {\n this.interceptors.push(new RedirectOnUnauthorizedInterceptor(redirectUri));\n return this;\n }\n withInterceptors(...interceptors) {\n this.interceptors.push(...interceptors);\n return this;\n }\n build() {\n const interceptors = this.interceptors;\n return new HttpClient({interceptors});\n }\n}\n\nclass HttpCall {\n async intercept(request, chain){\n return await fetch(request.resource, request.options);\n } \n}\n\nclass HttpInterceptorChain {\n constructor(interceptors, current){\n this.interceptors = interceptors;\n this.current = current;\n }\n async proceed(request){\n const interceptor = this.interceptors[this.current];\n return await interceptor.intercept(request, new HttpInterceptorChain(this.interceptors, this.current + 1));\n }\n}\n\n\nclass HttpClient {\n static builder() {\n return new HttpClientBuilder();\n }\n constructor({interceptors}){\n this.interceptors = interceptors || [];\n }\n async fetch(resource, options) {\n const interceptors = [...this.interceptors, ...options.interceptors || [], new HttpCall()];\n const chain = new HttpInterceptorChain(interceptors, 0);\n return await chain.proceed({resource, options});\n }\n async json(resource, options) {\n try {\n const response = await this.fetch(resource, options);\n if (!response.ok) {\n const message = await response.text();\n throw Failure.fromResponse(response.status, message);\n }\n const text = await response.text();\n return text ? JSON.parse(text) : undefined;\n } catch (e) {\n if (e instanceof Failure) {\n throw e;\n }\n throw new Failure(0, [{\n type: \"CONNECTION_PROBLEM\",\n context: null,\n reason: e.message,\n details: null\n }]);\n }\n }\n async form(resource, options, uiOptions) {\n const ui = uiOptions || {};\n ui.buttons?.forEach(el => {\n el.setAttribute(\"disabled\", \"disabled\");\n if (ui.loader) {\n el.dataset['oldContent'] = el.innerHTML;\n el.innerHTML = ui.loader;\n }\n });\n try {\n const r = await this.json(resource, options);\n ui.form?.clearErrors();\n return r;\n } catch (e) {\n ui.form?.setErrors(e.problems);\n throw e;\n } finally {\n ui.buttons?.forEach(el => {\n el.removeAttribute(\"disabled\");\n el.innerHTML = el.dataset['oldContent'];\n delete el.dataset['oldContent'];\n });\n }\n }\n}\n\n\n\nexport { HttpClient, Failure };\n","\nclass Storage {\n constructor(prefix, storage) {\n this.prefix = prefix;\n this.storage = storage;\n }\n save(k, v) {\n this.storage.setItem(`${this.prefix}-${k}`, JSON.stringify(v));\n }\n load(k) {\n const got = this.storage.getItem(`${this.prefix}-${k}`);\n return got === undefined ? undefined : JSON.parse(got);\n }\n remove(k) {\n this.storage.removeItem(`${this.prefix}-${k}`);\n }\n pop(k) {\n const decoded = this.load(k);\n this.remove(k);\n return decoded;\n }\n}\n\nclass LocalStorage extends Storage {\n constructor(prefix) {\n super(prefix, localStorage);\n }\n}\n\nclass SessionStorage extends Storage {\n constructor(prefix) {\n super(prefix, sessionStorage);\n }\n}\n\nclass VersionedStorage {\n constructor(storage, key, dataSupplier){\n this.storage = storage;\n this.key = key;\n this.dataSupplier = dataSupplier;\n this.cache = null;\n \n }\n async load(revision){\n const saved = this.storage.load(this.key);\n if (!!saved && saved.revision === revision) {\n this.cache = saved.value;\n return;\n }\n const freshData = await this.dataSupplier(revision, this.key);\n this.storage.save(this.key, {\n revision: revision,\n value: freshData\n });\n this.cache = freshData;\n }\n data(){\n return this.cache;\n }\n}\n\n\n\nexport {LocalStorage, SessionStorage, VersionedStorage};","import { Base64 } from \"./encodings.mjs\";\nimport { SessionStorage } from \"./storage.mjs\";\n\n\nclass AuthorizationCodeFlow {\n static forKeycloak(clientId, realmBaseUrl, redirectUri){\n const scope = \"openid profile\";\n return new AuthorizationCodeFlow(clientId, scope, {\n auth: new URL(\"protocol/openid-connect/auth\", realmBaseUrl),\n token: new URL(\"protocol/openid-connect/token\", realmBaseUrl),\n logout: new URL(\"protocol/openid-connect/logout\", realmBaseUrl),\n registration: new URL(\"protocol/openid-connect/registrations\", realmBaseUrl),\n redirect: redirectUri\n }); \n }\n constructor(clientId, scope, {auth, token, registration, logout, redirect}) {\n this.storage = new SessionStorage(clientId);\n this.clientId = clientId;\n this.scope = scope;\n this.uri = {auth, token, registration, logout, redirect};\n }\n async action(uri, additionalParams){\n const pkceVerifier = Base64.encode(crypto.getRandomValues(new Uint8Array(32)).buffer);\n const pkceChallenge = Base64.encode(await crypto.subtle.digest(\"SHA-256\", new TextEncoder().encode(pkceVerifier)));\n const state = this.clientId + Base64.encode(crypto.getRandomValues(new Uint8Array(16)).buffer);\n this.storage.save(AuthorizationCodeFlow.PKCE_AND_STATE_KEY, {\n state: state,\n verifier: pkceVerifier\n });\n const url = new URL(uri);\n url.searchParams.set(\"client_id\", this.clientId);\n url.searchParams.set(\"redirect_uri\", this.uri.redirect);\n url.searchParams.set(\"response_type\", 'code');\n url.searchParams.set(\"scope\", this.scope);\n url.searchParams.set(\"state\", state);\n url.searchParams.set(\"code_challenge\", pkceChallenge);\n url.searchParams.set(\"code_challenge_method\", 'S256');\n Object.entries(additionalParams || {}).forEach(kv => {\n url.searchParams.set(kv[0], kv[1]);\n });\n window.location = url;\n }\n async registration(additionalParams){\n await this.action(this.uri.registration, additionalParams);\n }\n async applicationInitiatedAction(kcAction){\n await this.action(this.uri.auth, {\n kc_action: kcAction\n });\n }\n async _tokenExchange(code, state) {\n window.history.replaceState('', \"\", this.uri.redirect);\n const stateAndVerifier = this.storage.pop(AuthorizationCodeFlow.PKCE_AND_STATE_KEY);\n if (stateAndVerifier.state !== state) {\n throw new Error(\"State mismatch\");\n }\n const response = await fetch(this.uri.token, {\n method: \"POST\",\n headers: {\n \"Content-Type\": 'application/x-www-form-urlencoded'\n },\n body: new URLSearchParams([\n [\"client_id\", this.clientId],\n [\"code\", code],\n [\"grant_type\", \"authorization_code\"],\n [\"code_verifier\", stateAndVerifier.verifier],\n [\"state\", stateAndVerifier.state],\n [\"redirect_uri\", this.uri.redirect]\n ])\n });\n if (!response.ok) {\n const text = await response.text();\n throw new Error(\"Error:\" + response.status + \": \" + text);\n }\n const token = await response.json();\n return new AuthorizationCodeFlowSession(this.clientId, token, this.uri);\n }\n async ensureLoggedIn() {\n const url = new URL(window.location.href);\n const code = url.searchParams.get(\"code\");\n if (code && this.storage.load(AuthorizationCodeFlow.PKCE_AND_STATE_KEY)) {\n //if callback from keycloak and we have our state still stored\n const state = url.searchParams.get(\"state\");\n return await this._tokenExchange(code, state);\n }\n //if not authorized\n await this.action(this.uri.auth, {});\n return null;\n }\n}\nAuthorizationCodeFlow.PKCE_AND_STATE_KEY = \"state-and-verifier\";\n\nclass AuthorizationCodeFlowSession {\n static parseToken(token) {\n const [rawHeader, rawPayload, signature] = token.split(\".\");\n const ut8decoder = new TextDecoder(\"utf-8\");\n return {\n header: JSON.parse(ut8decoder.decode(Base64.decode(rawHeader, Base64.STANDARD))),\n payload: JSON.parse(ut8decoder.decode(Base64.decode(rawPayload, Base64.STANDARD))),\n signature: signature\n };\n } \n constructor(clientId, t, {token, logout, redirect}) {\n this.clientId = clientId;\n this.token = t;\n this.accessToken = AuthorizationCodeFlowSession.parseToken(t.access_token);\n this.refreshToken = AuthorizationCodeFlowSession.parseToken(t.refresh_token);\n this.uri = { token, logout, redirect }\n this.refreshCallback = null;\n }\n onRefresh(callback) {\n this.refreshCallback = callback;\n }\n async refresh() {\n const response = await fetch(this.uri.token, {\n method: \"POST\",\n headers: {\n \"Content-Type\": 'application/x-www-form-urlencoded'\n },\n body: new URLSearchParams([\n [\"client_id\", this.clientId],\n [\"grant_type\", \"refresh_token\"],\n [\"refresh_token\", this.token.refresh_token]\n ])\n });\n if (!response.ok) {\n throw new Error(\"Error:\" + response.code + \": \" + response.text());\n }\n const token = await response.json();\n this.token = token;\n this.accessToken = this._parseToken(token.access_token);\n this.refreshToken = this._parseToken(token.refresh_token);\n if (this.refreshCallback) {\n this.refreshCallback(this.token, this.accessToken, this.refreshToken);\n }\n }\n shouldBeRefreshed(gracePeriod) {\n const now = new Date().getTime();\n const refreshTokenExpiresAt = this.refreshToken.payload.exp * 1000;\n const expired = now > refreshTokenExpiresAt;\n const shouldRefresh = now - gracePeriod > refreshTokenExpiresAt;\n return !expired && shouldRefresh;\n }\n async refreshIf(gracePeriod) {\n if (!this.shouldBeRefreshed(gracePeriod)) {\n return;\n }\n await this.refresh();\n }\n logout() {\n const url = new URL(this.uri.logout);\n url.searchParams.set(\"post_logout_redirect_uri\", this.uri.redirect);\n url.searchParams.set(\"id_token_hint\", this.token.id_token);\n window.location = url;\n }\n\n bearerToken() {\n return `Bearer ${this.token.access_token}`;\n }\n \n interceptor(gracePeriodBefore, gracePeriodAfter){\n return new AuthorizationCodeFlowInterceptor(this, gracePeriodBefore, gracePeriodAfter); \n }\n}\n\nclass AuthorizationCodeFlowInterceptor {\n constructor(session, gracePeriodBefore, gracePeriodAfter) {\n this.session = session;\n this.gracePeriodBefore = gracePeriodBefore || 2000;\n this.gracePeriodAfter = gracePeriodAfter || 30000;\n }\n async intercept(request, chain) {\n await this.session.refreshIf(this.gracePeriodBefore);\n const headers = new Headers(request.options.headers);\n headers.set(\"Authorization\", this.session.bearerToken());\n request.options.headers = headers;\n const response = await chain.proceed(request);\n await this.session.refreshIf(this.gracePeriodAfter);\n return response;\n }\n}\n\n\nexport {AuthorizationCodeFlow, AuthorizationCodeFlowSession, AuthorizationCodeFlowInterceptor };","\nconst timing = {\n sleep(ms) {\n return new Promise(resolve => setTimeout(resolve, ms));\n },\n DEBOUNCE_DEFAULT: 0,\n DEBOUNCE_IMMEDIATE: 1,\n debounce(timeoutMs, func, options) {\n let tid = null;\n let args = [];\n let previousTimestamp = 0;\n let opts = options || timing.DEBOUNCE_DEFAULT;\n\n const later = () => {\n const elapsed = new Date().getTime() - previousTimestamp;\n if (timeoutMs > elapsed) {\n tid = setTimeout(later, timeoutMs - elapsed);\n return;\n }\n tid = null;\n if (opts !== timing.DEBOUNCE_IMMEDIATE) {\n func(...args);\n }\n // This check is needed because `func` can recursively invoke `debounced`.\n if (tid === null) {\n args = [];\n }\n };\n\n return function () {\n args = arguments;\n previousTimestamp = new Date().getTime();\n if (tid === null) {\n tid = setTimeout(later, timeoutMs);\n if (opts === timing.DEBOUNCE_IMMEDIATE) {\n func(...args);\n }\n }\n };\n },\n THROTTLE_DEFAULT: 0,\n THROTTLE_NO_LEADING: 1,\n THROTTLE_NO_TRAILING: 2,\n throttle(timeoutMs, func, options) {\n let tid = null;\n let args = [];\n let previousTimestamp = 0;\n let opts = options || timing.THROTTLE_DEFAULT;\n\n const later = () => {\n previousTimestamp = (opts & timing.THROTTLE_NO_LEADING) ? 0 : new Date().getTime();\n tid = null;\n func(...args);\n if (tid === null) {\n args = [];\n }\n };\n\n return function () {\n const now = new Date().getTime();\n if (!previousTimestamp && (opts & timing.THROTTLE_NO_LEADING)) {\n previousTimestamp = now;\n }\n const remaining = timeoutMs - (now - previousTimestamp);\n args = arguments;\n if (remaining <= 0 || remaining > timeoutMs) {\n if (tid !== null) {\n clearTimeout(tid);\n tid = null;\n }\n previousTimestamp = now;\n func(...args);\n if (tid === null) {\n args = [];\n }\n } else if (tid === null && !(opts & timing.THROTTLE_NO_TRAILING)) {\n tid = setTimeout(later, remaining);\n }\n };\n\n }\n};\n\n\nexport { timing };","class App {\n constructor() {\n this.configurers = [];\n this.initializers = [];\n this.handlers = [];\n this.running = false;\n document.addEventListener(\"DOMContentLoaded\", async () => {\n await Promise.all(this.configurers);\n await Promise.all(this.initializers.map(h => Promise.resolve(h())));\n await Promise.all(this.handlers.map(h => Promise.resolve(h())));\n });\n }\n configure(cb) {\n this.configurers.push(Promise.resolve(cb()));\n return this;\n }\n initialize(cb) {\n this.initializers.push(cb);\n return this;\n }\n ready(cb) {\n this.handlers.push(cb);\n return this;\n }\n}\n\nexport { App };\n","class Wizard {\n constructor(el) {\n this.el = el;\n this.progress = [...el.children].filter(e => e.matches(\"header,ol,ul\"));\n\n this.progress.forEach(p => {\n const children = [...p.children];\n const current = children.filter(e => e.matches(\".active\"))[0];\n if (current === undefined && children.length > 0) {\n children[0].classList.add('active');\n }\n });\n if (this.el.querySelector('section.current') === null) {\n const firstSection = this.el.querySelector('section:first-of-type');\n if (firstSection !== null) {\n firstSection.classList.add('current');\n }\n }\n }\n next() {\n this.progress.forEach(p => {\n const children = [...p.children];\n const current = children.filter(e => e.matches(\".active\"))[0];\n current?.classList.remove('active');\n current?.nextElementSibling?.classList.add('active');\n });\n const currentSection = this.el.querySelector('section.current');\n currentSection.classList.remove(\"current\");\n currentSection.nextElementSibling.classList.add('current');\n\n this.el.dispatchEvent(new CustomEvent('wizard:activate', {\n bubbles: true,\n cancelable: true\n }));\n\n }\n prev() {\n this.progress.forEach(p => {\n const children = [...p.children];\n const current = children.filter(e => e.matches(\".active\"))[0];\n current?.classList.remove('active');\n current?.previousElementSibling?.classList.add('active');\n });\n const currentSection = this.el.querySelector('section.current');\n currentSection.classList.remove(\"current\");\n currentSection.previousElementSibling.classList.add('current');\n this.el.dispatchEvent(new CustomEvent('wizard:activate', {\n bubbles: true,\n cancelable: true\n }));\n }\n moveTo = function (n) {\n this.progress.forEach(p => {\n const children = [...p.children];\n const current = children.filter(e => e.matches(\".active\"))[0];\n current?.classList.remove('active');\n p.children[+n]?.classList.add('active');\n });\n const currentSection = this.el.querySelector('section.current');\n currentSection?.classList.remove(\"current\");\n const nthSection = this.el.querySelector(`section:nth-child(${+n})`);\n nthSection.classList.add('current');\n this.el.dispatchEvent(new CustomEvent('wizard:activate', {\n bubbles: true,\n cancelable: true\n }));\n }\n}\n\n\n\n\nexport { Wizard };\n"],"names":["mutate","mutators","el","raw","key","values","maybeMutator","dataset","getAttribute","value","checked","Base64","static","arrayBuffer","dialect","d","URL_SAFE","len","byteLength","view","Uint8Array","res","i","substring","length","str","nbytes","Math","floor","vi","si","v1","indexOf","charAt","v2","v3","v4","buffer","STANDARD","Form","constructor","bindings","globalErrorsEl","fieldContainerSelector","errorClass","hideClass","this","undefined","DEFAULT_FIELD_CONTAINER_SELECTOR","DEFAULT_ERROR_CLASS","DEFAULT_HIDE_CLASS","setValues","getValues","setErrors","errors","scrollFirstErrorIntoView","context","clearErrors","map","mapError","e","filter","type","forEach","name","replace","Array","from","querySelectorAll","CSS","escape","closest","label","classList","add","reason","globalErrors","innerHTML","join","remove","yOffsets","getBoundingClientRect","y","window","scrollY","firstErrorScrollY","min","Infinity","scroll","scrollX","l","ContextInterceptor","document","querySelector","endsWith","async","request","chain","separator","resource","startsWith","proceed","CsrfTokenInterceptor","k","v","headers","Headers","options","set","RedirectOnUnauthorizedInterceptor","redirectUri","response","status","location","href","Failure","Error","text","def","details","JSON","parse","parseProblems","problems","super","stringify","HttpClientBuilder","interceptors","withContext","push","withCsrfToken","withRedirectOnUnauthorized","withInterceptors","build","HttpClient","HttpCall","fetch","HttpInterceptorChain","current","interceptor","intercept","ok","message","fromResponse","uiOptions","ui","buttons","setAttribute","loader","r","json","form","removeAttribute","Storage","prefix","storage","save","setItem","load","got","getItem","removeItem","pop","decoded","SessionStorage","sessionStorage","AuthorizationCodeFlow","clientId","realmBaseUrl","auth","URL","token","logout","registration","redirect","scope","uri","additionalParams","pkceVerifier","encode","crypto","getRandomValues","pkceChallenge","subtle","digest","TextEncoder","state","PKCE_AND_STATE_KEY","verifier","url","searchParams","Object","entries","kv","action","kcAction","kc_action","code","history","replaceState","stateAndVerifier","method","body","URLSearchParams","AuthorizationCodeFlowSession","get","_tokenExchange","rawHeader","rawPayload","signature","split","ut8decoder","TextDecoder","header","decode","payload","t","accessToken","parseToken","access_token","refreshToken","refresh_token","refreshCallback","onRefresh","callback","_parseToken","shouldBeRefreshed","gracePeriod","now","Date","getTime","refreshTokenExpiresAt","exp","refresh","id_token","bearerToken","gracePeriodBefore","gracePeriodAfter","AuthorizationCodeFlowInterceptor","session","refreshIf","timing","sleep","ms","Promise","resolve","setTimeout","DEBOUNCE_DEFAULT","DEBOUNCE_IMMEDIATE","debounce","timeoutMs","func","tid","args","previousTimestamp","opts","later","elapsed","arguments","THROTTLE_DEFAULT","THROTTLE_NO_LEADING","THROTTLE_NO_TRAILING","throttle","remaining","clearTimeout","configurers","initializers","handlers","running","addEventListener","all","h","configure","cb","initialize","ready","extractors","ignoredChildrenSelector","valueHoldersSelector","hasOwnProperty","reduce","result","path","keys","match","previous","ckey","pkey","Number","isInteger","isArray","providePath","maybeExtractor","extract","hex","lenInBytes","offset","octet","parseInt","bytes","upper","b","toString","toUpperCase","o","padStart","localStorage","dataSupplier","cache","revision","saved","freshData","data","progress","children","matches","p","firstSection","next","nextElementSibling","currentSection","dispatchEvent","CustomEvent","bubbles","cancelable","prev","previousElementSibling","moveTo","n"],"mappings":"iCAsBA,SAASA,EAAOC,EAAUC,EAAIC,EAAKC,EAAKC,GACpC,MAAMC,EAAeL,EAASC,EAAGK,QAAqB,cAAMN,EAASC,EAAGK,QAAqB,aACzFD,EACAA,EAAaJ,EAAIC,EAAKC,EAAKC,GAGC,UAA5BH,EAAGM,aAAa,QAIY,aAA5BN,EAAGM,aAAa,QAIpBN,EAAGO,MAAQN,EAHPD,EAAGQ,QAAUP,EAJbD,EAAGQ,QAAUR,EAAGM,aAAa,WAAaL,CAQlD,CCnCA,MAAMQ,EACFC,cAAcC,EAAaC,GACvB,MAAMC,EAAID,GAAWH,EAAOK,SACtBC,EAAMJ,EAAYK,WAClBC,EAAO,IAAIC,WAAWP,GAC5B,IAAIQ,EAAM,GACV,IAAK,IAAIC,EAAI,EAAGA,EAAIL,EAAKK,GAAK,EAAG,CAK7BD,GAJWN,EAAEI,EAAKG,IAAM,GACbP,GAAc,EAAVI,EAAKG,KAAW,EAAMH,EAAKG,EAAI,IAAM,GACzCP,GAAkB,GAAdI,EAAKG,EAAI,KAAY,EAAMH,EAAKG,EAAI,IAAM,GAC9CP,EAAgB,GAAdI,EAAKG,EAAI,GAEzB,CAMD,OALIL,EAAM,GAAM,EACZI,EAAMA,EAAIE,UAAU,EAAGF,EAAIG,OAAS,GAC7BP,EAAM,GAAM,IACnBI,EAAMA,EAAIE,UAAU,EAAGF,EAAIG,OAAS,IAEjCH,CACV,CACDT,cAAca,EAAKX,GACf,MAAMC,EAAID,GAAWH,EAAOK,SAC5B,IAAIU,EAASC,KAAKC,MAAmB,IAAbH,EAAID,QAC5B,IAAK,IAAIF,EAAI,EAAGA,IAAMG,EAAID,QACU,MAA5BC,EAAIA,EAAID,OAASF,EAAI,KADOA,IAI9BI,EAEN,MAAMP,EAAO,IAAIC,WAAWM,GAE5B,IAAIG,EAAK,EACLC,EAAK,EACT,KAAOD,EAAkB,IAAbJ,EAAID,QAAe,CAC3B,MAAMO,EAAKhB,EAAEiB,QAAQP,EAAIQ,OAAOH,MAC1BI,EAAKnB,EAAEiB,QAAQP,EAAIQ,OAAOH,MAC1BK,EAAKpB,EAAEiB,QAAQP,EAAIQ,OAAOH,MAC1BM,EAAKrB,EAAEiB,QAAQP,EAAIQ,OAAOH,MAChCX,EAAKU,KAASE,GAAM,EAAMG,GAAM,EAChCf,EAAKU,MAAe,GAALK,IAAY,EAAMC,GAAM,EACvChB,EAAKU,MAAe,EAALM,IAAW,EAAKC,CAClC,CAED,OAAOjB,EAAKkB,MACf,EAGL1B,EAAO2B,SAAW,mEAClB3B,EAAOK,SAAW,mEC/ClB,MAAMuB,EACFC,YAAYtC,EAAIuC,GAAUC,eAACA,EAAcC,uBAAEA,EAAsBC,WAAEA,EAAUC,UAAEA,IAC3EC,KAAK5C,GAAKA,EACV4C,KAAKL,SAAWA,EAChBK,KAAKJ,eAAiBA,EACtBI,KAAKH,4BAAoDI,IAA3BJ,EAAuCA,EAAyBJ,EAAKS,iCACnGF,KAAKF,WAAaA,GAAcL,EAAKU,oBACrCH,KAAKD,UAAYA,GAAaN,EAAKW,kBACtC,CACDC,UAAU9C,GACN,OAAOyC,KAAKL,SAASU,UAAUL,KAAK5C,GAAIG,EAC3C,CACD+C,YACI,OAAON,KAAKL,SAASW,UAAUN,KAAK5C,GACvC,CACDmD,UAAUC,EAAQC,EAA0BC,GAgBxC,GAdAV,KAAKW,cACLH,EACSI,IAAIZ,KAAKa,SAAWb,KAAKa,SAAYC,GAAMA,GAC3CC,QAAQD,GAAiB,gBAAXA,EAAEE,MAAqC,mBAAXF,EAAEE,OAC5CC,SAASH,IACN,MAAMI,EAAOJ,EAAEJ,QAAQS,QAAQ,IAAK,KAAKA,QAAQ,KAAM,KACvDC,MAAMC,KAAKrB,KAAK5C,GAAGkE,iBAAiB,UAAUC,IAAIC,OAAON,SAChDN,KAAIxD,GAAM4C,KAAKH,uBAAyBzC,EAAGqE,QAAQzB,KAAKH,wBAA0BzC,IAClF2D,QAAO3D,GAAa,OAAPA,IACb6D,SAAQS,IACLA,EAAMC,UAAUC,IAAI5B,KAAKF,YACzB4B,EAAMjE,QAAe,MAAIqD,EAAEe,MAAM,GACnC,IAElB7B,KAAKJ,eAAgB,CACrB,MAAMkC,EAAetB,EAAOO,QAAQD,GAAiB,gBAAXA,EAAEE,MAAqC,mBAAXF,EAAEE,OACxEhB,KAAKJ,eAAemC,UAAYD,EAAalB,KAAIE,GAAKA,EAAEe,SAAQG,KAAK,MACzC,IAAxBF,EAAapD,QACbsB,KAAKJ,eAAe+B,UAAUM,OAAOjC,KAAKD,UAEjD,CACD,IAAKU,EACD,OAEJ,MAAMyB,EAAWd,MAAMC,KAAKrB,KAAK5C,GAAGkE,iBAAiB,oCAC5CV,KAAKc,GAAUA,EAAMS,wBAAwBC,EAAIC,OAAOC,UAC3DC,EAAoB1D,KAAK2D,OAAON,GAClCK,IAAsBE,KACtBJ,OAAOK,OAAOL,OAAOM,QAASJ,EAAoB,IAAMA,EAAoB,IAAM,EAEzF,CACD5B,cACIX,KAAK5C,GAAGkE,iBAAiB,IAAIC,IAAIC,OAAOxB,KAAKF,eAAemB,SAAQ2B,GAAKA,EAAEjB,UAAUM,OAAOjC,KAAKF,cAC7FE,KAAKJ,iBACLI,KAAKJ,eAAemC,UAAY,GAChC/B,KAAKJ,eAAe+B,UAAUC,IAAI5B,KAAKD,WAE9C,EAGLN,EAAKS,iCAAmC,QACxCT,EAAKU,oBAAsB,YAC3BV,EAAKW,mBAAqB,SC9D1B,MAAMyC,EACFnD,cACI,MAAMgB,EAAUoC,SAASC,cAAc,wBAAwBrF,aAAa,WAC5EsC,KAAKU,QAAUA,EAAQsC,SAAS,KAAOtC,EAAQjC,UAAU,EAAGiC,EAAQhC,OAAS,GAAKgC,CACrF,CACDuC,gBAAgBC,EAASC,GACrB,MAAMC,EAAYF,EAAQG,SAASC,WAAW,KAAO,GAAK,IAE1D,OADAJ,EAAQG,SAAWrD,KAAKU,QAAU0C,EAAYF,EAAQG,eACzCF,EAAMI,QAAQL,EAC9B,EAGL,MAAMM,EACF9D,cACIM,KAAKyD,EAAIX,SAASC,cAAc,6BAA6BrF,aAAa,WAC1EsC,KAAK0D,EAAIZ,SAASC,cAAc,sBAAsBrF,aAAa,UACtE,CACDuF,gBAAgBC,EAASC,GACrB,MAAMQ,EAAU,IAAIC,QAAQV,EAAQW,QAAQF,SAG5C,OAFAA,EAAQG,IAAI9D,KAAKyD,EAAGzD,KAAK0D,GACzBR,EAAQW,QAAQF,QAAUA,QACbR,EAAMI,QAAQL,EAC9B,EAGL,MAAMa,EACFrE,YAAYsE,GACRhE,KAAKgE,YAAcA,CACtB,CACDf,gBAAgBC,EAASC,GACrB,MAAMc,QAAkBd,EAAMI,QAAQL,GACtC,GAAwB,MAApBe,EAASC,OACT,OAAOD,EAEX5B,OAAO8B,SAASC,KAAOJ,WAC1B,EAGL,MAAMK,UAAgBC,MAClBxG,qBAAqBoG,EAAQK,GACzB,MAAMC,EAAM,CAAC,CACLxD,KAAM,kBACNN,QAAS,KACTmB,OAAQ,GAAGqC,MAAWK,IACtBE,QAAS,OAEjB,IACI,OAAOF,EAAOG,KAAKC,MAAMJ,GAAQC,CAGpC,CAFC,MAAO1D,GACL,OAAO0D,CACV,CACJ,CACD1G,oBAAoBoG,EAAQK,GACxB,OAAO,IAAIF,EAAQH,EAAQG,EAAQO,cAAcV,EAAQK,GAC5D,CACD7E,YAAYwE,EAAQW,GAChBC,MAAMJ,KAAKK,UAAUF,IACrB7E,KAAKkB,KAAO,WAAWgD,IACvBlE,KAAKkE,OAASA,EACdlE,KAAK6E,SAAWA,CACnB,EAGL,MAAMG,EACFtF,cACIM,KAAKiF,aAAe,EACvB,CACDC,cAEI,OADAlF,KAAKiF,aAAaE,KAAK,IAAItC,GACpB7C,IACV,CACDoF,gBAEI,OADApF,KAAKiF,aAAaE,KAAK,IAAI3B,GACpBxD,IACV,CACDqF,2BAA2BrB,GAEvB,OADAhE,KAAKiF,aAAaE,KAAK,IAAIpB,EAAkCC,IACtDhE,IACV,CACDsF,oBAAoBL,GAEhB,OADAjF,KAAKiF,aAAaE,QAAQF,GACnBjF,IACV,CACDuF,QACI,MAAMN,EAAejF,KAAKiF,aAC1B,OAAO,IAAIO,EAAW,CAACP,gBAC1B,EAGL,MAAMQ,EACFxC,gBAAgBC,EAASC,GACrB,aAAauC,MAAMxC,EAAQG,SAAUH,EAAQW,QAChD,EAGL,MAAM8B,EACFjG,YAAYuF,EAAcW,GACtB5F,KAAKiF,aAAeA,EACpBjF,KAAK4F,QAAUA,CAClB,CACD3C,cAAcC,GACV,MAAM2C,EAAc7F,KAAKiF,aAAajF,KAAK4F,SAC3C,aAAaC,EAAYC,UAAU5C,EAAS,IAAIyC,EAAqB3F,KAAKiF,aAAcjF,KAAK4F,QAAU,GAC1G,EAIL,MAAMJ,EACF1H,iBACI,OAAO,IAAIkH,CACd,CACDtF,aAAYuF,aAACA,IACTjF,KAAKiF,aAAeA,GAAgB,EACvC,CACDhC,YAAYI,EAAUQ,GAClB,MAAMoB,EAAe,IAAIjF,KAAKiF,gBAAiBpB,EAAQoB,cAAgB,GAAI,IAAIQ,GACzEtC,EAAQ,IAAIwC,EAAqBV,EAAc,GACrD,aAAa9B,EAAMI,QAAQ,CAACF,WAAUQ,WACzC,CACDZ,WAAWI,EAAUQ,GACjB,IACI,MAAMI,QAAiBjE,KAAK0F,MAAMrC,EAAUQ,GAC5C,IAAKI,EAAS8B,GAAI,CACd,MAAMC,QAAgB/B,EAASM,OAC/B,MAAMF,EAAQ4B,aAAahC,EAASC,OAAQ8B,EAC/C,CACD,MAAMzB,QAAaN,EAASM,OAC5B,OAAOA,EAAOG,KAAKC,MAAMJ,QAAQtE,CAWpC,CAVC,MAAOa,GACL,GAAIA,aAAauD,EACb,MAAMvD,EAEV,MAAM,IAAIuD,EAAQ,EAAG,CAAC,CACdrD,KAAM,qBACNN,QAAS,KACTmB,OAAQf,EAAEkF,QACVvB,QAAS,OAEpB,CACJ,CACDxB,WAAWI,EAAUQ,EAASqC,GAC1B,MAAMC,EAAKD,GAAa,GACxBC,EAAGC,SAASnF,SAAQ7D,IAChBA,EAAGiJ,aAAa,WAAY,YACxBF,EAAGG,SACHlJ,EAAGK,QAAoB,WAAIL,EAAG2E,UAC9B3E,EAAG2E,UAAYoE,EAAGG,OACrB,IAEL,IACI,MAAMC,QAAUvG,KAAKwG,KAAKnD,EAAUQ,GAEpC,OADAsC,EAAGM,MAAM9F,cACF4F,CAUV,CATC,MAAOzF,GAEL,MADAqF,EAAGM,MAAMlG,UAAUO,EAAE+D,UACf/D,CAClB,CAAkB,QACNqF,EAAGC,SAASnF,SAAQ7D,IAChBA,EAAGsJ,gBAAgB,YACnBtJ,EAAG2E,UAAY3E,EAAGK,QAAoB,kBAC/BL,EAAGK,QAAoB,UAAC,GAEtC,CACJ,EClKL,MAAMkJ,EACFjH,YAAYkH,EAAQC,GAChB7G,KAAK4G,OAASA,EACd5G,KAAK6G,QAAUA,CAClB,CACDC,KAAKrD,EAAGC,GACJ1D,KAAK6G,QAAQE,QAAQ,GAAG/G,KAAK4G,UAAUnD,IAAKiB,KAAKK,UAAUrB,GAC9D,CACDsD,KAAKvD,GACD,MAAMwD,EAAMjH,KAAK6G,QAAQK,QAAQ,GAAGlH,KAAK4G,UAAUnD,KACnD,YAAexD,IAARgH,OAAoBhH,EAAYyE,KAAKC,MAAMsC,EACrD,CACDhF,OAAOwB,GACHzD,KAAK6G,QAAQM,WAAW,GAAGnH,KAAK4G,UAAUnD,IAC7C,CACD2D,IAAI3D,GACA,MAAM4D,EAAUrH,KAAKgH,KAAKvD,GAE1B,OADAzD,KAAKiC,OAAOwB,GACL4D,CACV,EASL,MAAMC,UAAuBX,EACzBjH,YAAYkH,GACR9B,MAAM8B,EAAQW,eACjB,EC5BL,MAAMC,EACF1J,mBAAmB2J,EAAUC,EAAc1D,GAEvC,OAAO,IAAIwD,EAAsBC,EADnB,iBACoC,CAC9CE,KAAM,IAAIC,IAAI,+BAAgCF,GAC9CG,MAAO,IAAID,IAAI,gCAAiCF,GAChDI,OAAQ,IAAIF,IAAI,iCAAkCF,GAClDK,aAAc,IAAIH,IAAI,wCAAyCF,GAC/DM,SAAUhE,GAEjB,CACDtE,YAAY+H,EAAUQ,GAAON,KAACA,EAAIE,MAAEA,EAAKE,aAAEA,EAAYD,OAAEA,EAAME,SAAEA,IAC7DhI,KAAK6G,QAAU,IAAIS,EAAeG,GAClCzH,KAAKyH,SAAWA,EAChBzH,KAAKiI,MAAQA,EACbjI,KAAKkI,IAAM,CAACP,OAAME,QAAOE,eAAcD,SAAQE,WAClD,CACD/E,aAAaiF,EAAKC,GACd,MAAMC,EAAevK,EAAOwK,OAAOC,OAAOC,gBAAgB,IAAIjK,WAAW,KAAKiB,QACxEiJ,EAAgB3K,EAAOwK,aAAaC,OAAOG,OAAOC,OAAO,WAAW,IAAIC,aAAcN,OAAOD,KAC7FQ,EAAQ5I,KAAKyH,SAAW5J,EAAOwK,OAAOC,OAAOC,gBAAgB,IAAIjK,WAAW,KAAKiB,QACvFS,KAAK6G,QAAQC,KAAKU,EAAsBqB,mBAAoB,CACxDD,MAAOA,EACPE,SAAUV,IAEd,MAAMW,EAAM,IAAInB,IAAIM,GACpBa,EAAIC,aAAalF,IAAI,YAAa9D,KAAKyH,UACvCsB,EAAIC,aAAalF,IAAI,eAAgB9D,KAAKkI,IAAIF,UAC9Ce,EAAIC,aAAalF,IAAI,gBAAiB,QACtCiF,EAAIC,aAAalF,IAAI,QAAS9D,KAAKiI,OACnCc,EAAIC,aAAalF,IAAI,QAAS8E,GAC9BG,EAAIC,aAAalF,IAAI,iBAAkB0E,GACvCO,EAAIC,aAAalF,IAAI,wBAAyB,QAC9CmF,OAAOC,QAAQf,GAAoB,CAAE,GAAElH,SAAQkI,IAC3CJ,EAAIC,aAAalF,IAAIqF,EAAG,GAAIA,EAAG,GAAG,IAEtC9G,OAAO8B,SAAW4E,CACrB,CACD9F,mBAAmBkF,SACTnI,KAAKoJ,OAAOpJ,KAAKkI,IAAIH,aAAcI,EAC5C,CACDlF,iCAAiCoG,SACvBrJ,KAAKoJ,OAAOpJ,KAAKkI,IAAIP,KAAM,CAC7B2B,UAAWD,GAElB,CACDpG,qBAAqBsG,EAAMX,GACvBvG,OAAOmH,QAAQC,aAAa,GAAI,GAAIzJ,KAAKkI,IAAIF,UAC7C,MAAM0B,EAAmB1J,KAAK6G,QAAQO,IAAII,EAAsBqB,oBAChE,GAAIa,EAAiBd,QAAUA,EAC3B,MAAM,IAAItE,MAAM,kBAEpB,MAAML,QAAiByB,MAAM1F,KAAKkI,IAAIL,MAAO,CACzC8B,OAAQ,OACRhG,QAAS,CACL,eAAgB,qCAEpBiG,KAAM,IAAIC,gBAAgB,CACtB,CAAC,YAAa7J,KAAKyH,UACnB,CAAC,OAAQ8B,GACT,CAAC,aAAc,sBACf,CAAC,gBAAiBG,EAAiBZ,UACnC,CAAC,QAASY,EAAiBd,OAC3B,CAAC,eAAgB5I,KAAKkI,IAAIF,cAGlC,IAAK/D,EAAS8B,GAAI,CACd,MAAMxB,QAAaN,EAASM,OAC5B,MAAM,IAAID,MAAM,SAAWL,EAASC,OAAS,KAAOK,EACvD,CACD,MAAMsD,QAAc5D,EAASuC,OAC7B,OAAO,IAAIsD,EAA6B9J,KAAKyH,SAAUI,EAAO7H,KAAKkI,IACtE,CACDjF,uBACI,MAAM8F,EAAM,IAAInB,IAAIvF,OAAO8B,SAASC,MAC9BmF,EAAOR,EAAIC,aAAae,IAAI,QAClC,GAAIR,GAAQvJ,KAAK6G,QAAQG,KAAKQ,EAAsBqB,oBAAqB,CAErE,MAAMD,EAAQG,EAAIC,aAAae,IAAI,SACnC,aAAa/J,KAAKgK,eAAeT,EAAMX,EAC1C,CAGD,aADM5I,KAAKoJ,OAAOpJ,KAAKkI,IAAIP,KAAM,CAAA,GAC1B,IACV,EAELH,EAAsBqB,mBAAqB,qBAE3C,MAAMiB,EACFhM,kBAAkB+J,GACd,MAAOoC,EAAWC,EAAYC,GAAatC,EAAMuC,MAAM,KACjDC,EAAa,IAAIC,YAAY,SACnC,MAAO,CACHC,OAAQ7F,KAAKC,MAAM0F,EAAWG,OAAO3M,EAAO2M,OAAOP,EAAWpM,EAAO2B,YACrEiL,QAAS/F,KAAKC,MAAM0F,EAAWG,OAAO3M,EAAO2M,OAAON,EAAYrM,EAAO2B,YACvE2K,UAAWA,EAElB,CACDzK,YAAY+H,EAAUiD,GAAG7C,MAACA,EAAKC,OAAEA,EAAME,SAAEA,IACrChI,KAAKyH,SAAWA,EAChBzH,KAAK6H,MAAQ6C,EACb1K,KAAK2K,YAAcb,EAA6Bc,WAAWF,EAAEG,cAC7D7K,KAAK8K,aAAehB,EAA6Bc,WAAWF,EAAEK,eAC9D/K,KAAKkI,IAAM,CAAEL,QAAOC,SAAQE,YAC5BhI,KAAKgL,gBAAkB,IAC1B,CACDC,UAAUC,GACNlL,KAAKgL,gBAAkBE,CAC1B,CACDjI,gBACI,MAAMgB,QAAiByB,MAAM1F,KAAKkI,IAAIL,MAAO,CACzC8B,OAAQ,OACRhG,QAAS,CACL,eAAgB,qCAEpBiG,KAAM,IAAIC,gBAAgB,CACtB,CAAC,YAAa7J,KAAKyH,UACnB,CAAC,aAAc,iBACf,CAAC,gBAAiBzH,KAAK6H,MAAMkD,mBAGrC,IAAK9G,EAAS8B,GACV,MAAM,IAAIzB,MAAM,SAAWL,EAASsF,KAAO,KAAOtF,EAASM,QAE/D,MAAMsD,QAAc5D,EAASuC,OAC7BxG,KAAK6H,MAAQA,EACb7H,KAAK2K,YAAc3K,KAAKmL,YAAYtD,EAAMgD,cAC1C7K,KAAK8K,aAAe9K,KAAKmL,YAAYtD,EAAMkD,eACvC/K,KAAKgL,iBACLhL,KAAKgL,gBAAgBhL,KAAK6H,MAAO7H,KAAK2K,YAAa3K,KAAK8K,aAE/D,CACDM,kBAAkBC,GACd,MAAMC,GAAM,IAAIC,MAAOC,UACjBC,EAAwD,IAAhCzL,KAAK8K,aAAaL,QAAQiB,IAGxD,QAFgBJ,EAAMG,IACAH,EAAMD,EAAcI,CAE7C,CACDxI,gBAAgBoI,GACPrL,KAAKoL,kBAAkBC,UAGtBrL,KAAK2L,SACd,CACD7D,SACI,MAAMiB,EAAM,IAAInB,IAAI5H,KAAKkI,IAAIJ,QAC7BiB,EAAIC,aAAalF,IAAI,2BAA4B9D,KAAKkI,IAAIF,UAC1De,EAAIC,aAAalF,IAAI,gBAAiB9D,KAAK6H,MAAM+D,UACjDvJ,OAAO8B,SAAW4E,CACrB,CAED8C,cACI,MAAO,UAAU7L,KAAK6H,MAAMgD,cAC/B,CAEDhF,YAAYiG,EAAmBC,GAC3B,OAAO,IAAIC,EAAiChM,KAAM8L,EAAmBC,EACxE,EAGL,MAAMC,EACFtM,YAAYuM,EAASH,EAAmBC,GACpC/L,KAAKiM,QAAUA,EACfjM,KAAK8L,kBAAoBA,GAAqB,IAC9C9L,KAAK+L,iBAAmBA,GAAoB,GAC/C,CACD9I,gBAAgBC,EAASC,SACfnD,KAAKiM,QAAQC,UAAUlM,KAAK8L,mBAClC,MAAMnI,EAAU,IAAIC,QAAQV,EAAQW,QAAQF,SAC5CA,EAAQG,IAAI,gBAAiB9D,KAAKiM,QAAQJ,eAC1C3I,EAAQW,QAAQF,QAAUA,EAC1B,MAAMM,QAAiBd,EAAMI,QAAQL,GAErC,aADMlD,KAAKiM,QAAQC,UAAUlM,KAAK+L,kBAC3B9H,CACV,EClLA,MAACkI,EAAS,CACXC,MAAMC,GACK,IAAIC,SAAQC,GAAWC,WAAWD,EAASF,KAEtDI,iBAAkB,EAClBC,mBAAoB,EACpBC,SAASC,EAAWC,EAAMhJ,GACtB,IAAIiJ,EAAM,KACNC,EAAO,GACPC,EAAoB,EACpBC,EAAOpJ,GAAWsI,EAAOM,iBAE7B,MAAMS,EAAQ,KACV,MAAMC,GAAU,IAAI5B,MAAOC,UAAYwB,EACnCJ,EAAYO,EACZL,EAAMN,WAAWU,EAAON,EAAYO,IAGxCL,EAAM,KACFG,IAASd,EAAOO,oBAChBG,KAAQE,GAGA,OAARD,IACAC,EAAO,IACV,EAGL,OAAO,WACHA,EAAOK,UACPJ,GAAoB,IAAIzB,MAAOC,UACnB,OAARsB,IACAA,EAAMN,WAAWU,EAAON,GACpBK,IAASd,EAAOO,oBAChBG,KAAQE,GAG5B,CACK,EACDM,iBAAkB,EAClBC,oBAAqB,EACrBC,qBAAsB,EACtBC,SAASZ,EAAWC,EAAMhJ,GACtB,IAAIiJ,EAAM,KACNC,EAAO,GACPC,EAAoB,EACpBC,EAAOpJ,GAAWsI,EAAOkB,iBAE7B,MAAMH,EAAQ,KACVF,EAAqBC,EAAOd,EAAOmB,oBAAuB,GAAI,IAAI/B,MAAOC,UACzEsB,EAAM,KACND,KAAQE,GACI,OAARD,IACAC,EAAO,GACV,EAGL,OAAO,WACH,MAAMzB,GAAM,IAAIC,MAAOC,WAClBwB,GAAsBC,EAAOd,EAAOmB,sBACrCN,EAAoB1B,GAExB,MAAMmC,EAAYb,GAAatB,EAAM0B,GACrCD,EAAOK,UACHK,GAAa,GAAKA,EAAYb,GAClB,OAARE,IACAY,aAAaZ,GACbA,EAAM,MAEVE,EAAoB1B,EACpBuB,KAAQE,GACI,OAARD,IACAC,EAAO,KAEI,OAARD,GAAkBG,EAAOd,EAAOoB,uBACvCT,EAAMN,WAAWU,EAAOO,GAExC,CAEK,gBChFL,MACI/N,cACIM,KAAK2N,YAAc,GACnB3N,KAAK4N,aAAe,GACpB5N,KAAK6N,SAAW,GAChB7N,KAAK8N,SAAU,EACfhL,SAASiL,iBAAiB,oBAAoB9K,gBACpCqJ,QAAQ0B,IAAIhO,KAAK2N,mBACjBrB,QAAQ0B,IAAIhO,KAAK4N,aAAahN,KAAIqN,GAAK3B,QAAQC,QAAQ0B,cACvD3B,QAAQ0B,IAAIhO,KAAK6N,SAASjN,KAAIqN,GAAK3B,QAAQC,QAAQ0B,OAAM,GAEtE,CACDC,UAAUC,GAEN,OADAnO,KAAK2N,YAAYxI,KAAKmH,QAAQC,QAAQ4B,MAC/BnO,IACV,CACDoO,WAAWD,GAEP,OADAnO,KAAK4N,aAAazI,KAAKgJ,GAChBnO,IACV,CACDqO,MAAMF,GAEF,OADAnO,KAAK6N,SAAS1I,KAAKgJ,GACZnO,IACV,yHP4CL,MAEIN,aAAa4O,WAACA,EAAUnR,SAAEA,EAAQoR,wBAAEA,EAAuBC,qBAAEA,IACzDxO,KAAKsO,WAAaA,GAAc,GAChCtO,KAAK7C,SAAWA,GAAY,GAC5B6C,KAAKwO,qBAAuBA,GAAwB,4CACpDxO,KAAKuO,wBAA0BA,GAA2B,SAC7D,CACDlO,UAAUjD,EAAIG,GACV,IAAK,IAAIkG,KAAKlG,EACLA,EAAOkR,eAAehL,IAG3BrC,MAAMC,KAAKjE,EAAGkE,iBAAiB,UAAUC,IAAIC,OAAOiC,SAASxC,SAAS7D,IAClEF,EAAO8C,KAAK7C,SAAUC,EAAIG,EAAOkG,GAAIA,EAAGlG,EAAO,GAG1D,CACD+C,UAAUlD,GACN,OAAOgE,MAAMC,KAAKjE,EAAGkE,iBAAiBtB,KAAKwO,uBAClCzN,QAAQ3D,GAC6B,UAA9BA,EAAGK,QAAqB,cAGS,WAA9BL,EAAGK,QAAqB,aAA+D,OAA7CL,EAAGqE,QAAQzB,KAAKuO,4BAEpEG,QAAO,CAACC,EAAQvR,IArDjC,SAAqBuR,EAAQC,EAAMjR,GAC/B,MAAMkR,EAAOD,EAAKxE,MAAM,KAAKxJ,KAAK6C,GAAMA,EAAEqL,MAAM,aAAerL,EAAIA,IACnE,IAAImC,EAAU+I,EACVI,EAAW,KACf,IAAK,IAAIvQ,EAAI,KAAOA,EAAG,CACnB,MAAMwQ,EAAOH,EAAKrQ,GACZyQ,EAAOJ,EAAKrQ,EAAI,GAQtB,GAPI0Q,OAAOC,UAAUH,KAAU5N,MAAMgO,QAAQxJ,KACxB,OAAbmJ,EACAA,EAASE,GAAQrJ,EAAU,GAE3B+I,EAAS/I,EAAU,IAGvBpH,IAAMqQ,EAAKnQ,OAAS,EAGpB,OADAkH,EAAQoJ,QAAkB/O,IAAVtC,EAAsBA,EAASqR,KAAQpJ,EAAUA,EAAQoJ,GAAQ,KAC1EL,OAEW1O,IAAlB2F,EAAQoJ,KACRpJ,EAAQoJ,GAAQ,IAEpBD,EAAWnJ,EACXA,EAAUA,EAAQoJ,EACrB,CACL,CA6B2BK,CAAYV,EAAQvR,EAAGM,aAAa,QA5F/D,SAAiB4Q,EAAYlR,GACzB,MAAMkS,EAAiBhB,EAAWlR,EAAGK,QAAuB,gBAAM6Q,EAAWlR,EAAGK,QAAqB,aACrG,GAAI6R,EACA,OAAOA,EAAelS,GAE1B,GAAgC,UAA5BA,EAAGM,aAAa,QAAqB,CACrC,IAAKN,EAAGQ,QACJ,OAEJ,MAAkC,YAA3BR,EAAGK,QAAkB,SAA+B,SAAbL,EAAGO,MAAmBP,EAAGO,KAC1E,CACD,MAAgC,aAA5BP,EAAGM,aAAa,QACTN,EAAGQ,QAEiB,YAA3BR,EAAGK,QAAkB,SACbL,EAAGO,MAA4B,SAAbP,EAAGO,MAAV,KAEhBP,EAAGO,OAAS,IACvB,CA0EwE4R,CAAQvP,KAAKsO,WAAYlR,KAC9E,CAAE,EAChB,8BC3CL,MACIU,cAAc0R,GACV,GAAIA,EAAI9Q,OAAS,GAAM,EACnB,MAAM,IAAI4F,MAAM,kBAEpB,MAAMmL,EAAaD,EAAI9Q,OAAS,EAChC,OAAO,IAAIJ,WAAWmR,GAAY7O,KAAI,CAACE,EAAGtC,KACtC,MAAMkR,EAAa,EAAJlR,EACTmR,EAAQH,EAAI/Q,UAAUiR,EAAQA,EAAS,GAC7C,OAAOE,SAASD,EAAO,GAAG,GAEjC,CACD7R,cAAc+R,EAAOC,GACjB,OAAO1O,MAAMC,KAAKwO,GACTjP,KAAImP,GAAKA,EAAEC,SAAS,MACpBpP,KAAImP,GAAKD,EAAQC,EAAEE,cAAgBF,IACnCnP,KAAIsP,GAAKA,EAAEC,SAAS,EAAG,KACvBnO,KAAK,GACjB,iCGhDL,cAA2B2E,EACvBjH,YAAYkH,GACR9B,MAAM8B,EAAQwJ,aACjB,yCASL,MACI1Q,YAAYmH,EAASvJ,EAAK+S,GACtBrQ,KAAK6G,QAAUA,EACf7G,KAAK1C,IAAMA,EACX0C,KAAKqQ,aAAeA,EACpBrQ,KAAKsQ,MAAQ,IAEhB,CACDrN,WAAWsN,GACP,MAAMC,EAAQxQ,KAAK6G,QAAQG,KAAKhH,KAAK1C,KACrC,GAAMkT,GAASA,EAAMD,WAAaA,EAE9B,YADAvQ,KAAKsQ,MAAQE,EAAM7S,OAGvB,MAAM8S,QAAkBzQ,KAAKqQ,aAAaE,EAAUvQ,KAAK1C,KACzD0C,KAAK6G,QAAQC,KAAK9G,KAAK1C,IAAK,CACxBiT,SAAUA,EACV5S,MAAO8S,IAEXzQ,KAAKsQ,MAAQG,CAChB,CACDC,OACI,OAAO1Q,KAAKsQ,KACf,YI1DL,MACI5Q,YAAYtC,GAWR,GAVA4C,KAAK5C,GAAKA,EACV4C,KAAK2Q,SAAW,IAAIvT,EAAGwT,UAAU7P,QAAOD,GAAKA,EAAE+P,QAAQ,kBAEvD7Q,KAAK2Q,SAAS1P,SAAQ6P,IAClB,MAAMF,EAAW,IAAIE,EAAEF,eAEP3Q,IADA2Q,EAAS7P,QAAOD,GAAKA,EAAE+P,QAAQ,aAAY,IAC9BD,EAASlS,OAAS,GAC3CkS,EAAS,GAAGjP,UAAUC,IAAI,SAC7B,IAE4C,OAA7C5B,KAAK5C,GAAG2F,cAAc,mBAA6B,CACnD,MAAMgO,EAAe/Q,KAAK5C,GAAG2F,cAAc,yBACtB,OAAjBgO,GACAA,EAAapP,UAAUC,IAAI,UAElC,CACJ,CACDoP,OACIhR,KAAK2Q,SAAS1P,SAAQ6P,IAClB,MACMlL,EADW,IAAIkL,EAAEF,UACE7P,QAAOD,GAAKA,EAAE+P,QAAQ,aAAY,GAC3DjL,GAASjE,UAAUM,OAAO,UAC1B2D,GAASqL,oBAAoBtP,UAAUC,IAAI,SAAS,IAExD,MAAMsP,EAAiBlR,KAAK5C,GAAG2F,cAAc,mBAC7CmO,EAAevP,UAAUM,OAAO,WAChCiP,EAAeD,mBAAmBtP,UAAUC,IAAI,WAEhD5B,KAAK5C,GAAG+T,cAAc,IAAIC,YAAY,kBAAmB,CACrDC,SAAS,EACTC,YAAY,IAGnB,CACDC,OACIvR,KAAK2Q,SAAS1P,SAAQ6P,IAClB,MACMlL,EADW,IAAIkL,EAAEF,UACE7P,QAAOD,GAAKA,EAAE+P,QAAQ,aAAY,GAC3DjL,GAASjE,UAAUM,OAAO,UAC1B2D,GAAS4L,wBAAwB7P,UAAUC,IAAI,SAAS,IAE5D,MAAMsP,EAAiBlR,KAAK5C,GAAG2F,cAAc,mBAC7CmO,EAAevP,UAAUM,OAAO,WAChCiP,EAAeM,uBAAuB7P,UAAUC,IAAI,WACpD5B,KAAK5C,GAAG+T,cAAc,IAAIC,YAAY,kBAAmB,CACrDC,SAAS,EACTC,YAAY,IAEnB,CACDG,OAAS,SAAUC,GACf1R,KAAK2Q,SAAS1P,SAAQ6P,IACD,IAAIA,EAAEF,UACE7P,QAAOD,GAAKA,EAAE+P,QAAQ,aAAY,IAClDlP,UAAUM,OAAO,UAC1B6O,EAAEF,UAAUc,IAAI/P,UAAUC,IAAI,SAAS,IAEpB5B,KAAK5C,GAAG2F,cAAc,oBAC7BpB,UAAUM,OAAO,WACdjC,KAAK5C,GAAG2F,cAAc,sBAAsB2O,MACpD/P,UAAUC,IAAI,WACzB5B,KAAK5C,GAAG+T,cAAc,IAAIC,YAAY,kBAAmB,CACrDC,SAAS,EACTC,YAAY,IAEnB"}
package/dist/ful.min.mjs CHANGED
@@ -1,2 +1,2 @@
1
- function e(e,t,r,s,i){const o=e[t.dataset.bindMutator]||e[t.dataset.bindProvide];o?o(t,r,s,i):"radio"!==t.getAttribute("type")?"checkbox"!==t.getAttribute("type")?t.value=r:t.checked=r:t.checked=t.getAttribute("value")===r}class t{constructor({extractors:e,mutators:t,ignoredChildrenSelector:r,valueHoldersSelector:s}){this.extractors=e||{},this.mutators=t||{},this.valueHoldersSelector=s||"input[name], select[name], textarea[name]",this.ignoredChildrenSelector=r||".d-none"}setValues(t,r){for(let s in r)r.hasOwnProperty(s)&&Array.from(t.querySelectorAll(`[name='${CSS.escape(s)}']`)).forEach((t=>{e(this.mutators,t,r[s],s,r)}))}getValues(e){return Array.from(e.querySelectorAll(this.valueHoldersSelector)).filter((e=>"never"!==e.dataset.bindInclude&&("always"===e.dataset.bindInclude||null===e.closest(this.ignoredChildrenSelector)))).reduce(((e,t)=>function(e,t,r){const s=t.split(".").map((e=>e.match(/^[0-9]+$/)?+e:e));let i=e,o=null;for(let t=0;;++t){const n=s[t],a=s[t-1];if(Number.isInteger(n)&&!Array.isArray(i)&&(null!==o?o[a]=i=[]:e=i=[]),t===s.length-1)return i[n]=void 0!==r?r:n in i?i[n]:null,e;void 0===i[n]&&(i[n]={}),o=i,i=i[n]}}(e,t.getAttribute("name"),function(e,t){const r=e[t.dataset.bindExtractor]||e[t.dataset.bindProvide];if(r)return r(t);if("radio"===t.getAttribute("type")){if(!t.checked)return;return"boolean"===t.dataset.bindType?"true"===t.value:t.value}return"checkbox"===t.getAttribute("type")?t.checked:"boolean"===t.dataset.bindType?t.value?"true"===t.value:null:t.value||null}(this.extractors,t))),{})}}class r{static encode(e,t){const s=t||r.URL_SAFE,i=e.byteLength,o=new Uint8Array(e);let n="";for(let e=0;e<i;e+=3){n+=s[o[e]>>2]+s[(3&o[e])<<4|o[e+1]>>4]+s[(15&o[e+1])<<2|o[e+2]>>6]+s[63&o[e+2]]}return i%3==2?n=n.substring(0,n.length-1):i%3==1&&(n=n.substring(0,n.length-2)),n}static decode(e,t){const s=t||r.URL_SAFE;let i=Math.floor(.75*e.length);for(let t=0;t!==e.length&&"="===e[e.length-t-1];++t)--i;const o=new Uint8Array(i);let n=0,a=0;for(;n<.75*e.length;){const t=s.indexOf(e.charAt(a++)),r=s.indexOf(e.charAt(a++)),i=s.indexOf(e.charAt(a++)),c=s.indexOf(e.charAt(a++));o[n++]=t<<2|r>>4,o[n++]=(15&r)<<4|i>>2,o[n++]=(3&i)<<6|c}return o.buffer}}r.STANDARD="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",r.URL_SAFE="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_";class s{static decode(e){if(e.length%2!=0)throw new Error("invalid length");const t=e.length/2;return new Uint8Array(t).map(((t,r)=>{const s=2*r,i=e.substring(s,s+2);return parseInt(i,16)}))}static encode(e,t){return Array.from(e).map((e=>e.toString(16))).map((e=>t?e.toUpperCase():e)).map((e=>e.padStart(2,0))).join("")}}class i{constructor(e,t,{globalErrorsEl:r,fieldContainerSelector:s,errorClass:o,hideClass:n}){this.el=e,this.bindings=t,this.globalErrorsEl=r,this.fieldContainerSelector=void 0!==s?s:i.DEFAULT_FIELD_CONTAINER_SELECTOR,this.errorClass=o||i.DEFAULT_ERROR_CLASS,this.hideClass=n||i.DEFAULT_HIDE_CLASS}setValues(e){return this.bindings.setValues(this.el,e)}getValues(){return this.bindings.getValues(this.el)}setErrors(e,t,r){if(this.clearErrors(),e.map(this.mapError?this.mapError:e=>e).filter((e=>"FIELD_ERROR"===e.type||"INVALID_FORMAT"===e.type)).forEach((e=>{const t=e.context.replace("[",".").replace("].",".");Array.from(this.el.querySelectorAll(`[name='${CSS.escape(t)}']`)).map((e=>this.fieldContainerSelector?e.closest(this.fieldContainerSelector):e)).filter((e=>null!==e)).forEach((t=>{t.classList.add(this.errorClass),t.dataset.error=e.reason}))})),this.globalErrorsEl){const t=e.filter((e=>"FIELD_ERROR"!==e.type&&"INVALID_FORMAT"!==e.type));this.globalErrorsEl.innerHTML=t.map((e=>e.reason)).join("\n"),0!==t.length&&this.globalErrorsEl.classList.remove(this.hideClass)}if(!t)return;const s=Array.from(this.el.querySelectorAll(".${CSS.escape(this.errorClass)}")).map((e=>e.getBoundingClientRect().y+window.scrollY)),i=Math.min(...s);i!==1/0&&window.scroll(window.scrollX,i>100?i-100:0)}clearErrors(){this.el.querySelectorAll(`.${CSS.escape(this.errorClass)}`).forEach((e=>e.classList.remove(this.errorClass))),this.globalErrorsEl&&(this.globalErrorsEl.innerHTML="",this.globalErrorsEl.classList.add(this.hideClass))}}i.DEFAULT_FIELD_CONTAINER_SELECTOR="label",i.DEFAULT_ERROR_CLASS="has-error",i.DEFAULT_HIDE_CLASS="d-none";class o{constructor(){const e=document.querySelector("meta[name='context']").getAttribute("content");this.context=e.endsWith("/")?e.substring(0,e.length-1):e}before(e){const t=e.resource.startsWith("/")?"":"/";e.resource=this.context+t+e.resource}}class n{constructor(){this.k=document.querySelector("meta[name='_csrf_header']").getAttribute("content"),this.v=document.querySelector("meta[name='_csrf']").getAttribute("content")}before(e){const t=new Headers(e.options.headers);t.set(this.k,this.v),e.options.headers=t}}class a{constructor(e){this.redirectUri=e}after(e,t){401===t.status&&(window.location.href=redirectUri)}}class c extends Error{static parseProblems(e,t){const r=[{type:"GENERIC_PROBLEM",context:null,reason:`${e}: ${t}`,details:null}];try{return t?JSON.parse(t):r}catch(e){return r}}static fromResponse(e,t){return new c(e,c.parseProblems(e,t))}constructor(e,t){super(JSON.stringify(t)),this.name=`Failure:${e}`,this.status=e,this.problems=t}}class l{constructor(){this.interceptors=[]}withContext(){return this.interceptors.push(new o),this}withCsrfToken(){return this.interceptors.push(new n),this}withRedirectOnUnauthorized(e){return this.interceptors.push(new a(e)),this}withInterceptors(...e){return this.interceptors.push(...e),this}build(){const e=this.interceptors;return new h({interceptors:e})}}class h{static builder(){return new l}constructor({interceptors:e}){this.interceptors=e||[]}async fetch(e,t){const r=this.interceptors.concat(t.interceptors||[]),s={resource:e,options:t};await r.forEach((async e=>{e.before&&await e.before(s)}));const i=await fetch(s.resource,s.options);return await r.forEach((async e=>{e.after&&await e.after(s,i)})),i}async json(e,t){try{const r=await this.fetch(e,t);if(!r.ok){const e=await r.text();throw c.fromResponse(r.status,e)}const s=await r.text();return s?JSON.parse(s):void 0}catch(e){if(e instanceof c)throw e;throw new c(0,[{type:"CONNECTION_PROBLEM",context:null,reason:e.message,details:null}])}}async form(e,t,r){const s=r||{};s.buttons?.forEach((e=>{e.setAttribute("disabled","disabled"),s.loader&&(e.dataset.oldContent=e.innerHTML,e.innerHTML=s.loader)}));try{const r=await this.json(e,t);return s.form?.clearErrors(),r}catch(e){throw s.form?.setErrors(e.problems),e}finally{s.buttons?.forEach((e=>{e.removeAttribute("disabled"),e.innerHTML=e.dataset.oldContent,delete e.dataset.oldContent}))}}}class u{constructor(e,t){this.prefix=e,this.storage=t}save(e,t){this.storage.setItem(`${this.prefix}-${e}`,JSON.stringify(t))}load(e){const t=this.storage.getItem(`${this.prefix}-${e}`);return void 0===t?void 0:JSON.parse(t)}remove(e){this.storage.removeItem(`${this.prefix}-${e}`)}pop(e){const t=this.load(e);return this.remove(e),t}}class d extends u{constructor(e){super(e,localStorage)}}class f extends u{constructor(e){super(e,sessionStorage)}}class p{constructor(e,t,r){this.storage=e,this.key=t,this.dataSupplier=r,this.cache=null}async load(e){const t=this.storage.load(this.key);if(t&&t.revision===e)return void(this.cache=t.value);const r=await this.dataSupplier(e,this.key);this.storage.save(this.key,{revision:e,value:r}),this.cache=r}data(){return this.cache}}class E{static forKeycloak(e,t,r){const s=new URL("protocol/openid-connect/auth",t),i=new URL("protocol/openid-connect/token",t),o=new URL("protocol/openid-connect/logout",t);return new E(e,"openid profile",s,i,o,r)}constructor(e,t,r,s,i,o){this.clientId=e,this.scope=t,this.authUri=r,this.tokenUri=s,this.logoutUri=i,this.redirectUri=o,this.storage=new f(e)}async _auth(){const e=r.encode(crypto.getRandomValues(new Uint8Array(32)).buffer),t=r.encode(await crypto.subtle.digest("SHA-256",(new TextEncoder).encode(e))),s=this.clientId+r.encode(crypto.getRandomValues(new Uint8Array(16)).buffer);this.storage.save(E.PKCE_AND_STATE_KEY,{state:s,verifier:e});const i=new URL(this.authUri);i.searchParams.set("client_id",this.clientId),i.searchParams.set("redirect_uri",this.redirectUri),i.searchParams.set("response_type","code"),i.searchParams.set("scope",this.scope),i.searchParams.set("state",s),i.searchParams.set("code_challenge",t),i.searchParams.set("code_challenge_method","S256"),window.location=i}async _tokenExchange(e,t){window.history.replaceState("","",this.redirectUri);const r=this.storage.pop(E.PKCE_AND_STATE_KEY);if(r.state!==t)throw new Error("State mismatch");const s=await fetch(this.tokenUri,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams([["client_id",this.clientId],["code",e],["grant_type","authorization_code"],["code_verifier",r.verifier],["state",r.state],["redirect_uri",this.redirectUri]])});if(!s.ok){const e=await s.text();throw new Error("Error:"+s.status+": "+e)}const i=await s.json();return new m(this.clientId,i,this.tokenUri,this.logoutUri,this.redirectUri)}async ensureLoggedIn(){const e=new URL(window.location.href),t=e.searchParams.get("code");if(t){const r=e.searchParams.get("state");return await this._tokenExchange(t,r)}return await this._auth(),null}}E.PKCE_AND_STATE_KEY="state-and-verifier";class m{static parseToken(e){const[t,r,s]=e.split(".");return{header:JSON.parse(atob(t)),payload:JSON.parse(atob(r)),signature:s}}constructor(e,t,r,s,i){this.clientId=e,this.token=t,this.tokenUri=r,this.logoutUri=s,this.redirectUri=i,this.accessToken=m.parseToken(t.access_token),this.refreshToken=m.parseToken(t.refresh_token),this.refreshCallback=null}onRefresh(e){this.refreshCallback=e}async refresh(){const e=await fetch(this.tokenUri,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams([["client_id",this.clientId],["grant_type","refresh_token"],["refresh_token",this.token.refresh_token]])});if(!e.ok)throw new Error("Error:"+e.code+": "+e.text());const t=await e.json();this.token=t,this.accessToken=this._parseToken(t.access_token),this.refreshToken=this._parseToken(t.refresh_token),this.refreshCallback&&this.refreshCallback(this.token,this.accessToken,this.refreshToken)}shouldBeRefreshed(e){const t=(new Date).getTime(),r=1e3*this.refreshToken.payload.exp;return!(t>r)&&t-e>r}async refreshIf(e){this.shouldBeRefreshed(e)&&await this.refresh()}logout(){const e=new URL(this.logoutUri);e.searchParams.set("post_logout_redirect_uri",this.redirectUri),e.searchParams.set("id_token_hint",this.token.id_token),window.location=e}bearerToken(){return`Bearer ${this.token.access_token}`}interceptor(e,t){return new g(this,e,t)}}class g{constructor(e,t,r){this.session=e,this.gracePeriodBefore=t||2e3,this.gracePeriodAfter=r||3e4}async before(e){await this.session.refreshIf(this.gracePeriodBefore);return new Headers(e.options.headers).set("Authorization",this.session.bearerToken()),e}async after(e,t){return await this.session.refreshIf(this.gracePeriodAfter),t}}const w={sleep:e=>new Promise((t=>setTimeout(t,e))),DEBOUNCE_DEFAULT:0,DEBOUNCE_IMMEDIATE:1,debounce(e,t,r){let s=null,i=[],o=0,n=r||w.DEBOUNCE_DEFAULT;const a=()=>{const r=(new Date).getTime()-o;e>r?s=setTimeout(a,e-r):(s=null,n!==w.DEBOUNCE_IMMEDIATE&&t(...i),null===s&&(i=[]))};return function(){i=arguments,o=(new Date).getTime(),null===s&&(s=setTimeout(a,e),n===w.DEBOUNCE_IMMEDIATE&&t(...i))}},THROTTLE_DEFAULT:0,THROTTLE_NO_LEADING:1,THROTTLE_NO_TRAILING:2,throttle(e,t,r){let s=null,i=[],o=0,n=r||w.THROTTLE_DEFAULT;const a=()=>{o=n&w.THROTTLE_NO_LEADING?0:(new Date).getTime(),s=null,t(...i),null===s&&(i=[])};return function(){const r=(new Date).getTime();!o&&n&w.THROTTLE_NO_LEADING&&(o=r);const c=e-(r-o);i=arguments,c<=0||c>e?(null!==s&&(clearTimeout(s),s=null),o=r,t(...i),null===s&&(i=[])):null!==s||n&w.THROTTLE_NO_TRAILING||(s=setTimeout(a,c))}}};class b{constructor(e){if(this.el=e,this.progress=[...e.children].filter((e=>e.matches("header,ol,ul"))),this.progress.forEach((e=>{const t=[...e.children];void 0===t.filter((e=>e.matches(".active")))[0]&&t.length>0&&t[0].classList.add("active")})),null===this.el.querySelector("section.current")){const e=this.el.querySelector("section:first-of-type");null!==e&&e.classList.add("current")}}next(){this.progress.forEach((e=>{const t=[...e.children].filter((e=>e.matches(".active")))[0];t?.classList.remove("active"),t?.nextElementSibling?.classList.add("active")}));const e=this.el.querySelector("section.current");e.classList.remove("current"),e.nextElementSibling.classList.add("current"),this.el.dispatchEvent(new CustomEvent("wizard:activate",{bubbles:!0,cancelable:!0}))}prev(){this.progress.forEach((e=>{const t=[...e.children].filter((e=>e.matches(".active")))[0];t?.classList.remove("active"),t?.previousElementSibling?.classList.add("active")}));const e=this.el.querySelector("section.current");e.classList.remove("current"),e.previousElementSibling.classList.add("current"),this.el.dispatchEvent(new CustomEvent("wizard:activate",{bubbles:!0,cancelable:!0}))}moveTo=function(e){this.progress.forEach((t=>{[...t.children].filter((e=>e.matches(".active")))[0]?.classList.remove("active"),t.children[+e]?.classList.add("active")}));this.el.querySelector("section.current")?.classList.remove("current");this.el.querySelector(`section:nth-child(${+e})`).classList.add("current"),this.el.dispatchEvent(new CustomEvent("wizard:activate",{bubbles:!0,cancelable:!0}))}}class T{constructor(){this.configurers=[],this.initializers=[],this.handlers=[],this.running=!1,document.addEventListener("DOMContentLoaded",(async()=>{await Promise.all(this.configurers),await Promise.all(this.initializers.map((e=>Promise.resolve(e())))),await Promise.all(this.handlers.map((e=>Promise.resolve(e()))))}))}configure(e){return this.configurers.push(Promise.resolve(e())),this}initialize(e){return this.initializers.push(e),this}ready(e){return this.handlers.push(e),this}}export{T as App,E as AuthorizationCodeFlow,g as AuthorizationCodeFlowInterceptor,m as AuthorizationCodeFlowSession,r as Base64,t as Bindings,c as Failure,i as Form,s as Hex,h as HttpClient,d as LocalStorage,f as SessionStorage,p as VersionedStorage,b as Wizard,w as timing};
1
+ function e(e,t,r,s,i){const n=e[t.dataset.bindMutator]||e[t.dataset.bindProvide];n?n(t,r,s,i):"radio"!==t.getAttribute("type")?"checkbox"!==t.getAttribute("type")?t.value=r:t.checked=r:t.checked=t.getAttribute("value")===r}class t{constructor({extractors:e,mutators:t,ignoredChildrenSelector:r,valueHoldersSelector:s}){this.extractors=e||{},this.mutators=t||{},this.valueHoldersSelector=s||"input[name], select[name], textarea[name]",this.ignoredChildrenSelector=r||".d-none"}setValues(t,r){for(let s in r)r.hasOwnProperty(s)&&Array.from(t.querySelectorAll(`[name='${CSS.escape(s)}']`)).forEach((t=>{e(this.mutators,t,r[s],s,r)}))}getValues(e){return Array.from(e.querySelectorAll(this.valueHoldersSelector)).filter((e=>"never"!==e.dataset.bindInclude&&("always"===e.dataset.bindInclude||null===e.closest(this.ignoredChildrenSelector)))).reduce(((e,t)=>function(e,t,r){const s=t.split(".").map((e=>e.match(/^[0-9]+$/)?+e:e));let i=e,n=null;for(let t=0;;++t){const o=s[t],a=s[t-1];if(Number.isInteger(o)&&!Array.isArray(i)&&(null!==n?n[a]=i=[]:e=i=[]),t===s.length-1)return i[o]=void 0!==r?r:o in i?i[o]:null,e;void 0===i[o]&&(i[o]={}),n=i,i=i[o]}}(e,t.getAttribute("name"),function(e,t){const r=e[t.dataset.bindExtractor]||e[t.dataset.bindProvide];if(r)return r(t);if("radio"===t.getAttribute("type")){if(!t.checked)return;return"boolean"===t.dataset.bindType?"true"===t.value:t.value}return"checkbox"===t.getAttribute("type")?t.checked:"boolean"===t.dataset.bindType?t.value?"true"===t.value:null:t.value||null}(this.extractors,t))),{})}}class r{static encode(e,t){const s=t||r.URL_SAFE,i=e.byteLength,n=new Uint8Array(e);let o="";for(let e=0;e<i;e+=3){o+=s[n[e]>>2]+s[(3&n[e])<<4|n[e+1]>>4]+s[(15&n[e+1])<<2|n[e+2]>>6]+s[63&n[e+2]]}return i%3==2?o=o.substring(0,o.length-1):i%3==1&&(o=o.substring(0,o.length-2)),o}static decode(e,t){const s=t||r.URL_SAFE;let i=Math.floor(.75*e.length);for(let t=0;t!==e.length&&"="===e[e.length-t-1];++t)--i;const n=new Uint8Array(i);let o=0,a=0;for(;o<.75*e.length;){const t=s.indexOf(e.charAt(a++)),r=s.indexOf(e.charAt(a++)),i=s.indexOf(e.charAt(a++)),c=s.indexOf(e.charAt(a++));n[o++]=t<<2|r>>4,n[o++]=(15&r)<<4|i>>2,n[o++]=(3&i)<<6|c}return n.buffer}}r.STANDARD="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",r.URL_SAFE="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_";class s{static decode(e){if(e.length%2!=0)throw new Error("invalid length");const t=e.length/2;return new Uint8Array(t).map(((t,r)=>{const s=2*r,i=e.substring(s,s+2);return parseInt(i,16)}))}static encode(e,t){return Array.from(e).map((e=>e.toString(16))).map((e=>t?e.toUpperCase():e)).map((e=>e.padStart(2,0))).join("")}}class i{constructor(e,t,{globalErrorsEl:r,fieldContainerSelector:s,errorClass:n,hideClass:o}){this.el=e,this.bindings=t,this.globalErrorsEl=r,this.fieldContainerSelector=void 0!==s?s:i.DEFAULT_FIELD_CONTAINER_SELECTOR,this.errorClass=n||i.DEFAULT_ERROR_CLASS,this.hideClass=o||i.DEFAULT_HIDE_CLASS}setValues(e){return this.bindings.setValues(this.el,e)}getValues(){return this.bindings.getValues(this.el)}setErrors(e,t,r){if(this.clearErrors(),e.map(this.mapError?this.mapError:e=>e).filter((e=>"FIELD_ERROR"===e.type||"INVALID_FORMAT"===e.type)).forEach((e=>{const t=e.context.replace("[",".").replace("].",".");Array.from(this.el.querySelectorAll(`[name='${CSS.escape(t)}']`)).map((e=>this.fieldContainerSelector?e.closest(this.fieldContainerSelector):e)).filter((e=>null!==e)).forEach((t=>{t.classList.add(this.errorClass),t.dataset.error=e.reason}))})),this.globalErrorsEl){const t=e.filter((e=>"FIELD_ERROR"!==e.type&&"INVALID_FORMAT"!==e.type));this.globalErrorsEl.innerHTML=t.map((e=>e.reason)).join("\n"),0!==t.length&&this.globalErrorsEl.classList.remove(this.hideClass)}if(!t)return;const s=Array.from(this.el.querySelectorAll(".${CSS.escape(this.errorClass)}")).map((e=>e.getBoundingClientRect().y+window.scrollY)),i=Math.min(...s);i!==1/0&&window.scroll(window.scrollX,i>100?i-100:0)}clearErrors(){this.el.querySelectorAll(`.${CSS.escape(this.errorClass)}`).forEach((e=>e.classList.remove(this.errorClass))),this.globalErrorsEl&&(this.globalErrorsEl.innerHTML="",this.globalErrorsEl.classList.add(this.hideClass))}}i.DEFAULT_FIELD_CONTAINER_SELECTOR="label",i.DEFAULT_ERROR_CLASS="has-error",i.DEFAULT_HIDE_CLASS="d-none";class n{constructor(){const e=document.querySelector("meta[name='context']").getAttribute("content");this.context=e.endsWith("/")?e.substring(0,e.length-1):e}async intercept(e,t){const r=e.resource.startsWith("/")?"":"/";return e.resource=this.context+r+e.resource,await t.proceed(e)}}class o{constructor(){this.k=document.querySelector("meta[name='_csrf_header']").getAttribute("content"),this.v=document.querySelector("meta[name='_csrf']").getAttribute("content")}async intercept(e,t){const r=new Headers(e.options.headers);return r.set(this.k,this.v),e.options.headers=r,await t.proceed(e)}}class a{constructor(e){this.redirectUri=e}async intercept(e,t){const r=await t.proceed(e);if(401!==r.status)return r;window.location.href=redirectUri}}class c extends Error{static parseProblems(e,t){const r=[{type:"GENERIC_PROBLEM",context:null,reason:`${e}: ${t}`,details:null}];try{return t?JSON.parse(t):r}catch(e){return r}}static fromResponse(e,t){return new c(e,c.parseProblems(e,t))}constructor(e,t){super(JSON.stringify(t)),this.name=`Failure:${e}`,this.status=e,this.problems=t}}class l{constructor(){this.interceptors=[]}withContext(){return this.interceptors.push(new n),this}withCsrfToken(){return this.interceptors.push(new o),this}withRedirectOnUnauthorized(e){return this.interceptors.push(new a(e)),this}withInterceptors(...e){return this.interceptors.push(...e),this}build(){const e=this.interceptors;return new d({interceptors:e})}}class h{async intercept(e,t){return await fetch(e.resource,e.options)}}class u{constructor(e,t){this.interceptors=e,this.current=t}async proceed(e){const t=this.interceptors[this.current];return await t.intercept(e,new u(this.interceptors,this.current+1))}}class d{static builder(){return new l}constructor({interceptors:e}){this.interceptors=e||[]}async fetch(e,t){const r=[...this.interceptors,...t.interceptors||[],new h],s=new u(r,0);return await s.proceed({resource:e,options:t})}async json(e,t){try{const r=await this.fetch(e,t);if(!r.ok){const e=await r.text();throw c.fromResponse(r.status,e)}const s=await r.text();return s?JSON.parse(s):void 0}catch(e){if(e instanceof c)throw e;throw new c(0,[{type:"CONNECTION_PROBLEM",context:null,reason:e.message,details:null}])}}async form(e,t,r){const s=r||{};s.buttons?.forEach((e=>{e.setAttribute("disabled","disabled"),s.loader&&(e.dataset.oldContent=e.innerHTML,e.innerHTML=s.loader)}));try{const r=await this.json(e,t);return s.form?.clearErrors(),r}catch(e){throw s.form?.setErrors(e.problems),e}finally{s.buttons?.forEach((e=>{e.removeAttribute("disabled"),e.innerHTML=e.dataset.oldContent,delete e.dataset.oldContent}))}}}class p{constructor(e,t){this.prefix=e,this.storage=t}save(e,t){this.storage.setItem(`${this.prefix}-${e}`,JSON.stringify(t))}load(e){const t=this.storage.getItem(`${this.prefix}-${e}`);return void 0===t?void 0:JSON.parse(t)}remove(e){this.storage.removeItem(`${this.prefix}-${e}`)}pop(e){const t=this.load(e);return this.remove(e),t}}class f extends p{constructor(e){super(e,localStorage)}}class E extends p{constructor(e){super(e,sessionStorage)}}class m{constructor(e,t,r){this.storage=e,this.key=t,this.dataSupplier=r,this.cache=null}async load(e){const t=this.storage.load(this.key);if(t&&t.revision===e)return void(this.cache=t.value);const r=await this.dataSupplier(e,this.key);this.storage.save(this.key,{revision:e,value:r}),this.cache=r}data(){return this.cache}}class g{static forKeycloak(e,t,r){return new g(e,"openid profile",{auth:new URL("protocol/openid-connect/auth",t),token:new URL("protocol/openid-connect/token",t),logout:new URL("protocol/openid-connect/logout",t),registration:new URL("protocol/openid-connect/registrations",t),redirect:r})}constructor(e,t,{auth:r,token:s,registration:i,logout:n,redirect:o}){this.storage=new E(e),this.clientId=e,this.scope=t,this.uri={auth:r,token:s,registration:i,logout:n,redirect:o}}async action(e,t){const s=r.encode(crypto.getRandomValues(new Uint8Array(32)).buffer),i=r.encode(await crypto.subtle.digest("SHA-256",(new TextEncoder).encode(s))),n=this.clientId+r.encode(crypto.getRandomValues(new Uint8Array(16)).buffer);this.storage.save(g.PKCE_AND_STATE_KEY,{state:n,verifier:s});const o=new URL(e);o.searchParams.set("client_id",this.clientId),o.searchParams.set("redirect_uri",this.uri.redirect),o.searchParams.set("response_type","code"),o.searchParams.set("scope",this.scope),o.searchParams.set("state",n),o.searchParams.set("code_challenge",i),o.searchParams.set("code_challenge_method","S256"),Object.entries(t||{}).forEach((e=>{o.searchParams.set(e[0],e[1])})),window.location=o}async registration(e){await this.action(this.uri.registration,e)}async applicationInitiatedAction(e){await this.action(this.uri.auth,{kc_action:e})}async _tokenExchange(e,t){window.history.replaceState("","",this.uri.redirect);const r=this.storage.pop(g.PKCE_AND_STATE_KEY);if(r.state!==t)throw new Error("State mismatch");const s=await fetch(this.uri.token,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams([["client_id",this.clientId],["code",e],["grant_type","authorization_code"],["code_verifier",r.verifier],["state",r.state],["redirect_uri",this.uri.redirect]])});if(!s.ok){const e=await s.text();throw new Error("Error:"+s.status+": "+e)}const i=await s.json();return new w(this.clientId,i,this.uri)}async ensureLoggedIn(){const e=new URL(window.location.href),t=e.searchParams.get("code");if(t&&this.storage.load(g.PKCE_AND_STATE_KEY)){const r=e.searchParams.get("state");return await this._tokenExchange(t,r)}return await this.action(this.uri.auth,{}),null}}g.PKCE_AND_STATE_KEY="state-and-verifier";class w{static parseToken(e){const[t,s,i]=e.split("."),n=new TextDecoder("utf-8");return{header:JSON.parse(n.decode(r.decode(t,r.STANDARD))),payload:JSON.parse(n.decode(r.decode(s,r.STANDARD))),signature:i}}constructor(e,t,{token:r,logout:s,redirect:i}){this.clientId=e,this.token=t,this.accessToken=w.parseToken(t.access_token),this.refreshToken=w.parseToken(t.refresh_token),this.uri={token:r,logout:s,redirect:i},this.refreshCallback=null}onRefresh(e){this.refreshCallback=e}async refresh(){const e=await fetch(this.uri.token,{method:"POST",headers:{"Content-Type":"application/x-www-form-urlencoded"},body:new URLSearchParams([["client_id",this.clientId],["grant_type","refresh_token"],["refresh_token",this.token.refresh_token]])});if(!e.ok)throw new Error("Error:"+e.code+": "+e.text());const t=await e.json();this.token=t,this.accessToken=this._parseToken(t.access_token),this.refreshToken=this._parseToken(t.refresh_token),this.refreshCallback&&this.refreshCallback(this.token,this.accessToken,this.refreshToken)}shouldBeRefreshed(e){const t=(new Date).getTime(),r=1e3*this.refreshToken.payload.exp;return!(t>r)&&t-e>r}async refreshIf(e){this.shouldBeRefreshed(e)&&await this.refresh()}logout(){const e=new URL(this.uri.logout);e.searchParams.set("post_logout_redirect_uri",this.uri.redirect),e.searchParams.set("id_token_hint",this.token.id_token),window.location=e}bearerToken(){return`Bearer ${this.token.access_token}`}interceptor(e,t){return new T(this,e,t)}}class T{constructor(e,t,r){this.session=e,this.gracePeriodBefore=t||2e3,this.gracePeriodAfter=r||3e4}async intercept(e,t){await this.session.refreshIf(this.gracePeriodBefore);const r=new Headers(e.options.headers);r.set("Authorization",this.session.bearerToken()),e.options.headers=r;const s=await t.proceed(e);return await this.session.refreshIf(this.gracePeriodAfter),s}}const y={sleep:e=>new Promise((t=>setTimeout(t,e))),DEBOUNCE_DEFAULT:0,DEBOUNCE_IMMEDIATE:1,debounce(e,t,r){let s=null,i=[],n=0,o=r||y.DEBOUNCE_DEFAULT;const a=()=>{const r=(new Date).getTime()-n;e>r?s=setTimeout(a,e-r):(s=null,o!==y.DEBOUNCE_IMMEDIATE&&t(...i),null===s&&(i=[]))};return function(){i=arguments,n=(new Date).getTime(),null===s&&(s=setTimeout(a,e),o===y.DEBOUNCE_IMMEDIATE&&t(...i))}},THROTTLE_DEFAULT:0,THROTTLE_NO_LEADING:1,THROTTLE_NO_TRAILING:2,throttle(e,t,r){let s=null,i=[],n=0,o=r||y.THROTTLE_DEFAULT;const a=()=>{n=o&y.THROTTLE_NO_LEADING?0:(new Date).getTime(),s=null,t(...i),null===s&&(i=[])};return function(){const r=(new Date).getTime();!n&&o&y.THROTTLE_NO_LEADING&&(n=r);const c=e-(r-n);i=arguments,c<=0||c>e?(null!==s&&(clearTimeout(s),s=null),n=r,t(...i),null===s&&(i=[])):null!==s||o&y.THROTTLE_NO_TRAILING||(s=setTimeout(a,c))}}};class _{constructor(e){if(this.el=e,this.progress=[...e.children].filter((e=>e.matches("header,ol,ul"))),this.progress.forEach((e=>{const t=[...e.children];void 0===t.filter((e=>e.matches(".active")))[0]&&t.length>0&&t[0].classList.add("active")})),null===this.el.querySelector("section.current")){const e=this.el.querySelector("section:first-of-type");null!==e&&e.classList.add("current")}}next(){this.progress.forEach((e=>{const t=[...e.children].filter((e=>e.matches(".active")))[0];t?.classList.remove("active"),t?.nextElementSibling?.classList.add("active")}));const e=this.el.querySelector("section.current");e.classList.remove("current"),e.nextElementSibling.classList.add("current"),this.el.dispatchEvent(new CustomEvent("wizard:activate",{bubbles:!0,cancelable:!0}))}prev(){this.progress.forEach((e=>{const t=[...e.children].filter((e=>e.matches(".active")))[0];t?.classList.remove("active"),t?.previousElementSibling?.classList.add("active")}));const e=this.el.querySelector("section.current");e.classList.remove("current"),e.previousElementSibling.classList.add("current"),this.el.dispatchEvent(new CustomEvent("wizard:activate",{bubbles:!0,cancelable:!0}))}moveTo=function(e){this.progress.forEach((t=>{[...t.children].filter((e=>e.matches(".active")))[0]?.classList.remove("active"),t.children[+e]?.classList.add("active")}));this.el.querySelector("section.current")?.classList.remove("current");this.el.querySelector(`section:nth-child(${+e})`).classList.add("current"),this.el.dispatchEvent(new CustomEvent("wizard:activate",{bubbles:!0,cancelable:!0}))}}class b{constructor(){this.configurers=[],this.initializers=[],this.handlers=[],this.running=!1,document.addEventListener("DOMContentLoaded",(async()=>{await Promise.all(this.configurers),await Promise.all(this.initializers.map((e=>Promise.resolve(e())))),await Promise.all(this.handlers.map((e=>Promise.resolve(e()))))}))}configure(e){return this.configurers.push(Promise.resolve(e())),this}initialize(e){return this.initializers.push(e),this}ready(e){return this.handlers.push(e),this}}export{b as App,g as AuthorizationCodeFlow,T as AuthorizationCodeFlowInterceptor,w as AuthorizationCodeFlowSession,r as Base64,t as Bindings,c as Failure,i as Form,s as Hex,d as HttpClient,f as LocalStorage,E as SessionStorage,m as VersionedStorage,_ as Wizard,y as timing};
2
2
  //# sourceMappingURL=ful.min.mjs.map