@vuu-ui/vuu-utils 0.8.22 → 0.8.23-debug

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/esm/index.js CHANGED
@@ -1,8 +1,3739 @@
1
- var We=(e,t,n)=>{if(!t.has(e))throw TypeError("Cannot "+n)};var f=(e,t,n)=>(We(e,t,"read from private field"),n?n.call(e):t.get(e)),X=(e,t,n)=>{if(t.has(e))throw TypeError("Cannot add the same private member more than once");t instanceof WeakSet?t.add(e):t.set(e,n)};function $n(e,t,n=[],r=[]){for(let o=0,i=e.length;o<i;o++)(t(e[o],o)?n:r).push(e[o]);return[n,r]}function Nn(e,t,n){return e.length!==t.length?!0:n===void 0?!e.every(r=>t.includes(r)):e.some(r=>t.findIndex(o=>o[n]===r[n])===-1)}function Un(e,t,n){return e.length!==t.length?!0:n===void 0?e.some((r,o)=>t[o]!==r):e.some((r,o)=>t[o][n]!==r[n])}var Wn=(e,t,n)=>{let r=e.indexOf(t);if(r===n)return e;let o=e.slice();if(r===-1)throw Error("moveItem, item to be moved not found");if(o.splice(r,1),n===-1)o.push(t);else{let i=(n>r,0);o.splice(n+i,0,t)}return o},Y=(e,t,n)=>{if(t===n)return e;{let r=e.slice(),[o]=r.splice(t,1);if(n===-1)return r.concat(o);{let i=(n>t,0);return r.splice(n+i,0,o),r}}},jn=(e,t)=>{let n=r=>!(e!=null&&e.includes(r));return e===void 0?t:t.some(n)?t.filter(n):[]},Bn=(e,t,n)=>t.filter(r=>e.findIndex(o=>n(o)===r)===-1);function qn(e,t,n){if(e)return t>=e.left&&t<e.right&&n>=e.top&&n<e.bottom}var Q=new Set(["=","!=",">",">=","<","<=","starts","ends"]),Jn=e=>e==="in"||Q.has(e),Xn=e=>e!==void 0&&e.name!==void 0,Z=e=>e!==void 0&&Q.has(e.op),ee=e=>e!==void 0&&(Z(e)||te(e)),te=e=>e!==void 0&&e.op==="in",Yn=e=>e.op==="in",Qn=e=>e.op==="and",Zn=e=>e.op==="or",er=e=>Z(e)&&e.column!==void 0&&e.op!==void 0&&e.value!==void 0;function E(e){return e!==void 0&&(e.op==="and"||e.op==="or")}var je=e=>typeof e=="string"?`"${e}"`:e,Be=e=>typeof e=="string"?`"${e}"`:e,V=e=>E(e)?e.filters.map(t=>V(t)).join(` ${e.op} `):te(e)?`${e.column} ${e.op} [${e.values.map(Be).join(",")}]`:`${e.column} ${e.op} ${je(e.value)}`,tr=(e,t)=>{if(E(t)){let[n,r]=t.filters;if(n.column===e.name)return[r,V(r)];if(r.column===e.name)return[n,V(n)]}return[void 0,""]};var Ke="asc",ne=[],ir={Average:2,Count:3,Distinct:6,Sum:1,High:4,Low:5};function sr(e,t,n=0){return e.map(r=>{if(typeof r=="string")return[t[r]+n,"asc"];if(Array.isArray(r)){let[o,i]=r;return[t[o]+n,i||Ke]}else throw Error("columnUtils.mapSortCriteria invalid input")})}var qe=["int","long","double"],ur=e=>e===void 0?"left":qe.includes(e)?"right":"left",ze=e=>e==="left"||e==="right",ar=e=>ze(e)||e==="floating"||e==="",Je=e=>typeof e.key=="number",lr=e=>{switch(e){case"double":case"int":case"long":return"number";case"boolean":return"boolean";default:return"string"}},pr=({serverDataType:e,type:t})=>e==="int"||e==="long"||e==="double"?!0:typeof t=="string"?t==="number":typeof(t==null?void 0:t.name)=="string"?(t==null?void 0:t.name)==="number":!1,ie=e=>(g(e.type)?e.type.name:e.type)==="date/time",cr=e=>typeof e.pin=="string",Xe=e=>Array.isArray(e.heading)&&e.heading.length>0,mr=e=>e.resizing,fr=({serverDataType:e})=>e===void 0?!1:e==="char"||e==="string",dr=e=>({name:e}),g=e=>typeof e<"u"&&typeof e!="string",Ye={},A=e=>typeof(e==null?void 0:e.name)<"u",gr=e=>typeof(e==null?void 0:e.name)<"u"&&"lookup"in e,Cr=e=>typeof(e==null?void 0:e.name)<"u"&&Array.isArray(e.values),yr=e=>g(e)&&A(e.renderer)&&Array.isArray(e.renderer.rules)&&e.renderer.rules.length>0,se=e=>e!==void 0&&typeof(e==null?void 0:e.map)<"u";function hr(e){let t=C.count;return e?e.reduce((n,r,o)=>(typeof r=="string"?n[r]=t+o:Je(r)?n[r.name]=r.key:n[r.name]=t+o,n),{}):Ye}function xr(e){let t=[],n=C.count-2;for(let r=0;r<e.length;r+=3)t[r]=e[r]+n,t[r+1]=e[r+1],t[r+2]=e[r+2];return t}var C={IDX:0,RENDER_IDX:1,IS_LEAF:2,IS_EXPANDED:3,DEPTH:4,COUNT:5,KEY:6,SELECTED:7,count:8,PARENT_IDX:"parent_idx",IDX_POINTER:"idx_pointer",FILTER_COUNT:"filter_count",NEXT_FILTER_IDX:"next_filter_idx"},Qe=(e,t)=>{let{originalIdx:n}=t;if(typeof n=="number")for(let r=0;r<e.length;r++){let{originalIdx:o=-1}=e[r];if(o>n)return e.splice(r,0,t),e}return e.push(t),e},k=e=>{var t;if((t=e[0])!=null&&t.isGroup){let[n,...r]=e;return n.columns.forEach(o=>{Qe(r,o)}),r}else return e};function Ze(e,t,n=!0){if(t&&t.length>0){let r=k(e),[o,i]=r.reduce((l,c,y)=>{let[h,T]=l;return t.includes(c.name)?h.push({...c,originalIdx:y}):T.push(c),l},[[],[]]);if(o.length!==t.length)throw Error(`extractGroupColumn: no column definition found for all groupBy cols ${JSON.stringify(t)} `);let s=t.length,u=t.map((l,c)=>({...o.find(h=>h.name===l),groupLevel:s-c}));return[{key:-1,name:"group-col",heading:["group-col"],isGroup:!0,columns:u,groupConfirmed:n,width:u.map(l=>l.width).reduce((l,c)=>l+c)+100},i]}return[null,k(e)]}var et=e=>e.isGroup===!0,tt=e=>typeof e=="string"&&e.endsWith("+"),Tr=(e,t)=>{var n;return((n=e.type)==null?void 0:n.name)==="json"&&tt(t[e.key])},Dr=e=>{var t;return((t=e.type)==null?void 0:t.name)==="json"},br=e=>{let t=[],n=[],r=[],o=4;for(let s of e)switch(s.pin){case"left":t.push({...s,endPin:void 0,pinnedOffset:o}),o+=s.width;break;case"right":n.unshift(s);break;default:r.push(s)}t.length&&t.push({...t.pop(),endPin:!0});let i=t.length?t.concat(r):r;if(n.length){let s=[],u=0;for(let a of n)s.unshift({...a,pinnedOffset:u}),u+=a.width;return s[0].endPin=!0,i.concat(s)}else return i},Rr=e=>{if(e.some(Xe)){let t=e.reduce((i,{heading:s})=>{var u;return Math.max(i,(u=s==null?void 0:s.length)!=null?u:0)},0),n,r=[],o;for(let i=0;i<t;i++)o=[],e.forEach(({heading:s=ne,width:u})=>{var l;let a=(l=s[i])!=null?l:"";n&&n.label===a?n.width+=u:(n={label:a,width:u},o.push(n))}),r.push(o);return r}return ne},Er=({pin:e,pinnedOffset:t=e==="left"?0:4,width:n})=>e==="left"?{left:t,width:n,"--pin-width":`${t+n-3}px`}:e==="right"?{right:t,width:n,"--pin-width":`${t+n}px`}:{width:n},Sr=(e,t,n)=>e.filter(r=>r.column!==t.name).concat({column:t.name,aggType:n}),ue=(e,t)=>{if(E(e))return nt(e,t);if(ee(e))return e.column===t?e:void 0},nt=(e,t)=>{let{filters:n,op:r}=e,o=[];if(n.forEach(i=>{let s=ue(i,t);s&&o.push(s)}),o.length!==0)return o.length===1?o[0]:{op:r,filters:o}},Mr=(e,t,n=!0)=>{var r;if(t.length){let[o,i]=Ze(e,t,n);if(o)return[o].concat(i)}else if((r=e[0])!=null&&r.isGroup)return k(e);return e},wr=(e,t)=>e.map(n=>{let r=rt(n,t);return r!==void 0?{...n,sorted:r}:n.sorted?{...n,sorted:void 0}:n}),Fr=(e,{filterStruct:t})=>e.map(n=>{let r=ue(t,n.name);return r!==void 0?{...n,filter:r}:n.filter?{...n,filter:void 0}:n}),Lr=e=>e.filter!==void 0,vr=e=>e.map(t=>{let{filter:n,...r}=t;return n?r:t}),rt=(e,{sortDefs:t})=>{let n=t.find(r=>r.column===e.name);if(n)return t.length>1?(t.indexOf(n)+1)*(n.sortType==="A"?1:-1):n.sortType},Pr=e=>{let t=e.indexOf(":");return t===-1?e:e.slice(0,t)},Vr=e=>e.label?e.label:le(e.name)?at(e):e.name,ot=(e,t)=>{let n=e.find(r=>r.name===t);if(n)return n;{let r=e.find(o=>o.isGroup);if(r)return ot(r.columns,t)}};function kr(e,t,n){let r=typeof t=="string"?e.find(o=>o.name===t):t;if(r){let o=n?{...r,...n}:r;return e.map(i=>i.name===o.name?o:i)}else throw Error("column-utils.replaceColun, column not found")}var Ar=e=>e.name,Ir=(e,t)=>Object.entries(t).reduce((n,[r,o])=>(n[r]=e[o],n),{}),Or=e=>et(e[0])&&e[0].groupConfirmed===!1,Hr=(e,t,n)=>{var i;let r=[],o=0;for(let s=0,u=0;u<e.length;u++){let a=e[u];if(!a.hidden){if(s+a.width<t)a.pin==="left"||s+a.width+((i=e[u+1])==null?void 0:i.width)>t?r.push(a):o+=a.width;else if(s>n){r.push(a);break}else r.push(a);s+=a.width}}return[r,o]},re=e=>e.hidden!==!0,Gr=(e,t)=>e.every(re)?e[t]:e.filter(re).at(t),{DEPTH:it,IS_LEAF:st}=C,_r=(e,t)=>{let{[it]:n,[st]:r}=t;if(r||n>e.length)return[null,n===null?0:Math.max(0,n-1)];if(n===0)return["$root",0];{let{key:o,valueFormatter:i}=e[n-1];return[i(t[o]),n-1]}},ae=e=>{switch(e){case"int":case"long":case"double":return"number";case"boolean":return"boolean";default:return"string"}},$r=(e,t)=>{let{serverDataType:n,type:r=ae(n)}=e;return g(r)?{...e,type:{...r,formatting:t}}:{...e,type:{name:r,formatting:t}}};function Nr(e,t){return g(e.type)?{...e,type:{...e.type,name:t}}:{...e,type:t}}var Ur=(e,t)=>{let{serverDataType:n,type:r=ae(n)}=e;return g(r)?{...e,type:{...r,renderer:t}}:{...e,type:{name:r,renderer:t}}},oe={},Wr=e=>{var t;return g(e.type)&&(t=e.type.formatting)!=null?t:oe},jr=e=>t=>e==null?void 0:e.includes(t.name),Br=(e,t,n)=>{let r=(u=n)=>a=>a.name===u;if(e.findIndex(r())!==-1)throw Error(`column-utils, addColumnToSubscribedColumns column ${n} is already subscribed`);let o=t.findIndex(r());if(o===-1)throw Error(`column-utils, addColumnToSubscribedColumns column ${n} is not available`);let i={...t[o]},s=-1;for(let u=o-1;u>=0;u--){let{name:a}=t[u];if(s=e.findIndex(r(a)),s!==-1)break}if(s===-1)return[i].concat(e);{let u=[];for(let a=0;a<e.length;a++)u.push(e[a]),a===s&&(u.push(i),s=Number.MAX_SAFE_INTEGER);return u}},ut=/.*:.*:.*/,le=e=>e!==void 0&&ut.test(e),I=e=>{if(le(e.name))return e.name.split(/:=?/);throw Error(`column-utils, getCalculatedColumnDetails column name ${e.name} is not valid calculated column`)},at=e=>I(e)[0],Kr=e=>I(e)[1],qr=e=>I(e)[2],zr=(e,t)=>{let[,n,r]=e.name.split(":");return{...e,name:`${t}:${n}:${r}`}},Jr=(e,t)=>{let[n,,r]=e.name.split(":");return{...e,name:`${n}:${t}:${r}`}},Xr=(e,t)=>{let[n,r]=e.name.split(":");return{...e,name:`${n}:${r}:=${t}`}},Yr=(e,t,n)=>{let r=e.findIndex(o=>o.name===t.name);return Y(e,r,n)};function Qr(e,t){return e.map(n=>n.name===t.name?t:n)}var Zr=({columns:e,table:t},n)=>typeof n=="function"?e.map(r=>{let o=n(t.table,r.name);return o?{...r,...o}:r}):e,eo=(e,t)=>{if(t!==void 0){let n=e.columns.find(r=>r.name===t);if(n)return n;throw Error(`getColumnByName no column '${t}' in schema for ${e.table.table}`)}};var pe=e=>{var t,n;if(((t=globalThis.document)==null?void 0:t.cookie)!==void 0)return(n=globalThis.document.cookie.split("; ").find(r=>r.startsWith(`${e}=`)))==null?void 0:n.split("=")[1]};var D=new Map,S=new Map,ce=new Map,me=new Map,fe=new Map,O=new Map,lt=(e,t)=>e===void 0||e==="private"?!0:Array.isArray(e)?e.includes(t):e===t,pt=(e,t)=>e==="cell-renderer",ct=(e,t)=>e==="column-header-content-renderer",mt=(e,t)=>e==="column-header-label-renderer",ft=(e,t)=>e==="cell-config-panel",dt=(e,t)=>e==="data-edit-validator";function oo(e,t,n="cell-renderer",r){pt(n,t)?D.set(e,t):ct(n,t)||mt(n,t)?S.set(e,t):ft(n,t)?me.set(e,t):dt(n,t)&&fe.set(e,t),r&&O.set(e,r)}var io=(e,t)=>{ce.set(e,t)},so=e=>{let n=Array.from(D.keys()).map(r=>({name:r,...O.get(r)}));return e?n.filter(r=>lt(r.serverDataType,e)):n},uo=e=>O.get(e);function ao(e){return gt(e)}function lo(e){if(e.colHeaderContentRenderer)return S.get(e.colHeaderContentRenderer)}function po(e){if(e.colHeaderLabelRenderer)return S.get(e.colHeaderLabelRenderer)}function gt(e){if(g(e.type)){let{renderer:t}=e.type;if(A(t))return D.get(t.name)}else{if(e.serverDataType==="boolean")return D.get("checkbox-cell");if(e.editable)return D.get("input-cell")}}function co(e=""){return ce.get(e)}function mo(e){return me.get(e)}function fo(e){return fe.get(e)}var Co={from:0,to:0};function yo({from:e,to:t},n=0,r=Number.MAX_SAFE_INTEGER){if(n===0)return r<e?{from:0,to:0}:{from:e,to:Math.min(t,r)};if(e===0)return{from:e,to:Math.min(t+n,r)};{let o=t-e,i=Math.round(n/2),s=e-i<0,u=r-(t+i)<0;return s&&u?{from:0,to:r}:s?{from:0,to:o+n}:u?{from:Math.max(0,r-(o+n)),to:r}:{from:e-i,to:t+i}}}function ho({from:e,to:t,bufferSize:n=0}){return{from:0,to:t-e,bufferSize:n,reset:!0}}var Ct=(e,{from:t,to:n})=>e>=t&&e<n,xo=({from:e,to:t},n)=>{let{from:r,to:o}=n,i=r>=t||o<=e,s=r<e&&o>t;return i||s?n:o>t?{from:t,to:o}:{from:r,to:e}},M=class e{constructor(t,n){this.from=t,this.to=n}isWithin(t){return Ct(t,this)}overlap(t,n){return t>=this.to||n<this.from?[0,0]:[Math.max(t,this.from),Math.min(n,this.to)]}copy(){return new e(this.from,this.to)}};var{KEY:yt}=C,de=class{constructor({from:t,to:n}){this.rowCount=0;this.setRowCount=t=>{t<this.data.length&&(this.data.length=t),this.rowCount=t};this.range=new M(t,n),this.data=new Array(n-t)}add(t){let[n]=t;if(this.isWithinRange(n)){let r=n-this.range.from,o=this.data[r]!==void 0;return this.data[r]=t,o}else return!1}getAtIndex(t){return this.range.isWithin(t)&&this.data[t-this.range.from]!=null?this.data[t-this.range.from]:void 0}getByKey(t){return this.data.find(n=>n[yt]===t)}isWithinRange(t){return this.range.isWithin(t)&&t<=this.rowCount}setRange(t,n){if(t!==this.range.from||n!==this.range.to){let[r,o]=this.range.overlap(t,n),i=new Array(n-t);for(let s=r;s<o;s++){let u=this.getAtIndex(s);if(u){let a=s-t;i[a]=u}}this.data=i,this.range.from=t,this.range.to=n}}hasData(t,n){let r=this.range.from,o=t-r,i=Math.min(n-r-1,this.rowCount-1);return this.data[o]!==void 0&&this.data[i]!==void 0}getData(t,n){var u;let{from:r,to:o}=this.range,i=Math.max(0,t-r),s=Math.min(n-r,(u=this.rowCount)!=null?u:n);return this.data.slice(i,s)}};var Eo={horizontal:{positionProp:"left",sizeProp:"width"},vertical:{positionProp:"top",sizeProp:"height"}};var H="up1",G="up2",_="down1",$="down2",Mo=e=>typeof e=="number"&&isFinite(e),ge={},wo=(e=ge,t=ge)=>{let n=Object.keys(e),r=Object.keys(t);return n.length===r.length&&n.every(o=>e[o]===t[o])};function Fo(e,t,n,r){if(e===void 0||!isFinite(e)||n===void 0||t===void 0)return"";{let o=e-n;return o&&typeof r=="number"&&(o=+e.toFixed(r)-+n.toFixed(r)),o?t===""?o<0?_:H:o>0?t===_||t===$||t===G?H:G:t===H||t===G||t===$?_:$:""}}var ht=e=>e.type==="vuu-links",vo=e=>e.type==="vuu-link-created",Po=e=>e.type==="vuu-link-removed",xt=e=>e.type==="vuu-menu",Vo=e=>xt(e)||ht(e);var Tt={filter:""},Dt={sortDefs:[]},Ao={aggregations:[],columns:[],filter:Tt,groupBy:[],sort:Dt},bt=({aggregations:e},{aggregations:t})=>e===void 0&&(t==null?void 0:t.length)===0||t===void 0&&(e==null?void 0:e.length)===0,Rt=({columns:e},{columns:t})=>e===void 0&&(t==null?void 0:t.length)===0||t===void 0&&(e==null?void 0:e.length)===0,Et=({filter:e},{filter:t})=>e===void 0&&(t==null?void 0:t.filter)===""||t===void 0&&(e==null?void 0:e.filter)==="",St=({groupBy:e},{groupBy:t})=>e===void 0&&(t==null?void 0:t.length)===0||t===void 0&&(e==null?void 0:e.length)===0,Mt=({sort:e},{sort:t})=>e===void 0&&(t==null?void 0:t.sortDefs.length)===0||t===void 0&&(e==null?void 0:e.sortDefs.length)===0,b=(e,t)=>e===t?!0:e===void 0&&t===void 0,wt=(e,t)=>{let{aggregations:n}=e,{aggregations:r}=t;return b(n,r)||bt(e,t)?!1:n===void 0||r===void 0||n.length!==r.length?!0:n.some(({column:o,aggType:i},s)=>o!==r[s].column||i!==r[s].aggType)},Ft=(e,t)=>{let{columns:n}=e,{columns:r}=t;return b(n,r)||Rt(e,t)?!1:n===void 0||r===void 0||(n==null?void 0:n.length)!==(r==null?void 0:r.length)?!0:n.some((o,i)=>o!==(r==null?void 0:r[i]))},Lt=(e,t)=>{var n,r;return Et(e,t)?!1:((n=e.filter)==null?void 0:n.filter)!==((r=t.filter)==null?void 0:r.filter)},vt=(e,t)=>{let{groupBy:n}=e,{groupBy:r}=t;return b(n,r)||St(e,t)?!1:n===void 0||r===void 0||(n==null?void 0:n.length)!==(r==null?void 0:r.length)?!0:n.some((o,i)=>o!==(r==null?void 0:r[i]))},Pt=(e,t)=>{let{sort:n}=e,{sort:r}=t;return b(n,r)||Mt(e,t)?!1:n===void 0||r===void 0||(n==null?void 0:n.sortDefs.length)!==(r==null?void 0:r.sortDefs.length)?!0:n.sortDefs.some(({column:o,sortType:i},s)=>o!==r.sortDefs[s].column||i!==r.sortDefs[s].sortType)},Vt=()=>!1,Io=(e,t)=>b(e,t)?!1:e===void 0||t===void 0?!0:wt(e,t)||Ft(e,t)||Lt(e,t)||vt(e,t)||Pt(e,t)||Vt(e,t),Oo=e=>e!==void 0&&e.groupBy!==void 0&&e.groupBy.length>0,Ho=e=>(e==null?void 0:e.filter)!==void 0&&e.filter.filter.length>0,Go=e=>{var t;return(e==null?void 0:e.sort)!==void 0&&Array.isArray((t=e.sort)==null?void 0:t.sortDefs)&&e.sort.sortDefs.length>0},_o=e=>typeof e.getTypeaheadSuggestions=="function",$o=e=>e.type==="TABLE_META_RESP",No=e=>e.type==="connection-status",Uo=e=>e.type==="connection-metrics",Wo=e=>typeof e.result<"u",jo=e=>e!==void 0&&"error"in e,Bo=e=>e!=null&&"action"in e,Ko=e=>"viewport"in e,qo=e=>{if(e.aggregations&&e.columns&&e.filter&&e.groupBy&&e.sort)return e;{let{aggregations:t=[],columns:n=[],filter:r={filter:""},groupBy:o=[],sort:i={sortDefs:[]},visualLink:s}=e;return{aggregations:t,columns:n,filter:r,groupBy:o,sort:i,visualLink:s}}};function Ce(e){return e!=null}var ye={hour:"2-digit",minute:"2-digit",second:"2-digit"},kt={"hh:mm:ss":{locale:"en-GB",options:{...ye,hour12:!1}},"hh:mm:ss a":{locale:"en-GB",options:{...ye,hour12:!0}}},x={day:"2-digit",month:"2-digit",year:"numeric"},At={"dd.mm.yyyy":{locale:"de-De",options:{...x}},"dd/mm/yyyy":{locale:"en-GB",options:{...x}},"dd MMM yyyy":{locale:"en-GB",options:{...x,month:"short"}},"dd MMMM yyyy":{locale:"en-GB",options:{...x,month:"long"}},"mm/dd/yyyy":{locale:"en-US",options:{...x}},"MMM dd, yyyy":{locale:"en-US",options:{...x,month:"short"}},"MMMM dd, yyyy":{locale:"en-US",options:{...x,month:"long"}}};function It(e){return[e.date?At[e.date]:null,e.time?kt[e.time]:null]}function he(e){let t=It(e).filter(Ce).map(n=>Intl.DateTimeFormat(n.locale,n.options));return n=>t.map(r=>r.format(n)).join(" ")}var xe=["dd.mm.yyyy","dd/mm/yyyy","dd MMM yyyy","dd MMMM yyyy","mm/dd/yyyy","MMM dd, yyyy","MMMM dd, yyyy"],Te=["hh:mm:ss","hh:mm:ss a"],Ot={date:xe,time:Te},Ht=e=>xe.includes(e),Gt=e=>Te.includes(e),N=e=>Ht(e==null?void 0:e.date)||Gt(e==null?void 0:e.time);var De={time:"hh:mm:ss",date:"dd.mm.yyyy"},be={date:De.date};function Re(e){return g(e)&&e.formatting&&N(e.formatting.pattern)?e.formatting.pattern:be}var _t=["error","warn","info","debug"],$t=e=>typeof e=="string"&&_t.includes(e),Nt="error",w=()=>{},Ut="error",{loggingLevel:F=Ut}=Wt(),Ee=e=>{let t=F==="debug",n=t||F==="info",r=n||F==="warn",o=r||F==="error",i=n?l=>console.info(`[${e}] ${l}`):w,s=r?l=>console.warn(`[${e}] ${l}`):w,u=t?l=>console.debug(`[${e}] ${l}`):w;return{errorEnabled:o,error:o?l=>console.error(`[${e}] ${l}`):w}};function Wt(){return typeof loggingSettings<"u"?loggingSettings:{loggingLevel:Se()}}function Se(){let e=pe("vuu-logging-level");return $t(e)?e:Nt}var ai=()=>`const loggingSettings = { loggingLevel: "${Se()}"};`;var{debug:jt,debugEnabled:Bt}=Ee("range-monitor"),Me=class{constructor(t){this.source=t;this.range={from:0,to:0};this.timestamp=0}isSet(){return this.timestamp!==0}set({from:t,to:n}){let{timestamp:r}=this;if(this.range.from=t,this.range.to=n,this.timestamp=performance.now(),r)Bt&&jt(`<${this.source}> [${t}-${n}], ${(this.timestamp-r).toFixed(0)} ms elapsed`);else return 0}};var mi=(e,t,n)=>{let r=document.createElement(e);return t&&(r.className=t),n&&(r.textContent=n),r},Kt=(e,t)=>{if(e){if(e.hasAttribute("tabindex")){let r=parseInt(e.getAttribute("tabindex"));if(!isNaN(r)&&(t===void 0||r===t))return e}let n=typeof t=="number"?e.querySelector(`[tabindex="${t}"]`):e.querySelector("[tabindex]");if(n)return n}},fi=e=>{if(e){let t=parseInt(e.dataset.index||"");if(!isNaN(t))return t}return-1},qt=(e,t)=>e.closest(`[data-${t}]`),di=e=>qt(e,"index");function gi(e,t,n=!1){if(e===null&&n)throw Error("html-utils getElementByDataIndex, container is null");let r=e==null?void 0:e.querySelector(`[data-index="${t}"]`);if(r)return r;if(n)throw Error("html-utils getElementByDataIndex, Item not found with data-index='${index}'")}var Ci=(e,t)=>{requestAnimationFrame(()=>{let n=Kt(e,t);n&&n.focus()})},yi=e=>{let t=e==null?void 0:e.closest("[data-index]");return!(!t||t.ariaDisabled||t.dataset.selectable==="false"||t.querySelector('[data-selectable="false"],[aria-disabled="true"]'))},U;function hi(){if(U===void 0){let e=document.createElement("div");e.className="scrollable-content",e.style.width="50px",e.style.height="50px",e.style.overflowY="scroll",e.style.position="absolute",e.style.top="-200px",e.style.left="-200px";let t=document.createElement("div");t.style.height="100px",t.style.width="100%",e.appendChild(t),document.body.appendChild(e);let n=e.offsetWidth,r=t.offsetWidth;document.body.removeChild(e),U=n-r,e=null}return U}var xi=(e,t)=>{let n=new MouseEvent(t,{view:window,bubbles:!0,cancelable:!0});e.dispatchEvent(n)},Ti=(e,t)=>{let n=new Event(t,{bubbles:!0,cancelable:!0});e.dispatchEvent(n)};function we(e){return Array.isArray(e)}function zt(e){return!Array.isArray(e)}var m,Fe=class{constructor(){X(this,m,new Map)}addListener(t,n){let r=f(this,m).get(t);r?we(r)?r.push(n):zt(r)&&f(this,m).set(t,[r,n]):f(this,m).set(t,n)}removeListener(t,n){if(!f(this,m).has(t))return;let r=f(this,m).get(t),o=-1;if(r===n)f(this,m).delete(t);else if(Array.isArray(r)){for(let i=length;i-- >0;)if(r[i]===n){o=i;break}if(o<0)return;r.length===1?(r.length=0,f(this,m).delete(t)):r.splice(o,1)}}removeAllListeners(t){t&&f(this,m).has(t)?f(this,m).delete(t):t===void 0&&f(this,m).clear()}emit(t,...n){if(f(this,m)){let r=f(this,m).get(t);r&&this.invokeHandler(r,n)}}once(t,n){let r=(...o)=>{this.removeListener(t,r),n(...o)};this.on(t,r)}on(t,n){this.addListener(t,n)}hasListener(t,n){let r=f(this,m).get(t);return Array.isArray(r)?r.includes(n):r===n}invokeHandler(t,n){if(we(t))t.slice().forEach(r=>this.invokeHandler(r,n));else switch(n.length){case 0:t();break;case 1:t(n[0]);break;case 2:t(n[0],n[1]);break;default:t.call(null,...n)}}};m=new WeakMap;var L="\u2008",p="\u2007";var Le={DIGIT:p,TWO_DIGITS:p+p,THREE_DIGITS:p+p+p,FULL_PADDING:[null,L+p,L+p+p,L+p+p+p,L+p+p+p+p]},Jt={DIGIT:"0",TWO_DIGITS:"00",THREE_DIGITS:"000",FULL_PADDING:[null,"0","00","000","0000"]};function Xt(e,t=6){return(Yt+e).slice(-t)}var Yt=p+p+p+p+p+p+p+p+p,W={Right:"right",Center:"center",Left:"left"};function ve(e,t,n){let r=e.length,o=t-r;if(o>0)o===1?e=e+n.DIGIT:o===2?e=e+n.TWO_DIGITS:o===3&&(e=e+n.THREE_DIGITS);else if(o<0&&(e=e.slice(0,t),r=t),n===Le&&e.charAt(r-1)==="0")return e=e.replace(/0+$/,""),ve(e,t,n);return e}function Pe(e,t=W.Right,n=4,r,o){if(e===void 0||typeof e!="number"||isNaN(e))return"";let i,s,u,[a,l=""]=e.toString().split("."),c=l.length;return i=parseFloat(a).toLocaleString(),t===W.Left&&o&&(i=Xt(i)),n===-1||c===n?s=l:c>n?s=parseFloat("0."+l).toFixed(n).slice(2):(u=r?Jt:o&&t!==W.Left?Le:null)?c===0?s=u.FULL_PADDING[n]:s=ve(l,n,u):s=l,i+(s?"."+s:"")}var Qt={},Ve=e=>e==null?"":typeof e=="string"?e:e.toString(),Zt=e=>{let t=Re(e.type),n=he(t);return r=>typeof r=="number"&&r!==0?n(new Date(r)):""},en=({align:e="right",type:t})=>{var n;if(t===void 0||typeof t=="string")return Ve;{let{alignOnDecimals:r=!1,decimals:o,zeroPad:i=!1}=(n=t.formatting)!=null?n:Qt;return s=>{if(typeof s=="string"&&(s.startsWith("\u03A3")||s.startsWith("[")))return s;let u=typeof s=="number"?s:typeof s=="string"?parseFloat(s):void 0;return Pe(u,e,o,i,r)}}},tn=e=>t=>{var n;return(n=e[t])!=null?n:""},Li=(e,t=e.serverDataType)=>{if(ie(e))return Zt(e);let{type:n}=e;return g(n)&&se(n==null?void 0:n.renderer)?tn(n.renderer.map):t==="string"||t==="char"?r=>r:t==="double"?en(e):Ve};var Pi=()=>`hw-${Math.round(Math.random()*1e5)}`;function ki(e,t){return e?e.concat(t.name):[t.name]}var Ii=e=>e.length===1,Oi=e=>e.key==='"'||e.key==="'";function Gi(e,t){if(!e){let n=new Error(t);throw n.name="Invariant Violation",n.framesToPop=1,n}}var nn=e=>Object.prototype.toString.call(e)==="[object Object]";function $i(e){return typeof e=="string"?e:nn(e)?Object.prototype.hasOwnProperty.call(e,"label")?String(e.label):(console.warn(["itemToString: you've likely forgotten to set the label prop on the item object.","You can also provide your own `itemToString` implementation."].join(`
2
- `)),""):String(e)}var{COUNT:rn}=C,ke=e=>typeof e=="object"&&e!==null,on=["boolean","number","string"],sn=e=>on.includes(typeof e),un=e=>typeof e=="boolean"?"boolean":typeof e=="number"?"number":"string",an=(e,t)=>{if(ke(t))return{attribute:`${e}+`,attributeValue:"",type:"json"};if(t===void 0)return{attribute:e,attributeValue:"undefined",type:"string"};if(sn(t))return{attribute:e,attributeValue:t,type:un(t)};throw Error(`unsupported type ${typeof t} in JSON`)},j={name:"json",renderer:{name:"json"}},Wi=e=>{let t=[];t.push({name:"col 1",type:j},{name:"col 2",type:j});let n=[];return Ae(n,e,t),[t,n]},Ae=(e,t,n,r={value:0},o="$root",i=0)=>{let s=0,u=0;i===n.length-1&&n.push({name:`col ${n.length+1}`,hidden:!0,type:j});let a=Object.entries(t);for(let l=0;l<a.length;l++,r.value+=1){let[c,y]=a[l],{attribute:h,attributeValue:T,type:R}=an(c,y),Ne=R!=="json",Ue=Array(i).fill(""),K=`${o}|${c}`,q=[r.value,r.value,Ne,!1,i,0,K,0,...Ue,h,T];if(e.push(q),u+=1,ke(y)){let[z,J]=Ae(e,y,n,{value:r.value+1},K,i+1);q[rn]=z,s+=z,u+=J,r.value+=J}else s+=1}return[s,u]};var Bi="ArrowUp",Ki="ArrowDown",qi="ArrowLeft",zi="ArrowRight",Ji="Enter",Xi="Escape",Yi="Home",Qi="End",Zi="PageUp",es="PageDown",ts=" ",ns="Tab";var Ie=class{constructor(t){this.keys=new Map,this.free=[],this.nextKeyValue=0,this.reset(t)}next(){return this.free.length>0?this.free.shift():this.nextKeyValue++}reset({from:t,to:n}){this.keys.forEach((o,i)=>{(i<t||i>=n)&&(this.free.push(o),this.keys.delete(i))});let r=n-t;this.keys.size+this.free.length>r&&(this.free.length=Math.max(0,r-this.keys.size));for(let o=t;o<n;o++)if(!this.keys.has(o)){let i=this.next();this.keys.set(o,i)}this.nextKeyValue>this.keys.size&&(this.nextKeyValue=this.keys.size)}keyFor(t){let n=this.keys.get(t);if(n===void 0)throw console.log(`key not found
1
+ var __accessCheck = (obj, member, msg) => {
2
+ if (!member.has(obj))
3
+ throw TypeError("Cannot " + msg);
4
+ };
5
+ var __privateGet = (obj, member, getter) => {
6
+ __accessCheck(obj, member, "read from private field");
7
+ return getter ? getter.call(obj) : member.get(obj);
8
+ };
9
+ var __privateAdd = (obj, member, value) => {
10
+ if (member.has(obj))
11
+ throw TypeError("Cannot add the same private member more than once");
12
+ member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
13
+ };
14
+
15
+ // src/array-utils.ts
16
+ function partition(array, test, pass = [], fail = []) {
17
+ for (let i = 0, len = array.length; i < len; i++) {
18
+ (test(array[i], i) ? pass : fail).push(array[i]);
19
+ }
20
+ return [pass, fail];
21
+ }
22
+ function itemsChanged(currentItems, newItems, identityProperty) {
23
+ if (currentItems.length !== newItems.length) {
24
+ return true;
25
+ }
26
+ if (identityProperty === void 0) {
27
+ return !currentItems.every((item) => newItems.includes(item));
28
+ } else {
29
+ return currentItems.some(
30
+ (currentItem) => newItems.findIndex(
31
+ (newItem) => newItem[identityProperty] === currentItem[identityProperty]
32
+ ) === -1
33
+ );
34
+ }
35
+ }
36
+ function itemsOrOrderChanged(currentItems, newItems, identityProperty) {
37
+ if (currentItems.length !== newItems.length) {
38
+ return true;
39
+ }
40
+ if (identityProperty === void 0) {
41
+ return currentItems.some((item, index) => newItems[index] !== item);
42
+ } else {
43
+ return currentItems.some(
44
+ (currentItem, index) => newItems[index][identityProperty] !== currentItem[identityProperty]
45
+ );
46
+ }
47
+ }
48
+ var moveItemDeprecated = (items, item, moveTo) => {
49
+ const fromIndex = items.indexOf(item);
50
+ if (fromIndex === moveTo) {
51
+ return items;
52
+ }
53
+ const newItems = items.slice();
54
+ if (fromIndex === -1) {
55
+ throw Error("moveItem, item to be moved not found");
56
+ }
57
+ newItems.splice(fromIndex, 1);
58
+ if (moveTo === -1) {
59
+ newItems.push(item);
60
+ } else {
61
+ const offset = moveTo > fromIndex ? 0 : 0;
62
+ newItems.splice(moveTo + offset, 0, item);
63
+ }
64
+ return newItems;
65
+ };
66
+ var moveItem = (items, fromIndex, toIndex) => {
67
+ if (fromIndex === toIndex) {
68
+ return items;
69
+ } else {
70
+ const newItems = items.slice();
71
+ const [item] = newItems.splice(fromIndex, 1);
72
+ if (toIndex === -1) {
73
+ return newItems.concat(item);
74
+ } else {
75
+ const offset = toIndex > fromIndex ? 0 : 0;
76
+ newItems.splice(toIndex + offset, 0, item);
77
+ return newItems;
78
+ }
79
+ }
80
+ };
81
+ var getAddedItems = (values, newValues) => {
82
+ const isNew = (v) => !(values == null ? void 0 : values.includes(v));
83
+ if (values === void 0) {
84
+ return newValues;
85
+ } else if (newValues.some(isNew)) {
86
+ return newValues.filter(isNew);
87
+ } else {
88
+ return [];
89
+ }
90
+ };
91
+ var getMissingItems = (sourceItems, items, identity) => items.filter((i) => sourceItems.findIndex((s) => identity(s) === i) === -1);
92
+
93
+ // src/box-utils.ts
94
+ function boxContainsPoint(rect, x, y) {
95
+ if (rect) {
96
+ return x >= rect.left && x < rect.right && y >= rect.top && y < rect.bottom;
97
+ }
98
+ }
99
+
100
+ // src/filters/filterAsQuery.ts
101
+ var filterValue = (value) => typeof value === "string" ? `"${value}"` : value;
102
+ var quotedStrings = (value) => typeof value === "string" ? `"${value}"` : value;
103
+ var removeOuterMostParentheses = (s) => s.replace(/^\((.*)\)$/, "$1");
104
+ var filterAsQuery = (f, opts) => {
105
+ return removeOuterMostParentheses(filterAsQueryCore(f, opts));
106
+ };
107
+ var filterAsQueryCore = (f, opts) => {
108
+ if (isMultiClauseFilter(f)) {
109
+ const multiClauseFilter = f.filters.map((filter) => filterAsQueryCore(filter, opts)).join(` ${f.op} `);
110
+ return `(${multiClauseFilter})`;
111
+ } else if (isMultiValueFilter(f)) {
112
+ return `${f.column} ${f.op} [${f.values.map(quotedStrings).join(",")}]`;
113
+ } else {
114
+ return singleValueFilterAsQuery(f, opts);
115
+ }
116
+ };
117
+ function singleValueFilterAsQuery(f, opts) {
118
+ var _a;
119
+ const column = (_a = opts == null ? void 0 : opts.columnsByName) == null ? void 0 : _a[f.column];
120
+ if (column && isDateTimeColumn(column)) {
121
+ return dateFilterAsQuery(f);
122
+ } else {
123
+ return defaultSingleValueFilterAsQuery(f);
124
+ }
125
+ }
126
+ var ONE_DAY_IN_MILIS = 1e3 * 60 * 60 * 24;
127
+ function dateFilterAsQuery(f) {
128
+ switch (f.op) {
129
+ case "=": {
130
+ const filters = [
131
+ { op: ">=", column: f.column, value: f.value },
132
+ {
133
+ op: "<",
134
+ column: f.column,
135
+ value: f.value + ONE_DAY_IN_MILIS
136
+ }
137
+ ];
138
+ return filterAsQueryCore({ op: "and", filters });
139
+ }
140
+ case "!=": {
141
+ const filters = [
142
+ { op: "<", column: f.column, value: f.value },
143
+ {
144
+ op: ">=",
145
+ column: f.column,
146
+ value: f.value + ONE_DAY_IN_MILIS
147
+ }
148
+ ];
149
+ return filterAsQueryCore({ op: "or", filters });
150
+ }
151
+ default:
152
+ return defaultSingleValueFilterAsQuery(f);
153
+ }
154
+ }
155
+ var defaultSingleValueFilterAsQuery = (f) => `${f.column} ${f.op} ${filterValue(f.value)}`;
156
+
157
+ // src/filters/utils.ts
158
+ var singleValueFilterOps = /* @__PURE__ */ new Set([
159
+ "=",
160
+ "!=",
161
+ ">",
162
+ ">=",
163
+ "<",
164
+ "<=",
165
+ "starts",
166
+ "ends"
167
+ ]);
168
+ var isValidFilterClauseOp = (op) => op === "in" || singleValueFilterOps.has(op);
169
+ var isNamedFilter = (f) => f !== void 0 && f.name !== void 0;
170
+ var isSingleValueFilter = (f) => f !== void 0 && singleValueFilterOps.has(f.op);
171
+ var isFilterClause = (f) => f !== void 0 && (isSingleValueFilter(f) || isMultiValueFilter(f));
172
+ var isMultiValueFilter = (f) => f !== void 0 && f.op === "in";
173
+ var isInFilter = (f) => f.op === "in";
174
+ var isAndFilter = (f) => f.op === "and";
175
+ var isOrFilter = (f) => f.op === "or";
176
+ var isCompleteFilter = (filter) => isSingleValueFilter(filter) && filter.column !== void 0 && filter.op !== void 0 && filter.value !== void 0;
177
+ function isMultiClauseFilter(f) {
178
+ return f !== void 0 && (f.op === "and" || f.op === "or");
179
+ }
180
+ var removeColumnFromFilter = (column, filter) => {
181
+ if (isMultiClauseFilter(filter)) {
182
+ const [clause1, clause2] = filter.filters;
183
+ if (clause1.column === column.name) {
184
+ return [clause2, filterAsQuery(clause2)];
185
+ }
186
+ if (clause2.column === column.name) {
187
+ return [clause1, filterAsQuery(clause1)];
188
+ }
189
+ }
190
+ return [void 0, ""];
191
+ };
192
+
193
+ // src/column-utils.ts
194
+ var SORT_ASC = "asc";
195
+ var NO_HEADINGS = [];
196
+ var DEFAULT_COL_WIDTH = 100;
197
+ var DEFAULT_MAX_WIDTH = 250;
198
+ var DEFAULT_MIN_WIDTH = 50;
199
+ var AggregationType = {
200
+ Average: 2,
201
+ Count: 3,
202
+ Distinct: 6,
203
+ Sum: 1,
204
+ High: 4,
205
+ Low: 5
206
+ };
207
+ function mapSortCriteria(sortCriteria, columnMap, metadataOffset = 0) {
208
+ return sortCriteria.map((s) => {
209
+ if (typeof s === "string") {
210
+ return [columnMap[s] + metadataOffset, "asc"];
211
+ } else if (Array.isArray(s)) {
212
+ const [columnName, sortDir] = s;
213
+ return [columnMap[columnName] + metadataOffset, sortDir || SORT_ASC];
214
+ } else {
215
+ throw Error("columnUtils.mapSortCriteria invalid input");
216
+ }
217
+ });
218
+ }
219
+ var numericTypes = ["int", "long", "double"];
220
+ var getDefaultAlignment = (serverDataType) => serverDataType === void 0 ? "left" : numericTypes.includes(serverDataType) ? "right" : "left";
221
+ var isValidColumnAlignment = (v) => v === "left" || v === "right";
222
+ var isValidPinLocation = (v) => isValidColumnAlignment(v) || v === "floating" || v === "";
223
+ var fromServerDataType = (serverDataType) => {
224
+ switch (serverDataType) {
225
+ case "double":
226
+ case "int":
227
+ case "long":
228
+ return "number";
229
+ case "boolean":
230
+ return "boolean";
231
+ default:
232
+ return "string";
233
+ }
234
+ };
235
+ var isNumericColumn = ({ serverDataType, type }) => {
236
+ if (serverDataType === "int" || serverDataType === "long" || serverDataType === "double") {
237
+ return true;
238
+ }
239
+ if (typeof type === "string") {
240
+ return type === "number";
241
+ }
242
+ if (typeof (type == null ? void 0 : type.name) === "string") {
243
+ return (type == null ? void 0 : type.name) === "number";
244
+ }
245
+ return false;
246
+ };
247
+ var isDateTimeColumn = (column) => (isTypeDescriptor(column.type) ? column.type.name : column.type) === "date/time";
248
+ var isPinned = (column) => typeof column.pin === "string";
249
+ var hasHeadings = (column) => Array.isArray(column.heading) && column.heading.length > 0;
250
+ var isResizing = (column) => column.resizing;
251
+ var isTextColumn = ({ serverDataType }) => serverDataType === void 0 ? false : serverDataType === "char" || serverDataType === "string";
252
+ var toColumnDescriptor = (name) => ({
253
+ name
254
+ });
255
+ var isTypeDescriptor = (type) => typeof type !== "undefined" && typeof type !== "string";
256
+ var EMPTY_COLUMN_MAP = {};
257
+ var isColumnTypeRenderer = (renderer) => typeof (renderer == null ? void 0 : renderer.name) !== "undefined";
258
+ var isLookupRenderer = (renderer) => typeof (renderer == null ? void 0 : renderer.name) !== "undefined" && "lookup" in renderer;
259
+ var isValueListRenderer = (renderer) => typeof (renderer == null ? void 0 : renderer.name) !== "undefined" && Array.isArray(renderer.values);
260
+ var hasValidationRules = (type) => isTypeDescriptor(type) && isColumnTypeRenderer(type.renderer) && Array.isArray(type.renderer.rules) && type.renderer.rules.length > 0;
261
+ var isMappedValueTypeRenderer = (renderer) => renderer !== void 0 && typeof (renderer == null ? void 0 : renderer.map) !== "undefined";
262
+ function buildColumnMap(columns) {
263
+ const start = metadataKeys.count;
264
+ if (columns) {
265
+ return columns.reduce((map, column, i) => {
266
+ if (typeof column === "string") {
267
+ map[column] = start + i;
268
+ } else {
269
+ map[column.name] = start + i;
270
+ }
271
+ return map;
272
+ }, {});
273
+ } else {
274
+ return EMPTY_COLUMN_MAP;
275
+ }
276
+ }
277
+ function projectUpdates(updates) {
278
+ const results = [];
279
+ const metadataOffset = metadataKeys.count - 2;
280
+ for (let i = 0; i < updates.length; i += 3) {
281
+ results[i] = updates[i] + metadataOffset;
282
+ results[i + 1] = updates[i + 1];
283
+ results[i + 2] = updates[i + 2];
284
+ }
285
+ return results;
286
+ }
287
+ var metadataKeys = {
288
+ IDX: 0,
289
+ RENDER_IDX: 1,
290
+ IS_LEAF: 2,
291
+ IS_EXPANDED: 3,
292
+ DEPTH: 4,
293
+ COUNT: 5,
294
+ KEY: 6,
295
+ SELECTED: 7,
296
+ count: 8,
297
+ // TODO following only used in datamodel
298
+ PARENT_IDX: "parent_idx",
299
+ IDX_POINTER: "idx_pointer",
300
+ FILTER_COUNT: "filter_count",
301
+ NEXT_FILTER_IDX: "next_filter_idx"
302
+ };
303
+ var insertColumn = (columns, column) => {
304
+ const { originalIdx } = column;
305
+ if (typeof originalIdx === "number") {
306
+ for (let i = 0; i < columns.length; i++) {
307
+ const { originalIdx: colIdx = -1 } = columns[i];
308
+ if (colIdx > originalIdx) {
309
+ columns.splice(i, 0, column);
310
+ return columns;
311
+ }
312
+ }
313
+ }
314
+ columns.push(column);
315
+ return columns;
316
+ };
317
+ var flattenColumnGroup = (columns) => {
318
+ var _a;
319
+ if ((_a = columns[0]) == null ? void 0 : _a.isGroup) {
320
+ const [groupColumn, ...nonGroupedColumns] = columns;
321
+ groupColumn.columns.forEach((groupColumn2) => {
322
+ insertColumn(nonGroupedColumns, groupColumn2);
323
+ });
324
+ return nonGroupedColumns;
325
+ } else {
326
+ return columns;
327
+ }
328
+ };
329
+ function extractGroupColumn(columns, groupBy, confirmed = true) {
330
+ if (groupBy && groupBy.length > 0) {
331
+ const flattenedColumns = flattenColumnGroup(columns);
332
+ const [groupedColumns, rest] = flattenedColumns.reduce(
333
+ (result, column, i) => {
334
+ const [g, r2] = result;
335
+ if (groupBy.includes(column.name)) {
336
+ g.push({
337
+ ...column,
338
+ originalIdx: i
339
+ });
340
+ } else {
341
+ r2.push(column);
342
+ }
343
+ return result;
344
+ },
345
+ [[], []]
346
+ );
347
+ if (groupedColumns.length !== groupBy.length) {
348
+ throw Error(
349
+ `extractGroupColumn: no column definition found for all groupBy cols ${JSON.stringify(
350
+ groupBy
351
+ )} `
352
+ );
353
+ }
354
+ const groupCount = groupBy.length;
355
+ const groupCols = groupBy.map((name, idx) => {
356
+ const column = groupedColumns.find(
357
+ (col) => col.name === name
358
+ );
359
+ return {
360
+ ...column,
361
+ groupLevel: groupCount - idx
362
+ };
363
+ });
364
+ const groupCol = {
365
+ name: "group-col",
366
+ heading: ["group-col"],
367
+ isGroup: true,
368
+ columns: groupCols,
369
+ groupConfirmed: confirmed,
370
+ width: groupCols.map((c) => c.width).reduce((a, b) => a + b) + 100
371
+ };
372
+ return [groupCol, rest];
373
+ }
374
+ return [null, flattenColumnGroup(columns)];
375
+ }
376
+ var isGroupColumn = (column) => column.isGroup === true;
377
+ var isJsonAttribute = (value) => typeof value === "string" && value.endsWith("+");
378
+ var isJsonGroup = (column, row, columnMap) => {
379
+ var _a;
380
+ return ((_a = column.type) == null ? void 0 : _a.name) === "json" && isJsonAttribute(row[columnMap[column.name]]);
381
+ };
382
+ var isJsonColumn = (column) => {
383
+ var _a;
384
+ return ((_a = column.type) == null ? void 0 : _a.name) === "json";
385
+ };
386
+ var sortPinnedColumns = (columns) => {
387
+ const leftPinnedColumns = [];
388
+ const rightPinnedColumns = [];
389
+ const restColumns = [];
390
+ let pinnedWidthLeft = 4;
391
+ for (const column of columns) {
392
+ switch (column.pin) {
393
+ case "left":
394
+ {
395
+ leftPinnedColumns.push({
396
+ ...column,
397
+ endPin: void 0,
398
+ pinnedOffset: pinnedWidthLeft
399
+ });
400
+ pinnedWidthLeft += column.width;
401
+ }
402
+ break;
403
+ case "right":
404
+ rightPinnedColumns.unshift(column);
405
+ break;
406
+ default:
407
+ restColumns.push(column);
408
+ }
409
+ }
410
+ if (leftPinnedColumns.length) {
411
+ leftPinnedColumns.push({
412
+ ...leftPinnedColumns.pop(),
413
+ endPin: true
414
+ });
415
+ }
416
+ const allColumns = leftPinnedColumns.length ? leftPinnedColumns.concat(restColumns) : restColumns;
417
+ if (rightPinnedColumns.length) {
418
+ const measuredRightPinnedColumns = [];
419
+ let pinnedWidthRight = 0;
420
+ for (const column of rightPinnedColumns) {
421
+ measuredRightPinnedColumns.unshift({
422
+ ...column,
423
+ pinnedOffset: pinnedWidthRight
424
+ });
425
+ pinnedWidthRight += column.width;
426
+ }
427
+ measuredRightPinnedColumns[0].endPin = true;
428
+ return allColumns.concat(measuredRightPinnedColumns);
429
+ } else {
430
+ return allColumns;
431
+ }
432
+ };
433
+ var measurePinnedColumns = (columns, selectionEndSize) => {
434
+ let pinnedWidthLeft = 0;
435
+ let pinnedWidthRight = 0;
436
+ let unpinnedWidth = 0;
437
+ for (const column of columns) {
438
+ const { hidden, pin, width } = column;
439
+ const visibleWidth = hidden ? 0 : width;
440
+ if (pin === "left") {
441
+ pinnedWidthLeft += visibleWidth;
442
+ } else if (pin === "right") {
443
+ pinnedWidthRight += visibleWidth;
444
+ } else {
445
+ unpinnedWidth += visibleWidth;
446
+ }
447
+ }
448
+ return {
449
+ pinnedWidthLeft: pinnedWidthLeft + selectionEndSize,
450
+ pinnedWidthRight: pinnedWidthRight + selectionEndSize,
451
+ unpinnedWidth
452
+ };
453
+ };
454
+ var getTableHeadings = (columns) => {
455
+ if (columns.some(hasHeadings)) {
456
+ const maxHeadingDepth = columns.reduce(
457
+ (max, { heading: heading2 }) => {
458
+ var _a;
459
+ return Math.max(max, (_a = heading2 == null ? void 0 : heading2.length) != null ? _a : 0);
460
+ },
461
+ 0
462
+ );
463
+ let heading = void 0;
464
+ const tableHeadings = [];
465
+ let tableHeadingsRow;
466
+ for (let level = 0; level < maxHeadingDepth; level++) {
467
+ tableHeadingsRow = [];
468
+ columns.forEach(({ heading: columnHeading = NO_HEADINGS, width }) => {
469
+ var _a;
470
+ const label = (_a = columnHeading[level]) != null ? _a : "";
471
+ if (heading && heading.label === label) {
472
+ heading.width += width;
473
+ } else {
474
+ heading = { label, width };
475
+ tableHeadingsRow.push(heading);
476
+ }
477
+ });
478
+ tableHeadings.push(tableHeadingsRow);
479
+ }
480
+ return tableHeadings;
481
+ }
482
+ return NO_HEADINGS;
483
+ };
484
+ var getColumnStyle = ({
485
+ pin,
486
+ // the 4 is `selectionEndSize`, unfortunate if we need to be passed it from cell
487
+ // need to think about how to make this available
488
+ pinnedOffset = pin === "left" ? 0 : 4,
489
+ width
490
+ }) => pin === "left" ? {
491
+ left: pinnedOffset,
492
+ width,
493
+ "--pin-width": `${pinnedOffset + width - 3}px`
494
+ } : pin === "right" ? {
495
+ right: pinnedOffset,
496
+ width,
497
+ "--pin-width": `${pinnedOffset + width}px`
498
+ } : { width };
499
+ var setAggregations = (aggregations, column, aggType) => {
500
+ return aggregations.filter((agg) => agg.column !== column.name).concat({ column: column.name, aggType });
501
+ };
502
+ var extractFilterForColumn = (filter, columnName) => {
503
+ if (isMultiClauseFilter(filter)) {
504
+ return collectFiltersForColumn(filter, columnName);
505
+ }
506
+ if (isFilterClause(filter)) {
507
+ return filter.column === columnName ? filter : void 0;
508
+ }
509
+ return void 0;
510
+ };
511
+ var collectFiltersForColumn = (filter, columnName) => {
512
+ const { filters, op } = filter;
513
+ const results = [];
514
+ filters.forEach((filter2) => {
515
+ const ffc = extractFilterForColumn(filter2, columnName);
516
+ if (ffc) {
517
+ results.push(ffc);
518
+ }
519
+ });
520
+ if (results.length === 0) {
521
+ return void 0;
522
+ } else if (results.length === 1) {
523
+ return results[0];
524
+ }
525
+ return {
526
+ op,
527
+ filters: results
528
+ };
529
+ };
530
+ var applyGroupByToColumns = (columns, groupBy, confirmed = true) => {
531
+ var _a;
532
+ if (groupBy.length) {
533
+ const [groupColumn, nonGroupedColumns] = extractGroupColumn(
534
+ columns,
535
+ groupBy,
536
+ confirmed
537
+ );
538
+ if (groupColumn) {
539
+ return [groupColumn].concat(nonGroupedColumns);
540
+ }
541
+ } else if ((_a = columns[0]) == null ? void 0 : _a.isGroup) {
542
+ return flattenColumnGroup(columns);
543
+ }
544
+ return columns;
545
+ };
546
+ var applySortToColumns = (colunms, sort) => colunms.map((column) => {
547
+ const sorted = getSortType(column, sort);
548
+ if (sorted !== void 0) {
549
+ return {
550
+ ...column,
551
+ sorted
552
+ };
553
+ } else if (column.sorted) {
554
+ return {
555
+ ...column,
556
+ sorted: void 0
557
+ };
558
+ } else {
559
+ return column;
560
+ }
561
+ });
562
+ var applyFilterToColumns = (columns, { filterStruct }) => columns.map((column) => {
563
+ const filter = extractFilterForColumn(filterStruct, column.name);
564
+ if (filter !== void 0) {
565
+ return {
566
+ ...column,
567
+ filter
568
+ };
569
+ } else if (column.filter) {
570
+ return {
571
+ ...column,
572
+ filter: void 0
573
+ };
574
+ } else {
575
+ return column;
576
+ }
577
+ });
578
+ var isFilteredColumn = (column) => column.filter !== void 0;
579
+ var stripFilterFromColumns = (columns) => columns.map((col) => {
580
+ const { filter, ...rest } = col;
581
+ return filter ? rest : col;
582
+ });
583
+ var getSortType = (column, { sortDefs }) => {
584
+ const sortDef = sortDefs.find((sortCol) => sortCol.column === column.name);
585
+ if (sortDef) {
586
+ return sortDefs.length > 1 ? (sortDefs.indexOf(sortDef) + 1) * (sortDef.sortType === "A" ? 1 : -1) : sortDef.sortType;
587
+ }
588
+ };
589
+ var getColumnName = (name) => {
590
+ const pos = name.indexOf(":");
591
+ if (pos === -1) {
592
+ return name;
593
+ } else {
594
+ return name.slice(0, pos);
595
+ }
596
+ };
597
+ var getColumnLabel = (column) => {
598
+ if (column.label) {
599
+ return column.label;
600
+ } else if (isCalculatedColumn(column.name)) {
601
+ return getCalculatedColumnName(column);
602
+ } else {
603
+ return column.name;
604
+ }
605
+ };
606
+ var findColumn = (columns, columnName) => {
607
+ const column = columns.find((col) => col.name === columnName);
608
+ if (column) {
609
+ return column;
610
+ } else {
611
+ const groupColumn = columns.find(
612
+ (col) => col.isGroup
613
+ );
614
+ if (groupColumn) {
615
+ return findColumn(groupColumn.columns, columnName);
616
+ }
617
+ }
618
+ };
619
+ function updateColumn(columns, column, options) {
620
+ const targetColumn = typeof column === "string" ? columns.find((col) => col.name === column) : column;
621
+ if (targetColumn) {
622
+ const replacementColumn = options ? { ...targetColumn, ...options } : targetColumn;
623
+ return columns.map(
624
+ (col) => col.name === replacementColumn.name ? replacementColumn : col
625
+ );
626
+ } else {
627
+ throw Error("column-utils.replaceColun, column not found");
628
+ }
629
+ }
630
+ var toDataSourceColumns = (column) => column.name;
631
+ var getRowRecord = (row, columnMap) => {
632
+ return Object.entries(columnMap).reduce(
633
+ (map, [colName, key]) => {
634
+ map[colName] = row[key];
635
+ return map;
636
+ },
637
+ {}
638
+ );
639
+ };
640
+ var isDataLoading = (columns) => {
641
+ return isGroupColumn(columns[0]) && columns[0].groupConfirmed === false;
642
+ };
643
+ var getColumnsInViewport = (columns, vpStart, vpEnd) => {
644
+ var _a;
645
+ const visibleColumns = [];
646
+ let preSpan = 0;
647
+ let rightPinnedOnly = false;
648
+ for (let columnOffset = 0, i = 0; i < columns.length; i++) {
649
+ const column = columns[i];
650
+ if (column.hidden) {
651
+ continue;
652
+ } else if (rightPinnedOnly) {
653
+ if (column.pin === "right") {
654
+ visibleColumns.push(column);
655
+ }
656
+ } else if (columnOffset + column.width < vpStart) {
657
+ if (column.pin === "left") {
658
+ visibleColumns.push(column);
659
+ } else if (columnOffset + column.width + ((_a = columns[i + 1]) == null ? void 0 : _a.width) > vpStart) {
660
+ visibleColumns.push(column);
661
+ } else {
662
+ preSpan += column.width;
663
+ }
664
+ } else if (columnOffset > vpEnd) {
665
+ rightPinnedOnly = true;
666
+ } else {
667
+ visibleColumns.push(column);
668
+ }
669
+ columnOffset += column.width;
670
+ }
671
+ return [visibleColumns, preSpan];
672
+ };
673
+ var isNotHidden = (column) => column.hidden !== true;
674
+ var visibleColumnAtIndex = (columns, index) => {
675
+ if (columns.every(isNotHidden)) {
676
+ return columns[index];
677
+ } else {
678
+ return columns.filter(isNotHidden).at(index);
679
+ }
680
+ };
681
+ var { DEPTH, IS_LEAF } = metadataKeys;
682
+ var getGroupValueAndOffset = (columns, row, columnMap) => {
683
+ const { [DEPTH]: depth, [IS_LEAF]: isLeaf } = row;
684
+ if (isLeaf || depth > columns.length) {
685
+ return [null, depth === null ? 0 : Math.max(0, depth - 1)];
686
+ } else if (depth === 0) {
687
+ return ["$root", 0];
688
+ } else {
689
+ const { name, valueFormatter } = columns[depth - 1];
690
+ const value = valueFormatter(row[columnMap[name]]);
691
+ return [value, depth - 1];
692
+ }
693
+ };
694
+ var getDefaultColumnType = (serverDataType) => {
695
+ switch (serverDataType) {
696
+ case "int":
697
+ case "long":
698
+ case "double":
699
+ return "number";
700
+ case "boolean":
701
+ return "boolean";
702
+ default:
703
+ return "string";
704
+ }
705
+ };
706
+ var updateColumnFormatting = (column, formatting) => {
707
+ const { serverDataType, type = getDefaultColumnType(serverDataType) } = column;
708
+ if (isTypeDescriptor(type)) {
709
+ return { ...column, type: { ...type, formatting } };
710
+ } else {
711
+ return { ...column, type: { name: type, formatting } };
712
+ }
713
+ };
714
+ function updateColumnType(column, type) {
715
+ return isTypeDescriptor(column.type) ? { ...column, type: { ...column.type, name: type } } : { ...column, type };
716
+ }
717
+ var updateColumnRenderProps = (column, renderer) => {
718
+ const { serverDataType, type = getDefaultColumnType(serverDataType) } = column;
719
+ if (isTypeDescriptor(type)) {
720
+ return {
721
+ ...column,
722
+ type: {
723
+ ...type,
724
+ // TODO do we need to preserve any existing attributes from renderer ?
725
+ renderer
726
+ }
727
+ };
728
+ } else {
729
+ return { ...column, type: { name: type, renderer } };
730
+ }
731
+ };
732
+ var NO_TYPE_SETTINGS = {};
733
+ var getTypeFormattingFromColumn = (column) => {
734
+ var _a;
735
+ if (isTypeDescriptor(column.type)) {
736
+ return (_a = column.type.formatting) != null ? _a : NO_TYPE_SETTINGS;
737
+ } else {
738
+ return NO_TYPE_SETTINGS;
739
+ }
740
+ };
741
+ var subscribedOnly = (columnNames) => (column) => columnNames == null ? void 0 : columnNames.includes(column.name);
742
+ var addColumnToSubscribedColumns = (subscribedColumns, availableColumns, columnName) => {
743
+ const byColName = (n = columnName) => (column) => column.name === n;
744
+ if (subscribedColumns.findIndex(byColName()) !== -1) {
745
+ throw Error(
746
+ `column-utils, addColumnToSubscribedColumns column ${columnName} is already subscribed`
747
+ );
748
+ }
749
+ const indexOfAvailableColumn = availableColumns.findIndex(byColName());
750
+ if (indexOfAvailableColumn === -1) {
751
+ throw Error(
752
+ `column-utils, addColumnToSubscribedColumns column ${columnName} is not available`
753
+ );
754
+ }
755
+ const newColumn = {
756
+ ...availableColumns[indexOfAvailableColumn]
757
+ };
758
+ let index = -1;
759
+ for (let i = indexOfAvailableColumn - 1; i >= 0; i--) {
760
+ const { name } = availableColumns[i];
761
+ index = subscribedColumns.findIndex(byColName(name));
762
+ if (index !== -1) {
763
+ break;
764
+ }
765
+ }
766
+ if (index === -1) {
767
+ return [newColumn].concat(subscribedColumns);
768
+ } else {
769
+ const results = [];
770
+ for (let i = 0; i < subscribedColumns.length; i++) {
771
+ results.push(subscribedColumns[i]);
772
+ if (i === index) {
773
+ results.push(newColumn);
774
+ index = Number.MAX_SAFE_INTEGER;
775
+ }
776
+ }
777
+ return results;
778
+ }
779
+ };
780
+ var CalculatedColumnPattern = /.*:.*:.*/;
781
+ var isCalculatedColumn = (columnName) => columnName !== void 0 && CalculatedColumnPattern.test(columnName);
782
+ var getCalculatedColumnDetails = (column) => {
783
+ if (isCalculatedColumn(column.name)) {
784
+ return column.name.split(/:=?/);
785
+ } else {
786
+ throw Error(
787
+ `column-utils, getCalculatedColumnDetails column name ${column.name} is not valid calculated column`
788
+ );
789
+ }
790
+ };
791
+ var getCalculatedColumnName = (column) => getCalculatedColumnDetails(column)[0];
792
+ var getCalculatedColumnType = (column) => getCalculatedColumnDetails(column)[1];
793
+ var getCalculatedColumnExpression = (column) => getCalculatedColumnDetails(column)[2];
794
+ var setCalculatedColumnName = (column, name) => {
795
+ const [, type, expression] = column.name.split(":");
796
+ return {
797
+ ...column,
798
+ name: `${name}:${type}:${expression}`
799
+ };
800
+ };
801
+ var setCalculatedColumnType = (column, type) => {
802
+ const [name, , expression] = column.name.split(":");
803
+ return {
804
+ ...column,
805
+ name: `${name}:${type}:${expression}`
806
+ };
807
+ };
808
+ var setCalculatedColumnExpression = (column, expression) => {
809
+ const [name, type] = column.name.split(":");
810
+ return {
811
+ ...column,
812
+ name: `${name}:${type}:=${expression}`
813
+ };
814
+ };
815
+ var moveColumnTo = (columns, column, newIndex) => {
816
+ const index = columns.findIndex((col) => col.name === column.name);
817
+ return moveItem(columns, index, newIndex);
818
+ };
819
+ function replaceColumn(columns, column) {
820
+ return columns.map((col) => col.name === column.name ? column : col);
821
+ }
822
+ var applyDefaultColumnConfig = ({ columns, table }, getDefaultColumnConfig) => {
823
+ if (typeof getDefaultColumnConfig === "function") {
824
+ return columns.map((column) => {
825
+ const config = getDefaultColumnConfig(table.table, column.name);
826
+ if (config) {
827
+ return {
828
+ ...column,
829
+ ...config
830
+ };
831
+ } else {
832
+ return column;
833
+ }
834
+ });
835
+ } else {
836
+ return columns;
837
+ }
838
+ };
839
+ var getColumnByName = (schema, name) => {
840
+ if (name === void 0) {
841
+ return void 0;
842
+ } else {
843
+ const column = schema.columns.find((col) => col.name === name);
844
+ if (column) {
845
+ return column;
846
+ } else {
847
+ throw Error(
848
+ `getColumnByName no column '${name}' in schema for ${schema.table.table}`
849
+ );
850
+ }
851
+ }
852
+ };
853
+ function applyWidthToColumns(columns, options) {
854
+ const {
855
+ availableWidth = 0,
856
+ columnLayout = "Static",
857
+ defaultWidth = DEFAULT_COL_WIDTH,
858
+ defaultMinWidth = DEFAULT_MIN_WIDTH,
859
+ defaultMaxWidth = DEFAULT_MAX_WIDTH
860
+ // defaultFlex = DEFAULT_FLEX,
861
+ } = options;
862
+ if (columnLayout === "Static") {
863
+ return columns.map((column) => {
864
+ if (typeof column.width === "number") {
865
+ return column;
866
+ } else {
867
+ return {
868
+ ...column,
869
+ width: defaultWidth
870
+ };
871
+ }
872
+ });
873
+ } else if (columnLayout === "Fit") {
874
+ const { totalMinWidth, totalMaxWidth, totalWidth, flexCount } = columns.reduce(
875
+ (aggregated, column) => {
876
+ const { totalMinWidth: totalMinWidth2, totalMaxWidth: totalMaxWidth2, totalWidth: totalWidth2, flexCount: flexCount2 } = aggregated;
877
+ const {
878
+ minWidth = defaultMinWidth,
879
+ maxWidth = defaultMaxWidth,
880
+ width = defaultWidth,
881
+ flex = 0
882
+ } = column;
883
+ return {
884
+ totalMinWidth: totalMinWidth2 + minWidth,
885
+ totalMaxWidth: totalMaxWidth2 + maxWidth,
886
+ totalWidth: totalWidth2 + width,
887
+ flexCount: flexCount2 + flex
888
+ };
889
+ },
890
+ { totalMinWidth: 0, totalMaxWidth: 0, totalWidth: 0, flexCount: 0 }
891
+ );
892
+ if (totalMinWidth > availableWidth || totalMaxWidth < availableWidth) {
893
+ return columns;
894
+ } else if (totalWidth > availableWidth) {
895
+ const excessWidth = totalWidth - availableWidth;
896
+ const inFlexMode = flexCount > 0;
897
+ let excessWidthPerColumn = excessWidth / (flexCount || columns.length);
898
+ let columnsNotYetAtMinWidth = columns.length;
899
+ let unassignedExcess = 0;
900
+ let newColumns = columns.map((column) => {
901
+ const {
902
+ minWidth = defaultMinWidth,
903
+ width = defaultWidth,
904
+ flex = 0
905
+ } = column;
906
+ if (inFlexMode && flex === 0) {
907
+ return column;
908
+ }
909
+ const adjustedWidth = width - excessWidthPerColumn;
910
+ if (adjustedWidth < minWidth) {
911
+ columnsNotYetAtMinWidth -= 1;
912
+ unassignedExcess += minWidth - adjustedWidth;
913
+ return { ...column, width: minWidth };
914
+ } else {
915
+ return { ...column, width: adjustedWidth };
916
+ }
917
+ });
918
+ if (unassignedExcess === 0) {
919
+ return newColumns;
920
+ } else {
921
+ excessWidthPerColumn = unassignedExcess / columnsNotYetAtMinWidth;
922
+ newColumns = newColumns.map((column) => {
923
+ const adjustedWidth = column.width - excessWidthPerColumn;
924
+ if (column.width !== column.minWidth) {
925
+ return { ...column, width: adjustedWidth };
926
+ } else {
927
+ return column;
928
+ }
929
+ });
930
+ return newColumns;
931
+ }
932
+ } else if (totalWidth < availableWidth) {
933
+ {
934
+ const additionalWidth = availableWidth - totalWidth;
935
+ const inFlexMode = flexCount > 0;
936
+ let additionalWidthPerColumn = additionalWidth / (flexCount || columns.length);
937
+ let newColumns = columns.map((column) => {
938
+ const {
939
+ maxWidth = defaultMaxWidth,
940
+ width = defaultWidth,
941
+ flex = 0
942
+ } = column;
943
+ if (inFlexMode && flex === 0) {
944
+ return column;
945
+ }
946
+ const adjustedWidth = width + additionalWidthPerColumn;
947
+ if (adjustedWidth > maxWidth) {
948
+ return { ...column, width: maxWidth };
949
+ } else {
950
+ return { ...column, width: adjustedWidth, canStretch: true };
951
+ }
952
+ });
953
+ const unassignedAdditionalColumnWidth = additionalWidth - newColumns.reduce((sum, col) => sum + col.width, 0);
954
+ const columnsNotYetAtMaxWidth = newColumns.filter(
955
+ (col) => col.canStretch
956
+ ).length;
957
+ if (unassignedAdditionalColumnWidth > columnsNotYetAtMaxWidth) {
958
+ additionalWidthPerColumn = unassignedAdditionalColumnWidth / columnsNotYetAtMaxWidth;
959
+ newColumns = newColumns.map((column) => {
960
+ if (column.canStretch) {
961
+ const adjustedWidth = Math.min(
962
+ column.width + additionalWidthPerColumn
963
+ );
964
+ return { ...column, width: adjustedWidth };
965
+ } else {
966
+ return column;
967
+ }
968
+ });
969
+ }
970
+ return newColumns.map(({ canStretch, ...column }) => column);
971
+ }
972
+ }
973
+ }
974
+ return columns;
975
+ }
976
+ var dataAndColumnUnchanged = (p, p1) => p.column === p1.column && p.column.valueFormatter(p.row[p.columnMap[p.column.name]]) === p1.column.valueFormatter(p1.row[p1.columnMap[p1.column.name]]);
977
+
978
+ // src/cookie-utils.ts
979
+ var getCookieValue = (name) => {
980
+ var _a, _b;
981
+ if (((_a = globalThis.document) == null ? void 0 : _a.cookie) !== void 0) {
982
+ return (_b = globalThis.document.cookie.split("; ").find((row) => row.startsWith(`${name}=`))) == null ? void 0 : _b.split("=")[1];
983
+ }
984
+ };
985
+
986
+ // src/component-registry.ts
987
+ var cellRenderersMap = /* @__PURE__ */ new Map();
988
+ var columnHeaderRenderersMap = /* @__PURE__ */ new Map();
989
+ var configEditorsMap = /* @__PURE__ */ new Map();
990
+ var cellConfigPanelsMap = /* @__PURE__ */ new Map();
991
+ var editRuleValidatorsMap = /* @__PURE__ */ new Map();
992
+ var optionsMap = /* @__PURE__ */ new Map();
993
+ var isTypeCompatible = (rendererType, serverDataType) => {
994
+ if (rendererType === void 0 || rendererType === "private") {
995
+ return true;
996
+ } else if (Array.isArray(rendererType)) {
997
+ return rendererType.includes(serverDataType);
998
+ } else {
999
+ return rendererType === serverDataType;
1000
+ }
1001
+ };
1002
+ var isCellRenderer = (type, component) => type === "cell-renderer";
1003
+ var isColumnHeaderContentRenderer = (type, component) => type === "column-header-content-renderer";
1004
+ var isColumnHeaderLabelRenderer = (type, component) => type === "column-header-label-renderer";
1005
+ var isCellConfigPanel = (type, component) => type === "cell-config-panel";
1006
+ var isEditRuleValidator = (type, component) => type === "data-edit-validator";
1007
+ function registerComponent(componentName, component, type = "cell-renderer", options) {
1008
+ if (isCellRenderer(type, component)) {
1009
+ cellRenderersMap.set(componentName, component);
1010
+ } else if (isColumnHeaderContentRenderer(type, component)) {
1011
+ columnHeaderRenderersMap.set(componentName, component);
1012
+ } else if (isColumnHeaderLabelRenderer(type, component)) {
1013
+ columnHeaderRenderersMap.set(componentName, component);
1014
+ } else if (isCellConfigPanel(type, component)) {
1015
+ cellConfigPanelsMap.set(componentName, component);
1016
+ } else if (isEditRuleValidator(type, component)) {
1017
+ editRuleValidatorsMap.set(componentName, component);
1018
+ }
1019
+ if (options) {
1020
+ optionsMap.set(componentName, options);
1021
+ }
1022
+ }
1023
+ var registerConfigurationEditor = (componentName, configurationEditor) => {
1024
+ configEditorsMap.set(componentName, configurationEditor);
1025
+ };
1026
+ var getRegisteredCellRenderers = (serverDataType) => {
1027
+ const rendererNames = Array.from(cellRenderersMap.keys());
1028
+ const allRenderers = rendererNames.map((name) => ({
1029
+ name,
1030
+ ...optionsMap.get(name)
1031
+ }));
1032
+ if (serverDataType) {
1033
+ return allRenderers.filter(
1034
+ (renderer) => isTypeCompatible(renderer.serverDataType, serverDataType)
1035
+ );
1036
+ } else {
1037
+ return allRenderers;
1038
+ }
1039
+ };
1040
+ var getCellRendererOptions = (renderName) => optionsMap.get(renderName);
1041
+ function getCellRenderer(column) {
1042
+ return dataCellRenderer(column);
1043
+ }
1044
+ function getColumnHeaderContentRenderer(column) {
1045
+ if (column.colHeaderContentRenderer) {
1046
+ return columnHeaderRenderersMap.get(column.colHeaderContentRenderer);
1047
+ }
1048
+ }
1049
+ function getColumnHeaderLabelRenderer(column) {
1050
+ if (column.colHeaderLabelRenderer) {
1051
+ return columnHeaderRenderersMap.get(column.colHeaderLabelRenderer);
1052
+ }
1053
+ }
1054
+ function dataCellRenderer(column) {
1055
+ if (isTypeDescriptor(column.type)) {
1056
+ const { renderer } = column.type;
1057
+ if (isColumnTypeRenderer(renderer)) {
1058
+ return cellRenderersMap.get(renderer.name);
1059
+ }
1060
+ } else if (column.serverDataType === "boolean") {
1061
+ return cellRenderersMap.get("checkbox-cell");
1062
+ } else if (column.editable) {
1063
+ return cellRenderersMap.get("input-cell");
1064
+ }
1065
+ }
1066
+ function getConfigurationEditor(configEditor = "") {
1067
+ return configEditorsMap.get(configEditor);
1068
+ }
1069
+ function getCellConfigPanelRenderer(name) {
1070
+ return cellConfigPanelsMap.get(name);
1071
+ }
1072
+ function getEditRuleValidator(name) {
1073
+ return editRuleValidatorsMap.get(name);
1074
+ }
1075
+
1076
+ // src/range-utils.ts
1077
+ var NULL_RANGE = { from: 0, to: 0 };
1078
+ var rangesAreSame = (r1, r2) => {
1079
+ return (r1 == null ? void 0 : r1.from) === (r2 == null ? void 0 : r2.from) && (r1 == null ? void 0 : r1.to) === (r2 == null ? void 0 : r2.to);
1080
+ };
1081
+ function getFullRange({ from, to }, bufferSize = 0, totalRowCount = Number.MAX_SAFE_INTEGER) {
1082
+ if (from === 0 && to === 0) {
1083
+ return { from, to };
1084
+ } else if (bufferSize === 0) {
1085
+ if (totalRowCount < from) {
1086
+ return { from: 0, to: 0 };
1087
+ } else {
1088
+ return { from, to: Math.min(to, totalRowCount) };
1089
+ }
1090
+ } else if (from === 0) {
1091
+ return { from, to: Math.min(to + bufferSize, totalRowCount) };
1092
+ } else {
1093
+ const shortfallBefore = from - bufferSize < 0;
1094
+ const shortfallAfter = totalRowCount - (to + bufferSize) < 0;
1095
+ if (shortfallBefore && shortfallAfter) {
1096
+ return { from: 0, to: totalRowCount };
1097
+ } else if (shortfallBefore) {
1098
+ return { from: 0, to: to + bufferSize };
1099
+ } else if (shortfallAfter) {
1100
+ return {
1101
+ from: Math.max(0, from - bufferSize),
1102
+ to: totalRowCount
1103
+ };
1104
+ } else {
1105
+ return { from: from - bufferSize, to: to + bufferSize };
1106
+ }
1107
+ }
1108
+ }
1109
+ function resetRange({ from, to, bufferSize = 0 }) {
1110
+ return {
1111
+ from: 0,
1112
+ to: to - from,
1113
+ bufferSize,
1114
+ reset: true
1115
+ };
1116
+ }
1117
+ var withinRange = (value, { from, to }) => value >= from && value < to;
1118
+ var rangeNewItems = ({ from: from1, to: to1 }, newRange) => {
1119
+ const { from: from2, to: to2 } = newRange;
1120
+ const noOverlap = from2 >= to1 || to2 <= from1;
1121
+ const newFullySubsumesOld = from2 < from1 && to2 > to1;
1122
+ return noOverlap || newFullySubsumesOld ? newRange : to2 > to1 ? { from: to1, to: to2 } : { from: from2, to: from1 };
1123
+ };
1124
+ var WindowRange = class _WindowRange {
1125
+ constructor(from, to) {
1126
+ this.from = from;
1127
+ this.to = to;
1128
+ }
1129
+ isWithin(index) {
1130
+ return withinRange(index, this);
1131
+ }
1132
+ //find the overlap of this range and a new one
1133
+ overlap(from, to) {
1134
+ return from >= this.to || to < this.from ? [0, 0] : [Math.max(from, this.from), Math.min(to, this.to)];
1135
+ }
1136
+ copy() {
1137
+ return new _WindowRange(this.from, this.to);
1138
+ }
1139
+ };
1140
+
1141
+ // src/DataWindow.ts
1142
+ var { KEY } = metadataKeys;
1143
+ var DataWindow = class {
1144
+ constructor({ from, to }) {
1145
+ this.rowCount = 0;
1146
+ this.setRowCount = (rowCount) => {
1147
+ if (rowCount < this.data.length) {
1148
+ this.data.length = rowCount;
1149
+ }
1150
+ this.rowCount = rowCount;
1151
+ };
1152
+ this.range = new WindowRange(from, to);
1153
+ this.data = new Array(to - from);
1154
+ }
1155
+ // return true if existing row was updated
1156
+ add(data) {
1157
+ const [index] = data;
1158
+ if (this.isWithinRange(index)) {
1159
+ const internalIndex = index - this.range.from;
1160
+ const isUpdate = this.data[internalIndex] !== void 0;
1161
+ this.data[internalIndex] = data;
1162
+ return isUpdate;
1163
+ } else {
1164
+ return false;
1165
+ }
1166
+ }
1167
+ getAtIndex(index) {
1168
+ return this.range.isWithin(index) && this.data[index - this.range.from] != null ? this.data[index - this.range.from] : void 0;
1169
+ }
1170
+ getByKey(key) {
1171
+ return this.data.find((row) => row[KEY] === key);
1172
+ }
1173
+ isWithinRange(index) {
1174
+ return this.range.isWithin(index) && index <= this.rowCount;
1175
+ }
1176
+ setRange(from, to) {
1177
+ if (from !== this.range.from || to !== this.range.to) {
1178
+ const [overlapFrom, overlapTo] = this.range.overlap(from, to);
1179
+ const newData = new Array(to - from);
1180
+ for (let i = overlapFrom; i < overlapTo; i++) {
1181
+ const data = this.getAtIndex(i);
1182
+ if (data) {
1183
+ const index = i - from;
1184
+ newData[index] = data;
1185
+ }
1186
+ }
1187
+ this.data = newData;
1188
+ this.range.from = from;
1189
+ this.range.to = to;
1190
+ }
1191
+ }
1192
+ hasData(from, to) {
1193
+ const offset = this.range.from;
1194
+ const start = from - offset;
1195
+ const end = Math.min(to - offset - 1, this.rowCount - 1);
1196
+ return this.data[start] !== void 0 && this.data[end] !== void 0;
1197
+ }
1198
+ getData(from, to) {
1199
+ var _a;
1200
+ const { from: clientFrom } = this.range;
1201
+ const startOffset = Math.max(0, from - clientFrom);
1202
+ const endOffset = Math.min(to - clientFrom, (_a = this.rowCount) != null ? _a : to);
1203
+ return this.data.slice(startOffset, endOffset);
1204
+ }
1205
+ };
1206
+
1207
+ // src/common-types.ts
1208
+ var MEASURES = {
1209
+ horizontal: {
1210
+ positionProp: "left",
1211
+ sizeProp: "width"
1212
+ },
1213
+ vertical: {
1214
+ positionProp: "top",
1215
+ sizeProp: "height"
1216
+ }
1217
+ };
1218
+
1219
+ // src/data-utils.ts
1220
+ var UP1 = "up1";
1221
+ var UP2 = "up2";
1222
+ var DOWN1 = "down1";
1223
+ var DOWN2 = "down2";
1224
+ var isValidNumber = (n) => typeof n === "number" && isFinite(n);
1225
+ var EMPTY = {};
1226
+ var shallowEquals = (o1 = EMPTY, o2 = EMPTY) => {
1227
+ const props1 = Object.keys(o1);
1228
+ const props2 = Object.keys(o2);
1229
+ return props1.length === props2.length && props1.every((key) => o1[key] === o2[key]);
1230
+ };
1231
+ function getMovingValueDirection(newValue, direction, prevValue, decimalPlaces) {
1232
+ if (newValue === void 0) {
1233
+ return "";
1234
+ }
1235
+ if (!isFinite(newValue) || prevValue === void 0 || direction === void 0) {
1236
+ return "";
1237
+ } else {
1238
+ let diff = newValue - prevValue;
1239
+ if (diff) {
1240
+ if (typeof decimalPlaces === "number") {
1241
+ diff = +newValue.toFixed(decimalPlaces) - +prevValue.toFixed(decimalPlaces);
1242
+ }
1243
+ }
1244
+ if (diff) {
1245
+ if (direction === "") {
1246
+ if (diff < 0) {
1247
+ return DOWN1;
1248
+ } else {
1249
+ return UP1;
1250
+ }
1251
+ } else if (diff > 0) {
1252
+ if (direction === DOWN1 || direction === DOWN2 || direction === UP2) {
1253
+ return UP1;
1254
+ } else {
1255
+ return UP2;
1256
+ }
1257
+ } else if (direction === UP1 || direction === UP2 || direction === DOWN2) {
1258
+ return DOWN1;
1259
+ } else {
1260
+ return DOWN2;
1261
+ }
1262
+ } else {
1263
+ return "";
1264
+ }
1265
+ }
1266
+ }
1267
+
1268
+ // src/datasource-action-utils.ts
1269
+ var isVisualLinksAction = (action) => action.type === "vuu-links";
1270
+ var isVisualLinkCreatedAction = (action) => action.type === "vuu-link-created";
1271
+ var isVisualLinkRemovedAction = (action) => action.type === "vuu-link-removed";
1272
+ var isViewportMenusAction = (action) => action.type === "vuu-menu";
1273
+ var isVuuFeatureAction = (action) => isViewportMenusAction(action) || isVisualLinksAction(action);
1274
+
1275
+ // src/datasource-utils.ts
1276
+ var NoFilter = { filter: "" };
1277
+ var NoSort = { sortDefs: [] };
1278
+ var vanillaConfig = {
1279
+ aggregations: [],
1280
+ columns: [],
1281
+ filter: NoFilter,
1282
+ groupBy: [],
1283
+ sort: NoSort
1284
+ };
1285
+ var equivalentAggregations = ({ aggregations: agg1 }, { aggregations: agg2 }) => agg1 === void 0 && (agg2 == null ? void 0 : agg2.length) === 0 || agg2 === void 0 && (agg1 == null ? void 0 : agg1.length) === 0;
1286
+ var equivalentColumns = ({ columns: cols1 }, { columns: cols2 }) => cols1 === void 0 && (cols2 == null ? void 0 : cols2.length) === 0 || cols2 === void 0 && (cols1 == null ? void 0 : cols1.length) === 0;
1287
+ var equivalentFilter = ({ filter: f1 }, { filter: f2 }) => f1 === void 0 && (f2 == null ? void 0 : f2.filter) === "" || f2 === void 0 && (f1 == null ? void 0 : f1.filter) === "";
1288
+ var equivalentGroupBy = ({ groupBy: val1 }, { groupBy: val2 }) => val1 === void 0 && (val2 == null ? void 0 : val2.length) === 0 || val2 === void 0 && (val1 == null ? void 0 : val1.length) === 0;
1289
+ var equivalentSort = ({ sort: s1 }, { sort: s2 }) => s1 === void 0 && (s2 == null ? void 0 : s2.sortDefs.length) === 0 || s2 === void 0 && (s1 == null ? void 0 : s1.sortDefs.length) === 0;
1290
+ var exactlyTheSame = (a, b) => {
1291
+ if (a === b) {
1292
+ return true;
1293
+ } else if (a === void 0 && b === void 0) {
1294
+ return true;
1295
+ } else {
1296
+ return false;
1297
+ }
1298
+ };
1299
+ var aggregationsChanged = (config, newConfig) => {
1300
+ const { aggregations: agg1 } = config;
1301
+ const { aggregations: agg2 } = newConfig;
1302
+ if (exactlyTheSame(agg1, agg2) || equivalentAggregations(config, newConfig)) {
1303
+ return false;
1304
+ } else if (agg1 === void 0 || agg2 === void 0) {
1305
+ return true;
1306
+ } else if (agg1.length !== agg2.length) {
1307
+ return true;
1308
+ }
1309
+ return agg1.some(
1310
+ ({ column, aggType }, i) => column !== agg2[i].column || aggType !== agg2[i].aggType
1311
+ );
1312
+ };
1313
+ var columnsChanged = (config, newConfig) => {
1314
+ const { columns: cols1 } = config;
1315
+ const { columns: cols2 } = newConfig;
1316
+ if (exactlyTheSame(cols1, cols2) || equivalentColumns(config, newConfig)) {
1317
+ return false;
1318
+ } else if (cols1 === void 0 || cols2 === void 0) {
1319
+ return true;
1320
+ } else if ((cols1 == null ? void 0 : cols1.length) !== (cols2 == null ? void 0 : cols2.length)) {
1321
+ return true;
1322
+ }
1323
+ return cols1.some((column, i) => column !== (cols2 == null ? void 0 : cols2[i]));
1324
+ };
1325
+ var filterChanged = (c1, c2) => {
1326
+ var _a, _b;
1327
+ if (equivalentFilter(c1, c2)) {
1328
+ return false;
1329
+ } else {
1330
+ return ((_a = c1.filter) == null ? void 0 : _a.filter) !== ((_b = c2.filter) == null ? void 0 : _b.filter);
1331
+ }
1332
+ };
1333
+ var groupByChanged = (config, newConfig) => {
1334
+ const { groupBy: g1 } = config;
1335
+ const { groupBy: g2 } = newConfig;
1336
+ if (exactlyTheSame(g1, g2) || equivalentGroupBy(config, newConfig)) {
1337
+ return false;
1338
+ } else if (g1 === void 0 || g2 === void 0) {
1339
+ return true;
1340
+ } else if ((g1 == null ? void 0 : g1.length) !== (g2 == null ? void 0 : g2.length)) {
1341
+ return true;
1342
+ }
1343
+ return g1.some((column, i) => column !== (g2 == null ? void 0 : g2[i]));
1344
+ };
1345
+ var sortChanged = (config, newConfig) => {
1346
+ const { sort: s1 } = config;
1347
+ const { sort: s2 } = newConfig;
1348
+ if (exactlyTheSame(s1, s2) || equivalentSort(config, newConfig)) {
1349
+ return false;
1350
+ } else if (s1 === void 0 || s2 === void 0) {
1351
+ return true;
1352
+ } else if ((s1 == null ? void 0 : s1.sortDefs.length) !== (s2 == null ? void 0 : s2.sortDefs.length)) {
1353
+ return true;
1354
+ }
1355
+ return s1.sortDefs.some(
1356
+ ({ column, sortType }, i) => column !== s2.sortDefs[i].column || sortType !== s2.sortDefs[i].sortType
1357
+ );
1358
+ };
1359
+ var visualLinkChanged = () => {
1360
+ return false;
1361
+ };
1362
+ var configChanged = (config, newConfig) => {
1363
+ if (exactlyTheSame(config, newConfig)) {
1364
+ return false;
1365
+ }
1366
+ if (config === void 0 || newConfig === void 0) {
1367
+ return true;
1368
+ }
1369
+ return aggregationsChanged(config, newConfig) || columnsChanged(config, newConfig) || filterChanged(config, newConfig) || groupByChanged(config, newConfig) || sortChanged(config, newConfig) || visualLinkChanged(config, newConfig);
1370
+ };
1371
+ var hasGroupBy = (config) => config !== void 0 && config.groupBy !== void 0 && config.groupBy.length > 0;
1372
+ var hasFilter = (config) => (config == null ? void 0 : config.filter) !== void 0 && config.filter.filter.length > 0;
1373
+ var hasSort = (config) => {
1374
+ var _a;
1375
+ return (config == null ? void 0 : config.sort) !== void 0 && Array.isArray((_a = config.sort) == null ? void 0 : _a.sortDefs) && config.sort.sortDefs.length > 0;
1376
+ };
1377
+ var isTypeaheadSuggestionProvider = (source) => typeof source["getTypeaheadSuggestions"] === "function";
1378
+ var isTableSchema = (message) => message.type === "TABLE_META_RESP";
1379
+ var isConnectionStatusMessage = (msg) => msg.type === "connection-status";
1380
+ var isConnectionQualityMetrics = (msg) => msg.type === "connection-metrics";
1381
+ var messageHasResult = (msg) => typeof msg.result !== "undefined";
1382
+ var isErrorResponse = (response) => response !== void 0 && "error" in response;
1383
+ var hasAction = (response) => response != void 0 && "action" in response;
1384
+ var isViewporttMessage = (msg) => "viewport" in msg;
1385
+ var withConfigDefaults = (config) => {
1386
+ if (config.aggregations && config.columns && config.filter && config.groupBy && config.sort) {
1387
+ return config;
1388
+ } else {
1389
+ const {
1390
+ aggregations = [],
1391
+ columns = [],
1392
+ filter = { filter: "" },
1393
+ groupBy = [],
1394
+ sort = { sortDefs: [] },
1395
+ visualLink
1396
+ } = config;
1397
+ return {
1398
+ aggregations,
1399
+ columns,
1400
+ filter,
1401
+ groupBy,
1402
+ sort,
1403
+ visualLink
1404
+ };
1405
+ }
1406
+ };
1407
+
1408
+ // ../../node_modules/@internationalized/date/node_modules/@swc/helpers/esm/_check_private_redeclaration.js
1409
+ function _check_private_redeclaration(obj, privateCollection) {
1410
+ if (privateCollection.has(obj)) {
1411
+ throw new TypeError("Cannot initialize the same private elements twice on an object");
1412
+ }
1413
+ }
1414
+
1415
+ // ../../node_modules/@internationalized/date/node_modules/@swc/helpers/esm/_class_private_field_init.js
1416
+ function _class_private_field_init(obj, privateMap, value) {
1417
+ _check_private_redeclaration(obj, privateMap);
1418
+ privateMap.set(obj, value);
1419
+ }
1420
+
1421
+ // ../../node_modules/@internationalized/date/dist/import.mjs
1422
+ function $2b4dce13dd5a17fa$export$842a2cf37af977e1(amount, numerator) {
1423
+ return amount - numerator * Math.floor(amount / numerator);
1424
+ }
1425
+ var $3b62074eb05584b2$var$EPOCH = 1721426;
1426
+ function $3b62074eb05584b2$export$f297eb839006d339(era, year, month, day) {
1427
+ year = $3b62074eb05584b2$export$c36e0ecb2d4fa69d(era, year);
1428
+ let y1 = year - 1;
1429
+ let monthOffset = -2;
1430
+ if (month <= 2)
1431
+ monthOffset = 0;
1432
+ else if ($3b62074eb05584b2$export$553d7fa8e3805fc0(year))
1433
+ monthOffset = -1;
1434
+ return $3b62074eb05584b2$var$EPOCH - 1 + 365 * y1 + Math.floor(y1 / 4) - Math.floor(y1 / 100) + Math.floor(y1 / 400) + Math.floor((367 * month - 362) / 12 + monthOffset + day);
1435
+ }
1436
+ function $3b62074eb05584b2$export$553d7fa8e3805fc0(year) {
1437
+ return year % 4 === 0 && (year % 100 !== 0 || year % 400 === 0);
1438
+ }
1439
+ function $3b62074eb05584b2$export$c36e0ecb2d4fa69d(era, year) {
1440
+ return era === "BC" ? 1 - year : year;
1441
+ }
1442
+ function $3b62074eb05584b2$export$4475b7e617eb123c(year) {
1443
+ let era = "AD";
1444
+ if (year <= 0) {
1445
+ era = "BC";
1446
+ year = 1 - year;
1447
+ }
1448
+ return [
1449
+ era,
1450
+ year
1451
+ ];
1452
+ }
1453
+ var $3b62074eb05584b2$var$daysInMonth = {
1454
+ standard: [
1455
+ 31,
1456
+ 28,
1457
+ 31,
1458
+ 30,
1459
+ 31,
1460
+ 30,
1461
+ 31,
1462
+ 31,
1463
+ 30,
1464
+ 31,
1465
+ 30,
1466
+ 31
1467
+ ],
1468
+ leapyear: [
1469
+ 31,
1470
+ 29,
1471
+ 31,
1472
+ 30,
1473
+ 31,
1474
+ 30,
1475
+ 31,
1476
+ 31,
1477
+ 30,
1478
+ 31,
1479
+ 30,
1480
+ 31
1481
+ ]
1482
+ };
1483
+ var $3b62074eb05584b2$export$80ee6245ec4f29ec = class {
1484
+ fromJulianDay(jd) {
1485
+ let jd0 = jd;
1486
+ let depoch = jd0 - $3b62074eb05584b2$var$EPOCH;
1487
+ let quadricent = Math.floor(depoch / 146097);
1488
+ let dqc = (0, $2b4dce13dd5a17fa$export$842a2cf37af977e1)(depoch, 146097);
1489
+ let cent = Math.floor(dqc / 36524);
1490
+ let dcent = (0, $2b4dce13dd5a17fa$export$842a2cf37af977e1)(dqc, 36524);
1491
+ let quad = Math.floor(dcent / 1461);
1492
+ let dquad = (0, $2b4dce13dd5a17fa$export$842a2cf37af977e1)(dcent, 1461);
1493
+ let yindex = Math.floor(dquad / 365);
1494
+ let extendedYear = quadricent * 400 + cent * 100 + quad * 4 + yindex + (cent !== 4 && yindex !== 4 ? 1 : 0);
1495
+ let [era, year] = $3b62074eb05584b2$export$4475b7e617eb123c(extendedYear);
1496
+ let yearDay = jd0 - $3b62074eb05584b2$export$f297eb839006d339(era, year, 1, 1);
1497
+ let leapAdj = 2;
1498
+ if (jd0 < $3b62074eb05584b2$export$f297eb839006d339(era, year, 3, 1))
1499
+ leapAdj = 0;
1500
+ else if ($3b62074eb05584b2$export$553d7fa8e3805fc0(year))
1501
+ leapAdj = 1;
1502
+ let month = Math.floor(((yearDay + leapAdj) * 12 + 373) / 367);
1503
+ let day = jd0 - $3b62074eb05584b2$export$f297eb839006d339(era, year, month, 1) + 1;
1504
+ return new (0, $35ea8db9cb2ccb90$export$99faa760c7908e4f)(era, year, month, day);
1505
+ }
1506
+ toJulianDay(date) {
1507
+ return $3b62074eb05584b2$export$f297eb839006d339(date.era, date.year, date.month, date.day);
1508
+ }
1509
+ getDaysInMonth(date) {
1510
+ return $3b62074eb05584b2$var$daysInMonth[$3b62074eb05584b2$export$553d7fa8e3805fc0(date.year) ? "leapyear" : "standard"][date.month - 1];
1511
+ }
1512
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
1513
+ getMonthsInYear(date) {
1514
+ return 12;
1515
+ }
1516
+ getDaysInYear(date) {
1517
+ return $3b62074eb05584b2$export$553d7fa8e3805fc0(date.year) ? 366 : 365;
1518
+ }
1519
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
1520
+ getYearsInEra(date) {
1521
+ return 9999;
1522
+ }
1523
+ getEras() {
1524
+ return [
1525
+ "BC",
1526
+ "AD"
1527
+ ];
1528
+ }
1529
+ isInverseEra(date) {
1530
+ return date.era === "BC";
1531
+ }
1532
+ balanceDate(date) {
1533
+ if (date.year <= 0) {
1534
+ date.era = date.era === "BC" ? "AD" : "BC";
1535
+ date.year = 1 - date.year;
1536
+ }
1537
+ }
1538
+ constructor() {
1539
+ this.identifier = "gregory";
1540
+ }
1541
+ };
1542
+ function $14e0f24ef4ac5c92$export$68781ddf31c0090f(a, b) {
1543
+ return a.calendar.toJulianDay(a) - b.calendar.toJulianDay(b);
1544
+ }
1545
+ function $14e0f24ef4ac5c92$export$c19a80a9721b80f6(a, b) {
1546
+ return $14e0f24ef4ac5c92$var$timeToMs(a) - $14e0f24ef4ac5c92$var$timeToMs(b);
1547
+ }
1548
+ function $14e0f24ef4ac5c92$var$timeToMs(a) {
1549
+ return a.hour * 36e5 + a.minute * 6e4 + a.second * 1e3 + a.millisecond;
1550
+ }
1551
+ var $14e0f24ef4ac5c92$var$localTimeZone = null;
1552
+ function $14e0f24ef4ac5c92$export$aa8b41735afcabd2() {
1553
+ if ($14e0f24ef4ac5c92$var$localTimeZone == null)
1554
+ $14e0f24ef4ac5c92$var$localTimeZone = new Intl.DateTimeFormat().resolvedOptions().timeZone;
1555
+ return $14e0f24ef4ac5c92$var$localTimeZone;
1556
+ }
1557
+ function $11d87f3f76e88657$export$bd4fb2bc8bb06fb(date) {
1558
+ date = $11d87f3f76e88657$export$b4a036af3fc0b032(date, new (0, $3b62074eb05584b2$export$80ee6245ec4f29ec)());
1559
+ let year = (0, $3b62074eb05584b2$export$c36e0ecb2d4fa69d)(date.era, date.year);
1560
+ return $11d87f3f76e88657$var$epochFromParts(year, date.month, date.day, date.hour, date.minute, date.second, date.millisecond);
1561
+ }
1562
+ function $11d87f3f76e88657$var$epochFromParts(year, month, day, hour, minute, second, millisecond) {
1563
+ let date = /* @__PURE__ */ new Date();
1564
+ date.setUTCHours(hour, minute, second, millisecond);
1565
+ date.setUTCFullYear(year, month - 1, day);
1566
+ return date.getTime();
1567
+ }
1568
+ function $11d87f3f76e88657$export$59c99f3515d3493f(ms, timeZone) {
1569
+ if (timeZone === "UTC")
1570
+ return 0;
1571
+ if (ms > 0 && timeZone === (0, $14e0f24ef4ac5c92$export$aa8b41735afcabd2)())
1572
+ return new Date(ms).getTimezoneOffset() * -6e4;
1573
+ let { year, month, day, hour, minute, second } = $11d87f3f76e88657$var$getTimeZoneParts(ms, timeZone);
1574
+ let utc = $11d87f3f76e88657$var$epochFromParts(year, month, day, hour, minute, second, 0);
1575
+ return utc - Math.floor(ms / 1e3) * 1e3;
1576
+ }
1577
+ var $11d87f3f76e88657$var$formattersByTimeZone = /* @__PURE__ */ new Map();
1578
+ function $11d87f3f76e88657$var$getTimeZoneParts(ms, timeZone) {
1579
+ let formatter = $11d87f3f76e88657$var$formattersByTimeZone.get(timeZone);
1580
+ if (!formatter) {
1581
+ formatter = new Intl.DateTimeFormat("en-US", {
1582
+ timeZone,
1583
+ hour12: false,
1584
+ era: "short",
1585
+ year: "numeric",
1586
+ month: "numeric",
1587
+ day: "numeric",
1588
+ hour: "numeric",
1589
+ minute: "numeric",
1590
+ second: "numeric"
1591
+ });
1592
+ $11d87f3f76e88657$var$formattersByTimeZone.set(timeZone, formatter);
1593
+ }
1594
+ let parts = formatter.formatToParts(new Date(ms));
1595
+ let namedParts = {};
1596
+ for (let part of parts)
1597
+ if (part.type !== "literal")
1598
+ namedParts[part.type] = part.value;
1599
+ return {
1600
+ // Firefox returns B instead of BC... https://bugzilla.mozilla.org/show_bug.cgi?id=1752253
1601
+ year: namedParts.era === "BC" || namedParts.era === "B" ? -namedParts.year + 1 : +namedParts.year,
1602
+ month: +namedParts.month,
1603
+ day: +namedParts.day,
1604
+ hour: namedParts.hour === "24" ? 0 : +namedParts.hour,
1605
+ minute: +namedParts.minute,
1606
+ second: +namedParts.second
1607
+ };
1608
+ }
1609
+ var $11d87f3f76e88657$var$DAYMILLIS = 864e5;
1610
+ function $11d87f3f76e88657$var$getValidWallTimes(date, timeZone, earlier, later) {
1611
+ let found = earlier === later ? [
1612
+ earlier
1613
+ ] : [
1614
+ earlier,
1615
+ later
1616
+ ];
1617
+ return found.filter((absolute) => $11d87f3f76e88657$var$isValidWallTime(date, timeZone, absolute));
1618
+ }
1619
+ function $11d87f3f76e88657$var$isValidWallTime(date, timeZone, absolute) {
1620
+ let parts = $11d87f3f76e88657$var$getTimeZoneParts(absolute, timeZone);
1621
+ return date.year === parts.year && date.month === parts.month && date.day === parts.day && date.hour === parts.hour && date.minute === parts.minute && date.second === parts.second;
1622
+ }
1623
+ function $11d87f3f76e88657$export$5107c82f94518f5c(date, timeZone, disambiguation = "compatible") {
1624
+ let dateTime = $11d87f3f76e88657$export$b21e0b124e224484(date);
1625
+ if (timeZone === "UTC")
1626
+ return $11d87f3f76e88657$export$bd4fb2bc8bb06fb(dateTime);
1627
+ if (timeZone === (0, $14e0f24ef4ac5c92$export$aa8b41735afcabd2)() && disambiguation === "compatible") {
1628
+ dateTime = $11d87f3f76e88657$export$b4a036af3fc0b032(dateTime, new (0, $3b62074eb05584b2$export$80ee6245ec4f29ec)());
1629
+ let date2 = /* @__PURE__ */ new Date();
1630
+ let year = (0, $3b62074eb05584b2$export$c36e0ecb2d4fa69d)(dateTime.era, dateTime.year);
1631
+ date2.setFullYear(year, dateTime.month - 1, dateTime.day);
1632
+ date2.setHours(dateTime.hour, dateTime.minute, dateTime.second, dateTime.millisecond);
1633
+ return date2.getTime();
1634
+ }
1635
+ let ms = $11d87f3f76e88657$export$bd4fb2bc8bb06fb(dateTime);
1636
+ let offsetBefore = $11d87f3f76e88657$export$59c99f3515d3493f(ms - $11d87f3f76e88657$var$DAYMILLIS, timeZone);
1637
+ let offsetAfter = $11d87f3f76e88657$export$59c99f3515d3493f(ms + $11d87f3f76e88657$var$DAYMILLIS, timeZone);
1638
+ let valid = $11d87f3f76e88657$var$getValidWallTimes(dateTime, timeZone, ms - offsetBefore, ms - offsetAfter);
1639
+ if (valid.length === 1)
1640
+ return valid[0];
1641
+ if (valid.length > 1)
1642
+ switch (disambiguation) {
1643
+ case "compatible":
1644
+ case "earlier":
1645
+ return valid[0];
1646
+ case "later":
1647
+ return valid[valid.length - 1];
1648
+ case "reject":
1649
+ throw new RangeError("Multiple possible absolute times found");
1650
+ }
1651
+ switch (disambiguation) {
1652
+ case "earlier":
1653
+ return Math.min(ms - offsetBefore, ms - offsetAfter);
1654
+ case "compatible":
1655
+ case "later":
1656
+ return Math.max(ms - offsetBefore, ms - offsetAfter);
1657
+ case "reject":
1658
+ throw new RangeError("No such absolute time found");
1659
+ }
1660
+ }
1661
+ function $11d87f3f76e88657$export$e67a095c620b86fe(dateTime, timeZone, disambiguation = "compatible") {
1662
+ return new Date($11d87f3f76e88657$export$5107c82f94518f5c(dateTime, timeZone, disambiguation));
1663
+ }
1664
+ function $11d87f3f76e88657$export$b21e0b124e224484(date, time) {
1665
+ let hour = 0, minute = 0, second = 0, millisecond = 0;
1666
+ if ("timeZone" in date)
1667
+ ({ hour, minute, second, millisecond } = date);
1668
+ else if ("hour" in date && !time)
1669
+ return date;
1670
+ if (time)
1671
+ ({ hour, minute, second, millisecond } = time);
1672
+ return new (0, $35ea8db9cb2ccb90$export$ca871e8dbb80966f)(date.calendar, date.era, date.year, date.month, date.day, hour, minute, second, millisecond);
1673
+ }
1674
+ function $11d87f3f76e88657$export$b4a036af3fc0b032(date, calendar) {
1675
+ if (date.calendar.identifier === calendar.identifier)
1676
+ return date;
1677
+ let calendarDate = calendar.fromJulianDay(date.calendar.toJulianDay(date));
1678
+ let copy = date.copy();
1679
+ copy.calendar = calendar;
1680
+ copy.era = calendarDate.era;
1681
+ copy.year = calendarDate.year;
1682
+ copy.month = calendarDate.month;
1683
+ copy.day = calendarDate.day;
1684
+ (0, $735220c2d4774dd3$export$c4e2ecac49351ef2)(copy);
1685
+ return copy;
1686
+ }
1687
+ function $735220c2d4774dd3$export$e16d8520af44a096(date, duration) {
1688
+ let mutableDate = date.copy();
1689
+ let days = "hour" in mutableDate ? $735220c2d4774dd3$var$addTimeFields(mutableDate, duration) : 0;
1690
+ $735220c2d4774dd3$var$addYears(mutableDate, duration.years || 0);
1691
+ if (mutableDate.calendar.balanceYearMonth)
1692
+ mutableDate.calendar.balanceYearMonth(mutableDate, date);
1693
+ mutableDate.month += duration.months || 0;
1694
+ $735220c2d4774dd3$var$balanceYearMonth(mutableDate);
1695
+ $735220c2d4774dd3$var$constrainMonthDay(mutableDate);
1696
+ mutableDate.day += (duration.weeks || 0) * 7;
1697
+ mutableDate.day += duration.days || 0;
1698
+ mutableDate.day += days;
1699
+ $735220c2d4774dd3$var$balanceDay(mutableDate);
1700
+ if (mutableDate.calendar.balanceDate)
1701
+ mutableDate.calendar.balanceDate(mutableDate);
1702
+ if (mutableDate.year < 1) {
1703
+ mutableDate.year = 1;
1704
+ mutableDate.month = 1;
1705
+ mutableDate.day = 1;
1706
+ }
1707
+ let maxYear = mutableDate.calendar.getYearsInEra(mutableDate);
1708
+ if (mutableDate.year > maxYear) {
1709
+ var _mutableDate_calendar, _mutableDate_calendar_isInverseEra;
1710
+ let isInverseEra = (_mutableDate_calendar_isInverseEra = (_mutableDate_calendar = mutableDate.calendar).isInverseEra) === null || _mutableDate_calendar_isInverseEra === void 0 ? void 0 : _mutableDate_calendar_isInverseEra.call(_mutableDate_calendar, mutableDate);
1711
+ mutableDate.year = maxYear;
1712
+ mutableDate.month = isInverseEra ? 1 : mutableDate.calendar.getMonthsInYear(mutableDate);
1713
+ mutableDate.day = isInverseEra ? 1 : mutableDate.calendar.getDaysInMonth(mutableDate);
1714
+ }
1715
+ if (mutableDate.month < 1) {
1716
+ mutableDate.month = 1;
1717
+ mutableDate.day = 1;
1718
+ }
1719
+ let maxMonth = mutableDate.calendar.getMonthsInYear(mutableDate);
1720
+ if (mutableDate.month > maxMonth) {
1721
+ mutableDate.month = maxMonth;
1722
+ mutableDate.day = mutableDate.calendar.getDaysInMonth(mutableDate);
1723
+ }
1724
+ mutableDate.day = Math.max(1, Math.min(mutableDate.calendar.getDaysInMonth(mutableDate), mutableDate.day));
1725
+ return mutableDate;
1726
+ }
1727
+ function $735220c2d4774dd3$var$addYears(date, years) {
1728
+ var _date_calendar, _date_calendar_isInverseEra;
1729
+ if ((_date_calendar_isInverseEra = (_date_calendar = date.calendar).isInverseEra) === null || _date_calendar_isInverseEra === void 0 ? void 0 : _date_calendar_isInverseEra.call(_date_calendar, date))
1730
+ years = -years;
1731
+ date.year += years;
1732
+ }
1733
+ function $735220c2d4774dd3$var$balanceYearMonth(date) {
1734
+ while (date.month < 1) {
1735
+ $735220c2d4774dd3$var$addYears(date, -1);
1736
+ date.month += date.calendar.getMonthsInYear(date);
1737
+ }
1738
+ let monthsInYear = 0;
1739
+ while (date.month > (monthsInYear = date.calendar.getMonthsInYear(date))) {
1740
+ date.month -= monthsInYear;
1741
+ $735220c2d4774dd3$var$addYears(date, 1);
1742
+ }
1743
+ }
1744
+ function $735220c2d4774dd3$var$balanceDay(date) {
1745
+ while (date.day < 1) {
1746
+ date.month--;
1747
+ $735220c2d4774dd3$var$balanceYearMonth(date);
1748
+ date.day += date.calendar.getDaysInMonth(date);
1749
+ }
1750
+ while (date.day > date.calendar.getDaysInMonth(date)) {
1751
+ date.day -= date.calendar.getDaysInMonth(date);
1752
+ date.month++;
1753
+ $735220c2d4774dd3$var$balanceYearMonth(date);
1754
+ }
1755
+ }
1756
+ function $735220c2d4774dd3$var$constrainMonthDay(date) {
1757
+ date.month = Math.max(1, Math.min(date.calendar.getMonthsInYear(date), date.month));
1758
+ date.day = Math.max(1, Math.min(date.calendar.getDaysInMonth(date), date.day));
1759
+ }
1760
+ function $735220c2d4774dd3$export$c4e2ecac49351ef2(date) {
1761
+ if (date.calendar.constrainDate)
1762
+ date.calendar.constrainDate(date);
1763
+ date.year = Math.max(1, Math.min(date.calendar.getYearsInEra(date), date.year));
1764
+ $735220c2d4774dd3$var$constrainMonthDay(date);
1765
+ }
1766
+ function $735220c2d4774dd3$export$3e2544e88a25bff8(duration) {
1767
+ let inverseDuration = {};
1768
+ for (let key in duration)
1769
+ if (typeof duration[key] === "number")
1770
+ inverseDuration[key] = -duration[key];
1771
+ return inverseDuration;
1772
+ }
1773
+ function $735220c2d4774dd3$export$4e2d2ead65e5f7e3(date, duration) {
1774
+ return $735220c2d4774dd3$export$e16d8520af44a096(date, $735220c2d4774dd3$export$3e2544e88a25bff8(duration));
1775
+ }
1776
+ function $735220c2d4774dd3$export$adaa4cf7ef1b65be(date, fields) {
1777
+ let mutableDate = date.copy();
1778
+ if (fields.era != null)
1779
+ mutableDate.era = fields.era;
1780
+ if (fields.year != null)
1781
+ mutableDate.year = fields.year;
1782
+ if (fields.month != null)
1783
+ mutableDate.month = fields.month;
1784
+ if (fields.day != null)
1785
+ mutableDate.day = fields.day;
1786
+ $735220c2d4774dd3$export$c4e2ecac49351ef2(mutableDate);
1787
+ return mutableDate;
1788
+ }
1789
+ function $735220c2d4774dd3$export$e5d5e1c1822b6e56(value, fields) {
1790
+ let mutableValue = value.copy();
1791
+ if (fields.hour != null)
1792
+ mutableValue.hour = fields.hour;
1793
+ if (fields.minute != null)
1794
+ mutableValue.minute = fields.minute;
1795
+ if (fields.second != null)
1796
+ mutableValue.second = fields.second;
1797
+ if (fields.millisecond != null)
1798
+ mutableValue.millisecond = fields.millisecond;
1799
+ $735220c2d4774dd3$export$7555de1e070510cb(mutableValue);
1800
+ return mutableValue;
1801
+ }
1802
+ function $735220c2d4774dd3$var$balanceTime(time) {
1803
+ time.second += Math.floor(time.millisecond / 1e3);
1804
+ time.millisecond = $735220c2d4774dd3$var$nonNegativeMod(time.millisecond, 1e3);
1805
+ time.minute += Math.floor(time.second / 60);
1806
+ time.second = $735220c2d4774dd3$var$nonNegativeMod(time.second, 60);
1807
+ time.hour += Math.floor(time.minute / 60);
1808
+ time.minute = $735220c2d4774dd3$var$nonNegativeMod(time.minute, 60);
1809
+ let days = Math.floor(time.hour / 24);
1810
+ time.hour = $735220c2d4774dd3$var$nonNegativeMod(time.hour, 24);
1811
+ return days;
1812
+ }
1813
+ function $735220c2d4774dd3$export$7555de1e070510cb(time) {
1814
+ time.millisecond = Math.max(0, Math.min(time.millisecond, 1e3));
1815
+ time.second = Math.max(0, Math.min(time.second, 59));
1816
+ time.minute = Math.max(0, Math.min(time.minute, 59));
1817
+ time.hour = Math.max(0, Math.min(time.hour, 23));
1818
+ }
1819
+ function $735220c2d4774dd3$var$nonNegativeMod(a, b) {
1820
+ let result = a % b;
1821
+ if (result < 0)
1822
+ result += b;
1823
+ return result;
1824
+ }
1825
+ function $735220c2d4774dd3$var$addTimeFields(time, duration) {
1826
+ time.hour += duration.hours || 0;
1827
+ time.minute += duration.minutes || 0;
1828
+ time.second += duration.seconds || 0;
1829
+ time.millisecond += duration.milliseconds || 0;
1830
+ return $735220c2d4774dd3$var$balanceTime(time);
1831
+ }
1832
+ function $735220c2d4774dd3$export$d52ced6badfb9a4c(value, field, amount, options) {
1833
+ let mutable = value.copy();
1834
+ switch (field) {
1835
+ case "era": {
1836
+ let eras = value.calendar.getEras();
1837
+ let eraIndex = eras.indexOf(value.era);
1838
+ if (eraIndex < 0)
1839
+ throw new Error("Invalid era: " + value.era);
1840
+ eraIndex = $735220c2d4774dd3$var$cycleValue(eraIndex, amount, 0, eras.length - 1, options === null || options === void 0 ? void 0 : options.round);
1841
+ mutable.era = eras[eraIndex];
1842
+ $735220c2d4774dd3$export$c4e2ecac49351ef2(mutable);
1843
+ break;
1844
+ }
1845
+ case "year":
1846
+ var _mutable_calendar, _mutable_calendar_isInverseEra;
1847
+ if ((_mutable_calendar_isInverseEra = (_mutable_calendar = mutable.calendar).isInverseEra) === null || _mutable_calendar_isInverseEra === void 0 ? void 0 : _mutable_calendar_isInverseEra.call(_mutable_calendar, mutable))
1848
+ amount = -amount;
1849
+ mutable.year = $735220c2d4774dd3$var$cycleValue(value.year, amount, -Infinity, 9999, options === null || options === void 0 ? void 0 : options.round);
1850
+ if (mutable.year === -Infinity)
1851
+ mutable.year = 1;
1852
+ if (mutable.calendar.balanceYearMonth)
1853
+ mutable.calendar.balanceYearMonth(mutable, value);
1854
+ break;
1855
+ case "month":
1856
+ mutable.month = $735220c2d4774dd3$var$cycleValue(value.month, amount, 1, value.calendar.getMonthsInYear(value), options === null || options === void 0 ? void 0 : options.round);
1857
+ break;
1858
+ case "day":
1859
+ mutable.day = $735220c2d4774dd3$var$cycleValue(value.day, amount, 1, value.calendar.getDaysInMonth(value), options === null || options === void 0 ? void 0 : options.round);
1860
+ break;
1861
+ default:
1862
+ throw new Error("Unsupported field " + field);
1863
+ }
1864
+ if (value.calendar.balanceDate)
1865
+ value.calendar.balanceDate(mutable);
1866
+ $735220c2d4774dd3$export$c4e2ecac49351ef2(mutable);
1867
+ return mutable;
1868
+ }
1869
+ function $735220c2d4774dd3$export$dd02b3e0007dfe28(value, field, amount, options) {
1870
+ let mutable = value.copy();
1871
+ switch (field) {
1872
+ case "hour": {
1873
+ let hours = value.hour;
1874
+ let min = 0;
1875
+ let max = 23;
1876
+ if ((options === null || options === void 0 ? void 0 : options.hourCycle) === 12) {
1877
+ let isPM = hours >= 12;
1878
+ min = isPM ? 12 : 0;
1879
+ max = isPM ? 23 : 11;
1880
+ }
1881
+ mutable.hour = $735220c2d4774dd3$var$cycleValue(hours, amount, min, max, options === null || options === void 0 ? void 0 : options.round);
1882
+ break;
1883
+ }
1884
+ case "minute":
1885
+ mutable.minute = $735220c2d4774dd3$var$cycleValue(value.minute, amount, 0, 59, options === null || options === void 0 ? void 0 : options.round);
1886
+ break;
1887
+ case "second":
1888
+ mutable.second = $735220c2d4774dd3$var$cycleValue(value.second, amount, 0, 59, options === null || options === void 0 ? void 0 : options.round);
1889
+ break;
1890
+ case "millisecond":
1891
+ mutable.millisecond = $735220c2d4774dd3$var$cycleValue(value.millisecond, amount, 0, 999, options === null || options === void 0 ? void 0 : options.round);
1892
+ break;
1893
+ default:
1894
+ throw new Error("Unsupported field " + field);
1895
+ }
1896
+ return mutable;
1897
+ }
1898
+ function $735220c2d4774dd3$var$cycleValue(value, amount, min, max, round = false) {
1899
+ if (round) {
1900
+ value += Math.sign(amount);
1901
+ if (value < min)
1902
+ value = max;
1903
+ let div = Math.abs(amount);
1904
+ if (amount > 0)
1905
+ value = Math.ceil(value / div) * div;
1906
+ else
1907
+ value = Math.floor(value / div) * div;
1908
+ if (value > max)
1909
+ value = min;
1910
+ } else {
1911
+ value += amount;
1912
+ if (value < min)
1913
+ value = max - (min - value - 1);
1914
+ else if (value > max)
1915
+ value = min + (value - max - 1);
1916
+ }
1917
+ return value;
1918
+ }
1919
+ var $fae977aafc393c5c$var$requiredDurationTimeGroups = [
1920
+ "hours",
1921
+ "minutes",
1922
+ "seconds"
1923
+ ];
1924
+ var $fae977aafc393c5c$var$requiredDurationGroups = [
1925
+ "years",
1926
+ "months",
1927
+ "weeks",
1928
+ "days",
1929
+ ...$fae977aafc393c5c$var$requiredDurationTimeGroups
1930
+ ];
1931
+ function $fae977aafc393c5c$export$f59dee82248f5ad4(time) {
1932
+ return `${String(time.hour).padStart(2, "0")}:${String(time.minute).padStart(2, "0")}:${String(time.second).padStart(2, "0")}${time.millisecond ? String(time.millisecond / 1e3).slice(1) : ""}`;
1933
+ }
1934
+ function $fae977aafc393c5c$export$60dfd74aa96791bd(date) {
1935
+ let gregorianDate = (0, $11d87f3f76e88657$export$b4a036af3fc0b032)(date, new (0, $3b62074eb05584b2$export$80ee6245ec4f29ec)());
1936
+ return `${String(gregorianDate.year).padStart(4, "0")}-${String(gregorianDate.month).padStart(2, "0")}-${String(gregorianDate.day).padStart(2, "0")}`;
1937
+ }
1938
+ function $fae977aafc393c5c$export$4223de14708adc63(date) {
1939
+ return `${$fae977aafc393c5c$export$60dfd74aa96791bd(date)}T${$fae977aafc393c5c$export$f59dee82248f5ad4(date)}`;
1940
+ }
1941
+ function $35ea8db9cb2ccb90$var$shiftArgs(args) {
1942
+ let calendar = typeof args[0] === "object" ? args.shift() : new (0, $3b62074eb05584b2$export$80ee6245ec4f29ec)();
1943
+ let era;
1944
+ if (typeof args[0] === "string")
1945
+ era = args.shift();
1946
+ else {
1947
+ let eras = calendar.getEras();
1948
+ era = eras[eras.length - 1];
1949
+ }
1950
+ let year = args.shift();
1951
+ let month = args.shift();
1952
+ let day = args.shift();
1953
+ return [
1954
+ calendar,
1955
+ era,
1956
+ year,
1957
+ month,
1958
+ day
1959
+ ];
1960
+ }
1961
+ var $35ea8db9cb2ccb90$var$_type = /* @__PURE__ */ new WeakMap();
1962
+ var $35ea8db9cb2ccb90$export$99faa760c7908e4f = class _$35ea8db9cb2ccb90$export$99faa760c7908e4f {
1963
+ /** Returns a copy of this date. */
1964
+ copy() {
1965
+ if (this.era)
1966
+ return new _$35ea8db9cb2ccb90$export$99faa760c7908e4f(this.calendar, this.era, this.year, this.month, this.day);
1967
+ else
1968
+ return new _$35ea8db9cb2ccb90$export$99faa760c7908e4f(this.calendar, this.year, this.month, this.day);
1969
+ }
1970
+ /** Returns a new `CalendarDate` with the given duration added to it. */
1971
+ add(duration) {
1972
+ return (0, $735220c2d4774dd3$export$e16d8520af44a096)(this, duration);
1973
+ }
1974
+ /** Returns a new `CalendarDate` with the given duration subtracted from it. */
1975
+ subtract(duration) {
1976
+ return (0, $735220c2d4774dd3$export$4e2d2ead65e5f7e3)(this, duration);
1977
+ }
1978
+ /** Returns a new `CalendarDate` with the given fields set to the provided values. Other fields will be constrained accordingly. */
1979
+ set(fields) {
1980
+ return (0, $735220c2d4774dd3$export$adaa4cf7ef1b65be)(this, fields);
1981
+ }
1982
+ /**
1983
+ * Returns a new `CalendarDate` with the given field adjusted by a specified amount.
1984
+ * When the resulting value reaches the limits of the field, it wraps around.
1985
+ */
1986
+ cycle(field, amount, options) {
1987
+ return (0, $735220c2d4774dd3$export$d52ced6badfb9a4c)(this, field, amount, options);
1988
+ }
1989
+ /** Converts the date to a native JavaScript Date object, with the time set to midnight in the given time zone. */
1990
+ toDate(timeZone) {
1991
+ return (0, $11d87f3f76e88657$export$e67a095c620b86fe)(this, timeZone);
1992
+ }
1993
+ /** Converts the date to an ISO 8601 formatted string. */
1994
+ toString() {
1995
+ return (0, $fae977aafc393c5c$export$60dfd74aa96791bd)(this);
1996
+ }
1997
+ /** Compares this date with another. A negative result indicates that this date is before the given one, and a positive date indicates that it is after. */
1998
+ compare(b) {
1999
+ return (0, $14e0f24ef4ac5c92$export$68781ddf31c0090f)(this, b);
2000
+ }
2001
+ constructor(...args) {
2002
+ (0, _class_private_field_init)(this, $35ea8db9cb2ccb90$var$_type, {
2003
+ writable: true,
2004
+ value: void 0
2005
+ });
2006
+ let [calendar, era, year, month, day] = $35ea8db9cb2ccb90$var$shiftArgs(args);
2007
+ this.calendar = calendar;
2008
+ this.era = era;
2009
+ this.year = year;
2010
+ this.month = month;
2011
+ this.day = day;
2012
+ (0, $735220c2d4774dd3$export$c4e2ecac49351ef2)(this);
2013
+ }
2014
+ };
2015
+ var $35ea8db9cb2ccb90$var$_type2 = /* @__PURE__ */ new WeakMap();
2016
+ var $35ea8db9cb2ccb90$export$ca871e8dbb80966f = class _$35ea8db9cb2ccb90$export$ca871e8dbb80966f {
2017
+ /** Returns a copy of this date. */
2018
+ copy() {
2019
+ if (this.era)
2020
+ return new _$35ea8db9cb2ccb90$export$ca871e8dbb80966f(this.calendar, this.era, this.year, this.month, this.day, this.hour, this.minute, this.second, this.millisecond);
2021
+ else
2022
+ return new _$35ea8db9cb2ccb90$export$ca871e8dbb80966f(this.calendar, this.year, this.month, this.day, this.hour, this.minute, this.second, this.millisecond);
2023
+ }
2024
+ /** Returns a new `CalendarDateTime` with the given duration added to it. */
2025
+ add(duration) {
2026
+ return (0, $735220c2d4774dd3$export$e16d8520af44a096)(this, duration);
2027
+ }
2028
+ /** Returns a new `CalendarDateTime` with the given duration subtracted from it. */
2029
+ subtract(duration) {
2030
+ return (0, $735220c2d4774dd3$export$4e2d2ead65e5f7e3)(this, duration);
2031
+ }
2032
+ /** Returns a new `CalendarDateTime` with the given fields set to the provided values. Other fields will be constrained accordingly. */
2033
+ set(fields) {
2034
+ return (0, $735220c2d4774dd3$export$adaa4cf7ef1b65be)((0, $735220c2d4774dd3$export$e5d5e1c1822b6e56)(this, fields), fields);
2035
+ }
2036
+ /**
2037
+ * Returns a new `CalendarDateTime` with the given field adjusted by a specified amount.
2038
+ * When the resulting value reaches the limits of the field, it wraps around.
2039
+ */
2040
+ cycle(field, amount, options) {
2041
+ switch (field) {
2042
+ case "era":
2043
+ case "year":
2044
+ case "month":
2045
+ case "day":
2046
+ return (0, $735220c2d4774dd3$export$d52ced6badfb9a4c)(this, field, amount, options);
2047
+ default:
2048
+ return (0, $735220c2d4774dd3$export$dd02b3e0007dfe28)(this, field, amount, options);
2049
+ }
2050
+ }
2051
+ /** Converts the date to a native JavaScript Date object in the given time zone. */
2052
+ toDate(timeZone, disambiguation) {
2053
+ return (0, $11d87f3f76e88657$export$e67a095c620b86fe)(this, timeZone, disambiguation);
2054
+ }
2055
+ /** Converts the date to an ISO 8601 formatted string. */
2056
+ toString() {
2057
+ return (0, $fae977aafc393c5c$export$4223de14708adc63)(this);
2058
+ }
2059
+ /** Compares this date with another. A negative result indicates that this date is before the given one, and a positive date indicates that it is after. */
2060
+ compare(b) {
2061
+ let res = (0, $14e0f24ef4ac5c92$export$68781ddf31c0090f)(this, b);
2062
+ if (res === 0)
2063
+ return (0, $14e0f24ef4ac5c92$export$c19a80a9721b80f6)(this, (0, $11d87f3f76e88657$export$b21e0b124e224484)(b));
2064
+ return res;
2065
+ }
2066
+ constructor(...args) {
2067
+ (0, _class_private_field_init)(this, $35ea8db9cb2ccb90$var$_type2, {
2068
+ writable: true,
2069
+ value: void 0
2070
+ });
2071
+ let [calendar, era, year, month, day] = $35ea8db9cb2ccb90$var$shiftArgs(args);
2072
+ this.calendar = calendar;
2073
+ this.era = era;
2074
+ this.year = year;
2075
+ this.month = month;
2076
+ this.day = day;
2077
+ this.hour = args.shift() || 0;
2078
+ this.minute = args.shift() || 0;
2079
+ this.second = args.shift() || 0;
2080
+ this.millisecond = args.shift() || 0;
2081
+ (0, $735220c2d4774dd3$export$c4e2ecac49351ef2)(this);
2082
+ }
2083
+ };
2084
+ var $7c5f6fbf42389787$var$HOUR_PARTS = 1080;
2085
+ var $7c5f6fbf42389787$var$DAY_PARTS = 24 * $7c5f6fbf42389787$var$HOUR_PARTS;
2086
+ var $7c5f6fbf42389787$var$MONTH_DAYS = 29;
2087
+ var $7c5f6fbf42389787$var$MONTH_FRACT = 12 * $7c5f6fbf42389787$var$HOUR_PARTS + 793;
2088
+ var $7c5f6fbf42389787$var$MONTH_PARTS = $7c5f6fbf42389787$var$MONTH_DAYS * $7c5f6fbf42389787$var$DAY_PARTS + $7c5f6fbf42389787$var$MONTH_FRACT;
2089
+ var $fb18d541ea1ad717$var$formatterCache = /* @__PURE__ */ new Map();
2090
+ var $fb18d541ea1ad717$export$ad991b66133851cf = class {
2091
+ /** Formats a date as a string according to the locale and format options passed to the constructor. */
2092
+ format(value) {
2093
+ return this.formatter.format(value);
2094
+ }
2095
+ /** Formats a date to an array of parts such as separators, numbers, punctuation, and more. */
2096
+ formatToParts(value) {
2097
+ return this.formatter.formatToParts(value);
2098
+ }
2099
+ /** Formats a date range as a string. */
2100
+ formatRange(start, end) {
2101
+ if (typeof this.formatter.formatRange === "function")
2102
+ return this.formatter.formatRange(start, end);
2103
+ if (end < start)
2104
+ throw new RangeError("End date must be >= start date");
2105
+ return `${this.formatter.format(start)} \u2013 ${this.formatter.format(end)}`;
2106
+ }
2107
+ /** Formats a date range as an array of parts. */
2108
+ formatRangeToParts(start, end) {
2109
+ if (typeof this.formatter.formatRangeToParts === "function")
2110
+ return this.formatter.formatRangeToParts(start, end);
2111
+ if (end < start)
2112
+ throw new RangeError("End date must be >= start date");
2113
+ let startParts = this.formatter.formatToParts(start);
2114
+ let endParts = this.formatter.formatToParts(end);
2115
+ return [
2116
+ ...startParts.map((p) => ({
2117
+ ...p,
2118
+ source: "startRange"
2119
+ })),
2120
+ {
2121
+ type: "literal",
2122
+ value: " \u2013 ",
2123
+ source: "shared"
2124
+ },
2125
+ ...endParts.map((p) => ({
2126
+ ...p,
2127
+ source: "endRange"
2128
+ }))
2129
+ ];
2130
+ }
2131
+ /** Returns the resolved formatting options based on the values passed to the constructor. */
2132
+ resolvedOptions() {
2133
+ let resolvedOptions = this.formatter.resolvedOptions();
2134
+ if ($fb18d541ea1ad717$var$hasBuggyResolvedHourCycle()) {
2135
+ if (!this.resolvedHourCycle)
2136
+ this.resolvedHourCycle = $fb18d541ea1ad717$var$getResolvedHourCycle(resolvedOptions.locale, this.options);
2137
+ resolvedOptions.hourCycle = this.resolvedHourCycle;
2138
+ resolvedOptions.hour12 = this.resolvedHourCycle === "h11" || this.resolvedHourCycle === "h12";
2139
+ }
2140
+ if (resolvedOptions.calendar === "ethiopic-amete-alem")
2141
+ resolvedOptions.calendar = "ethioaa";
2142
+ return resolvedOptions;
2143
+ }
2144
+ constructor(locale, options = {}) {
2145
+ this.formatter = $fb18d541ea1ad717$var$getCachedDateFormatter(locale, options);
2146
+ this.options = options;
2147
+ }
2148
+ };
2149
+ var $fb18d541ea1ad717$var$hour12Preferences = {
2150
+ true: {
2151
+ // Only Japanese uses the h11 style for 12 hour time. All others use h12.
2152
+ ja: "h11"
2153
+ },
2154
+ false: {}
2155
+ };
2156
+ function $fb18d541ea1ad717$var$getCachedDateFormatter(locale, options = {}) {
2157
+ if (typeof options.hour12 === "boolean" && $fb18d541ea1ad717$var$hasBuggyHour12Behavior()) {
2158
+ options = {
2159
+ ...options
2160
+ };
2161
+ let pref = $fb18d541ea1ad717$var$hour12Preferences[String(options.hour12)][locale.split("-")[0]];
2162
+ let defaultHourCycle = options.hour12 ? "h12" : "h23";
2163
+ options.hourCycle = pref !== null && pref !== void 0 ? pref : defaultHourCycle;
2164
+ delete options.hour12;
2165
+ }
2166
+ let cacheKey = locale + (options ? Object.entries(options).sort((a, b) => a[0] < b[0] ? -1 : 1).join() : "");
2167
+ if ($fb18d541ea1ad717$var$formatterCache.has(cacheKey))
2168
+ return $fb18d541ea1ad717$var$formatterCache.get(cacheKey);
2169
+ let numberFormatter = new Intl.DateTimeFormat(locale, options);
2170
+ $fb18d541ea1ad717$var$formatterCache.set(cacheKey, numberFormatter);
2171
+ return numberFormatter;
2172
+ }
2173
+ var $fb18d541ea1ad717$var$_hasBuggyHour12Behavior = null;
2174
+ function $fb18d541ea1ad717$var$hasBuggyHour12Behavior() {
2175
+ if ($fb18d541ea1ad717$var$_hasBuggyHour12Behavior == null)
2176
+ $fb18d541ea1ad717$var$_hasBuggyHour12Behavior = new Intl.DateTimeFormat("en-US", {
2177
+ hour: "numeric",
2178
+ hour12: false
2179
+ }).format(new Date(2020, 2, 3, 0)) === "24";
2180
+ return $fb18d541ea1ad717$var$_hasBuggyHour12Behavior;
2181
+ }
2182
+ var $fb18d541ea1ad717$var$_hasBuggyResolvedHourCycle = null;
2183
+ function $fb18d541ea1ad717$var$hasBuggyResolvedHourCycle() {
2184
+ if ($fb18d541ea1ad717$var$_hasBuggyResolvedHourCycle == null)
2185
+ $fb18d541ea1ad717$var$_hasBuggyResolvedHourCycle = new Intl.DateTimeFormat("fr", {
2186
+ hour: "numeric",
2187
+ hour12: false
2188
+ }).resolvedOptions().hourCycle === "h12";
2189
+ return $fb18d541ea1ad717$var$_hasBuggyResolvedHourCycle;
2190
+ }
2191
+ function $fb18d541ea1ad717$var$getResolvedHourCycle(locale, options) {
2192
+ if (!options.timeStyle && !options.hour)
2193
+ return void 0;
2194
+ locale = locale.replace(/(-u-)?-nu-[a-zA-Z0-9]+/, "");
2195
+ locale += (locale.includes("-u-") ? "" : "-u") + "-nu-latn";
2196
+ let formatter = $fb18d541ea1ad717$var$getCachedDateFormatter(locale, {
2197
+ ...options,
2198
+ timeZone: void 0
2199
+ // use local timezone
2200
+ });
2201
+ let min = parseInt(formatter.formatToParts(new Date(2020, 2, 3, 0)).find((p) => p.type === "hour").value, 10);
2202
+ let max = parseInt(formatter.formatToParts(new Date(2020, 2, 3, 23)).find((p) => p.type === "hour").value, 10);
2203
+ if (min === 0 && max === 23)
2204
+ return "h23";
2205
+ if (min === 24 && max === 23)
2206
+ return "h24";
2207
+ if (min === 0 && max === 11)
2208
+ return "h11";
2209
+ if (min === 12 && max === 11)
2210
+ return "h12";
2211
+ throw new Error("Unexpected hour cycle result");
2212
+ }
2213
+
2214
+ // src/ts-utils.ts
2215
+ function isNotNullOrUndefined(value) {
2216
+ return value !== void 0 && value !== null;
2217
+ }
2218
+
2219
+ // src/date/formatter.ts
2220
+ var baseTimeFormatOptions = {
2221
+ hour: "2-digit",
2222
+ minute: "2-digit",
2223
+ second: "2-digit"
2224
+ };
2225
+ var formatConfigByTimePatterns = {
2226
+ "hh:mm:ss": {
2227
+ locale: "en-GB",
2228
+ options: { ...baseTimeFormatOptions, hour12: false }
2229
+ },
2230
+ "hh:mm:ss a": {
2231
+ locale: "en-GB",
2232
+ options: { ...baseTimeFormatOptions, hour12: true }
2233
+ }
2234
+ };
2235
+ var baseDateFormatOptions = {
2236
+ day: "2-digit",
2237
+ month: "2-digit",
2238
+ year: "numeric"
2239
+ };
2240
+ var formatConfigByDatePatterns = {
2241
+ "dd.mm.yyyy": {
2242
+ locale: "de-De",
2243
+ options: { ...baseDateFormatOptions }
2244
+ },
2245
+ "dd/mm/yyyy": { locale: "en-GB", options: { ...baseDateFormatOptions } },
2246
+ "dd MMM yyyy": {
2247
+ locale: "en-GB",
2248
+ options: { ...baseDateFormatOptions, month: "short" }
2249
+ },
2250
+ "dd MMMM yyyy": {
2251
+ locale: "en-GB",
2252
+ options: { ...baseDateFormatOptions, month: "long" }
2253
+ },
2254
+ "mm/dd/yyyy": { locale: "en-US", options: { ...baseDateFormatOptions } },
2255
+ "MMM dd, yyyy": {
2256
+ locale: "en-US",
2257
+ options: { ...baseDateFormatOptions, month: "short" }
2258
+ },
2259
+ "MMMM dd, yyyy": {
2260
+ locale: "en-US",
2261
+ options: { ...baseDateFormatOptions, month: "long" }
2262
+ }
2263
+ };
2264
+ function getFormatConfigs(pattern) {
2265
+ return [
2266
+ pattern.date ? formatConfigByDatePatterns[pattern.date] : null,
2267
+ pattern.time ? formatConfigByTimePatterns[pattern.time] : null
2268
+ ];
2269
+ }
2270
+ function formatDate(pattern) {
2271
+ const formatters = getFormatConfigs(pattern).filter(isNotNullOrUndefined).map((c) => getDateFormatter(c.locale, c.options));
2272
+ return (d) => formatters.map((f) => f.format(d)).join(" ");
2273
+ }
2274
+ function getDateFormatter(locale, options) {
2275
+ return new $fb18d541ea1ad717$export$ad991b66133851cf(locale, options);
2276
+ }
2277
+
2278
+ // src/date/types.ts
2279
+ var supportedDatePatterns = [
2280
+ "dd.mm.yyyy",
2281
+ "dd/mm/yyyy",
2282
+ "dd MMM yyyy",
2283
+ "dd MMMM yyyy",
2284
+ "mm/dd/yyyy",
2285
+ "MMM dd, yyyy",
2286
+ "MMMM dd, yyyy"
2287
+ ];
2288
+ var supportedTimePatterns = ["hh:mm:ss", "hh:mm:ss a"];
2289
+ var supportedDateTimePatterns = {
2290
+ date: supportedDatePatterns,
2291
+ time: supportedTimePatterns
2292
+ };
2293
+ var isDatePattern = (pattern) => supportedDatePatterns.includes(pattern);
2294
+ var isTimePattern = (pattern) => supportedTimePatterns.includes(pattern);
2295
+ var isDateTimePattern = (pattern) => isDatePattern(pattern == null ? void 0 : pattern.date) || isTimePattern(pattern == null ? void 0 : pattern.time);
2296
+
2297
+ // src/date/utils.ts
2298
+ function toCalendarDate(d) {
2299
+ return new $35ea8db9cb2ccb90$export$99faa760c7908e4f(d.getFullYear(), d.getMonth() + 1, d.getDate());
2300
+ }
2301
+
2302
+ // src/date/dateTimePattern.ts
2303
+ var defaultPatternsByType = {
2304
+ time: "hh:mm:ss",
2305
+ date: "dd.mm.yyyy"
2306
+ };
2307
+ var fallbackDateTimePattern = {
2308
+ date: defaultPatternsByType["date"]
2309
+ };
2310
+ function dateTimePattern(type) {
2311
+ if (isTypeDescriptor(type)) {
2312
+ if (type.formatting && isDateTimePattern(type.formatting.pattern)) {
2313
+ return type.formatting.pattern;
2314
+ }
2315
+ }
2316
+ return fallbackDateTimePattern;
2317
+ }
2318
+
2319
+ // src/logging-utils.ts
2320
+ var logLevels = ["error", "warn", "info", "debug"];
2321
+ var isValidLogLevel = (value) => typeof value === "string" && logLevels.includes(value);
2322
+ var DEFAULT_LOG_LEVEL = "error";
2323
+ var NO_OP = () => void 0;
2324
+ var DEFAULT_DEBUG_LEVEL = false ? "error" : "info";
2325
+ var { loggingLevel = DEFAULT_DEBUG_LEVEL } = getLoggingSettings();
2326
+ var logger = (category) => {
2327
+ const debugEnabled2 = loggingLevel === "debug";
2328
+ const infoEnabled = debugEnabled2 || loggingLevel === "info";
2329
+ const warnEnabled = infoEnabled || loggingLevel === "warn";
2330
+ const errorEnabled = warnEnabled || loggingLevel === "error";
2331
+ const info = infoEnabled ? (message) => console.info(`[${category}] ${message}`) : NO_OP;
2332
+ const warn = warnEnabled ? (message) => console.warn(`[${category}] ${message}`) : NO_OP;
2333
+ const debug2 = debugEnabled2 ? (message) => console.debug(`[${category}] ${message}`) : NO_OP;
2334
+ const error = errorEnabled ? (message) => console.error(`[${category}] ${message}`) : NO_OP;
2335
+ if (false) {
2336
+ return {
2337
+ errorEnabled,
2338
+ error
2339
+ };
2340
+ } else {
2341
+ return {
2342
+ debugEnabled: debugEnabled2,
2343
+ infoEnabled,
2344
+ warnEnabled,
2345
+ errorEnabled,
2346
+ info,
2347
+ warn,
2348
+ debug: debug2,
2349
+ error
2350
+ };
2351
+ }
2352
+ };
2353
+ function getLoggingSettings() {
2354
+ if (typeof loggingSettings !== "undefined") {
2355
+ return loggingSettings;
2356
+ } else {
2357
+ return {
2358
+ loggingLevel: getLoggingLevelFromCookie()
2359
+ };
2360
+ }
2361
+ }
2362
+ function getLoggingLevelFromCookie() {
2363
+ const value = getCookieValue("vuu-logging-level");
2364
+ if (isValidLogLevel(value)) {
2365
+ return value;
2366
+ } else {
2367
+ return DEFAULT_LOG_LEVEL;
2368
+ }
2369
+ }
2370
+ var getLoggingConfigForWorker = () => {
2371
+ return `const loggingSettings = { loggingLevel: "${getLoggingLevelFromCookie()}"};`;
2372
+ };
2373
+
2374
+ // src/debug-utils.ts
2375
+ var { debug, debugEnabled } = logger("range-monitor");
2376
+ var RangeMonitor = class {
2377
+ constructor(source) {
2378
+ this.source = source;
2379
+ this.range = { from: 0, to: 0 };
2380
+ this.timestamp = 0;
2381
+ }
2382
+ isSet() {
2383
+ return this.timestamp !== 0;
2384
+ }
2385
+ set({ from, to }) {
2386
+ const { timestamp } = this;
2387
+ this.range.from = from;
2388
+ this.range.to = to;
2389
+ this.timestamp = performance.now();
2390
+ if (timestamp) {
2391
+ debugEnabled && debug(
2392
+ `<${this.source}> [${from}-${to}], ${(this.timestamp - timestamp).toFixed(0)} ms elapsed`
2393
+ );
2394
+ } else {
2395
+ return 0;
2396
+ }
2397
+ }
2398
+ };
2399
+
2400
+ // src/html-utils.ts
2401
+ var createEl = (elementType, className, textContent) => {
2402
+ const el = document.createElement(elementType);
2403
+ if (className) {
2404
+ el.className = className;
2405
+ }
2406
+ if (textContent) {
2407
+ el.textContent = textContent;
2408
+ }
2409
+ return el;
2410
+ };
2411
+ var getFocusableElement = (el, tabIndex) => {
2412
+ if (el) {
2413
+ if (el.hasAttribute("tabindex")) {
2414
+ const rootTabIndex = parseInt(el.getAttribute("tabindex"));
2415
+ if (!isNaN(rootTabIndex) && (tabIndex === void 0 || rootTabIndex === tabIndex)) {
2416
+ return el;
2417
+ }
2418
+ }
2419
+ const focusableEl = typeof tabIndex === "number" ? el.querySelector(`[tabindex="${tabIndex}"]`) : el.querySelector("[tabindex]");
2420
+ if (focusableEl) {
2421
+ return focusableEl;
2422
+ }
2423
+ }
2424
+ };
2425
+ var getElementDataIndex = (el) => {
2426
+ if (el) {
2427
+ const index = parseInt(el.dataset.index || "");
2428
+ if (!isNaN(index)) {
2429
+ return index;
2430
+ }
2431
+ }
2432
+ return -1;
2433
+ };
2434
+ var getClosest = (el, dataProperty) => el.closest(`[data-${dataProperty}]`);
2435
+ var getClosestIndexItem = (el) => getClosest(el, "index");
2436
+ function getElementByDataIndex(container, index, throwIfNotFound = false) {
2437
+ if (container === null && throwIfNotFound) {
2438
+ throw Error("html-utils getElementByDataIndex, container is null");
2439
+ }
2440
+ const element = container == null ? void 0 : container.querySelector(
2441
+ `[data-index="${index}"]`
2442
+ );
2443
+ if (element) {
2444
+ return element;
2445
+ } else if (throwIfNotFound) {
2446
+ throw Error(
2447
+ "html-utils getElementByDataIndex, Item not found with data-index='${index}'"
2448
+ );
2449
+ } else {
2450
+ return void 0;
2451
+ }
2452
+ }
2453
+ var focusFirstFocusableElement = (el, tabIndex) => {
2454
+ requestAnimationFrame(() => {
2455
+ const focusableElement = getFocusableElement(el, tabIndex);
2456
+ if (focusableElement) {
2457
+ focusableElement.focus();
2458
+ }
2459
+ });
2460
+ };
2461
+ var isSelectableElement = (el) => {
2462
+ const item = el == null ? void 0 : el.closest("[data-index]");
2463
+ if (!item || item.ariaDisabled || item.dataset.selectable === "false" || item.querySelector('[data-selectable="false"],[aria-disabled="true"]')) {
2464
+ return false;
2465
+ } else {
2466
+ return true;
2467
+ }
2468
+ };
2469
+ var size;
2470
+ function getScrollbarSize() {
2471
+ if (size === void 0) {
2472
+ let outer = document.createElement("div");
2473
+ outer.className = "scrollable-content";
2474
+ outer.style.width = "50px";
2475
+ outer.style.height = "50px";
2476
+ outer.style.overflowY = "scroll";
2477
+ outer.style.position = "absolute";
2478
+ outer.style.top = "-200px";
2479
+ outer.style.left = "-200px";
2480
+ const inner = document.createElement("div");
2481
+ inner.style.height = "100px";
2482
+ inner.style.width = "100%";
2483
+ outer.appendChild(inner);
2484
+ document.body.appendChild(outer);
2485
+ const outerWidth = outer.offsetWidth;
2486
+ const innerWidth = inner.offsetWidth;
2487
+ document.body.removeChild(outer);
2488
+ size = outerWidth - innerWidth;
2489
+ outer = null;
2490
+ }
2491
+ return size;
2492
+ }
2493
+ var dispatchMouseEvent = (el, type) => {
2494
+ const evt = new MouseEvent(type, {
2495
+ view: window,
2496
+ bubbles: true,
2497
+ cancelable: true
2498
+ });
2499
+ el.dispatchEvent(evt);
2500
+ };
2501
+ var dispatchCustomEvent = (el, type) => {
2502
+ const evt = new Event(type, {
2503
+ bubbles: true,
2504
+ cancelable: true
2505
+ });
2506
+ el.dispatchEvent(evt);
2507
+ };
2508
+
2509
+ // src/event-emitter.ts
2510
+ function isArrayOfListeners(listeners) {
2511
+ return Array.isArray(listeners);
2512
+ }
2513
+ function isOnlyListener(listeners) {
2514
+ return !Array.isArray(listeners);
2515
+ }
2516
+ var _events;
2517
+ var EventEmitter = class {
2518
+ constructor() {
2519
+ __privateAdd(this, _events, /* @__PURE__ */ new Map());
2520
+ }
2521
+ addListener(event, listener) {
2522
+ const listeners = __privateGet(this, _events).get(event);
2523
+ if (!listeners) {
2524
+ __privateGet(this, _events).set(event, listener);
2525
+ } else if (isArrayOfListeners(listeners)) {
2526
+ listeners.push(listener);
2527
+ } else if (isOnlyListener(listeners)) {
2528
+ __privateGet(this, _events).set(event, [listeners, listener]);
2529
+ }
2530
+ }
2531
+ removeListener(event, listener) {
2532
+ if (!__privateGet(this, _events).has(event)) {
2533
+ return;
2534
+ }
2535
+ const listenerOrListeners = __privateGet(this, _events).get(event);
2536
+ let position = -1;
2537
+ if (listenerOrListeners === listener) {
2538
+ __privateGet(this, _events).delete(event);
2539
+ } else if (Array.isArray(listenerOrListeners)) {
2540
+ for (let i = length; i-- > 0; ) {
2541
+ if (listenerOrListeners[i] === listener) {
2542
+ position = i;
2543
+ break;
2544
+ }
2545
+ }
2546
+ if (position < 0) {
2547
+ return;
2548
+ }
2549
+ if (listenerOrListeners.length === 1) {
2550
+ listenerOrListeners.length = 0;
2551
+ __privateGet(this, _events).delete(event);
2552
+ } else {
2553
+ listenerOrListeners.splice(position, 1);
2554
+ }
2555
+ }
2556
+ }
2557
+ removeAllListeners(event) {
2558
+ if (event && __privateGet(this, _events).has(event)) {
2559
+ __privateGet(this, _events).delete(event);
2560
+ } else if (event === void 0) {
2561
+ __privateGet(this, _events).clear();
2562
+ }
2563
+ }
2564
+ emit(event, ...args) {
2565
+ if (__privateGet(this, _events)) {
2566
+ const handler = __privateGet(this, _events).get(event);
2567
+ if (handler) {
2568
+ this.invokeHandler(handler, args);
2569
+ }
2570
+ }
2571
+ }
2572
+ once(event, listener) {
2573
+ const handler = (...args) => {
2574
+ this.removeListener(event, handler);
2575
+ listener(...args);
2576
+ };
2577
+ this.on(event, handler);
2578
+ }
2579
+ on(event, listener) {
2580
+ this.addListener(event, listener);
2581
+ }
2582
+ hasListener(event, listener) {
2583
+ const listeners = __privateGet(this, _events).get(event);
2584
+ if (Array.isArray(listeners)) {
2585
+ return listeners.includes(listener);
2586
+ } else {
2587
+ return listeners === listener;
2588
+ }
2589
+ }
2590
+ invokeHandler(handler, args) {
2591
+ if (isArrayOfListeners(handler)) {
2592
+ handler.slice().forEach((listener) => this.invokeHandler(listener, args));
2593
+ } else {
2594
+ switch (args.length) {
2595
+ case 0:
2596
+ handler();
2597
+ break;
2598
+ case 1:
2599
+ handler(args[0]);
2600
+ break;
2601
+ case 2:
2602
+ handler(args[0], args[1]);
2603
+ break;
2604
+ default:
2605
+ handler.call(null, ...args);
2606
+ }
2607
+ }
2608
+ }
2609
+ };
2610
+ _events = new WeakMap();
2611
+
2612
+ // src/round-decimal.ts
2613
+ var PUNCTUATION_STR = String.fromCharCode(8200);
2614
+ var DIGIT_STR = String.fromCharCode(8199);
2615
+ var DECIMALS_AUTO = -1;
2616
+ var Space = {
2617
+ DIGIT: DIGIT_STR,
2618
+ TWO_DIGITS: DIGIT_STR + DIGIT_STR,
2619
+ THREE_DIGITS: DIGIT_STR + DIGIT_STR + DIGIT_STR,
2620
+ FULL_PADDING: [
2621
+ null,
2622
+ PUNCTUATION_STR + DIGIT_STR,
2623
+ PUNCTUATION_STR + DIGIT_STR + DIGIT_STR,
2624
+ PUNCTUATION_STR + DIGIT_STR + DIGIT_STR + DIGIT_STR,
2625
+ PUNCTUATION_STR + DIGIT_STR + DIGIT_STR + DIGIT_STR + DIGIT_STR
2626
+ ]
2627
+ };
2628
+ var Zero = {
2629
+ DIGIT: "0",
2630
+ TWO_DIGITS: "00",
2631
+ THREE_DIGITS: "000",
2632
+ FULL_PADDING: [null, "0", "00", "000", "0000"]
2633
+ };
2634
+ function padLeft(value, maxLength = 6) {
2635
+ return (LEADING_FILL + value).slice(-maxLength);
2636
+ }
2637
+ var LEADING_FILL = DIGIT_STR + DIGIT_STR + DIGIT_STR + DIGIT_STR + DIGIT_STR + DIGIT_STR + DIGIT_STR + DIGIT_STR + DIGIT_STR;
2638
+ var Align = {
2639
+ Right: "right",
2640
+ Center: "center",
2641
+ Left: "left"
2642
+ };
2643
+ function pad(n, dp, Pad) {
2644
+ let len = n.length;
2645
+ const diff = dp - len;
2646
+ if (diff > 0) {
2647
+ if (diff === 1) {
2648
+ n = n + Pad.DIGIT;
2649
+ } else if (diff === 2) {
2650
+ n = n + Pad.TWO_DIGITS;
2651
+ } else if (diff === 3) {
2652
+ n = n + Pad.THREE_DIGITS;
2653
+ }
2654
+ } else {
2655
+ if (diff < 0) {
2656
+ n = n.slice(0, dp);
2657
+ len = dp;
2658
+ }
2659
+ if (Pad === Space && n.charAt(len - 1) === "0") {
2660
+ n = n.replace(/0+$/, "");
2661
+ return pad(n, dp, Pad);
2662
+ }
2663
+ }
2664
+ return n;
2665
+ }
2666
+ function roundDecimal(value, align = Align.Right, decimals = 4, zeroPad, alignOnDecimals) {
2667
+ if (value === void 0 || typeof value !== "number" || isNaN(value)) {
2668
+ return "";
2669
+ }
2670
+ let integral, fraction, Pad;
2671
+ const [part1, part2 = ""] = value.toString().split(".");
2672
+ const actualDecimals = part2.length;
2673
+ integral = parseFloat(part1).toLocaleString();
2674
+ if (align === Align.Left && alignOnDecimals) {
2675
+ integral = padLeft(integral);
2676
+ }
2677
+ if (decimals === DECIMALS_AUTO || actualDecimals === decimals) {
2678
+ fraction = part2;
2679
+ } else if (actualDecimals > decimals) {
2680
+ fraction = parseFloat("0." + part2).toFixed(decimals).slice(2);
2681
+ } else {
2682
+ if (Pad = zeroPad ? Zero : alignOnDecimals && align !== Align.Left ? Space : null) {
2683
+ if (actualDecimals === 0) {
2684
+ fraction = Pad.FULL_PADDING[decimals];
2685
+ } else {
2686
+ fraction = pad(part2, decimals, Pad);
2687
+ }
2688
+ } else {
2689
+ fraction = part2;
2690
+ }
2691
+ }
2692
+ return integral + (fraction ? "." + fraction : "");
2693
+ }
2694
+
2695
+ // src/formatting-utils.ts
2696
+ var DEFAULT_NUMERIC_FORMAT = {};
2697
+ var defaultValueFormatter = (value) => value == null ? "" : typeof value === "string" ? value : value.toString();
2698
+ var dateFormatter = (column) => {
2699
+ const pattern = dateTimePattern(column.type);
2700
+ const formatter = formatDate(pattern);
2701
+ return (value) => {
2702
+ if (typeof value === "number" && value !== 0) {
2703
+ return formatter(new Date(value));
2704
+ } else {
2705
+ return "";
2706
+ }
2707
+ };
2708
+ };
2709
+ var numericFormatter = ({
2710
+ align = "right",
2711
+ type
2712
+ }) => {
2713
+ var _a;
2714
+ if (type === void 0 || typeof type === "string") {
2715
+ return defaultValueFormatter;
2716
+ } else {
2717
+ const {
2718
+ alignOnDecimals = false,
2719
+ decimals,
2720
+ zeroPad = false
2721
+ } = (_a = type.formatting) != null ? _a : DEFAULT_NUMERIC_FORMAT;
2722
+ return (value) => {
2723
+ if (typeof value === "string" && (value.startsWith("\u03A3") || value.startsWith("["))) {
2724
+ return value;
2725
+ }
2726
+ const number = typeof value === "number" ? value : typeof value === "string" ? parseFloat(value) : void 0;
2727
+ return roundDecimal(number, align, decimals, zeroPad, alignOnDecimals);
2728
+ };
2729
+ }
2730
+ };
2731
+ var mapFormatter = (map) => {
2732
+ return (value) => {
2733
+ var _a;
2734
+ return (_a = map[value]) != null ? _a : "";
2735
+ };
2736
+ };
2737
+ var getValueFormatter = (column, serverDataType = column.serverDataType) => {
2738
+ if (isDateTimeColumn(column)) {
2739
+ return dateFormatter(column);
2740
+ }
2741
+ const { type } = column;
2742
+ if (isTypeDescriptor(type) && isMappedValueTypeRenderer(type == null ? void 0 : type.renderer)) {
2743
+ return mapFormatter(type.renderer.map);
2744
+ } else if (serverDataType === "string" || serverDataType === "char") {
2745
+ return (value) => value;
2746
+ } else if (serverDataType === "double") {
2747
+ return numericFormatter(column);
2748
+ }
2749
+ return defaultValueFormatter;
2750
+ };
2751
+
2752
+ // src/getUniqueId.ts
2753
+ var getUniqueId = () => `hw-${Math.round(Math.random() * 1e5)}`;
2754
+
2755
+ // src/group-utils.ts
2756
+ function addGroupColumn(groupBy, column) {
2757
+ if (groupBy) {
2758
+ return groupBy.concat(column.name);
2759
+ } else {
2760
+ return [column.name];
2761
+ }
2762
+ }
2763
+
2764
+ // src/input-utils.ts
2765
+ var isCharacterKey = (key) => key.length === 1;
2766
+ var isQuoteKey = (evt) => {
2767
+ return evt.key === '"' || evt.key === "'";
2768
+ };
2769
+
2770
+ // src/invariant.ts
2771
+ function invariant(condition, message) {
2772
+ if (!condition) {
2773
+ const error = new Error(message);
2774
+ error.name = "Invariant Violation";
2775
+ error.framesToPop = 1;
2776
+ throw error;
2777
+ }
2778
+ }
2779
+
2780
+ // src/itemToString.ts
2781
+ var isPlainObject = (obj) => Object.prototype.toString.call(obj) === "[object Object]";
2782
+ function itemToString(item) {
2783
+ if (typeof item === "string") {
2784
+ return item;
2785
+ } else if (!isPlainObject(item)) {
2786
+ return String(item);
2787
+ }
2788
+ if (Object.prototype.hasOwnProperty.call(item, "label")) {
2789
+ return String(item.label);
2790
+ }
2791
+ console.warn(
2792
+ [
2793
+ "itemToString: you've likely forgotten to set the label prop on the item object.",
2794
+ "You can also provide your own `itemToString` implementation."
2795
+ ].join("\n")
2796
+ );
2797
+ return "";
2798
+ }
2799
+
2800
+ // src/json-utils.ts
2801
+ var { COUNT } = metadataKeys;
2802
+ var isJsonData = (value) => typeof value === "object" && value !== null;
2803
+ var vuuRowDataItemTypes = ["boolean", "number", "string"];
2804
+ var isVuuRowDataItem = (value) => vuuRowDataItemTypes.includes(typeof value);
2805
+ var typeofVuuDataItem = (value) => typeof value === "boolean" ? "boolean" : typeof value === "number" ? "number" : "string";
2806
+ var getCellValue = (attribute, attributeValue) => {
2807
+ if (isJsonData(attributeValue)) {
2808
+ return { attribute: `${attribute}+`, attributeValue: "", type: "json" };
2809
+ } else if (attributeValue === void 0) {
2810
+ return {
2811
+ attribute,
2812
+ attributeValue: "undefined",
2813
+ type: "string"
2814
+ };
2815
+ } else if (isVuuRowDataItem(attributeValue)) {
2816
+ return {
2817
+ attribute,
2818
+ attributeValue,
2819
+ type: typeofVuuDataItem(attributeValue)
2820
+ };
2821
+ } else {
2822
+ throw Error(`unsupported type ${typeof attributeValue} in JSON`);
2823
+ }
2824
+ };
2825
+ var jsonColumnType = {
2826
+ name: "json",
2827
+ renderer: {
2828
+ name: "json"
2829
+ }
2830
+ };
2831
+ var jsonToDataSourceRows = (json) => {
2832
+ const cols = [];
2833
+ cols.push(
2834
+ {
2835
+ name: "col 1",
2836
+ type: jsonColumnType
2837
+ },
2838
+ {
2839
+ name: "col 2",
2840
+ type: jsonColumnType
2841
+ }
2842
+ );
2843
+ const rows = [];
2844
+ addChildValues(rows, json, cols);
2845
+ return [cols, rows];
2846
+ };
2847
+ var addChildValues = (rows, json, cols, index = { value: 0 }, keyBase = "$root", depth = 0) => {
2848
+ let leafCount = 0;
2849
+ let rowCount = 0;
2850
+ if (depth === cols.length - 1) {
2851
+ cols.push({
2852
+ name: `col ${cols.length + 1}`,
2853
+ hidden: true,
2854
+ type: jsonColumnType
2855
+ });
2856
+ }
2857
+ const columnEntries = Object.entries(json);
2858
+ for (let i = 0; i < columnEntries.length; i++, index.value += 1) {
2859
+ const [key, value] = columnEntries[i];
2860
+ const { attribute, attributeValue, type } = getCellValue(key, value);
2861
+ const isLeaf = type !== "json";
2862
+ const blanks = Array(depth).fill("");
2863
+ const fullKey = `${keyBase}|${key}`;
2864
+ const row = [index.value, index.value, isLeaf, false, depth, 0, fullKey, 0, ...blanks, attribute, attributeValue];
2865
+ rows.push(row);
2866
+ rowCount += 1;
2867
+ if (isJsonData(value)) {
2868
+ const [nestedLeafCount, nestedRowCount] = addChildValues(
2869
+ rows,
2870
+ value,
2871
+ cols,
2872
+ { value: index.value + 1 },
2873
+ fullKey,
2874
+ depth + 1
2875
+ );
2876
+ row[COUNT] = nestedLeafCount;
2877
+ leafCount += nestedLeafCount;
2878
+ rowCount += nestedRowCount;
2879
+ index.value += nestedRowCount;
2880
+ } else {
2881
+ leafCount += 1;
2882
+ }
2883
+ }
2884
+ return [leafCount, rowCount];
2885
+ };
2886
+
2887
+ // src/keyboard-utils.ts
2888
+ var ArrowUp = "ArrowUp";
2889
+ var ArrowDown = "ArrowDown";
2890
+ var ArrowLeft = "ArrowLeft";
2891
+ var ArrowRight = "ArrowRight";
2892
+ var Enter = "Enter";
2893
+ var Escape = "Escape";
2894
+ var Home = "Home";
2895
+ var End = "End";
2896
+ var PageUp = "PageUp";
2897
+ var PageDown = "PageDown";
2898
+ var Space2 = " ";
2899
+ var Tab = "Tab";
2900
+
2901
+ // src/keyset.ts
2902
+ var EMPTY2 = [];
2903
+ var KeySet = class {
2904
+ constructor(range) {
2905
+ this.keys = /* @__PURE__ */ new Map();
2906
+ this.nextKeyValue = 0;
2907
+ this.range = range;
2908
+ this.init(range);
2909
+ }
2910
+ next(free = EMPTY2) {
2911
+ if (free.length > 0) {
2912
+ return free.shift();
2913
+ } else {
2914
+ return this.nextKeyValue++;
2915
+ }
2916
+ }
2917
+ init({ from, to }) {
2918
+ this.keys.clear();
2919
+ this.nextKeyValue = 0;
2920
+ for (let rowIndex = from; rowIndex < to; rowIndex++) {
2921
+ const nextKeyValue = this.next();
2922
+ this.keys.set(rowIndex, nextKeyValue);
2923
+ }
2924
+ return true;
2925
+ }
2926
+ reset(range) {
2927
+ const { from, to } = range;
2928
+ const newSize = to - from;
2929
+ const currentSize = this.range.to - this.range.from;
2930
+ this.range = range;
2931
+ if (currentSize > newSize) {
2932
+ return this.init(range);
2933
+ }
2934
+ const freeKeys = [];
2935
+ this.keys.forEach((keyValue, rowIndex) => {
2936
+ if (rowIndex < from || rowIndex >= to) {
2937
+ freeKeys.push(keyValue);
2938
+ this.keys.delete(rowIndex);
2939
+ }
2940
+ });
2941
+ for (let rowIndex = from; rowIndex < to; rowIndex++) {
2942
+ if (!this.keys.has(rowIndex)) {
2943
+ const nextKeyValue = this.next(freeKeys);
2944
+ this.keys.set(rowIndex, nextKeyValue);
2945
+ }
2946
+ }
2947
+ return false;
2948
+ }
2949
+ keyFor(rowIndex) {
2950
+ const key = this.keys.get(rowIndex);
2951
+ if (key === void 0) {
2952
+ console.log(`key not found
3
2953
  keys: ${this.toDebugString()}
4
- free : ${this.free.join(",")}
5
- `),Error(`KeySet, no key found for rowIndex ${t}`);return n}toDebugString(){return Array.from(this.keys.entries()).map(([t,n])=>`${t}=>${n}`).join(",")}};var is=e=>e!==void 0&&"children"in e;var us=(e=21)=>{let t="",n=crypto.getRandomValues(new Uint8Array(e));for(;e--;){let r=n[e]&63;r<36?t+=r.toString(36):r<62?t+=(r-26).toString(36).toUpperCase():r<63?t+="_":t+="-"}return t};function ls(e,t){let n;return(...r)=>{clearTimeout(n),n=window.setTimeout(()=>e(...r),t)}}function ps(e,t){let n=!1,r;function o(){r==null?n=!1:(e(...r),r=void 0,setTimeout(o,t))}return(...i)=>{n?r=i:(e(...i),n=!0,setTimeout(o,t))}}var{IDX:Oe}=C,fs=e=>[t=>t[Oe]*e,t=>Math.floor(t/e),!1],ds=(e,t,n)=>[r=>{let o=n.current*t;return r[Oe]*e-o},r=>{let o=n.current*t;return Math.round((r+o)/e)},!0],gs=(e,t)=>{if(t===-1)return null;{let n=e.querySelector(`[aria-rowindex="${t+1}"]`);if(n)return n;throw Error(`getRowElementAtIndex no row found for index index ${t}`)}},Cs=e=>{let t=e.ariaRowIndex;if(t!=null){let n=parseInt(t)-1;if(isNaN(n))throw Error(`getIndexFromRowElement row element aria rowindex invalid ${t}`);return n}else throw Error("getIndexFromRowElement row element does not have aria rowindex")};var v=[],{SELECTED:He}=C,d={False:0,True:1,First:2,Last:4},xs=e=>(e[He]&d.True)===d.True,Ts=e=>e!==void 0&&(e[He]&d.Last)===d.Last,ln=(e,t)=>{let n=typeof e=="number"?e:e[0],r=typeof t=="number"?t:t[0];return n-r},Ds=(e,t,n,r,o=!1)=>e==="single"||(e==="extended"||e==="checkbox")&&!o&&!r||!r&&!o?v:!r&&o?mn(t,n):v,pn=(e,t)=>{for(let n=0;n<e.length;n++){let r=e[n];if(typeof r=="number"){if(r===t-1)return!0;if(r>t)return!1}else{if(r[0]===t+1||r[1]===t-1)return!0;if(r[0]>t)return!1}}return!1},cn=(e,t)=>{for(let n=0;n<e.length;n++){let r=e[n];if(typeof r=="number"){if(r===t-1){let o=e[n+1];if(o===t+1){let i=[r,o];return e.slice(0,n).concat([i]).concat(e.slice(n+2))}else{let i=[r,t];return e.slice(0,n).concat([i]).concat(e.slice(n+1))}}else if(r>t)break}else if(r[0]===t+1){let o=[t,r[1]];return e.slice(0,n).concat([o]).concat(e.slice(n+1))}else if(r[1]===t-1){let o=e[n+1];if(Array.isArray(o)&&o[0]===t+1){let i=[r[0],o[1]];return e.slice(0,n).concat([i]).concat(e.slice(n+2))}else if(typeof o=="number"&&o===t+1){let i=[r[0],o];return e.slice(0,n).concat([i]).concat(e.slice(n+2))}else{let i=[r[0],t];return e.slice(0,n).concat([i]).concat(e.slice(n+1))}}}return e},bs=(e,t,n,r,o=!1,i=-1)=>{let s=e==="single",u=e==="extended"||e==="checkbox",a=s||u&&!o&&!r;if(e==="none")return v;if(a)return[n];if(r){if(t.length===0)return[n];{let l=n>i?[i,n]:[n,i];return fn(t,l)}}else if(!r)return pn(t,n)?cn(t,n):t==null?void 0:t.concat(n).sort(ln);return v};function mn(e,t){if(e.includes(t))return e.filter(n=>n!==t);{let n=[];for(let r of e)Array.isArray(r)&&P(r,t)?n.push(...Tn(r,t)):n.push(r);return n}}function fn(e,t){let[n,r]=t;return e.reduce((o,i)=>(typeof i=="number"?i<n||i>r?o.push(i):Cn(o.at(-1),i)||o.push(t):dn(i,t)?o.push(gn(i,t)):(t[1]<i[0]&&o.push(t),o.push(i)),o),[])}var dn=(e,t)=>e[1]>=t[0]&&e[1]<=t[1]||e[0]>=t[0]&&e[0]<=t[1],gn=(e,t)=>[Math.min(e[0],t[0]),Math.max(e[1],t[1])],Cn=(e,t)=>typeof e>"u"||typeof e=="number"?!1:P(e,t),P=(e,t)=>t>=e[0]&&t<=e[1],yn=d.True+d.First+d.Last,hn=d.True+d.First,xn=d.True+d.Last,Rs=(e,t)=>{for(let n of e)if(typeof n=="number"){if(n===t)return yn}else if(P(n,t))return t===n[0]?hn:t===n[1]?xn:d.True;return d.False},Es=(e,t)=>{for(let n of e)if(typeof n=="number"){if(n===t)return!0;if(n>t)return!1}else{if(P(n,t))return!0;if(n[0]>t)return!1}return!1},Ss=e=>{if(e.every(n=>typeof n=="number"))return e;let t=[];for(let n of e)if(typeof n=="number")t.push(n);else for(let r=n[0];r<=n[1];r++)t.push(r);return t};function Tn([e,t],n){return n===e?[[e+1,t]]:n===t?[[e,t-1]]:t-e===2?[e,t]:n===t-1?[[e,t-2],t]:[[e,n-1],[n+1,t]]}var Dn=e=>e==="A"?"D":"A",ws=({sortDefs:e},{name:t},n=!1,r)=>{if(n)return{sortDefs:e.concat({column:t,sortType:r!=null?r:"A"})};let o=typeof r=="string"?r:e.length===1&&e[0].column===t?Dn(e[0].sortType):"A";return{sortDefs:[{column:t,sortType:o}]}},Fs=({sortDefs:e},t,n)=>{if(n===void 0){let r=e.find(o=>o.column===t.name);if(r)return{sortDefs:[{column:t.name,sortType:r.sortType==="A"?"D":"A"}]}}return{sortDefs:[{column:t.name,sortType:n!=null?n:"A"}]}},Ls=({sortDefs:e},t,n="A")=>{let r={column:t.name,sortType:n};return e.length>0?{sortDefs:e.concat(r)}:{sortDefs:[r]}};var Ps=e=>{let t=e.trim(),n=t.lastIndexOf(" ");return n===-1?t:t.slice(n+1)},bn=e=>e.length===0?"":e[0].toUpperCase()+e.slice(1),Rn=/(?<!(^|[A-Z]))(?=[A-Z])|(?<!^)(?=[A-Z][a-z])/,Vs=e=>{let[t,...n]=e.split(Rn);return`${bn(t)} ${n.join(" ")}`};import{createContext as Sn,isValidElement as Mn,cloneElement as wn,useContext as $e}from"react";function Ge(e){var t,n,r="";if(typeof e=="string"||typeof e=="number")r+=e;else if(typeof e=="object")if(Array.isArray(e))for(t=0;t<e.length;t++)e[t]&&(n=Ge(e[t]))&&(r&&(r+=" "),r+=n);else for(t in e)e[t]&&(r&&(r+=" "),r+=t);return r}function En(){for(var e,t,n=0,r="";n<arguments.length;)(e=arguments[n++])&&(t=Ge(e))&&(r&&(r+=" "),r+=t);return r}var _e=En;import{jsx as An}from"react/jsx-runtime";var Fn="medium",Ln="salt-theme",vn="light",B=Sn({density:"high",theme:"vuu",themeMode:"light"}),Pn=["vuu","vuu-density-high","light"],$s=e=>{let t=$e(B);return e?[e.themeClass,e.densityClass,e.dataMode]:t?[`${t.theme}-theme`,`${t.theme}-density-${t.density}`,t.themeMode]:Pn},Vn=(e,t,n,r)=>{var o;return Mn(e)?wn(e,{className:_e((o=e.props)==null?void 0:o.className,`${t}-theme`,`${t}-density-${r}`),"data-mode":n}):(console.warn(`
2954
+ `);
2955
+ throw Error(`KeySet, no key found for rowIndex ${rowIndex}`);
2956
+ }
2957
+ return key;
2958
+ }
2959
+ toDebugString() {
2960
+ return `${this.keys.size} keys
2961
+ ${Array.from(this.keys.entries()).sort(([key1], [key2]) => key1 - key2).map(([k, v]) => `${k}=>${v}`).join(",")}]
2962
+ `;
2963
+ }
2964
+ };
2965
+
2966
+ // src/menu-utils.ts
2967
+ var isGroupMenuItemDescriptor = (menuItem) => menuItem !== void 0 && "children" in menuItem;
2968
+
2969
+ // src/module-utils.ts
2970
+ var isModule = (entity) => entity !== void 0 && typeof entity !== "function";
2971
+ var assertModuleExportsAtLeastOneComponent = (module) => {
2972
+ if (module && Object.values(module).every((item) => isModule(item))) {
2973
+ throw Error("module file, no components");
2974
+ }
2975
+ };
2976
+
2977
+ // src/nanoid/index.ts
2978
+ var uuid = (size2 = 21) => {
2979
+ let id = "";
2980
+ const bytes = crypto.getRandomValues(new Uint8Array(size2));
2981
+ while (size2--) {
2982
+ const byte = bytes[size2] & 63;
2983
+ if (byte < 36) {
2984
+ id += byte.toString(36);
2985
+ } else if (byte < 62) {
2986
+ id += (byte - 26).toString(36).toUpperCase();
2987
+ } else if (byte < 63) {
2988
+ id += "_";
2989
+ } else {
2990
+ id += "-";
2991
+ }
2992
+ }
2993
+ return id;
2994
+ };
2995
+
2996
+ // src/react-utils.ts
2997
+ import { Children, isValidElement } from "react";
2998
+ var EMPTY_ARRAY = [];
2999
+ var asReactElements = (children) => {
3000
+ const isArray = Array.isArray(children);
3001
+ const count = isArray ? children.length : Children.count(children);
3002
+ if (isArray && children.every(isValidElement)) {
3003
+ return children;
3004
+ } else if (count === 1 && !isArray && isValidElement(children)) {
3005
+ return [children];
3006
+ } else if (count > 1) {
3007
+ return children;
3008
+ } else {
3009
+ return EMPTY_ARRAY;
3010
+ }
3011
+ };
3012
+
3013
+ // src/perf-utils.ts
3014
+ function debounce(callback, timeInterval) {
3015
+ let timeout;
3016
+ return (...args) => {
3017
+ clearTimeout(timeout);
3018
+ timeout = window.setTimeout(() => callback(...args), timeInterval);
3019
+ };
3020
+ }
3021
+ function throttle(callback, limit) {
3022
+ let wait = false;
3023
+ let lastArgs = void 0;
3024
+ function checkLastArgs() {
3025
+ if (lastArgs == void 0) {
3026
+ wait = false;
3027
+ } else {
3028
+ callback(...lastArgs);
3029
+ lastArgs = void 0;
3030
+ setTimeout(checkLastArgs, limit);
3031
+ }
3032
+ }
3033
+ return (...args) => {
3034
+ if (wait) {
3035
+ lastArgs = args;
3036
+ } else {
3037
+ callback(...args);
3038
+ wait = true;
3039
+ setTimeout(checkLastArgs, limit);
3040
+ }
3041
+ };
3042
+ }
3043
+
3044
+ // src/row-utils.ts
3045
+ var { IDX } = metadataKeys;
3046
+ var actualRowPositioning = (rowHeight) => [
3047
+ (row) => row[IDX] * rowHeight,
3048
+ (position) => Math.floor(position / rowHeight),
3049
+ false
3050
+ ];
3051
+ var virtualRowPositioning = (rowHeight, virtualisedExtent, pctScrollTop) => [
3052
+ (row, offset = 0) => {
3053
+ const rowOffset = pctScrollTop.current * virtualisedExtent;
3054
+ return (row[IDX] - offset) * rowHeight - rowOffset;
3055
+ },
3056
+ /*
3057
+ Return index position of closest row
3058
+ */
3059
+ (position) => {
3060
+ const rowOffset = pctScrollTop.current * virtualisedExtent;
3061
+ return Math.round((position + rowOffset) / rowHeight);
3062
+ },
3063
+ true
3064
+ ];
3065
+ var getRowElementAtIndex = (container, rowIndex) => {
3066
+ if (rowIndex === -1) {
3067
+ return null;
3068
+ } else {
3069
+ const activeRow = container.querySelector(
3070
+ `[aria-rowindex="${rowIndex + 1}"]`
3071
+ );
3072
+ if (activeRow) {
3073
+ return activeRow;
3074
+ } else {
3075
+ throw Error(
3076
+ `getRowElementAtIndex no row found for index index ${rowIndex}`
3077
+ );
3078
+ }
3079
+ }
3080
+ };
3081
+ var getIndexFromRowElement = (rowElement) => {
3082
+ const rowIndex = rowElement.ariaRowIndex;
3083
+ if (rowIndex != null) {
3084
+ const index = parseInt(rowIndex) - 1;
3085
+ if (!isNaN(index)) {
3086
+ return index;
3087
+ } else {
3088
+ throw Error(
3089
+ `getIndexFromRowElement row element aria rowindex invalid ${rowIndex}`
3090
+ );
3091
+ }
3092
+ } else {
3093
+ throw Error(
3094
+ "getIndexFromRowElement row element does not have aria rowindex"
3095
+ );
3096
+ }
3097
+ };
3098
+
3099
+ // src/selection-utils.ts
3100
+ var NO_SELECTION = [];
3101
+ var { SELECTED } = metadataKeys;
3102
+ var RowSelected = {
3103
+ False: 0,
3104
+ True: 1,
3105
+ First: 2,
3106
+ Last: 4
3107
+ };
3108
+ var isRowSelected = (row) => (row[SELECTED] & RowSelected.True) === RowSelected.True;
3109
+ var isRowSelectedLast = (row) => row !== void 0 && (row[SELECTED] & RowSelected.Last) === RowSelected.Last;
3110
+ var inAscendingOrder = (item1, item2) => {
3111
+ const n1 = typeof item1 === "number" ? item1 : item1[0];
3112
+ const n2 = typeof item2 === "number" ? item2 : item2[0];
3113
+ return n1 - n2;
3114
+ };
3115
+ var deselectItem = (selectionModel, selected, itemIndex, rangeSelect, keepExistingSelection = false) => {
3116
+ const singleSelect = selectionModel === "single";
3117
+ const multiSelect = selectionModel === "extended" || selectionModel === "checkbox";
3118
+ const actsLikeSingleSelect = singleSelect || multiSelect && !keepExistingSelection && !rangeSelect;
3119
+ if (actsLikeSingleSelect || !rangeSelect && !keepExistingSelection) {
3120
+ return NO_SELECTION;
3121
+ } else if (!rangeSelect && keepExistingSelection) {
3122
+ return removeSelectedItem(selected, itemIndex);
3123
+ }
3124
+ return NO_SELECTION;
3125
+ };
3126
+ var newSelectedFillsGapOrExtends = (selection, itemIndex) => {
3127
+ for (let i = 0; i < selection.length; i++) {
3128
+ const item = selection[i];
3129
+ if (typeof item === "number") {
3130
+ if (item === itemIndex - 1) {
3131
+ return true;
3132
+ } else if (item > itemIndex) {
3133
+ return false;
3134
+ }
3135
+ } else if (item[0] === itemIndex + 1 || item[1] === itemIndex - 1) {
3136
+ return true;
3137
+ } else if (item[0] > itemIndex) {
3138
+ return false;
3139
+ }
3140
+ }
3141
+ return false;
3142
+ };
3143
+ var fillGapOrExtendSelection = (selection, itemIndex) => {
3144
+ for (let i = 0; i < selection.length; i++) {
3145
+ const item = selection[i];
3146
+ if (typeof item === "number") {
3147
+ if (item === itemIndex - 1) {
3148
+ const nextSelectionItem = selection[i + 1];
3149
+ if (nextSelectionItem === itemIndex + 1) {
3150
+ const newRange = [item, nextSelectionItem];
3151
+ return selection.slice(0, i).concat([newRange]).concat(selection.slice(i + 2));
3152
+ } else {
3153
+ const newRange = [item, itemIndex];
3154
+ return selection.slice(0, i).concat([newRange]).concat(selection.slice(i + 1));
3155
+ }
3156
+ } else if (item > itemIndex) {
3157
+ break;
3158
+ }
3159
+ } else if (item[0] === itemIndex + 1) {
3160
+ const newRange = [itemIndex, item[1]];
3161
+ return selection.slice(0, i).concat([newRange]).concat(selection.slice(i + 1));
3162
+ } else if (item[1] === itemIndex - 1) {
3163
+ const nextItem = selection[i + 1];
3164
+ if (Array.isArray(nextItem) && nextItem[0] === itemIndex + 1) {
3165
+ const newRange = [item[0], nextItem[1]];
3166
+ return selection.slice(0, i).concat([newRange]).concat(selection.slice(i + 2));
3167
+ } else if (typeof nextItem === "number" && nextItem === itemIndex + 1) {
3168
+ const newRange = [item[0], nextItem];
3169
+ return selection.slice(0, i).concat([newRange]).concat(selection.slice(i + 2));
3170
+ } else {
3171
+ const newRange = [item[0], itemIndex];
3172
+ return selection.slice(0, i).concat([newRange]).concat(selection.slice(i + 1));
3173
+ }
3174
+ }
3175
+ }
3176
+ return selection;
3177
+ };
3178
+ var selectItem = (selectionModel, selected, itemIndex, rangeSelect, keepExistingSelection = false, activeItemIndex = -1) => {
3179
+ const singleSelect = selectionModel === "single";
3180
+ const multiSelect = selectionModel === "extended" || selectionModel === "checkbox";
3181
+ const actsLikeSingleSelect = singleSelect || multiSelect && !keepExistingSelection && !rangeSelect;
3182
+ if (selectionModel === "none") {
3183
+ return NO_SELECTION;
3184
+ } else if (actsLikeSingleSelect) {
3185
+ return [itemIndex];
3186
+ } else if (rangeSelect) {
3187
+ if (selected.length === 0) {
3188
+ return [itemIndex];
3189
+ } else {
3190
+ const range = itemIndex > activeItemIndex ? [activeItemIndex, itemIndex] : [itemIndex, activeItemIndex];
3191
+ return insertRange(selected, range);
3192
+ }
3193
+ } else if (!rangeSelect) {
3194
+ if (newSelectedFillsGapOrExtends(selected, itemIndex)) {
3195
+ return fillGapOrExtendSelection(selected, itemIndex);
3196
+ } else {
3197
+ return selected == null ? void 0 : selected.concat(itemIndex).sort(inAscendingOrder);
3198
+ }
3199
+ } else if (multiSelect) {
3200
+ }
3201
+ return NO_SELECTION;
3202
+ };
3203
+ function removeSelectedItem(selected, itemIndex) {
3204
+ if (selected.includes(itemIndex)) {
3205
+ return selected.filter((selectedItem) => selectedItem !== itemIndex);
3206
+ } else {
3207
+ const newSelected = [];
3208
+ for (const selectedItem of selected) {
3209
+ if (Array.isArray(selectedItem)) {
3210
+ if (rangeIncludes(selectedItem, itemIndex)) {
3211
+ newSelected.push(...splitRange(selectedItem, itemIndex));
3212
+ } else {
3213
+ newSelected.push(selectedItem);
3214
+ }
3215
+ } else {
3216
+ newSelected.push(selectedItem);
3217
+ }
3218
+ }
3219
+ return newSelected;
3220
+ }
3221
+ }
3222
+ function insertRange(selected, range) {
3223
+ const [from, to] = range;
3224
+ return selected.reduce((newSelected, selectedItem) => {
3225
+ if (typeof selectedItem === "number") {
3226
+ if (selectedItem < from || selectedItem > to) {
3227
+ newSelected.push(selectedItem);
3228
+ } else if (!includedInRange(newSelected.at(-1), selectedItem)) {
3229
+ newSelected.push(range);
3230
+ }
3231
+ } else if (overlappingRange(selectedItem, range)) {
3232
+ newSelected.push(mergeRanges(selectedItem, range));
3233
+ } else {
3234
+ if (range[1] < selectedItem[0]) {
3235
+ newSelected.push(range);
3236
+ }
3237
+ newSelected.push(selectedItem);
3238
+ }
3239
+ return newSelected;
3240
+ }, []);
3241
+ }
3242
+ var overlappingRange = (r1, r2) => r1[1] >= r2[0] && r1[1] <= r2[1] || r1[0] >= r2[0] && r1[0] <= r2[1];
3243
+ var mergeRanges = (r1, r2) => [
3244
+ Math.min(r1[0], r2[0]),
3245
+ Math.max(r1[1], r2[1])
3246
+ ];
3247
+ var includedInRange = (selectedItem, index) => {
3248
+ if (typeof selectedItem === "undefined" || typeof selectedItem === "number") {
3249
+ return false;
3250
+ } else
3251
+ return rangeIncludes(selectedItem, index);
3252
+ };
3253
+ var rangeIncludes = (range, index) => index >= range[0] && index <= range[1];
3254
+ var SINGLE_SELECTED_ROW = RowSelected.True + RowSelected.First + RowSelected.Last;
3255
+ var FIRST_SELECTED_ROW_OF_BLOCK = RowSelected.True + RowSelected.First;
3256
+ var LAST_SELECTED_ROW_OF_BLOCK = RowSelected.True + RowSelected.Last;
3257
+ var getSelectionStatus = (selected, itemIndex) => {
3258
+ for (const item of selected) {
3259
+ if (typeof item === "number") {
3260
+ if (item === itemIndex) {
3261
+ return SINGLE_SELECTED_ROW;
3262
+ }
3263
+ } else if (rangeIncludes(item, itemIndex)) {
3264
+ if (itemIndex === item[0]) {
3265
+ return FIRST_SELECTED_ROW_OF_BLOCK;
3266
+ } else if (itemIndex === item[1]) {
3267
+ return LAST_SELECTED_ROW_OF_BLOCK;
3268
+ } else {
3269
+ return RowSelected.True;
3270
+ }
3271
+ }
3272
+ }
3273
+ return RowSelected.False;
3274
+ };
3275
+ var isSelected = (selected, itemIndex) => {
3276
+ for (const item of selected) {
3277
+ if (typeof item === "number") {
3278
+ if (item === itemIndex) {
3279
+ return true;
3280
+ } else if (item > itemIndex) {
3281
+ return false;
3282
+ }
3283
+ } else if (rangeIncludes(item, itemIndex)) {
3284
+ return true;
3285
+ } else if (item[0] > itemIndex) {
3286
+ return false;
3287
+ }
3288
+ }
3289
+ return false;
3290
+ };
3291
+ var expandSelection = (selected) => {
3292
+ if (selected.every((selectedItem) => typeof selectedItem === "number")) {
3293
+ return selected;
3294
+ }
3295
+ const expandedSelected = [];
3296
+ for (const selectedItem of selected) {
3297
+ if (typeof selectedItem === "number") {
3298
+ expandedSelected.push(selectedItem);
3299
+ } else {
3300
+ for (let i = selectedItem[0]; i <= selectedItem[1]; i++) {
3301
+ expandedSelected.push(i);
3302
+ }
3303
+ }
3304
+ }
3305
+ return expandedSelected;
3306
+ };
3307
+ function splitRange([from, to], itemIndex) {
3308
+ if (itemIndex === from) {
3309
+ return [[from + 1, to]];
3310
+ } else if (itemIndex === to) {
3311
+ return [[from, to - 1]];
3312
+ } else if (to - from === 2) {
3313
+ return [from, to];
3314
+ } else if (itemIndex === to - 1) {
3315
+ return [[from, to - 2], to];
3316
+ } else {
3317
+ return [
3318
+ [from, itemIndex - 1],
3319
+ [itemIndex + 1, to]
3320
+ ];
3321
+ }
3322
+ }
3323
+
3324
+ // src/sort-utils.ts
3325
+ var toggle = (sortType) => sortType === "A" ? "D" : "A";
3326
+ var applySort = ({ sortDefs }, { name: column }, extendSort = false, sortType) => {
3327
+ if (extendSort) {
3328
+ return {
3329
+ sortDefs: sortDefs.concat({
3330
+ column,
3331
+ sortType: sortType != null ? sortType : "A"
3332
+ })
3333
+ };
3334
+ }
3335
+ const newSortType = typeof sortType === "string" ? sortType : sortDefs.length === 1 && sortDefs[0].column === column ? toggle(sortDefs[0].sortType) : "A";
3336
+ return {
3337
+ sortDefs: [{ column, sortType: newSortType }]
3338
+ };
3339
+ };
3340
+ var setSortColumn = ({ sortDefs }, column, sortType) => {
3341
+ if (sortType === void 0) {
3342
+ const columnSort = sortDefs.find((item) => item.column === column.name);
3343
+ if (columnSort) {
3344
+ return {
3345
+ sortDefs: [
3346
+ {
3347
+ column: column.name,
3348
+ sortType: columnSort.sortType === "A" ? "D" : "A"
3349
+ }
3350
+ ]
3351
+ };
3352
+ }
3353
+ }
3354
+ return { sortDefs: [{ column: column.name, sortType: sortType != null ? sortType : "A" }] };
3355
+ };
3356
+ var addSortColumn = ({ sortDefs }, column, sortType = "A") => {
3357
+ const sortEntry = { column: column.name, sortType };
3358
+ if (sortDefs.length > 0) {
3359
+ return {
3360
+ sortDefs: sortDefs.concat(sortEntry)
3361
+ };
3362
+ } else {
3363
+ return { sortDefs: [sortEntry] };
3364
+ }
3365
+ };
3366
+
3367
+ // src/text-utils.ts
3368
+ var lastWord = (text) => {
3369
+ const trimmedText = text.trim();
3370
+ const pos = trimmedText.lastIndexOf(" ");
3371
+ if (pos === -1) {
3372
+ return trimmedText;
3373
+ } else {
3374
+ return trimmedText.slice(pos + 1);
3375
+ }
3376
+ };
3377
+ var capitalize = (text) => text.length === 0 ? "" : text[0].toUpperCase() + text.slice(1);
3378
+ var regexp_worfify = /(?<!(^|[A-Z]))(?=[A-Z])|(?<!^)(?=[A-Z][a-z])/;
3379
+ var wordify = (text) => {
3380
+ const [firstWord, ...rest] = text.split(regexp_worfify);
3381
+ return `${capitalize(firstWord)} ${rest.join(" ")}`;
3382
+ };
3383
+
3384
+ // src/ThemeProvider.tsx
3385
+ import {
3386
+ createContext,
3387
+ isValidElement as isValidElement2,
3388
+ cloneElement,
3389
+ useContext
3390
+ } from "react";
3391
+
3392
+ // ../../node_modules/clsx/dist/clsx.mjs
3393
+ function r(e) {
3394
+ var t, f, n = "";
3395
+ if ("string" == typeof e || "number" == typeof e)
3396
+ n += e;
3397
+ else if ("object" == typeof e)
3398
+ if (Array.isArray(e))
3399
+ for (t = 0; t < e.length; t++)
3400
+ e[t] && (f = r(e[t])) && (n && (n += " "), n += f);
3401
+ else
3402
+ for (t in e)
3403
+ e[t] && (n && (n += " "), n += t);
3404
+ return n;
3405
+ }
3406
+ function clsx() {
3407
+ for (var e, t, f = 0, n = ""; f < arguments.length; )
3408
+ (e = arguments[f++]) && (t = r(e)) && (n && (n += " "), n += t);
3409
+ return n;
3410
+ }
3411
+ var clsx_default = clsx;
3412
+
3413
+ // src/ThemeProvider.tsx
3414
+ import { jsx } from "react/jsx-runtime";
3415
+ var DEFAULT_DENSITY = "medium";
3416
+ var DEFAULT_THEME = "salt-theme";
3417
+ var DEFAULT_THEME_MODE = "light";
3418
+ var ThemeContext = createContext({
3419
+ density: "high",
3420
+ theme: "vuu",
3421
+ themeMode: "light"
3422
+ });
3423
+ var DEFAULT_THEME_ATTRIBUTES = [
3424
+ "vuu",
3425
+ "vuu-density-high",
3426
+ "light"
3427
+ ];
3428
+ var useThemeAttributes = (themeAttributes) => {
3429
+ const context = useContext(ThemeContext);
3430
+ if (themeAttributes) {
3431
+ return [
3432
+ themeAttributes.themeClass,
3433
+ themeAttributes.densityClass,
3434
+ themeAttributes.dataMode
3435
+ ];
3436
+ } else if (context) {
3437
+ return [
3438
+ `${context.theme}-theme`,
3439
+ `${context.theme}-density-${context.density}`,
3440
+ context.themeMode
3441
+ ];
3442
+ }
3443
+ return DEFAULT_THEME_ATTRIBUTES;
3444
+ };
3445
+ var createThemedChildren = (children, theme, themeMode, density) => {
3446
+ var _a;
3447
+ if (isValidElement2(children)) {
3448
+ return cloneElement(children, {
3449
+ className: clsx_default(
3450
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-member-access
3451
+ (_a = children.props) == null ? void 0 : _a.className,
3452
+ `${theme}-theme`,
3453
+ `${theme}-density-${density}`
3454
+ ),
3455
+ // eslint-disable-next-line @typescript-eslint/ban-ts-comment
3456
+ // @ts-expect-error
3457
+ "data-mode": themeMode
3458
+ });
3459
+ } else {
3460
+ console.warn(
3461
+ `
6
3462
  ThemeProvider can only apply CSS classes for theming to a single nested child element of the ThemeProvider.
7
- Wrap elements with a single container`),e)},kn=({applyThemeClasses:e=!1,children:t,theme:n,themeMode:r,density:o})=>{var h,T,R;let{density:i,themeMode:s,theme:u}=$e(B),a=(h=o!=null?o:i)!=null?h:Fn,l=(T=r!=null?r:s)!=null?T:vn,c=(R=n!=null?n:u)!=null?R:Ln,y=e?Vn(t,c,l,a):t;return An(B.Provider,{value:{themeMode:l,density:a,theme:c},children:y})};kn.displayName="ThemeProvider";var Ws=(e,t)=>{var n;return(n=new URL(document.location.href).searchParams.get(e))!=null?n:t},js=e=>new URL(document.location.href).searchParams.has(e);import{useMemo as In}from"react";var On=0,qs=e=>In(()=>e!=null?e:`vuu-${++On}`,[e]);import{useLayoutEffect as Hn,useRef as Gn}from"react";var Qs=(e,t)=>{let n=Gn(!1);Hn(()=>{n.current?e():n.current=!0},t)};export{ir as AggregationType,Ki as ArrowDown,qi as ArrowLeft,zi as ArrowRight,Bi as ArrowUp,Fn as DEFAULT_DENSITY,Ln as DEFAULT_THEME,vn as DEFAULT_THEME_MODE,_ as DOWN1,$ as DOWN2,de as DataWindow,Qi as End,Ji as Enter,Xi as Escape,Fe as EventEmitter,Yi as Home,Ie as KeySet,Eo as MEASURES,Co as NULL_RANGE,Tt as NoFilter,Dt as NoSort,es as PageDown,Zi as PageUp,Me as RangeMonitor,d as RowSelected,ts as Space,ns as Tab,B as ThemeContext,kn as ThemeProvider,H as UP1,G as UP2,M as WindowRange,fs as actualRowPositioning,Br as addColumnToSubscribedColumns,ki as addGroupColumn,Ls as addSortColumn,Zr as applyDefaultColumnConfig,Fr as applyFilterToColumns,Mr as applyGroupByToColumns,ws as applySort,wr as applySortToColumns,qn as boxContainsPoint,hr as buildColumnMap,Ft as columnsChanged,Io as configChanged,mi as createEl,ls as debounce,De as defaultPatternsByType,Ve as defaultValueFormatter,Ds as deselectItem,Ti as dispatchCustomEvent,xi as dispatchMouseEvent,Ss as expandSelection,ue as extractFilterForColumn,Ze as extractGroupColumn,be as fallbackDateTimePattern,V as filterAsQuery,Lt as filterChanged,je as filterValue,ot as findColumn,k as flattenColumnGroup,Ci as focusFirstFocusableElement,he as formatDate,lr as fromServerDataType,jn as getAddedItems,I as getCalculatedColumnDetails,qr as getCalculatedColumnExpression,at as getCalculatedColumnName,Kr as getCalculatedColumnType,mo as getCellConfigPanelRenderer,ao as getCellRenderer,uo as getCellRendererOptions,qt as getClosest,di as getClosestIndexItem,eo as getColumnByName,lo as getColumnHeaderContentRenderer,po as getColumnHeaderLabelRenderer,Vr as getColumnLabel,Pr as getColumnName,Er as getColumnStyle,Hr as getColumnsInViewport,co as getConfigurationEditor,pe as getCookieValue,ur as getDefaultAlignment,ae as getDefaultColumnType,fo as getEditRuleValidator,gi as getElementByDataIndex,fi as getElementDataIndex,Kt as getFocusableElement,yo as getFullRange,_r as getGroupValueAndOffset,Cs as getIndexFromRowElement,ai as getLoggingConfigForWorker,Bn as getMissingItems,Fo as getMovingValueDirection,so as getRegisteredCellRenderers,gs as getRowElementAtIndex,Ir as getRowRecord,hi as getScrollbarSize,Rs as getSelectionStatus,Rr as getTableHeadings,Wr as getTypeFormattingFromColumn,Pi as getUniqueId,Ws as getUrlParameter,Li as getValueFormatter,vt as groupByChanged,Bo as hasAction,Ho as hasFilter,Oo as hasGroupBy,Xe as hasHeadings,Go as hasSort,js as hasUrlParameter,yr as hasValidationRules,Gi as invariant,Qn as isAndFilter,le as isCalculatedColumn,Ii as isCharacterKey,A as isColumnTypeRenderer,er as isCompleteFilter,Uo as isConnectionQualityMetrics,No as isConnectionStatusMessage,Or as isDataLoading,ie as isDateTimeColumn,N as isDateTimePattern,jo as isErrorResponse,ee as isFilterClause,Lr as isFilteredColumn,et as isGroupColumn,is as isGroupMenuItemDescriptor,Yn as isInFilter,tt as isJsonAttribute,Dr as isJsonColumn,Tr as isJsonGroup,Je as isKeyedColumn,gr as isLookupRenderer,se as isMappedValueTypeRenderer,E as isMultiClauseFilter,te as isMultiValueFilter,Xn as isNamedFilter,re as isNotHidden,Ce as isNotNullOrUndefined,pr as isNumericColumn,Zn as isOrFilter,cr as isPinned,Oi as isQuoteKey,mr as isResizing,xs as isRowSelected,Ts as isRowSelectedLast,yi as isSelectableElement,Es as isSelected,Z as isSingleValueFilter,$o as isTableSchema,fr as isTextColumn,g as isTypeDescriptor,_o as isTypeaheadSuggestionProvider,ze as isValidColumnAlignment,Jn as isValidFilterClauseOp,Mo as isValidNumber,ar as isValidPinLocation,Cr as isValueListRenderer,xt as isViewportMenusAction,Ko as isViewporttMessage,vo as isVisualLinkCreatedAction,Po as isVisualLinkRemovedAction,ht as isVisualLinksAction,Vo as isVuuFeatureAction,$i as itemToString,Nn as itemsChanged,Un as itemsOrOrderChanged,Wi as jsonToDataSourceRows,Ps as lastWord,Ee as logger,sr as mapSortCriteria,Wo as messageHasResult,C as metadataKeys,Yr as moveColumnTo,Y as moveItem,Wn as moveItemDeprecated,en as numericFormatter,$n as partition,xr as projectUpdates,Be as quotedStrings,xo as rangeNewItems,oo as registerComponent,io as registerConfigurationEditor,tr as removeColumnFromFilter,Qr as replaceColumn,ho as resetRange,Pe as roundDecimal,bs as selectItem,Sr as setAggregations,Xr as setCalculatedColumnExpression,zr as setCalculatedColumnName,Jr as setCalculatedColumnType,Fs as setSortColumn,wo as shallowEquals,br as sortPinnedColumns,vr as stripFilterFromColumns,jr as subscribedOnly,Ot as supportedDateTimePatterns,ps as throttle,dr as toColumnDescriptor,Ar as toDataSourceColumns,kr as updateColumn,$r as updateColumnFormatting,Ur as updateColumnRenderProps,Nr as updateColumnType,qs as useId,Qs as useLayoutEffectSkipFirst,$s as useThemeAttributes,us as uuid,Ao as vanillaConfig,ds as virtualRowPositioning,Gr as visibleColumnAtIndex,qo as withConfigDefaults,Ct as withinRange,Vs as wordify};
3463
+ Wrap elements with a single container`
3464
+ );
3465
+ return children;
3466
+ }
3467
+ };
3468
+ var ThemeProvider = ({
3469
+ applyThemeClasses = false,
3470
+ children,
3471
+ theme: themeProp,
3472
+ themeMode: themeModeProp,
3473
+ density: densityProp
3474
+ }) => {
3475
+ var _a, _b, _c;
3476
+ const {
3477
+ density: inheritedDensity,
3478
+ themeMode: inheritedThemeMode,
3479
+ theme: inheritedTheme
3480
+ } = useContext(ThemeContext);
3481
+ const density = (_a = densityProp != null ? densityProp : inheritedDensity) != null ? _a : DEFAULT_DENSITY;
3482
+ const themeMode = (_b = themeModeProp != null ? themeModeProp : inheritedThemeMode) != null ? _b : DEFAULT_THEME_MODE;
3483
+ const theme = (_c = themeProp != null ? themeProp : inheritedTheme) != null ? _c : DEFAULT_THEME;
3484
+ const themedChildren = applyThemeClasses ? createThemedChildren(children, theme, themeMode, density) : children;
3485
+ return /* @__PURE__ */ jsx(ThemeContext.Provider, { value: { themeMode, density, theme }, children: themedChildren });
3486
+ };
3487
+ ThemeProvider.displayName = "ThemeProvider";
3488
+
3489
+ // src/url-utils.ts
3490
+ var getUrlParameter = (paramName, defaultValue) => {
3491
+ var _a;
3492
+ return (_a = new URL(document.location.href).searchParams.get(paramName)) != null ? _a : defaultValue;
3493
+ };
3494
+ var hasUrlParameter = (paramName) => new URL(document.location.href).searchParams.has(paramName);
3495
+
3496
+ // src/useId.ts
3497
+ import { useMemo } from "react";
3498
+ var vuuComponentIdCount = 0;
3499
+ var useId = (id) => useMemo(() => id != null ? id : `vuu-${++vuuComponentIdCount}`, [id]);
3500
+
3501
+ // src/useLayoutEffectSkipFirst.ts
3502
+ import { useLayoutEffect, useRef } from "react";
3503
+ var useLayoutEffectSkipFirst = (func, deps) => {
3504
+ const goodToGo = useRef(false);
3505
+ useLayoutEffect(() => {
3506
+ if (goodToGo.current) {
3507
+ func();
3508
+ } else {
3509
+ goodToGo.current = true;
3510
+ }
3511
+ }, deps);
3512
+ };
3513
+ export {
3514
+ AggregationType,
3515
+ ArrowDown,
3516
+ ArrowLeft,
3517
+ ArrowRight,
3518
+ ArrowUp,
3519
+ DEFAULT_DENSITY,
3520
+ DEFAULT_THEME,
3521
+ DEFAULT_THEME_MODE,
3522
+ DOWN1,
3523
+ DOWN2,
3524
+ DataWindow,
3525
+ End,
3526
+ Enter,
3527
+ Escape,
3528
+ EventEmitter,
3529
+ Home,
3530
+ KeySet,
3531
+ MEASURES,
3532
+ NULL_RANGE,
3533
+ NoFilter,
3534
+ NoSort,
3535
+ PageDown,
3536
+ PageUp,
3537
+ RangeMonitor,
3538
+ RowSelected,
3539
+ Space2 as Space,
3540
+ Tab,
3541
+ ThemeContext,
3542
+ ThemeProvider,
3543
+ UP1,
3544
+ UP2,
3545
+ WindowRange,
3546
+ actualRowPositioning,
3547
+ addColumnToSubscribedColumns,
3548
+ addGroupColumn,
3549
+ addSortColumn,
3550
+ applyDefaultColumnConfig,
3551
+ applyFilterToColumns,
3552
+ applyGroupByToColumns,
3553
+ applySort,
3554
+ applySortToColumns,
3555
+ applyWidthToColumns,
3556
+ asReactElements,
3557
+ assertModuleExportsAtLeastOneComponent,
3558
+ boxContainsPoint,
3559
+ buildColumnMap,
3560
+ columnsChanged,
3561
+ configChanged,
3562
+ createEl,
3563
+ dataAndColumnUnchanged,
3564
+ dateTimePattern,
3565
+ debounce,
3566
+ defaultPatternsByType,
3567
+ defaultValueFormatter,
3568
+ deselectItem,
3569
+ dispatchCustomEvent,
3570
+ dispatchMouseEvent,
3571
+ expandSelection,
3572
+ extractFilterForColumn,
3573
+ extractGroupColumn,
3574
+ fallbackDateTimePattern,
3575
+ filterAsQuery,
3576
+ filterChanged,
3577
+ findColumn,
3578
+ flattenColumnGroup,
3579
+ focusFirstFocusableElement,
3580
+ formatDate,
3581
+ fromServerDataType,
3582
+ getAddedItems,
3583
+ getCalculatedColumnDetails,
3584
+ getCalculatedColumnExpression,
3585
+ getCalculatedColumnName,
3586
+ getCalculatedColumnType,
3587
+ getCellConfigPanelRenderer,
3588
+ getCellRenderer,
3589
+ getCellRendererOptions,
3590
+ getClosest,
3591
+ getClosestIndexItem,
3592
+ getColumnByName,
3593
+ getColumnHeaderContentRenderer,
3594
+ getColumnHeaderLabelRenderer,
3595
+ getColumnLabel,
3596
+ getColumnName,
3597
+ getColumnStyle,
3598
+ getColumnsInViewport,
3599
+ getConfigurationEditor,
3600
+ getCookieValue,
3601
+ getDateFormatter,
3602
+ getDefaultAlignment,
3603
+ getDefaultColumnType,
3604
+ getEditRuleValidator,
3605
+ getElementByDataIndex,
3606
+ getElementDataIndex,
3607
+ getFocusableElement,
3608
+ getFullRange,
3609
+ getGroupValueAndOffset,
3610
+ getIndexFromRowElement,
3611
+ getLoggingConfigForWorker,
3612
+ getMissingItems,
3613
+ getMovingValueDirection,
3614
+ getRegisteredCellRenderers,
3615
+ getRowElementAtIndex,
3616
+ getRowRecord,
3617
+ getScrollbarSize,
3618
+ getSelectionStatus,
3619
+ getTableHeadings,
3620
+ getTypeFormattingFromColumn,
3621
+ getUniqueId,
3622
+ getUrlParameter,
3623
+ getValueFormatter,
3624
+ groupByChanged,
3625
+ hasAction,
3626
+ hasFilter,
3627
+ hasGroupBy,
3628
+ hasHeadings,
3629
+ hasSort,
3630
+ hasUrlParameter,
3631
+ hasValidationRules,
3632
+ invariant,
3633
+ isAndFilter,
3634
+ isCalculatedColumn,
3635
+ isCharacterKey,
3636
+ isColumnTypeRenderer,
3637
+ isCompleteFilter,
3638
+ isConnectionQualityMetrics,
3639
+ isConnectionStatusMessage,
3640
+ isDataLoading,
3641
+ isDateTimeColumn,
3642
+ isDateTimePattern,
3643
+ isErrorResponse,
3644
+ isFilterClause,
3645
+ isFilteredColumn,
3646
+ isGroupColumn,
3647
+ isGroupMenuItemDescriptor,
3648
+ isInFilter,
3649
+ isJsonAttribute,
3650
+ isJsonColumn,
3651
+ isJsonGroup,
3652
+ isLookupRenderer,
3653
+ isMappedValueTypeRenderer,
3654
+ isModule,
3655
+ isMultiClauseFilter,
3656
+ isMultiValueFilter,
3657
+ isNamedFilter,
3658
+ isNotHidden,
3659
+ isNotNullOrUndefined,
3660
+ isNumericColumn,
3661
+ isOrFilter,
3662
+ isPinned,
3663
+ isQuoteKey,
3664
+ isResizing,
3665
+ isRowSelected,
3666
+ isRowSelectedLast,
3667
+ isSelectableElement,
3668
+ isSelected,
3669
+ isSingleValueFilter,
3670
+ isTableSchema,
3671
+ isTextColumn,
3672
+ isTypeDescriptor,
3673
+ isTypeaheadSuggestionProvider,
3674
+ isValidColumnAlignment,
3675
+ isValidFilterClauseOp,
3676
+ isValidNumber,
3677
+ isValidPinLocation,
3678
+ isValueListRenderer,
3679
+ isViewportMenusAction,
3680
+ isViewporttMessage,
3681
+ isVisualLinkCreatedAction,
3682
+ isVisualLinkRemovedAction,
3683
+ isVisualLinksAction,
3684
+ isVuuFeatureAction,
3685
+ itemToString,
3686
+ itemsChanged,
3687
+ itemsOrOrderChanged,
3688
+ jsonToDataSourceRows,
3689
+ lastWord,
3690
+ logger,
3691
+ mapSortCriteria,
3692
+ measurePinnedColumns,
3693
+ messageHasResult,
3694
+ metadataKeys,
3695
+ moveColumnTo,
3696
+ moveItem,
3697
+ moveItemDeprecated,
3698
+ numericFormatter,
3699
+ partition,
3700
+ projectUpdates,
3701
+ rangeNewItems,
3702
+ rangesAreSame,
3703
+ registerComponent,
3704
+ registerConfigurationEditor,
3705
+ removeColumnFromFilter,
3706
+ replaceColumn,
3707
+ resetRange,
3708
+ roundDecimal,
3709
+ selectItem,
3710
+ setAggregations,
3711
+ setCalculatedColumnExpression,
3712
+ setCalculatedColumnName,
3713
+ setCalculatedColumnType,
3714
+ setSortColumn,
3715
+ shallowEquals,
3716
+ sortPinnedColumns,
3717
+ stripFilterFromColumns,
3718
+ subscribedOnly,
3719
+ supportedDateTimePatterns,
3720
+ throttle,
3721
+ toCalendarDate,
3722
+ toColumnDescriptor,
3723
+ toDataSourceColumns,
3724
+ updateColumn,
3725
+ updateColumnFormatting,
3726
+ updateColumnRenderProps,
3727
+ updateColumnType,
3728
+ useId,
3729
+ useLayoutEffectSkipFirst,
3730
+ useThemeAttributes,
3731
+ uuid,
3732
+ vanillaConfig,
3733
+ virtualRowPositioning,
3734
+ visibleColumnAtIndex,
3735
+ withConfigDefaults,
3736
+ withinRange,
3737
+ wordify
3738
+ };
8
3739
  //# sourceMappingURL=index.js.map