@radio-garden/ditojs-admin 2.85.2-0.5067ad799

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.
Files changed (153) hide show
  1. package/README.md +180 -0
  2. package/dist/dito-admin.css +1 -0
  3. package/dist/dito-admin.es.js +12106 -0
  4. package/dist/dito-admin.umd.js +7 -0
  5. package/package.json +96 -0
  6. package/src/DitoAdmin.js +293 -0
  7. package/src/DitoComponent.js +34 -0
  8. package/src/DitoContext.js +318 -0
  9. package/src/DitoTypeComponent.js +42 -0
  10. package/src/DitoUser.js +12 -0
  11. package/src/appState.js +12 -0
  12. package/src/components/DitoAccount.vue +60 -0
  13. package/src/components/DitoAffix.vue +68 -0
  14. package/src/components/DitoAffixes.vue +200 -0
  15. package/src/components/DitoButtons.vue +80 -0
  16. package/src/components/DitoClipboard.vue +186 -0
  17. package/src/components/DitoContainer.vue +374 -0
  18. package/src/components/DitoCreateButton.vue +146 -0
  19. package/src/components/DitoDialog.vue +242 -0
  20. package/src/components/DitoDraggable.vue +117 -0
  21. package/src/components/DitoEditButtons.vue +135 -0
  22. package/src/components/DitoErrors.vue +83 -0
  23. package/src/components/DitoForm.vue +521 -0
  24. package/src/components/DitoFormInner.vue +26 -0
  25. package/src/components/DitoFormNested.vue +17 -0
  26. package/src/components/DitoHeader.vue +84 -0
  27. package/src/components/DitoLabel.vue +200 -0
  28. package/src/components/DitoMenu.vue +186 -0
  29. package/src/components/DitoNavigation.vue +40 -0
  30. package/src/components/DitoNotifications.vue +170 -0
  31. package/src/components/DitoPagination.vue +42 -0
  32. package/src/components/DitoPane.vue +334 -0
  33. package/src/components/DitoPanel.vue +256 -0
  34. package/src/components/DitoPanels.vue +61 -0
  35. package/src/components/DitoRoot.vue +524 -0
  36. package/src/components/DitoSchema.vue +846 -0
  37. package/src/components/DitoSchemaInlined.vue +97 -0
  38. package/src/components/DitoScopes.vue +76 -0
  39. package/src/components/DitoSidebar.vue +50 -0
  40. package/src/components/DitoSpinner.vue +95 -0
  41. package/src/components/DitoTableCell.vue +64 -0
  42. package/src/components/DitoTableHead.vue +121 -0
  43. package/src/components/DitoTabs.vue +103 -0
  44. package/src/components/DitoTrail.vue +124 -0
  45. package/src/components/DitoTreeItem.vue +420 -0
  46. package/src/components/DitoUploadFile.vue +199 -0
  47. package/src/components/DitoVNode.vue +14 -0
  48. package/src/components/DitoView.vue +143 -0
  49. package/src/components/index.js +42 -0
  50. package/src/directives/resize.js +83 -0
  51. package/src/index.js +1 -0
  52. package/src/mixins/ContextMixin.js +68 -0
  53. package/src/mixins/DataMixin.js +131 -0
  54. package/src/mixins/DitoMixin.js +591 -0
  55. package/src/mixins/DomMixin.js +29 -0
  56. package/src/mixins/EmitterMixin.js +158 -0
  57. package/src/mixins/ItemMixin.js +144 -0
  58. package/src/mixins/LoadingMixin.js +23 -0
  59. package/src/mixins/NumberMixin.js +118 -0
  60. package/src/mixins/OptionsMixin.js +304 -0
  61. package/src/mixins/PulldownMixin.js +63 -0
  62. package/src/mixins/ResourceMixin.js +398 -0
  63. package/src/mixins/RouteMixin.js +190 -0
  64. package/src/mixins/SchemaParentMixin.js +33 -0
  65. package/src/mixins/SortableMixin.js +49 -0
  66. package/src/mixins/SourceMixin.js +734 -0
  67. package/src/mixins/TextMixin.js +26 -0
  68. package/src/mixins/TypeMixin.js +280 -0
  69. package/src/mixins/ValidationMixin.js +119 -0
  70. package/src/mixins/ValidatorMixin.js +57 -0
  71. package/src/mixins/ValueMixin.js +31 -0
  72. package/src/styles/_base.scss +17 -0
  73. package/src/styles/_button.scss +191 -0
  74. package/src/styles/_imports.scss +3 -0
  75. package/src/styles/_info.scss +19 -0
  76. package/src/styles/_layout.scss +19 -0
  77. package/src/styles/_pulldown.scss +38 -0
  78. package/src/styles/_scroll.scss +13 -0
  79. package/src/styles/_settings.scss +88 -0
  80. package/src/styles/_table.scss +223 -0
  81. package/src/styles/_tippy.scss +45 -0
  82. package/src/styles/style.scss +9 -0
  83. package/src/types/DitoTypeButton.vue +143 -0
  84. package/src/types/DitoTypeCheckbox.vue +27 -0
  85. package/src/types/DitoTypeCheckboxes.vue +65 -0
  86. package/src/types/DitoTypeCode.vue +199 -0
  87. package/src/types/DitoTypeColor.vue +272 -0
  88. package/src/types/DitoTypeComponent.vue +31 -0
  89. package/src/types/DitoTypeComputed.vue +50 -0
  90. package/src/types/DitoTypeDate.vue +99 -0
  91. package/src/types/DitoTypeLabel.vue +23 -0
  92. package/src/types/DitoTypeList.vue +364 -0
  93. package/src/types/DitoTypeMarkup.vue +700 -0
  94. package/src/types/DitoTypeMultiselect.vue +522 -0
  95. package/src/types/DitoTypeNumber.vue +66 -0
  96. package/src/types/DitoTypeObject.vue +136 -0
  97. package/src/types/DitoTypePanel.vue +18 -0
  98. package/src/types/DitoTypeProgress.vue +40 -0
  99. package/src/types/DitoTypeRadio.vue +45 -0
  100. package/src/types/DitoTypeSection.vue +80 -0
  101. package/src/types/DitoTypeSelect.vue +133 -0
  102. package/src/types/DitoTypeSlider.vue +66 -0
  103. package/src/types/DitoTypeSpacer.vue +11 -0
  104. package/src/types/DitoTypeSwitch.vue +40 -0
  105. package/src/types/DitoTypeText.vue +101 -0
  106. package/src/types/DitoTypeTextarea.vue +48 -0
  107. package/src/types/DitoTypeTreeList.vue +193 -0
  108. package/src/types/DitoTypeUpload.vue +503 -0
  109. package/src/types/index.js +30 -0
  110. package/src/utils/SchemaGraph.js +147 -0
  111. package/src/utils/accessor.js +75 -0
  112. package/src/utils/agent.js +47 -0
  113. package/src/utils/data.js +92 -0
  114. package/src/utils/filter.js +266 -0
  115. package/src/utils/math.js +14 -0
  116. package/src/utils/options.js +48 -0
  117. package/src/utils/path.js +5 -0
  118. package/src/utils/resource.js +44 -0
  119. package/src/utils/route.js +53 -0
  120. package/src/utils/schema.js +1121 -0
  121. package/src/utils/type.js +81 -0
  122. package/src/utils/uid.js +15 -0
  123. package/src/utils/units.js +5 -0
  124. package/src/validators/_creditcard.js +6 -0
  125. package/src/validators/_decimals.js +11 -0
  126. package/src/validators/_domain.js +6 -0
  127. package/src/validators/_email.js +6 -0
  128. package/src/validators/_hostname.js +6 -0
  129. package/src/validators/_integer.js +6 -0
  130. package/src/validators/_max.js +6 -0
  131. package/src/validators/_min.js +6 -0
  132. package/src/validators/_password.js +5 -0
  133. package/src/validators/_range.js +6 -0
  134. package/src/validators/_required.js +9 -0
  135. package/src/validators/_url.js +6 -0
  136. package/src/validators/index.js +12 -0
  137. package/src/verbs.js +17 -0
  138. package/types/index.d.ts +3298 -0
  139. package/types/tests/admin.test-d.ts +27 -0
  140. package/types/tests/component-buttons.test-d.ts +44 -0
  141. package/types/tests/component-list.test-d.ts +159 -0
  142. package/types/tests/component-misc.test-d.ts +137 -0
  143. package/types/tests/component-object.test-d.ts +69 -0
  144. package/types/tests/component-section.test-d.ts +174 -0
  145. package/types/tests/component-select.test-d.ts +107 -0
  146. package/types/tests/components.test-d.ts +81 -0
  147. package/types/tests/context.test-d.ts +31 -0
  148. package/types/tests/fixtures.ts +24 -0
  149. package/types/tests/form.test-d.ts +109 -0
  150. package/types/tests/instance.test-d.ts +20 -0
  151. package/types/tests/schema-features.test-d.ts +402 -0
  152. package/types/tests/variance.test-d.ts +125 -0
  153. package/types/tests/view.test-d.ts +146 -0
@@ -0,0 +1,7 @@
1
+ (function(n,W){typeof exports=="object"&&typeof module<"u"?module.exports=W(require("vue"),require("vue-router"),require("@kyvg/vue3-notification"),require("@ditojs/utils"),require("tippy.js"),require("nanoid"),require("focus-trap"),require("sortablejs"),require("codeflask"),require("tinycolor2"),require("@lk77/vue3-color"),require("@ditojs/ui"),require("@tiptap/vue-3"),require("@tiptap/extension-document"),require("@tiptap/extension-text"),require("@tiptap/extension-bold"),require("@tiptap/extension-code"),require("@tiptap/extension-italic"),require("@tiptap/extension-link"),require("@tiptap/extension-strike"),require("@tiptap/extension-subscript"),require("@tiptap/extension-superscript"),require("@tiptap/extension-underline"),require("@tiptap/extension-blockquote"),require("@tiptap/extension-code-block"),require("@tiptap/extension-hard-break"),require("@tiptap/extension-heading"),require("@tiptap/extension-paragraph"),require("@tiptap/extension-horizontal-rule"),require("@tiptap/extension-ordered-list"),require("@tiptap/extension-bullet-list"),require("@tiptap/extension-list-item"),require("tiptap-footnotes"),require("@tiptap/extension-history"),require("vue-multiselect"),require("filesize-parser"),require("filesize"),require("vue-upload-component")):typeof define=="function"&&define.amd?define(["vue","vue-router","@kyvg/vue3-notification","@ditojs/utils","tippy.js","nanoid","focus-trap","sortablejs","codeflask","tinycolor2","@lk77/vue3-color","@ditojs/ui","@tiptap/vue-3","@tiptap/extension-document","@tiptap/extension-text","@tiptap/extension-bold","@tiptap/extension-code","@tiptap/extension-italic","@tiptap/extension-link","@tiptap/extension-strike","@tiptap/extension-subscript","@tiptap/extension-superscript","@tiptap/extension-underline","@tiptap/extension-blockquote","@tiptap/extension-code-block","@tiptap/extension-hard-break","@tiptap/extension-heading","@tiptap/extension-paragraph","@tiptap/extension-horizontal-rule","@tiptap/extension-ordered-list","@tiptap/extension-bullet-list","@tiptap/extension-list-item","tiptap-footnotes","@tiptap/extension-history","vue-multiselect","filesize-parser","filesize","vue-upload-component"],W):(n=typeof globalThis<"u"?globalThis:n||self,n["dito-admin"]=W(n.vue,n["vue-router"],n["@kyvg/vue3-notification"],n["@ditojs/utils"],n.tippy.js,n.nanoid,n["focus-trap"],n.sortablejs,n.codeflask,n.tinycolor2,n["@lk77/vue3-color"],n["@ditojs/ui"],n["@tiptap/vue-3"],n["@tiptap/extension-document"],n["@tiptap/extension-text"],n["@tiptap/extension-bold"],n["@tiptap/extension-code"],n["@tiptap/extension-italic"],n["@tiptap/extension-link"],n["@tiptap/extension-strike"],n["@tiptap/extension-subscript"],n["@tiptap/extension-superscript"],n["@tiptap/extension-underline"],n["@tiptap/extension-blockquote"],n["@tiptap/extension-code-block"],n["@tiptap/extension-hard-break"],n["@tiptap/extension-heading"],n["@tiptap/extension-paragraph"],n["@tiptap/extension-horizontal-rule"],n["@tiptap/extension-ordered-list"],n["@tiptap/extension-bullet-list"],n["@tiptap/extension-list-item"],n["tiptap-footnotes"],n["@tiptap/extension-history"],n["vue-multiselect"],n["filesize-parser"],n.filesize,n["vue-upload-component"]))})(this,(function(n,W,et,h,tt,Vn,Pn,En,Nn,Be,we,On,se,nt,Tn,Ln,Fn,In,Mn,Rn,jn,zn,An,qn,Un,Hn,Wn,Kn,Yn,Jn,Gn,Qn,Se,Xn,Zn,_n,xn,vn){"use strict";function eo(e=""){const t={},o=e.toLowerCase(),[s]=/(iphone|ipad|linux; android|darwin|win|mac|linux|freebsd|sunos)/.exec(o)||[],i={darwin:"mac",iphone:"ios",ipad:"ios","linux; android":"android"}[s]||s;return i&&(t.platform=i,t[i]=!0),o.replace(/(opera|chrome|safari|webkit|firefox|msie|trident)\/?\s*([.\d]+)(?:.*version\/([.\d]+))?(?:.*rv:v?([.\d]+))?/g,(a,r,l,d,c)=>{if(!t.chrome){const p=c||d||l;(!t.version||r!=="safari")&&(t.version=p,t.versionNumber=parseFloat(p)),t.browser=r,t[r]=!0}}),t.chrome&&delete t.webkit,t}const ot=n.reactive({title:"",routeComponents:[],user:null,agent:eo(navigator.userAgent||""),loadCache:{},activeLabel:null,clipboardData:null});function O(e,t){return e?`${e}/${t}`:t}function to(e){const t=h.parseDataPath(e);return t?.pop(),t}function Ve(e,t=!1){return t?to(e):h.parseDataPath(e)}function no(e,t=!1){return h.normalizeDataPath(Ve(e,t))}function st(e,t=!1){const o=Ve(e,t);if(o){let s;do s=o.pop();while(s!=null&&h.isInteger(+s));if(s!=null)return o}return null}function oo(e,t=!1){return h.normalizeDataPath(st(e,t))}function at(e,t,o=!1){const s=Ve(t,o);return s?h.getValueAtDataPath(e,s):null}function it(e,t,o=!1){const s=st(t,o);return s?h.getValueAtDataPath(e,s):null}function rt(e){const t=h.parseDataPath(e);return t[t.length-1]}function so(e){const t=rt(e);return t==null||h.isInteger(+t)?null:t}function Pe(e){const t=rt(e),o=t==null?null:+t;return h.isInteger(o)?o:null}let ao=0;function io(e,t="id"){e[t]=`@${++ao}`}function lt(e){return/^@/.test(e)}function ro(e,t="id"){return e?.[t]!=null&&Object.keys(e).length===1}const{hasOwnProperty:lo}=Object.prototype,Ee=new WeakMap;function dt(e){const t=n.toRaw(e);let o=t,s=null;do{if(s=Ee.get(o),s)break;o=Object.getPrototypeOf(o)}while(o);return s&&o!==t&&Ee.set(o,s),s}function D(e,t,o){const s=dt(e),i=t in s?s[t]:void 0;return i!==void 0||lo.call(s,t)?i:h.isFunction(o)?o():o}function ct(e,t,o){dt(e)[t]=o}class S{constructor(t,o){o=o?h.isFunction(o)?o():{...o}:{},o.nested??=!0,o.component=t;const s=Object.setPrototypeOf(o,t);Ee.set(this,s)}static get(t,o){return o instanceof S?o:new S(t,o)}extend(t){return Object.setPrototypeOf(t,this)}get nested(){return D(this,"nested",!0)}get schema(){return D(this,"schema",null)}get value(){return D(this,"value",()=>this.nested?h.getValueAtDataPath(this.rootItem,this.dataPath):void 0)}get dataPath(){return D(this,"dataPath","")}get name(){return D(this,"name",()=>so(this.dataPath))}get index(){return D(this,"index",()=>Pe(this.dataPath))}get itemDataPath(){return no(this.dataPath,this.nested)}get parentItemDataPath(){return oo(this.dataPath,this.nested)}get itemIndex(){return Pe(this.itemDataPath)}get parentItemIndex(){return Pe(this.parentItemDataPath)}get item(){return D(this,"data",()=>at(this.rootItem,this.dataPath,this.nested)||null)}get parentItem(){const t=it(this.rootItem,this.dataPath,this.nested)||null;return t!==this.item?t:null}get rootItem(){return D(this,"rootData",null)}get processedItem(){return D(this,"processedData",null)}get processedRootItem(){return D(this,"processedRootData",null)}get clipboardItem(){return D(this,"clipboardData",null)}get user(){return D(this,"user",null)}get api(){return D(this,"api",null)}get views(){return D(this,"views",null)}get flattenedViews(){return D(this,"flattenedViews",null)}get itemLabel(){return D(this,"itemLabel",null)}get formLabel(){return D(this,"formLabel",null)}get component(){return D(this,"component",null)}get schemaComponent(){return D(this,"schemaComponent",null)}get formComponent(){return D(this,"formComponent",null)}get viewComponent(){return D(this,"viewComponent",null)}get dialogComponent(){return D(this,"dialogComponent",null)}get panelComponent(){return D(this,"panelComponent",null)}get resourceComponent(){return D(this,"resourceComponent",null)}get sourceComponent(){return D(this,"sourceComponent",null)}get option(){return D(this,"option",void 0)}get options(){return D(this,"options",void 0)}get open(){return D(this,"open",void 0)}get searchTerm(){return D(this,"searchTerm",void 0)}get error(){return D(this,"error",void 0)}get wasNotified(){return D(this,"wasNotified",!1)}get isRunning(){return D(this,"isRunning",!1)}set isRunning(t){ct(this,"isRunning",t)}get query(){return this.component.$route.query}get request(){return t=>this.component.request(t)}get format(){return(t,o)=>this.component.format(t,o)}get navigate(){return t=>this.component.navigate(t)}get download(){return t=>this.component.download(t)}get getResourceUrl(){return t=>this.component.getResourceUrl(t)}get notify(){return t=>{this.component.notify(t),ct(this,"wasNotified",!0)}}}const co={data(){return{listeners:null}},methods:{on(e,t){if(h.isArray(e))for(const o of e)this.on(o,t);else if(h.isPlainObject(e))for(const o in e)this.on(o,e[o]);else{const o=this.listeners||=Object.create(null),{callbacks:s}=o[e]||={callbacks:[],queue:[]};s.push(t)}return this},once(e,t){const o=(...s)=>(this.off(e,o),t.apply(this,s));return o.callback=t,this.on(e,o)},off(e,t){if(!arguments.length)delete this.listeners;else if(h.isArray(e))for(const o of e)this.off(o,t);else if(h.isPlainObject(e))for(const o in e)this.off(o,e[o]);else{const o=this.listeners?.[e];if(o)if(!t)delete this.listeners[e];else{const{callbacks:s}=o,i=s.findIndex(a=>a===t||a.callback===t);i!==-1&&s.splice(i,1)}}return this},emit(e,...t){const o=this.listeners?.[e];if(o){const{queue:s,callbacks:i}=o;return new Promise(a=>{const r=async()=>{const l=s.shift();if(l){let d;const c=[];for(const p of i)try{const u=await p.apply(this,l.args);u!==void 0&&(d=u)}catch(u){c.push(u)}if(c.length>0){const p=new AggregateError(c,`Errors during event handler for '${e}'`);l.resolve(Promise.reject(p))}else l.resolve(d);r()}};s.push({args:t,resolve:a}),s.length===1&&r()})}return Promise.resolve()},hasListeners(e){if(h.isArray(e)){for(const t of e)if(!this.hasListeners(t))return!1;return e.length>0}else return!!this.listeners?.[e]},delegate(e,t){if(t)if(h.isArray(e))for(const o of e)this.delegate(o,t);else this.on(e,(...o)=>t.emit(e,...o));return this}}},ae={computed:{value:{get(){const e=Ft(this.schema,this.data,this.name,this.dataPath,{component:this}),{format:t}=this.schema;return t?t(new S(this,{value:e})):e},set(e){const{parse:t}=this.schema;t&&(e=t(new S(this,{value:e}))),this.parsedValue=e,this.data[this.name]=e}}}},L={computed:{context(){return new S(this,{nested:this.nested})},parentData(){const e=it(this.rootData,this.dataPath,this.nested);return e!==this.data?e:null},processedData(){return ht(this,this.dataPath,this.nested)},processedRootData(){return ht(this,"",!1)},item(){return this.data},parentItem(){return this.parentData},rootItem(){return this.rootData},processedItem(){return this.processedData},processedRootItem(){return this.processedRootData}}};function ht(e,t,o=!1){let{schemaComponent:s}=e;for(;s.dataPath.length>t.length;)s=s.parentSchemaComponent;return at(s.processedData,t.slice(s.dataPath.length),o)}const ho=Object.freeze(Object.defineProperty({__proto__:null,creditcard:{validate:e=>h.isCreditCard(e),message:"is invalid"},decimals:{validate:(e,t)=>{const o=t==="*"?"+":`{1,${t}}`;return new RegExp(`^[-+]?\\d*(\\.\\d${o})?$`).test(e)},message:(e,t)=>`must be numeric and may contain ${!t||t==="*"?"":t} decimal points`},domain:{validate:e=>h.isDomain(e),message:"is not a domain"},email:{validate:e=>h.isEmail(e),message:"must be a valid email"},hostname:{validate:e=>h.isHostname(e),message:"is not a host name"},integer:{validate:e=>h.isInteger(e),message:"must be whole number"},max:{validate:(e,t)=>e<=t,message(e,t){return`must be ${t} or less`}},min:{validate:(e,t)=>e>=t,message(e,t){return`must be ${t} or more`}},password:{validate:()=>!0},range:{validate:(e,[t,o])=>e>=t&&e<=o,message(e,[t,o]){return`must be between ${t} and ${o}`}},required:{validate:(e,t,{password:o})=>e!=null&&e!==""||o&&e===void 0,message:"is required"},url:{validate:e=>h.isUrl(e),message:"is not a valid URL"}},Symbol.toStringTag,{value:"Module"})),po={emits:["errors"],data(){return{isTouched:!1,isDirty:!1,isValidated:!1,isValid:!1,errors:null}},computed:{hasErrors(){return!!this.errors}},methods:{resetValidation(){this.isTouched=!1,this.isDirty=!1,this.isValidated=!1,this.isValid=!1,this.clearErrors()},validate(e=!0){let t=!0;e&&this.clearErrors();const{value:o}=this;for(const[s,i]of Object.entries(this.validations)){const a=ho[s];if(a&&(s==="required"||o!=null&&o!=="")){const{validate:r,message:l}=a;if(!r(o,i,this.validations)&&(t=!1,e)){const d=h.isFunction(l)?l(o,i,this):l;this.addError(d,!0)}}}return e&&(this.isValidated=!0,this.isValid=t),t},verify(){return this.validate(!1)},markTouched(){this.isTouched=!0,this.clearErrors()},markDirty(){this.isDirty=!0,this.isValidated=!1,this.isValid=!1,this.clearErrors()},addError(e,t=!1){this.errors||=[],t&&(e=`The ${this.label||this.placeholder||this.name} field ${e}.`),this.errors.push(e),this.$emit("errors",this.errors)},showValidationErrors(e,t){if(this.errors=[],e.length===0)return!1;for(const{message:o}of e)this.addError(o,!0);return t&&this.scrollIntoView(),!0},getErrors(){return this.errors?[...this.errors]:null},clearErrors(){this.errors=null,this.$emit("errors",this.errors)}}};function b(e,{type:t,default:o,get:s,set:i,callback:a=!0}={}){h.isString(e)&&e.includes(".")&&(e=h.parseDataPath(e));const r=h.normalizeDataPath(e);return{get(){const l=!s||s.length>0?this.overrides&&r in this.overrides?this.overrides[r]:this.getSchemaValue(e,{type:t,default:o,callback:a}):void 0;return s?s.call(this,l):l},set(l){i?i.call(this,l):(this.overrides||={},this.overrides[r]=l)}}}function Ne(e,{default:t,get:o,set:s}={}){return{get(){let i=this.getStore(e);return i===void 0&&t!==void 0&&(i=h.isFunction(t)?t.call(this):t,this[e]=i,this.getStore(e)),o?o.call(this,i):i},set(i){(!s||(i=s.call(this,i))!==void 0)&&this.setStore(e,i)}}}const Oe={mixins:[ae,L,po],emits:["update:component"],props:{schema:{type:Object,required:!0},dataPath:{type:String,required:!0},data:{type:[Object,Array],required:!0},meta:{type:Object,required:!0},store:{type:Object,required:!0},width:{type:[Number,String],default:null},label:{type:String,default:null},single:{type:Boolean,default:!1},nested:{type:Boolean,default:!0},accumulatedBasis:{type:Number,default:null}},data(){return{parsedValue:void 0,focused:!1}},computed:{name(){return this.schema.name},type(){return this.schema.type},labelNode(){const e=this.isMounted?this.$el.previousElementSibling:null;return e?.matches(".dito-label")?e:null},visible:b("visible",{type:Boolean,default(){return this.$options.defaultVisible}}),exclude:b("exclude",{type:Boolean,default:!1}),required:b("required",{type:Boolean,default:!1}),readonly:b("readonly",{type:Boolean,default:!1}),autofocus:b("autofocus",{type:Boolean,default:!1}),clearable:b("clearable",{type:Boolean,default:!1,get(e){return e&&!this.readonly}}),disabled:b("disabled",{type:Boolean,default:!1}),maxLength:b("maxLength",{type:Number}),placeholder:b("placeholder",{type:String}),autocomplete:b("autocomplete",{type:String}),info:b("info",{type:String,default:null}),inlineInfo(){return this.label?null:this.info},events(){const e=this.getEvents();for(const t of Object.keys(this.schema.events||{}))e[`on${h.camelize(t,!0)}`]??=()=>{this.emitEvent(t)};return e},attributes(){const{nativeField:e,textField:t}=this.$options,o={...this.events,disabled:this.disabled};return e&&(o.name=this.dataPath,this.label&&(o.title=this.label),o.readonly=this.readonly,o.autofocus=this.autofocus,t&&(o.maxlength=this.maxLength,o.placeholder=this.placeholder,o.autocomplete=this.autocomplete)),o},validations(){const e={...this.getValidations()};this.required&&(e.required=!0);for(const[t,o]of Object.entries(this.schema.rules||{}))o===void 0?delete e[t]:e[t]=o;return e},showClearButton(){return this.clearable&&this.value!=null}},created(){this._register(!0),this.setupSchemaFields()},unmounted(){this._register(!1)},methods:{_register(e){this.$emit("update:component",e?this:null),this.nested&&this.schemaComponent._registerComponent(this,e)},getEvents(){const{onFocus:e,onBlur:t,onInput:o,onChange:s}=this;return{onFocus:e,onBlur:t,onInput:o,onChange:s}},getValidations(){return null},async scrollIntoView(){await this.focusSchema(),this.getFocusElement()?.scrollIntoView?.({behavior:"smooth",block:"center"})},focusElement(){this.getFocusElement()?.focus?.()},blurElement(){this.getFocusElement()?.blur?.()},getFocusElement(){const e=h.asArray(this.$refs.element)[0]??this;return e.$el??e},async focusSchema(){await this.schemaComponent.focus(),await this.tabComponent?.focus()},async focus(){await this.focusSchema(),this.scrollIntoView(),this.focusElement()},blur(){this.blurElement()},clear(){this.value=null,this.blur(),this.onChange()},onFocus(){this.focused=!0,this.markTouched(),this.emitEvent("focus")},onBlur(){this.focused=!1,this.validate(),this.emitEvent("blur")},onInput(){this.markDirty(),this.emitEvent("input")},onChange(){this.markDirty(),this.emitEvent("change",{context:{value:this.parsedValue!==void 0?this.parsedValue:this.value},parent:this.schemaComponent})}}},pt=new WeakMap;let uo=0;function mo(e,t=null){const o=n.toRaw(e);let s=pt.get(o);return!s&&e&&(s=t?.(e)||`@${++uo}`,pt.set(o,s)),s}class fo{graph={};references={};set(t,o,s){t=h.parseDataPath(t);let i=this.graph;for(const a of t){const r=h.isInteger(+a)?"*":a;i=i[r]??={}}i.$settings={...s,...i.$settings,...o}}addSource(t,o){this.set(t,{type:"source",schema:o},{related:!1})}setSourceRelated(t){this.set(t,{related:!0,reference:this.getReferencePrefix(t)})}addRelation(t,o,s){this.set(t,{type:"relation",schema:s,internal:!!o,reference:this.getReferencePrefix(o)})}getReferencePrefix(t){return t?this.references[t]??=Vn.nanoid(6):null}flatten(){const t=o=>{const s=[];for(const[i,{$settings:a,...r}]of Object.entries(o)){a&&s.push([i,a]);for(const[l,d]of t(r))s.push([`${i}/${l}`,d])}return s};return t(this.graph)}process(t,o,{target:s}){const i=s==="clipboard";i&&delete o[t.idKey||"id"];for(const[a,r]of this.flatten()){const{type:l,schema:d,internal:c,related:p,reference:u}=r,m=l==="source",f=l==="relation";if(m||f&&c){const g=h.getValueAtDataPath(o,a,()=>null),k=i&&m&&!p,V=i&&(f&&c||m&&p);for(const w of h.asArray(g).flat()){const $=m&&d.idKey||f&&d.relateBy||"id";let P=w?.[$];if(P!=null&&(k&&delete w[$],V||lt(P))){lt(P)&&(P=P.slice(1));const N=i?$:m?"#id":"#ref",z=i?`@${P}`:u?`${u}-${P}`:P;w[N]=z,N!==$&&delete w[$]}}}}return o}}const go={Boolean:h.isBoolean,Number:h.isNumber,String:h.isString,Date:h.isDate,Array:h.isArray,Object:h.isObject,RegExp:h.isRegExp,Function:h.isFunction},bo={Boolean:e=>!!e,Number:e=>+e,String:e=>String(e),Date:e=>h.isDate(e)?e:new Date(e),Array:e=>h.isArray(e)?e:h.isString(e)?e.split(","):h.asArray(e),Object:e=>h.isObject(e)?e:e===!0?{}:null,RegExp:e=>h.isRegExp(e)?e:new RegExp(e)};function Te(e,t){if(e&&t!=null){for(const o of e)if(go[o.name]?.(t))return!0}return!1}function yo(e,t){const o=e&&bo[e.name||e];return o?o(t):t}const ut={},mt={},ft={};function ko(e,t){ut[e]=t}function ie(e,t=!1){const o=ut[e]||null;if(!o&&!t&&!mt[e])throw mt[e]=!0,new Error(`Unknown Dito.js component type: '${e}'`);return o}function gt(e,t){for(const o of e)if(Me(o)){const s=t(o.component,o.name,0);if(s!==void 0)return s}else if(R(o))for(const[s,i]of Object.entries(o.components||{})){const a=t(i,s,1);if(a!==void 0)return a}}function re(e,t){return e?gt([e,...At(e)],t):void 0}function Co(e,t){return re(e,o=>t(o)?o:void 0)??null}function Le(e,t){return re(e,o=>t(o)?!0:void 0)??!1}function $o(e){return Le(e,()=>!0)??!1}function R(e){return h.isObject(e)&&h.isString(e.type)}function Do(e){return R(e)&&e.type==="form"}function bt(e){return R(e)&&e.type==="view"}function Bo(e){return R(e)&&e.type==="tab"}function wo(e){return R(e)&&e.type==="panel"}function Fe(e){return R(e)&&e.type==="menu"}function le(e){return JSON.stringify(e)}const Ie=new WeakMap;async function A(e,t=!1){if(Ie.has(e))return Ie.get(e);let o=e;if(h.isFunction(o)&&(o=o()),h.isPromise(o)&&(o=await o),h.isModule(o)&&(o={...o},!o.name&&(t||o.default))){const s=Object.keys(o).filter(i=>i!=="_rerender_only");if(s.length===1){const i=s[0];o=o[i],i!=="default"&&(o={...o,name:i})}}return Ie.set(e,o),o}async function _(e,t=A){let o=h.isFunction(e)?e():e;return o=await A(o,!1),h.isArray(o)?o=Object.fromEntries(await h.mapConcurrently(o,async s=>{const i=await t(s,!0);return[i.name,i]})):h.isObject(o)&&(o=Object.fromEntries(await h.mapConcurrently(Object.entries(o),async([s,i])=>{const a=await t(i,!0);return[s,a]}))),o}async function So(e){return _(e,async(t,o)=>(t=await A(t,o),!t.name&&Fe(t)&&(t={...t,name:h.camelize(t.label),items:await _(t.items)}),t))}function Vo(e){return Object.fromEntries(Object.entries(e).reduce((t,[o,s])=>(Fe(s)?t.push(...Object.entries(s.items)):t.push([o,s]),t),[]))}async function de(e){let{component:t}=e;t&&(t=await A(t,!0),t&&(e.component=n.markRaw({...t,mixins:[Ht,Oe,...t.mixins||[]]})))}async function yt(e){await h.mapConcurrently(Object.values(e||{}),de)}const kt=new WeakMap;function x(e,t,o=null,s=0,i=1){if(t){const a=kt.get(t)??0;if(a<i){kt.set(t,a+1);const r=[],l=(d,c,p)=>{r.push(Po(e,d,c,o,s+p))};return re(t,l),gt(He(t),l),Promise.all(r)}}}function Po(e,t,o,s=null,i=0){return K(e,t),Promise.all([h.mapConcurrently(He(t),a=>x(e,a,s,i)),T(t)?.processSchema?.(e,t,o,s,i)])}async function Ct(e,t,o,s,i=""){K(t,o),Dt(t,o,s,i);let a=[];if(bt(o))await Bt(t,o),await x(t,o,a);else if(Fe(o))a=await Promise.all(Object.entries(o.items).map(async([r,l])=>Ct(e,t,l,r,o.fullPath)));else throw new Error(`Invalid view schema: '${le(o)}'`);return{path:o.fullPath,children:a,component:e,meta:{api:t,schema:o}}}function K(e,t){let o=e.defaults[t.type]||e.defaults[h.camelize(t.type)];if(o&&(h.isFunction(o)&&(o=o(t)),h.isObject(o)))for(const[s,i]of Object.entries(o))t[s]===void 0?t[s]=i:t[s]=h.assignDeeply(t[s],i)}function $t(e,t){re(t,o=>{K(e,o);const s=Y(o);for(const i of Object.values(s))$t(e,i)})}function Dt(e,t,o,s=null){t.name??=o,t.path??=e.normalizePath(o),s!==null&&(t.fullPath=`${s}/${t.path}`)}async function Eo(e,t,o){const s=[],{form:i,forms:a,components:r,maxDepth:l=1}=t;return a?t.forms=await _(a,d=>ce(e,d,s,o,l)):i?t.form=await ce(e,i,s,o,l):h.isObject(r)&&await ce(e,{type:"form",components:r},s,o,l),s}async function ce(e,t,o=null,s=0,i=1){if(t=await A(t,!0),!Do(t))throw new Error(`Invalid form schema: '${le(t)}'`);return K(e,t),await Bt(e,t),await x(e,t,o,s,i),t}async function No(e,t){if(t=await A(t,!0),!Bo(t))throw new Error(`Invalid tab schema: '${le(t)}'`);return K(e,t),t}async function Oo(e,t){if(t=await A(t,!0),!wo(t))throw new Error(`Invalid panel schema: '${le(t)}'`);return K(e,t),t}async function Bt(e,t){const{tabs:o,panels:s}=t;o&&(t.tabs=await _(o,i=>No(e,i))),s&&(t.panels=await _(s,i=>Oo(e,i)))}function q(e){return R(e)&&h.isObject(e.form||e.forms||e.components)}function To(e){return R(e)&&Object.keys(e?.forms||{}).length>1}function Me(e){return bt(e)&&h.isObject(e.component)}function wt(e,t){const{view:o}=e,s=o&&t.flattenedViews[o];return s&&Co(s,q)||null}function Re(e,t){return wt(e,t)?t.flattenedViews[e.view]:null}function Lo(e,t){return!!Re(e,t)}function St(e,t){const o=Re(e,t);return o?Me(o)?o.fullPath:`${o.fullPath}/${o.path}`:null}function Vt(e,t,o){const s=St(e,o);return s?`${s}/${t}`:null}function Y(e,t,o){const s=t&&wt(e,t);if(s)e=s;else if(e.view)throw new Error(`Unknown view: '${e.view}'`);let{form:i,forms:a}=e;if(!i&&!a){const{name:r,compact:l,clipboard:d,tabs:c,components:p}=e;if(p||c)i={type:"form",name:r,compact:l,clipboard:d,tabs:c,components:p};else return{}}return a||={default:i},Object.fromEntries(Object.entries(a).map(([r,l])=>(t&&h.isFunction(l.components)&&(l=n.reactive({...l,components:l.components(t)}),ce(t.api,l).catch(console.error)),[r,o?.(l)??l])))}function Pt(e,t){return e[t?.type]||e.default||null}function je(e,t,o){return Pt(Y(e,o),t)||ft}function Fo(e){return e===ft}function Et(e){return!!e.compact}function ze(e){return!!(e.inlined||e.components)}function Ae(e){return!!(e.nested||T(e)?.defaultNested===!0)}function Io(e,t){const{label:o}=e;return o!==!1&&(!!o||t&&T(e)?.generateLabel)}function Mo(e){return!!T(e)?.omitSpacing}function Nt(e,{type:t,schema:o,callback:s=!0,default:i,context:a}={}){const r=t&&h.asArray(t);let l=o?h.isArray(e)?h.getValueAtDataPath(o,e,()=>{}):o[e]:void 0;if(l===void 0&&i!==void 0)return s&&h.isFunction(i)&&!Te(r,i)&&(i=i(a)),i;if(Te(r,l))return l;if(s&&h.isFunction(l)&&(l=l(a)),r&&l!=null&&!Te(r,l))for(const d of r){const c=yo(d,l);if(c!==l)return c}return l}function qe(e,t){return Nt("if",{type:Boolean,schema:e,context:t,default:!0})&&(!$o(e)||Le(e,o=>qe(o,t)))}function J(e){return h.isFunction(e)?e():e}function Ue(e,t){const o=e.default!==void 0?e.default:T(e)?.defaultValue;return h.isFunction(o)?o(J(t)):h.clone(o)}function Ro(e,t){const o=e.exclude!==void 0?e.exclude:T(e)?.excludeValue;return h.isFunction(o)?o(J(t)):!!o}function Ot(e,t){return!!T(e)?.ignoreMissingValue?.(J(t))}function Tt(e){return e.multiple??!!T(e)?.defaultMultiple}function Lt(e,t={},o){const s={component:o,rootData:t};return he(e,t,null,null,(a,r,l,d)=>{const c=()=>new S(o,{schema:a,name:l,data:r,dataPath:d,rootData:s.rootData});!(l in r)&&!Ot(a,c)&&(r[l]=Ue(a,c))},null,s)}function Ft(e,t,o,s,{component:i=null,rootData:a=i?.rootData}={}){const r=()=>new S(i,{schema:e,value:t[o],name:o,data:t,dataPath:s,rootData:a}),{compute:l}=e;if(l){const d=l(J(r));d!==void 0&&(t[o]=d)}return!(o in t)&&!Ot(e,r)&&(t[o]=Ue(e,r)),t[o]}function It(e,t,o){if(o.schemaOnly){const s={},{idKey:i="id",orderKey:a}=e,r=t[i];return r!==void 0&&(s[i]=r),To(e)&&(s.type=t.type),a&&(s[a]=t[a]),s}else return{...t}}function jo(e,t,o,s,{component:i,rootData:a,schemaOnly:r,target:l}={}){const d={component:i,rootData:a,schemaOnly:r,target:l},c=It(t,o,d),p=new fo;return he(e,o,s,c,(f,g,k,V,w)=>{let $=Ft(f,g,k,V,d);if(h.isArray($)){const{wrapPrimitives:P}=f;P?$=$.map(N=>({[P]:N})):$=[...$]}w[k]=$},(f,g,k,V,w)=>{const{wrapPrimitives:$,process:P}=f;let N=w[k];const z=()=>new S(i,{schema:f,value:N,name:k,data:g,dataPath:V,rootData:d.rootData,processedData:w});$&&h.isArray(N)&&(N=N.map(Dh=>Dh[$]));const De=T(f)?.processValue;De&&(N=De(J(z),p)),P&&(N=P(J(z))),Ro(f,z)?delete w[k]:w[k]=N},d),p.process(t,c,d)}function he(e,t,o,s,i,a,r){const l=d=>{const c=(p,u)=>p!=null?O(p,u):null;if(d)for(const[p,u]of Object.entries(d))if(!Ae(u))he(u,t,o,s,i,a,r);else{const m=c(o,p),f=(k,V=null)=>{const w=V!==null?c(m,V):m,$=new S(r.component,{schema:u,data:t,dataPath:m,name:p,rootData:r.rootData}),N=(T(u)?.getFormSchemasForProcessing||Y)(u,$),z=Pt(N,k);if(z){const De=s?It(u,k,r):null;return he(z,k,w,De,i,a,r)}else return{...k}};i?.(u,t,p,m,s);let g=s?s[p]:t[p];g!=null&&q(u)&&(h.isArray(g)?g=s?g.map(f):g.forEach(f):g=f(g),s&&(s[p]=g)),a?.(u,t,p,m,s)}};l(e.components);for(const d of At(e))l(d.components);for(const d of He(e))l(d.components);return s||t}function G(e,t){const o=(s,i)=>s.length>0?s.reduce((a,r)=>{const l=i(r);return l&&(a[l.name]=l&&t?{...t,...l}:l),a},{}):null;return h.isArray(e)?o(e,s=>h.isObject(s)?s:{name:h.camelize(s,!1)}):h.isObject(e)?o(Object.entries(e),([s,i])=>h.isObject(i)?{name:s,...i}:h.isString(i)?{name:s,label:i}:null):null}function v(e){return G(e,{type:"button"})}function Mt(e){return h.isObject(e)?e.type:e}function T(e){return ie(Mt(e),!0)??null}function Rt(e){return T(e)?.getSourceType?.(Mt(e))??null}function jt(e,t=null,o=null){return e?{schema:e,dataPath:t!=null&&e.name?O(t,e.name):t,tabComponent:o}:null}function zt(e,t,o=null,s=[]){if(e)for(const[i,a]of Object.entries(e)){const r=jt(a,O(t,i),o);r&&s.push(r)}return s}function At(e){return e?.tabs?Object.values(e.tabs):[]}function He(e){return e?.panels?Object.values(e.panels):[]}function zo(e,t,o,s=null,i=null){const a=T(t)?.getPanelSchema?.(e,t,o,s),r=a?[jt(a,o,i)]:[];return zt(t?.panels,o,i,r),r}function ee(e){return Rt(e)==="object"}function te(e){return Rt(e)==="list"}function qt(e,t){const o=t[e.idKey||"id"];return o!=null?String(o):void 0}function Ao(e,t){return mo(t,o=>qt(e,o))}function Ut(e){return!!F(e.resource)}function F(e,t={}){const{parent:o,...s}=t;return h.isFunction(e)&&(e=e(t)),e=h.isObject(e)?{...s,...e}:h.isString(e)?{...s,path:e}:null,e&&o!==void 0&&e.parent===void 0&&!e.path?.startsWith("/")&&(e.parent=o,e.path||(e.path=".")),e}function We(e,t){return e!=null&&t?.type==="collection"?{type:"member",...h.pickBy(t,(o,s)=>["method","path","parent"].includes(s)),id:`${e}`}:null}const Ht={mixins:[co],inject:["api","$verbs","$views","$isPopulated","$parentComponent","$schemaComponent","$routeComponent","$dataComponent","$sourceComponent","$resourceComponent","$dialogComponent","$panelComponent","$tabComponent"],provide(){const e=()=>this;return this.providesData?{$parentComponent:e,$dataComponent:e}:{$parentComponent:e}},data(){return{appState:ot,isMounted:!1,overrides:null}},computed:{providesData(){return!1},sourceSchema(){return this.meta?.schema},user(){return ot.user},verbs(){return this.$verbs()},views(){return this.$views()},flattenedViews(){return Vo(this.views)},isPopulated(){return this.$isPopulated()},locale(){return this.api.locale},context(){return new S(this,{nested:!1})},rootComponent(){return this.$root.$refs.root},parentComponent(){return this.$parentComponent()},schemaComponent(){return this.$schemaComponent()},routeComponent(){return this.$routeComponent()},formComponent(){const e=this.routeComponent;return e?.isForm?e:null},viewComponent(){const e=this.routeComponent;return e?.isView?e:null},dataComponent(){return this.providesData?this:this.$dataComponent()},sourceComponent(){return this.$sourceComponent()},resourceComponent(){return this.$resourceComponent()},dialogComponent(){return this.$dialogComponent()},panelComponent(){return this.$panelComponent()},tabComponent(){return this.$tabComponent()},parentSchemaComponent(){return pe(this,"schemaComponent")},parentRouteComponent(){return pe(this,"routeComponent")},parentFormComponent(){return pe(this,"formComponent")},parentResourceComponent(){return pe(this,"resourceComponent")},rootData(){return this.dataComponent?.data}},mounted(){this.isMounted=!0},beforeCreate(){const e=qo++;Object.defineProperty(this,"$uid",{get:()=>e})},methods:{labelize:h.labelize,getStore(e){return this.store[e]},setStore(e,t){return this.store[e]=t,t},removeStore(e){delete this.store[e]},getStoreKeyByIndex(e){return this.store.$keysByIndex?.[e]},setStoreKeyByIndex(e,t){this.store.$keysByIndex??={},this.store.$keysByIndex[e]=t},getChildStore(e,t){let o=this.getStore(e);if(!o&&t!=null){const s=this.getStoreKeyByIndex(t);o=this.getStore(s),o&&(this.setStore(e,o),this.removeStore(s))}return o||(o=this.setStore(e,n.reactive({}))),t!=null&&this.setStoreKeyByIndex(t,e),o},removeChildStore(e,t){this.getChildStore(e,t),this.removeStore(e)},getSchemaValue(e,{type:t,default:o,schema:s=this.schema,context:i=this.context,callback:a=!0}={}){return Nt(e,{type:t,schema:s,context:i,callback:a,default:h.isFunction(o)?()=>o.call(this):o})},getLabel(e,t){return e?this.getSchemaValue("label",{schema:e,type:[String,Object]})||h.labelize(t||e.name):h.labelize(t)||""},getButtonAttributes(e){return{class:`dito-button--${e}`,title:h.labelize(e)}},getQueryLink(e){return{query:e,hash:this.$route.hash}},shouldRenderSchema(e=null){return qe(e,this.context)},shouldShowSchema(e=null){return this.getSchemaValue("visible",{type:Boolean,default:!0,schema:e})},shouldDisableSchema(e=null){return this.getSchemaValue("disabled",{type:Boolean,default:!1,schema:e})},getResourcePath(e){return e=F(e,{parent:this.dataComponent?.getResource({method:e?.method,child:e})??null}),this.api.resources.any(e)},getResourceUrl(e){const t=this.getResourcePath(e);return t?this.api.getApiUrl({url:t,query:e.query}):null},async sendRequest({method:e,url:t,resource:o,query:s,data:i,signal:a,internal:r}){t||=this.getResourceUrl(o),e||=o?.method;const l=!r&&this.api.isApiUrl(t);l&&await this.rootComponent.ensureUser();const d=await this.api.request({method:e,url:t,query:s,data:i,signal:a});return l&&e==="patch"&&h.equals(o,We(this.user.id,this.api.users))&&await this.rootComponent.fetchUser(),d},showDialog({components:e,buttons:t,data:o,settings:s}){return this.rootComponent.showDialog({components:e,buttons:t,data:o,settings:s})},request({cache:e,...t}){const s=(e&&{global:this.appState,local:this.dataComponent}[e])?.loadCache,i=s&&`${t.method||"get"} ${t.url} ${JSON.stringify(t.query||"")} ${JSON.stringify(t.data||"")}`;if(s&&i in s)return s[i];const a=this.sendRequest(t).then(r=>r.data).catch(r=>{const l=r.response?.data;throw l?Object.assign(new Error(l.message),l):r});return s&&(s[i]=a),a},format(e,{locale:t=this.api.locale,defaults:o=this.api.formats,...s}={}){return h.format(e,{locale:t,defaults:o,...s})},async navigate(e){return this.$router.push(e)},download(e={}){h.isString(e)&&(e={url:e});const t=document.createElement("a");t.href=e.url?.startsWith("blob:")?e.url:this.api.getApiUrl(e),t.download=e.filename??null;const{body:o}=document;o.appendChild(t),t.click(),o.removeChild(t)},notify(e){this.rootComponent.notify(e)},closeNotifications(){this.rootComponent.closeNotifications()},setupSchemaFields(){this.setupMethods(),this.setupComputed(),this.setupEvents()},setupMethods(){for(const[e,t]of Object.entries(this.schema.methods||{}))h.isFunction(t)?this[e]=t:console.error(`Invalid method definition: ${e}: ${t}`)},setupComputed(){const e=({get:t,set:o})=>{const s=n.computed(()=>t.call(this));return{get:()=>s.value,set:o?i=>o.call(this,i):void 0}};for(const[t,o]of Object.entries(this.schema.computed||{})){const s=h.isFunction(o)?e({get:o}):h.isObject(o)&&h.isFunction(o.get)?e(o):null;s?Object.defineProperty(this,t,s):console.error(`Invalid computed property definition: ${t}: ${o}`)}},setupEvents(){const{watch:e,events:t}=this.schema;if(e){const s=h.isFunction(e)?e.call(this):e;h.isObject(s)&&this.$nextTick(()=>{for(const[i,a]of Object.entries(s)){const r=this.schemaComponent.getComponentByName(i)?`data.${i}`:i;this.$watch(r,a)}})}const o=(s,i,a)=>{h.isFunction(a)?this.on(h.hyphenate(i),a):console.error(`Invalid event definition: ${s}: ${a}`)};if(t)for(const[s,i]of Object.entries(t))o(s,s,i);for(const[s,i]of Object.entries(this.schema))/^on[A-Z]/.test(s)&&o(s,s.slice(2),i)},emitEvent(e,{context:t=null,parent:o=null}={}){const s=this.hasListeners(e),i=o?.hasListeners(e);if(s||i){const a=d=>d.emit(e,t=S.get(this,t)),r=d=>i&&d!==!1?a(o).then(()=>d):d,l=()=>s?a(this).then(r):r(void 0);return["load","change"].includes(e)?this.$nextTick(l):l()}},emitSchemaEvent(e,t){return this.schemaComponent.emitEvent(e,t)}}};let qo=0;function pe(e,t){const o=e[t];let s=e.parentComponent;for(;s&&s[t]===o;)s=s.parentComponent;return s?.[t]??null}function Uo(e){const{mixins:t}=e;return t||e.extends?Ke({...e},e):e}function Ke(e,t){if(t.extends&&Ke(e,t.extends),t.mixins)for(const o of t.mixins)Ke(e,o);for(const o of Ho)o in t&&(e[o]=t[o]);return e}const Ho=["defaultValue","defaultNested","defaultVisible","generateLabel","excludeValue","ignoreMissingValue","omitSpacing","processValue","processSchema","getPanelSchema","getFormSchemasForProcessing","beforeRouteUpdate","beforeRouteLeave"],ue={},C={mixins:[Ht],components:ue,component(e,t){if(t&&(h.isPlainObject(t)&&(t=Uo({extends:this,name:e,...t})),ue[e]=t),!(e in ue))throw new Error(`Component "${e}" not registered`);return ue[e]},methods:{getTypeComponent:ie}};function Wt(e){return e&&h.asArray(e).some(t=>t.type!==n.Comment)}function ne(e,t={}){return e=h.isString(e)?n.useSlots()[e]:e,Wt(e?.(t))}const Wo=["type","title","disabled"],Ko={key:0,class:"dito-button__prefix"},Yo={key:1,class:"dito-button__text"},Jo={key:2,class:"dito-button__suffix"};function Go(e,t,o,s,i,a){return n.openBlock(),n.createElementBlock("button",n.mergeProps({class:["dito-button",[a.classes,{"dito-button--affixed":a.hasAffixes}]],type:o.type,title:o.title,disabled:o.disabled},a.attributes),[a.hasAffixes?(n.openBlock(),n.createElementBlock("div",Ko,[n.renderSlot(e.$slots,"prefix")])):n.createCommentVNode("",!0),o.text||a.hasAffixes?(n.openBlock(),n.createElementBlock("div",Yo,[n.createTextVNode(n.toDisplayString(o.text||""),1),n.renderSlot(e.$slots,"default")])):n.createCommentVNode("",!0),a.hasAffixes?(n.openBlock(),n.createElementBlock("div",Jo,[n.renderSlot(e.$slots,"suffix")])):n.createCommentVNode("",!0)],16,Wo)}const y=(e,t)=>{const o=e.__vccOpts||e;for(const[s,i]of t)o[s]=i;return o},Qo=y({inheritAttrs:!1,props:{type:{type:String,default:"button"},text:{type:String,default:null},title:{type:String,default:null},disabled:{type:Boolean,default:!1}},computed:{hasAffixes(){return ne(this.$slots.prefix)||ne(this.$slots.suffix)},classes(){return this.$attrs.class},attributes(){const{class:e,...t}=this.$attrs;return t}}},[["render",Go]]);function Kt(e){return{year:e?.getFullYear()??0,month:e?.getMonth()??0,day:e?.getDate()??0,hour:e?.getHours()??0,minute:e?.getMinutes()??0,second:e?.getSeconds()??0,millisecond:e?.getMilliseconds()??0}}function me(e,t={}){return new Date(...Object.values({...Kt(e),...t}))}function Ye(e,{locale:t="en-US",date:o=!0,time:s=!0}={}){const i=s?null:0;let[a,r,l,d,c,,p=i,,u=i,,m=i,,f=i]=Jt(e,{date:o,time:s});if(c&&c.length>=4){t==="en-US"&&r==="/"&&d==="/"&&([a,l]=[l,a]),l=Xo(l,{locale:t});const g=k=>k===null||k.length===2;if(l!==null&&(!s||g(p)&&g(u)&&g(m)))return new Date(+c,+l,+a,+p,+u,+m,+f)}return null}function Yt(e,t,{locale:o="en-US",date:s=!0,time:i=!0}={}){const a=Jt(e,{date:s,time:i}),r=(u,m=a.length)=>{let f=0,g=0;for(;(u===null||f<=u)&&g<m;)f+=a[g++]?.length??0;return{position:f,index:g}},l=s?0:r(null,6).position;t+=l;let{index:d}=r(t);const c=o==="en-US",p=[c?"month":"day",null,c?"day":"month",null,"year",null,"hour",null,"minute",null,"second",null,"millisecond"];for(;d--;)if(p[d]){const u=r(null,d).position-l,m=u+a[d].length;return{name:p[d],start:u,end:m}}return null}function Jt(e,{date:t=!0,time:o=!0}={}){const s=e?.split(/([\s.,:/]+)/)||[];return t||s.unshift("1",".","1",".","2000"," "),!o&&s.length>5&&(s.length=5),s}function Xo(e,{locale:t="en-US"}={}){const o=+e;if(!isNaN(o))return o-1;const s=e.trim().toLowerCase();if(s.length<3)return null;const i=new Intl.DateTimeFormat(t,{month:"short"}),a=new Intl.DateTimeFormat(t,{month:"long"});for(let r=0;r<12;r++){const l=new Date(2e3,r,1);if(i.format(l).toLowerCase().startsWith(s)||a.format(l).toLowerCase().startsWith(s))return r}return null}const Zo={class:"dito-calendar"},_o={class:"dito-calendar-popup"},xo={class:"dito-calendar-inner"},vo={class:"dito-calendar-header"},es={class:"dito-calendar-body"},ts={class:"dito-calendar-weekdays"},ns={class:"dito-calendar-dates"},os=["onClick"],ss={class:"dito-calendar-footer"},as=["title"],is={class:"dito-calendar-header"},rs={class:"dito-calendar-body"},ls={class:"dito-calendar-months"},ds=["onClick"],cs={class:"dito-calendar-header"},hs={class:"dito-calendar-body"},ps={class:"dito-calendar-years"},us=["onClick"];function ms(e,t,o,s,i,a){return n.openBlock(),n.createElementBlock("div",Zo,[n.createElementVNode("div",_o,[n.createElementVNode("div",xo,[i.currentMode==="day"?(n.openBlock(),n.createElementBlock(n.Fragment,{key:0},[n.createElementVNode("div",vo,[n.createElementVNode("a",{class:"dito-calendar-step-prev dito-calendar-step-year",onClick:t[0]||(t[0]=r=>a.stepYear(-1))}),n.createElementVNode("a",{class:"dito-calendar-step-prev dito-calendar-step-month",onClick:t[1]||(t[1]=r=>a.stepMonth(-1))}),n.createElementVNode("span",null,[n.createElementVNode("a",{class:"dito-calendar-select-year",onClick:t[2]||(t[2]=r=>a.setMode("year"))},n.toDisplayString(a.dateToString(i.currentValue,{year:!0})),1),n.createElementVNode("a",{class:"dito-calendar-select-month",onClick:t[3]||(t[3]=r=>a.setMode("month"))},n.toDisplayString(a.dateToString(i.currentValue,{month:!0})),1)]),n.createElementVNode("a",{class:"dito-calendar-step-next dito-calendar-step-month",onClick:t[4]||(t[4]=r=>a.stepMonth(1))}),n.createElementVNode("a",{class:"dito-calendar-step-next dito-calendar-step-year",onClick:t[5]||(t[5]=r=>a.stepYear(1))})]),n.createElementVNode("div",es,[n.createElementVNode("div",ts,[(n.openBlock(!0),n.createElementBlock(n.Fragment,null,n.renderList(i.weekdayNames,r=>(n.openBlock(),n.createElementBlock("span",null,n.toDisplayString(r.short),1))),256))]),n.createElementVNode("div",ns,[(n.openBlock(!0),n.createElementBlock(n.Fragment,null,n.renderList(i.dateRange,r=>(n.openBlock(),n.createElementBlock("span",{class:n.normalizeClass(r.state&&`dito-calendar-item-${r.state}`),onClick:l=>r.state!=="disabled"&&a.selectDate(r.date)},n.toDisplayString(r.text),11,os))),256))])]),n.createElementVNode("div",ss,[n.createElementVNode("a",{class:"dito-calendar-select-now",role:"button",title:a.dateToString(new Date),onClick:t[6]||(t[6]=r=>a.selectDate(new Date))},null,8,as)])],64)):i.currentMode==="month"?(n.openBlock(),n.createElementBlock(n.Fragment,{key:1},[n.createElementVNode("div",is,[n.createElementVNode("a",{class:"dito-calendar-step-prev",onClick:t[7]||(t[7]=r=>a.stepYear(-1))}),n.createElementVNode("span",null,[n.createElementVNode("a",{class:"dito-calendar-select-year",onClick:t[8]||(t[8]=r=>a.setMode("year"))},n.toDisplayString(a.dateToString(i.currentValue,{year:!0})),1)]),n.createElementVNode("a",{class:"dito-calendar-step-next",onClick:t[9]||(t[9]=r=>a.stepYear(1))})]),n.createElementVNode("div",rs,[n.createElementVNode("div",ls,[(n.openBlock(!0),n.createElementBlock(n.Fragment,null,n.renderList(i.monthNames,(r,l)=>(n.openBlock(),n.createElementBlock("span",{class:n.normalizeClass(a.getMonthClass(l)),onClick:d=>a.selectMonth(l)},n.toDisplayString(r.short),11,ds))),256))])])],64)):i.currentMode==="year"?(n.openBlock(),n.createElementBlock(n.Fragment,{key:2},[n.createElementVNode("div",cs,[n.createElementVNode("a",{class:"dito-calendar-step-prev",onClick:t[10]||(t[10]=r=>a.stepDecade(-1))}),n.createElementVNode("span",null,n.toDisplayString(a.decadeToString(i.currentValue)),1),n.createElementVNode("a",{class:"dito-calendar-step-next",onClick:t[11]||(t[11]=r=>a.stepDecade(1))})]),n.createElementVNode("div",hs,[n.createElementVNode("div",ps,[(n.openBlock(!0),n.createElementBlock(n.Fragment,null,n.renderList(i.yearRange,r=>(n.openBlock(),n.createElementBlock("span",{class:n.normalizeClass(a.getYearClass(r)),onClick:l=>a.selectYear(r)},n.toDisplayString(r),11,us))),256))])])],64)):n.createCommentVNode("",!0)])])])}const fs={emits:["update:modelValue","select"],props:{modelValue:{type:Date,default:null},locale:{type:String,default:"en-US"},disabledDate:{type:Function,default:()=>!1},mode:{type:String,default:"day"}},data(){const{weekdayNames:e,monthNames:t}=gs(this.locale);return{weekdayNames:e,monthNames:t,dateRange:[],yearRange:[],currentValue:this.modelValue||me(new Date,{hour:0,minute:0,second:0,millisecond:0}),currentMode:this.mode}},watch:{modelValue(e,t){+e!=+t&&(this.currentValue=e||new Date,this.updateDateRange())},currentValue(e,t){+e!=+t&&this.updateDateRange()},disabledDate:"updateDateRange",mode(e){this.currentMode=e}},mounted(){this.updateDateRange()},methods:{getMonthClass(e){return{"dito-calendar-item-active":this.modelValue&&e===this.modelValue.getMonth()&&this.currentValue.getFullYear()===this.modelValue.getFullYear(),"dito-calendar-item-current":e===this.currentValue.getMonth()}},getYearClass(e){return{"dito-calendar-item-active":this.modelValue&&e===this.modelValue.getFullYear(),"dito-calendar-item-current":e===this.currentValue.getFullYear()}},setDate(e,t=!1){this.currentValue=me(this.currentValue,e),t&&this.$emit("update:modelValue",this.currentValue)},stepDecade(e){this.setDate({year:this.currentValue.getFullYear()+e*10})},setMode(e){this.currentMode=e},stepMonth(e){const{currentValue:t}=this,{year:o,month:s}=this.getYearMonth(t.getFullYear(),t.getMonth()+e);this.setDate({month:s,day:Math.min(this.getDaysInMonth(o,s),this.currentValue.getDate())})},stepYear(e){this.setDate({year:this.currentValue.getFullYear()+e})},selectDate(e){this.setDate(Kt(e),!0),this.$emit("select")},selectMonth(e){this.setMode("day"),this.setDate({month:e,day:1},!0)},selectYear(e){this.setMode("month"),this.setDate({year:e},!0)},getYearMonth(e,t){return t>11?(e++,t=0):t<0&&(e--,t=11),{year:e,month:t}},dateToString(e,{year:t,month:o,day:s}={year:!0,month:!0,day:!0}){return e.toLocaleString(this.locale,{year:t&&"numeric",month:o&&"long",day:s&&"numeric"})},decadeToString(e){const t=this.getFirstYearOfDecade(e.getFullYear());return`${t} – ${t+9}`},getDaysInMonth(e,t){return new Date(e,t+1,0).getDate()},getFirstYearOfDecade(e){return+`${e.toString().slice(0,-1)}0`},navigate({step:e,enter:t,mode:o=this.currentMode,update:s=!1}){const{currentValue:i}=this;if(e){switch(o){case"day":this.setDate({day:i.getDate()+e},s);break;case"month":this.setDate({month:i.getMonth()+e},s);break;case"year":this.setDate({year:i.getFullYear()+e},s);break}return!0}else if(t){switch(this.currentMode){case"day":this.selectDate(i);break;case"month":this.setMode("day");break;case"year":this.setMode("month");break}return!0}},updateDateRange(){this.dateRange=[],this.yearRange=[];const{currentValue:e}=this,t=e.getFullYear(),o=e.getMonth(),s=this.getFirstYearOfDecade(t);for(let c=0;c<10;c++)this.yearRange.push(s+c);let a=new Date(t,o,1).getDay()+1;a===0&&(a=7);const r=this.getDaysInMonth(t,o);if(a>1){const c=this.getYearMonth(t,o-1),p=this.getDaysInMonth(c.year,c.month);for(let u=1;u<a;u++){const m=p-a+u+1,f=new Date(c.year,c.month,m);this.dateRange.push({text:m,date:f,state:this.disabledDate(f)?"disabled":"gray"})}}const l=new Date;for(let c=1;c<=r;c++){const p=new Date(t,o,c),u=f=>f&&f.getDate()===c&&f.getFullYear()===t&&f.getMonth()===o,m=u(this.modelValue)?"active":u(l)?"today":this.disabledDate(p)?"disabled":u(e)?"current":null;this.dateRange.push({text:c,date:p,state:m})}const d=42-this.dateRange.length;if(d>0){const c=this.getYearMonth(t,o+1);for(let p=1;p<=d;p++){const u=new Date(c.year,c.month,p),m=this.disabledDate(u)?"disabled":"gray";this.dateRange.push({text:p,date:u,state:m})}}}}},Gt={};function gs(e){let t=Gt[e];if(!t){const o=[];for(let i=0;i<7;i++){const a=new Date(0,0,i);o.push({long:a.toLocaleString(e,{weekday:"long"}),short:a.toLocaleString(e,{weekday:"short"})})}const s=[];for(let i=1;i<=12;i++){const a=new Date(0,i,0);s.push({long:a.toLocaleString(e,{month:"long"}),short:a.toLocaleString(e,{month:"short"})})}t=Gt[e]={weekdayNames:o,monthNames:s}}return t}const bs=y(fs,[["render",ms]]);function fe(e,t){e=e instanceof NodeList?Array.from(e):h.asArray(e);for(const[o,s]of Object.entries(t))for(const i of e)i.addEventListener(o,s,!1);return{remove(){for(const[o,s]of Object.entries(t))for(const i of e)i.removeEventListener(o,s,!1)}}}function ys(...e){return{remove(){for(const t of e)t.remove()}}}function ks(e){return{37:"left",38:"up",39:"right",40:"down",13:"enter"}[e?.keyCode]}function Je(e){const t=ks(e);return{hor:{left:-1,right:1}[t]||0,ver:{up:-1,down:1}[t]||0,enter:t==="enter"}}function Ge(e){const t=h.isString(e.target)?e.$refs[e.target]:e.target;return t?.$el??t}const Cs={class:"dito-trigger-container"};function $s(e,t,o,s,i,a){return n.openBlock(),n.createElementBlock("div",Cs,[o.alwaysShow?(n.openBlock(),n.createElementBlock("div",{key:0,class:n.normalizeClass(["dito-trigger",a.triggerClass]),ref:"trigger"},[n.renderSlot(e.$slots,"trigger")],2)):o.trigger==="click"?(n.openBlock(),n.createElementBlock("div",{key:1,class:n.normalizeClass(["dito-trigger",a.triggerClass]),ref:"trigger",onClick:t[0]||(t[0]=(...r)=>a.onClick&&a.onClick(...r))},[n.renderSlot(e.$slots,"trigger")],2)):o.trigger==="hover"?(n.openBlock(),n.createElementBlock("div",{key:2,class:n.normalizeClass(["dito-trigger",a.triggerClass]),ref:"trigger",onMouseenter:t[1]||(t[1]=r=>a.onHover(!0)),onMouseleave:t[2]||(t[2]=r=>a.onHover(!1))},[n.renderSlot(e.$slots,"trigger")],34)):o.trigger==="focus"||o.trigger==="always"?(n.openBlock(),n.createElementBlock("div",{key:3,class:n.normalizeClass(["dito-trigger",a.triggerClass]),ref:"trigger"},[n.renderSlot(e.$slots,"trigger")],2)):n.createCommentVNode("",!0),n.createVNode(n.Transition,{name:`dito-${o.transition}`},{default:n.withCtx(()=>[o.trigger==="hover"?n.withDirectives((n.openBlock(),n.createElementBlock("div",{key:0,class:n.normalizeClass(["dito-popup",a.popupClass]),ref:"popup",style:n.normalizeStyle(a.popupStyle),onMouseenter:t[3]||(t[3]=r=>a.onHover(!0)),onMouseleave:t[4]||(t[4]=r=>a.onHover(!1))},[i.showPopup?n.renderSlot(e.$slots,"popup",{key:0}):n.createCommentVNode("",!0)],38)),[[n.vShow,i.showPopup]]):n.withDirectives((n.openBlock(),n.createElementBlock("div",{key:1,class:n.normalizeClass(["dito-popup",a.popupClass]),ref:"popup",style:n.normalizeStyle(a.popupStyle)},[i.showPopup?n.renderSlot(e.$slots,"popup",{key:0}):n.createCommentVNode("",!0)],6)),[[n.vShow,i.showPopup]])]),_:3},8,["name"])])}const Qe=y({emits:["update:show"],props:{trigger:{type:String,default:"click"},transition:{type:String,default:"slide"},placement:{type:String,default:"bottom"},show:{type:Boolean,default:!1},disabled:{type:Boolean,default:!1},target:{type:[String,HTMLElement],default:null},customClass:{type:String,default:null},zIndex:{type:Number,default:0},keepInView:{type:Boolean,default:!0},hideWhenClickOutside:{type:Boolean,default:!0},alwaysShow:{type:Boolean,default:!1},cover:{type:Boolean,default:!1},hideDelay:{type:Number,default:0}},data(){return{showPopup:this.show,popupPlacement:this.placement,focusEvents:null,closeEvents:null,popupEvents:null,blurTimer:null,mouseLeaveTimer:null}},computed:{triggerClass(){return{"dito-trigger-disabled":this.disabled}},popupClass(){const e={[`dito-popup-${h.hyphenate(this.placement)}`]:!0};return this.customClass&&(e[this.customClass]=!0),e},popupStyle(){return this.zIndex?`z-index: ${this.zIndex}`:""},triggerTarget(){return Ge(this)}},watch:{show(e){this.showPopup=e||this.alwaysShow},showPopup(e,t){e^t&&(this.$emit("update:show",e),this.$nextTick(()=>this.onShowPopup(e)))}},mounted(){const{trigger:e,popup:t}=this.$refs;this.trigger==="focus"&&(this.focusEvents=this.addFocusEvents(this.triggerTarget??e)),this.hideWhenClickOutside&&!this.alwaysShow&&(this.closeEvents=fe(window,{mouseup:o=>{this.showPopup&&!t.contains(o.target)&&!e.contains(o.target)&&!this.triggerTarget?.contains(o.target)&&(this.showPopup=!1)},blur:()=>{this.showPopup=!1}})),this.alwaysShow&&(this.showPopup=!0)},created(){this.showPopup=this.show},unmounted(){this.focusEvents?.remove(),this.closeEvents?.remove(),this.popupEvents?.remove()},methods:{updatePosition(){const{trigger:e,popup:t}=this.$refs;if(this.show&&t.offsetWidth===0){setTimeout(()=>this.updatePosition(),0);return}const o=this.triggerTarget??e,s=this.target==="popup"?e:t.firstElementChild;s&&(s.style.width=getComputedStyle(o).width);const i=o.getBoundingClientRect(),a=i.left+window.scrollX,r=i.top+window.scrollY,l=i.width,d=i.height,c=t.offsetWidth,p=t.offsetHeight;let[u,m]=this.popupPlacement.split("-")||[];if(this.keepInView){const k=window.innerWidth,V=window.innerHeight;u==="top"?r<p&&(u="bottom"):u==="bottom"?V-r-d<p&&(u="top"):u==="left"?a<c&&(u="right"):u==="right"&&k-a-l<c&&(u="left"),m==="top"?V-r<p&&(m="bottom"):m==="bottom"?r+d<p&&(m="top"):m==="left"?k-a<c&&(m="right"):m==="right"&&a+l<c&&(m="left")}let f=0,g=0;switch(u){case"top":g-=p;break;case"left":f-=c;break;case"right":f+=l;break;case"bottom":g+=d;break}switch(m){case"right":f-=c-l;break;case"bottom":g-=p-d;break}if(this.cover&&(u==="top"?g+=d:u==="bottom"&&(g-=d)),o!==e){const k=e.getBoundingClientRect();f+=a-k.left,g+=r-k.top}t.style.left=`${f}px`,t.style.top=`${g}px`},addFocusEvents(e){const t=e.querySelectorAll("input, textarea");let o;return ys(fe(t,{focus:()=>{this.showPopup=!0,clearTimeout(this.blurTimer)},blur:()=>{this.blurTimer=setTimeout(()=>{this.$refs.popup.matches(":focus-within")||(this.showPopup=!1)},0)}}),fe(e,{mousedown:s=>{s.target.matches("input, textarea, button")||(s.preventDefault(),s.stopPropagation()),s.target.matches(".dito-button-clear")||(o=(this.triggerTarget??this.$refs.trigger).querySelector("input, textarea"),o&&!o.hasAttribute("readonly")?o.setAttribute("readonly","true"):o=null)},mouseup:s=>{o&&setTimeout(()=>{o.removeAttribute("readonly"),s.target.matches("input, textarea, button")||o.focus(),o=null},0)}}))},onShowPopup(e){e?(this.trigger==="focus"&&(this.popupEvents=this.addFocusEvents(this.$refs.popup)),this.updatePosition()):(this.popupEvents?.remove(),this.popupEvents=null)},onClick(){this.disabled||(this.showPopup=!0)},onHover(e){this.disabled||(clearTimeout(this.mouseLeaveTimer),e?this.showPopup=!0:this.hideDelay?this.mouseLeaveTimer=setTimeout(()=>{this.showPopup=!1},this.hideDelay):this.showPopup=!1)}}},[["render",$s]]),Ds=["id","type","name","title","disabled","readonly","autofocus","placeholder","autocomplete","aria-label"];function Bs(e,t,o,s,i,a){return n.openBlock(),n.createElementBlock("div",{class:n.normalizeClass(["dito-input",a.classes]),onMousedown:t[2]||(t[2]=(...r)=>a.onMouseDown&&a.onMouseDown(...r))},[n.renderSlot(e.$slots,"prefix"),n.withDirectives(n.createElementVNode("input",n.mergeProps({id:o.id,ref:"input","onUpdate:modelValue":t[0]||(t[0]=r=>i.currentValue=r),type:o.type,name:o.name,title:o.title,disabled:o.disabled,readonly:o.readonly,autofocus:o.autofocus,placeholder:o.placeholder,autocomplete:o.autocomplete,"aria-label":o.title},a.attributes,{onMousedown:t[1]||(t[1]=(...r)=>a.onMouseDown&&a.onMouseDown(...r))}),null,16,Ds),[[n.vModelDynamic,i.currentValue]]),n.renderSlot(e.$slots,"suffix")],34)}const U=y({emits:["update:modelValue"],inheritAttrs:!1,props:{modelValue:{type:[String,Number],default:null},type:{type:String,default:"text"},id:{type:String,default:null},name:{type:String,default:null},title:{type:String,default:null},disabled:{type:Boolean,default:!1},readonly:{type:Boolean,default:!1},autofocus:{type:Boolean,default:!1},focused:{type:Boolean,default:!1},placeholder:{type:String,default:null},autocomplete:{type:String,default:"off"}},data(){return{currentValue:this.modelValue}},computed:{classes(){return[this.$attrs.class,{"dito-input--focus":this.focused}]},attributes(){const{class:e,...t}=this.$attrs;return t},input(){return this.$refs.input},size(){const{size:e,min:t,max:o}=this.$attrs,s=i=>i!=null?`${i}`.length:0;return e||s(t)||s(o)||void 0}},watch:{modelValue(e,t){e!==t&&(this.currentValue=e)},currentValue(e){e!==this.modelValue&&this.$emit("update:modelValue",e)}},methods:{focus(){this.input.focus()},blur(){this.input.blur()},onMouseDown(e){e.target===this.input?e.stopPropagation():!this.disabled&&!this.readonly&&(this.focus(),e.preventDefault())}}},[["render",Bs]]);function ws(e,t,o,s,i,a){return n.openBlock(),n.createElementBlock("i",{class:n.normalizeClass(["dito-icon",a.classes])},null,2)}const Q=y({props:{name:{type:String,required:!0},disabled:{type:Boolean,default:!1}},computed:{classes(){const e="dito-icon";return{[`${e}--${this.name}`]:!0,[`${e}--disabled`]:this.disabled}}}},[["render",ws]]);function j(e,{start:t,end:o}){e?.setSelectionRange&&(e.focus(),e.setSelectionRange(t,o))}function oe(e){return e&&"selectionStart"in e?{start:e.selectionStart,end:e.selectionEnd}:null}function Ss(e,t,o,s,i,a){const r=n.resolveComponent("DitoIcon"),l=n.resolveComponent("DitoInput"),d=n.resolveComponent("DitoCalendar"),c=n.resolveComponent("DitoTrigger");return n.openBlock(),n.createBlock(c,n.mergeProps({class:"dito-date-picker",ref:"trigger",show:i.showPopup,"onUpdate:show":t[7]||(t[7]=p=>i.showPopup=p),trigger:"focus"},{transition:o.transition,placement:o.placement,disabled:o.disabled,target:o.target}),{trigger:n.withCtx(()=>[e.$slots.trigger?n.renderSlot(e.$slots,"trigger",{key:0}):(n.openBlock(),n.createBlock(l,n.mergeProps({key:1,class:"dito-date-picker-input",ref:"input",modelValue:a.currentText,"onUpdate:modelValue":t[1]||(t[1]=p=>a.currentText=p),type:"text"},{placeholder:o.placeholder,disabled:o.disabled,focused:a.focused,...e.$attrs},{onFocus:t[2]||(t[2]=p=>a.onFocus(!0)),onBlur:t[3]||(t[3]=p=>a.onFocus(!1)),onKeydown:a.onKeyDown,onMousedown:t[4]||(t[4]=n.withModifiers(p=>a.onMouseDown(!1),["stop"]))}),{prefix:n.withCtx(()=>[n.renderSlot(e.$slots,"prefix")]),suffix:n.withCtx(()=>[n.createVNode(r,{name:"calendar",disabled:o.disabled,onMousedown:t[0]||(t[0]=n.withModifiers(p=>a.onMouseDown(!0),["prevent"]))},null,8,["disabled"]),n.renderSlot(e.$slots,"suffix")]),_:3},16,["modelValue","onKeydown"]))]),popup:n.withCtx(()=>[n.createVNode(d,n.mergeProps({class:"dito-date-picker-popup",ref:"calendar",modelValue:i.currentValue,"onUpdate:modelValue":t[5]||(t[5]=p=>i.currentValue=p)},{locale:o.locale,disabledDate:o.disabledDate},{onSelect:t[6]||(t[6]=p=>i.showPopup=!1)}),null,16,["modelValue"])]),_:3},16,["show"])}const Qt=y({components:{DitoTrigger:Qe,DitoCalendar:bs,DitoInput:U,DitoIcon:Q},emits:["update:modelValue","update:show","change","focus","blur"],inheritAttrs:!1,props:{modelValue:{type:Date,default:null},transition:{type:String,default:"slide"},placement:{type:String,default:"bottom-left"},placeholder:{type:String,default:null},show:{type:Boolean,default:!1},disabled:{type:Boolean,default:!1},target:{type:[String,HTMLElement],default:"trigger"},locale:{type:String,default:"en-US"},format:{type:Object,default:()=>({date:h.defaultFormats.date,time:!1})},disabledDate:{type:Function,default:()=>!1}},data(){return{currentValue:this.modelValue,showPopup:this.show,inputFocused:!1}},computed:{focused(){return this.inputFocused||this.showPopup},input(){return Ge(this)?.querySelector("input")},formatOptions(){return{locale:this.locale,...this.format}},currentText:{get(){return h.format(this.currentValue,this.formatOptions)||""},set(e){const t=Ye(e,this.formatOptions);t&&(this.currentValue=t)}}},watch:{modelValue(e,t){+e!=+t&&(this.currentValue=e)},currentValue(e){+e!=+this.modelValue&&(this.$emit("update:modelValue",e),this.$emit("change",e))},show(e){this.showPopup=e},showPopup(e,t){e^t&&this.$emit("update:show",e)},focused(e,t){e^t&&this.$emit(e?"focus":"blur")}},methods:{onFocus(e){this.inputFocused=e,this.showPopup=e},onKeyDown(e){const{ver:t,enter:o}=Je(e);if(t||o){e.preventDefault();const s=oe(this.input)?.start,i=a=>Yt(this.currentText,a,this.formatOptions);if(t&&!this.showPopup)this.showPopup=!0;else{const{calendar:a}=this.$refs;if(a){const{name:r,start:l}=i(s)||{};r&&a.navigate({step:t,enter:o,mode:r,update:!0})&&this.$nextTick(()=>j(this.input,i(l)))}}}},onMouseDown(e){this.showPopup=!this.disabled&&(!e||!this.showPopup),this.showPopup&&this.focus()},focus(){this.input.focus()},blur(){this.input.blur()}}},[["render",Ss]]),Vs={class:"dito-time-picker-popup"},Ps={class:"dito-time-picker-panel"},Es={class:"dito-time-picker-hour",ref:"hour"},Ns=["onClick"],Os={class:"dito-time-picker-panel"},Ts={class:"dito-time-picker-minute",ref:"minute"},Ls=["onClick"],Fs={class:"dito-time-picker-panel"},Is={class:"dito-time-picker-second",ref:"second"},Ms=["onClick"];function Rs(e,t,o,s,i,a){const r=n.resolveComponent("DitoIcon"),l=n.resolveComponent("DitoInput"),d=n.resolveComponent("DitoTrigger");return n.openBlock(),n.createBlock(d,n.mergeProps({class:"dito-time-picker",ref:"trigger",show:i.showPopup,"onUpdate:show":t[5]||(t[5]=c=>i.showPopup=c),trigger:"focus"},{transition:o.transition,placement:o.placement,disabled:o.disabled,target:o.target}),{trigger:n.withCtx(()=>[e.$slots.trigger?n.renderSlot(e.$slots,"trigger",{key:0}):(n.openBlock(),n.createBlock(l,n.mergeProps({key:1,class:"dito-time-picker-input",ref:"input",modelValue:a.currentText,"onUpdate:modelValue":t[1]||(t[1]=c=>a.currentText=c),type:"text"},{placeholder:o.placeholder,disabled:o.disabled,focused:a.focused,...e.$attrs},{onFocus:t[2]||(t[2]=c=>a.onFocus(!0)),onBlur:t[3]||(t[3]=c=>a.onFocus(!1)),onKeydown:a.onKeyDown,onMousedown:t[4]||(t[4]=n.withModifiers(c=>a.onMouseDown(!1),["stop"]))}),{prefix:n.withCtx(()=>[n.renderSlot(e.$slots,"prefix")]),suffix:n.withCtx(()=>[n.createVNode(r,{name:"clock",disabled:o.disabled,onMousedown:t[0]||(t[0]=n.withModifiers(c=>a.onMouseDown(!0),["prevent"]))},null,8,["disabled"]),n.renderSlot(e.$slots,"suffix")]),_:3},16,["modelValue","onKeydown"]))]),popup:n.withCtx(()=>[n.createElementVNode("div",Vs,[n.createElementVNode("div",Ps,[n.createElementVNode("ul",Es,[(n.openBlock(),n.createElementBlock(n.Fragment,null,n.renderList(24,c=>(n.openBlock(),n.createElementBlock(n.Fragment,null,[o.disabledHour(c-1)?n.createCommentVNode("",!0):(n.openBlock(),n.createElementBlock("li",{key:0,class:n.normalizeClass({selected:a.hour===c-1}),onClick:p=>a.hour=c-1},n.toDisplayString(a.leftPad(c-1)),11,Ns))],64))),64))],512)]),n.createElementVNode("div",Os,[n.createElementVNode("ul",Ts,[(n.openBlock(),n.createElementBlock(n.Fragment,null,n.renderList(60,c=>(n.openBlock(),n.createElementBlock(n.Fragment,null,[o.disabledMinute(c-1)?n.createCommentVNode("",!0):(n.openBlock(),n.createElementBlock("li",{key:0,class:n.normalizeClass({selected:a.minute===c-1}),onClick:p=>a.minute=c-1},n.toDisplayString(a.leftPad(c-1)),11,Ls))],64))),64))],512)]),n.createElementVNode("div",Fs,[n.createElementVNode("ul",Is,[(n.openBlock(),n.createElementBlock(n.Fragment,null,n.renderList(60,c=>(n.openBlock(),n.createElementBlock(n.Fragment,null,[o.disabledSecond(c-1)?n.createCommentVNode("",!0):(n.openBlock(),n.createElementBlock("li",{key:0,class:n.normalizeClass({selected:a.second===c-1}),onClick:p=>a.second=c-1},n.toDisplayString(a.leftPad(c-1)),11,Ms))],64))),64))],512)])])]),_:3},16,["show"])}const Xt=y({components:{DitoTrigger:Qe,DitoInput:U,DitoIcon:Q},emits:["update:modelValue","update:show","change","focus","blur"],inheritAttrs:!1,props:{modelValue:{type:Date,default:null},transition:{type:String,default:"slide"},placement:{type:String,default:"bottom-left"},placeholder:{type:String,default:null},show:{type:Boolean,default:!1},disabled:{type:Boolean,default:!1},target:{type:[String,HTMLElement],default:"trigger"},locale:{type:String,default:"en-US"},format:{type:Object,default:()=>({time:h.defaultFormats.time,date:!1})},disabledHour:{type:Function,default:()=>!1},disabledMinute:{type:Function,default:()=>!1},disabledSecond:{type:Function,default:()=>!1}},data(){return{currentValue:this.modelValue,showPopup:this.show,inputFocused:!1,ignoreNextChange:!1}},computed:{focused(){return this.inputFocused||this.showPopup},input(){return Ge(this)?.querySelector("input")},formatOptions(){return{locale:this.locale,...this.format}},currentText:{get(){return h.format(this.currentValue,this.formatOptions)||""},set(e){const t=Ye(e,this.formatOptions);t&&(this.currentValue=t)}},currentDate(){return this.currentValue||me(new Date,{hour:0,minute:0,second:0,millisecond:0})},hour:{get(){return this.currentDate.getHours()},set(e){this.setTime({hour:e})}},minute:{get(){return this.currentDate.getMinutes()},set(e){this.setTime({minute:e})}},second:{get(){return this.currentDate.getSeconds()},set(e){this.setTime({second:e})}}},watch:{modelValue(e,t){+e!=+t&&(this.currentValue=e,this.scrollAll(!0))},currentValue(e){+e!=+this.modelValue&&(this.$emit("update:modelValue",e),this.$emit("change",e),this.scrollAll(!0))},currentText(){const{input:e}=this,t=oe(e);this.focused&&!this.ignoreNextChange&&t.start===t.end&&this.$nextTick(()=>j(e,t)),this.ignoreNextChange=!1},show(e){this.showPopup=e},showPopup(e,t){e&&this.scrollAll(!1),e^t&&this.$emit("update:show",e)},focused(e,t){e^t&&this.$emit(e?"focus":"blur")}},methods:{leftPad(e){return("0"+e).slice(-2)},setTime(e){this.currentValue=me(this.currentDate,{...e,millisecond:0})},scrollAll(e){const t=(o,s)=>{const i=this.$refs[o];if(i){const a=i.scrollHeight/(i.childElementCount+6),r=Math.round(s*a),l=Math.abs(i.scrollTop-r);i.scrollTo({top:r,behavior:e&&l<100?"smooth":"auto"})}};this.$nextTick(()=>{t("hour",this.hour),t("minute",this.minute),t("second",this.second)})},onFocus(e){this.inputFocused=e,this.showPopup=e},onKeyDown(e){const{input:t}=this,o=oe(t),{ver:s,enter:i}=Je(e);if(s||i){e.preventDefault();const a=r=>Yt(this.currentText,r,this.formatOptions);if(s)if(!this.showPopup)this.showPopup=!0;else{const{name:r,start:l}=a(o.start)||{};if(r){const d=this[r]+s,c=this.$refs[r].childElementCount;this[r]=d<0?d+c:d>=c?d-c:d,this.ignoreNextChange=!0,this.$nextTick(()=>j(t,a(l)))}}else i&&(this.showPopup=!1)}else if(o.start===o.end){const{value:a}=t;let r=o.start;const l=d=>!isNaN(Number(d));if(e.key.length===1)if(l(e.key)&&r<a.length)a[r]===":"&&l(a[r-1])&&l(a[r-2])&&r++,l(a[r])&&(l(a[r+1])||l(a[r-1]))&&(t.value=a.slice(0,r)+a.slice(r+1),j(t,{start:r,end:r}));else{const d=h.format(this.currentValue,this.formatOptions).length;a.length===d?e.preventDefault():a.length>d&&(t.value=a.slice(0,d),j(t,o),e.preventDefault())}else e.key==="Backspace"&&(r===1||[" ",":"].includes(a[r-2]))&&(r===a.length||a[r]===":"?(r--,t.value=a.slice(0,r)+((a[r-1]??"")+"00")+a.slice(r+1),j(t,{start:r,end:r})):l(a[r])&&!l(+a[r+1])&&(t.value=a.slice(0,r)+"0"+a.slice(r),j(t,{start:r,end:r})))}},onMouseDown(e){this.showPopup=!this.disabled&&(!e||!this.showPopup),this.showPopup&&this.focus()},focus(){this.input.focus()},blur(){this.input.blur()}}},[["render",Rs]]),js={class:"dito-date-time-picker",ref:"picker"};function zs(e,t,o,s,i,a){const r=n.resolveComponent("DitoIcon"),l=n.resolveComponent("DitoInput"),d=n.resolveComponent("DitoDatePicker"),c=n.resolveComponent("DitoTimePicker");return n.openBlock(),n.createElementBlock("div",js,[n.createElementVNode("div",{class:n.normalizeClass(["dito-date-time-picker__inner",{"dito-date-time-picker__inner--focus":a.focused}])},[n.createVNode(l,n.mergeProps({class:"dito-date-time-picker__input",ref:"input",modelValue:a.currentText,"onUpdate:modelValue":t[1]||(t[1]=p=>a.currentText=p),type:"text"},{placeholder:o.placeholder,disabled:o.disabled,focused:a.focused,...e.$attrs},{onFocus:t[2]||(t[2]=p=>a.onFocus(!0)),onBlur:t[3]||(t[3]=p=>a.onFocus(!1)),onKeydown:a.onKeyDown,onMousedown:t[4]||(t[4]=n.withModifiers(p=>a.onMouseDown(!1),["stop"]))}),{prefix:n.withCtx(()=>[n.renderSlot(e.$slots,"prefix")]),suffix:n.withCtx(()=>[n.createVNode(r,{name:"calendar",disabled:o.disabled,onMousedown:t[0]||(t[0]=n.withModifiers(p=>a.onMouseDown(!0),["prevent"]))},null,8,["disabled"]),n.renderSlot(e.$slots,"suffix")]),_:3},16,["modelValue","onKeydown"]),n.createVNode(d,n.mergeProps({ref:"date",modelValue:i.currentValue,"onUpdate:modelValue":t[5]||(t[5]=p=>i.currentValue=p),show:i.showDate,"onUpdate:show":t[6]||(t[6]=p=>i.showDate=p),placement:"bottom-left",target:e.$refs.picker},a.attributes),{trigger:n.withCtx(()=>[...t[9]||(t[9]=[])]),_:1},16,["modelValue","show","target"]),n.createVNode(c,n.mergeProps({ref:"time",modelValue:i.currentValue,"onUpdate:modelValue":t[7]||(t[7]=p=>i.currentValue=p),show:i.showTime,"onUpdate:show":t[8]||(t[8]=p=>i.showTime=p),placement:"bottom-right",target:e.$refs.picker},a.attributes),{trigger:n.withCtx(()=>[...t[10]||(t[10]=[])]),_:1},16,["modelValue","show","target"])],2)],512)}const As=y({components:{DitoInput:U,DitoDatePicker:Qt,DitoTimePicker:Xt,DitoIcon:Q},emits:["update:modelValue","change","focus","blur"],inheritAttrs:!1,props:{modelValue:{type:Date,default:null},transition:{type:String,default:"slide"},placeholder:{type:String,default:null},disabled:{type:Boolean,default:!1},locale:{type:String,default:"en-US"},format:{type:Object,default:null}},data(){return{currentValue:this.modelValue,showDate:!1,showTime:!1,inputFocused:!1,dateFocused:!1,timeFocused:!1,closedMode:null}},computed:{attributes(){const{transition:e,disabled:t,locale:o,formatOptions:s}=this;return{transition:e,disabled:t,locale:o,format:s}},focused(){return this.inputFocused||this.showDate||this.showTime},input(){return this.$refs.input.input},formatOptions(){return h.assignDeeply({locale:this.locale,time:h.defaultFormats.time,date:h.defaultFormats.date},{date:{month:"short",format:(e,t,o)=>t==="literal"&&/\bat\b/.test(e)?", ":this.format?.date?.format?.(e,t,o)??e}},this.format)},timeIndex(){const e=this.currentText;if(e){const t=e.match(/([\S]+\s*)$/)?.[1];if(t)return e.length-t.length}return null},currentText:{get(){return h.format(this.currentValue,this.formatOptions)||""},set(e){const t=Ye(e,this.formatOptions);if(t){const o=oe(this.input);this.currentValue=t,this.$nextTick(()=>j(this.input,o))}}}},watch:{modelValue(e,t){+e!=+t&&(this.currentValue=e)},currentValue(e){+e!=+this.modelValue&&(this.$emit("update:modelValue",e),this.$emit("change",e))},focused(e,t){e^t&&this.$emit(e?"focus":"blur")}},methods:{onFocus(e){this.inputFocused=e,e?this.updatePopups():(this.showDate=!1,this.showTime=!1)},onMouseDown(e){e&&(this.showDate||this.showTime)?(this.showDate=!1,this.showTime=!1):this.disabled||(this.focus(),requestAnimationFrame(()=>this.updatePopups()))},onKeyDown(e){const t=this.getMode(e);this.$refs[t].onKeyDown(e),e.defaultPrevented?this.closedMode=t:t!==this.closedMode&&this.updatePopups(t)},getMode(e=null){const{start:t}=oe(this.input),{hor:o}=Je(e);return this.timeIndex===null||t+o<this.timeIndex?"date":"time"},updatePopups(e=this.getMode()){e&&(this.closedMode=null),this.showDate=e==="date",this.showTime=e==="time"},focus(){this.input.focus()},blur(){this.input.blur()}}},[["render",zs]]),qs={class:"dito-pagination"},Us={key:0,class:"dito-pagination-total"},Hs={key:1,class:"dito-buttons dito-buttons--round"},Ws=["disabled","onClick"],Ks={key:0};function Ys(e,t,o,s,i,a){return n.openBlock(),n.createElementBlock("div",qs,[o.showTotal?(n.openBlock(),n.createElementBlock("div",Us,[o.total>0?(n.openBlock(),n.createElementBlock(n.Fragment,{key:0},[n.createTextVNode(n.toDisplayString(a.first)+" – "+n.toDisplayString(a.last)+" / "+n.toDisplayString(o.total),1)],64)):n.createCommentVNode("",!0)])):n.createCommentVNode("",!0),a.numPages>1?(n.openBlock(),n.createElementBlock("div",Hs,[(n.openBlock(!0),n.createElementBlock(n.Fragment,null,n.renderList(a.buttons,r=>(n.openBlock(),n.createElementBlock("button",{class:n.normalizeClass(["dito-button",a.getButtonClasses(r)]),disabled:r.disabled,onClick:l=>a.onClickButton(r)},[r.text?(n.openBlock(),n.createElementBlock("span",Ks,n.toDisplayString(r.text),1)):n.createCommentVNode("",!0)],10,Ws))),256))])):n.createCommentVNode("",!0)])}const Js=y({emits:["update:page"],props:{total:{type:Number,default:0},page:{type:Number,default:1},pageSize:{type:Number,default:10},showTotal:{type:Boolean,default:!0}},data(){return{showPrev:!0,showNext:!0,currentPage:this.page}},computed:{first(){return(this.currentPage-1)*this.pageSize+1},last(){return Math.min(this.first+this.pageSize-1,this.total)},numPages(){return Math.ceil(this.total/this.pageSize)},buttons(){const{showPrev:e,showNext:t,currentPage:o,numPages:s}=this,i=e+t+1;let a=1,r=1;s<=i?r=s:o<=e+1?r=i:o>=s-t?(r=s,a=s-i+1):(a=o-e,r=o+t);const l=[];l.push({index:o-1,type:"prev",disabled:o<=1}),a>=2&&l.push({index:1,text:1}),a>2&&l.push({index:Math.max(1,o-10),type:"ellipsis-prev"});for(let d=a;d<=r;d++)l.push({index:d,text:d,active:d===o});return r<s-1&&l.push({index:Math.min(s,o+10),type:"ellipsis-next"}),r<=s-1&&l.push({index:s,text:s}),l.push({index:o+1,type:"next",disabled:o>=s}),l}},watch:{page(e){this.currentPage=e},pageSize(){this.currentPage>this.numPages&&(this.currentPage=this.numPages)},currentPage(e,t){e!==t&&this.$emit("update:page",e)}},created(){this.currentPage=this.page},methods:{getButtonClasses(e){const t="dito-button";return{[`${t}--${e.type}`]:e.type,[`${t}--active`]:e.active}},onClickButton(e){e.index&&!e.disabled&&e.index!==this.currentPage&&(this.currentPage=e.index)}}},[["render",Ys]]),Gs={class:"dito-switch__pane"},Qs=["id","name","disabled"],Xs={key:0,class:"dito-switch__label"};function Zs(e,t,o,s,i,a){return n.openBlock(),n.createElementBlock("div",{class:n.normalizeClass(["dito-switch",a.classes]),style:n.normalizeStyle(a.styles)},[n.createElementVNode("div",Gs,[n.withDirectives(n.createElementVNode("input",n.mergeProps({id:o.id,ref:"input"},a.attributes,{"onUpdate:modelValue":t[0]||(t[0]=r=>i.checked=r),type:"checkbox",name:o.name,disabled:o.disabled}),null,16,Qs),[[n.vModelCheckbox,i.checked]]),t[1]||(t[1]=n.createElementVNode("div",{class:"dito-switch__button"},null,-1)),o.labels?(n.openBlock(),n.createElementBlock("span",Xs,[i.checked?n.renderSlot(e.$slots,"checked",{key:0},()=>[n.createTextVNode(n.toDisplayString(o.labels.checked||"on"),1)]):n.renderSlot(e.$slots,"unchecked",{key:1},()=>[n.createTextVNode(n.toDisplayString(o.labels.unchecked||"off"),1)])])):n.createCommentVNode("",!0)])],6)}const _s=y({emits:["update:modelValue","change"],inheritAttrs:!1,props:{modelValue:{type:Boolean,default:!1},id:{type:String,default:null},name:{type:String,default:null},disabled:{type:Boolean,default:!1},labels:{type:[Object,Boolean],default:!1}},data(){return{checked:this.modelValue}},computed:{classes(){const e="dito-switch";return[this.$attrs.class,{[`${e}--checked`]:this.checked,[`${e}--disabled`]:this.disabled}]},styles(){const{labels:{checked:e,unchecked:t}={}}=this,o=Math.max(0,e?.length,t?.length);return{"--switch-width":o?`${o*1.5}rem`:null}},attributes(){const{class:e,...t}=this.$attrs;return t}},watch:{modelValue(e){this.checked=e},checked(e){e!==this.modelValue&&(this.$emit("update:modelValue",e),this.$emit("change",e))}},methods:{focus(){this.$refs.input.focus()}}},[["render",Zs]]);function Zt({enabled:e},{slots:t}){return e?n.h(n.Transition,vs,t):t.default()}Zt.props={enabled:{type:Boolean,default:!0}};const xs=Zt,X=(e,t)=>Object.assign(e.style,t),ge=e=>setTimeout(e,0),_t=e=>getComputedStyle(e).height,vs={name:"dito-height",onAfterEnter(e){ge(()=>X(e,{height:null}))},onEnter(e){const{width:t}=getComputedStyle(e);X(e,{width:t,position:"absolute",visibility:"hidden",height:"auto"}),ge(()=>{const{height:o}=getComputedStyle(e);X(e,{width:null,position:null,visibility:null,height:0}),_t(e),ge(()=>X(e,{height:o}))})},onLeave(e){const{height:t}=getComputedStyle(e);X(e,{height:t}),_t(e),ge(()=>X(e,{height:0}))}},H={data(){return{domHandlers:[]}},unmounted(){for(const{remove:e}of this.domHandlers)e();this.domHandlers=[]},methods:{domOn(e,t,o){const s=fe(e,h.isObject(t)?t:{[t]:o});return this.domHandlers.push(s),s}}};class ea{hasRole(...t){if(this.roles){for(const o of t)if(this.roles.includes(o))return!0}return!1}}const xt={provide(){return{$schemaParentComponent:()=>this}},data(){return{schemaComponents:[]}},computed:{mainSchemaComponent(){return this.schemaComponents[0]}},methods:{_registerSchemaComponent(e,t){const{schemaComponents:o}=this;t?o.push(e):o.splice(o.indexOf(e),1)}}},vt={mixins:[xt],computed:{errors(){return this.schemaComponents.flatMap(({errors:e})=>e||[])},isTouched(){return this.schemaComponents.some(e=>e.isTouched)},isDirty(){return this.schemaComponents.some(e=>e.isDirty)},isValid(){return this.schemaComponents.every(e=>e.isValid)},isValidated(){return this.schemaComponents.every(e=>e.isValid)}},methods:{validateAll(e,t=!0){return this.schemaComponents.every(o=>o.validateAll(e,t))},verifyAll(e){return this.schemaComponents.every(t=>t.verifyAll(e))},resetValidation(){this.schemaComponents.forEach(e=>e.resetValidation())},clearErrors(){this.schemaComponents.forEach(e=>e.clearErrors())},showValidationErrors(e,t,o=!0){return this.schemaComponents.forEach(s=>{s.showValidationErrors(e,t,o)&&(o=!1)}),!o}}},en={mixins:[vt],provide(){return{$routeComponent:()=>this}},data(){return{reload:!1,store:{},loadCache:{}}},computed:{routeComponent(){return this},routeLevel(){let e=0,t=this;for(;t=t.parentRouteComponent;)e++;return e},routeRecord(){return this.$route.matched[this.routeLevel]},isLastRoute(){const{matched:e}=this.$route;return this.routeRecord===e[e.length-1]},isLastUnnestedRoute(){const{matched:e}=this.$route;for(let t=e.length-1;t>=0;t--){const o=e[t];if(!o.meta.nested)return this.routeRecord===o}return!1},isNestedRoute(){return this.meta.nested},isView(){return!1},meta(){return this.routeRecord?.meta},path(){return this.getRoutePath(this.routeRecord?.path)},label(){return this.getLabel(this.schema)},breadcrumb(){const{breadcrumb:e}=this.schema||{};return e||`${this.breadcrumbPrefix} ${this.label}`},breadcrumbPrefix(){return""},param(){return this.$route.params[this.meta?.param]||null},isMutating(){return!1}},beforeRouteUpdate(e,t){return this?.beforeRouteChange(e,t)},beforeRouteLeave(e,t){return this?.beforeRouteChange(e,t)},created(){this.appState.routeComponents.push(this)},unmounted(){const{routeComponents:e}=this.appState;e.splice(e.indexOf(this),1)},methods:{beforeRouteChange(e,t){let o=!0;return t.path.startsWith(this.path)&&!e.path.startsWith(this.path)&&t.path!==e.path&&(this.isFullRouteChange(e,t)||e.path.length<=t.path.length)&&(this.isMutating?o=this.isValidated||this.validateAll():this.isDirty&&(o=window.confirm(`You have unsaved changes. Do you really want to ${this.verbs.cancel}?`))),o},getRoutePath(e){const{path:t}=this.$route;return e?t.split("/").slice(0,e.split("/").length).join("/"):t},getChildPath(e){return`${this.path}/${e}`},isFullRouteChange(e,t){const o=this.path.match(/^(\/[^/]*)/)[1];return!h.getCommonPrefix(e.path,t.path).startsWith(o)}}},ta=["data-resource"];function na(e,t,o,s,i,a){const r=n.resolveComponent("RouterView"),l=n.resolveComponent("DitoSchema");return e.user&&e.shouldRenderSchema(e.viewSchema)?(n.openBlock(),n.createElementBlock(n.Fragment,{key:0},[e.isLastRoute?(n.openBlock(),n.createElementBlock("div",{key:1,class:"dito-view dito-scroll-parent","data-resource":e.sourceSchema.path},[(n.openBlock(),n.createBlock(l,{key:e.name,schema:e.viewSchema,data:e.data,meta:e.meta,store:e.getChildStore(e.name),padding:"root",disabled:e.isLoading,scrollable:"",single:""},null,8,["schema","data","meta","store","disabled"]))],8,ta)):(n.openBlock(),n.createBlock(r,{key:e.name}))],64)):n.createCommentVNode("",!0)}const oa=C.component("DitoView",{mixins:[en],provide(){return{$sourceComponent:()=>this.mainComponent?.sourceComponent||null,$resourceComponent:()=>this.mainComponent?.resourceComponent||null}},data(){return{isLoading:!1,data:{}}},computed:{schema(){return this.meta.schema??{}},name(){return this.schema.name},isView(){return!0},isSingleComponentView(){return Me(this.schema)},mainComponent(){return this.mainSchemaComponent?.getComponentByDataPath(this.name)},viewSchema(){const{component:e,...t}=this.schema;return this.isSingleComponentView?{...t,components:{[t.name]:{name:t.name,label:!1,...e}}}:t},providesData(){return Le(this.viewSchema,Ut)}},watch:{$route:{flush:"post",handler(e,t){this.isFullRouteChange(e,t)&&(this.isLoading=!1,this.data={})}}},mounted(){this.shouldRenderSchema(this.viewSchema)||this.$router.replace({path:"/"})},methods:{setData(e){this.data=e},getChildPath(e){return this.isSingleComponentView?this.path:`${this.path}/${e}`},setLoading(e){this.isLoading=!!e}}}),tn=y(oa,[["render",na]]);function nn(e,t){return n.getCurrentScope()?(n.onScopeDispose(e,t),!0):!1}const sa=typeof window<"u"&&typeof document<"u";typeof WorkerGlobalScope<"u"&&globalThis instanceof WorkerGlobalScope;const aa=e=>typeof e<"u",ia=e=>e!=null;function ra(e){return Array.isArray(e)?e:[e]}function la(e){return n.getCurrentInstance()}function da(e,t=!0,o){la()?n.onMounted(e,o):t?e():n.nextTick(e)}const ca=sa?window.document:void 0;function on(e){var t;const o=n.toValue(e);return(t=o?.$el)!==null&&t!==void 0?t:o}function ha(e){return JSON.parse(JSON.stringify(e))}function pa(e,t,o,s={}){var i,a;const{clone:r=!1,passive:l=!1,eventName:d,deep:c=!1,defaultValue:p,shouldEmit:u}=s,m=n.getCurrentInstance(),f=m?.emit||(m==null||(i=m.$emit)===null||i===void 0?void 0:i.bind(m))||(m==null||(a=m.proxy)===null||a===void 0||(a=a.$emit)===null||a===void 0?void 0:a.bind(m?.proxy));let g=d;g=g||`update:${t.toString()}`;const k=$=>r?typeof r=="function"?r($):ha($):$,V=()=>aa(e[t])?k(e[t]):p,w=$=>{u?u($)&&f(g,$):f(g,$)};if(l){const $=n.ref(V());let P=!1;return n.watch(()=>e[t],N=>{P||(P=!0,$.value=k(N),n.nextTick(()=>P=!1))}),n.watch($,N=>{!P&&(N!==e[t]||c)&&w(N)},{deep:c}),$}else return n.computed({get(){return V()},set($){w($)}})}function ua(e,t={}){let o;const{immediate:s,...i}=t,a=n.shallowRef(!1),r=n.shallowRef(!1),l=u=>o&&o.activate(u),d=u=>o&&o.deactivate(u),c=()=>{o&&(o.pause(),r.value=!0)},p=()=>{o&&(o.unpause(),r.value=!1)};return n.watch(n.computed(()=>ra(n.toValue(e)).map(u=>{const m=n.toValue(u);return typeof m=="string"?m:on(m)}).filter(ia)),u=>{if(u.length)if(!o)o=Pn.createFocusTrap(u,{...i,onActivate(){a.value=!0,t.onActivate&&t.onActivate()},onDeactivate(){a.value=!1,t.onDeactivate&&t.onDeactivate()}}),s&&l();else{const m=o?.active;o?.updateContainerElements(u),!m&&s&&l()}},{flush:"post"}),nn(()=>d()),{hasFocus:a,isPaused:r,activate:l,deactivate:d,pause:c,unpause:p}}const ma=n.defineComponent((e,{slots:t})=>{const o=n.shallowRef(),s=n.reactive(ua(o,e.options));return()=>{if(t.default)return n.h(e.as||"div",{ref:o},t.default(s))}},{name:"UseFocusTrap",props:["as","options"]});function fa(e,t,o,s,i,a){const r=n.resolveComponent("DitoButtons"),l=n.resolveComponent("DitoSchema"),d=n.resolveComponent("UseFocusTrap");return n.openBlock(),n.createElementBlock("div",{class:"dito-dialog",ref:"dialog",role:"dialog","aria-expanded":"true","aria-modal":"true",style:n.normalizeStyle({"--width":e.settings.width?`${e.settings.width}px`:null}),onMouseup:t[2]||(t[2]=(...c)=>e.onMouseUp&&e.onMouseUp(...c))},[n.createVNode(d,{class:"dito-dialog__focus-trap",options:e.focusTrapOptions},{default:n.withCtx(()=>[n.createElementVNode("form",{class:"dito-scroll-parent",onSubmit:t[0]||(t[0]=n.withModifiers((...c)=>e.submit&&e.submit(...c),["prevent"])),onKeydown:t[1]||(t[1]=n.withKeys((...c)=>e.onEnter&&e.onEnter(...c),["enter"]))},[n.withDirectives(n.createElementVNode("button",null,null,512),[[n.vShow,!1]]),n.createVNode(l,{schema:e.schema,data:e.dialogData,padding:"root",scrollable:"",generateLabels:""},{buttons:n.withCtx(()=>[n.createVNode(r,{class:"dito-buttons--large",buttons:e.buttonSchemas,data:e.dialogData},null,8,["buttons","data"])]),_:1},8,["schema","data"])],32)]),_:1},8,["options"])],36)}const ga=C.component("DitoDialog",{mixins:[H],components:{UseFocusTrap:ma},emits:["remove"],provide(){return{$dialogComponent:()=>this}},props:{components:{type:Object,required:!0},buttons:{type:Object,required:!0},promise:{type:Object,required:!0},data:{type:Object,default:()=>({})},settings:{type:Object,default:()=>({width:480,clickToClose:!1})}},data(){const e=h.clone(this.data);for(const t in this.components)t in e||(e[t]=null);return{dialogData:e}},computed:{dialogComponent(){return this},schema(){return{type:"dialog",components:this.components}},buttonSchemas(){return Object.fromEntries(Object.entries(v(this.buttons)).map(([e,t])=>(e==="cancel"&&!t.events&&(t={...t,events:{click:()=>this.cancel()}}),[e,t])))},focusTrapOptions(){return{immediate:!0,fallbackFocus:()=>this.$refs.dialog,onDeactivate:this.cancel}},hasButtons(){return Object.keys(this.buttonSchemas).length>0},hasCancel(){return!!this.buttonSchemas.cancel}},mounted(){this.domOn(window,{keyup:e=>{(this.hasCancel||!this.hasButtons)&&e.keyCode===27&&this.cancel()}})},methods:{remove(){this.$emit("remove")},resolve(e){this.promise.resolve(e),this.remove()},reject(e){this.promise.reject(e),this.remove()},onEnter(e){e.target instanceof HTMLInputElement&&this.submit()},submit(){this.resolve(this.dialogData)},cancel(){this.resolve(void 0)},close(){this.cancel()},onMouseUp(){this.settings.clickToClose&&this.close()}}}),sn=y(ga,[["render",fa]]),ba=["data-agent-browser","data-agent-platform","data-agent-version"],ya={key:0,class:"dito-drag-overlay"};function ka(e,t,o,s,i,a){const r=n.resolveComponent("DitoDialog"),l=n.resolveComponent("DitoNavigation"),d=n.resolveComponent("DitoHeader"),c=n.resolveComponent("RouterView"),p=n.resolveComponent("DitoAccount"),u=n.resolveComponent("DitoSidebar"),m=n.resolveComponent("DitoNotifications"),f=n.resolveDirective("resize");return n.openBlock(),n.createElementBlock("div",{class:"dito-root","data-agent-browser":e.appState.agent.browser,"data-agent-platform":e.appState.agent.platform,"data-agent-version":e.appState.agent.versionNumber},[n.createVNode(n.Transition,{name:"dito-drag"},{default:n.withCtx(()=>[e.isDraggingFiles?(n.openBlock(),n.createElementBlock("div",ya)):n.createCommentVNode("",!0)]),_:1}),n.createVNode(n.TransitionGroup,{name:"dito-dialog"},{default:n.withCtx(()=>[(n.openBlock(!0),n.createElementBlock(n.Fragment,null,n.renderList(e.dialogs,(g,k)=>(n.openBlock(),n.createBlock(r,{key:k,components:g.components,buttons:g.buttons,promise:g.promise,data:g.data,settings:g.settings,onRemove:V=>e.removeDialog(k)},null,8,["components","buttons","promise","data","settings","onRemove"]))),128))]),_:1}),n.createVNode(l),n.withDirectives((n.openBlock(),n.createElementBlock("main",{class:n.normalizeClass(["dito-page dito-scroll-parent",e.pageClasses])},[n.createVNode(d,{spinner:e.options.spinner,isLoading:e.isLoading},null,8,["spinner","isLoading"]),n.createVNode(c)],2)),[[f,e.onResizePage]]),n.createVNode(u,null,{default:n.withCtx(()=>[e.user?(n.openBlock(),n.createBlock(p,{key:0})):e.allowLogin?(n.openBlock(),n.createElementBlock("a",{key:1,class:"dito-login",onClick:t[0]||(t[0]=g=>e.rootComponent.login())},[...t[1]||(t[1]=[n.createElementVNode("span",null,"Login",-1)])])):n.createCommentVNode("",!0)]),_:1}),n.createVNode(m,{ref:"notifications"},null,512)],8,ba)}const Ca=C.component("DitoRoot",{mixins:[H],components:{DitoDialog:sn},provide(){return{$views:()=>this.resolvedViews}},props:{unresolvedViews:{type:[Object,Function,Promise],required:!0},options:{type:Object,default:()=>({})}},data(){return{resolvedViews:{},removeRoutes:null,dialogs:{},pageWidth:0,loadingCount:0,allowLogin:!1,isDraggingFiles:!1}},computed:{notifications(){return this.isMounted&&this.$refs.notifications},isLoading(){return this.loadingCount>0},pageClasses(){const e="dito-page";return[this.appState.pageClass,{[`${e}--width-80`]:this.pageWidth<=900*.8,[`${e}--width-60`]:this.pageWidth<=900*.6}]}},created(){this.appState.title=document.title||"Dito.js Admin",this.appState.routeComponents=[]},async mounted(){this.setupDragAndDrop(),tt.delegate(this.$el,{target:".dito-info",theme:"info",animation:"shift-away-subtle",interactive:!0,delay:250,zIndex:1,appendTo:e=>e.closest(".dito-pane"),onShow:e=>e.setContent(e.reference.dataset.info)}),this.domOn(document,{click:e=>{e.target.closest(".dito-label")||(this.appState.activeLabel=null)},keyup:e=>{e.code==="Tab"&&(this.appState.activeLabel=null)}});try{this.allowLogin=!1,await this.fetchUser()?await this.resolveViews():await this.login()}catch(e){console.error(e)}this.allowLogin=!0},methods:{setupDragAndDrop(){let e=0,t=[];const o=i=>{for(const a of t)a.closest(".dito-container").classList.toggle("dito-drop-target",i);i||(t=[])},s=i=>{this.isDraggingFiles=i,i?o(!0):setTimeout(()=>o(!1),150)};this.domOn(document,{dragenter:i=>{if(!e&&i.dataTransfer){t=document.querySelectorAll(".dito-upload");const a=t.length>0;if(i.dataTransfer.effectAllowed=a?"copy":"none",a)s(!0);else{i.preventDefault(),i.stopPropagation();return}}e++},dragleave:i=>{e--,!e&&i.dataTransfer&&s(!1)},dragover:i=>{if(i.dataTransfer){const a=i.target.closest(".dito-container:has(.dito-upload)");i.dataTransfer.dropEffect=a?"copy":"none",a||(i.preventDefault(),i.stopPropagation())}},drop:i=>{e=0,i.dataTransfer&&s(!1)}})},notify({type:e="info",title:t,text:o,error:s,duration:i}={}){this.notifications.notify({type:e,title:t,text:o,error:s,duration:i})},closeNotifications(){this.notifications.destroyAll()},registerLoading(e){this.loadingCount+=e?1:-1},showDialog({components:e,buttons:t,data:o,settings:s}){return new Promise(async(i,a)=>{const r=[];if(await x(this.api,{type:"dialog",components:e},r,0),r.length>0)throw new Error("Dialogs do not support components that produce routes");const l=`dialog-${++$a}`;this.dialogs[l]={components:e,buttons:t,data:o,settings:s,promise:{resolve:i,reject:a}}})},removeDialog(e){delete this.dialogs[e]},async login(){this.allowLogin=!0;const{additionalComponents:e,redirectAfterLogin:t}=this.options.login||{},o=await this.showDialog({components:{username:{type:"text",autofocus:!0},password:{type:"password"},...e},buttons:{login:{type:"submit",text:"Login"},cancel:{type:"button",text:"Cancel"}}});if(o)try{const s=await this.sendRequest({resource:this.api.users.login,data:o,internal:!0});t?location.replace(t):(this.setUser(s.data.user),await this.resolveViews())}catch(s){const i=s.response?.data?.error||s;this.notify({type:"error",error:i,title:"Authentication Error",text:i}),this.login()}},navigateHome(){return this.navigate("/")},async logout(){try{(await this.sendRequest({resource:this.api.users.logout,internal:!0})).data.success&&(this.setUser(null),this.navigateHome())}catch(e){console.error(e)}},async fetchUser(){let e=null;try{e=(await this.sendRequest({resource:this.api.users.session,internal:!0})).data.user||null}catch(t){const o=t.response?.data?.error||t;this.notify({type:"error",error:o,title:"Authentication Error",text:o})}return this.setUser(e),e},setUser(e){this.appState.user=e&&Object.setPrototypeOf(e,ea.prototype),e||(this.resolvedViews={},this.navigateHome())},async ensureUser(){await this.fetchUser()||await this.login()},async resolveViews(){try{this.resolvedViews=await So(this.unresolvedViews)}catch(o){return o.request||console.error(o),this.login()}const e=await h.mapConcurrently(Object.entries(this.resolvedViews),([o,s])=>Ct(tn,this.api,s,o)),{fullPath:t}=this.$route;this.removeRoutes?.(),this.removeRoutes=Da(this.$router,[{name:"root",path:"/",components:{}},...e.flat()]),this.$router.replace(t)},onResizePage({contentRect:{width:e}}){this.pageWidth=e}}});let $a=0;function Da(e,t){const o=[];for(const s of t)o.push(e.addRoute(s));return()=>{for(const s of o)s()}}const Xe=y(Ca,[["render",ka]]),Ba={class:"dito-menu__item"},wa=["href","onClick"];function Sa(e,t,o,s,i,a){const r=n.resolveComponent("DitoMenu",!0),l=n.resolveDirective("resize");return n.withDirectives((n.openBlock(),n.createElementBlock("ul",{class:"dito-menu",style:n.normalizeStyle({"--width":e.width?`${e.width}px`:null})},[(n.openBlock(!0),n.createElementBlock(n.Fragment,null,n.renderList(e.items,d=>(n.openBlock(),n.createElementBlock("li",Ba,[e.shouldShowItem(d)?(n.openBlock(),n.createElementBlock(n.Fragment,{key:0},[n.createElementVNode("a",{class:n.normalizeClass(["dito-menu__link",{"dito-menu__link--active":e.isActiveItem(d)}]),href:e.getItemHref(d),onClick:n.withModifiers(c=>e.onClickItem(d),["prevent","stop"])},n.toDisplayString(e.getLabel(d)),11,wa),d.items?(n.openBlock(),n.createBlock(r,{key:0,class:"dito-menu__sub",items:d.items,path:e.getItemPath(d,!1)},null,8,["items","path"])):n.createCommentVNode("",!0)],64)):n.createCommentVNode("",!0)]))),256))],4)),[[l,e.onResize]])}const Va=C.component("DitoMenu",{props:{items:{type:[Object,Array],default:()=>[]},path:{type:String,default:""}},data(){return{width:0}},methods:{shouldShowItem(e){return this.shouldRenderSchema(e)&&(!e.items||Object.values(e.items).some(this.shouldRenderSchema))},onResize({contentRect:{width:e}}){e&&(this.width=e)},getItemPath(e,t){const o=e.path?`${this.path}/${e.path}`:null;return t&&o&&e.items?`${o}${this.getItemPath(Object.values(e.items)[0],!1)}`:o},getItemHref(e){const t=this.getItemPath(e,!0);return t?this.$router.resolve(t).href:null},isActiveItem(e){return this.$route.path.startsWith(this.getItemPath(e,!1))||e.items&&Object.values(e.items).some(this.isActiveItem)},onClickItem(e){const t=this.getItemPath(e,!0);t&&this.$router.push({path:t,force:!0})}}}),Pa=y(Va,[["render",Sa]]),Ea={class:"dito-trail"},Na=["href","onClick"];function Oa(e,t,o,s,i,a){return n.openBlock(),n.createElementBlock("div",Ea,[n.createElementVNode("ul",null,[(n.openBlock(!0),n.createElementBlock(n.Fragment,null,n.renderList(e.trail,r=>(n.openBlock(),n.createElementBlock("li",null,[n.createElementVNode("a",{class:n.normalizeClass(["dito-trail__link",{"dito-trail__link--active":r.path===e.$route.path}]),href:e.getComponentHref(r),onClick:n.withModifiers(l=>e.onClickComponent(r),["prevent","stop"])},[n.createElementVNode("span",{class:n.normalizeClass(["dito-trail__text",{"dito-trail__text--dirty":r.isDirty}])},n.toDisplayString(r.breadcrumb),3)],10,Na)]))),256))]),n.renderSlot(e.$slots,"default")])}const Ta=C.component("DitoTrail",{computed:{trail(){return this.appState.routeComponents.filter(e=>!!e.routeRecord)}},methods:{getComponentPath(e){const{schema:t}=e;return t.type==="menu"?Object.values(t.items)[0].fullPath:e.path},getComponentHref(e){return this.$router.resolve(this.getComponentPath(e)).href},onClickComponent(e){this.$router.push({path:this.getComponentPath(e),force:!0})}}}),La=y(Ta,[["render",Oa]]),Fa={class:"dito-header"};function Ia(e,t,o,s,i,a){const r=n.resolveComponent("DitoSpinner"),l=n.resolveComponent("DitoTrail");return n.openBlock(),n.createElementBlock("nav",Fa,[n.createVNode(l,null,{default:n.withCtx(()=>[e.isLoading?(n.openBlock(),n.createBlock(r,{key:0,size:e.spinner?.size,color:e.spinner?.color},null,8,["size","color"])):n.createCommentVNode("",!0)]),_:1}),t[0]||(t[0]=n.createElementVNode("div",{class:"dito-header__teleport"},null,-1)),n.renderSlot(e.$slots,"default")])}const Ma=C.component("DitoHeader",{props:{spinner:{type:Object,default:null},isLoading:{type:Boolean,default:!1}}}),Ra=y(Ma,[["render",Ia]]),ja={class:"dito-navigation dito-scroll-parent"};function za(e,t,o,s,i,a){const r=n.resolveComponent("RouterLink"),l=n.resolveComponent("DitoMenu");return n.openBlock(),n.createElementBlock("nav",ja,[n.createElementVNode("h1",null,[n.createVNode(r,{class:"dito-link",to:"/"},{default:n.withCtx(()=>[n.createTextVNode(n.toDisplayString(e.appState.title),1)]),_:1})]),n.createVNode(l,{class:"dito-scroll",items:e.views},null,8,["items"])])}const Aa=C.component("DitoNavigation",{}),qa=y(Aa,[["render",za]]),Ua={class:"dito-notifications"},Ha={class:"dito-notifications__inner"};function Wa(e,t,o,s,i,a){const r=n.resolveComponent("VueNotifications");return n.openBlock(),n.createElementBlock("div",Ua,[t[0]||(t[0]=n.createElementVNode("div",{class:"dito-header"},[n.createElementVNode("span")],-1)),n.createElementVNode("div",Ha,[n.createVNode(r,{ref:"notifications",classes:"dito-notification",dangerouslySetInnerHtml:!0,position:"",width:""},null,512)])])}const Ka=C.component("DitoNotifications",{notifications(){return this.isMounted&&this.$refs.notifications},methods:{notify({type:e="info",title:t,text:o,error:s,duration:i}={}){t||={warning:"Warning",error:"Error",info:"Information",success:"Success"}[e]||"Notification",o=`<p>${h.asArray(o).join("</p> <p>")}</p>`.replace(/\n|\r\n|\r/g,"<br>");const a={warning:"warn",error:"error",info:"log",success:"log"}[e]||"error";console[a](h.stripHtml(o),...e==="error"&&s?[s]:[]);const{notifications:r=!0}=this.api;if(r){const{durationFactor:l=20}=r;i??=(40+o.length+t.length)*l,this.$notify({type:e,title:t,text:o,duration:i===0?-1:i})}},destroyAll(){this.notifications.destroyAll()}}}),Ya=y(Ka,[["render",Wa]]),Ja={class:"dito-header"};function Ga(e,t,o,s,i,a){const r=n.resolveDirective("resize");return n.withDirectives((n.openBlock(),n.createElementBlock("aside",{class:n.normalizeClass(["dito-sidebar dito-scroll-parent",e.classes])},[n.createElementVNode("nav",Ja,[n.renderSlot(e.$slots,"default")]),t[0]||(t[0]=n.createElementVNode("div",{class:"dito-sidebar__teleport dito-scroll"},null,-1))],2)),[[r,e.onResizeSidebar]])}const Qa=C.component("DitoSidebar",{data(){return{sidebarWidth:0}},computed:{classes(){const e="dito-sidebar";return{[`${e}--width-99`]:this.sidebarWidth<360,[`${e}--width-60`]:this.sidebarWidth<=360*.6}}},methods:{onResizeSidebar({contentRect:{width:e}}){this.sidebarWidth=e}}}),Xa=y(Qa,[["render",Ga]]),an={mixins:[H],data(){return{pulldown:{open:!1,startTime:0,checkTime:!0,events:{mousedown:()=>{this.setPulldownOpen(!1),this.pulldown.handlers.remove()},mouseup:()=>{this.onPulldownMouseUp()&&this.pulldown.handlers.remove()}},handlers:null}}},methods:{onPulldownMouseDown(e=null){e===null?(this.setPulldownOpen(!0),this.checkTime=!0):this.checkTime=!1},onPulldownMouseUp(e=null){const{startTime:t}=this.pulldown;if(!this.checkTime||t&&Date.now()-t>250)return this.setPulldownOpen(!1),e!==null&&this.onPulldownSelect(e),!0},onPulldownSelect(){},setPulldownOpen(e){this.pulldown.open=e,this.pulldown.startTime=e?Date.now():0,e&&(this.pulldown.handlers=this.domOn(document,this.pulldown.events))}}},Za={class:"dito-account"},_a=["onMousedown","onMouseup"];function xa(e,t,o,s,i,a){return n.openBlock(),n.createElementBlock("div",Za,[n.createElementVNode("a",{onMousedown:t[0]||(t[0]=n.withModifiers(r=>e.onPulldownMouseDown(),["stop"]))},[n.createElementVNode("span",null,n.toDisplayString(e.user.username),1)],32),n.createElementVNode("ul",{class:n.normalizeClass(["dito-pulldown",{"dito-pulldown--open":e.pulldown.open}])},[(n.openBlock(!0),n.createElementBlock(n.Fragment,null,n.renderList(e.items,(r,l)=>(n.openBlock(),n.createElementBlock("li",null,[n.createElementVNode("a",{class:"dito-pulldown__item",onMousedown:n.withModifiers(d=>e.onPulldownMouseDown(l),["stop"]),onMouseup:d=>e.onPulldownMouseUp(l)},n.toDisplayString(r),41,_a)]))),256))],2)])}const va=C.component("DitoAccount",{mixins:[an],data(){return{items:{settings:"Settings",logout:"Logout"}}},methods:{onPulldownSelect(e){switch(e){case"logout":this.rootComponent.logout();break;case"settings":console.info("TODO: Implement Settings");break}}}}),ei=y(va,[["render",xa]]);function ti(e,t,o,s,i,a){return n.withDirectives((n.openBlock(),n.createElementBlock("div",{class:"dito-spinner",style:n.normalizeStyle({"--color":e.color,"--size":e.size,"--margin":e.margin})},[...t[0]||(t[0]=[n.createElementVNode("div",{class:"dito-spinner__pulse dito-spinner__pulse1"},null,-1),n.createElementVNode("div",{class:"dito-spinner__pulse dito-spinner__pulse2"},null,-1),n.createElementVNode("div",{class:"dito-spinner__pulse dito-spinner__pulse3"},null,-1)])],4)),[[n.vShow,e.loading]])}const ni=C.component("DitoSpinner",{props:{loading:{type:Boolean,default:!0},color:{type:String,default:null},size:{type:String,default:null},margin:{type:String,default:null}}}),rn=y(ni,[["render",ti]]);function oi(e,t,o,s,i,a){const r=n.resolveComponent("DitoSpinner"),l=n.resolveComponent("DitoIcon");return e.item.type==="text"?(n.openBlock(),n.createBlock(n.resolveDynamicComponent(e.item.as||"div"),{key:0},{default:n.withCtx(()=>[n.createTextVNode(n.toDisplayString(e.item.text),1)]),_:1})):e.item.type==="html"?(n.openBlock(),n.createBlock(n.resolveDynamicComponent(e.item.as||"div"),{key:1,innerHTML:e.item.html},null,8,["innerHTML"])):e.item.type==="spinner"?(n.openBlock(),n.createBlock(r,{key:2,size:e.item.size,color:e.item.color},null,8,["size","color"])):e.item.type==="icon"?(n.openBlock(),n.createBlock(l,{key:3,name:e.item.name,disabled:e.item.disabled},null,8,["name","disabled"])):e.item.type==="component"?(n.openBlock(),n.createBlock(n.resolveDynamicComponent(e.item.component),n.normalizeProps(n.mergeProps({key:4},e.item.props)),null,16)):n.createCommentVNode("",!0)}const si=C.component("DitoAffix",{components:{DitoSpinner:rn,DitoIcon:Q},props:{item:{type:Object,required:!0},parentContext:{type:Object,required:!0}},computed:{context(){return this.parentContext}}}),ln=y(si,[["render",oi]]),ai=["disabled"],ii=["data-info"];function ri(e,t,o,s,i,a){const r=n.resolveComponent("DitoAffix");return e.hasContent?(n.openBlock(),n.createElementBlock("div",{key:0,class:n.normalizeClass(["dito-affixes",e.classes])},[n.renderSlot(e.$slots,"prepend"),(n.openBlock(!0),n.createElementBlock(n.Fragment,null,n.renderList(e.visibleItems,(l,d)=>(n.openBlock(),n.createBlock(r,{class:n.normalizeClass(["dito-affix",e.getItemClasses(l)]),key:d,style:n.normalizeStyle(l.style),item:l,parentContext:e.parentContext},null,8,["class","style","item","parentContext"]))),128)),e.clearable?(n.openBlock(),n.createElementBlock("button",{key:0,class:"dito-affixes__clear",type:"button",title:"Clear",disabled:e.disabled,onClick:t[0]||(t[0]=n.withModifiers(l=>e.$emit("clear"),["stop"])),onMousedown:t[1]||(t[1]=n.withModifiers(()=>{},["stop"]))},null,40,ai)):n.createCommentVNode("",!0),n.renderSlot(e.$slots,"append"),e.inlineInfo?(n.openBlock(),n.createElementBlock("div",{key:1,class:"dito-info","data-info":e.inlineInfo},null,8,ii)):n.createCommentVNode("",!0)],2)):n.createCommentVNode("",!0)}const li=C.component("DitoAffixes",{components:{DitoAffix:ln},emits:["clear"],props:{items:{type:[String,Object,Array],default:null},mode:{type:String,default:null},position:{type:String,default:null},absolute:{type:Boolean,default:!1},clearable:{type:Boolean,default:!1},disabled:{type:Boolean,default:!1},inlineInfo:{type:String,default:null},parentContext:{type:Object,required:!0}},computed:{context(){return this.parentContext},processedItems(){return h.asArray(this.items).filter(Boolean).map(e=>h.isString(e)?{type:"text",text:e}:e.type?e:e.text!=null?{type:"text",...e}:e.html!=null?{type:"html",...e}:e)},visibleItems(){return this.processedItems.filter(e=>qe(e,this.context))},classes(){const e="dito-affixes";return{[`${e}--${this.position}`]:this.position,[`${e}--${this.mode}`]:this.mode,[`${e}--absolute`]:this.absolute}},hasContent(){return this.visibleItems.length>0||this.clearable||this.inlineInfo||ne(this.$slots.prepend)||ne(this.$slots.append)}},methods:{getItemClasses(e){const t="dito-affix";return[{[`${t}--${e.type}`]:e.type,[`${t}--ellipsis`]:this.mode==="ellipsis"&&["text","html"].includes(e.type)},e.class]}}}),I=y(li,[["render",ri]]),di={key:1,class:"dito-label__inner"},ci=["for","innerHTML"],hi=["data-info"];function pi(e,t,o,s,i,a){const r=n.resolveComponent("DitoAffixes");return e.text||e.collapsible?(n.openBlock(),n.createBlock(n.resolveDynamicComponent(e.collapsible?"button":"div"),n.mergeProps({key:0,class:"dito-label",type:e.collapsible?"button":null},e.attributes,{class:{"dito-label--active":e.isActive}}),{default:n.withCtx(()=>[e.collapsible?(n.openBlock(),n.createElementBlock("div",{key:0,class:n.normalizeClass(["dito-chevron",{"dito-chevron--open":!e.collapsed}])},null,2)):n.createCommentVNode("",!0),e.text||e.prefixes.length>0||e.suffixes.length>0?(n.openBlock(),n.createElementBlock("div",di,[n.createVNode(r,{items:e.prefixes,position:"prefix",parentContext:e.context},null,8,["items","parentContext"]),e.text?(n.openBlock(),n.createElementBlock("label",{key:0,for:e.dataPath,innerHTML:e.text},null,8,ci)):n.createCommentVNode("",!0),n.createVNode(r,{items:e.suffixes,mode:"ellipsis",position:"suffix",parentContext:e.context},null,8,["items","parentContext"]),e.info?(n.openBlock(),n.createElementBlock("div",{key:1,class:"dito-info","data-info":e.info},null,8,hi)):n.createCommentVNode("",!0)])):n.createCommentVNode("",!0)]),_:1},16,["type","class"])):n.createCommentVNode("",!0)}const ui=C.component("DitoLabel",{components:{DitoAffixes:I},emits:["open"],props:{label:{type:[String,Object],default:null},dataPath:{type:String,default:null},collapsed:{type:Boolean,default:!1},collapsible:{type:Boolean,default:!1},info:{type:String,default:null}},computed:{text(){const{label:e}=this;return h.isObject(e)?e?.text:e},prefixes(){return h.asArray(this.label?.prefix)},suffixes(){return h.asArray(this.label?.suffix)},attributes(){return this.collapsible?{onClick:this.onClick}:{}},isActive(){return this.appState.activeLabel===this}},methods:{onClick(){this.appState.activeLabel=this,this.$emit("open",this.collapsed)}}}),mi=y(ui,[["render",pi]]),be={methods:{getItemFormSchema:je,getItemUid:Ao,getItemId(e,t,o=null){return this.isTransient&&o!==null?String(o):qt(e,t)},getItemDataPath(e,t){let{dataPath:o}=this;return e!==this.schema&&(o=O(o,e.name)),t!=null&&(o=O(o,t)),o},getItemStore(e,t,o){return this.getChildStore(this.getItemUid(e,t),o)},removeItemStore(e,t,o){this.removeChildStore(this.getItemUid(e,t),o)},findItemIdIndex(e,t,o){const s=this.isTransient?o:t?.findIndex((i,a)=>this.getItemId(e,i,a)===o);return s!==-1?s:null},getItemLabel(e,t,{index:o=null,extended:s=!1,asObject:i=!1}={}){const{itemLabel:a}=e;if(!t||!s&&a===!1)return null;let r;const l=()=>r??=this.getItemDataPath(e,o);let d;const c=()=>d??=this.getLabel(je(e,t,this.context));let p,u,m;if(h.isFunction(a)){const g=a.call(this,new S(this,{nested:!1,data:t,value:t,index:o,get dataPath(){return l()},get formLabel(){return c()}}));h.isObject(g)?{text:p,prefix:u,suffix:m}=g:p=g,s=!1}else if(h.isString(a)&&!(a in t))p=a;else{const{columns:g}=e,k=h.isString(a)&&a||te(e)&&g&&Object.keys(g)[0]||"name";p=t[k]}const f=!!p;if(p==null&&(s=!0,p=te(e)&&o!==null?p=`${o+1}`:""),s){const g=c();g&&(p=`${g} ${f?`'${p}'`:p}`)}return i?p||u||m?{text:p,prefix:u,suffix:m}:null:p}}},fi={key:0,class:"dito-schema-header"};function gi(e,t,o,s,i,a){const r=n.resolveComponent("DitoPanels"),l=n.resolveComponent("DitoLabel"),d=n.resolveComponent("DitoTabs"),c=n.resolveComponent("DitoClipboard"),p=n.resolveComponent("DitoPane"),u=n.resolveComponent("TransitionHeight");return n.openBlock(),n.createElementBlock(n.Fragment,null,[n.renderSlot(e.$slots,"prepend"),n.createElementVNode("div",n.mergeProps({class:["dito-schema",{"dito-scroll-parent":e.scrollable,"dito-schema--open":e.opened}]},e.$attrs),[e.isPopulated&&e.panelEntries.length>0?(n.openBlock(),n.createBlock(n.Teleport,{key:0,to:".dito-sidebar__teleport"},[e.active?(n.openBlock(),n.createBlock(r,{key:0,panels:e.panelEntries,data:e.data,meta:e.meta,store:e.store,disabled:e.disabled},null,8,["panels","data","meta","store","disabled"])):n.createCommentVNode("",!0)])):n.createCommentVNode("",!0),e.hasHeader?(n.openBlock(),n.createBlock(n.Teleport,{key:1,to:e.headerTeleport,disabled:!e.headerTeleport},[e.active?(n.openBlock(),n.createElementBlock("div",fi,[e.hasLabel?(n.openBlock(),n.createBlock(l,{key:0,label:e.label,info:e.info,dataPath:e.dataPath,collapsible:e.collapsible,collapsed:!e.opened,onOpen:e.onOpen},null,8,["label","info","dataPath","collapsible","collapsed","onOpen"])):n.createCommentVNode("",!0),e.tabs?(n.openBlock(),n.createBlock(n.Transition,{key:1,name:"dito-fade"},{default:n.withCtx(()=>[e.opened?(n.openBlock(),n.createBlock(d,{key:0,modelValue:e.selectedTab,"onUpdate:modelValue":t[0]||(t[0]=m=>e.selectedTab=m),tabs:e.tabs},null,8,["modelValue","tabs"])):n.createCommentVNode("",!0)]),_:1})):n.createCommentVNode("",!0),e.clipboard?(n.openBlock(),n.createBlock(c,{key:2,clipboard:e.clipboard,schema:e.schema},null,8,["clipboard","schema"])):n.createCommentVNode("",!0),n.renderSlot(e.$slots,"edit-buttons")])):n.createCommentVNode("",!0)],8,["to","disabled"])):n.createCommentVNode("",!0),n.createVNode(u,{enabled:e.inlined},{default:n.withCtx(()=>[e.opened?(n.openBlock(),n.createElementBlock("div",{key:0,class:n.normalizeClass(["dito-schema-content",{"dito-scroll":e.scrollable}]),ref:"content"},[e.hasTabs?(n.openBlock(!0),n.createElementBlock(n.Fragment,{key:0},n.renderList(e.tabs,(m,f)=>n.withDirectives((n.openBlock(),n.createBlock(p,{key:f,class:"dito-pane__tab",ref_for:!0,ref:"tabs",tab:f,schema:m,dataPath:e.dataPath,data:e.data,meta:e.meta,store:e.store,padding:e.padding,single:e.single&&!e.inlined&&!e.hasMainPane,disabled:e.disabled,compact:e.compact,generateLabels:e.generateLabels,accumulatedBasis:e.accumulatedBasis},null,8,["tab","schema","dataPath","data","meta","store","padding","single","disabled","compact","generateLabels","accumulatedBasis"])),[[n.vShow,e.selectedTab===f]])),128)):n.createCommentVNode("",!0),e.hasMainPane?(n.openBlock(),n.createBlock(p,{key:1,class:"dito-pane__main",ref:"components",schema:e.schema,dataPath:e.dataPath,data:e.data,meta:e.meta,store:e.store,padding:e.padding,single:e.single&&!e.inlined&&!e.hasTabs,disabled:e.disabled,compact:e.compact,generateLabels:e.generateLabels,accumulatedBasis:e.accumulatedBasis},null,8,["schema","dataPath","data","meta","store","padding","single","disabled","compact","generateLabels","accumulatedBasis"])):n.createCommentVNode("",!0),!e.inlined&&e.isPopulated?n.renderSlot(e.$slots,"buttons",{key:2}):n.createCommentVNode("",!0)],2)):n.createCommentVNode("",!0)]),_:3},8,["enabled"]),e.inlined&&!e.hasHeader?n.renderSlot(e.$slots,"edit-buttons",{key:2}):n.createCommentVNode("",!0)],16),n.renderSlot(e.$slots,"append")],64)}const bi=C.component("DitoSchema",{mixins:[L,be],components:{TransitionHeight:xs},inheritAttrs:!1,provide(){return{$schemaComponent:()=>this}},inject:["$schemaParentComponent"],props:{schema:{type:Object,required:!0},dataSchema:{type:Object,default:e=>e.schema},dataPath:{type:String,default:""},data:{type:Object,default:null},meta:{type:Object,default:()=>({})},store:{type:Object,default:()=>({})},label:{type:[String,Object],default:null},info:{type:String,default:null},single:{type:Boolean,default:!1},padding:{type:String,default:null},active:{type:Boolean,default:!0},inlined:{type:Boolean,default:!1},disabled:{type:Boolean,default:!1},compact:{type:Boolean,default:!1},collapsed:{type:Boolean,default:!1},collapsible:{type:Boolean,default:!1},scrollable:{type:Boolean,default:!1},hasOwnData:{type:Boolean,default:!1},generateLabels:{type:Boolean,default:!1},labelNode:{type:HTMLElement,default:null},accumulatedBasis:{type:Number,default:1}},data(){const{data:e}=this.schema;return{...e&&h.isFunction(e)?e(this.context):e,selectedTab:null,componentsRegistry:{},panesRegistry:{},panelsRegistry:{},scrollPositions:{}}},computed:{nested(){return!1},schemaComponent(){return this},parentSchemaComponent(){return this.hasOwnData?null:this.parentComponent.schemaComponent},panelEntries(){return zt(this.schema.panels,this.dataPath)},tabs(){return G(this.schema.tabs)},defaultTab(){let e=null;if(this.tabs){const t=Object.values(this.tabs).filter(this.shouldRenderSchema);for(const{name:o,defaultTab:s}of t){if(h.isFunction(s)?s(this.context):s)return o;e??=o}}return e},routeTab(){return this.$route.hash?.slice(1)||null},clipboard(){return this.schema?.clipboard??null},hasHeader(){return this.hasLabel||this.hasTabs||!!this.clipboard},headerTeleport(){return this.isTopLevelSchema?".dito-header__teleport":this.labelNode},processedData(){return this.processData({target:"server",schemaOnly:!0})},clipboardData:{get(){return this.processData({target:"clipboard",schemaOnly:!0})},set(e){this.setData(e)}},clipboardItem(){return this.clipboardData},formLabel(){return this.getLabel(this.getItemFormSchema(this.sourceSchema,this.data,this.context))},isNested(){return Ae(this.schema)},isDirty(){return this.someComponent(e=>e.isDirty)},isTouched(){return this.someComponent(e=>e.isTouched)},isValid(){return this.everyComponent(e=>e.isValid)},isValidated(){return this.everyComponent(e=>e.isValidated)},hasErrors(){return this.someComponent(e=>e.hasErrors)},hasData(){return!!this.data},hasLabel(){return!!this.label||this.collapsible},hasTabs(){return!!this.tabs},isTopLevelSchema(){return!this.isNested&&!this.inlined},hasTopLevelTabs(){return this.hasTabs&&this.isTopLevelSchema},hasMainPane(){const{components:e}=this.schema;return!!e&&Object.keys(e).length>0},opened:Ne("opened",{default(){return!this.collapsed}}),components(){return Object.values(this.componentsRegistry)},panes(){return Object.values(this.panesRegistry)},panels(){return Object.values(this.panelsRegistry)},componentsByDataPath(){return this._listEntriesByDataPath(this.componentsRegistry)},panesByDataPath(){return this._listEntriesByDataPath(this.panesRegistry)},panelsByDataPath(){return this._listEntriesByDataPath(this.panelsRegistry)},wide:b("wide",{type:Boolean,default:!1})},watch:{schema:{immediate:!0,handler(e){Fo(e)||this.setupSchema()}},routeTab:{immediate:!0,flush:"post",handler(e){this.hasTopLevelTabs&&(this.selectedTab=e)}},selectedTab(e,t){if(this.scrollable){const{content:o}=this.$refs;this.scrollPositions[t]=o.scrollTop,this.$nextTick(()=>{o.scrollTop=this.scrollPositions[e]??0})}if(this.hasTopLevelTabs){const o=this.shouldRenderSchema(this.tabs[e])?e:this.defaultTab;this.$router.replace({query:this.$route.query,hash:o?`#${o}`:null})}this.hasErrors&&this.repositionErrors()}},created(){this._register(!0),this.scrollable&&this.wide&&(this.appState.pageClass="dito-page--wide")},mounted(){this.selectedTab=this.routeTab||this.defaultTab},unmounted(){this.emitEvent("destroy"),this._register(!1),this.scrollable&&this.wide&&(this.appState.pageClass=null)},methods:{setupSchema(){this.setupSchemaFields(),this.delegate("change",this.parentSchemaComponent),this.emitEvent("initialize")},getComponentsByDataPath(e){return this._getEntriesByDataPath(this.componentsByDataPath,e)},getComponentByDataPath(e){return this.getComponentsByDataPath(e)[0]||null},getComponentsByName(e){return this._getEntriesByName(this.componentsByDataPath,e)},getComponentByName(e){return this.getComponentsByName(e)[0]||null},getComponents(e){return this._getEntries(this.componentsByDataPath,e)},getComponent(e){return this.getComponents(e)[0]||null},getPanelsByDataPath(e){return this._getEntriesByDataPath(this.panelsByDataPath,e)},getPanelByDataPath(e){return this.getPanelsByDataPath(e)[0]||null},getPanels(e){return this._getEntries(this.panelsByDataPath,e)},getPanel(e){return this.getPanels(e)[0]||null},someComponent(e){return this.isPopulated&&this.components.some(e)},everyComponent(e){return this.isPopulated&&this.components.every(e)},onOpen(e){this.emitEvent("open",{context:{open:e}}),(!this.opened||e||this.validateAll())&&(this.opened=e)},onChange(){this.emitEvent("change")},resetValidation(){for(const e of this.components)e.resetValidation()},clearErrors(){for(const e of this.components)e.clearErrors()},repositionErrors(){const e=this.$refs.content.closest(".dito-scroll"),t=()=>e.dispatchEvent(new Event("scroll"));t(),setTimeout(t,0)},focus(){return this.opened=!0,this.parentSchemaComponent?.focus()},validateAll(e,t=!0){const{componentsByDataPath:o}=this;let s;if(e){const r=h.isFunction(e)?e:h.isRegExp(e)?l=>e.test(l):null;s=r?Object.keys(o).filter(r):h.isArray(e)?e:[e]}t&&this.clearErrors();let i=!0,a=!0;s||=Object.keys(o);for(const r of s){const l=this.getComponentsByDataPath(r);for(const d of l)d.validate(t)||(t&&a&&d.scrollIntoView(),a=!1,i=!1)}return t&&!i&&this.notifyErrors(),i},verifyAll(e){return this.validateAll(e,!1)},async showValidationErrors(e,t,o=!0){this.clearErrors();const s=[],i=o;for(const[a,r]of Object.entries(e)){const l=this.hasOwnData?O(this.dataPath,a):a,d=h.parseDataPath(l);let c=!1;const p=this.getComponentsByDataPath(d);for(const u of p)if(u.showValidationErrors(r,o&&t)){c=!0,o=!1;break}if(!c){const u=d.pop();for(;d.length>0;){const f=this.getComponentsByDataPath(d);for(const g of f)if(await g.navigateToComponent?.(l,V=>{let w=!1;for(const $ of V){const P=Object.fromEntries(Object.entries(e).filter(([N])=>h.normalizeDataPath(N).startsWith($.dataPath)));if(Object.keys(P).length>0&&$.showValidationErrors(P,o&&t)){w=!0,o=!1;break}}return w}))return;d.pop()}const m=h.labelize(u);for(const f of r){const g=m?`The field ${m}`:`The ${this.formLabel}`;s.push(`${g} ${f.message}`)}}o=!1}return i&&!o&&this.notifyErrors(s.join(`
2
+ `)),!o},notifyErrors(e){this.notify({type:"error",title:"Validation Errors",text:e||"Please correct the highlighted errors."})},resetData(){Object.assign(this.data,Lt(this.dataSchema,{},this)),this.clearErrors()},setData(e){for(const t in e)if(t in this.data&&!h.equals(this.data[t],e[t])){this.data[t]=e[t];for(const o of this.getComponentsByName(t))o.markDirty()}},filterData(e){const t={},o={};for(const[s,i]of Object.entries(e)){if((h.isArray(i)||h.isObject(i))&&this.getComponentsByName(s).some(r=>r.providesData)){o[s]=i;continue}t[s]=i}return{localData:t,foreignData:o}},processData({target:e="clipboard",schemaOnly:t=!0}={}){return jo(this.dataSchema,this.sourceSchema,this.data,this.dataPath,{rootData:this.rootData,component:this,schemaOnly:t,target:e})},_register(e){this.$schemaParentComponent()?._registerSchemaComponent(this,e)},_registerComponent(e,t){this._registerEntry(this.componentsRegistry,e,t),this.parentSchemaComponent?._registerComponent(e,t)},_registerPane(e,t){this._registerEntry(this.panesRegistry,e,t)},_registerPanel(e,t){this._registerEntry(this.panelsRegistry,e,t)},_registerEntry(e,t,o){const s=t.$uid;o?e[s]=t:delete e[s]},_listEntriesByDataPath(e){return Object.values(e).reduce((t,o)=>{const{dataPath:s}=o;return(t[s]||=[]).push(o),t},{})},_getEntries(e,t){return h.normalizeDataPath(t).startsWith(this.dataPath)?this._getEntriesByDataPath(e,t):this._getEntriesByName(e,t)},_getEntriesByDataPath(e,t){return e[h.normalizeDataPath(t)]||[]},_getEntriesByName(e,t){return e[O(this.dataPath,t)]||[]}}}),yi=y(bi,[["render",gi]]);function ki(e,t,o,s,i,a){const r=n.resolveComponent("DitoEditButtons"),l=n.resolveComponent("DitoSchema");return n.openBlock(),n.createBlock(l,{class:"dito-schema-inlined",schema:e.schema,dataPath:e.dataPath,data:e.data,meta:e.meta,store:e.store,label:e.isCompact?null:e.label,info:e.info,padding:e.padding??"inlined",inlined:!0,disabled:e.disabled,compact:e.isCompact,collapsed:e.collapsed,collapsible:e.collapsible,generateLabels:!e.isCompact,labelNode:e.labelNode,accumulatedBasis:e.accumulatedBasis},{"edit-buttons":n.withCtx(()=>[e.deletable||e.draggable||e.editable?(n.openBlock(),n.createBlock(r,{key:0,schema:e.schema,dataPath:e.dataPath,data:e.data,meta:e.meta,store:e.store,disabled:e.disabled,deletable:e.deletable,draggable:e.draggable,editable:e.editable,editPath:e.editPath,onDelete:t[0]||(t[0]=d=>e.$emit("delete"))},null,8,["schema","dataPath","data","meta","store","disabled","deletable","draggable","editable","editPath"])):n.createCommentVNode("",!0)]),_:1},8,["schema","dataPath","data","meta","store","label","info","padding","disabled","compact","collapsed","collapsible","generateLabels","labelNode","accumulatedBasis"])}const Ci=C.component("DitoSchemaInlined",{emits:["delete"],props:{schema:{type:Object,required:!0},dataPath:{type:String,required:!0},data:{type:Object,required:!0},meta:{type:Object,required:!0},store:{type:Object,required:!0},label:{type:[String,Object],default:null},info:{type:String,default:null},padding:{type:String,default:null},disabled:{type:Boolean,required:!0},collapsed:{type:Boolean,default:!1},collapsible:{type:Boolean,default:!1},draggable:{type:Boolean,default:!1},editable:{type:Boolean,default:!1},deletable:{type:Boolean,default:!1},editPath:{type:String,default:null},labelNode:{type:HTMLElement,default:null},accumulatedBasis:{type:Number,default:null}},computed:{isCompact(){return Et(this.schema)},hasLabel(){return!this.isCompact&&!!this.label}}}),$i=y(Ci,[["render",ki]]),Di={key:0,class:"dito-pane__break"},Bi={key:2,class:"dito-pane__break"};function wi(e,t,o,s,i,a){const r=n.resolveComponent("DitoContainer"),l=n.resolveDirective("resize");return e.isPopulated&&e.componentSchemas.length>0?n.withDirectives((n.openBlock(),n.createElementBlock("div",{key:0,class:n.normalizeClass(["dito-pane",e.classes])},[(n.openBlock(!0),n.createElementBlock(n.Fragment,null,n.renderList(e.componentSchemas,({schema:d,dataPath:c,nestedDataPath:p,nested:u,store:m},f)=>(n.openBlock(),n.createElementBlock(n.Fragment,null,[["before","both"].includes(d.break)?(n.openBlock(),n.createElementBlock("span",Di)):n.createCommentVNode("",!0),e.shouldRenderSchema(d)?(n.openBlock(),n.createBlock(r,{ref_for:!0,ref:"containers",key:p,"data-index":f,schema:d,dataPath:c,data:e.data,meta:e.meta,store:m,single:e.isSingleComponent,nested:u,disabled:e.disabled,compact:e.compact,generateLabels:e.generateLabels,verticalLabels:e.isInLabeledRow(f),accumulatedBasis:e.accumulatedBasis},null,8,["data-index","schema","dataPath","data","meta","store","single","nested","disabled","compact","generateLabels","verticalLabels","accumulatedBasis"])):n.createCommentVNode("",!0),["after","both"].includes(d.break)?(n.openBlock(),n.createElementBlock("span",Bi)):n.createCommentVNode("",!0)],64))),256))],2)),[[l,e.onResizePane]]):n.createCommentVNode("",!0)}const Si=C.component("DitoPane",{mixins:[L],provide(){return{$tabComponent:()=>this.tabComponent}},props:{schema:{type:Object,required:!0},dataPath:{type:String,default:""},data:{type:Object,default:null},meta:{type:Object,required:!0},store:{type:Object,required:!0},tab:{type:String,default:null},single:{type:Boolean,default:!1},padding:{type:String,default:null},disabled:{type:Boolean,default:!1},compact:{type:Boolean,default:!1},generateLabels:{type:Boolean,default:!1},accumulatedBasis:{type:Number,default:null}},data(){return{positions:[]}},computed:{nested(){return!1},classes(){const e="dito-pane";return{[`${e}--single`]:this.isSingleComponent,[`${e}--padding-${this.padding}`]:!!this.padding}},tabComponent(){return this.tab?this:this.$tabComponent()},componentSchemas(){const e=this.sourceSchema?.wrapPrimitives;return Object.entries(this.schema?.components||{}).map(([t,o])=>{o={...o,name:t};const s=Ae(o),i=O(this.dataPath,t);return{schema:o,dataPath:s&&!e?i:this.dataPath,nestedDataPath:i,nested:s,store:this.getChildStore(t)}})},isSingleComponent(){return this.single&&this.componentSchemas.length===1},verticalLabelsByIndices(){const{positions:e}=this,t=r=>e[r]&&(r===e.length-1||o(r).top>e[r].top),o=r=>{for(let l=r+1;l<e.length;l++)if(e[l])return e[l];return 0},s=[];let i=[];for(let r=0;r<e.length;r++)i.push(r),t(r)&&(s.push(i),i=[]);i.length>0&&s.push(i);const a=[];for(const r of s){let l=!1;for(const d of r){const c=this.positions[d];if(c?.height>2&&(c.node.matches(":has(> .dito-label)")||c.node.closest(".dito-container").matches(".dito-container--label-vertical"))){l=!0;break}}for(const d of r)a[d]=l}return a}},watch:{"componentSchemas.length"(e){this.positions.length=e}},created(){this._register(!0)},unmounted(){this._register(!1)},methods:{_register(e){this.schemaComponent._registerPane(this,e)},focus(){if(this.tab)return this.$router.push({hash:`#${this.tab}`})},onResizePane(){this.$nextTick(()=>{for(const e of this.$refs.containers){const t=e.$el,o=+t.dataset.index,s=t.getBoundingClientRect(),i=getComputedStyle(t),a=parseFloat(i.padding),r=parseFloat(i.fontSize),l=s.height-2*a;this.positions[o]=l<=0?null:{top:s.y,height:l/r,node:t}}})},isInLabeledRow(e){return!!this.verticalLabelsByIndices[e]}}}),Vi=y(Si,[["render",wi]]);function Pi(e){const t=h.isString(e)&&e.match(/^\s*([+-]?\d+)\s*\/\s*([+-]?\d+)\s*$/);if(t){const[,o,s]=t;return parseFloat(o)/parseFloat(s)}else return parseFloat(e)}function Ei(e,t,o,s,i,a){const r=n.resolveComponent("DitoPanels"),l=n.resolveComponent("DitoLabel"),d=n.resolveComponent("DitoErrors");return n.withDirectives((n.openBlock(),n.createElementBlock("div",{class:n.normalizeClass(["dito-container",e.containerClasses]),style:n.normalizeStyle(e.containerStyles)},[e.isMounted&&e.panelEntries.length>0?(n.openBlock(),n.createBlock(n.Teleport,{key:0,to:".dito-sidebar__teleport"},[n.createVNode(r,{panels:e.panelEntries,data:e.data,meta:e.meta,store:e.store,disabled:e.disabled},null,8,["panels","data","meta","store","disabled"])])):n.createCommentVNode("",!0),e.hasLabel?(n.openBlock(),n.createBlock(l,{key:1,class:n.normalizeClass(e.labelClasses),dataPath:e.labelDataPath,label:e.label,info:e.info},null,8,["class","dataPath","label","info"])):n.createCommentVNode("",!0),e.hasLabel&&e.isLabel?n.createCommentVNode("",!0):(n.openBlock(),n.createBlock(n.resolveDynamicComponent(e.typeComponent),{key:2,class:n.normalizeClass(["dito-component",e.componentClasses]),ref:"component",schema:e.schema,dataPath:e.dataPath,data:e.data,meta:e.meta,store:e.store,width:e.width,label:e.label,single:e.single,nested:e.nested,accumulatedBasis:e.combinedBasis,onErrors:e.onErrors,"onUpdate:component":t[0]||(t[0]=c=>e.component=c)},null,40,["class","schema","dataPath","data","meta","store","width","label","single","nested","accumulatedBasis","onErrors"])),n.createVNode(d,{errors:e.errors},null,8,["errors"])],6)),[[n.vShow,e.componentVisible]])}const Ni=C.component("DitoContainer",{mixins:[ae,L],props:{schema:{type:Object,required:!0},dataPath:{type:String,default:""},data:{type:[Object,Array],required:!0},meta:{type:Object,required:!0},store:{type:Object,required:!0},single:{type:Boolean,default:!1},nested:{type:Boolean,default:!0},disabled:{type:Boolean,required:!0},compact:{type:Boolean,default:!1},generateLabels:{type:Boolean,default:!1},verticalLabels:{type:Boolean,default:!1},accumulatedBasis:{type:Number,default:null}},data(){return{errors:null,component:null}},computed:{context(){return new S(this.component??this,{nested:this.nested})},name(){return this.schema.name},type(){return this.schema.type},typeComponent(){return ie(this.type)},isLabel(){return this.type==="label"},hasLabel(){return Io(this.schema,this.generateLabels)},label(){return this.hasLabel?this.getLabel(this.schema):null},labelDataPath(){return this.nested?this.dataPath:null},info:b("info",{type:String,default:null}),width:b("width",{type:[String,Number],default(){return this.typeComponent?.defaultWidth},get(e){return e===void 0?1:h.isString(e)?e.match(/^\s*[<>]?\s*(.*)$/)[1]:e}}),widthOperator:b("width",{type:String,get(e){return h.isString(e)&&e.match(/^\s*([<>]?)/)[1]||null}}),componentVisible:b("visible",{type:Boolean,default(){return this.typeComponent?.defaultVisible}}),componentDisabled:b("disabled",{type:Boolean,default:!1,get(e){return e||this.disabled}}),flexGrow(){return this.widthOperator===">"||this.width==="fill"},flexShrink(){return this.widthOperator==="<"},flexBasis(){const e=this.width;return[null,"auto","fill"].includes(e)?"auto":/%$/.test(e)?parseFloat(e)/100:/[a-z]/.test(e)?e:Pi(e)},combinedBasis(){const{accumulatedBasis:e,flexBasis:t}=this;return h.isNumber(e)&&h.isNumber(t)?e*t:null},containerClasses(){const{class:e}=this.schema,t="dito-container";return{[`${t}--disabled`]:this.componentDisabled,[`${t}--has-errors`]:!!this.errors,[`${t}--single`]:this.single,[`${t}--compact`]:this.compact,[`${t}--label-vertical`]:this.verticalLabels,[`${t}--omit-spacing`]:Mo(this.schema),...h.isString(e)?{[e]:!0}:e}},containerStyles(){const{flexBasis:e,combinedBasis:t}=this;return{"--grow":this.flexGrow?1:0,"--shrink":this.flexShrink?1:0,"--basis":h.isNumber(e)?`${e*100}%`:e,"--basis-mobile":h.isNumber(t)&&t<=.25?`${e*200}%`:null}},componentClasses(){return{"dito-component--single":this.single,...this.getLayoutClasses("dito-component")}},labelClasses(){return{"dito-label--visible":this.isLabel,...this.getLayoutClasses("dito-label")}},panelEntries(){return zo(this.api,this.schema,this.dataPath,this.$refs.component,this.tabComponent)}},methods:{getLayoutClasses(e){return{[`${e}--fill`]:this.width==="fill"||this.flexBasis!=="auto",[`${e}--grow`]:this.flexGrow,[`${e}--shrink`]:this.flexShrink}},onErrors(e){this.errors=e}}}),Oi=y(Ni,[["render",Ei]]),Ti={class:"dito-tabs"},Li=["onClick"];function Fi(e,t,o,s,i,a){return n.openBlock(),n.createElementBlock("div",Ti,[(n.openBlock(!0),n.createElementBlock(n.Fragment,null,n.renderList(e.tabs,(r,l)=>(n.openBlock(),n.createElementBlock(n.Fragment,null,[e.shouldRenderSchema(r)?(n.openBlock(),n.createElementBlock("a",{class:n.normalizeClass(["dito-tabs__link",{"dito-tabs__link--active":e.modelValue===l}]),key:l,onClick:d=>e.$emit("update:modelValue",l)},n.toDisplayString(e.getLabel(r,l)),11,Li)):n.createCommentVNode("",!0)],64))),256))])}const Ii=C.component("DitoTabs",{emits:["update:modelValue"],props:{tabs:{type:Object,default:null},modelValue:{type:String,default:null}}}),Mi=y(Ii,[["render",Fi]]);function Ri(e,t,o,s,i,a){const r=n.resolveComponent("DitoButtons"),l=n.resolveComponent("DitoSchema");return e.shouldRenderSchema(e.panelSchema)?n.withDirectives((n.openBlock(),n.createBlock(n.resolveDynamicComponent(e.panelTag),{key:0,class:"dito-panel",onSubmit:t[0]||(t[0]=n.withModifiers(()=>{},["prevent"]))},{default:n.withCtx(()=>[n.createVNode(l,{class:"dito-panel__schema",schema:e.panelSchema,dataSchema:e.panelDataSchema,dataPath:e.panelDataPath,data:e.panelData,meta:e.meta,store:e.store,padding:"nested",disabled:e.disabled,hasOwnData:e.hasOwnData,generateLabels:""},{prepend:n.withCtx(()=>[n.createElementVNode("h2",{class:n.normalizeClass(["dito-panel__header",{"dito-panel__header--sticky":e.sticky}])},[n.createElementVNode("span",null,n.toDisplayString(e.getLabel(e.schema)),1),n.createVNode(r,{class:"dito-buttons--small",buttons:e.panelButtonSchemas,dataPath:e.panelDataPath,data:e.panelData,meta:e.meta,store:e.store,disabled:e.disabled},null,8,["buttons","dataPath","data","meta","store","disabled"])],2)]),buttons:n.withCtx(()=>[n.createVNode(r,{buttons:e.buttonSchemas,dataPath:e.panelDataPath,data:e.panelData,meta:e.meta,store:e.store,disabled:e.disabled},null,8,["buttons","dataPath","data","meta","store","disabled"])]),_:1},8,["schema","dataSchema","dataPath","data","meta","store","disabled","hasOwnData"])]),_:1},544)),[[n.vShow,e.visible&&(!e.panelTabComponent||e.panelTabComponent.visible)]]):n.createCommentVNode("",!0)}const ji=C.component("DitoPanel",{mixins:[L,vt],provide(){return{$panelComponent:()=>this,$tabComponent:()=>this.panelTabComponent}},props:{schema:{type:Object,required:!0},dataPath:{type:String,required:!0},data:{type:Object,required:!0},meta:{type:Object,required:!0},store:{type:Object,required:!0},disabled:{type:Boolean,required:!0},panelTabComponent:{type:Object,default:null}},data(){return{ownData:null}},computed:{nested(){return!0},panelComponent(){return this},tabComponent(){return this.panelTabComponent},buttonSchemas(){return v(this.schema.buttons)},panelButtonSchemas(){return v(this.schema.panelButtons)},hasOwnData(){return!!this.ownData},panelData(){return this.ownData||this.data},panelSchema(){if(this.hasOwnData)return this.schema;{const{data:e,...t}=this.schema;return t}},panelTag(){return this.hasOwnData?"form":"div"},panelDataSchema(){return this.hasOwnData?this.schema:this.schemaComponent.schema},panelDataPath(){return this.hasOwnData?this.dataPath:this.schemaComponent.dataPath},visible:b("visible",{type:Boolean,default:!0}),sticky:b("sticky",{type:Boolean,default:!1})},created(){this._register(!0);const{data:e}=this.schema;e&&(this.ownData=h.isFunction(e)?e(this.context):e)},unmounted(){this._register(!1)},methods:{_register(e){this.schemaComponent._registerPanel(this,e)}}}),zi=y(ji,[["render",Ri]]),Ai={key:0,class:"dito-panels"};function qi(e,t,o,s,i,a){const r=n.resolveComponent("DitoPanel");return e.panels.length>0?(n.openBlock(),n.createElementBlock("div",Ai,[(n.openBlock(!0),n.createElementBlock(n.Fragment,null,n.renderList(e.panels,({schema:l,dataPath:d,tabComponent:c})=>(n.openBlock(),n.createElementBlock(n.Fragment,null,[e.shouldRenderSchema(l)?(n.openBlock(),n.createBlock(r,{key:e.getPanelKey(d,c),schema:l,dataPath:d,data:e.data,meta:e.meta,store:e.getChildStore(l.name),disabled:l.disabled??e.disabled,panelTabComponent:c},null,8,["schema","dataPath","data","meta","store","disabled","panelTabComponent"])):n.createCommentVNode("",!0)],64))),256))])):n.createCommentVNode("",!0)}const Ui=C.component("DitoPanels",{mixins:[L],props:{panels:{type:Array,default:null},data:{type:Object,required:!0},meta:{type:Object,required:!0},store:{type:Object,required:!0},disabled:{type:Boolean,required:!0}},computed:{nested(){return!1}},methods:{getPanelKey(e,t){return t?`${t.tab}_${e}`:e}}}),Hi=y(Ui,[["render",qi]]),Wi={key:0,class:"dito-buttons"},Ki={key:0,class:"dito-container"};function Yi(e,t,o,s,i,a){const r=n.resolveComponent("DitoContainer"),l=n.resolveComponent("DitoVnode");return e.buttonSchemas||e.hasSlotContent(e.$slots.default)?(n.openBlock(),n.createElementBlock("div",Wi,[(n.openBlock(!0),n.createElementBlock(n.Fragment,null,n.renderList(e.buttonSchemas,(d,c)=>(n.openBlock(),n.createElementBlock(n.Fragment,null,[e.shouldRenderSchema(d)?(n.openBlock(),n.createBlock(r,{key:c,schema:d,dataPath:c,data:e.data,meta:e.meta,nested:e.nested,store:e.getChildStore(d.name),disabled:e.disabled},null,8,["schema","dataPath","data","meta","nested","store","disabled"])):n.createCommentVNode("",!0)],64))),256)),(n.openBlock(!0),n.createElementBlock(n.Fragment,null,n.renderList(e.$slots.default?.(),d=>(n.openBlock(),n.createElementBlock(n.Fragment,null,[e.hasVNodeContent(d)?(n.openBlock(),n.createElementBlock("div",Ki,[n.createVNode(l,{vnode:d},null,8,["vnode"])])):n.createCommentVNode("",!0)],64))),256))])):n.createCommentVNode("",!0)}const Ji=C.component("DitoButtons",{mixins:[L],provide:{$tabComponent:()=>null},props:{buttons:{type:Object,default:null},dataPath:{type:String,default:""},data:{type:[Object,Array],default:null},meta:{type:Object,default:()=>({})},store:{type:Object,default:()=>({})},nested:{type:Boolean,default:!0},disabled:{type:Boolean,default:!1}},computed:{buttonSchemas(){const{dataPath:e,buttons:t}=this;return t?Object.values(t).reduce((o,s)=>(o[O(e,s.name)]=s,o),{}):null}},methods:{hasSlotContent:ne,hasVNodeContent:Wt}}),Gi=y(Ji,[["render",Yi]]),Qi=["disabled"];function Xi(e,t,o,s,i,a){const r=n.resolveComponent("RouterLink"),l=n.resolveComponent("DitoCreateButton"),d=n.resolveComponent("DitoButtons");return n.openBlock(),n.createBlock(d,{class:"dito-edit-buttons dito-buttons--round",buttons:e.buttons,dataPath:e.dataPath,data:e.data,meta:e.meta,store:e.store,nested:e.nested,onClick:t[1]||(t[1]=n.withModifiers(()=>{},["stop"]))},{default:n.withCtx(()=>[e.draggable?(n.openBlock(),n.createElementBlock("a",n.mergeProps({key:0,class:["dito-button",{"dito-button--disabled":e.isDraggableDisabled}]},e.getButtonAttributes(e.verbs.drag)),null,16)):n.createCommentVNode("",!0),e.editable?(n.openBlock(),n.createBlock(r,n.mergeProps({key:1,class:["dito-button",{"dito-button--disabled":e.isEditableDisabled}],to:e.editPath?{path:e.editPath}:{}},e.getButtonAttributes(e.verbs.edit)),null,16,["class","to"])):n.createCommentVNode("",!0),e.creatable?(n.openBlock(),n.createBlock(l,{key:2,schema:e.schema,dataPath:e.dataPath,data:e.data,meta:e.meta,store:e.store,nested:e.nested,path:e.createPath,verb:e.verbs.create,text:e.createButtonText,disabled:e.isCreatableDisabled},null,8,["schema","dataPath","data","meta","store","nested","path","verb","text","disabled"])):n.createCommentVNode("",!0),e.deletable?(n.openBlock(),n.createElementBlock("button",n.mergeProps({key:3,class:"dito-button",type:"button",disabled:e.isDeletableDisabled},e.getButtonAttributes(e.verbs.delete),{onClick:t[0]||(t[0]=c=>e.$emit("delete"))}),null,16,Qi)):n.createCommentVNode("",!0)]),_:1},8,["buttons","dataPath","data","meta","store","nested"])}const Zi=C.component("DitoEditButtons",{mixins:[L],emits:["delete"],props:{buttons:{type:Object,default:null},schema:{type:Object,required:!0},dataPath:{type:String,required:!0},data:{type:[Object,Array],default:null},meta:{type:Object,required:!0},store:{type:Object,required:!0},nested:{type:Boolean,default:!1},disabled:{type:Boolean,required:!0},draggable:{type:Boolean,default:!1},editable:{type:Boolean,default:!1},creatable:{type:Boolean,default:!1},deletable:{type:Boolean,default:!1},editPath:{type:String,default:null},createPath:{type:String,default:null}},computed:{formLabel(){return this.getLabel(this.schema.form)},isDraggableDisabled(){return this.disabled||!this.hasSchemaOption("draggable")},isDeletableDisabled(){return this.disabled||!this.hasSchemaOption("deletable")},isEditableDisabled(){return this.disabled||!this.editPath||!this.hasSchemaOption("editable")},isCreatableDisabled(){return this.disabled||!this.createPath||!this.hasSchemaOption("creatable")},createButtonText(){return this.schema.creatable?.label||this.formLabel&&`${h.capitalize(this.verbs.create)} ${this.formLabel}`||null}},methods:{hasSchemaOption(e){return this.getSchemaValue(e,{type:Boolean,default:!0})}}}),_i=y(Zi,[["render",Xi]]),xi={class:"dito-create-button"},vi=["type","disabled"],er=["disabled"],tr=["onMousedown","onMouseup"];function nr(e,t,o,s,i,a){return n.openBlock(),n.createElementBlock("div",xi,[e.creatableForm?(n.openBlock(),n.createElementBlock("button",n.mergeProps({key:0,class:"dito-button",type:e.isInlined?"button":"submit",disabled:e.disabled},e.getButtonAttributes(e.verb),{onClick:t[0]||(t[0]=r=>e.createItem(e.creatableForm))}),n.toDisplayString(e.text),17,vi)):e.creatableForms?(n.openBlock(),n.createElementBlock(n.Fragment,{key:1},[n.createElementVNode("button",n.mergeProps({class:"dito-button",type:"button",disabled:e.disabled},e.getButtonAttributes(e.verb),{onMousedown:t[1]||(t[1]=n.withModifiers(r=>e.onPulldownMouseDown(),["stop"]))}),n.toDisplayString(e.text),17,er),n.createElementVNode("ul",{class:n.normalizeClass(["dito-pulldown",{"dito-pulldown--open":e.pulldown.open}])},[(n.openBlock(!0),n.createElementBlock(n.Fragment,null,n.renderList(e.creatableForms,(r,l)=>n.withDirectives((n.openBlock(),n.createElementBlock("li",null,[n.createElementVNode("a",{class:n.normalizeClass(["dito-pulldown__item",{"dito-pulldown__item--disabled":e.shouldDisableSchema(r)}]),onMousedown:n.withModifiers(d=>e.onPulldownMouseDown(l),["stop"]),onMouseup:d=>e.onPulldownMouseUp(l)},n.toDisplayString(e.getLabel(r)),43,tr)],512)),[[n.vShow,e.shouldShowSchema(r)]])),256))],2)],64)):n.createCommentVNode("",!0)])}const or=C.component("DitoCreateButton",{mixins:[L,an],props:{schema:{type:Object,required:!0},dataPath:{type:String,required:!0},data:{type:[Object,Array],default:null},meta:{type:Object,required:!0},store:{type:Object,required:!0},nested:{type:Boolean,default:!1},path:{type:String,required:!0},verb:{type:String,required:!0},text:{type:String,default:null},disabled:{type:Boolean,required:!0}},computed:{forms(){return Y(this.schema,this.context)},creatableForms(){const e=Object.entries(this.forms).filter(([,t])=>this.isFormCreatable(t));return e.length>0?Object.fromEntries(e):null},creatableForm(){const e=this.creatableForms;return e&&Object.keys(e).length===1&&e.default||null},isInlined(){return ze(this.schema)}},methods:{isFormCreatable(e){return this.shouldRenderSchema(e)&&this.getSchemaValue("creatable",{type:Boolean,default:!0,schema:e})},createItem(e,t=null){if(this.shouldDisableSchema(e))throw new Error("Not allowed to create item for given form");if(this.isInlined)this.sourceComponent.createItem(e,t);else{const{creatable:o}=this.schema,s={...t&&{type:t},...o?.query?.(this.context)};this.$router.push({path:`${this.path}/create`,query:s})}},onPulldownSelect(e){this.createItem(this.forms[e],e),this.setPulldownOpen(!1)}}}),sr=y(or,[["render",nr]]),ar={key:0,class:"dito-clipboard dito-buttons dito-buttons--round"},ir=["disabled"],rr=["disabled"];function lr(e,t,o,s,i,a){return e.clipboard?(n.openBlock(),n.createElementBlock("div",ar,[n.createElementVNode("button",{class:"dito-button dito-button--copy",ref:"copyData",type:"button",title:"Copy Data",disabled:!e.copyEnabled,onClick:t[0]||(t[0]=(...r)=>e.onCopy&&e.onCopy(...r))},null,8,ir),n.createElementVNode("button",{class:"dito-button dito-button--paste",type:"button",title:"Paste Data",disabled:!e.pasteEnabled,onClick:t[1]||(t[1]=(...r)=>e.onPaste&&e.onPaste(...r))},null,8,rr)])):n.createCommentVNode("",!0)}const dr=C.component("DitoClipboard",{mixins:[H],props:{clipboard:{type:[Boolean,Object],required:!0},schema:{type:Object,required:!0}},data(){return{copyEnabled:!1,pasteEnabled:!1}},computed:{clipboardOptions(){return h.isObject(this.clipboard)?this.clipboard:{}},copyData(){const{copy:e}=this.clipboardOptions;return e?t=>e.call(this,new S(this,{clipboardData:t})):t=>h.clone(t)},pasteData(){const{paste:e}=this.clipboardOptions;return e?t=>e.call(this,new S(this,{clipboardData:t})):t=>t}},watch:{"parentComponent.hasData":{immediate:!0,handler:"updateCopy"},"appState.clipboardData":{immediate:!0,handler:"updatePaste"}},mounted(){this.domOn(document,{copy:this.updatePaste}),this.domOn(window,{focus:this.updatePaste})},methods:{checkClipboardData(e){const{$schema:t,...o}=e||{};return t===this.schema.name?o:null},async getClipboardData(e){let{clipboardData:t}=this.appState;try{const o=await navigator.clipboard?.readText?.();o&&(t=JSON.parse(o))}catch(o){e&&(console.error(o,o.name,o.message),o.name==="SyntaxError"&&alert(h.deindent`
3
+ The data in the clipboard appears to be malformed:
4
+ ${o.message}
5
+ `))}return this.checkClipboardData(t)},updateCopy(){this.copyEnabled=this.parentComponent.hasData},async updatePaste(){if(this.pasteEnabled=!!this.checkClipboardData(this.appState.clipboardData),!this.pasteEnabled&&this.appState.agent.chrome){const e=await this.getClipboardData(!1);this.pasteEnabled=!!e}},async onCopy(){let e=this.parentComponent.clipboardData;try{e&&(e={$schema:this.schema.name,...this.copyData(e)}),this.appState.clipboardData=e,this.pasteEnabled=!0;try{const t=JSON.stringify(e,null,2);await navigator.clipboard?.writeText?.(t)}catch(t){console.error(t,t.name,t.message)}}catch(t){console.error(t),alert(t.message)}},async onPaste(){let e=await this.getClipboardData(!0);try{e=e&&this.pasteData(e),e&&(this.parentComponent.clipboardData=e)}catch(t){console.error(t),alert(t.message)}}}}),cr=y(dr,[["render",lr]]),dn={data(){return{isLoading:!1}},methods:{setLoading(e,{updateRoot:t=!1,updateView:o=!1}={}){!this.isLoading^!e&&(this.isLoading=!!e,t&&this.rootComponent.registerLoading(e),o&&this.viewComponent.setLoading(this.isLoading))}}},Ze={mixins:[be,dn],provide(){return{$resourceComponent:()=>this,$verbs:()=>this.verbs,$isPopulated:()=>this.hasData}},data(){return{loadedData:null,abortController:null}},computed:{resourceComponent(){return this},resource(){return this.getResource()},providesData(){return!!this.resource},linksToView(){return!1},isTransient(){const e=this.formComponent;return!this.providesData&&!this.linksToView||e&&(e.isTransient||e.isCreating)},transientNote(){return this.isTransient&&"<b>Note</b>: the parent still needs to be saved in order to persist this change."},shouldLoad(){return!this.isTransient&&!this.isLoading},hasData(){return!!this.loadedData},verbs(){return this.getVerbs()},paginationRange(){const{paginate:e}=this.sourceSchema;if(this.isListSource&&e){const{page:t=0}=this.query||{},o=t*e;return[o,o+e-1]}return null},queryParams(){const e=this.paginationRange,{page:t,...o}=this.query||{};return{...o,...e&&{range:e.join(",")}}}},created(){(this.providesData||this.isCreating)&&this.setupData()},methods:{getResource({method:e="get",child:t}={}){const o=this.sourceSchema?.resource;return F(o,{type:"collection",method:e,parent:this.parentResourceComponent?.getResource({method:e,child:o})??null,child:t})},getVerbs(){const e=this.$verbs();return this.isTransient?{...e,create:"add",created:"added",save:"apply",saved:"applied",delete:"remove",deleted:"removed"}:e},clearData(){this.loadedData=null},setData(e){this.loadedData=e},setupData(){this.ensureData()},ensureData(){this.shouldLoad&&(this.hasData?this.reloadData():this.loadData(!0))},reloadData(){this.loadData(!1)},loadData(e){this.isTransient||(e&&this.clearData(),this.requestData())},createData(e,t){return Lt(e,t?{type:t}:{},this)},requestData(){const e=this.queryParams;this.handleRequest({method:"get",query:e},(t,o)=>{if(t){if(o){const{data:s}=o;if(s?.type==="FilterValidation"&&this.onFilterErrors?.(s.errors))return!0;if(this.isUnauthorizedError(o))return!0}}else this.setData(o.data),this.emitSchemaEvent("load")})},isValidationError(e){return e?.status===400},isUnauthorizedError(e){return e?.status===401},async handleRequest({method:e,resource:t=this.getResource({method:e}),query:o,data:s},i){const a={updateRoot:!0,updateView:this.isInView};this.abortController?.abort();const r=new AbortController;this.abortController=r;const{signal:l}=r;e=t.method||e;const d={method:e,resource:t,query:o,data:s,signal:l};this.setLoading(!0,a);try{const c=await this.sendRequest(d);i(null,c)}catch(c){if(c.name!=="AbortError"){const{response:p}=c;if(!i(c,p)){const u=p?.data,m=h.isString(u?.type)?h.labelize(u.type):"Error",f=u?.message??c;this.notify({type:"error",error:c,title:m,text:f})}}}this.abortController===r&&(this.abortController=null,this.setLoading(!1,a))},getPayloadData(e,t){return["post","put","patch"].includes(t)&&(e.getSchemaValue(["resource","data"])||e.processedItem)},async submit(e){let{resource:t}=e.schema;if(t=F(t,{parent:this.getResource({method:t?.method,child:t})}),t){const{method:o}=t,s=this.getPayloadData(e,o);return this.submitResource(e,t,o,s)}return!1},async submitResource(e,t,o,s,{setData:i=!1,onSuccess:a,onError:r,notifySuccess:l=()=>this.notify({type:"success",title:"Request Successful",text:"Request was successfully sent."}),notifyError:d=c=>this.notify({type:"error",error:c,title:"Request Error",text:[`Unable to send request${c?":":""}`,c?.message||c]})}={}){return new Promise(c=>{this.handleRequest({method:o,resource:t,data:s},async(p,u)=>{const m=u?.data;if(p){const f=this.isValidationError(u)&&m.errors;if(f)await this.showValidationErrors(f,!0);else{const g=h.isObject(m)?m:p;r?.(g),await this.emitButtonEvent(e,"error",{notify:d,error:g})}c(!1)}else{if(i&&m){const{foreignData:f}=this.mainSchemaComponent.filterData(this.data),g=this.parentRouteComponent?.routeRecord?.meta;g&&(g.reload=!0),this.setData(h.assignDeeply({},f,m))}a?.(),await this.emitButtonEvent(e,"success",{notify:l}),c(!0)}})})},async emitButtonEvent(e,t,{notify:o,error:s}){const i=new S(e,{nested:!1,data:this.data,itemLabel:this.itemLabel,error:s}),a=await e.emitEvent(t,{context:i});return o&&a===void 0&&!i.wasNotified&&o(s),a}}};function hr(e){return new URL(`file:${e}`).pathname}const pr=["data-resource"],ur={type:"submit",disabled:""};function mr(e,t,o,s,i,a){const r=n.resolveComponent("RouterView"),l=n.resolveComponent("DitoButtons"),d=n.resolveComponent("DitoSchema"),c=n.resolveComponent("DitoFormInner");return n.openBlock(),n.createElementBlock("div",{class:n.normalizeClass(["dito-form dito-scroll-parent",{"dito-form-nested":e.isNestedRoute}]),"data-resource":e.sourceSchema.path},[!e.isLastUnnestedRoute&&!e.isNestedRoute?n.withDirectives((n.openBlock(),n.createBlock(r,{key:0},null,512)),[[n.vShow,!e.isActiveRoute]]):n.createCommentVNode("",!0),n.withDirectives(n.createVNode(c,{nested:e.isNestedRoute},{default:n.withCtx(()=>[n.withDirectives(n.createElementVNode("button",ur,null,512),[[n.vShow,!1]]),n.createVNode(d,{schema:e.schema,dataPath:e.dataPath,data:e.data,meta:e.meta,store:e.store,padding:e.isNestedRoute?"nested":"root",active:e.isActiveRoute,disabled:e.isLoading,scrollable:!e.isNestedRoute,generateLabels:""},{buttons:n.withCtx(()=>[n.createVNode(l,{class:n.normalizeClass(["dito-buttons--round dito-buttons--large dito-buttons--main",{"dito-buttons--sticky":!e.isNestedRoute}]),buttons:e.buttonSchemas,dataPath:e.dataPath,data:e.data,meta:e.meta,store:e.store,disabled:e.isLoading},null,8,["class","buttons","dataPath","data","meta","store","disabled"])]),_:1},8,["schema","dataPath","data","meta","store","padding","active","disabled","scrollable"])]),_:1},8,["nested"]),[[n.vShow,e.isActiveRoute]])],10,pr)}const fr=C.component("DitoForm",{mixins:[en,Ze],data(){return{createdData:null,clonedData:void 0,sourceKey:null,isForm:!0}},computed:{verbs(){const e=this.getVerbs(),{isCreating:t,providesData:o}=this;return{...e,submit:t?e.create:e.save,submitted:t?e.created:e.saved,cancel:o?e.cancel:e.close,cancelled:o?e.cancelled:e.closed}},schema(){return this.getItemFormSchema(this.sourceSchema,this.data||(this.creationType?{type:this.creationType}:null),this.context)},buttonSchemas(){return v(h.assignDeeply({cancel:{type:"button",events:{click:()=>this.cancel()}},submit:!this.isMutating&&{type:"submit",closeForm:!0,events:{click:({component:e})=>e.submit()}}},this.schema.buttons))},isActiveRoute(){return this.isLastRoute||this.isLastUnnestedRoute},isTransient(){return!this.providesData},isCreating(){return this.param==="create"},isDirty(){return!this.isMutating&&!!this.mainSchemaComponent?.isDirty},isMutating(){return!!this.sourceSchema.mutate},selectedTab(){return this.mainSchemaComponent?.selectedTab||null},creationType(){return this.$route.query.type},itemId(){return this.isCreating?null:this.param??null},method(){return this.isCreating?"post":"patch"},breadcrumbPrefix(){return h.capitalize(this.isCreating?this.verbs.create:this.verbs.edit)},data(){return this.createdData||this.loadedData||this.inheritedData||null},dataPath(){return this.getDataPathFrom(this.dataComponent)},sourceData(){let e=this.routeRecord?this.parentRouteComponent.data:null;if(e){const t=h.parseDataPath(this.getDataPathFrom(this.parentRouteComponent)),o=this.routeRecord.path.split("/"),s=o.slice(o.length-t.length);this.sourceKey=null;const i=t[t.length-1];ee(this.sourceSchema)&&i==="create"&&t.length--;for(let a=0,r=t.length;a<r&&e;a++){const l=t[a],d=/^:id/.test(s[a])?l==="create"?null:this.findItemIdIndex(this.sourceSchema,e,l):l;a===r-1?this.sourceKey=d:e=e[d]}}return e},inheritedData(){if(this.isTransient&&this.clonedData===void 0&&this.sourceData&&this.sourceKey!==null){let e=this.sourceData[this.sourceKey];return this.isMutating||(this.clonedData=e=h.clone(e)),e===null&&!this.isCreating&&ee(this.sourceSchema)&&this.$router.push({path:`${this.path}/create`}),e}return this.clonedData},hasData(){return!!this.data},itemLabel(){return this.getItemLabel(this.sourceSchema,this.data,{extended:!0})}},watch:{$route:{flush:"post",handler(e,t){const o=this.meta?.param;o&&this.providesData&&t.matched[0].path===e.matched[0].path&&t.params[o]!=="create"&&e.params[o]!==t.params[o]&&this.loadData(!0)}},sourceData:"clearClonedData",create:"setupData"},methods:{emitSchemaEvent(e,t){return this.mainSchemaComponent?.emitEvent(e,t)},getDataPathFrom(e){return this.api.denormalizePath(this.path.slice((e.isView?0:e.path.length)+1))},getResource(e){const t=Ze.methods.getResource.call(this,e);return We(this.itemId,t)||t},setupData(){this.isCreating?this.createdData||=this.createData(this.schema,this.creationType):this.ensureData()},setSourceData(e){if(this.sourceData&&this.sourceKey!==null){const{mainSchemaComponent:t}=this;return this.sourceData[this.sourceKey]=t.filterData(e).localData,t.onChange(),!0}return!1},addSourceData(e){return ee(this.sourceSchema)?this.setSourceData(e):!!this.sourceData?.push(e)},clearData(){this.setData(null)},setData(e){this.isTransient?this.setSourceData(e):(this.createdData=null,this.loadedData=e)},clearClonedData(e,t){e!==t&&(this.clonedData=void 0)},async cancel(){return this.close()},async close(){return this.navigate(this.parentRouteComponent.path)},getSubmitVerb(e=!0){return this.isCreating?e?"create":"created":e?"submit":"submitted"},async submit(e,{validate:t=!0,closeForm:o=!1}={}){if(t&&!this.validateAll())return!1;const s=c=>this.verbs[this.getSubmitVerb(c)];let{method:i}=this,a=this.getResource({method:i});const r=F(e.schema.resource,{parent:a});a=r||a,i=a?.method||i;const l=this.getPayloadData(e,i);let d;if(!r&&this.isTransient?d=await this.submitTransient(e,a,i,l,{onSuccess:()=>this.emitSchemaEvent(this.getSubmitVerb()),onError:c=>this.emitSchemaEvent("error",{context:{error:c}}),notifySuccess:()=>{const c=s(!1);this.notify({type:"info",title:this.isCreating?`Item ${h.capitalize(c)}`:`Change ${h.capitalize(c)}`,text:[this.isCreating?`${this.itemLabel} was ${c}.`:`Changes to ${this.itemLabel} were ${c}.`,this.transientNote]})},notifyError:c=>{const p=s(!0);this.notify({type:"error",error:c,title:"Request Error",text:`Unable to ${p} ${this.itemLabel}.`})}}):d=await this.submitResource(e,a,i,l,{setData:!0,onSuccess:()=>this.emitSchemaEvent(this.getSubmitVerb()),onError:c=>this.emitSchemaEvent("error",{context:{error:c}}),notifySuccess:()=>{const c=s(!1);this.notify({type:"success",title:`Successfully ${h.capitalize(c)}`,text:`${this.itemLabel} was ${c}.`})},notifyError:c=>{const p=s(!0);this.notify({type:"error",error:c,title:"Request Error",text:[`Unable to ${p} ${this.itemLabel}${c?":":""}`,c?.message||c]})}}),d){if(this.resetValidation(),o||e.closeForm)this.close();else if(this.isCreating){const c=this.getItemId(this.schema,this.data);this.$router.replace({path:hr(`${this.path}/../${c}`),hash:this.$route.hash})}}return d},async submitTransient(e,t,o,s,{onSuccess:i,onError:a,notifySuccess:r,notifyError:l}){const d=this.isCreating?this.addSourceData(s):this.setSourceData(s);if(d)i?.(),await this.emitButtonEvent(e,"success",{notify:r});else{const c="Could not submit transient item";a?.(c),await this.emitButtonEvent(e,"error",{notify:l,error:c})}return d}}}),cn=y(fr,[["render",mr]]),gr={key:0};function br(e,t,o,s,i,a){return e.nested?(n.openBlock(),n.createElementBlock("div",gr,[n.renderSlot(e.$slots,"default")])):(n.openBlock(),n.createElementBlock("form",{key:1,class:"dito-scroll-parent",onSubmit:t[0]||(t[0]=n.withModifiers(()=>{},["prevent"]))},[n.renderSlot(e.$slots,"default")],32))}const yr=C.component("DitoFormInner",{props:{nested:{type:Boolean,default:!1}}}),kr=y(yr,[["render",br]]),Cr=C.component("DitoFormNested",{extends:cn}),$r={key:0,class:"dito-errors"};function Dr(e,t,o,s,i,a){return e.errors?(n.openBlock(),n.createElementBlock("div",$r,[n.createElementVNode("ul",null,[(n.openBlock(!0),n.createElementBlock(n.Fragment,null,n.renderList(e.errors,r=>(n.openBlock(),n.createElementBlock("li",null,n.toDisplayString(r),1))),256))])])):n.createCommentVNode("",!0)}const Br=C.component("DitoErrors",{props:{errors:{type:Array,default:null}},data(){return{tip:null}},watch:{errors(){this.$nextTick(this.updateErrors)}},unmounted(){this.tip?.destroy()},methods:{updateErrors(){let{tip:e}=this;e?.hide(),this.errors&&(e=this.tip??=n.markRaw(tt(this.$el.closest(".dito-container"))),e.setProps({content:this.errors.join(`
6
+ `),theme:"error",trigger:"manual",appendTo:"parent",placement:"bottom-start",animation:"shift-away-subtle",popperOptions:{modifiers:[{name:"flip",enabled:!1}]},interactive:!0,hideOnClick:!1,offset:[3,3],zIndex:1}),e.popper.addEventListener("mousedown",()=>e.hide()),e.show())}}}),wr=y(Br,[["render",Dr]]),Sr={class:"dito-scopes"},Vr=["title","onClick"];function Pr(e,t,o,s,i,a){const r=n.resolveComponent("RouterLink");return n.openBlock(),n.createElementBlock("div",Sr,[(n.openBlock(!0),n.createElementBlock(n.Fragment,null,n.renderList(e.scopes,(l,d)=>(n.openBlock(),n.createBlock(r,{key:d,to:e.getScopeLink(l),custom:""},{default:n.withCtx(({navigate:c})=>[n.createElementVNode("button",{class:n.normalizeClass(["dito-button",{"dito-button--selected":l.name===e.query.scope}]),type:"button",title:l.hint||e.getLabel(l),onClick:c},n.toDisplayString(e.getLabel(l)),11,Vr)]),_:2},1032,["to"]))),128))])}const Er=C.component("DitoScopes",{props:{query:{type:Object,required:!0},scopes:{type:Object,required:!0}},methods:{getScopeLink(e){const t={...this.query,scope:e.name};return t.page&&(t.page=0),this.getQueryLink(t)}}}),Nr=y(Er,[["render",Pr]]);function Or(e,t,o,s,i,a){const r=n.resolveComponent("Pagination");return n.openBlock(),n.createBlock(r,{page:e.page,"onUpdate:page":t[0]||(t[0]=l=>e.page=l),pageSize:e.limit,total:e.total},null,8,["page","pageSize","total"])}const Tr=C.component("DitoPagination",{components:{Pagination:Js},props:{query:{type:Object,required:!0},limit:{type:Number,required:!0},total:{type:Number,required:!0}},computed:{page:{get(){return(+this.query.page||0)+1},set(e){this.page!==e&&this.$router.push(this.getQueryLink({...this.query,page:e-1}))}}}}),Lr=y(Tr,[["render",Or]]),ye={data(){return{isDragging:!1}},methods:{getDraggableOptions(e=!1){const t="dito-draggable";return{animation:150,handle:".dito-button--drag",dragClass:`${t}__drag`,chosenClass:`${t}__chosen`,ghostClass:`${t}__ghost`,fallbackClass:`${t}__fallback`,forceFallback:e,onStart:this.onStartDrag,onEnd:this.onEndDrag}},onStartDrag(){this.isDragging=!0},onEndDrag({oldIndex:e,newIndex:t}){this.isDragging=!1,e!==t&&this.onChange()},updateOrder(e,t,o){const{orderKey:s}=e;if(s){const i=o?.[0]||0;for(let a=0;a<t.length;a++)t[a][s]=a+i}return t}}},Fr=["id","data-path"],Ir={key:0,class:"dito-tree-header"},Mr=["innerHTML"],Rr={key:1,class:"dito-tree-info"},jr={key:1,class:"dito-tree-leaf"},zr=["innerHTML"],Ar={key:2,class:"dito-buttons dito-buttons--small"},qr={key:1,class:"dito-properties"};function Ur(e,t,o,s,i,a){const r=n.resolveComponent("DitoLabel"),l=n.resolveComponent("DitoTableCell"),d=n.resolveComponent("DitoTreeItem",!0),c=n.resolveComponent("DitoDraggable");return n.openBlock(),n.createElementBlock("div",{class:n.normalizeClass(["dito-tree-item",{"dito-tree-item--dragging":e.isDragging,"dito-tree-item--active":e.active}]),id:e.dataPath,style:n.normalizeStyle(e.level>0&&{"--level":e.level}),"data-path":e.path},[e.label?(n.openBlock(),n.createElementBlock("div",Ir,[e.numEntries?(n.openBlock(),n.createElementBlock("div",{key:0,class:"dito-tree-branch",onClick:t[0]||(t[0]=n.withModifiers(p=>e.opened=!e.opened,["stop"]))},[e.numEntries?(n.openBlock(),n.createElementBlock("div",{key:0,class:n.normalizeClass(["dito-chevron",{"dito-chevron--open":e.opened}])},null,2)):n.createCommentVNode("",!0),n.createElementVNode("div",{class:"dito-tree-label",innerHTML:e.label},null,8,Mr),e.details?(n.openBlock(),n.createElementBlock("div",Rr,n.toDisplayString(e.details),1)):n.createCommentVNode("",!0)])):(n.openBlock(),n.createElementBlock("div",jr,[n.createElementVNode("div",{class:"dito-tree-label",innerHTML:e.label},null,8,zr)])),e.hasEditButtons?(n.openBlock(),n.createElementBlock("div",Ar,[e.draggable?(n.openBlock(),n.createElementBlock("a",n.mergeProps({key:0,class:"dito-button"},e.getButtonAttributes(e.verbs.drag)),null,16)):n.createCommentVNode("",!0),e.editable?(n.openBlock(),n.createElementBlock("button",n.mergeProps({key:1,class:"dito-button",type:"button"},e.getButtonAttributes(e.verbs.edit),{onClick:t[1]||(t[1]=(...p)=>e.onEdit&&e.onEdit(...p))}),null,16)):n.createCommentVNode("",!0),e.deletable?(n.openBlock(),n.createElementBlock("button",n.mergeProps({key:2,class:"dito-button",type:"button"},e.getButtonAttributes(e.verbs.delete),{onClick:t[2]||(t[2]=(...p)=>e.onDelete&&e.onDelete(...p))}),null,16)):n.createCommentVNode("",!0)])):n.createCommentVNode("",!0)])):n.createCommentVNode("",!0),e.properties?n.withDirectives((n.openBlock(),n.createElementBlock("table",qr,[(n.openBlock(!0),n.createElementBlock(n.Fragment,null,n.renderList(e.properties,p=>(n.openBlock(),n.createElementBlock("tr",null,[n.createElementVNode("td",null,[p.label!==!1?(n.openBlock(),n.createBlock(r,{key:0,dataPath:e.getPropertyDataPath(p),label:e.getLabel(p)},null,8,["dataPath","label"])):n.createCommentVNode("",!0)]),n.createVNode(l,{cell:p,schema:p,dataPath:e.getPropertyDataPath(p),data:e.data,meta:e.nestedMeta,store:e.store,disabled:e.disabled},null,8,["cell","schema","dataPath","data","meta","store","disabled"])]))),256))],512)),[[n.vShow,e.opened]]):n.createCommentVNode("",!0),e.childrenSchema?n.withDirectives((n.openBlock(),n.createBlock(c,{key:2,options:e.getDraggableOptions(!0),draggable:e.childrenDraggable,modelValue:e.updateOrder(e.childrenSchema,e.childrenList),"onUpdate:modelValue":t[3]||(t[3]=p=>e.childrenList=p)},{default:n.withCtx(()=>[(n.openBlock(!0),n.createElementBlock(n.Fragment,null,n.renderList(e.childrenItems,(p,u)=>(n.openBlock(),n.createBlock(d,{key:e.getItemUid(e.childrenSchema,p.data),schema:e.childrenSchema,dataPath:e.getItemDataPath(e.childrenSchema,u),data:p.data,path:p.path,open:p.open,active:p.active,draggable:e.childrenDraggable,label:e.getItemLabel(e.childrenSchema,p.data,{index:u}),level:e.level+1},null,8,["schema","dataPath","data","path","open","active","draggable","label","level"]))),128))]),_:1},8,["options","draggable","modelValue"])),[[n.vShow,e.opened]]):n.createCommentVNode("",!0)],14,Fr)}const Hr=C.component("DitoTreeItem",{mixins:[be,ye],emits:["update:data"],inject:["container"],props:{schema:{type:Object,required:!0},dataPath:{type:String,required:!0},data:{type:[Array,Object],default:null},path:{type:String,default:""},open:{type:Boolean,default:!1},active:{type:Boolean,default:!1},draggable:{type:Boolean,default:!1},label:{type:String,default:null},level:{type:Number,default:0}},data(){return{opened:this.open||this.schema.open}},computed:{meta(){return this.container.meta},store(){return this.container.store},disabled(){return this.container.disabled},nestedMeta(){return{...this.meta,schema:this.schema}},properties(){return G(this.schema.properties)},childrenSchema(){return this.schema.children},childrenList:{get(){const e=this.childrenSchema?.name;return e&&this.data[e]},set(e){const t=this.childrenSchema?.name;t&&(this.updateOrder(this.childrenSchema,e),this.data[t]=e,this.$emit("update:data",e))}},childrenDraggable(){return this.childrenList?.length>1&&this.getSchemaValue("draggable",{type:Boolean,default:!1,schema:this.childrenSchema})},numChildren(){return this.childrenList?.length||0},numProperties(){return this.properties?.length||0},numEntries(){return this.numProperties+this.numChildren},childrenItems(){const{childrenSchema:e,childrenList:t}=this;if(e&&t){const{editPath:o}=this.container,s=!this.path&&e.open;return t.map((i,a)=>{const r=e.path&&`${this.path}/${e.path}/${a}`,l=s||o.startsWith(r)&&r.length<o.length;return{data:i,path:r,open:l,active:o===r}})}return[]},details(){const{numChildren:e}=this;return e&&`${e} ${e===1?"item":"items"}`},hasEditButtons(){return this.draggable||this.editable||this.deletable},creatable:b("creatable",{type:Boolean,default:!1,get(e){return e&&q(this.schema)}}),editable:b("editable",{type:Boolean,default:!1,get(e){return e&&q(this.schema)}}),deletable:b("deletable",{type:Boolean,default:!1})},methods:{getPropertyDataPath(e){return O(this.dataPath,e.name)},editPath(e){this.$router.push({path:`${this.container.path}${e}`,query:this.$route.query})},onEdit(){this.editPath(this.path)},onDelete(){},onChange(){this.container.onChange()},onEndDrag(e){ye.methods.onEndDrag.call(this,e);const{item:t}=e;t.classList.contains("dito-tree-item--active")&&this.$nextTick(()=>{this.editPath(e.item.dataset.path)})}}}),Wr=y(Hr,[["render",Ur]]),Kr={class:"dito-table-head"},Yr=["onClick"],Jr={key:1},Gr={key:0};function Qr(e,t,o,s,i,a){const r=n.resolveComponent("RouterLink");return n.openBlock(),n.createElementBlock("thead",Kr,[n.createElementVNode("tr",null,[(n.openBlock(!0),n.createElementBlock(n.Fragment,null,n.renderList(e.columns,l=>(n.openBlock(),n.createElementBlock(n.Fragment,null,[e.shouldRenderSchema(l)?(n.openBlock(),n.createElementBlock("th",{key:0,class:n.normalizeClass(e.getColumnClass(l))},[l.sortable?(n.openBlock(),n.createBlock(r,{key:0,to:e.getSortLink(l),custom:""},{default:n.withCtx(({navigate:d})=>[n.createElementVNode("button",{class:n.normalizeClass(["dito-button",e.getSortClass(l)]),type:"button",onClick:d},[t[0]||(t[0]=n.createElementVNode("div",{class:"dito-button__order-arrows"},null,-1)),n.createElementVNode("span",null,n.toDisplayString(e.getLabel(l)),1)],10,Yr)]),_:2},1032,["to"])):(n.openBlock(),n.createElementBlock("span",Jr,n.toDisplayString(e.getLabel(l)),1))],2)):n.createCommentVNode("",!0)],64))),256)),e.hasEditButtons?(n.openBlock(),n.createElementBlock("th",Gr,[...t[1]||(t[1]=[n.createElementVNode("span",null,null,-1)])])):n.createCommentVNode("",!0)])])}const Xr=C.component("DitoTableHead",{props:{query:{type:Object,required:!0},columns:{type:Object,required:!0},hasEditButtons:{type:Boolean,required:!0}},computed:{sort(){const e=(this.query.order||"").split(/\s+/);return{name:e[0],order:e[1]}}},methods:{getColumnClass(e){return`dito-column--${h.hyphenate(e.name)}`},getSortClass(e){return this.sort.name===e.name?`dito-button--selected dito-button--order-${this.sort.order}`:null},getSortLink(e){const t=this.sort.name===e.name&&this.sort.order==="asc"?"desc":"asc";return this.getQueryLink({...this.query,order:`${e.name} ${t}`})}}}),Zr=y(Xr,[["render",Qr]]),_r=["innerHTML"];function xr(e,t,o,s,i,a){return n.openBlock(),n.createElementBlock("td",{class:n.normalizeClass(e.cell.class),style:n.normalizeStyle(e.cell.style)},[e.cell.component?(n.openBlock(),n.createBlock(n.resolveDynamicComponent(e.cell.component),{key:0,schema:e.schema,dataPath:e.dataPath,data:e.data,meta:e.meta,store:e.store,nested:e.nested,disabled:e.disabled},null,8,["schema","dataPath","data","meta","store","nested","disabled"])):(n.openBlock(),n.createElementBlock("span",{key:1,innerHTML:e.renderCell(e.data)},null,8,_r))],6)}const vr=C.component("DitoTableCell",{mixins:[L],props:{cell:{type:Object,required:!0},schema:{type:Object,required:!0},dataPath:{type:String,required:!0},data:{type:Object,required:!0},meta:{type:Object,required:!0},store:{type:Object,required:!0},nested:{type:Boolean,default:!0},disabled:{type:Boolean,default:!1}},methods:{renderCell(e){const{name:t,render:o}=this.cell,s=e[t];return o?o.call(this,new S(this,{name:t,value:s,data:e,dataPath:O(this.dataPath,t)})):h.escapeHtml(s)}}}),el=y(vr,[["render",xr]]),tl={class:"dito-upload-file"},nl={class:"dito-thumbnail__inner"},ol=["src"],sl={key:1,class:"dito-thumbnail__type"};function al(e,t,o,s,i,a){return n.openBlock(),n.createElementBlock("div",tl,[e.thumbnail?(n.openBlock(),n.createElementBlock("div",{key:0,class:n.normalizeClass(["dito-thumbnail",`dito-thumbnail--${e.thumbnail}`])},[n.createElementVNode("div",nl,[e.source?(n.openBlock(),n.createElementBlock("img",{key:0,src:e.source,crossorigin:"anonymous"},null,8,ol)):(n.openBlock(),n.createElementBlock("div",sl,[n.createElementVNode("span",null,n.toDisplayString(e.type),1)]))])],2)):n.createCommentVNode("",!0),n.createElementVNode("span",null,n.toDisplayString(e.file.name),1)])}const il=C.component("DitoUploadFile",{props:{file:{type:Object,required:!0},thumbnail:{type:String,default:null},thumbnailUrl:{type:String,default:null}},data(){return{uploadUrl:null}},computed:{type(){return rl[this.file.type]||this.file.name.split(".").pop().toUpperCase()},source(){return this.uploadUrl||this.thumbnailUrl}},watch:{"file.upload.file":{immediate:!0,handler(e){if(this.thumbnail&&e?.type.startsWith("image/")){const t=new FileReader;t.onload=()=>{this.uploadUrl=t.result},t.readAsDataURL(e)}else this.uploadUrl=null}}}}),rl={"text/plain":"TXT","text/html":"HTML","text/css":"CSS","text/javascript":"JS","image/jpeg":"JPG","image/png":"PNG","image/gif":"GIF","image/svg+xml":"SVG","movie/mp4":"MP4","audio/mpeg":"MP3","application/json":"JSON","application/xml":"XML","application/pdf":"PDF","application/zip":"ZIP"},ll=y(il,[["render",al]]);function dl(e,t,o={}){let s;const{document:i=ca,watchElement:a=!1,...r}=o,l={onUpdate:k=>{pl(t,k.oldIndex,k.newIndex,k)}},d=n.computed(()=>typeof e=="string"?i?.querySelector(e):on(e)),c=()=>{s?.destroy(),s=void 0},p=k=>{!k||s!==void 0||(s=new En(k,{...l,...r}))},u=()=>{const k=d.value;k&&p(k)},m=(k,V)=>{if(V!==void 0)s?.option(k,V);else return s?.option(k)};let f;a&&typeof e!="string"?f=n.watch(d,k=>{c(),k&&p(k)},{immediate:!0,flush:"post"}):da(u);const g=()=>{c()};return nn(()=>{f?.(),c()}),{stop:g,start:u,option:m}}function cl(e,t,o){const s=e.children[o];e.insertBefore(t,s)}function hl(e){e.parentNode&&e.parentNode.removeChild(e)}function pl(e,t,o,s=null){s!=null&&(hl(s.item),cl(s.from,s.item,t));const i=n.isRef(e),a=i?[...n.toValue(e)]:n.toValue(e);if(o>=0&&o<a.length){const r=a.splice(t,1)[0];n.nextTick(()=>{a.splice(o,0,r),i&&(e.value=a)})}}const ul=n.defineComponent((e,{slots:t})=>{const o=pa(e,"modelValue"),s=n.shallowRef(),i=n.reactive(dl(s,o,e.options));return()=>{if(t.default)return n.h(e.as||"div",{ref:s},t.default(i))}},{name:"UseSortable",props:["as","modelValue","options"]});function ml(e,t,o,s,i,a){const r=n.resolveComponent("UseSortable");return e.draggable?(n.openBlock(),n.createBlock(r,{key:0,class:n.normalizeClass(["dito-draggable",{"dito-draggable--dragging":e.isDragging}]),as:e.as,modelValue:e.modelValue,options:{...e.options,onStart:e.onStart,onEnd:e.onEnd},"onUpdate:modelValue":t[0]||(t[0]=l=>e.$emit("update:modelValue",l))},{default:n.withCtx(()=>[n.renderSlot(e.$slots,"default")]),_:3},8,["class","as","modelValue","options"])):(n.openBlock(),n.createBlock(n.resolveDynamicComponent(e.as),{key:1},{default:n.withCtx(()=>[n.renderSlot(e.$slots,"default")]),_:3}))}const fl=C.component("DitoDraggable",{mixins:[H],components:{UseSortable:ul},emits:["update:modelValue"],props:{modelValue:{type:Array,required:!0},as:{type:String,default:"div"},options:{type:Object,required:!0},draggable:{type:Boolean,default:!0}},data(){return{mouseEvents:null,isDragging:!1}},methods:{onStart(e){this.options.onStart?.(e),this.isDragging=!0,this.mouseEvents?.remove()},onEnd(e){this.options.onEnd?.(e),this.mouseEvents=this.domOn(document,{mousedown:this.onMouse,mousemove:this.onMouse,mouseleave:this.onMouse})},onMouse(){this.isDragging=!1,this.mouseEvents?.remove(),this.mouseEvents=null}}}),gl=y(fl,[["render",ml]]);function hn({vnode:e}){return e}hn.props={vnode:{type:Object,required:!0}};const bl=C.component("DitoVnode",hn),yl=Object.freeze(Object.defineProperty({__proto__:null,DitoAccount:ei,DitoAffix:ln,DitoAffixes:I,DitoButtons:Gi,DitoClipboard:cr,DitoContainer:Oi,DitoCreateButton:sr,DitoDialog:sn,DitoDraggable:gl,DitoEditButtons:_i,DitoErrors:wr,DitoForm:cn,DitoFormInner:kr,DitoFormNested:Cr,DitoHeader:Ra,DitoLabel:mi,DitoMenu:Pa,DitoNavigation:qa,DitoNotifications:Ya,DitoPagination:Lr,DitoPane:Vi,DitoPanel:zi,DitoPanels:Hi,DitoRoot:Xe,DitoSchema:yi,DitoSchemaInlined:$i,DitoScopes:Nr,DitoSidebar:Xa,DitoSpinner:rn,DitoTableCell:el,DitoTableHead:Zr,DitoTabs:Mi,DitoTrail:La,DitoTreeItem:Wr,DitoUploadFile:ll,DitoVNode:bl,DitoView:tn},Symbol.toStringTag,{value:"Module"})),B={extends:C,mixins:[Oe],nativeField:!1,textField:!1,defaultValue:null,defaultNested:!0,defaultVisible:!0,defaultMultiple:!1,generateLabel:!0,excludeValue:!1,ignoreMissingValue:null,omitSpacing:!1,component:C.component,get:ie,register(e,t={}){e=h.asArray(e);const o=this.component(`DitoType${h.camelize(e[0],!0)}`,t);for(const s of e)ko(s,o);return o}},kl=["data-info"];function Cl(e,t,o,s,i,a){const r=n.resolveComponent("DitoAffixes"),l=n.resolveComponent("DitoButton");return n.openBlock(),n.createBlock(l,n.mergeProps({class:["dito-button",e.buttonClass],id:e.dataPath,ref:"element",type:e.type,text:e.text,title:e.title,disabled:e.disabled},e.attributes),{prefix:n.withCtx(()=>[e.prefixes.length>0?(n.openBlock(),n.createBlock(r,{key:0,items:e.prefixes,position:"prefix",disabled:e.disabled,parentContext:e.context},null,8,["items","disabled","parentContext"])):n.createCommentVNode("",!0)]),suffix:n.withCtx(()=>[e.suffixes.length>0?(n.openBlock(),n.createBlock(r,{key:0,items:e.suffixes,position:"suffix",disabled:e.disabled,parentContext:e.context},null,8,["items","disabled","parentContext"])):n.createCommentVNode("",!0),!e.label&&e.info?(n.openBlock(),n.createElementBlock("div",{key:1,class:"dito-info","data-info":e.info},null,8,kl)):n.createCommentVNode("",!0)]),_:1},16,["id","type","text","title","disabled","class"])}const $l=B.register(["button","submit"],{components:{DitoAffixes:I,DitoButton:Qo},defaultValue:()=>{},excludeValue:!0,defaultWidth:"auto",generateLabel:!1,data(){return{isRunning:!1}},computed:{verb(){return this.verbs[this.name]},buttonClass(){return this.verb?`dito-button--${this.verb}`:null},text:b("text",{type:String}),title(){return this.text||h.labelize(this.verb)},prefixes(){return h.asArray(this.schema.prefix)},suffixes(){return h.asArray(this.schema.suffix)},closeForm:b("closeForm",{type:Boolean,default:!1})},methods:{getEvents(){const{onFocus:e,onBlur:t,onClick:o}=this;return{onFocus:e,onBlur:t,onClick:o}},async submit(e){return this.resourceComponent?.submit(this,e)},async onClick(){this.isRunning=!0;try{await this.emitEvent("click",{parent:this.schemaComponent})===void 0&&Ut(this.schema)&&await this.submit()}catch(e){if(await this.emitEvent("error",{error:e})===void 0)if(e instanceof AggregateError)for(const o of e.errors)this.notify({type:"error",text:o});else this.notify({type:"error",text:e})}finally{this.isRunning=!1}}}}),Dl=y($l,[["render",Cl]]),Bl={class:"dito-checkbox"},wl=["id"];function Sl(e,t,o,s,i,a){return n.openBlock(),n.createElementBlock("div",Bl,[n.withDirectives(n.createElementVNode("input",n.mergeProps({id:e.dataPath,ref:"element","onUpdate:modelValue":t[0]||(t[0]=r=>e.value=r),type:"checkbox"},e.attributes),null,16,wl),[[n.vModelCheckbox,e.value]])])}const Vl=B.register("checkbox",{nativeField:!0}),Pl=y(Vl,[["render",Sl]]),pn={mixins:[dn],data(){return{isLoading:!1,asyncDataEntries:n.markRaw({})}},methods:{handleDataSchema(e,t,o){h.isObject(e)||(e={data:e});let{data:s=void 0,dataPath:i=null}=e;const a=this.asyncDataEntries[t]??={reactiveVersion:n.ref(1),dependencyFunction:null,resolvedData:void 0,resolving:!1,resolved:!1};if(a.reactiveVersion.value&&a.dependencyFunction?.(this.context),a.resolved){const{resolvedData:r}=a;return a.resolvedData=void 0,a.resolved=!1,r}if(a.resolving)s=null;else if(s){if(h.isFunction(s)){const r=s(this.context);h.isFunction(r)?(a.dependencyFunction=s,s=r(this.context)):s=r}h.isPromise(s)&&(a.resolving=!0,this.resolveData(s,o).then(r=>{a.resolvedData=r,a.resolving=!1,a.resolved=!0,a.reactiveVersion.value++}).catch(r=>{console.error(r),a.resolving=!1}),s=null)}else i&&(s=h.getValueAtDataPath(this.rootData,h.normalizeDataPath(`${this.dataPath}/${i}`)));return s},async resolveData(e,t={}){let o=!1;const s=setTimeout(()=>{this.setLoading(!0,t),o=!0},0);let i=null;try{i=await(h.isFunction(e)?e():e)}catch(a){this.addError(a.message||a)}return o?this.setLoading(!1,t):clearTimeout(s),i}}},ke={mixins:[pn],computed:{multiple(){return Tt(this.schema)},selectedValue:{get(){const e=o=>{const s=this.relate?this.getValueForOption(o):o;return this.hasOptions?this.getOptionForValue(s)?s:null:o},t=this.multiple&&h.isArray(this.value)?this.value.map(e).filter(o=>o!==null):e(this.value);return this.hasOptions&&(t===null&&this.value!==null||ro(this.value))&&(this.selectedValue=t),t},set(e){const t=o=>this.relate?this.getOptionForValue(o):o;this.value=this.multiple&&h.isArray(e)?e.map(t):t(e)}},selectedOption(){return this.getOptionForValue(this.selectedValue)},options(){const e=this.handleDataSchema(this.schema.options,"options")??[];if(!h.isArray(e))throw new Error(`Invalid options data, should be array: ${e}`);return this.processOptions(e)},activeOptions(){return this.options},hasOptions(){return this.activeOptions.length>0},relate:b("relate",{type:Boolean,default:!1,callback:!1}),groupBy:b("groupBy",{type:String,default:null}),optionLabel:b("options.label",{type:[String,Function],default:null,get(e){return e||this.getOptionKey("label")||null}}),optionValue:b("options.value",{type:[String,Function],default:null,get(e){return e||this.relate&&"id"||this.getOptionKey("value")||null}}),optionEquals:b("options.equals",{type:Function,default:null}),searchFilter:b("search",{type:[Object,Function],default:null,get(e){if(e){const{filter:t,debounce:o}=h.isFunction(e)?{filter:e}:e;return o?h.debounceAsync(t,o):t}}}),editable:b("editable",{type:Boolean,default:!1,get(e){return e&&Lo(this.schema,this.context)}}),editPath(){return this.editable&&this.selectedValue?Vt(this.schema,this.selectedValue,this.context):null},groupByLabel(){return this.groupBy?"label":null},groupByOptions(){return this.groupBy?"options":null}},methods:{getOptionKey(e){const[t]=this.activeOptions;return h.isObject(t)&&e in t?e:null},processOptions(e){if(e.length){if(this.relate)for(const t of e)"id"in t||io(t,"id");if(this.groupBy){const t={};e=e.reduce((o,s)=>{const i=s[this.groupBy];let a=t[i];return a||(a=t[i]={[this.groupByLabel]:i,[this.groupByOptions]:[]},o.push(a)),a[this.groupByOptions].push(s),o},[])}}return e},getOptionForValue(e){const t=(o,s,i)=>{for(const a of o)if(i){const r=t(a.options,s,null);if(r)return r}else if(this.optionEquals?this.optionEquals(new S(this,{value:s,option:a})):s===this.getValueForOption(a))return a};return this.optionValue?t(this.activeOptions,e,this.groupBy):e},getValueForOption(e){const{optionValue:t}=this;return h.isString(t)?e?.[t]??null:h.isFunction(t)?t(new S(this,{option:e})):e},getLabelForOption(e){const{optionLabel:t}=this;return h.isString(t)?e?.[t]:h.isFunction(t)?t(new S(this,{option:e})):h.labelize(`${e}`)}},processValue({schema:e,value:t,dataPath:o},s){if(e.relate){const i=e.options?.dataPath,a=i?h.normalizeDataPath(`${o}/${i}`):null;s.addRelation(o,a,e),a&&s.setSourceRelated(a);const r=l=>l&&{id:l.id};t=Tt(e)&&h.isArray(t)?t.map(r):r(t)}return t}},El=["id"],Nl={class:"dito-checkbox"},Ol=["value"];function Tl(e,t,o,s,i,a){return n.openBlock(),n.createElementBlock("ul",{class:n.normalizeClass(["dito-checkboxes",`dito-layout--${e.schema.layout||"vertical"}`]),id:e.dataPath},[(n.openBlock(!0),n.createElementBlock(n.Fragment,null,n.renderList(e.options,r=>(n.openBlock(),n.createElementBlock("li",null,[n.createElementVNode("label",null,[n.createElementVNode("div",Nl,[n.withDirectives(n.createElementVNode("input",n.mergeProps({ref_for:!0,ref:"element","onUpdate:modelValue":t[0]||(t[0]=l=>e.selectedOptions=l),type:"checkbox",value:e.getValueForOption(r)},{ref_for:!0},e.attributes),null,16,Ol),[[n.vModelCheckbox,e.selectedOptions]]),n.createElementVNode("span",null,n.toDisplayString(e.getLabelForOption(r)),1)])])]))),256))],10,El)}const Ll=B.register("checkboxes",{mixins:[ke],nativeField:!0,defaultValue:[],defaultWidth:"auto",defaultMultiple:!0,computed:{multiple(){return!0},selectedOptions:{get(){return(this.selectedValue||[]).filter(e=>e)},set(e){this.selectedValue=e||[]}}}}),Fl=y(Ll,[["render",Tl]]),Il=["id"],Ml={class:"dito-code__editor",ref:"editor"};function Rl(e,t,o,s,i,a){return n.openBlock(),n.createElementBlock("div",{class:"dito-code",id:e.dataPath,style:n.normalizeStyle(e.style)},[n.createElementVNode("div",Ml,null,512),e.resizable?(n.openBlock(),n.createElementBlock("div",{key:0,class:"dito-resize",onMousedown:t[0]||(t[0]=n.withModifiers((...r)=>e.onDragResize&&e.onDragResize(...r),["stop","prevent"]))},null,32)):n.createCommentVNode("",!0)],12,Il)}const jl=B.register("code",{mixins:[H],data(){return{height:null}},computed:{lines:b("lines",{type:Number,default:3}),language:b("language",{type:String,default:"javascript"}),indentSize:b("indentSize",{type:Number,default:2}),resizable:b("resizable",{type:Boolean,default:!1}),style(){return{height:this.height||`calc(${this.lines}em * var(--line-height))`}}},mounted(){const e=new Nn(this.$refs.editor,{language:this.language,indentSize:this.indentSize,lineNumbers:!1});let t=!1,o=!1,s=!1;const i=()=>{!this.focused&&t&&(t=!1,this.onChange())},a=()=>this.onFocus(),r=()=>{this.onBlur(),i()};this.domOn(this.$refs.editor.querySelector("textarea"),{focus:a,blur:r});const l=c=>{c!==e.code&&(s=!0,e.updateCode(c))},d=c=>{c!==this.value&&(o=!0,this.value=c,t=!0,i())};e.onUpdate(c=>{s?s=!1:d(c)}),this.$watch("value",c=>{o?o=!1:l(c||"")}),this.$watch("language",c=>{e.updateLanguage(c)}),l(this.value||"")},methods:{focusElement(){this.$el.querySelector("textarea")?.focus()},blurElement(){this.$el.querySelector("textarea")?.blur()},onDragResize(e){const t=({clientX:r,clientY:l})=>({x:r,y:l});let o=t(e).y,s=parseFloat(getComputedStyle(this.$el).height);const i=r=>{const{y:l}=t(r);s+=l-o,o=l,this.height=`${Math.max(s,0)}px`},a=this.domOn(document,{mousemove:i,mouseup(r){i(r),a.remove()}})}}}),zl=y(jl,[["render",Rl]]),Al={key:0,class:"dito-color__preview"};function ql(e,t,o,s,i,a){const r=n.resolveComponent("DitoAffixes"),l=n.resolveComponent("DitoInput"),d=n.resolveComponent("SketchPicker"),c=n.resolveComponent("DitoTrigger");return n.openBlock(),n.createBlock(c,{class:"dito-color",show:e.showPopup,"onUpdate:show":t[2]||(t[2]=p=>e.showPopup=p),trigger:"focus"},{trigger:n.withCtx(()=>[n.createVNode(l,n.mergeProps({id:e.dataPath,ref:"element",modelValue:e.hexValue,"onUpdate:modelValue":t[0]||(t[0]=p=>e.hexValue=p),type:"input",size:"8",focused:e.showPopup},e.attributes),{prefix:n.withCtx(()=>[n.createVNode(r,{items:e.schema.prefix,position:"prefix",mode:"input",disabled:e.disabled,parentContext:e.context},null,8,["items","disabled","parentContext"])]),suffix:n.withCtx(()=>[n.createVNode(r,{items:e.schema.suffix,position:"suffix",mode:"input",clearable:e.showClearButton,disabled:e.disabled,inlineInfo:e.inlineInfo,parentContext:e.context,onClear:e.clear},{append:n.withCtx(()=>[e.value?(n.openBlock(),n.createElementBlock("div",Al,[n.createElementVNode("div",{style:n.normalizeStyle({background:`#${e.hexValue||"00000000"}`})},null,4)])):n.createCommentVNode("",!0)]),_:1},8,["items","clearable","disabled","inlineInfo","parentContext","onClear"])]),_:1},16,["id","modelValue","focused"])]),popup:n.withCtx(()=>[n.createVNode(d,{class:"dito-color__picker",modelValue:e.colorValue,"onUpdate:modelValue":t[1]||(t[1]=p=>e.colorValue=p),disableAlpha:!e.alpha,disableFields:!e.inputs,presetColors:e.presets},null,8,["modelValue","disableAlpha","disableFields","presetColors"])]),_:1},8,["show"])}const{hex:Ul}=we.Sketch.computed;we.Sketch.computed.hex=function(){return Ul.call(this).toLowerCase()};const Hl=B.register("color",{components:{DitoTrigger:Qe,DitoInput:U,DitoAffixes:I,SketchPicker:we.Sketch},data(){return{showPopup:!1,convertedValue:null}},computed:{canUpdateValue(){return!this.focused||this.readonly},colorValue:{get(){return this.convertedValue||this.value||(this.colorFormat==="hex"?"":{})},set(e){this.value=un(e,this.colorFormat)}},hexValue:{get(){const e=Be(this.value);return e.isValid()?e.toString(e.getAlpha()<1?"hex8":"hex6").slice(1).toLowerCase():null},set(e){if(Be(e).isValid()){const o=un(e,this.colorFormat);this.canUpdateValue?this.value=o:this.convertedValue=o}}},colorFormat:b("format",{type:String,default:"hex"}),alpha:b("alpha",{type:Boolean,default:!1}),inputs:b("inputs",{type:Boolean,default:!0}),presets:b("presets",{type:Array,default:["#ffffff","#c3c3c3","#7f7f7f","#000000","#880015","#ed1c24","#ff7f27","#fff200","#22b14c","#00a2e8","#3f48cc","#a349a4","#b97a57","#ffaec9","#ffc90e","#00000000"]})},watch:{value:"onChange",canUpdateValue(e){e&&this.convertedValue!==null&&(this.value=this.convertedValue,this.convertedValue=null)}}});function un(e,t){return h.isObject(e)?Wl(e,t):Kl(Be(e),t)}function Wl(e,t){const o=e[{hex:e?.a<1?"hex8":"hex",rgb:"rgba"}[t]||t];return h.isString(o)&&o[0]==="#"?o.toLowerCase():o}function Kl(e,t){switch(t){case"rgb":return e.toRgb();case"prgb":return e.toPercentageRgb();case"name":return e.toName();case"hsl":return e.toHsl();case"hsv":return e.toHsv();case"hex3":return`#${e.toHex(!0)}`;case"hex4":return`#${e.toHex8(!0)}`;case"hex8":return`#${e.toHex8()}`;default:return e.getAlpha()<1?`#${e.toHex8()}`:`#${e.toHex()}`}}const Yl=y(Hl,[["render",ql]]);function Jl(e,t,o,s,i,a){return n.openBlock(),n.createBlock(n.resolveDynamicComponent(e.schema.component),n.normalizeProps(n.guardReactiveProps(e.$props)),null,16)}const Gl=B.register("component",{defaultValue:()=>{},ignoreMissingValue:({schema:e})=>!("default"in e),async processSchema(e,t){await de(t)}}),Ql=y(Gl,[["render",Jl]]),Xl=["id","name","value","disabled"];function Zl(e,t,o,s,i,a){return n.openBlock(),n.createElementBlock("input",{class:"dito-text dito-input",id:e.dataPath,ref:"element",name:e.name,type:"text",value:e.value,disabled:e.disabled,readonly:!0},null,8,Xl)}const _l=B.register(["computed","data","hidden"],{mixins:[pn],defaultValue:()=>{},defaultVisible:!1,computed:{value:{get(){const{schema:e}=this;if(e.data||e.dataPath){const t=this.handleDataSchema(e,"value");this.data[this.name]=t}return ae.computed.value.get.call(this)},set(e){ae.computed.value.set.call(this,e)}}}}),xl=y(_l,[["render",Zl]]),vl={class:"dito-date"};function ed(e,t,o,s,i,a){const r=n.resolveComponent("DitoAffixes");return n.openBlock(),n.createElementBlock("div",vl,[(n.openBlock(),n.createBlock(n.resolveDynamicComponent(e.getComponent(e.type)),n.mergeProps({id:e.dataPath,ref:"element",modelValue:e.dateValue,"onUpdate:modelValue":t[0]||(t[0]=l=>e.dateValue=l),locale:e.locale,format:e.formats},e.attributes),{prefix:n.withCtx(()=>[n.createVNode(r,{items:e.schema.prefix,position:"prefix",mode:"input",absolute:"",disabled:e.disabled,parentContext:e.context},null,8,["items","disabled","parentContext"])]),suffix:n.withCtx(()=>[n.createVNode(r,{items:e.schema.suffix,position:"suffix",mode:"input",absolute:"",clearable:e.showClearButton,disabled:e.disabled,inlineInfo:e.inlineInfo,parentContext:e.context,onClear:e.clear},null,8,["items","clearable","disabled","inlineInfo","parentContext","onClear"])]),_:1},16,["id","modelValue","locale","format"]))])}const td=B.register(["date","datetime","time"],{components:{DitoAffixes:I},nativeField:!0,textField:!0,computed:{dateValue:{get(){const{value:e}=this;return e&&new Date(e)},set(e){this.value=e}},formats:b("formats",{type:Object,default:null,get(e){const{date:t,time:o}=h.assignDeeply({},this.api.formats,e);return{date:["date","datetime"].includes(this.type)?t:null,time:["time","datetime"].includes(this.type)?o:null}}})},methods:{getComponent(e){return{date:Qt,time:Xt,datetime:As}[e]}},processValue({value:e}){return h.isDate(e)?e.toISOString():e}}),nd=y(td,[["render",ed]]);function mn(e){const t=e?h.isArray(e)?e:Object.entries(e):[];return new URLSearchParams(t.reduce((o,[s,i])=>{if(h.isArray(i))for(const a of i)o.push([s,a??""]);else i!=null&&o.push([s,i]);return o},[])).toString().replaceAll(/%(?:21|24|28|29|2C|2F|3A|3B|3D|3F|40)/g,decodeURIComponent)}function od({path:e,query:t,hash:o}){const{location:s}=window;history.replaceState(history.state,null,`${s.origin}${e??s.pathname}?${t?mn(t):s.search.slice(1)}${o??s.hash}`)}const Z={mixins:[be,Ze,xt],defaultValue:e=>te(e.schema)?[]:null,excludeValue:e=>!!e.schema.resource,provide(){return{$sourceComponent:()=>this}},data(){return{wrappedPrimitives:null,unwrappingPrimitives:On.raw(!1)}},computed:{sourceComponent(){return this},isObjectSource(){return ee(this.type)},isListSource(){return te(this.type)},hasData(){return!!this.value},shouldRender(){return this.sourceDepth<this.maxDepth},isReady(){return this.shouldRender&&(this.hasData||!this.providesData)},isInView(){return!!this.viewComponent},wrapPrimitives(){return this.schema.wrapPrimitives},listData:{get(){let e=this.value;this.isObjectSource?e=e!=null?[e]:[]:e=this.unwrapListData(e)||e,e||=[];const{wrapPrimitives:t}=this;return t?(this.unwrappingPrimitives.value?this.unwrappingPrimitives.value=!1:this.wrappedPrimitives=e.map(o=>({[t]:o})),this.wrappedPrimitives):e},set(e){this.wrapPrimitives?this.wrappedPrimitives=e:this.value=this.isObjectSource?e?.length>0?e[0]:null:e}},objectData:{get(){return this.listData[0]||null},set(e){this.listData=e?[e]:[]}},sourceSchema(){return this.schema},sourceDepth(){return this.$route.matched.reduce((e,t)=>e+(t.meta.schema===this.sourceSchema?1:0),0)},path(){return this.routeComponent.getChildPath(this.schema.path)},defaultQuery(){const{defaultOrder:e}=this;return e?{order:e}:{}},query:Ne("query",{get(e){return{...this.defaultQuery,...e}},set(e){const{scope:t=this.defaultScope?.name,page:o=this.schema.page,type:s}=this.query;return e={...this.query,...t!=null&&{scope:t},...o!=null&&{page:o},...s!=null&&{type:s},...e},h.equals(e,this.$route.query)||od({query:e}),e}}),total:Ne("total"),columns(){return G(this.schema.columns)},scopes(){return G(this.schema.scopes)},defaultScope(){let e=null;if(this.scopes)for(const t of Object.values(this.scopes)){if(t.defaultScope)return t;e||(e=t)}return e},defaultOrder(){if(this.columns)for(const e of Object.values(this.columns)){const{defaultSort:t}=e;if(t){const o=h.isString(t)?t:"asc";return`${e.name} ${o}`}}return null},nestedMeta(){return{...this.meta,schema:this.schema}},forms(){return Object.values(Y(this.schema,this.context))},view(){return Re(this.schema,this.context)},linksToView(){return!!this.view},buttonSchemas(){return v(this.schema.buttons)},isCompact(){return this.forms.every(Et)},isInlined(){return ze(this.schema)},paginate:b("paginate",{type:Number}),render:b("render",{type:Function,default:null}),creatable:b("creatable",{type:Boolean,default:!1,get(e){return e&&q(this.schema)?this.isObjectSource?!this.value:!0:!1}}),editable:b("editable",{type:Boolean,default:!1,get(e){return e&&!this.isInlined}}),deletable:b("deletable",{type:Boolean,default:!1}),draggable:b("draggable",{type:Boolean,default:!1,get(e){return this.isListSource&&this.listData.length>1&&e}}),collapsible:b("collapsible",{type:Boolean,default:!1,get(e){return e&&this.isInlined}}),collapsed:b("collapsed",{type:Boolean,default:!1,get(e){return e&&this.collapsible}}),maxDepth:b("maxDepth",{type:Number,default:1}),createPath(){return this.creatable?St(this.schema,this.context)||this.path:null}},watch:{$route:{flush:"post",handler(e,t){this.providesData&&(t.path===e.path&&t.hash===e.hash?(this.query=e.query,this.loadData(!1)):this.meta.reload&&t.path!==e.path&&t.path.startsWith(e.path)&&(this.meta.reload=!1,this.loadData(!1)))}},wrappedPrimitives:{deep:!0,handler(e,t){const{wrapPrimitives:o}=this;o&&t!==null&&(this.unwrappingPrimitives.value=!0,this.value=e.map(s=>s[o]))}}},methods:{setupData(){this.query=this.$route.query,this.ensureData()},clearData(){this.total=0,this.value=null},setData(e){!e||this.isListSource&&h.isArray(e)||this.isObjectSource&&h.isObject(e)?this.value=e:this.unwrapListData(e)||h.isObject(e)&&this.isInView&&this.viewComponent.setData(e)},unwrapListData(e){if(this.isListSource&&h.isObject(e)&&h.isNumber(e.total)&&h.isArray(e.results))return this.total=e.total,this.value=e.results,this.value},createItem(e,t){const o=this.createData(e,t);return this.isObjectSource?this.objectData=o:this.listData.push(o),this.collapsible&&this.$nextTick(()=>this.openSchemaComponent(-1)),this.onChange(),o},removeItem(e,t){let o=!1;if(this.isObjectSource)this.objectData=null,o=!0;else{const{listData:s}=this;t>=0&&(s.splice(t,1),o=!0)}o&&(this.removeItemStore(this.schema,e,t),this.onChange())},deleteItem(e,t){const o=e&&this.getItemLabel(this.schema,e,{index:t,extended:!0}),s=()=>this.notify({type:this.isTransient?"info":"success",title:"Successfully Removed",text:[`${o} was ${this.verbs.deleted}.`,this.transientNote]});if(e&&window.confirm(`Do you really want to ${this.verbs.delete} ${o}?`))if(this.isTransient)this.removeItem(e,t),s();else{const i=this.getItemId(this.schema,e,t),a="delete",r=We(i,this.getResource({method:a}));r&&this.handleRequest({method:a,resource:r},l=>{l||(this.removeItem(e,t),s()),this.reloadData()})}},getSchemaComponent(e){const{schemaComponents:t}=this,{length:o}=t;return t[(e%o+o)%o]},openSchemaComponent(e){const t=this.getSchemaComponent(e);t&&(t.opened=!0)},async navigateToComponent(e,t){if(this.collapsible){const o=e.startsWith(this.dataPath)?this.isListSource?h.parseDataPath(e.slice(this.dataPath.length+1))[0]??null:0:null;if(o!==null&&h.isNumber(+o)){const s=this.getSchemaComponent(+o);if(s){const{opened:i}=s;i||(s.opened=!0,await this.$nextTick());const a=s.getComponentsByDataPath(e);if(a.length>0&&(t?.(a)??!0))return!0;s.opened=i}}}return this.navigateToRouteComponent(e,t)},navigateToRouteComponent(e,t){return new Promise((o,s)=>{const i=()=>{const{routeComponents:r}=this.appState,l=r[r.length-1];o(t?.([l])??!0)},a=h.parseDataPath(e);for(;a.length>0;){const r=this.routeComponent.getChildPath(this.api.normalizePath(h.normalizeDataPath(a))),{matched:l}=this.$router.resolve(r);if(l.length&&l[0].name!=="catch-all"){this.$route.path===r?i():this.$router.push({path:r}).catch(s).then(()=>{this.$nextTick(i)});return}a.pop()}o(!1)})}},async processSchema(e,t,o,s,i,a=!1,r=!1,l=null){Dt(e,t,o);const d=ze(t);if(d&&t.resource)throw new Error(`Nested ${this.isListSource?"lists":this.isObjectSource?"objects":"schema"} cannot load data from their own resources`);const c=`id${i+1}`,p={api:e,schema:t},u={...p,flatten:r,nested:a,param:c},m=await Eo(e,t,i);if(l&&await l(m,i+1),q(t)&&!d){const f=i===0?"":t.path,g={path:fn(f,te(t)?c:null),component:C.component(a?"DitoFormNested":"DitoForm"),meta:u};ee(t)&&s.push({...g,path:fn(f,c)}),f&&s.push({path:f,redirect:".",meta:p});const[k,V]=m.reduce((w,$)=>(w[$.meta.flatten?0:1].push($),w),[[],[]]);if(V.length&&(g.children=V),s.push(g),k.length)for(const w of k)s.push({...w.redirect?w:g,path:`${g.path}/${w.path}`,meta:{...w.meta,flatten:r}})}},processValue({schema:e,value:t,dataPath:o},s){return s.addSource(o,e),t}};function fn(e,t){return t?e?`${e}/:${t}`:`:${t}`:e}const sd={text(e){const t=[{label:"contains",value:"contains"},{label:"equals",value:"equals"},{label:"starts with",value:"starts-with"},{label:"ends with",value:"ends-with"}];return{operator:e.operators?{type:"select",width:"2/5",options:h.isArray(e.operators)?t.filter(o=>e.operators.includes(o.value)):t,clearable:!0}:null,text:{type:"text",width:e.operators?"3/5":"fill",clearable:!0}}},"date-range"(){const e={type:"datetime",width:"1/2",formats:{date:{day:"2-digit",month:"2-digit",year:"numeric"}},clearable:!0};return{from:e,to:e}}};function ad(e,t,o,s){const{sticky:i,...a}=t,r={type:"panel",label:"Filters",name:"$filters",disabled:!1,sticky:i,data(){return dd(r,s.value)},components:rd(a),buttons:gn(!1),panelButtons:gn(!0),events:{change(){this.applyFilters()}},computed:{filters(){return ld(this.schema,this.data)},hasFilters(){return this.filters.length>0}},methods:{applyFilters(){s.value={...s.value,filter:this.filters,page:void 0}},clearFilters(){this.resetData(),this.applyFilters()}}};return $t(e,r),r}function gn(e){return{clear:{type:"button",text:e?null:"Clear",disabled:({schemaComponent:t})=>!t.hasFilters,events:{click({schemaComponent:t}){t.clearFilters()}}},submit:{type:"submit",text:e?null:"Filter",visible:!e,events:{click({schemaComponent:t}){t.applyFilters()}}}}}function id(e){return`$${e}`}function bn(e){return e.startsWith("$")?e.slice(1):null}function rd(e){const t={};for(const o of Object.values(G(e)||{})){const{filter:s,width:i,...a}=o,r=s?sd[s]?.(o):o.components;if(r){a.type="form",a.components={};for(const[l,d]of Object.entries(r))if(d){const c=d.label||h.labelize(d.name||l);a.components[l]={...d,label:!1,placeholder:c}}t[id(o.name)]={label:a.label??h.labelize(o.name),type:"object",width:i,default:()=>({}),form:a,inlined:!0}}else throw new Error(`Invalid filter '${o.name}': Unknown filter type '${s}'.`)}return t}function yn(e,t){return e.components[t]?.form?.components}function ld(e,t){const o=[];for(const s in t){const i=t[s];if(i){const a=Object.keys(yn(e,s)).map(r=>i[r]??null);a.some(r=>r!==null)&&o.push(`${bn(s)}:${a.map(JSON.stringify).join(",")}`)}}return o}function dd(e,t){const o={};if(t)for(const i of h.asArray(t.filter)){const[,a,r]=i.match(/^(\w+):(.*)$/);try{o[a]=h.asArray(JSON.parse(`[${r}]`))}catch{}}const s={};for(const i in e.components){const a={},r=o[bn(i)];if(r){const l=yn(e,i);if(l){let d=0;for(const c in l)a[c]=r[d++]}}s[i]=a}return s}const cd=["id"],hd={key:0,class:"dito-list__header"},pd={key:1,class:"dito-spacer"},ud=["id"],md={key:1},fd=["innerHTML"],gd=["innerHTML"],bd={key:2,class:"dito-table__buttons"},yd={key:1},kd=["colspan"];function Cd(e,t,o,s,i,a){const r=n.resolveComponent("DitoScopes"),l=n.resolveComponent("DitoPagination"),d=n.resolveComponent("DitoTableHead"),c=n.resolveComponent("DitoTableCell"),p=n.resolveComponent("DitoSchemaInlined"),u=n.resolveComponent("DitoEditButtons"),m=n.resolveComponent("DitoDraggable");return e.isReady?(n.openBlock(),n.createElementBlock("div",{key:0,class:"dito-list",id:e.dataPath},[e.scopes||e.hasPagination?(n.openBlock(),n.createElementBlock("div",hd,[e.scopes?(n.openBlock(),n.createBlock(r,{key:0,query:e.query,scopes:e.scopes},null,8,["query","scopes"])):e.hasPagination?(n.openBlock(),n.createElementBlock("div",pd)):n.createCommentVNode("",!0),e.hasPagination?(n.openBlock(),n.createBlock(l,{key:2,query:e.query,limit:e.paginate,total:e.total||0},null,8,["query","limit","total"])):n.createCommentVNode("",!0)])):n.createCommentVNode("",!0),n.createElementVNode("table",{class:n.normalizeClass(["dito-table",{"dito-table--separators":e.isInlined,"dito-table--larger-padding":e.hasEditButtons&&!e.isInlined,"dito-table--alternate-colors":!e.isInlined,"dito-table--even-count":e.hasEvenCount}])},[e.columns?(n.openBlock(),n.createBlock(d,{key:0,query:e.query,columns:e.columns,hasEditButtons:e.hasEditButtons},null,8,["query","columns","hasEditButtons"])):n.createCommentVNode("",!0),n.createVNode(m,{as:"tbody",options:e.getDraggableOptions(),draggable:e.draggable,modelValue:e.updateOrder(e.sourceSchema,e.listData,e.paginationRange),"onUpdate:modelValue":t[0]||(t[0]=f=>e.listData=f)},{default:n.withCtx(()=>[(n.openBlock(!0),n.createElementBlock(n.Fragment,null,n.renderList(e.listData,(f,g)=>(n.openBlock(),n.createElementBlock("tr",{id:e.getDataPath(g),key:e.getItemUid(e.schema,f)},[e.columns?(n.openBlock(!0),n.createElementBlock(n.Fragment,{key:0},n.renderList(e.columns,k=>(n.openBlock(),n.createElementBlock(n.Fragment,null,[e.shouldRenderSchema(k)?(n.openBlock(),n.createBlock(c,{key:k.name,class:n.normalizeClass(e.getCellClass(k)),cell:k,schema:e.schema,dataPath:e.getDataPath(g),data:f,meta:e.nestedMeta,store:e.store,nested:!1,disabled:e.disabled||e.isLoading},null,8,["class","cell","schema","dataPath","data","meta","store","disabled"])):n.createCommentVNode("",!0)],64))),256)):(n.openBlock(),n.createElementBlock("td",md,[e.isInlined?(n.openBlock(),n.createBlock(p,{key:0,label:e.getItemLabel(e.schema,f,{index:g,asObject:!0}),schema:e.getItemFormSchema(e.schema,f,e.context),dataPath:e.getDataPath(g),data:f,meta:e.nestedMeta,store:e.getItemStore(e.schema,f,g),disabled:e.disabled||e.isLoading,collapsed:e.collapsed,collapsible:e.collapsible,deletable:e.deletable,draggable:e.draggable,editable:e.editable,editPath:e.getEditPath(f,g),onDelete:k=>e.deleteItem(f,g)},null,8,["label","schema","dataPath","data","meta","store","disabled","collapsed","collapsible","deletable","draggable","editable","editPath","onDelete"])):e.schema.component?(n.openBlock(),n.createBlock(n.resolveDynamicComponent(e.schema.component),{key:1,dataPath:e.getDataPath(g),data:f,nested:!1},null,8,["dataPath","data"])):e.render?(n.openBlock(),n.createElementBlock("span",{key:2,innerHTML:e.render(e.getContext(f,g))},null,8,fd)):(n.openBlock(),n.createElementBlock("span",{key:3,innerHTML:e.getItemLabel(e.schema,f,{index:g})},null,8,gd))])),e.hasCellEditButtons?(n.openBlock(),n.createElementBlock("td",bd,[n.createVNode(u,{nested:"",schema:e.getItemFormSchema(e.schema,f,e.context),dataPath:e.getDataPath(g),data:f,meta:e.nestedMeta,store:e.getItemStore(e.schema,f,g),disabled:e.disabled||e.isLoading,deletable:e.deletable,draggable:e.draggable,editable:e.editable,editPath:e.getEditPath(f,g),onDelete:k=>e.deleteItem(f,g)},null,8,["schema","dataPath","data","meta","store","disabled","deletable","draggable","editable","editPath","onDelete"])])):n.createCommentVNode("",!0)],8,ud))),128))]),_:1},8,["options","draggable","modelValue"]),e.hasListButtons&&!e.single?(n.openBlock(),n.createElementBlock("tfoot",yd,[n.createElementVNode("tr",null,[n.createElementVNode("td",{class:"dito-table__buttons",colspan:e.numColumns},[n.createVNode(u,{buttons:e.buttonSchemas,schema:e.schema,dataPath:e.dataPath,data:e.data,meta:e.meta,store:e.store,nested:e.nested,disabled:e.disabled||e.isLoading,creatable:e.creatable,createPath:e.createPath},null,8,["buttons","schema","dataPath","data","meta","store","nested","disabled","creatable","createPath"])],8,kd)])])):n.createCommentVNode("",!0)],2),e.hasListButtons&&e.single?(n.openBlock(),n.createBlock(u,{key:1,class:"dito-buttons--large dito-buttons--main dito-buttons--sticky",buttons:e.buttonSchemas,schema:e.schema,dataPath:e.dataPath,data:e.listData,meta:e.meta,store:e.store,disabled:e.disabled||e.isLoading,creatable:e.creatable,createPath:e.createPath},null,8,["buttons","schema","dataPath","data","meta","store","disabled","creatable","createPath"])):n.createCommentVNode("",!0)],8,cd)):n.createCommentVNode("",!0)}const $d=B.register("list",{mixins:[Z,ye],getSourceType(e){return e},getPanelSchema(e,t,o,s){const{filters:i}=t;if(i)return ad(e,i,o,n.computed({get(){return s.query},set(a){const r=l=>h.pickBy(l,d=>d!==void 0);h.equals(r(a),r(s.query))||(s.query=a,s.loadData(!1))}}))},computed:{hasPagination(){return!!this.paginate},hasListButtons(){return!!(this.buttonSchemas||this.creatable)},hasEditButtons(){const{listData:e}=this;return e.length>0&&(this.editable||this.deletable||this.draggable)},hasCellEditButtons(){return!this.isInlined&&this.hasEditButtons},hasEvenCount(){return!(this.listData.length%2)},numColumns(){return(this.columns?Object.keys(this.columns).length:1)+(this.hasCellEditButtons?1:0)}},methods:{getDataPath(e){return O(this.dataPath,e)},getEditPath(e,t){if(this.editable){const o=this.getItemId(this.schema,e,t);return Vt(this.schema,o,this.context)||`${this.path}/${o}`}return null},getCellClass(e){return`dito-cell--${h.hyphenate(e.name)}`},getContext(e,t){return new S(this,{data:e,value:e,index:t,dataPath:this.getDataPath(t)})},onFilterErrors(e){const t=O(this.dataPath,"$filters"),o=this.schemaComponent.getPanelByDataPath(t);if(o)return o.showValidationErrors(e,!0),!0}},async processSchema(e,t,o,s,i,a=!1,r=!1,l=null){await Promise.all([de(t),yt(t.columns),Z.processSchema(e,t,o,s,i,a,r,l)])}}),Dd=y($d,[["render",Cd]]);function Bd(e,t,o,s,i,a){const r=n.resolveComponent("DitoLabel");return n.openBlock(),n.createBlock(r,{class:"dito-label-component",label:e.value,dataPath:e.dataPath},null,8,["label","dataPath"])}const wd=B.register("label",{excludeValue:!0,generateLabel:!1}),Sd=y(wd,[["render",Bd]]);function kn(e,t,o){for(let s=0;;s++){if(s==e.childCount||s==t.childCount)return e.childCount==t.childCount?null:o;let i=e.child(s),a=t.child(s);if(i==a){o+=i.nodeSize;continue}if(!i.sameMarkup(a))return o;if(i.isText&&i.text!=a.text){for(let r=0;i.text[r]==a.text[r];r++)o++;return o}if(i.content.size||a.content.size){let r=kn(i.content,a.content,o+1);if(r!=null)return r}o+=i.nodeSize}}function Cn(e,t,o,s){for(let i=e.childCount,a=t.childCount;;){if(i==0||a==0)return i==a?null:{a:o,b:s};let r=e.child(--i),l=t.child(--a),d=r.nodeSize;if(r==l){o-=d,s-=d;continue}if(!r.sameMarkup(l))return{a:o,b:s};if(r.isText&&r.text!=l.text){let c=0,p=Math.min(r.text.length,l.text.length);for(;c<p&&r.text[r.text.length-c-1]==l.text[l.text.length-c-1];)c++,o--,s--;return{a:o,b:s}}if(r.content.size||l.content.size){let c=Cn(r.content,l.content,o-1,s-1);if(c)return c}o-=d,s-=d}}class E{constructor(t,o){if(this.content=t,this.size=o||0,o==null)for(let s=0;s<t.length;s++)this.size+=t[s].nodeSize}nodesBetween(t,o,s,i=0,a){for(let r=0,l=0;l<o;r++){let d=this.content[r],c=l+d.nodeSize;if(c>t&&s(d,i+l,a||null,r)!==!1&&d.content.size){let p=l+1;d.nodesBetween(Math.max(0,t-p),Math.min(d.content.size,o-p),s,i+p)}l=c}}descendants(t){this.nodesBetween(0,this.size,t)}textBetween(t,o,s,i){let a="",r=!0;return this.nodesBetween(t,o,(l,d)=>{let c=l.isText?l.text.slice(Math.max(t,d)-d,o-d):l.isLeaf?i?typeof i=="function"?i(l):i:l.type.spec.leafText?l.type.spec.leafText(l):"":"";l.isBlock&&(l.isLeaf&&c||l.isTextblock)&&s&&(r?r=!1:a+=s),a+=c},0),a}append(t){if(!t.size)return this;if(!this.size)return t;let o=this.lastChild,s=t.firstChild,i=this.content.slice(),a=0;for(o.isText&&o.sameMarkup(s)&&(i[i.length-1]=o.withText(o.text+s.text),a=1);a<t.content.length;a++)i.push(t.content[a]);return new E(i,this.size+t.size)}cut(t,o=this.size){if(t==0&&o==this.size)return this;let s=[],i=0;if(o>t)for(let a=0,r=0;r<o;a++){let l=this.content[a],d=r+l.nodeSize;d>t&&((r<t||d>o)&&(l.isText?l=l.cut(Math.max(0,t-r),Math.min(l.text.length,o-r)):l=l.cut(Math.max(0,t-r-1),Math.min(l.content.size,o-r-1))),s.push(l),i+=l.nodeSize),r=d}return new E(s,i)}cutByIndex(t,o){return t==o?E.empty:t==0&&o==this.content.length?this:new E(this.content.slice(t,o))}replaceChild(t,o){let s=this.content[t];if(s==o)return this;let i=this.content.slice(),a=this.size+o.nodeSize-s.nodeSize;return i[t]=o,new E(i,a)}addToStart(t){return new E([t].concat(this.content),this.size+t.nodeSize)}addToEnd(t){return new E(this.content.concat(t),this.size+t.nodeSize)}eq(t){if(this.content.length!=t.content.length)return!1;for(let o=0;o<this.content.length;o++)if(!this.content[o].eq(t.content[o]))return!1;return!0}get firstChild(){return this.content.length?this.content[0]:null}get lastChild(){return this.content.length?this.content[this.content.length-1]:null}get childCount(){return this.content.length}child(t){let o=this.content[t];if(!o)throw new RangeError("Index "+t+" out of range for "+this);return o}maybeChild(t){return this.content[t]||null}forEach(t){for(let o=0,s=0;o<this.content.length;o++){let i=this.content[o];t(i,s,o),s+=i.nodeSize}}findDiffStart(t,o=0){return kn(this,t,o)}findDiffEnd(t,o=this.size,s=t.size){return Cn(this,t,o,s)}findIndex(t){if(t==0)return Ce(0,t);if(t==this.size)return Ce(this.content.length,t);if(t>this.size||t<0)throw new RangeError(`Position ${t} outside of fragment (${this})`);for(let o=0,s=0;;o++){let i=this.child(o),a=s+i.nodeSize;if(a>=t)return a==t?Ce(o+1,a):Ce(o,s);s=a}}toString(){return"<"+this.toStringInner()+">"}toStringInner(){return this.content.join(", ")}toJSON(){return this.content.length?this.content.map(t=>t.toJSON()):null}static fromJSON(t,o){if(!o)return E.empty;if(!Array.isArray(o))throw new RangeError("Invalid input for Fragment.fromJSON");return new E(o.map(t.nodeFromJSON))}static fromArray(t){if(!t.length)return E.empty;let o,s=0;for(let i=0;i<t.length;i++){let a=t[i];s+=a.nodeSize,i&&a.isText&&t[i-1].sameMarkup(a)?(o||(o=t.slice(0,i)),o[o.length-1]=a.withText(o[o.length-1].text+a.text)):o&&o.push(a)}return new E(o||t,s)}static from(t){if(!t)return E.empty;if(t instanceof E)return t;if(Array.isArray(t))return this.fromArray(t);if(t.attrs)return new E([t],t.nodeSize);throw new RangeError("Can not convert "+t+" to a Fragment"+(t.nodesBetween?" (looks like multiple versions of prosemirror-model were loaded)":""))}}E.empty=new E([],0);const _e={index:0,offset:0};function Ce(e,t){return _e.index=e,_e.offset=t,_e}class M{constructor(t,o,s){this.content=t,this.openStart=o,this.openEnd=s}get size(){return this.content.size-this.openStart-this.openEnd}insertAt(t,o){let s=Dn(this.content,t+this.openStart,o);return s&&new M(s,this.openStart,this.openEnd)}removeBetween(t,o){return new M($n(this.content,t+this.openStart,o+this.openStart),this.openStart,this.openEnd)}eq(t){return this.content.eq(t.content)&&this.openStart==t.openStart&&this.openEnd==t.openEnd}toString(){return this.content+"("+this.openStart+","+this.openEnd+")"}toJSON(){if(!this.content.size)return null;let t={content:this.content.toJSON()};return this.openStart>0&&(t.openStart=this.openStart),this.openEnd>0&&(t.openEnd=this.openEnd),t}static fromJSON(t,o){if(!o)return M.empty;let s=o.openStart||0,i=o.openEnd||0;if(typeof s!="number"||typeof i!="number")throw new RangeError("Invalid input for Slice.fromJSON");return new M(E.fromJSON(t,o.content),s,i)}static maxOpen(t,o=!0){let s=0,i=0;for(let a=t.firstChild;a&&!a.isLeaf&&(o||!a.type.spec.isolating);a=a.firstChild)s++;for(let a=t.lastChild;a&&!a.isLeaf&&(o||!a.type.spec.isolating);a=a.lastChild)i++;return new M(t,s,i)}}M.empty=new M(E.empty,0,0);function $n(e,t,o){let{index:s,offset:i}=e.findIndex(t),a=e.maybeChild(s),{index:r,offset:l}=e.findIndex(o);if(i==t||a.isText){if(l!=o&&!e.child(r).isText)throw new RangeError("Removing non-flat range");return e.cut(0,t).append(e.cut(o))}if(s!=r)throw new RangeError("Removing non-flat range");return e.replaceChild(s,a.copy($n(a.content,t-i-1,o-i-1)))}function Dn(e,t,o,s){let{index:i,offset:a}=e.findIndex(t),r=e.maybeChild(i);if(a==t||r.isText)return s&&!s.canReplace(i,i,o)?null:e.cut(0,t).append(o).append(e.cut(t));let l=Dn(r.content,t-a-1,o,r);return l&&e.replaceChild(i,r.copy(l))}const Vd=["id"],Pd={key:0,class:"dito-buttons dito-buttons--toolbar"},Ed={class:"dito-buttons__group"},Nd=["onClick"];function Od(e,t,o,s,i,a){const r=n.resolveComponent("DitoIcon"),l=n.resolveComponent("EditorContent");return n.openBlock(),n.createElementBlock("div",{class:"dito-markup",id:e.dataPath},[e.groupedButtons.length>0?(n.openBlock(),n.createElementBlock("div",Pd,[(n.openBlock(!0),n.createElementBlock(n.Fragment,null,n.renderList(e.groupedButtons,d=>(n.openBlock(),n.createElementBlock("div",Ed,[(n.openBlock(!0),n.createElementBlock(n.Fragment,null,n.renderList(d,({name:c,icon:p,isActive:u,onClick:m})=>(n.openBlock(),n.createElementBlock("button",{class:n.normalizeClass(["dito-button",{"dito-button--active":u}]),key:c,onClick:m},[n.createVNode(r,{name:p},null,8,["name"])],10,Nd))),128))]))),256))])):n.createCommentVNode("",!0),n.createVNode(l,{class:"dito-markup-editor",ref:"editor",editor:e.editor,style:n.normalizeStyle(e.styles)},null,8,["editor","style"]),e.resizable?(n.openBlock(),n.createElementBlock("div",{key:1,class:"dito-resize",onMousedown:t[0]||(t[0]=n.withModifiers((...d)=>e.onDragResize&&e.onDragResize(...d),["stop","prevent"]))},null,32)):n.createCommentVNode("",!0)],8,Vd)}const Td=B.register("markup",{mixins:[H],components:{EditorContent:se.EditorContent,DitoIcon:Q},data(){return{editor:null,height:null}},computed:{lines(){return this.schema.lines||10},hardBreak(){return!!this.schema.hardBreak},styles(){return{height:this.height||`calc(${this.lines}em * var(--line-height))`}},markButtons(){return this.getButtons("marks",{bold:!0,italic:!0,underline:!0,strike:!0,small:!0,code:!0,subscript:!0,superscript:!0,link:{onClick:e=>this.onClickLink(e)}})},basicNodeButtons(){return this.getButtons("nodes",{paragraph:{command:"setParagraph"},heading:{attribute:"level",values:[1,2,3,4,5,6]}})},advancedNodeButtons(){return this.getButtons("nodes",{bulletList:!0,orderedList:!0,blockquote:!0,codeBlock:!0})},toolButtons(){return this.getButtons("tools",{undo:!0,redo:!0,footnotes:{command:"addFootnote"}})},groupedButtons(){return[this.markButtons,this.basicNodeButtons,this.advancedNodeButtons,this.toolButtons].filter(e=>e.length>0)},parseOptions(){return{preserveWhitespace:{collapse:!1,preserve:!0,"preserve-all":"full"}[this.whitespace]}},editorOptions(){return{editable:!this.readyonly,autoFocus:this.autofocus,disableInputRules:!this.enableRules.input,disablePasteRules:!this.enableRules.paste,parseOptions:this.parseOptions,editorProps:this.hardBreak?{handlePaste:(e,t,o)=>{const s=[];o.content.forEach((a,r,l)=>{l>0&&a.type.name==="paragraph"&&s.push(e.state.schema.nodes.hardBreak.create()),a.type.name==="paragraph"?a.content.forEach(d=>s.push(d)):s.push(a)});const i=e.state.schema.nodes.paragraph.create(null,E.from(s));return e.dispatch(e.state.tr.replaceSelection(new M(E.from(i),0,0))),!0}}:{}}},resizable:b("resizable",{type:Boolean,default:!1}),whitespace:b("whitespace",{type:String,default:"collapse"}),enableRules:b("enableRules",{type:[Object,Boolean],default:!1,get(e){return h.isObject(e)?e:{input:!!e,paste:!!e}}})},watch:{readyonly:"updateEditorOptions",autofocus:"updateEditorOptions",enableRules:"updateEditorOptions"},created(){let e=!1,t=!1;const o=()=>this.onFocus(),s=()=>{this.onBlur(),r()},i=()=>{a(),this.onInput()},a=h.debounce(()=>{t=!0,r()},100),r=()=>{const l=this.editor.getHTML(),d=this.hardBreak?l.replace(/^<p>(.*?)<\/p>$/s,"$1"):l;d!==this.value&&(e=!0,this.value=d),!this.focused&&e&&(this.onChange(),e=!1)};this.$watch("value",l=>{if(t)t=!1;else{const d=this.hardBreak?`<p>${l}</p>`:l;this.editor.commands.setContent(d,{emitUpdate:!1,parseOptions:this.parseOptions})}}),this.editor=new se.Editor({...this.editorOptions,onFocus:o,onBlur:s,onUpdate:i,extensions:this.getExtensions(),content:this.value||""})},unmounted(){this.editor.destroy()},methods:{onDragResize(e){const t=({clientX:r,clientY:l})=>({x:r,y:l});let o=t(e).y,s=parseFloat(getComputedStyle(this.$refs.editor.$el).height);const i=r=>{const{y:l}=t(r);s+=l-o,o=l,this.height=`${Math.max(s,0)}px`},a=this.domOn(document,{mousemove:i,mouseup(r){i(r),a.remove()}})},updateEditorOptions(){this.editor.setOptions(this.editorOptions)},async onClickLink(e){const t=await this.rootComponent.showDialog({components:{DitoIcon:Q,href:{type:"url",label:"Link",autofocus:!0},title:{type:"text",label:"Title"}},buttons:{cancel:{},apply:{type:"submit"},remove:{events:{click({dialogComponent:o}){o.resolve(null)}}}},data:se.getMarkAttributes(this.editor.state,"link")});if(t){let{href:o,title:s}=t;if(o)try{new URL(o)}catch{o=`https://${o}`}e.commands.setLink({href:o,title:s})}else t===null&&e.commands.unsetLink()},getExtensions(){const{marks:e={},nodes:t={},tools:o={}}=this.schema;return[o.footnotes?nt.Document.extend({content:"block+ footnotes?"}):nt.Document,Tn.Text,Kn.Paragraph,e.bold&&Ln.Bold,e.italic&&In.Italic,e.underline&&An.Underline,e.strike&&Rn.Strike,e.small&&Ld,e.code&&Fn.Code,e.subscript&&zn.Superscript,e.superscript&&jn.Subscript,e.link&&Fd,t.blockquote&&qn.Blockquote,t.codeBlock&&Un.CodeBlock,t.heading&&Wn.Heading.configure({levels:t.heading}),t.horizontalRule&&Yn.HorizontalRule,(t.orderedList||t.bulletList)&&Qn.ListItem,t.bulletList&&Gn.BulletList,t.orderedList&&Jn.OrderedList,...o.footnotes?[Se.Footnotes,Se.Footnote,Se.FootnoteReference]:[],o.history&&Xn.History,Hn.HardBreak.extend({addKeyboardShortcuts:()=>{const s=()=>this.editor.commands.setHardBreak();return{"Mod-Enter":s,"Shift-Enter":s,...this.hardBreak?{Enter:s}:null}}})].filter(s=>!!s)},getButtons(e,t){const o=[],{commands:s}=this.editor,i=({name:r,icon:l,command:d,attributes:c,onClick:p})=>{o.push({name:r,icon:l,isActive:this.editor.isActive(r,c),onClick:()=>{d??=r in s?r:`toggle${h.camelize(r,!0)}`,d in s&&(p?p(this.editor,c):(m=>this.editor.chain()[d](m).focus().run())(c))}})},a=this.schema[e];if(a)for(const[r,l]of Object.entries(t)){const d=["undo","redo"].includes(r)?"history":r,c=a[d],p=h.hyphenate(r);if(c){if(l===!0)i({name:r,icon:p});else if(h.isObject(l)){const{command:u,attribute:m,values:f,onClick:g}=l;if(m){if(h.isArray(f)&&h.isArray(c))for(const k of f)c.includes(k)&&i({name:r,icon:`${p}-${k}`,command:u,attributes:{[m]:k},onClick:g})}else i({name:r,icon:p,command:u,onClick:g})}}}return o},focusElement(){this.editor.commands.focus()},blurElement(){this.editor.commands.blur()}}}),Ld=se.Mark.create({name:"small",parseHTML(){return[{tag:"small"}]},renderHTML(){return["small",0]},addCommands(){return{setSmall:e=>({commands:t})=>t.setMark(this.name,e),toggleSmall:e=>({commands:t})=>t.toggleMark(this.name,e),unsetSmall:()=>({commands:e})=>e.unsetMark(this.name)}}}),Fd=Mn.Link.extend({inclusive:!1,addAttributes(){return{href:{default:null},title:{default:null}}},parseHTML(){return[{tag:"a",getAttrs:e=>({href:e.getAttribute("href"),title:e.getAttribute("title")})}]},renderHTML({HTMLAttributes:e}){return["a",e,0]}}),Id=y(Td,[["render",Od]]),Md={class:"dito-multiselect"},Rd={class:"dito-multiselect__inner"};function jd(e,t,o,s,i,a){const r=n.resolveComponent("DitoAffixes"),l=n.resolveComponent("VueMultiselect"),d=n.resolveComponent("DitoEditButtons");return n.openBlock(),n.createElementBlock("div",Md,[n.createElementVNode("div",Rd,[n.createVNode(r,{items:e.schema.prefix,position:"prefix",mode:"input",absolute:"",disabled:e.disabled,parentContext:e.context},null,8,["items","disabled","parentContext"]),n.createVNode(l,n.mergeProps({ref:"element",modelValue:e.selectedOptions,"onUpdate:modelValue":t[0]||(t[0]=c=>e.selectedOptions=c),class:e.multiselectClasses,showLabels:!1,placeholder:e.placeholder,tagPlaceholder:"Press enter to add new tag",options:e.populate&&e.activeOptions||[],customLabel:e.getLabelForOption,trackBy:e.optionValue,groupLabel:e.groupByLabel,groupValues:e.groupByOptions,multiple:e.multiple,taggable:e.taggable,searchable:e.searchable,internalSearch:!e.searchFilter,preserveSearch:!!e.searchFilter,clearOnSelect:!e.searchFilter,closeOnSelect:!e.stayOpen,loading:e.isLoading},e.attributes,{onOpen:e.onOpen,onClose:e.onClose,onTag:e.onAddTag,onSearchChange:e.onSearchChange}),null,16,["modelValue","class","placeholder","options","customLabel","trackBy","groupLabel","groupValues","multiple","taggable","searchable","internalSearch","preserveSearch","clearOnSelect","closeOnSelect","loading","onOpen","onClose","onTag","onSearchChange"]),n.createVNode(r,{items:e.schema.suffix,position:"suffix",mode:"input",absolute:"",clearable:e.showClearButton,disabled:e.disabled,inlineInfo:e.inlineInfo,parentContext:e.context,onClear:e.clear},null,8,["items","clearable","disabled","inlineInfo","parentContext","onClear"])]),e.editable?(n.openBlock(),n.createBlock(d,{key:0,schema:e.schema,dataPath:e.dataPath,data:e.data,meta:e.meta,store:e.store,disabled:!1,editable:e.editable,editPath:e.editPath},null,8,["schema","dataPath","data","meta","store","editable","editPath"])):n.createCommentVNode("",!0)])}const zd=B.register("multiselect",{mixins:[ke],components:{DitoAffixes:I,VueMultiselect:Zn},data(){return{searchedOptions:null,populate:!1}},computed:{selectedOptions:{get(){return this.multiple?(this.selectedValue||[]).map(e=>this.getOptionForValue(e)||this.addTagOption(e)).filter(Boolean):this.selectedOption},set(e){this.selectedValue=this.multiple?(e||[]).map(t=>this.getValueForOption(t)):this.getValueForOption(e),this.onChange()}},activeOptions(){return this.searchedOptions||this.options},multiple:b("multiple",{type:Boolean,default:!1}),searchable:b("searchable",{type:Boolean,default:!1}),taggable:b("taggable",{type:Boolean,default:!1}),stayOpen:b("stayOpen",{type:Boolean,default:!1}),multiselectClasses(){const e="multiselect";return{[`${e}--multiple`]:this.multiple,[`${e}--loading`]:this.isLoading,[`${e}--highlight`]:this.showHighlight}},placeholder(){let{placeholder:e,searchable:t,taggable:o}=this.schema;return h.isBoolean(e)&&(e=e?void 0:null),e===void 0?t&&o?`Search or add a ${this.label}`:t?`Select or search ${this.label}`:void 0:e},showHighlight(){return this.isMounted&&this.$refs.element.pointerDirty}},mounted(){this.autofocus&&this.focus()},methods:{addTagOption(e){if(this.taggable){const{optionLabel:t,optionValue:o}=this,s=t&&o?{[t]:e,[o]:e}:e;return this.options.push(s),s}},focusElement(){this.$refs.element.activate()},blurElement(){this.$refs.element.deactivate()},onOpen(){this.populate=!0},onClose(){this.focused&&this.onBlur()},onBlur(){this.$refs.element.isOpen||Oe.methods.onBlur.call(this)},onAddTag(e){const t=this.addTagOption(e);t&&(this.value??=[],this.value.push(this.getValueForOption(t)))},async onSearchChange(e){this.searchFilter&&(e?(this.searchedOptions=[],this.searchedOptions=await this.resolveData(()=>this.searchFilter(new S(this,{searchTerm:e})))):this.searchedOptions=null)}}}),Ad=y(zd,[["render",jd]]),xe={computed:{inputValue:{get(){return this.value!==null?this.value:""},set(e){this.value=e!==""?this.isInteger?Number(e):parseFloat(e):null}},isInteger(){return!1},stepValue(){return this.step==null&&!this.isInteger?"any":this.step},decimals:b("decimals",{type:Number}),step:b("step",{type:Number,get(e){return this.isInteger&&e!=null?Math.ceil(e):e}}),min:b("min",{type:Number,get(e){return e=e===void 0?this.getSchemaValue("range",{type:Array})?.[0]:e,this.isInteger&&e!=null?Math.floor(e):e}}),max:b("max",{type:Number,get(e){return e=e===void 0?this.getSchemaValue("range",{type:Array})?.[1]:e,this.isInteger&&e!=null?Math.ceil(e):e}}),range:b("range",{type:Array,get(){const{min:e,max:t}=this;return e!=null&&t!=null?[e,t]:void 0},set(e){h.isArray(e)&&([this.min,this.max]=e)}})},methods:{getValidations(){const e={},{range:t,min:o,max:s,decimals:i,step:a}=this;if(t?e.range=t:(o!=null&&(e.min=o),s!=null&&(e.max=s)),i!=null)e.decimals=i;else if(a){const r=(`${a}`.split(".")[1]||"").length;r>0?e.decimals=r:e.integer=!0}return this.isInteger&&(e.integer=!0),e}}};function qd(e,t,o,s,i,a){const r=n.resolveComponent("DitoAffixes"),l=n.resolveComponent("DitoInput");return n.openBlock(),n.createBlock(l,n.mergeProps({class:"dito-number",id:e.dataPath,ref:"element",modelValue:e.inputValue,"onUpdate:modelValue":t[0]||(t[0]=d=>e.inputValue=d),type:"number"},e.attributes,{min:e.min,max:e.max,step:e.stepValue}),{prefix:n.withCtx(()=>[n.createVNode(r,{items:e.schema.prefix,position:"prefix",mode:"input",disabled:e.disabled,parentContext:e.context},null,8,["items","disabled","parentContext"])]),suffix:n.withCtx(()=>[n.createVNode(r,{items:e.schema.suffix,position:"suffix",mode:"input",clearable:e.showClearButton,disabled:e.disabled,inlineInfo:e.inlineInfo,parentContext:e.context,onClear:e.clear},null,8,["items","clearable","disabled","inlineInfo","parentContext","onClear"])]),_:1},16,["id","modelValue","min","max","step"])}const Ud=B.register(["number","integer"],{mixins:[xe],components:{DitoInput:U,DitoAffixes:I},nativeField:!0,textField:!0,computed:{isInteger(){return this.type==="integer"}}}),Hd=y(Ud,[["render",qd]]),Wd=["id"],Kd={key:0,class:"dito-object-content"},Yd=["innerHTML"],Jd=["innerHTML"];function Gd(e,t,o,s,i,a){const r=n.resolveComponent("DitoSchemaInlined"),l=n.resolveComponent("DitoEditButtons");return e.isReady?(n.openBlock(),n.createElementBlock("div",{key:0,class:"dito-object",id:e.dataPath},[e.objectData?(n.openBlock(),n.createElementBlock("div",Kd,[e.isInlined?(n.openBlock(),n.createBlock(r,{key:0,label:e.objectLabel,schema:e.getItemFormSchema(e.schema,e.objectData,e.context),dataPath:e.dataPath,data:e.objectData,meta:e.nestedMeta,store:e.store,disabled:e.disabled||e.isLoading,collapsed:e.collapsed,collapsible:e.collapsible,deletable:e.objectData&&e.deletable,editable:e.objectData&&e.editable,editPath:e.path,accumulatedBasis:e.accumulatedBasis,onDelete:t[0]||(t[0]=d=>e.deleteItem(e.objectData))},null,8,["label","schema","dataPath","data","meta","store","disabled","collapsed","collapsible","deletable","editable","editPath","accumulatedBasis"])):e.schema.component?(n.openBlock(),n.createBlock(n.resolveDynamicComponent(e.schema.component),{key:1,dataPath:e.dataPath,data:e.objectData,nested:!1},null,8,["dataPath","data"])):e.render?(n.openBlock(),n.createElementBlock("span",{key:2,innerHTML:e.render(e.getContext())},null,8,Yd)):(n.openBlock(),n.createElementBlock("span",{key:3,innerHTML:e.getItemLabel(e.schema,e.objectData)},null,8,Jd))])):n.createCommentVNode("",!0),n.createVNode(l,{buttons:e.buttonSchemas,schema:e.schema,dataPath:e.dataPath,data:e.objectData,path:e.path,meta:e.meta,store:e.store,disabled:e.disabled||e.isLoading,creatable:e.creatable,createPath:e.createPath},null,8,["buttons","schema","dataPath","data","path","meta","store","disabled","creatable","createPath"])],8,Wd)):n.createCommentVNode("",!0)}const Qd=B.register("object",{mixins:[Z],getSourceType(e){return e},computed:{objectLabel(){return this.collapsible?this.getItemLabel(this.schema,this.objectData,{asObject:!0}):null}},methods:{getContext(){return new S(this,{data:this.objectData})}},async processSchema(e,t,o,s,i,a=!1,r=!1,l=null){await Promise.all([de(t),Z.processSchema(e,t,o,s,i,a,r,l)])}}),Xd=y(Qd,[["render",Gd]]),Zd=B.register("panel",{defaultValue:()=>{},excludeValue:!0,generateLabel:!1,omitSpacing:!0,getPanelSchema(e,t){const{name:o,...s}=t;return s}}),_d=["id","value","max"];function xd(e,t,o,s,i,a){return n.openBlock(),n.createElementBlock("progress",n.mergeProps({class:"dito-progress",id:e.dataPath,ref:"element",value:e.progressValue,max:e.progressMax},e.attributes),null,16,_d)}const vd=B.register("progress",{mixins:[xe],computed:{progressValue(){let{value:e,range:t,step:o}=this;return e!==null?(t&&(e-=t[0]),o&&(e=Math.round(e/o)*o)):e="",e},progressMax(){const{range:e}=this;return e?e[1]-e[0]:null}}}),ec=y(vd,[["render",xd]]),tc=["id"],nc=["value"];function oc(e,t,o,s,i,a){return n.openBlock(),n.createElementBlock("ul",{class:n.normalizeClass(["dito-radio-buttons",`dito-layout--${e.schema.layout||"vertical"}`]),id:e.dataPath},[(n.openBlock(!0),n.createElementBlock(n.Fragment,null,n.renderList(e.options,r=>(n.openBlock(),n.createElementBlock("li",null,[n.createElementVNode("label",null,[n.withDirectives(n.createElementVNode("input",n.mergeProps({class:"dito-radio-button",ref_for:!0,ref:"element","onUpdate:modelValue":t[0]||(t[0]=l=>e.selectedValue=l),type:"radio",value:e.getValueForOption(r)},{ref_for:!0},e.attributes),null,16,nc),[[n.vModelRadio,e.selectedValue]]),n.createTextVNode(n.toDisplayString(e.getLabelForOption(r)),1)])]))),256))],10,tc)}const sc=B.register("radio",{mixins:[ke],nativeField:!0,defaultWidth:"auto"}),ac=y(sc,[["render",oc]]);function ic(e,t,o,s,i,a){const r=n.resolveComponent("DitoSchemaInlined");return n.openBlock(),n.createElementBlock("div",{class:n.normalizeClass(["dito-section",{"dito-section--labelled":e.hasLabel}])},[n.createVNode(r,{class:"dito-section__schema",schema:e.getItemFormSchema(e.schema,e.item,e.context),dataPath:e.dataPath,data:e.item,meta:e.meta,store:e.store,label:e.label,info:e.info,padding:e.hasLabel?"nested":"inlined",disabled:e.disabled,collapsed:e.collapsed,collapsible:e.collapsible,labelNode:e.labelNode},null,8,["schema","dataPath","data","meta","store","label","info","padding","disabled","collapsed","collapsible","labelNode"])],2)}const rc=B.register("section",{defaultValue:()=>{},ignoreMissingValue:({schema:e})=>!e.nested&&!("default"in e),defaultNested:!1,generateLabel:!1,computed:{item(){return this.nested?this.value:this.data},hasLabel(){return!!this.schema.label},collapsible:b("collapsible",{type:Boolean,default:!1}),collapsed:b("collapsed",{type:Boolean,default:!1,get(e){return e&&this.collapsible}})},methods:{getItemFormSchema:je},async processSchema(e,t,o,s,i){await x(e,t,s,i)}}),lc=y(rc,[["render",ic]]),dc={class:"dito-select"},cc={class:"dito-select__inner"},hc=["id"],pc=["label"],uc=["value"],mc=["value"],fc=["value"];function gc(e,t,o,s,i,a){const r=n.resolveComponent("DitoAffixes"),l=n.resolveComponent("DitoEditButtons");return n.openBlock(),n.createElementBlock("div",dc,[n.createElementVNode("div",cc,[n.createVNode(r,{items:e.schema.prefix,position:"prefix",mode:"input",absolute:"",disabled:e.disabled,parentContext:e.context},null,8,["items","disabled","parentContext"]),n.withDirectives(n.createElementVNode("select",n.mergeProps({id:e.dataPath,ref:"element","onUpdate:modelValue":t[0]||(t[0]=d=>e.selectedValue=d)},e.attributes,{onMousedown:t[1]||(t[1]=d=>e.populate=!0),onFocus:t[2]||(t[2]=d=>e.populate=!0)}),[e.populate?(n.openBlock(!0),n.createElementBlock(n.Fragment,{key:0},n.renderList(e.options,d=>(n.openBlock(),n.createElementBlock(n.Fragment,null,[e.groupBy?(n.openBlock(),n.createElementBlock("optgroup",{key:0,label:d[e.groupByLabel]},[(n.openBlock(!0),n.createElementBlock(n.Fragment,null,n.renderList(d[e.groupByOptions],c=>(n.openBlock(),n.createElementBlock("option",{value:e.getValueForOption(c)},n.toDisplayString(e.getLabelForOption(c)),9,uc))),256))],8,pc)):(n.openBlock(),n.createElementBlock("option",{key:1,value:e.getValueForOption(d)},n.toDisplayString(e.getLabelForOption(d)),9,mc))],64))),256)):e.selectedOption?(n.openBlock(),n.createElementBlock("option",{key:1,value:e.selectedValue},n.toDisplayString(e.getLabelForOption(e.selectedOption)),9,fc)):n.createCommentVNode("",!0)],16,hc),[[n.vModelSelect,e.selectedValue]]),n.createVNode(r,{items:e.schema.suffix,position:"suffix",mode:"input",absolute:"",clearable:e.showClearButton,disabled:e.disabled,inlineInfo:e.inlineInfo,parentContext:e.context,onClear:e.clear},null,8,["items","clearable","disabled","inlineInfo","parentContext","onClear"])]),e.editable?(n.openBlock(),n.createBlock(l,{key:0,schema:e.schema,dataPath:e.dataPath,data:e.data,meta:e.meta,store:e.store,disabled:!1,editable:e.editable,editPath:e.editPath},null,8,["schema","dataPath","data","meta","store","editable","editPath"])):n.createCommentVNode("",!0)])}const bc=B.register("select",{mixins:[ke],components:{DitoAffixes:I},nativeField:!0,data(){return{populate:!0}}}),yc=y(bc,[["render",gc]]),kc={class:"dito-slider"},Cc=["id","min","max","step"];function $c(e,t,o,s,i,a){const r=n.resolveComponent("DitoInput");return n.openBlock(),n.createElementBlock("div",kc,[n.withDirectives(n.createElementVNode("input",n.mergeProps({class:"dito-range",id:e.dataPath,ref:"element","onUpdate:modelValue":t[0]||(t[0]=l=>e.inputValue=l),type:"range"},e.attributes,{min:e.min,max:e.max,step:e.stepValue}),null,16,Cc),[[n.vModelText,e.inputValue]]),e.input?(n.openBlock(),n.createBlock(r,n.mergeProps({key:0,class:"dito-number",modelValue:e.inputValue,"onUpdate:modelValue":t[1]||(t[1]=l=>e.inputValue=l),type:"number"},e.attributes,{min:e.min,max:e.max,step:e.stepValue}),null,16,["modelValue","min","max","step"])):n.createCommentVNode("",!0)])}const Dc=B.register("slider",{mixins:[xe],components:{DitoInput:U},nativeField:!0,computed:{input:b("input",{type:Boolean,default:!0})}}),Bc=y(Dc,[["render",$c]]);function wc(e,t,o,s,i,a){return null}const Sc=B.register("spacer",{defaultValue:()=>{},excludeValue:!0,generateLabel:!1}),Vc=y(Sc,[["render",wc]]);function Pc(e,t,o,s,i,a){const r=n.resolveComponent("DitoSwitch");return n.openBlock(),n.createBlock(r,n.mergeProps({class:"dito-switch",id:e.dataPath,ref:"element",modelValue:e.value,"onUpdate:modelValue":t[0]||(t[0]=l=>e.value=l),labels:e.labels},e.attributes),null,16,["id","modelValue","labels"])}const Ec=B.register("switch",{defaultValue:!1,defaultWidth:"auto",components:{DitoSwitch:_s},computed:{labels(){return this.schema.labels}}}),Nc=y(Ec,[["render",Pc]]),Bn={computed:{trim:b("trim",{type:Boolean,default:!1})},processValue(e){let{schema:t,value:o}=e;return t.trim&&o!=null&&h.isString(o)&&(o=o.trim()),o===""&&(o=Ue(t,e)),o}};function Oc(e,t,o,s,i,a){const r=n.resolveComponent("DitoAffixes"),l=n.resolveComponent("DitoInput");return n.openBlock(),n.createBlock(l,n.mergeProps({class:"dito-text",id:e.dataPath,ref:"element",modelValue:e.inputValue,"onUpdate:modelValue":t[0]||(t[0]=d=>e.inputValue=d),type:e.inputType},e.attributes),{prefix:n.withCtx(()=>[n.createVNode(r,{items:e.schema.prefix,position:"prefix",mode:"input",disabled:e.disabled,parentContext:e.context},null,8,["items","disabled","parentContext"])]),suffix:n.withCtx(()=>[n.createVNode(r,{items:e.schema.suffix,position:"suffix",mode:"input",clearable:e.showClearButton,disabled:e.disabled,inlineInfo:e.inlineInfo,parentContext:e.context,onClear:e.clear},null,8,["items","clearable","disabled","inlineInfo","parentContext","onClear"])]),_:1},16,["id","modelValue","type"])}const Tc="****************",Lc=B.register(["text","email","url","hostname","domain","tel","password","creditcard"],{mixins:[Bn],components:{DitoInput:U,DitoAffixes:I},nativeField:!0,textField:!0,ignoreMissingValue:({schema:e})=>e.type==="password",computed:{inputType(){return{creditcard:"text",hostname:"text",domain:"text"}[this.type]||this.type},inputValue:{get(){return this.type==="password"&&this.value===void 0&&!this.focused?Tc:this.value},set(e){this.value=e}}},methods:{getValidations(){const e={email:"email",url:"url",hostname:"hostname",domain:"domain",password:"password",creditcard:"creditcard"}[this.type];return e?{[e]:!0}:{}}}}),Fc=y(Lc,[["render",Oc]]),Ic=["id","rows"];function Mc(e,t,o,s,i,a){return n.withDirectives((n.openBlock(),n.createElementBlock("textarea",n.mergeProps({class:"dito-textarea dito-input",id:e.dataPath,ref:"element","onUpdate:modelValue":t[0]||(t[0]=r=>e.value=r)},e.attributes,{rows:e.lines,class:{"dito-textarea--resizable":e.resizable}}),null,16,Ic)),[[n.vModelText,e.value]])}const Rc=B.register("textarea",{mixins:[Bn],nativeField:!0,textField:!0,computed:{lines(){return this.schema.lines||4},resizable:b("resizable",{type:Boolean,default:!1})}}),jc=y(Rc,[["render",Mc]]),zc={class:"dito-tree-list"},Ac={class:"dito-tree-panel"},qc={key:0,class:"dito-tree-form-container"};function Uc(e,t,o,s,i,a){const r=n.resolveComponent("DitoScopes"),l=n.resolveComponent("DitoTreeItem"),d=n.resolveComponent("RouterView");return n.openBlock(),n.createElementBlock("div",zc,[e.scopes?(n.openBlock(),n.createBlock(r,{key:0,query:e.query,scopes:e.scopes},null,8,["query","scopes"])):n.createCommentVNode("",!0),n.createElementVNode("div",Ac,[n.createVNode(l,{schema:e.treeSchema,dataPath:e.treeDataPath,data:e.treeData,draggable:e.draggable,open:!0,"onUpdate:data":t[0]||(t[0]=c=>e.value=c)},null,8,["schema","dataPath","data","draggable"]),e.editPath&&e.hasEditableForms?(n.openBlock(),n.createElementBlock("div",qc,[n.createVNode(d)])):n.createCommentVNode("",!0)])])}const Hc=B.register(["tree-list","tree-object"],{mixins:[Z],provide(){return{container:this}},getSourceType(e){return e==="tree-object"?"object":"list"},computed:{path(){return this.formComponent?.path},editPath(){const e=this.$route.path.slice(this.path?.length);return e.startsWith(`/${this.schema.path}`)?e:""},treeData(){return this.isListSource?{[this.name]:this.value}:this.value},treeDataPath(){return this.isListSource?this.dataPath.slice(0,this.dataPath.length-this.name.length):this.dataPath},treeSchema(){return this.isListSource?{children:{name:this.name,...this.schema}}:this.schema},hasEditableForms(){const e=t=>q(t)&&(this.getSchemaValue("editable",{type:Boolean,default:!1,schema:t})||t.children&&e(t.children));return e(this.schema)}},async processSchema(e,t,o,s,i,a=!0,r=!1,l=null){await Promise.all([yt(t.properties),Z.processSchema(e,t,o,s,i,a,r,(d,c)=>{const{children:p}=t;if(p)return p.type="tree-list",this.processSchema(e,p,p.name,d,c,a,!0,l)})])},getFormSchemasForProcessing(e,t){const{children:o}=e;return Y(e,t,o?s=>({...s,components:{...s.components,[o.name]:o}}):null)}}),Wc=y(Hc,[["render",Uc]]);function wn(e){return xn.filesize(e,{base:10})}const Kc={class:"dito-upload"},Yc={class:"dito-table dito-table--separators dito-table--background"},Jc=["innerHTML"],Gc={key:1},Qc=["download","href","onClick"],Xc={key:2},Zc={class:"dito-upload__size"},_c={class:"dito-upload__status"},xc={class:"dito-table__buttons"},vc={class:"dito-buttons dito-buttons--round"},eh=["title"],th=["onClick"],nh={key:0},oh={colspan:4},sh={class:"dito-upload-footer"},ah=["value"],ih={class:"dito-buttons dito-buttons--round"},rh=["title"];function lh(e,t,o,s,i,a){const r=n.resolveComponent("VueUpload"),l=n.resolveComponent("DitoUploadFile"),d=n.resolveComponent("DitoDraggable");return n.openBlock(),n.createElementBlock("div",Kc,[n.createVNode(r,{class:"dito-upload__input",ref:"upload",modelValue:e.uploads,"onUpdate:modelValue":t[0]||(t[0]=c=>e.uploads=c),inputId:e.dataPath,name:e.dataPath,disabled:e.disabled,postAction:e.uploadPath,extensions:e.extensions,accept:e.accept,multiple:e.multiple,size:e.maxSize,drop:e.$el?.closest(".dito-container"),dropDirectory:!0,onInputFilter:e.onInputFilter,onInputFile:e.onInputFile},null,8,["modelValue","inputId","name","disabled","postAction","extensions","accept","multiple","size","drop","onInputFilter","onInputFile"]),n.createElementVNode("table",Yc,[t[5]||(t[5]=n.createElementVNode("thead",{class:"dito-table-head"},[n.createElementVNode("tr",null,[n.createElementVNode("th",null,[n.createElementVNode("span",null,"File")]),n.createElementVNode("th",null,[n.createElementVNode("span",null,"Size")]),n.createElementVNode("th",null,[n.createElementVNode("span",null,"Status")]),n.createElementVNode("th",null,[n.createElementVNode("span")])])],-1)),n.createVNode(d,{modelValue:e.files,"onUpdate:modelValue":t[2]||(t[2]=c=>e.files=c),as:"tbody",options:e.getDraggableOptions(),draggable:e.draggable},{default:n.withCtx(()=>[e.multiple||!e.isUploadActive?(n.openBlock(!0),n.createElementBlock(n.Fragment,{key:0},n.renderList(e.files,(c,p)=>(n.openBlock(),n.createElementBlock("tr",{key:c.name},[e.render?(n.openBlock(),n.createElementBlock("td",{key:0,innerHTML:e.renderFile(c,p)},null,8,Jc)):e.downloadUrls[p]?(n.openBlock(),n.createElementBlock("td",Gc,[n.createElementVNode("a",{download:c.name,href:e.downloadUrls[p],target:"_blank",onClick:n.withModifiers(u=>e.onClickDownload(c,p),["prevent"])},[n.createVNode(l,{file:c,thumbnail:e.thumbnails,thumbnailUrl:e.thumbnailUrls[p]},null,8,["file","thumbnail","thumbnailUrl"])],8,Qc)])):(n.openBlock(),n.createElementBlock("td",Xc,[n.createVNode(l,{file:c,thumbnail:e.thumbnails,thumbnailUrl:e.thumbnailUrls[p]},null,8,["file","thumbnail","thumbnailUrl"])])),n.createElementVNode("td",Zc,n.toDisplayString(e.formatFileSize(c.size)),1),n.createElementVNode("td",_c,[c.upload?(n.openBlock(),n.createElementBlock(n.Fragment,{key:0},[c.upload.error?(n.openBlock(),n.createElementBlock(n.Fragment,{key:0},[n.createTextVNode("Error: "+n.toDisplayString(c.upload.error),1)],64)):c.upload.active?(n.openBlock(),n.createElementBlock(n.Fragment,{key:1},[n.createTextVNode("Uploading...")],64)):c.upload.success?(n.openBlock(),n.createElementBlock(n.Fragment,{key:2},[n.createTextVNode("Uploaded")],64)):n.createCommentVNode("",!0)],64)):(n.openBlock(),n.createElementBlock(n.Fragment,{key:1},[n.createTextVNode("Stored")],64))]),n.createElementVNode("td",xc,[n.createElementVNode("div",vc,[e.multiple?n.createCommentVNode("",!0):(n.openBlock(),n.createElementBlock("button",{key:0,class:"dito-button dito-button--upload",title:e.uploadTitle,onClick:t[1]||(t[1]=(...u)=>e.onClickUpload&&e.onClickUpload(...u))},null,8,eh)),e.draggable?(n.openBlock(),n.createElementBlock("a",n.mergeProps({key:1,class:"dito-button"},{ref_for:!0},e.getButtonAttributes(e.verbs.drag)),null,16)):n.createCommentVNode("",!0),e.deletable?(n.openBlock(),n.createElementBlock("button",n.mergeProps({key:2,class:"dito-button",type:"button"},{ref_for:!0},e.getButtonAttributes(e.verbs.delete),{onClick:u=>e.deleteFile(c,p)}),null,16,th)):n.createCommentVNode("",!0)])])]))),128)):n.createCommentVNode("",!0)]),_:1},8,["modelValue","options","draggable"]),e.multiple||e.isUploadActive||!e.hasFiles?(n.openBlock(),n.createElementBlock("tfoot",nh,[n.createElementVNode("tr",null,[n.createElementVNode("td",oh,[n.createElementVNode("div",sh,[e.isUploadActive?(n.openBlock(),n.createElementBlock("progress",{key:0,class:"dito-progress",value:e.uploadProgress,max:"100"},null,8,ah)):n.createCommentVNode("",!0),n.createElementVNode("div",ih,[e.isUploadActive?(n.openBlock(),n.createElementBlock("button",{key:0,class:"dito-button",type:"button",onClick:t[3]||(t[3]=n.withModifiers(c=>e.upload.active=!1,["prevent"]))},"Cancel")):n.createCommentVNode("",!0),e.multiple||!e.hasFiles?(n.openBlock(),n.createElementBlock("button",{key:1,class:"dito-button dito-button--upload",title:e.uploadTitle,onClick:t[4]||(t[4]=(...c)=>e.onClickUpload&&e.onClickUpload(...c))},null,8,rh)):n.createCommentVNode("",!0)])])])])])):n.createCommentVNode("",!0)])])}const dh=B.register("upload",{mixins:[ye],components:{VueUpload:vn},data(){return{uploads:[]}},computed:{upload(){return this.$refs.upload},uploadTitle(){return this.multiple?"Upload Files":"Upload File"},files(){return Sn(this.value)},downloadUrls(){return this.files.map((e,t)=>this.getDownloadUrl(e,t))},thumbnailUrls(){return this.files.map((e,t)=>this.getThumbnailUrl(e,t))},multiple:b("multiple",{type:Boolean,default:!1,callback:!1}),extensions:b("extensions",{type:[Array,String,RegExp]}),accept:b("accept",{type:Array,get(e){return h.isArray(e)?e.join(","):e}}),maxSize:b("maxSize",{type:[String,Number],get(e){return e?_n(e):void 0}}),draggable:b("draggable",{type:Boolean,default:!1,get(e){return e&&this.files.length>1}}),deletable:b("deletable",{type:Boolean,default:!1}),render:b("render",{type:Function,default:null}),thumbnails:b("thumbnails",{type:[Boolean,String],default(e){return e??!!this.schema.thumbnailUrl},get(e){return e===!0?"medium":e||null}}),hasFiles(){return this.files.length>0},hasUploads(){return this.uploads.length>0},isUploadReady(){return this.hasUploads&&!(this.upload.active||this.upload.uploaded)},isUploadActive(){return this.hasUploads&&this.upload.active},uploadProgress(){return this.uploads.reduce((e,t)=>e+ +t.progress,0)/this.uploads.length},uploadPath(){return this.getResourceUrl({type:"upload",method:"post",path:this.api.normalizePath(this.dataPath)})}},watch:{isUploadReady(e){e&&this.$nextTick(()=>{this.upload.active=!0})}},methods:{formatFileSize:wn,getFileContext(e,t){return this.multiple?new S(this,{value:e,data:this.files,index:t,dataPath:O(this.dataPath,t)}):this.context},renderFile(e,t){return this.render(this.getFileContext(e,t))},getDownloadUrl(e,t){return e.url?e.url:!e.upload||e.upload.success?this.getSchemaValue("downloadUrl",{type:"String",default:null,context:this.getFileContext(e,t)}):null},getThumbnailUrl(e,t){return!e.upload||e.upload.success?this.getSchemaValue("thumbnailUrl",{type:"String",default:null,context:this.getFileContext(e,t)})||(e.type.startsWith("image/")?e.url:null):null},deleteFile(e,t){const{name:o}=e;e&&window.confirm(`Do you really want to ${this.verbs.remove} ${o}?`)&&(this.multiple?this.value.splice(t,1):this.value=null,e.upload&&this.upload.remove(e.upload),this.onChange(),this.notify({type:"info",title:"Successfully Removed",text:`${o} was ${this.verbs.deleted}.`}))},getFileIndex(e){return this.multiple&&this.value?this.value.findIndex(t=>t.id===e.id):-1},addFile(e){this.multiple?this.value?this.value.push(e):this.value=[e]:this.value=e},replaceFile(e,t){if(this.multiple){const o=this.getFileIndex(e);o>=0&&(t?this.value[o]=t:this.value.splice(o,1))}else this.value=t},removeFile(e){this.replaceFile(e,null)},onInputFile(e,t){if(e&&!t){const{id:o,name:s,size:i}=e;this.addFile({id:o,name:s,size:i,upload:e})}if(e&&t){const{success:o,error:s}=e;if(o){this.onChange();const i=e.response[0];i?(i.upload=e,this.replaceFile(e,i)):this.removeFile(e)}else if(s){this.removeFile(e);const i={abort:"Upload aborted",denied:"Upload denied",extension:`Unsupported file-type: ${e.name}`,network:"Network error encountered during upload",server:"Server error occurred during upload",size:`File is too large: ${wn(e.size)}`,timeout:"Timeout occurred during upload"}[s]||`Unknown File Upload Error: '${s}'`;this.notify({type:"error",error:s,title:"File Upload Error",text:i})}}},onInputFilter(e){const t=e?.xhr;this.api.cors?.credentials&&t&&!t.withCredentials&&(t.withCredentials=!0)},async onClickDownload(e,t){try{const s=await(await fetch(this.downloadUrls[t])).blob();this.download({filename:e.name,url:URL.createObjectURL(s)})}catch(o){console.error(o)}},onClickUpload(e){this.upload.$el.querySelector("input").dispatchEvent(new e.constructor(e.type,e))}},processValue({schema:e,value:t}){const o=Sn(t).map(({upload:s,...i})=>!s||s.success?i:null).filter(s=>s);return e.multiple?o:o[0]||null}});function Sn(e){return e?h.asArray(e):[]}const ch=Object.freeze(Object.defineProperty({__proto__:null,DitoDitoTypeComponent:Ql,DitoTypeButton:Dl,DitoTypeCheckbox:Pl,DitoTypeCheckboxes:Fl,DitoTypeCode:zl,DitoTypeColor:Yl,DitoTypeComputed:xl,DitoTypeDate:nd,DitoTypeLabel:Sd,DitoTypeList:Dd,DitoTypeMarkup:Id,DitoTypeMultiselect:Ad,DitoTypeNumber:Hd,DitoTypeObject:Xd,DitoTypePanel:Zd,DitoTypeProgress:ec,DitoTypeRadio:ac,DitoTypeSection:lc,DitoTypeSelect:yc,DitoTypeSlider:Bc,DitoTypeSpacer:Vc,DitoTypeSwitch:Nc,DitoTypeText:Fc,DitoTypeTextarea:jc,DitoTypeTreeList:Wc,DitoTypeUpload:y(dh,[["render",lh]])},Symbol.toStringTag,{value:"Module"})),hh={mounted(e,t){ph(e,t.value,t.arg)},unmounted(e,t){uh(e,t.value,t.arg)}};function ph(e,t,o){$e.getObserver(o).observe(e,t)}function uh(e,t,o){$e.getObserver(o).unobserve(e,t)}const mh=typeof ResizeObserver<"u",ve={};class $e{constructor(t,o){this.key=t,this.options=o,this.observer=mh?new ResizeObserver(s=>this.handle(s)):null,this.handlersByNode=new WeakMap,this.nodeCount=0}observe(t,o){let s=this.handlersByNode.get(t);s||(s=new Set,this.handlersByNode.set(t,s),this.observer?.observe(t,this.options),this.nodeCount++),s.add(o)}unobserve(t,o){const s=this.handlersByNode.get(t);s?.delete(o)&&s.size===0&&(this.handlersByNode.delete(t),this.observer?.unobserve(t),--this.nodeCount===0&&delete ve[this.key])}handle(t){for(const o of t){const s=this.handlersByNode.get(o.target);if(s){const i={target:o.target,contentRect:o.contentRect,borderBoxSize:h.asArray(o.borderBoxSize),contentBoxSize:h.asArray(o.contentBoxSize),devicePixelContentBoxSize:h.asArray(o.devicePixelContentBoxSize)};for(const a of s)a(i)}}}static getObserver({box:t="content-box"}={}){const o={box:t},s=JSON.stringify(o);return ve[s]||=new $e(s,o),ve[s]}}const fh=["create","created","save","saved","apply","applied","submit","submitted","delete","deleted","remove","removed","clear","cleared","edit","edited","close","closed","cancel","cancelled","drag","dragged","login","logged in"].reduce((e,t)=>(e[t]=t,e),{});class gh{constructor(t,{dito:o={},api:s,views:i={},...a}={}){this.el=t,this.api=s=h.assignDeeply({base:"/"},o.api,s),this.options=a,s.locale||="en-US",s.formats=h.assignDeeply({},h.defaultFormats,s.formats),s.request||=d=>yh(s,d),s.getApiUrl||=d=>Ch(s,d),s.isApiUrl||=d=>kh(s,d),s.normalizePath||=s.normalizePaths?h.hyphenate:d=>d,s.denormalizePath||=s.normalizePaths?h.camelize:d=>d,s.defaults||={};const r=F(s.users,{type:"collection"})||{};r.login=F(r.login||"login",{method:"post",parent:r}),r.logout=F(r.logout||"logout",{method:"post",parent:r}),r.session=F(r.session||"session",{method:"get",parent:r}),s.users=r,s.resources={any(d){const c=this[d?.type]||this.default;return d&&c.call(this,d)},default(d){const c=this.any(d.parent);return c?`${c}/${d.path}`:d.path},collection(d){return this.default(d)},member(d){return`${this.default(d)}/${d.id}`},upload(d){return`${this.collection(d.parent)}/upload/${d.path}`},...s.resources},s.headers={"Content-Type":"application/json",...s.headers},h.isString(t)&&(t=document.querySelector(t));const l=this.app=n.createApp({components:{DitoRoot:Xe,VueNotifications:et,...yl,...ch},provide:{api:s,$verbs:()=>fh,$views:()=>{},$isPopulated:()=>!0,$parentComponent:()=>null,$schemaComponent:()=>null,$schemaParentComponent:()=>null,$routeComponent:()=>null,$dataComponent:()=>null,$sourceComponent:()=>null,$resourceComponent:()=>null,$dialogComponent:()=>null,$panelComponent:()=>null,$tabComponent:()=>null},render:()=>n.h(Xe,{ref:"root",class:o.settings.rootClass,unresolvedViews:i,options:a})});l.config.errorHandler=console.error,l.use(et,{componentName:"VueNotifications",name:"notify"}),l.directive("resize",hh),l.use(W.createRouter({routes:[{name:"catch-all",path:"/:_(.*)",components:{}}],history:W.createWebHistory(o.base),linkActiveClass:"",linkExactActiveClass:""})),t.classList.add("dito-app"),l.mount(t)}register(t,o){return B.register(t,o)}}class bh extends Error{constructor(t){super(`Request failed with status code: ${t.status} (${t.statusText})`),this.response=t}}async function yh(e,{url:t,method:o="get",query:s=null,headers:i=null,data:a=null,signal:r=null}){const l=e.isApiUrl(t),d=await fetch(e.getApiUrl({url:t,query:s}),{method:o.toUpperCase(),...a&&{body:JSON.stringify(a)},headers:{...l&&e.headers,...i},credentials:l&&e.cors?.credentials?"include":"same-origin",signal:r});if(d.headers.get("Content-Type")?.includes("application/json")&&(d.data=await d.json()),!d.ok)throw new bh(d);return d}function kh(e,t){return!h.isAbsoluteUrl(t)||t.startsWith(e.url)}function Ch(e,{url:t,query:o}){!t.startsWith(e.url)&&!h.isAbsoluteUrl(t)&&(t=$h(e.url,t));const s=mn(o);return s?`${t}${t.includes("?")?"&":"?"}${s}`:t}function $h(e,t){return`${e.replace(/\/+$/,"")}/${t.replace(/^\/+/,"")}`}return gh}));
7
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"dito-admin.umd.js","sources":["../src/utils/agent.js","../src/appState.js","../src/utils/data.js","../src/DitoContext.js","../src/mixins/EmitterMixin.js","../src/mixins/ValueMixin.js","../src/mixins/ContextMixin.js","../src/validators/_creditcard.js","../src/validators/_decimals.js","../src/validators/_domain.js","../src/validators/_email.js","../src/validators/_hostname.js","../src/validators/_integer.js","../src/validators/_max.js","../src/validators/_min.js","../src/validators/_password.js","../src/validators/_range.js","../src/validators/_required.js","../src/validators/_url.js","../src/mixins/ValidationMixin.js","../src/utils/accessor.js","../src/mixins/TypeMixin.js","../src/utils/uid.js","../src/utils/SchemaGraph.js","../src/utils/type.js","../src/utils/schema.js","../src/utils/resource.js","../src/mixins/DitoMixin.js","../src/utils/options.js","../src/DitoComponent.js","../../ui/src/utils/vue.js","../../ui/src/components/DitoButton.vue","../../ui/src/utils/date.js","../../ui/src/components/DitoCalendar.vue","../../ui/src/utils/event.js","../../ui/src/utils/trigger.js","../../ui/src/components/DitoTrigger.vue","../../ui/src/components/DitoInput.vue","../../ui/src/components/DitoIcon.vue","../../ui/src/utils/selection.js","../../ui/src/components/DitoDatePicker.vue","../../ui/src/components/DitoTimePicker.vue","../../ui/src/components/DitoDateTimePicker.vue","../../ui/src/components/DitoPagination.vue","../../ui/src/components/DitoSwitch.vue","../../ui/src/transitions/TransitionHeight.vue","../src/mixins/DomMixin.js","../src/DitoUser.js","../src/mixins/SchemaParentMixin.js","../src/mixins/ValidatorMixin.js","../src/mixins/RouteMixin.js","../src/components/DitoView.vue","../../../node_modules/@vueuse/shared/dist/index.js","../../../node_modules/@vueuse/core/dist/index.js","../../../node_modules/@vueuse/integrations/dist/useFocusTrap-lXZ_YG-8.js","../../../node_modules/@vueuse/integrations/dist/useFocusTrap/component.js","../src/components/DitoDialog.vue","../src/components/DitoRoot.vue","../src/components/DitoMenu.vue","../src/components/DitoTrail.vue","../src/components/DitoHeader.vue","../src/components/DitoNavigation.vue","../src/components/DitoNotifications.vue","../src/components/DitoSidebar.vue","../src/mixins/PulldownMixin.js","../src/components/DitoAccount.vue","../src/components/DitoSpinner.vue","../src/components/DitoAffix.vue","../src/components/DitoAffixes.vue","../src/components/DitoLabel.vue","../src/mixins/ItemMixin.js","../src/components/DitoSchema.vue","../src/components/DitoSchemaInlined.vue","../src/components/DitoPane.vue","../src/utils/math.js","../src/components/DitoContainer.vue","../src/components/DitoTabs.vue","../src/components/DitoPanel.vue","../src/components/DitoPanels.vue","../src/components/DitoButtons.vue","../src/components/DitoEditButtons.vue","../src/components/DitoCreateButton.vue","../src/components/DitoClipboard.vue","../src/mixins/LoadingMixin.js","../src/mixins/ResourceMixin.js","../src/utils/path.js","../src/components/DitoForm.vue","../src/components/DitoFormInner.vue","../src/components/DitoFormNested.vue","../src/components/DitoErrors.vue","../src/components/DitoScopes.vue","../src/components/DitoPagination.vue","../src/mixins/SortableMixin.js","../src/components/DitoTreeItem.vue","../src/components/DitoTableHead.vue","../src/components/DitoTableCell.vue","../src/components/DitoUploadFile.vue","../../../node_modules/@vueuse/integrations/dist/useSortable-Cc5LKbDD.js","../../../node_modules/@vueuse/integrations/dist/useSortable/component.js","../src/components/DitoDraggable.vue","../src/components/DitoVNode.vue","../src/DitoTypeComponent.js","../src/types/DitoTypeButton.vue","../src/types/DitoTypeCheckbox.vue","../src/mixins/DataMixin.js","../src/mixins/OptionsMixin.js","../src/types/DitoTypeCheckboxes.vue","../src/types/DitoTypeCode.vue","../src/types/DitoTypeColor.vue","../src/types/DitoTypeComponent.vue","../src/types/DitoTypeComputed.vue","../src/types/DitoTypeDate.vue","../src/utils/route.js","../src/mixins/SourceMixin.js","../src/utils/filter.js","../src/types/DitoTypeList.vue","../src/types/DitoTypeLabel.vue","../../../node_modules/prosemirror-model/dist/index.js","../src/types/DitoTypeMarkup.vue","../src/types/DitoTypeMultiselect.vue","../src/mixins/NumberMixin.js","../src/types/DitoTypeNumber.vue","../src/types/DitoTypeObject.vue","../src/types/DitoTypePanel.vue","../src/types/DitoTypeProgress.vue","../src/types/DitoTypeRadio.vue","../src/types/DitoTypeSection.vue","../src/types/DitoTypeSelect.vue","../src/types/DitoTypeSlider.vue","../src/types/DitoTypeSpacer.vue","../src/types/DitoTypeSwitch.vue","../src/mixins/TextMixin.js","../src/types/DitoTypeText.vue","../src/types/DitoTypeTextarea.vue","../src/types/DitoTypeTreeList.vue","../src/utils/units.js","../src/types/DitoTypeUpload.vue","../src/directives/resize.js","../src/verbs.js","../src/DitoAdmin.js"],"sourcesContent":["// This user-agent parser was lifted from Paper.js:\n// https://github.com/paperjs/paper.js/blob/cc15696750035ab00e00c64c7c95daa2c85efe01/src/core/PaperScope.js#L75-L107\n\nexport function parseUserAgent(userAgent = '') {\n  const agent = {}\n  // Use replace() to get all matches, and deal with Chrome/Webkit overlap:\n  const ua = userAgent.toLowerCase()\n  const [os] =\n    /(iphone|ipad|linux; android|darwin|win|mac|linux|freebsd|sunos)/.exec(\n      ua\n    ) || []\n  const platform = (\n    {\n      'darwin': 'mac',\n      'iphone': 'ios',\n      'ipad': 'ios',\n      'linux; android': 'android'\n    }[os] ||\n    os\n  )\n  if (platform) {\n    agent.platform = platform\n    agent[platform] = true\n  }\n  ua.replace(\n    /(opera|chrome|safari|webkit|firefox|msie|trident)\\/?\\s*([.\\d]+)(?:.*version\\/([.\\d]+))?(?:.*rv:v?([.\\d]+))?/g,\n    (match, browser, v1, v2, rv) => {\n      // Do not set additional browsers once chrome is detected.\n      if (!agent.chrome) {\n        const version = rv || v2 || v1\n        if (!agent.version || browser !== 'safari') {\n          // Use the version we get for webkit for Safari, which is actually\n          // The Safari version, e.g. 16.0\n          agent.version = version\n          agent.versionNumber = parseFloat(version)\n        }\n        agent.browser = browser\n        agent[browser] = true\n      }\n    }\n  )\n  if (agent.chrome) {\n    // Can't have it both ways, Chrome.\n    delete agent.webkit\n  }\n  return agent\n}\n","import { reactive } from 'vue'\nimport { parseUserAgent } from './utils/agent'\n\nexport default reactive({\n  title: '',\n  routeComponents: [],\n  user: null,\n  agent: parseUserAgent(navigator.userAgent || ''),\n  loadCache: {}, // See TypeMixin.load()\n  activeLabel: null,\n  clipboardData: null\n})\n","import {\n  isInteger,\n  parseDataPath,\n  getValueAtDataPath,\n  normalizeDataPath\n} from '@ditojs/utils'\n\nexport function appendDataPath(dataPath, token) {\n  return dataPath\n    ? `${dataPath}/${token}`\n    : token\n}\n\nexport function parseParentDataPath(dataPath) {\n  const path = parseDataPath(dataPath)\n  path?.pop()\n  return path\n}\n\nexport function getParentDataPath(dataPath) {\n  return normalizeDataPath(parseParentDataPath(dataPath))\n}\n\nexport function parseItemDataPath(dataPath, nested = false) {\n  return nested ? parseParentDataPath(dataPath) : parseDataPath(dataPath)\n}\n\nexport function getItemDataPath(dataPath, nested = false) {\n  return normalizeDataPath(parseItemDataPath(dataPath, nested))\n}\n\nexport function parseParentItemDataPath(dataPath, nested = false) {\n  const path = parseItemDataPath(dataPath, nested)\n  if (path) {\n    // Remove the parent token. If it's a number, then we're dealing with an\n    // array and need to remove more tokens until we meet the actual parent:\n    let token\n    do {\n      token = path.pop()\n    } while (token != null && isInteger(+token))\n    // If the removed token is valid, we can get the parent data:\n    if (token != null) {\n      return path\n    }\n  }\n  return null\n}\n\nexport function getParentItemDataPath(dataPath, nested = false) {\n  return normalizeDataPath(parseParentItemDataPath(dataPath, nested))\n}\n\nexport function getItem(rootItem, dataPath, nested = false) {\n  const path = parseItemDataPath(dataPath, nested)\n  return path ? getValueAtDataPath(rootItem, path) : null\n}\n\nexport function getParentItem(rootItem, dataPath, nested = false) {\n  const path = parseParentItemDataPath(dataPath, nested)\n  return path ? getValueAtDataPath(rootItem, path) : null\n}\n\nexport function getLastDataPathToken(dataPath) {\n  const path = parseDataPath(dataPath)\n  return path[path.length - 1]\n}\n\nexport function getLastDataPathName(dataPath) {\n  const token = getLastDataPathToken(dataPath)\n  return token == null || isInteger(+token) ? null : token\n}\n\nexport function getLastDataPathIndex(dataPath) {\n  const token = getLastDataPathToken(dataPath)\n  const index = token == null ? null : +token\n  return isInteger(index) ? index : null\n}\n\nlet temporaryId = 0\nexport function setTemporaryId(data, idKey = 'id') {\n  // Temporary ids are marked with a '@' at the beginning.\n  data[idKey] = `@${++temporaryId}`\n}\n\nexport function isTemporaryId(id) {\n  return /^@/.test(id)\n}\n\nexport function isReference(data, idKey = 'id') {\n  // Returns true if value is an object that holds nothing more than an id.\n  return data?.[idKey] != null && Object.keys(data).length === 1\n}\n","import { toRaw } from 'vue'\nimport { getValueAtDataPath, isFunction } from '@ditojs/utils'\nimport {\n  getItemDataPath,\n  getParentItemDataPath,\n  getParentItem,\n  getItem,\n  getLastDataPathName,\n  getLastDataPathIndex\n} from './utils/data.js'\n\nconst { hasOwnProperty } = Object.prototype\n\n// See also `ContextMixin`: `DitoContext` instances are a thin wrapper around\n// raw `context` objects, which themselves actually inherit from the linked\n// `component` instance, so that they only need to provide the values that\n// should be different than in the underlying component. In order to not expose\n// all fields from the component, the wrapper is introduced.\n\n// Use WeakMap for the raw `context` objects, so we don't have to pollute the\n// actual `DitoContext` instance with it.\nconst contexts = new WeakMap()\n\nfunction toObject(context) {\n  const rawStart = toRaw(context)\n  let raw = rawStart\n  let object = null\n  // In case `DitoContext.extend()` was used, we need to find the actual context\n  // object from the object's the inheritance chain:\n  do {\n    object = contexts.get(raw)\n    if (object) break\n    raw = Object.getPrototypeOf(raw)\n  } while (raw)\n  if (object && raw !== rawStart) {\n    // Assign the passed context with the original object as well, so we don't\n    // have to search for it again:\n    contexts.set(raw, object)\n  }\n  return object\n}\n\nfunction get(context, key, defaultValue) {\n  const object = toObject(context)\n  const value = key in object ? object[key] : undefined\n  // If `object` explicitly sets the key to `undefined`, return it.\n  return value !== undefined || hasOwnProperty.call(object, key)\n    ? value\n    : isFunction(defaultValue)\n      ? defaultValue()\n      : defaultValue\n}\n\nfunction set(context, key, value) {\n  toObject(context)[key] = value\n}\n\nexport default class DitoContext {\n  constructor(component, context) {\n    // Use the provided params object / function, or create a new one:\n    context = context\n      ? isFunction(context)\n        ? context()\n        : { ...context }\n      : {}\n    // If not explicitly set (to false), default to true so we don't fall back\n    // to `component` for its value.\n    context.nested ??= true\n    context.component = component\n    // Have `object` inherit from the `component` instance, so it can override\n    // its values and still retrieve from it, and associate it with `this`\n    // through `contexts` map:\n    const object = Object.setPrototypeOf(context, component)\n    // No need for `toRaw(this)` here as it's always raw inside the constructor.\n    contexts.set(this, object)\n  }\n\n  static get(component, context) {\n    return context instanceof DitoContext\n      ? context\n      : new DitoContext(component, context)\n  }\n\n  extend(object) {\n    // Create a copy of this context that inherits from the real one, but\n    // overrides some properties with the ones from the passed `object`.\n    return Object.setPrototypeOf(object, this)\n  }\n\n  // `nested` is `true` when the data-path points a value inside an item, and\n  // `false` when it points to the item itself.\n  get nested() {\n    return get(this, 'nested', true)\n  }\n\n  get schema() {\n    return get(this, 'schema', null)\n  }\n\n  get value() {\n    return get(\n      this,\n      'value',\n      () =>\n        // If the value is not defined on the underlying object, it's not a type\n        // component. If it is nested, we can still get the value from the root.\n        this.nested\n          ? getValueAtDataPath(this.rootItem, this.dataPath)\n          : undefined\n    )\n  }\n\n  get dataPath() {\n    return get(this, 'dataPath', '')\n  }\n\n  get name() {\n    return get(this, 'name', () => getLastDataPathName(this.dataPath))\n  }\n\n  get index() {\n    return get(this, 'index', () => getLastDataPathIndex(this.dataPath))\n  }\n\n  get itemDataPath() {\n    return getItemDataPath(this.dataPath, this.nested)\n  }\n\n  get parentItemDataPath() {\n    return getParentItemDataPath(this.dataPath, this.nested)\n  }\n\n  get itemIndex() {\n    return getLastDataPathIndex(this.itemDataPath)\n  }\n\n  get parentItemIndex() {\n    return getLastDataPathIndex(this.parentItemDataPath)\n  }\n\n  // NOTE: While internally, we speak of `data`, in the API surface the\n  // term `item` is used for the data that relates to editing objects:\n  get item() {\n    return get(\n      this,\n      'data',\n      // If `data` isn't provided, we can determine it from rootData & dataPath:\n      () => getItem(this.rootItem, this.dataPath, this.nested) || null\n    )\n  }\n\n  // NOTE: `parentItem` isn't the closest data parent to `item`, it's the\n  // closest parent that isn't an array, e.g. for relations or nested JSON data.\n  // This is why the term `item` was chosen over `data`, e.g. VS the use of\n  // `parentData` in server-sided validation, which is the closest parent. If\n  // needed, we could expose this data here too, as we can do all sorts of data\n  // processing with `rootData` and `dataPath`.\n  get parentItem() {\n    const item = (\n      getParentItem(this.rootItem, this.dataPath, this.nested) || null\n    )\n    return item !== this.item ? item : null\n  }\n\n  get rootItem() {\n    return get(this, 'rootData', null)\n  }\n\n  get processedItem() {\n    return get(this, 'processedData', null)\n  }\n\n  get processedRootItem() {\n    return get(this, 'processedRootData', null)\n  }\n\n  get clipboardItem() {\n    return get(this, 'clipboardData', null)\n  }\n\n  get user() {\n    return get(this, 'user', null)\n  }\n\n  get api() {\n    return get(this, 'api', null)\n  }\n\n  get views() {\n    return get(this, 'views', null)\n  }\n\n  get flattenedViews() {\n    return get(this, 'flattenedViews', null)\n  }\n\n  get itemLabel() {\n    return get(this, 'itemLabel', null)\n  }\n\n  get formLabel() {\n    return get(this, 'formLabel', null)\n  }\n\n  // NOTE: Like 'options', the associated component doesn't always exist, e.g.\n  // in nested forms during `processData()`. But `schema` is guaranteed to\n  // always be available.\n  get component() {\n    return get(this, 'component', null)\n  }\n\n  // TODO: Add `componentSchema` getter for the schema of the current component,\n  // even when the component isn't actually instantiated. Consider adding\n  // `sourceSchema` as well?\n\n  // TODO: Fix unclear naming: Which schema is this, that of the component or of\n  // its parent? Isn't exposing `formComponent` and `viewComponent` enough, once\n  // we offer access to their components there through `getComponent()` & co. on\n  // `DitoMixin` perhaps?  Also, there could be a `tabComponent` getter for\n  // schemas in tabs?\n  get schemaComponent() {\n    return get(this, 'schemaComponent', null)\n  }\n\n  get formComponent() {\n    return get(this, 'formComponent', null)\n  }\n\n  get viewComponent() {\n    return get(this, 'viewComponent', null)\n  }\n\n  get dialogComponent() {\n    return get(this, 'dialogComponent', null)\n  }\n\n  get panelComponent() {\n    return get(this, 'panelComponent', null)\n  }\n\n  get resourceComponent() {\n    return get(this, 'resourceComponent', null)\n  }\n\n  get sourceComponent() {\n    return get(this, 'sourceComponent', null)\n  }\n\n  // When used in OptionsMixin for `schema.options.value()`,\n  // `schema.options.label()` and  `schema.search.filter()` callbacks:\n  get option() {\n    return get(this, 'option', undefined)\n  }\n\n  get options() {\n    return get(this, 'options', undefined)\n  }\n\n  get open() {\n    return get(this, 'open', undefined)\n  }\n\n  // For search term in selects:\n  get searchTerm() {\n    return get(this, 'searchTerm', undefined)\n  }\n\n  // The error field is only populated in the context of buttons that send\n  // requests, see `ResourceMixin.emitButtonEvent()`:\n  get error() {\n    return get(this, 'error', undefined)\n  }\n\n  get wasNotified() {\n    return get(this, 'wasNotified', false)\n  }\n\n  get isRunning() {\n    return get(this, 'isRunning', false)\n  }\n\n  set isRunning(value) {\n    set(this, 'isRunning', value)\n  }\n\n  get query() {\n    return this.component.$route.query\n  }\n\n  // Helper Methods\n\n  get request() {\n    return options => this.component.request(options)\n  }\n\n  get format() {\n    return (value, options) => this.component.format(value, options)\n  }\n\n  get navigate() {\n    return location => this.component.navigate(location)\n  }\n\n  get download() {\n    return options => this.component.download(options)\n  }\n\n  get getResourceUrl() {\n    return resource => this.component.getResourceUrl(resource)\n  }\n\n  get notify() {\n    return options => {\n      this.component.notify(options)\n      set(this, 'wasNotified', true)\n    }\n  }\n}\n","import { isArray, isPlainObject } from '@ditojs/utils'\n\n// @vue/component\nexport default {\n  data() {\n    return {\n      listeners: null\n    }\n  },\n\n  methods: {\n    // Async on() and $off() methods that keep track of the events added /\n    // removed, and provide a hasListeners() method that checks if the component\n    // has listeners for a given event.\n\n    // Also adds proper handling of async events, including a async emit() that\n    // deals with proper event queueing.\n    on(event, callback) {\n      if (isArray(event)) {\n        for (const ev of event) {\n          this.on(ev, callback)\n        }\n      } else if (isPlainObject(event)) {\n        for (const key in event) {\n          this.on(key, event[key])\n        }\n      } else {\n        const listeners = (this.listeners ||= Object.create(null))\n        const { callbacks } = (listeners[event] ||= {\n          callbacks: [],\n          queue: []\n        })\n        callbacks.push(callback)\n      }\n      return this\n    },\n\n    once(event, callback) {\n      const on = (...args) => {\n        this.off(event, on)\n        return callback.apply(this, args)\n      }\n      on.callback = callback // Needed for `off()`, see below.\n      return this.on(event, on)\n    },\n\n    off(event, callback) {\n      if (!arguments.length) {\n        // Remove all events\n        delete this.listeners\n      } else if (isArray(event)) {\n        for (const ev of event) {\n          this.off(ev, callback)\n        }\n      } else if (isPlainObject(event)) {\n        for (const key in event) {\n          this.off(key, event[key])\n        }\n      } else {\n        // Remove specific event\n        const entry = this.listeners?.[event]\n        if (entry) {\n          if (!callback) {\n            // Remove all handlers for this event\n            delete this.listeners[event]\n          } else {\n            // Remove a specific handler: find the index in callbacks\n            const { callbacks } = entry\n            const index = callbacks.findIndex(\n              // Match `cb.callback` also, as used by `once()`, see  above:\n              cb => cb === callback || cb.callback === callback\n            )\n            if (index !== -1) {\n              callbacks.splice(index, 1)\n            }\n          }\n        }\n      }\n      return this\n    },\n\n    emit(event, ...args) {\n      // Only queue event if there actually are listeners for it.\n      const entry = this.listeners?.[event]\n      if (entry) {\n        const { queue, callbacks } = entry\n        return new Promise(resolve => {\n          const next = async () => {\n            // Emit the next event in the queue with its params.\n            // Note that it only gets removed once `next()` is called.\n            const entry = queue.shift()\n            if (entry) {\n              let result\n              const errors = []\n              for (const callback of callbacks) {\n                try {\n                  const res = await callback.apply(this, entry.args)\n                  if (res !== undefined) {\n                    result = res\n                  }\n                } catch (error) {\n                  errors.push(error)\n                }\n              }\n              if (errors.length > 0) {\n                const error = new AggregateError(\n                  errors,\n                  `Errors during event handler for '${event}'`\n                )\n                entry.resolve(Promise.reject(error))\n              } else {\n                // Resolve the promise that was added to the queue for the event\n                // that was just completed by the wrapper that called `next()`\n                entry.resolve(result)\n              }\n              next()\n            }\n          }\n          queue.push({ args, resolve })\n          // For new queues (= only one entry) emit the first event immediately,\n          // to get the queue running.\n          if (queue.length === 1) {\n            next()\n          }\n        })\n      }\n      // Make sure it's thenable even if there are no listeners.\n      return Promise.resolve()\n    },\n\n    // Checks if the component has listeners for a given event type:\n    hasListeners(event) {\n      if (isArray(event)) {\n        for (const ev of event) {\n          if (!this.hasListeners(ev)) {\n            return false\n          }\n        }\n        return event.length > 0\n      } else {\n        return !!this.listeners?.[event]\n      }\n    },\n\n    delegate(event, target) {\n      if (target) {\n        if (isArray(event)) {\n          for (const ev of event) {\n            this.delegate(ev, target)\n          }\n        } else {\n          this.on(event, (...args) => target.emit(event, ...args))\n        }\n      }\n      return this\n    }\n  }\n}\n","import DitoContext from '../DitoContext.js'\nimport { computeValue } from '../utils/schema.js'\n\nexport default {\n  computed: {\n    value: {\n      get() {\n        const value = computeValue(\n          this.schema,\n          this.data,\n          this.name,\n          this.dataPath,\n          { component: this }\n        )\n        const { format } = this.schema\n        return format\n          ? format(new DitoContext(this, { value }))\n          : value\n      },\n\n      set(value) {\n        const { parse } = this.schema\n        if (parse) {\n          value = parse(new DitoContext(this, { value }))\n        }\n        this.parsedValue = value\n        this.data[this.name] = value\n      }\n    }\n  }\n}\n","import DitoContext from '../DitoContext.js'\nimport { getItem, getParentItem } from '../utils/data.js'\n\n// @vue/component\nexport default {\n  computed: {\n    context() {\n      return new DitoContext(this, { nested: this.nested })\n    },\n\n    // The following computed properties are similar to `DitoContext`\n    // properties, so that we can access these on `this` as well:\n    // NOTE: While internally, we speak of `data`, in the API surface the\n    // term `item` is used for the data that relates to editing objects.\n    // NOTE: This should always return the same as:\n    // return getItem(this.rootData, this.dataPath, false)\n    parentData() {\n      const data = getParentItem(this.rootData, this.dataPath, this.nested)\n      return data !== this.data ? data : null\n    },\n\n    // @overridable\n    processedData() {\n      return getProcessedParentData(this, this.dataPath, this.nested)\n    },\n\n    processedRootData() {\n      return getProcessedParentData(this, '', false)\n    },\n\n    item() {\n      return this.data\n    },\n\n    parentItem() {\n      return this.parentData\n    },\n\n    rootItem() {\n      return this.rootData\n    },\n\n    processedItem() {\n      return this.processedData\n    },\n\n    processedRootItem() {\n      return this.processedRootData\n    }\n  }\n}\n\nfunction getProcessedParentData(component, dataPath, nested = false) {\n  // We can only get the processed data through the schemaComponent, but\n  // that's not necessarily the item represented by this component.\n  // Solution: Find the relative path and the processed sub-item from there:\n  let { schemaComponent } = component\n  // Find the schema component that contains the desired data-path:\n  while (schemaComponent.dataPath.length > dataPath.length) {\n    schemaComponent = schemaComponent.parentSchemaComponent\n  }\n  return getItem(\n    schemaComponent.processedData,\n    // Get the dataPath relative to the schemaComponent's data:\n    dataPath.slice(schemaComponent.dataPath.length),\n    nested\n  )\n}\n","import { isCreditCard } from '@ditojs/utils'\n\nexport const creditcard = {\n  validate: value => isCreditCard(value),\n  message: 'is invalid'\n}\n","export const decimals = {\n  validate: (value, decimals) => {\n    const match = decimals === '*' ? '+' : `{1,${decimals}}`\n    return new RegExp(`^[-+]?\\\\d*(\\\\.\\\\d${match})?$`).test(value)\n  },\n\n  message: (value, decimals) =>\n    `must be numeric and may contain ${\n      !decimals || decimals === '*' ? '' : decimals\n    } decimal points`\n}\n","import { isDomain } from '@ditojs/utils'\n\nexport const domain = {\n  validate: value => isDomain(value),\n  message: 'is not a domain'\n}\n","import { isEmail } from '@ditojs/utils'\n\nexport const email = {\n  validate: value => isEmail(value),\n  message: 'must be a valid email'\n}\n","import { isHostname } from '@ditojs/utils'\n\nexport const hostname = {\n  validate: value => isHostname(value),\n  message: 'is not a host name'\n}\n","import { isInteger } from '@ditojs/utils'\n\nexport const integer = {\n  validate: value => isInteger(value),\n  message: 'must be whole number'\n}\n","export const max = {\n  validate: (value, max) => value <= max,\n  message(value, max) {\n    return `must be ${max} or less`\n  }\n}\n","export const min = {\n  validate: (value, min) => value >= min,\n  message(value, min) {\n    return `must be ${min} or more`\n  }\n}\n","export const password = {\n  // Allow any value. For now this is only used as a marker, to allow the\n  // required validation to handle unchanged passwords separately.\n  validate: () => true\n}\n","export const range = {\n  validate: (value, [min, max]) => value >= min && value <= max,\n  message(value, [min, max]) {\n    return `must be between ${min} and ${max}`\n  }\n}\n","export const required = {\n  validate: (value, settings, { password }) => (\n    (value != null && value !== '') ||\n    // Password fields use `undefined` as opposed to `null` when they're set\n    // but unchanged, allow this to pass through:\n    (password && value === undefined)\n  ),\n  message: 'is required'\n}\n","import { isUrl } from '@ditojs/utils'\n\nexport const url = {\n  validate: value => isUrl(value),\n  message: 'is not a valid URL'\n}\n","import { isFunction } from '@ditojs/utils'\nimport * as validators from '../validators/index.js'\n\n// @vue/component\nexport default {\n  emits: ['errors'],\n\n  data() {\n    return {\n      isTouched: false,\n      isDirty: false,\n      isValidated: false,\n      isValid: false,\n      errors: null\n    }\n  },\n\n  computed: {\n    hasErrors() {\n      return !!this.errors\n    }\n  },\n\n  methods: {\n    resetValidation() {\n      this.isTouched = false\n      this.isDirty = false\n      this.isValidated = false\n      this.isValid = false\n      this.clearErrors()\n    },\n\n    validate(notify = true) {\n      let isValid = true\n      if (notify) {\n        this.clearErrors()\n      }\n      const { value } = this\n      for (const [rule, setting] of Object.entries(this.validations)) {\n        // eslint-disable-next-line import/namespace\n        const validator = validators[rule]\n        if (\n          validator &&\n          // Only apply 'required' validator to empty values.\n          // Apply all other validators only to non-empty values.\n          (rule === 'required' || value != null && value !== '')\n        ) {\n          const { validate, message } = validator\n          if (!validate(value, setting, this.validations)) {\n            isValid = false\n            if (notify) {\n              const error = isFunction(message)\n                ? message(value, setting, this)\n                : message\n              this.addError(error, true)\n            }\n          }\n        }\n      }\n      if (notify) {\n        this.isValidated = true\n        this.isValid = isValid\n      }\n      return isValid\n    },\n\n    verify() {\n      return this.validate(false)\n    },\n\n    markTouched() {\n      this.isTouched = true\n      // Clear currently displayed errors when focusing input.\n      this.clearErrors()\n    },\n\n    markDirty() {\n      this.isDirty = true\n      this.isValidated = false\n      this.isValid = false\n      // Clear currently displayed errors on new input.\n      this.clearErrors()\n    },\n\n    addError(error, addLabel = false) {\n      this.errors ||= []\n      if (addLabel) {\n        const label = this.label || this.placeholder || this.name\n        error = `The ${label} field ${error}.`\n      }\n      this.errors.push(error)\n      this.$emit('errors', this.errors)\n    },\n\n    showValidationErrors(errors, focus) {\n      // Convert from AJV errors objects to an array of error messages\n      this.errors = []\n      if (errors.length === 0) {\n        return false\n      }\n      for (const { message } of errors) {\n        this.addError(message, true)\n      }\n      if (focus) {\n        this.scrollIntoView()\n      }\n      return true\n    },\n\n    getErrors() {\n      return this.errors ? [...this.errors] : null\n    },\n\n    clearErrors() {\n      this.errors = null\n      this.$emit('errors', this.errors)\n    }\n  }\n}\n","import {\n  isFunction,\n  isString,\n  parseDataPath,\n  normalizeDataPath\n} from '@ditojs/utils'\n\nexport function getSchemaAccessor(\n  keyOrDataPath,\n  { type, default: def, get, set, callback = true } = {}\n) {\n  // `keyOrDataPath` can be a simple property key,\n  // or a data-path into sub-properties, both in array or string format.\n  if (isString(keyOrDataPath) && keyOrDataPath.includes('.')) {\n    keyOrDataPath = parseDataPath(keyOrDataPath)\n  }\n  // Use the normalized data path for the handling overrides\n  const name = normalizeDataPath(keyOrDataPath)\n  return {\n    get() {\n      // Only determine schema value if we have no getter, or the getter\n      // wants to receive the value and process it further:\n      const value =\n        !get || get.length > 0\n          ? // NOTE: Because `schema` objects are retrieved from `meta`, they\n            // don't seem to be reactive. To allow changed in `schema` values,\n            // `set()` stores changed values in the separate `overrides` object.\n            this.overrides && name in this.overrides\n            ? this.overrides[name]\n            : this.getSchemaValue(keyOrDataPath, {\n                type,\n                default: def,\n                callback\n              })\n          : undefined\n      return get ? get.call(this, value) : value\n    },\n\n    set(value) {\n      if (set) {\n        set.call(this, value)\n      } else {\n        this.overrides ||= {}\n        this.overrides[name] = value\n      }\n    }\n  }\n}\n\nexport function getStoreAccessor(name, { default: def, get, set } = {}) {\n  return {\n    get() {\n      let value = this.getStore(name)\n      if (value === undefined && def !== undefined) {\n        // Support `default()` functions:\n        value = isFunction(def) ? def.call(this) : def\n        // Trigger setter by setting value and accessor to default:\n        this[name] = value\n        // Now access store again, for reactivity tracking\n        this.getStore(name)\n      }\n      // Allow the provided getter to further change or process the value\n      // retrieved from the store:\n      return get ? get.call(this, value) : value\n    },\n\n    set(value) {\n      // Allow the provided setter to return a new value to set, or do the\n      // setting itself, and then return `undefined`:\n      if (!set || (value = set.call(this, value)) !== undefined) {\n        this.setStore(name, value)\n      }\n    }\n  }\n}\n","import ValueMixin from './ValueMixin.js'\nimport ContextMixin from './ContextMixin.js'\nimport ValidationMixin from './ValidationMixin.js'\nimport { getSchemaAccessor } from '../utils/accessor.js'\nimport { asArray, camelize } from '@ditojs/utils'\n\n// @vue/component\nexport default {\n  mixins: [ValueMixin, ContextMixin, ValidationMixin],\n  emits: ['update:component'],\n\n  props: {\n    schema: { type: Object, required: true },\n    // NOTE: While `dataPath` points to the actual `value`, `data` represents\n    // the `item` in which the `value` is contained, under the key `name`.\n    dataPath: { type: String, required: true },\n    data: { type: [Object, Array], required: true },\n    meta: { type: Object, required: true },\n    store: { type: Object, required: true },\n    width: { type: [Number, String], default: null },\n    label: { type: String, default: null },\n    single: { type: Boolean, default: false },\n    nested: { type: Boolean, default: true },\n    accumulatedBasis: { type: Number, default: null }\n  },\n\n  data() {\n    return {\n      parsedValue: undefined,\n      focused: false\n    }\n  },\n\n  computed: {\n    name() {\n      return this.schema.name\n    },\n\n    type() {\n      return this.schema.type\n    },\n\n    labelNode() {\n      const node = this.isMounted ? this.$el.previousElementSibling : null\n      return node?.matches('.dito-label') ? node : null\n    },\n\n    visible: getSchemaAccessor('visible', {\n      type: Boolean,\n      default() {\n        return this.$options.defaultVisible\n      }\n    }),\n\n    // TODO: Rename to `excluded` for consistent naming?\n    exclude: getSchemaAccessor('exclude', {\n      type: Boolean,\n      default: false\n    }),\n\n    required: getSchemaAccessor('required', {\n      type: Boolean,\n      default: false\n    }),\n\n    // TODO: Move these to a sub-class component used for all input components?\n    readonly: getSchemaAccessor('readonly', {\n      type: Boolean,\n      default: false\n    }),\n\n    autofocus: getSchemaAccessor('autofocus', {\n      type: Boolean,\n      default: false\n    }),\n\n    // To be used for selects and inputs only?\n    clearable: getSchemaAccessor('clearable', {\n      type: Boolean,\n      default: false,\n\n      get(clearable) {\n        return clearable && !this.readonly\n      }\n    }),\n\n    disabled: getSchemaAccessor('disabled', {\n      type: Boolean,\n      default: false\n    }),\n\n    maxLength: getSchemaAccessor('maxLength', {\n      type: Number\n    }),\n\n    placeholder: getSchemaAccessor('placeholder', {\n      type: String\n    }),\n\n    autocomplete: getSchemaAccessor('autocomplete', {\n      type: String\n    }),\n\n    info: getSchemaAccessor('info', {\n      type: String,\n      default: null\n    }),\n\n    inlineInfo() {\n      // When a label is present, info is shown in the label component.\n      // Otherwise, we have to show it inline.\n      return !this.label ? this.info : null\n    },\n\n    events() {\n      const events = this.getEvents()\n      // Register callbacks for all provides non-recognized events,\n      // assuming they are native events.\n      // TODO: Move to vue3-style `on[A-Z]` event handlers naming that aren't\n      // namespaced in `schema.events` once the transition is complete.\n      for (const event of Object.keys(this.schema.events || {})) {\n        events[`on${camelize(event, true)}`] ??= () => {\n          this.emitEvent(event)\n        }\n      }\n      return events\n    },\n\n    attributes() {\n      const { nativeField, textField } = this.$options\n\n      const attributes = {\n        ...this.events,\n        disabled: this.disabled\n      }\n\n      if (nativeField) {\n        attributes.name = this.dataPath\n        if (this.label) {\n          attributes.title = this.label\n        }\n        attributes.readonly = this.readonly\n        attributes.autofocus = this.autofocus\n        if (textField) {\n          attributes.maxlength = this.maxLength\n          attributes.placeholder = this.placeholder\n          attributes.autocomplete = this.autocomplete\n        }\n      }\n\n      return attributes\n    },\n\n    validations() {\n      const validations = { ...this.getValidations() }\n      if (this.required) {\n        validations.required = true\n      }\n      // Allow schema to override default rules and add any new ones:\n      for (const [key, value] of Object.entries(this.schema.rules || {})) {\n        if (value === undefined) {\n          delete validations[key]\n        } else {\n          validations[key] = value\n        }\n      }\n      return validations\n    },\n\n    showClearButton() {\n      return this.clearable && this.value != null\n    }\n  },\n\n  created() {\n    this._register(true)\n    this.setupSchemaFields()\n  },\n\n  unmounted() {\n    this._register(false)\n  },\n\n  methods: {\n    _register(add) {\n      // Provide component to container for schema accessor evaluation.\n      this.$emit('update:component', add ? this : null)\n      // Prevent unnested type components from overriding parent data paths\n      if (this.nested) {\n        this.schemaComponent._registerComponent(this, add)\n      }\n    },\n\n    // @overridable\n    getEvents() {\n      const { onFocus, onBlur, onInput, onChange } = this\n      return { onFocus, onBlur, onInput, onChange }\n    },\n\n    // @overridable\n    getValidations() {\n      return null\n    },\n\n    // @overridable\n    async scrollIntoView() {\n      await this.focusSchema()\n      this.getFocusElement()?.scrollIntoView?.({\n        behavior: 'smooth',\n        block: 'center'\n      })\n    },\n\n    // @overridable\n    focusElement() {\n      this.getFocusElement()?.focus?.()\n    },\n\n    // @overridable\n    blurElement() {\n      this.getFocusElement()?.blur?.()\n    },\n\n    getFocusElement() {\n      const element = asArray(this.$refs.element)[0] ?? this\n      return element.$el ?? element\n    },\n\n    async focusSchema() {\n      // Also focus this component's schema and panel in case it's a tab.\n      await this.schemaComponent.focus()\n      await this.tabComponent?.focus()\n    },\n\n    async focus() {\n      await this.focusSchema()\n      this.scrollIntoView()\n      this.focusElement()\n    },\n\n    blur() {\n      this.blurElement()\n    },\n\n    clear() {\n      this.value = null\n      this.blur()\n      this.onChange()\n    },\n\n    onFocus() {\n      this.focused = true\n      this.markTouched()\n      this.emitEvent('focus')\n    },\n\n    onBlur() {\n      this.focused = false\n      this.validate()\n      this.emitEvent('blur')\n    },\n\n    onInput() {\n      this.markDirty()\n      this.emitEvent('input')\n    },\n\n    onChange() {\n      this.markDirty()\n      this.emitEvent('change', {\n        context: {\n          // Prevent endless parse recursion:\n          value: this.parsedValue !== undefined ? this.parsedValue : this.value\n        },\n        // Pass `schemaComponent` as parent, so change events can propagate up.\n        parent: this.schemaComponent\n      })\n    }\n  }\n}\n","import { toRaw } from 'vue'\n\nconst uidMap = new WeakMap()\n\n// Generated and remembers unique ids per passed object using a weak map.\nlet uid = 0\nexport function getUid(item, getItemId = null) {\n  const raw = toRaw(item)\n  let id = uidMap.get(raw)\n  if (!id && item) {\n    id = getItemId?.(item) || `@${++uid}`\n    uidMap.set(raw, id)\n  }\n  return id\n}\n","import { isTemporaryId } from './data.js'\nimport {\n  isInteger,\n  asArray,\n  parseDataPath,\n  getValueAtDataPath\n} from '@ditojs/utils'\nimport { nanoid } from 'nanoid'\n\n// SchemaGraph is a class to collect schema graph meta information in order to\n// process sources and relations for the given targets 'server' and 'clipboard',\n// according to the following table:\n//\n// | --------------------------------------------| --------- | --------- |\n// | data                                        | server    | clipboard |\n// | --------------------------------------------| --------- | --------- |\n// | type: 'relation', internal: false           | keep id   | keep id   |\n// | type: 'relation', internal: true            | keep id   | ref, #ref |\n// | type: 'relation', internal: true, temporary | ref, #ref | ref, #ref |\n// | type: 'source', related: false              | keep id   | remove id |\n// | type: 'source', related: false, temporary   | ref, #id  | remove id |\n// | type: 'source', related: true               | keep id   | ref, #id  |\n// | type: 'source', related: true, temporary    | ref, #id  | ref, #id  |\n// | --------------------------------------------| --------- | --------- |\n\nexport class SchemaGraph {\n  graph = {}\n  references = {}\n\n  set(dataPath, settings, defaults) {\n    dataPath = parseDataPath(dataPath)\n    let subGraph = this.graph\n    for (const part of dataPath) {\n      const key = isInteger(+part) ? '*' : part\n      subGraph = subGraph[key] ??= {}\n    }\n    subGraph.$settings = {\n      ...defaults, // See `addSource(dataPath)`\n      ...subGraph.$settings,\n      ...settings\n    }\n  }\n\n  addSource(dataPath, schema) {\n    // Only set `related: false` through the defaults, as `setSourceRelated()`\n    // may be called before `addSource()`, depending on the graph structure.\n    this.set(dataPath, { type: 'source', schema }, { related: false })\n  }\n\n  setSourceRelated(dataPath) {\n    this.set(dataPath, {\n      related: true,\n      reference: this.getReferencePrefix(dataPath)\n    })\n  }\n\n  addRelation(dataPath, relatedDataPath, schema) {\n    this.set(dataPath, {\n      type: 'relation',\n      schema,\n      internal: !!relatedDataPath,\n      reference: this.getReferencePrefix(relatedDataPath)\n    })\n  }\n\n  getReferencePrefix(dataPath) {\n    return dataPath\n      ? (this.references[dataPath] ??= nanoid(6))\n      : null\n  }\n\n  flatten() {\n    const flatten = graph => {\n      const entries = []\n      for (const [key, { $settings, ...subGraph }] of Object.entries(graph)) {\n        if ($settings) {\n          entries.push([key, $settings])\n        }\n        for (const [subKey, settings] of flatten(subGraph)) {\n          entries.push([`${key}/${subKey}`, settings])\n        }\n      }\n      return entries\n    }\n\n    return flatten(this.graph)\n  }\n\n  process(sourceSchema, data, { target }) {\n    const clipboard = target === 'clipboard'\n    if (clipboard) {\n      delete data[sourceSchema.idKey || 'id']\n    }\n    for (const [dataPath, settings] of this.flatten()) {\n      const { type, schema, internal, related, reference } = settings\n      const source = type === 'source'\n      const relation = type === 'relation'\n      if (source || relation && internal) {\n        const values = getValueAtDataPath(data, dataPath, () => null)\n        const removeId = clipboard && source && !related\n        const referenceId = (\n          clipboard && (\n            relation && internal ||\n            source && related\n          )\n        )\n        for (const value of asArray(values).flat()) {\n          const idKey = (\n            source && schema.idKey ||\n            relation && schema.relateBy ||\n            'id'\n          )\n          let id = value?.[idKey]\n          if (id != null) {\n            if (removeId) {\n              delete value[idKey]\n            }\n            if (referenceId || isTemporaryId(id)) {\n              if (isTemporaryId(id)) {\n                id = id.slice(1)\n              }\n              const refKey = clipboard\n                ? // Clipboard just needs temporary ids under the actual `idKey`\n                  idKey\n                : // Server wants Objection-style '#id' / '#ref' pairs.\n                  source\n                  ? '#id'\n                  : '#ref'\n              const revValue = clipboard\n                ? `@${id}`\n                : // Keep the ids unique in reference groups, since they\n                  // reference across the full graph.\n                  reference\n                  ? `${reference}-${id}`\n                  : id // A temporary id without a related, just preserve it.\n              value[refKey] = revValue\n              if (refKey !== idKey) {\n                delete value[idKey]\n              }\n            }\n          }\n        }\n      }\n    }\n    return data\n  }\n}\n","import {\n  isArray,\n  isObject,\n  isString,\n  isBoolean,\n  isNumber,\n  isFunction,\n  isDate,\n  isRegExp,\n  asArray\n} from '@ditojs/utils'\n\nconst typeCheckers = {\n  Boolean: isBoolean,\n  Number: isNumber,\n  String: isString,\n  Date: isDate,\n  Array: isArray,\n  Object: isObject,\n  RegExp: isRegExp,\n  Function: isFunction\n}\n\n// Declare these separately from the `typeConverters` object, to prevent\n// Babel issues with `Object` overriding the global `Object`:\nconst toBoolean = value => !!value\nconst toNumber = value => +value\nconst toString = value => String(value)\n\nconst toDate = value =>\n  isDate(value)\n    ? value\n    : new Date(value)\n\nconst toArray = value =>\n  isArray(value)\n    ? value\n    : isString(value)\n      ? value.split(',')\n      : asArray(value)\n\nconst toObject = value =>\n  isObject(value)\n    ? value\n    : // If a Object is expected but a Boolean provide, convert to an empty\n      // object. Used by `creatable` & co, that can be both.\n      value === true\n      ? {}\n      : null\n\nconst toRegExp = value =>\n  isRegExp(value)\n    ? value\n    : new RegExp(value)\n\nconst typeConverters = {\n  Boolean: toBoolean,\n  Number: toNumber,\n  String: toString,\n  Date: toDate,\n  Array: toArray,\n  Object: toObject,\n  RegExp: toRegExp\n}\n\nexport function isMatchingType(types, value) {\n  // See if any of the expect types match, return immediately if they do:\n  if (types && value != null) {\n    for (const type of types) {\n      if (typeCheckers[type.name]?.(value)) {\n        return true\n      }\n    }\n  }\n  return false\n}\n\nexport function convertType(type, value) {\n  const converter = type && typeConverters[type.name || type]\n  return converter ? converter(value) : value\n}\n","import DitoContext from '../DitoContext.js'\nimport DitoMixin from '../mixins/DitoMixin.js'\nimport TypeMixin from '../mixins/TypeMixin.js'\nimport { getUid } from './uid.js'\nimport { SchemaGraph } from './SchemaGraph.js'\nimport { appendDataPath } from './data.js'\nimport { isMatchingType, convertType } from './type.js'\nimport {\n  isObject,\n  isString,\n  isArray,\n  isFunction,\n  isPromise,\n  isModule,\n  asArray,\n  clone,\n  camelize,\n  assignDeeply,\n  mapConcurrently,\n  getValueAtDataPath\n} from '@ditojs/utils'\nimport { markRaw, reactive } from 'vue'\n\nconst typeComponents = {}\nconst unknownTypeReported = {}\nconst emptySchema = {}\n\nexport function registerTypeComponent(type, component) {\n  typeComponents[type] = component\n}\n\nexport function getTypeComponent(type, allowNull = false) {\n  const component = typeComponents[type] || null\n  if (!component && !allowNull && !unknownTypeReported[type]) {\n    // Report each missing type only once, to avoid flooding the console:\n    unknownTypeReported[type] = true\n    throw new Error(`Unknown Dito.js component type: '${type}'`)\n  }\n  return component\n}\n\nexport function iterateSchemaComponents(schemas, callback) {\n  for (const schema of schemas) {\n    if (isSingleComponentView(schema)) {\n      const res = callback(schema.component, schema.name, 0)\n      if (res !== undefined) {\n        return res\n      }\n    } else if (isSchema(schema)) {\n      for (const [name, component] of Object.entries(schema.components || {})) {\n        const res = callback(component, name, 1)\n        if (res !== undefined) {\n          return res\n        }\n      }\n    }\n  }\n}\n\nexport function iterateNestedSchemaComponents(schema, callback) {\n  return schema\n    ? iterateSchemaComponents([schema, ...getTabSchemas(schema)], callback)\n    : undefined\n}\n\nexport function findNestedSchemaComponent(schema, callback) {\n  return (\n    iterateNestedSchemaComponents(\n      schema,\n      component => (callback(component) ? component : undefined)\n    ) ?? null\n  )\n}\n\nexport function someNestedSchemaComponent(schema, callback) {\n  return (\n    iterateNestedSchemaComponents(\n      schema,\n      component => (callback(component) ? true : undefined)\n    ) ?? false\n  )\n}\n\nexport function everyNestedSchemaComponent(schema, callback) {\n  return (\n    iterateNestedSchemaComponents(\n      schema,\n      component => (callback(component) ? undefined : false)\n    ) ?? true\n  )\n}\n\nexport function hasNestedSchemaComponents(schema) {\n  return someNestedSchemaComponent(schema, () => true) ?? false\n}\n\nexport function isSchema(schema) {\n  return isObject(schema) && isString(schema.type)\n}\n\nexport function isForm(schema) {\n  return isSchema(schema) && schema.type === 'form'\n}\n\nexport function isView(schema) {\n  return isSchema(schema) && schema.type === 'view'\n}\n\nexport function isTab(schema) {\n  return isSchema(schema) && schema.type === 'tab'\n}\n\nexport function isPanel(schema) {\n  return isSchema(schema) && schema.type === 'panel'\n}\n\nexport function isMenu(schema) {\n  return isSchema(schema) && schema.type === 'menu'\n}\n\nexport function getSchemaIdentifier(schema) {\n  return JSON.stringify(schema)\n}\n\nconst resolvedSchemas = new WeakMap()\nexport async function resolveSchema(value, unwrapModule = false) {\n  if (resolvedSchemas.has(value)) {\n    return resolvedSchemas.get(value)\n  }\n  let schema = value\n  if (isFunction(schema)) {\n    schema = schema()\n  }\n  if (isPromise(schema)) {\n    schema = await schema\n  }\n  if (isModule(schema)) {\n    // Copy to convert from module to object:\n    schema = { ...schema }\n    // Unwrap default or named schema\n    if (!schema.name && (unwrapModule || schema.default)) {\n      // Filter out internal key added by vite / vue 3 plugin when changing\n      // code in a dynamically imported vue component, see:\n      // https://github.com/vitejs/vite-plugin-vue/blob/abdf5f4f32d02af641e5f60871bde14535569b1e/packages/plugin-vue/src/main.ts#L133\n      const keys = Object.keys(schema).filter(key => key !== '_rerender_only')\n      if (keys.length === 1) {\n        const name = keys[0]\n        schema = schema[name]\n        if (name !== 'default') {\n          schema = { ...schema, name }\n        }\n      }\n    }\n  }\n  resolvedSchemas.set(value, schema)\n  return schema\n}\n\nexport async function resolveSchemas(\n  unresolvedSchemas,\n  resolveItem = resolveSchema\n) {\n  let schemas = isFunction(unresolvedSchemas)\n    ? unresolvedSchemas()\n    : unresolvedSchemas\n  schemas = await resolveSchema(schemas, false)\n  if (isArray(schemas)) {\n    // Translate an array of dynamic import, each importing one named schema\n    // module to an object with named entries.\n    schemas = Object.fromEntries(\n      await mapConcurrently(\n        schemas,\n        async item => {\n          const schema = await resolveItem(item, true)\n          return [schema.name, schema]\n        }\n      )\n    )\n  } else if (isObject(schemas)) {\n    schemas = Object.fromEntries(\n      await mapConcurrently(\n        Object.entries(schemas),\n        async ([key, item]) => {\n          const schema = await resolveItem(item, true)\n          return [key, schema]\n        }\n      )\n    )\n  }\n  return schemas\n}\n\nexport async function resolveViews(unresolvedViews) {\n  return resolveSchemas(unresolvedViews, async (schema, unwrapModule) => {\n    schema = await resolveSchema(schema, unwrapModule)\n    if (!schema.name && isMenu(schema)) {\n      // Generate a name for sub-menus from their label if it's missing.\n      // NOTE: This is never actually referenced from anywhere, but they need\n      // a name by which they're stored in the parent object.\n      schema = {\n        ...schema,\n        name: camelize(schema.label),\n        items: await resolveSchemas(schema.items)\n      }\n    }\n    return schema\n  })\n}\n\nexport function flattenViews(views) {\n  return Object.fromEntries(\n    Object.entries(views).reduce(\n      (entries, [key, schema]) => {\n        if (isMenu(schema)) {\n          entries.push(...Object.entries(schema.items))\n        } else {\n          entries.push([key, schema])\n        }\n        return entries\n      },\n      []\n    )\n  )\n}\n\nexport async function resolveSchemaComponent(schema) {\n  // Resolves async schema components and adds DitoMixin and TypeMixin to them.\n  let { component } = schema\n  if (component) {\n    component = await resolveSchema(component, true)\n    if (component) {\n      // Prevent warning: \"Vue received a Component which was made a reactive\n      // object. This can lead to unnecessary performance overhead, and should\n      // be avoided by marking the component with `markRaw`\":\n      schema.component = markRaw({\n        ...component,\n        mixins: [DitoMixin, TypeMixin, ...(component.mixins || [])]\n      })\n    }\n  }\n}\n\nexport async function resolveSchemaComponents(schemas) {\n  // `schemas` are of the same possible forms as passed to `getNamedSchemas()`\n  await mapConcurrently(Object.values(schemas || {}), resolveSchemaComponent)\n}\n\nconst processedSchemaDepths = new WeakMap()\nexport function processSchemaComponents(\n  api,\n  schema,\n  routes = null,\n  level = 0,\n  maxDepth = 1\n) {\n  if (schema) {\n    const depth = processedSchemaDepths.get(schema) ?? 0\n    if (depth < maxDepth) {\n      processedSchemaDepths.set(schema, depth + 1)\n      const promises = []\n      const process = (component, name, relativeLevel) => {\n        promises.push(\n          processSchemaComponent(\n            api,\n            component,\n            name,\n            routes,\n            level + relativeLevel\n          )\n        )\n      }\n\n      iterateNestedSchemaComponents(schema, process)\n      iterateSchemaComponents(getPanelSchemas(schema), process)\n\n      return Promise.all(promises)\n    }\n  }\n}\n\nexport function processSchemaComponent(\n  api,\n  schema,\n  name,\n  routes = null,\n  level = 0\n) {\n  processSchemaDefaults(api, schema)\n\n  return Promise.all([\n    // Also process nested panel schemas.\n    mapConcurrently(\n      getPanelSchemas(schema),\n      panel => processSchemaComponents(api, panel, routes, level)\n    ),\n    // Delegate schema processing to the actual type components.\n    getTypeOptions(schema)?.processSchema?.(\n      api,\n      schema,\n      name,\n      routes,\n      level\n    )\n  ])\n}\n\nexport async function processView(component, api, schema, name, fullPath = '') {\n  processSchemaDefaults(api, schema)\n  processRouteSchema(api, schema, name, fullPath)\n  let children = []\n  if (isView(schema)) {\n    await processNestedSchemas(api, schema)\n    await processSchemaComponents(api, schema, children)\n  } else if (isMenu(schema)) {\n    children = await Promise.all(\n      Object.entries(schema.items).map(async ([name, item]) =>\n        processView(component, api, item, name, schema.fullPath)\n      )\n    )\n  } else {\n    throw new Error(`Invalid view schema: '${getSchemaIdentifier(schema)}'`)\n  }\n  return {\n    path: schema.fullPath,\n    children,\n    component,\n    meta: {\n      api,\n      schema\n    }\n  }\n}\n\nexport function processSchemaDefaults(api, schema) {\n  let defaults = (\n    api.defaults[schema.type] ||\n    api.defaults[camelize(schema.type)]\n  )\n  if (defaults) {\n    if (isFunction(defaults)) {\n      defaults = defaults(schema)\n    }\n    if (isObject(defaults)) {\n      for (const [key, value] of Object.entries(defaults)) {\n        if (schema[key] === undefined) {\n          schema[key] = value\n        } else {\n          schema[key] = assignDeeply(schema[key], value)\n        }\n      }\n    }\n  }\n}\n\nexport function processNestedSchemaDefaults(api, schema) {\n  // Process defaults for nested schemas. Note that this is also done when\n  // calling `processSchemaComponents()`, but that function is async, and we\n  // need a sync version that only handles the defaults for filters, see\n  // `getFiltersPanel()`.\n  iterateNestedSchemaComponents(schema, component => {\n    processSchemaDefaults(api, component)\n    const forms = getFormSchemas(component)\n    for (const form of Object.values(forms)) {\n      processNestedSchemaDefaults(api, form)\n    }\n  })\n}\n\nexport function processRouteSchema(api, schema, name, fullPath = null) {\n  // Used for view and source schemas, see SourceMixin.\n  schema.name ??= name\n  schema.path ??= api.normalizePath(name)\n  if (fullPath !== null) {\n    schema.fullPath = `${fullPath}/${schema.path}`\n  }\n}\n\nexport async function processForms(api, schema, level) {\n  const routes = []\n  // First resolve the forms and store the results back on the schema.\n  const { form, forms, components, maxDepth = 1 } = schema\n  if (forms) {\n    schema.forms = await resolveSchemas(forms, form =>\n      processForm(api, form, routes, level, maxDepth)\n    )\n  } else if (form) {\n    schema.form = await processForm(api, form, routes, level, maxDepth)\n  } else if (isObject(components)) {\n    // NOTE: Processing forms in computed components is not supported, since it\n    // only can be computed in conjunction with actual data.\n    const form = {\n      type: 'form',\n      components\n    }\n    await processForm(api, form, routes, level, maxDepth)\n  }\n  return routes\n}\n\nexport async function processForm(\n  api,\n  schema,\n  routes = null,\n  level = 0,\n  maxDepth = 1\n) {\n  schema = await resolveSchema(schema, true)\n  if (!isForm(schema)) {\n    throw new Error(`Invalid form schema: '${getSchemaIdentifier(schema)}'`)\n  }\n  processSchemaDefaults(api, schema)\n  await processNestedSchemas(api, schema)\n  await processSchemaComponents(api, schema, routes, level, maxDepth)\n  return schema\n}\n\nexport async function processTab(api, schema) {\n  schema = await resolveSchema(schema, true)\n  if (!isTab(schema)) {\n    throw new Error(`Invalid tab schema: '${getSchemaIdentifier(schema)}'`)\n  }\n  processSchemaDefaults(api, schema)\n  return schema\n}\n\nexport async function processPanel(api, schema) {\n  schema = await resolveSchema(schema, true)\n  if (!isPanel(schema)) {\n    throw new Error(`Invalid panel schema: '${getSchemaIdentifier(schema)}'`)\n  }\n  processSchemaDefaults(api, schema)\n  return schema\n}\n\nexport async function processNestedSchemas(api, schema) {\n  const { tabs, panels } = schema\n  if (tabs) {\n    schema.tabs = await resolveSchemas(\n      tabs,\n      tab => processTab(api, tab)\n    )\n  }\n  if (panels) {\n    schema.panels = await resolveSchemas(\n      panels,\n      panel => processPanel(api, panel)\n    )\n  }\n}\n\nexport function hasFormSchema(schema) {\n  // Support both single form and multiple forms notation, as well as inlined\n  // components.\n  return (\n    isSchema(schema) &&\n    isObject(schema.form || schema.forms || schema.components)\n  )\n}\n\nexport function hasMultipleFormSchemas(schema) {\n  return (\n    isSchema(schema) &&\n    Object.keys(schema?.forms || {}).length > 1\n  )\n}\n\nexport function isSingleComponentView(schema) {\n  return (\n    isView(schema) &&\n    isObject(schema.component)\n  )\n}\n\nexport function getViewFormSchema(schema, context) {\n  const { view } = schema\n  const viewSchema = view && context.flattenedViews[view]\n  return viewSchema\n    ? // NOTE: Views can have tabs, in which case the view component is nested\n      // in one of the tabs, go find it.\n      findNestedSchemaComponent(viewSchema, hasFormSchema) || null\n    : null\n}\n\nexport function getViewSchema(schema, context) {\n  return getViewFormSchema(schema, context)\n    ? context.flattenedViews[schema.view]\n    : null\n}\n\nexport function hasViewSchema(schema, context) {\n  return !!getViewSchema(schema, context)\n}\n\nexport function getViewPath(schema, context) {\n  const view = getViewSchema(schema, context)\n  if (view) {\n    return isSingleComponentView(view)\n      ? view.fullPath\n      : `${view.fullPath}/${view.path}`\n  }\n  return null\n}\n\nexport function getViewEditPath(schema, id, context) {\n  const path = getViewPath(schema, context)\n  return path ? `${path}/${id}` : null\n}\n\nexport function getFormSchemas(schema, context, modifyForm) {\n  const viewSchema = context && getViewFormSchema(schema, context)\n  if (viewSchema) {\n    schema = viewSchema\n  } else if (schema.view) {\n    throw new Error(`Unknown view: '${schema.view}'`)\n  }\n\n  let { form, forms } = schema\n  if (!form && !forms) {\n    const { name, compact, clipboard, tabs, components } = schema\n    if (components || tabs) {\n      // Convert inlined forms to stand-alone forms, supporting `name`,\n      // `compact`, `clipboard`, `tabs` and `components` settings.\n      form = { type: 'form', name, compact, clipboard, tabs, components }\n    } else {\n      // No `forms`, `form` or `components`, return and empty `forms` object.\n      return {}\n    }\n  }\n  forms ||= { default: form }\n  return Object.fromEntries(\n    Object.entries(forms).map(([type, form]) => {\n      // Support `schema.components` callbacks to create components on the fly.\n      if (context && isFunction(form.components)) {\n        // Make the form schema reactive since `processForm()` is async, so that\n        // the setting of defaults will be picked up by downstream code.\n        form = reactive({\n          ...form,\n          components: form.components(context)\n        })\n        // Process the form again, now that we have the components.\n        processForm(context.api, form).catch(console.error)\n      }\n      return [type, modifyForm?.(form) ?? form]\n    })\n  )\n}\n\nexport function getItemFormSchemaFromForms(forms, item) {\n  return forms[item?.type] || forms.default || null\n}\n\nexport function getItemFormSchema(schema, item, context) {\n  return (\n    getItemFormSchemaFromForms(getFormSchemas(schema, context), item) ||\n    // Always return a schema object so we don't need to check for it.\n    emptySchema\n  )\n}\n\nexport function isEmptySchema(schema) {\n  return schema === emptySchema\n}\n\nexport function isCompact(schema) {\n  return !!schema.compact\n}\n\nexport function isInlined(schema) {\n  return !!(schema.inlined || schema.components)\n}\n\nexport function isNested(schema) {\n  return !!(schema.nested || getTypeOptions(schema)?.defaultNested === true)\n}\n\nexport function hasLabel(schema, generateLabels) {\n  const { label } = schema\n  return (\n    label !== false && (\n      !!label ||\n      generateLabels && getTypeOptions(schema)?.generateLabel\n    )\n  )\n}\n\nexport function omitSpacing(schema) {\n  return !!getTypeOptions(schema)?.omitSpacing\n}\n\nexport function getSchemaValue(\n  keyOrDataPath,\n  { type, schema, callback = true, default: def, context } = {}\n) {\n  const types = type && asArray(type)\n  // For performance reasons, data-paths in `keyOrDataPath` can only be\n  // provided in in array format here:\n  let value = schema\n    ? isArray(keyOrDataPath)\n      ? getValueAtDataPath(schema, keyOrDataPath, () => undefined)\n      : schema[keyOrDataPath]\n    : undefined\n\n  if (value === undefined && def !== undefined) {\n    if (callback && isFunction(def) && !isMatchingType(types, def)) {\n      // Support `default()` functions for any type except `Function`:\n      def = def(context)\n    }\n    return def\n  }\n\n  if (isMatchingType(types, value)) {\n    return value\n  }\n  // Any schema value handled through `getSchemaValue()` can provide\n  // a function that's resolved when the value is evaluated:\n  if (callback && isFunction(value)) {\n    value = value(context)\n  }\n  // Now finally see if we can convert to the expect types.\n  if (types && value != null && !isMatchingType(types, value)) {\n    for (const type of types) {\n      const converted = convertType(type, value)\n      if (converted !== value) {\n        return converted\n      }\n    }\n  }\n  return value\n}\n\nexport function shouldRenderSchema(schema, context) {\n  return (\n    getSchemaValue('if', {\n      type: Boolean,\n      schema,\n      context,\n      default: true\n    }) && (\n      !hasNestedSchemaComponents(schema) ||\n      someNestedSchemaComponent(schema, component =>\n        shouldRenderSchema(component, context)\n      )\n    )\n  )\n}\n\nfunction getContext(context) {\n  return isFunction(context) ? context() : context\n}\n\nexport function getDefaultValue(schema, context) {\n  // Support default values both on schema and on component level.\n  // NOTE: At the time of creation, components may not be instantiated, (e.g. if\n  // entries are created through nested forms, the parent form isn't mounted) so\n  // we can't use `dataPath` to get to components, and the `defaultValue` from\n  // there. That's why `defaultValue` is defined statically in the components:\n  const defaultValue =\n    schema.default !== undefined\n      ? schema.default\n      : getTypeOptions(schema)?.defaultValue\n  return isFunction(defaultValue)\n    ? defaultValue(getContext(context))\n    : clone(defaultValue)\n}\n\nexport function shouldExcludeValue(schema, context) {\n  const excludeValue =\n    schema.exclude !== undefined\n      ? schema.exclude\n      : getTypeOptions(schema)?.excludeValue\n  return isFunction(excludeValue)\n    ? excludeValue(getContext(context))\n    : !!excludeValue\n}\n\nexport function shouldIgnoreMissingValue(schema, context) {\n  return !!getTypeOptions(schema)?.ignoreMissingValue?.(getContext(context))\n}\n\nexport function getMultipleValue(schema) {\n  return schema.multiple ?? !!getTypeOptions(schema)?.defaultMultiple\n}\n\nexport function setDefaultValues(schema, data = {}, component) {\n  const options = { component, rootData: data }\n\n  const processBefore = (schema, data, name, dataPath) => {\n    const context = () =>\n      new DitoContext(component, {\n        schema,\n        name,\n        data,\n        dataPath,\n        rootData: options.rootData\n      })\n    if (!(name in data) && !shouldIgnoreMissingValue(schema, context)) {\n      data[name] = getDefaultValue(schema, context)\n    }\n  }\n\n  // Sets up a data object that has keys with default values for all\n  // form fields, so they can be correctly watched for changes.\n  return processSchemaData(\n    schema,\n    data,\n    null,\n    null,\n    processBefore,\n    null,\n    options\n  )\n}\n\nexport function computeValue(schema, data, name, dataPath, {\n  component = null,\n  rootData = component?.rootData\n} = {}) {\n  const context = () =>\n    new DitoContext(component, {\n      schema,\n      // Override value to prevent endless recursion through calling the\n      // getter for `this.value` in `DitoContext`:\n      value: data[name],\n      name,\n      data,\n      dataPath,\n      rootData\n    })\n  const { compute } = schema\n  if (compute) {\n    const value = compute(getContext(context))\n    if (value !== undefined) {\n      // Access `data[name]` directly to update the value without calling\n      // parse():\n      // TODO: Fix side-effects\n      data[name] = value\n    }\n  }\n  // If the value is still missing after compute, set the default for it:\n  if (!(name in data) && !shouldIgnoreMissingValue(schema, context)) {\n    // TODO: Fix side-effects\n    data[name] = getDefaultValue(schema, context)\n  }\n  // Now access the value. This is important for reactivity and needs to\n  // happen after all prior manipulation of `data[name]`, see above:\n  return data[name]\n}\n\nfunction cloneItem(sourceSchema, item, options) {\n  if (options.schemaOnly) {\n    const copy = {}\n    const { idKey = 'id', orderKey } = sourceSchema\n    const id = item[idKey]\n    if (id !== undefined) {\n      copy[idKey] = id\n    }\n    // Copy over type in case there are multiple forms to choose from.\n    if (hasMultipleFormSchemas(sourceSchema)) {\n      copy.type = item.type\n    }\n    if (orderKey) {\n      copy[orderKey] = item[orderKey]\n    }\n    return copy\n  } else {\n    return { ...item }\n  }\n}\n\nexport function processData(schema, sourceSchema, data, dataPath, {\n  component,\n  rootData,\n  schemaOnly, // whether to only include data covered by the schema, or all data\n  target\n} = {}) {\n  const options = { component, rootData, schemaOnly, target }\n  const processedData = cloneItem(sourceSchema, data, options)\n  const graph = new SchemaGraph()\n\n  const processBefore = (schema, data, name, dataPath, processedData) => {\n    let value = computeValue(schema, data, name, dataPath, options)\n    // The schema expects the `wrapPrimitives` transformations to be present on\n    // the data that it is applied on, so warp before and unwrap after.\n    if (isArray(value)) {\n      const { wrapPrimitives } = schema\n      if (wrapPrimitives) {\n        value = value.map(entry => ({\n          [wrapPrimitives]: entry\n        }))\n      } else {\n        // Always shallow-clone array values:\n        value = [...value]\n      }\n    }\n    processedData[name] = value\n  }\n\n  const processAfter = (schema, data, name, dataPath, processedData) => {\n    const { wrapPrimitives, process } = schema\n    let value = processedData[name]\n\n    // NOTE: We don't cache this context, since `value` is changing.\n    const context = () =>\n      new DitoContext(component, {\n        schema,\n        value,\n        name,\n        data,\n        dataPath,\n        rootData: options.rootData,\n        // Pass the already processed data to `process()`, so it can be modified\n        // through `processedItem` from there.\n        processedData\n      })\n\n    // First unwrap the wrapped primitives again, to bring the data back into\n    // its native form. Se `processBefore()` for more details.\n    if (wrapPrimitives && isArray(value)) {\n      value = value.map(object => object[wrapPrimitives])\n    }\n\n    // Each component type can provide its own static `processValue()` method\n    // to convert the data for storage.\n    const processValue = getTypeOptions(schema)?.processValue\n    if (processValue) {\n      value = processValue(getContext(context), graph)\n    }\n\n    // Handle the user's `process()` callback next, if one is provided, so that\n    // it can modify data in `processedData` even if it provides `exclude: true`\n    if (process) {\n      value = process(getContext(context))\n    }\n\n    if (shouldExcludeValue(schema, context)) {\n      delete processedData[name]\n    } else {\n      processedData[name] = value\n    }\n  }\n\n  processSchemaData(\n    schema,\n    data,\n    dataPath,\n    processedData,\n    processBefore,\n    processAfter,\n    options\n  )\n\n  return graph.process(sourceSchema, processedData, options)\n}\n\nexport function processSchemaData(\n  schema,\n  data,\n  dataPath,\n  processedData,\n  processBefore,\n  processAfter,\n  options\n) {\n  const processComponents = components => {\n    const getDataPath = (dataPath, token) =>\n      dataPath != null\n        ? appendDataPath(dataPath, token)\n        : null\n\n    if (components) {\n      for (const [name, componentSchema] of Object.entries(components)) {\n        if (!isNested(componentSchema)) {\n          // Recursively process data on unnested components.\n          processSchemaData(\n            componentSchema,\n            data,\n            dataPath,\n            processedData,\n            processBefore,\n            processAfter,\n            options\n          )\n        } else {\n          const componentDataPath = getDataPath(dataPath, name)\n\n          const processItem = (item, index = null) => {\n            const itemDataPath =\n              index !== null\n                ? getDataPath(componentDataPath, index)\n                : componentDataPath\n            const context = new DitoContext(options.component, {\n              schema: componentSchema,\n              data,\n              dataPath: componentDataPath,\n              name,\n              rootData: options.rootData\n            })\n            const getForms = (\n              getTypeOptions(componentSchema)?.getFormSchemasForProcessing ||\n              getFormSchemas\n            )\n            const forms = getForms(componentSchema, context)\n            const form = getItemFormSchemaFromForms(forms, item)\n            if (form) {\n              const processedItem = processedData\n                ? cloneItem(componentSchema, item, options)\n                : null\n              return processSchemaData(\n                form,\n                item,\n                itemDataPath,\n                processedItem,\n                processBefore,\n                processAfter,\n                options\n              )\n            } else {\n              // Items without forms still get fully (but shallowly) cloned.\n              // TODO: Find out of this is actually needed / used at all?\n              return { ...item }\n            }\n          }\n\n          processBefore?.(\n            componentSchema,\n            data,\n            name,\n            componentDataPath,\n            processedData\n          )\n\n          let value = processedData ? processedData[name] : data[name]\n          if (value != null && hasFormSchema(componentSchema)) {\n            // Recursively process data on nested form items.\n            if (isArray(value)) {\n              // Optimization: No need to collect values if we're not cloning!\n              value = processedData\n                ? value.map(processItem)\n                : value.forEach(processItem)\n            } else {\n              value = processItem(value)\n            }\n            if (processedData) {\n              processedData[name] = value\n            }\n          }\n\n          processAfter?.(\n            componentSchema,\n            data,\n            name,\n            componentDataPath,\n            processedData\n          )\n        }\n      }\n    }\n  }\n\n  processComponents(schema.components)\n  for (const tab of getTabSchemas(schema)) {\n    processComponents(tab.components)\n  }\n  for (const panel of getPanelSchemas(schema)) {\n    processComponents(panel.components)\n  }\n\n  return processedData || data\n}\n\nexport function getNamedSchemas(schemas, defaults) {\n  const toObject = (array, toSchema) => {\n    return array.length > 0\n      ? array.reduce((object, value) => {\n          const schema = toSchema(value)\n          if (schema) {\n            object[schema.name] =\n              schema && defaults\n                ? { ...defaults, ...schema }\n                : schema\n          }\n          return object\n        }, {})\n      : null\n  }\n\n  return isArray(schemas)\n    ? toObject(schemas, value =>\n        isObject(value)\n          ? value\n          : {\n              name: camelize(value, false)\n            }\n      )\n    : isObject(schemas)\n      ? toObject(\n          Object.entries(schemas),\n          ([name, value]) =>\n            isObject(value)\n              ? {\n                  name,\n                  ...value\n                }\n              : isString(value)\n                ? {\n                    name,\n                    label: value\n                  }\n                : null\n        )\n      : null\n}\n\nexport function getButtonSchemas(buttons) {\n  return getNamedSchemas(\n    buttons,\n    { type: 'button' } // Defaults\n  )\n}\n\nfunction getType(schemaOrType) {\n  return isObject(schemaOrType) ? schemaOrType.type : schemaOrType\n}\n\nexport function getTypeOptions(schemaOrType) {\n  return getTypeComponent(getType(schemaOrType), true) ?? null\n}\n\nexport function getSourceType(schemaOrType) {\n  return (\n    getTypeOptions(schemaOrType)?.getSourceType?.(getType(schemaOrType)) ??\n    null\n  )\n}\n\nexport function getPanelEntry(schema, dataPath = null, tabComponent = null) {\n  return schema\n    ? {\n        schema,\n        // If the panel provides its own name, append it to the dataPath.\n        // This is used e.g. for $filters panels.\n        dataPath:\n          dataPath != null && schema.name\n            ? appendDataPath(dataPath, schema.name)\n            : dataPath,\n        tabComponent\n      }\n    : null\n}\n\nexport function getPanelEntries(\n  panelSchemas,\n  dataPath,\n  tabComponent = null,\n  panelEntries = []\n) {\n  if (panelSchemas) {\n    for (const [key, schema] of Object.entries(panelSchemas)) {\n      const entry = getPanelEntry(\n        schema,\n        appendDataPath(dataPath, key),\n        tabComponent\n      )\n      if (entry) {\n        panelEntries.push(entry)\n      }\n    }\n  }\n  return panelEntries\n}\n\nexport function getTabSchemas(schema) {\n  return schema?.tabs ? Object.values(schema.tabs) : []\n}\n\nexport function getPanelSchemas(schema) {\n  return schema?.panels ? Object.values(schema.panels) : []\n}\n\nexport function getAllPanelEntries(\n  api,\n  schema,\n  dataPath,\n  component = null,\n  tabComponent = null\n) {\n  const panelSchema = getTypeOptions(schema)?.getPanelSchema?.(\n    api,\n    schema,\n    dataPath,\n    component\n  )\n  const panelEntries = panelSchema\n    ? [getPanelEntry(panelSchema, dataPath, tabComponent)]\n    : []\n  // Allow each component to provide its own set of panels, in\n  // addition to the default one (e.g. getFiltersPanel(), $filters):\n  getPanelEntries(schema?.panels, dataPath, tabComponent, panelEntries)\n  return panelEntries\n}\n\nexport function isObjectSource(schemaOrType) {\n  return getSourceType(schemaOrType) === 'object'\n}\n\nexport function isListSource(schemaOrType) {\n  return getSourceType(schemaOrType) === 'list'\n}\n\nexport function getItemId(sourceSchema, item) {\n  const id = item[sourceSchema.idKey || 'id']\n  return id != null ? String(id) : undefined\n}\n\nexport function getItemUid(sourceSchema, item) {\n  // Try to use the item id as the uid, falling back on auto-generated ids, but\n  // either way, pass through `getUid()` so that the ids are associated with the\n  // item through a weak map, as the ids can be filtered out in `processData()`\n  // while the components that use the uids as key are still visible.\n  return getUid(item, item => getItemId(sourceSchema, item))\n}\n","import { isFunction, isObject, isString, pickBy } from '@ditojs/utils'\n\nexport function hasResource(schema) {\n  return !!getResource(schema.resource)\n}\n\nexport function getResource(resource, defaults = {}) {\n  const { parent, ...defs } = defaults\n  if (isFunction(resource)) {\n    resource = resource(defaults)\n  }\n  resource = isObject(resource)\n    ? { ...defs, ...resource }\n    : isString(resource)\n      ? { ...defs, path: resource }\n      : null\n  // Only set parent if path doesn't start with '/', so relative URLs are\n  // dealt with correctly.\n  if (\n    resource &&\n    parent !== undefined &&\n    resource.parent === undefined &&\n    !resource.path?.startsWith('/')\n  ) {\n    resource.parent = parent\n    if (!resource.path) {\n      resource.path = '.'\n    }\n  }\n  return resource\n}\n\nexport function getMemberResource(id, resource) {\n  return id != null && resource?.type === 'collection'\n    ? {\n        type: 'member',\n        ...pickBy(\n          resource,\n          (value, key) => ['method', 'path', 'parent'].includes(key)\n        ),\n        id: `${id}`\n      }\n    : null\n}\n","import {\n  isObject,\n  isString,\n  isFunction,\n  equals,\n  labelize,\n  hyphenate,\n  format\n} from '@ditojs/utils'\nimport appState from '../appState.js'\nimport DitoContext from '../DitoContext.js'\nimport EmitterMixin from './EmitterMixin.js'\nimport {\n  flattenViews,\n  getSchemaValue,\n  shouldRenderSchema\n} from '../utils/schema.js'\nimport { getResource, getMemberResource } from '../utils/resource.js'\nimport { computed, reactive } from 'vue'\n\n// @vue/component\nexport default {\n  mixins: [EmitterMixin],\n\n  inject: [\n    'api',\n    '$verbs',\n    '$views',\n    '$isPopulated',\n    '$parentComponent',\n    '$schemaComponent',\n    '$routeComponent',\n    '$dataComponent',\n    '$sourceComponent',\n    '$resourceComponent',\n    '$dialogComponent',\n    '$panelComponent',\n    '$tabComponent'\n  ],\n\n  provide() {\n    const self = () => this\n    return this.providesData\n      ? {\n          $parentComponent: self,\n          $dataComponent: self\n        }\n      : {\n          $parentComponent: self\n        }\n  },\n\n  data() {\n    return {\n      appState,\n      isMounted: false,\n      overrides: null // See accessor.js\n    }\n  },\n\n  computed: {\n    providesData() {\n      // NOTE: This is overridden in ResourceMixin, used by lists.\n      return false\n    },\n\n    sourceSchema() {\n      return this.meta?.schema\n    },\n\n    user() {\n      return appState.user\n    },\n\n    // $verbs, $verbs and $isPopulated are defined as functions, to preserve\n    // reactiveness across provide/inject.\n    // See: https://github.com/vuejs/vue/issues/7017#issuecomment-480906691\n    verbs() {\n      return this.$verbs()\n    },\n\n    views() {\n      return this.$views()\n    },\n\n    flattenedViews() {\n      return flattenViews(this.views)\n    },\n\n    isPopulated() {\n      return this.$isPopulated()\n    },\n\n    locale() {\n      return this.api.locale\n    },\n\n    context() {\n      return new DitoContext(this, { nested: false })\n    },\n\n    rootComponent() {\n      return this.$root.$refs.root\n    },\n\n    // Use computed properties as links to injects, so DitoSchema can\n    // override the property and return `this` instead of the parent.\n    parentComponent() {\n      return this.$parentComponent()\n    },\n\n    schemaComponent() {\n      return this.$schemaComponent()\n    },\n\n    routeComponent() {\n      return this.$routeComponent()\n    },\n\n    formComponent() {\n      const component = this.routeComponent\n      return component?.isForm ? component : null\n    },\n\n    viewComponent() {\n      const component = this.routeComponent\n      return component?.isView ? component : null\n    },\n\n    // Returns the first route component in the chain of parents, including\n    // this current component, that is linked to a resource (and thus loads its\n    // own data and doesn't hold nested data).\n    dataComponent() {\n      return this.providesData ? this : this.$dataComponent()\n    },\n\n    sourceComponent() {\n      return this.$sourceComponent()\n    },\n\n    resourceComponent() {\n      return this.$resourceComponent()\n    },\n\n    dialogComponent() {\n      return this.$dialogComponent()\n    },\n\n    panelComponent() {\n      return this.$panelComponent()\n    },\n\n    tabComponent() {\n      return this.$tabComponent()\n    },\n\n    parentSchemaComponent() {\n      return getParentComponent(this, 'schemaComponent')\n    },\n\n    parentRouteComponent() {\n      return getParentComponent(this, 'routeComponent')\n    },\n\n    parentFormComponent() {\n      return getParentComponent(this, 'formComponent')\n    },\n\n    parentResourceComponent() {\n      return getParentComponent(this, 'resourceComponent')\n    },\n\n    // Returns the data of the first route component in the chain of parents\n    // that loads its own data from an associated API resource.\n    rootData() {\n      return this.dataComponent?.data\n    }\n  },\n\n  mounted() {\n    this.isMounted = true\n  },\n\n  beforeCreate() {\n    const uid = nextUid++\n    Object.defineProperty(this, '$uid', { get: () => uid })\n  },\n\n  methods: {\n    labelize,\n\n    // The state of components is only available during the life-cycle of a\n    // component. Some information we need available longer than that, e.g.\n    // `query` & `total` on TypeList, so that when the user navigates back from\n    // editing an item in the list, the state of the list is still the same.\n    // We can't store this in `data`, as this is already the pure data from the\n    // API server. That's what the `store` is for: Memory that's available as\n    // long as the current editing path is still valid. For type components,\n    // this memory is provided by the parent, see RouteMixin and DitoPane.\n    getStore(key) {\n      return this.store[key]\n    },\n\n    setStore(key, value) {\n      this.store[key] = value\n      return value\n    },\n\n    removeStore(key) {\n      delete this.store[key]\n    },\n\n    getStoreKeyByIndex(index) {\n      return this.store.$keysByIndex?.[index]\n    },\n\n    setStoreKeyByIndex(index, key) {\n      this.store.$keysByIndex ??= {}\n      this.store.$keysByIndex[index] = key\n    },\n\n    getChildStore(key, index) {\n      let store = this.getStore(key)\n      if (!store && index != null) {\n        // When storing, temporary ids change to permanent ones and thus the key\n        // can change. To still find the store, we reference by index as well,\n        // to be able to find the store again after the item was saved.\n        const oldKey = this.getStoreKeyByIndex(index)\n        store = this.getStore(oldKey)\n        if (store) {\n          this.setStore(key, store)\n          this.removeStore(oldKey)\n        }\n      }\n      if (!store) {\n        store = this.setStore(key, reactive({}))\n      }\n      if (index != null) {\n        // temporary uid keys will change between persistence, so we need to\n        // assign the key to the index even when the store already existed.\n        this.setStoreKeyByIndex(index, key)\n      }\n      return store\n    },\n\n    removeChildStore(key, index) {\n      // GEt the child-store first, so that indices can be transferred over\n      // temporary id changes during persistence.\n      this.getChildStore(key, index)\n      this.removeStore(key)\n    },\n\n    getSchemaValue(\n      keyOrDataPath,\n      {\n        type,\n        default: def,\n        schema = this.schema,\n        context = this.context,\n        callback = true\n      } = {}\n    ) {\n      return getSchemaValue(keyOrDataPath, {\n        type,\n        schema,\n        context,\n        callback,\n        default: isFunction(def) ? () => def.call(this) : def\n      })\n    },\n\n    getLabel(schema, name) {\n      return schema\n        ? this.getSchemaValue('label', { schema, type: [String, Object] }) ||\n          labelize(name || schema.name)\n        : labelize(name) || ''\n    },\n\n    getButtonAttributes(verb) {\n      return {\n        class: `dito-button--${verb}`,\n        title: labelize(verb)\n      }\n    },\n\n    // TODO: Rename *Link() to *Route().\n    getQueryLink(query) {\n      return {\n        query,\n        // Preserve hash for tabs:\n        hash: this.$route.hash\n      }\n    },\n\n    shouldRenderSchema(schema = null) {\n      return shouldRenderSchema(schema, this.context)\n    },\n\n    shouldShowSchema(schema = null) {\n      return this.getSchemaValue('visible', {\n        type: Boolean,\n        default: true,\n        schema\n      })\n    },\n\n    shouldDisableSchema(schema = null) {\n      return this.getSchemaValue('disabled', {\n        type: Boolean,\n        default: false,\n        schema\n      })\n    },\n\n    getResourcePath(resource) {\n      resource = getResource(resource, {\n        // Resources without a parent inherit the one from `dataComponent`\n        // automatically.\n        parent: this.dataComponent?.getResource({\n          method: resource?.method,\n          child: resource\n        }) ?? null\n      })\n      return this.api.resources.any(resource)\n    },\n\n    getResourceUrl(resource) {\n      const url = this.getResourcePath(resource)\n      return url ? this.api.getApiUrl({ url, query: resource.query }) : null\n    },\n\n    async sendRequest({\n      method,\n      url,\n      resource,\n      query,\n      data,\n      signal,\n      internal\n    }) {\n      url ||= this.getResourceUrl(resource)\n      method ||= resource?.method\n      const checkUser = !internal && this.api.isApiUrl(url)\n      if (checkUser) {\n        await this.rootComponent.ensureUser()\n      }\n      const response = await this.api.request({\n        method,\n        url,\n        query,\n        data,\n        signal\n      })\n      // Detect change of the own user, and fetch it again if it was changed.\n      if (\n        checkUser &&\n        method === 'patch' &&\n        equals(resource, getMemberResource(this.user.id, this.api.users))\n      ) {\n        await this.rootComponent.fetchUser()\n      }\n      return response\n    },\n\n    showDialog({ components, buttons, data, settings }) {\n      return this.rootComponent.showDialog({\n        components,\n        buttons,\n        data,\n        settings\n      })\n    },\n\n    request({ cache, ...options }) {\n      // Allow caching of loaded data on two levels:\n      // - 'global': cache globally, for the entire admin session\n      // - 'local': cache locally within the closest route component that is\n      //    associated with a resource and loads its own data.\n      const cacheParent = (\n        cache &&\n        {\n          global: this.appState,\n          local: this.dataComponent\n        }[cache]\n      )\n      const loadCache = cacheParent?.loadCache\n      // Build a cache key from the config:\n      const cacheKey = (\n        loadCache &&\n        `${\n          options.method || 'get'\n        } ${\n          options.url\n        } ${\n          JSON.stringify(options.query || '')\n        } ${\n          JSON.stringify(options.data || '')\n        }`\n      )\n      if (loadCache && (cacheKey in loadCache)) {\n        return loadCache[cacheKey]\n      }\n      // NOTE: No await here, res is a promise that we can easily cache.\n      // That's fine because promises can be resolved over and over again.\n      const res = this.sendRequest(options)\n        .then(response => response.data)\n        .catch(error => {\n          // Convert axios errors to normal errors\n          const data = error.response?.data\n          throw data\n            ? Object.assign(new Error(data.message), data)\n            : error\n        })\n      if (loadCache) {\n        loadCache[cacheKey] = res\n      }\n      return res\n    },\n\n    format(value, {\n      locale = this.api.locale,\n      defaults = this.api.formats,\n      ...options\n    } = {}) {\n      return format(value, {\n        locale,\n        defaults,\n        ...options\n      })\n    },\n\n    async navigate(location) {\n      return this.$router.push(location)\n    },\n\n    download(options = {}) {\n      if (isString(options)) {\n        options = { url: options }\n      }\n      // See: https://stackoverflow.com/a/49917066/1163708\n      const a = document.createElement('a')\n      a.href = options.url?.startsWith('blob:')\n        ? options.url\n        : this.api.getApiUrl(options)\n      a.download = options.filename ?? null\n      const { body } = document\n      body.appendChild(a)\n      a.click()\n      body.removeChild(a)\n    },\n\n    notify(options) {\n      this.rootComponent.notify(options)\n    },\n\n    closeNotifications() {\n      this.rootComponent.closeNotifications()\n    },\n\n    setupSchemaFields() {\n      this.setupMethods()\n      this.setupComputed()\n      this.setupEvents()\n    },\n\n    setupMethods() {\n      for (const [key, value] of Object.entries(this.schema.methods || {})) {\n        if (isFunction(value)) {\n          this[key] = value\n        } else {\n          console.error(`Invalid method definition: ${key}: ${value}`)\n        }\n      }\n    },\n\n    setupComputed() {\n      const getComputedAccessor = ({ get, set }) => {\n        const getter = computed(() => get.call(this))\n        return {\n          get: () => getter.value,\n          set: set ? value => set.call(this, value) : undefined\n        }\n      }\n\n      for (const [key, item] of Object.entries(this.schema.computed || {})) {\n        const accessor = isFunction(item)\n          ? getComputedAccessor({ get: item })\n          : isObject(item) && isFunction(item.get)\n            ? getComputedAccessor(item)\n            : null\n        if (accessor) {\n          Object.defineProperty(this, key, accessor)\n        } else {\n          console.error(\n            `Invalid computed property definition: ${key}: ${item}`\n          )\n        }\n      }\n    },\n\n    setupEvents() {\n      const { watch, events } = this.schema\n      if (watch) {\n        const handlers = isFunction(watch) ? watch.call(this) : watch\n        if (isObject(handlers)) {\n          // Install the watch handlers in the next tick, so all components are\n          // initialized and we can check against their names.\n          this.$nextTick(() => {\n            for (const [key, callback] of Object.entries(handlers)) {\n              // Expand property names to 'data.property':\n              const expr = this.schemaComponent.getComponentByName(key)\n                ? `data.${key}`\n                : key\n              this.$watch(expr, callback)\n            }\n          })\n        }\n      }\n\n      const addEvent = (key, event, callback) => {\n        if (isFunction(callback)) {\n          this.on(hyphenate(event), callback)\n        } else {\n          console.error(`Invalid event definition: ${key}: ${callback}`)\n        }\n      }\n\n      if (events) {\n        for (const [key, value] of Object.entries(events)) {\n          addEvent(key, key, value)\n        }\n      }\n      // Also scan schema for `on[A-Z]`-style callbacks and add them\n      // TODO: Deprecate one format or the other, in favour of only one way of\n      // doing things. Decide which one to remove.\n      for (const [key, value] of Object.entries(this.schema)) {\n        if (/^on[A-Z]/.test(key)) {\n          addEvent(key, key.slice(2), value)\n        }\n      }\n    },\n\n    emitEvent(event, {\n      context = null,\n      parent = null\n    } = {}) {\n      const hasListeners = this.hasListeners(event)\n      const parentHasListeners = parent?.hasListeners(event)\n      if (hasListeners || parentHasListeners) {\n        const emitEvent = target =>\n          target.emit(event, (context = DitoContext.get(this, context)))\n\n        const handleParentListeners = result =>\n          // Don't bubble to parent if handled event returned `false`\n          parentHasListeners && result !== false\n            ? emitEvent(parent).then(() => result)\n            : result\n\n        const handleListeners = () =>\n          hasListeners\n            ? emitEvent(this).then(handleParentListeners)\n            : handleParentListeners(undefined)\n\n        return ['load', 'change'].includes(event)\n          ? // The effects of some events need time to propagate through Vue.\n            // Use $nextTick() to make sure our handlers see these changes.\n            // For example, `processedItem` is only correct after components\n            // that are newly rendered due to data changes have registered.\n            // NOTE: The result of `handleListeners()` makes it through the\n            // `$nextTick()` call and will be returned as expected.\n            this.$nextTick(handleListeners)\n          : handleListeners()\n      }\n    },\n\n    emitSchemaEvent(event, params) {\n      return this.schemaComponent.emitEvent(event, params)\n    }\n  }\n}\n\nlet nextUid = 0\n\nfunction getParentComponent(component, key) {\n  const current = component[key]\n  let parent = component.parentComponent\n  while (parent && parent[key] === current) {\n    parent = parent.parentComponent\n  }\n  return parent?.[key] ?? null\n}\n","// A mini-replication of vue's internal `resolveMergedOptions()` but only\n// handling our own added options properties and merging them early instead\n// of lazily.\n\nexport function resolveMergedOptions(options) {\n  const { mixins } = options\n  return mixins || options.extends\n    ? mergeOptions(\n        { ...options },\n        options\n      )\n    : options\n}\n\nexport function mergeOptions(to, from) {\n  if (from.extends) {\n    mergeOptions(to, from.extends)\n  }\n  if (from.mixins) {\n    for (const mixin of from.mixins) {\n      mergeOptions(to, mixin)\n    }\n  }\n  for (const key of ditoOptionKeys) {\n    if (key in from) {\n      to[key] = from[key]\n    }\n  }\n  return to\n}\n\nconst ditoOptionKeys = [\n  'defaultValue',\n  'defaultNested',\n  'defaultVisible',\n  'generateLabel',\n  'excludeValue',\n  'ignoreMissingValue',\n  'omitSpacing',\n  'processValue',\n  'processSchema',\n  'getPanelSchema',\n  'getFormSchemasForProcessing',\n  // Vue 3 / Vue-router 4 forgets these.\n  // TODO: Create bug-report?\n  'beforeRouteUpdate',\n  'beforeRouteLeave'\n]\n","import DitoMixin from './mixins/DitoMixin.js'\nimport { getTypeComponent } from './utils/schema.js'\nimport { resolveMergedOptions } from './utils/options.js'\nimport { isPlainObject } from '@ditojs/utils'\n\nconst components = {}\n\n// @vue/component\nexport default {\n  mixins: [DitoMixin],\n  // Make sure that registered components are present in all DitoComponent.\n  components,\n\n  component(name, definition) {\n    if (definition) {\n      if (isPlainObject(definition)) {\n        definition = resolveMergedOptions({\n          extends: this,\n          name,\n          ...definition\n        })\n      }\n      components[name] = definition\n    }\n    if (!(name in components)) {\n      throw new Error(`Component \"${name}\" not registered`)\n    }\n    return components[name]\n  },\n\n  methods: {\n    getTypeComponent\n  }\n}\n","import { markRaw, useSlots, Comment } from 'vue'\nimport { isString, asArray } from '@ditojs/utils'\n\nexport function hasVNodeContent(vnode) {\n  return vnode && asArray(vnode).some(vnode => vnode.type !== Comment)\n}\n\nexport function hasSlotContent(slot, props = {}) {\n  slot = isString(slot) ? useSlots()[slot] : slot\n  return hasVNodeContent(slot?.(props))\n}\n\nexport function raw(value) {\n  return markRaw({ value })\n}\n","<template lang=\"pug\">\nbutton.dito-button(\n  :type=\"type\"\n  :title=\"title\"\n  :disabled=\"disabled\"\n  :class=\"[classes, { 'dito-button--affixed': hasAffixes }]\"\n  v-bind=\"attributes\"\n)\n  .dito-button__prefix(\n    v-if=\"hasAffixes\"\n  )\n    slot(name=\"prefix\")\n  .dito-button__text(\n    v-if=\"text || hasAffixes\"\n  ) {{ text || '' }}\n    slot\n  .dito-button__suffix(\n    v-if=\"hasAffixes\"\n  )\n    slot(name=\"suffix\")\n</template>\n\n<script>\nimport { hasSlotContent } from '../utils/vue.js'\n\nexport default {\n  inheritAttrs: false,\n\n  props: {\n    type: { type: String, default: 'button' },\n    text: { type: String, default: null },\n    title: { type: String, default: null },\n    disabled: { type: Boolean, default: false }\n  },\n\n  computed: {\n    hasAffixes() {\n      return (\n        hasSlotContent(this.$slots.prefix) ||\n        hasSlotContent(this.$slots.suffix)\n      )\n    },\n\n    classes() {\n      return this.$attrs.class\n    },\n\n    attributes() {\n      const { class: _, ...attributes } = this.$attrs\n      return attributes\n    }\n  }\n}\n</script>\n","export function describeDate(date) {\n  return {\n    year: date?.getFullYear() ?? 0,\n    month: date?.getMonth() ?? 0,\n    day: date?.getDate() ?? 0,\n    hour: date?.getHours() ?? 0,\n    minute: date?.getMinutes() ?? 0,\n    second: date?.getSeconds() ?? 0,\n    millisecond: date?.getMilliseconds() ?? 0\n  }\n}\n\nexport function alterDate(date, overrides = {}) {\n  return new Date(...Object.values({ ...describeDate(date), ...overrides }))\n}\n\nexport function parseDate(string, {\n  locale = 'en-US',\n  date = true,\n  time = true\n} = {}) {\n  const timeDefault = time ? null : 0\n  let [\n    day,\n    sep1,\n    month,\n    sep2,\n    year,\n    ,\n    hour = timeDefault,\n    ,\n    minute = timeDefault,\n    ,\n    second = timeDefault,\n    ,\n    millisecond = timeDefault\n  ] = getDateParts(string, { date, time })\n  if (year && year.length >= 4) {\n    if (locale === 'en-US' && sep1 === '/' && sep2 === '/') {\n      // American format: MM/DD/YYYY\n      ;[day, month] = [month, day]\n    }\n    month = getMonthIndex(month, { locale })\n    const isValidTimePart = part => part === null || part.length === 2\n    if (\n      month !== null && (\n        !time || (\n          isValidTimePart(hour) &&\n          isValidTimePart(minute) &&\n          isValidTimePart(second)\n        )\n      )\n    ) {\n      return new Date(\n        +year,\n        +month,\n        +day,\n        +hour,\n        +minute,\n        +second,\n        +millisecond\n      )\n    }\n  }\n  return null\n}\n\nexport function getDatePartAtPosition(string, position, {\n  locale = 'en-US',\n  date = true,\n  time = true\n} = {}) {\n  const parts = getDateParts(string, { date, time })\n\n  const getPosition = (position, length = parts.length) => {\n    let pos = 0\n    let index = 0\n    while ((position === null || pos <= position) && index < length) {\n      pos += parts[index++]?.length ?? 0\n    }\n    return { position: pos, index }\n  }\n\n  // Time starts at index 6, due to the separator after the date.\n  const offset = !date ? getPosition(null, 6).position : 0\n  position += offset\n\n  let { index } = getPosition(position)\n\n  const isUS = locale === 'en-US'\n  const values = [\n    isUS ? 'month' : 'day',\n    null,\n    isUS ? 'day' : 'month',\n    null,\n    'year',\n    null,\n    'hour',\n    null,\n    'minute',\n    null,\n    'second',\n    null,\n    'millisecond'\n  ]\n  while (index--) {\n    if (values[index]) {\n      const start = getPosition(null, index).position - offset\n      const end = start + parts[index].length\n      return { name: values[index], start, end }\n    }\n  }\n  return null\n}\n\nfunction getDateParts(string, { date = true, time = true } = {}) {\n  const parts = string?.split(/([\\s.,:/]+)/) || []\n  if (!date) {\n    // Add dummy date parts to make sure we get a time-only date.\n    parts.unshift('1', '.', '1', '.', '2000', ' ')\n  }\n  if (!time && parts.length > 5) {\n    parts.length = 5\n  }\n  return parts\n}\n\nfunction getMonthIndex(month, { locale = 'en-US' } = {}) {\n  const value = +month\n  if (!isNaN(value)) {\n    return value - 1\n  }\n  const match = month.trim().toLowerCase()\n  if (match.length < 3) return null\n  const shortFormat = new Intl.DateTimeFormat(locale, { month: 'short' })\n  const longFormat = new Intl.DateTimeFormat(locale, { month: 'long' })\n  for (let i = 0; i < 12; i++) {\n    const date = new Date(2000, i, 1)\n    if (\n      shortFormat.format(date).toLowerCase().startsWith(match) ||\n      longFormat.format(date).toLowerCase().startsWith(match)\n    ) {\n      return i\n    }\n  }\n  return null\n}\n","<!-- Derived from ATUI, and further extended: https://aliqin.github.io/atui/ -->\n<template lang=\"pug\">\n.dito-calendar\n  .dito-calendar-popup\n    .dito-calendar-inner\n      template(\n        v-if=\"currentMode === 'day'\"\n      )\n        .dito-calendar-header\n          a.dito-calendar-step-prev.dito-calendar-step-year(\n            @click=\"stepYear(-1)\"\n          )\n          a.dito-calendar-step-prev.dito-calendar-step-month(\n            @click=\"stepMonth(-1)\"\n          )\n          span\n            a.dito-calendar-select-year(\n              @click=\"setMode('year')\"\n            ) {{ dateToString(currentValue, { year: true }) }}\n            a.dito-calendar-select-month(\n              @click=\"setMode('month')\"\n            ) {{ dateToString(currentValue, { month: true }) }}\n          a.dito-calendar-step-next.dito-calendar-step-month(\n            @click=\"stepMonth(1)\"\n          )\n          a.dito-calendar-step-next.dito-calendar-step-year(\n            @click=\"stepYear(1)\"\n          )\n        .dito-calendar-body\n          .dito-calendar-weekdays\n            span(\n              v-for=\"weekday in weekdayNames\"\n            ) {{ weekday.short }}\n          .dito-calendar-dates\n            span(\n              v-for=\"date in dateRange\"\n              :class=\"date.state && `dito-calendar-item-${date.state}`\"\n              @click=\"date.state !== 'disabled' && selectDate(date.date)\"\n            ) {{ date.text }}\n        .dito-calendar-footer\n          a.dito-calendar-select-now(\n            role=\"button\"\n            :title=\"dateToString(new Date())\"\n            @click=\"selectDate(new Date())\"\n          )\n      template(\n        v-else-if=\"currentMode === 'month'\"\n      )\n        .dito-calendar-header\n          a.dito-calendar-step-prev(\n            @click=\"stepYear(-1)\"\n          )\n          span\n            a.dito-calendar-select-year(\n              @click=\"setMode('year')\"\n            ) {{ dateToString(currentValue, { year: true }) }}\n          a.dito-calendar-step-next(\n            @click=\"stepYear(1)\"\n          )\n        .dito-calendar-body\n          .dito-calendar-months\n            span(\n              v-for=\"(month, index) in monthNames\"\n              :class=\"getMonthClass(index)\"\n              @click=\"selectMonth(index)\"\n            ) {{ month.short }}\n      template(\n        v-else-if=\"currentMode === 'year'\"\n      )\n        .dito-calendar-header\n          a.dito-calendar-step-prev(\n            @click=\"stepDecade(-1)\"\n          )\n          span {{ decadeToString(currentValue) }}\n          a.dito-calendar-step-next(\n            @click=\"stepDecade(1)\"\n          )\n        .dito-calendar-body\n          .dito-calendar-years\n            span(\n              v-for=\"year in yearRange\"\n              :class=\"getYearClass(year)\"\n              @click=\"selectYear(year)\"\n            ) {{ year }}\n</template>\n\n<script>\nimport { describeDate, alterDate } from '../utils/date.js'\n\nexport default {\n  emits: ['update:modelValue', 'select'],\n\n  props: {\n    modelValue: { type: Date, default: null },\n    locale: { type: String, default: 'en-US' },\n    disabledDate: { type: Function, default: () => false },\n    mode: { type: String, default: 'day' }\n  },\n\n  data() {\n    const { weekdayNames, monthNames } = getLocaleNames(this.locale)\n    return {\n      weekdayNames,\n      monthNames,\n      dateRange: [],\n      yearRange: [],\n      currentValue: (\n        this.modelValue ||\n        // If no value is provided, use current date but clear time fields:\n        alterDate(new Date(), { hour: 0, minute: 0, second: 0, millisecond: 0 })\n      ),\n      currentMode: this.mode\n    }\n  },\n\n  watch: {\n    modelValue(to, from) {\n      if (+to !== +from) {\n        this.currentValue = to || new Date()\n        this.updateDateRange()\n      }\n    },\n\n    currentValue(to, from) {\n      if (+to !== +from) {\n        this.updateDateRange()\n      }\n    },\n\n    disabledDate: 'updateDateRange',\n\n    mode(mode) {\n      this.currentMode = mode\n    }\n  },\n\n  mounted() {\n    this.updateDateRange()\n  },\n\n  methods: {\n    getMonthClass(month) {\n      return {\n        'dito-calendar-item-active': (\n          this.modelValue &&\n          month === this.modelValue.getMonth() &&\n          this.currentValue.getFullYear() === this.modelValue.getFullYear()\n        ),\n        'dito-calendar-item-current': month === this.currentValue.getMonth()\n      }\n    },\n\n    getYearClass(year) {\n      return {\n        'dito-calendar-item-active': (\n          this.modelValue && year === this.modelValue.getFullYear()\n        ),\n        'dito-calendar-item-current': year === this.currentValue.getFullYear()\n      }\n    },\n\n    setDate(overrides, update = false) {\n      this.currentValue = alterDate(this.currentValue, overrides)\n      if (update) {\n        this.$emit('update:modelValue', this.currentValue)\n      }\n    },\n\n    stepDecade(step) {\n      this.setDate({\n        year: this.currentValue.getFullYear() + step * 10\n      })\n    },\n\n    setMode(mode) {\n      this.currentMode = mode\n    },\n\n    stepMonth(step) {\n      const { currentValue } = this\n      const { year, month } = this.getYearMonth(\n        currentValue.getFullYear(),\n        currentValue.getMonth() + step\n      )\n      this.setDate({\n        month,\n        day: Math.min(\n          this.getDaysInMonth(year, month),\n          this.currentValue.getDate()\n        )\n      })\n    },\n\n    stepYear(step) {\n      this.setDate({\n        year: this.currentValue.getFullYear() + step\n      })\n    },\n\n    selectDate(date) {\n      this.setDate(describeDate(date), true)\n      this.$emit('select')\n    },\n\n    selectMonth(month) {\n      this.setMode('day')\n      // Set day to 1 to avoid selecting a date that is not available in the\n      // new month, e.g. Feb 31 -> Mar 3.\n      this.setDate({ month, day: 1 }, true)\n    },\n\n    selectYear(year) {\n      this.setMode('month')\n      this.setDate({ year }, true)\n    },\n\n    getYearMonth(year, month) {\n      if (month > 11) {\n        year++\n        month = 0\n      } else if (month < 0) {\n        year--\n        month = 11\n      }\n      return { year, month }\n    },\n\n    dateToString(\n      date,\n      { year, month, day } = { year: true, month: true, day: true }\n    ) {\n      return date.toLocaleString(this.locale, {\n        year: year && 'numeric',\n        month: month && 'long',\n        day: day && 'numeric'\n      })\n    },\n\n    decadeToString(date) {\n      const year = this.getFirstYearOfDecade(date.getFullYear())\n      return `${year} – ${year + 9}`\n    },\n\n    getDaysInMonth(year, month) {\n      return new Date(year, month + 1, 0).getDate()\n    },\n\n    getFirstYearOfDecade(year) {\n      const yearStr = year.toString()\n      return +`${yearStr.slice(0, -1)}0`\n    },\n\n    navigate({ step, enter, mode = this.currentMode, update = false }) {\n      const { currentValue } = this\n      if (step) {\n        switch (mode) {\n          case 'day':\n            this.setDate({ day: currentValue.getDate() + step }, update)\n            break\n          case 'month':\n            this.setDate({ month: currentValue.getMonth() + step }, update)\n            break\n          case 'year':\n            this.setDate({ year: currentValue.getFullYear() + step }, update)\n            break\n        }\n        return true\n      } else if (enter) {\n        switch (this.currentMode) {\n          case 'day':\n            this.selectDate(currentValue)\n            break\n          case 'month':\n            this.setMode('day')\n            break\n          case 'year':\n            this.setMode('month')\n            break\n        }\n        return true\n      }\n    },\n\n    updateDateRange() {\n      this.dateRange = []\n      this.yearRange = []\n\n      const { currentValue } = this\n      const year = currentValue.getFullYear()\n      const month = currentValue.getMonth()\n      const startYear = this.getFirstYearOfDecade(year)\n      for (let i = 0; i < 10; i++) {\n        this.yearRange.push(startYear + i)\n      }\n      const currMonthFirstDay = new Date(year, month, 1)\n      let firstDayWeek = currMonthFirstDay.getDay() + 1\n      if (firstDayWeek === 0) {\n        firstDayWeek = 7\n      }\n      const numDays = this.getDaysInMonth(year, month)\n      if (firstDayWeek > 1) {\n        const prevMonth = this.getYearMonth(year, month - 1)\n        const prevMonthNumDays = this.getDaysInMonth(\n          prevMonth.year,\n          prevMonth.month\n        )\n        for (let i = 1; i < firstDayWeek; i++) {\n          const day = prevMonthNumDays - firstDayWeek + i + 1\n          const date = new Date(prevMonth.year, prevMonth.month, day)\n          this.dateRange.push({\n            text: day,\n            date,\n            state: this.disabledDate(date) ? 'disabled' : 'gray'\n          })\n        }\n      }\n\n      const now = new Date()\n      for (let i = 1; i <= numDays; i++) {\n        const date = new Date(year, month, i)\n        const isDay = date => (\n          date &&\n          date.getDate() === i &&\n          date.getFullYear() === year &&\n          date.getMonth() === month\n        )\n        const state = isDay(this.modelValue)\n          ? 'active'\n          : isDay(now)\n            ? 'today'\n            : this.disabledDate(date)\n              ? 'disabled'\n              : isDay(currentValue)\n                ? 'current'\n                : null\n        this.dateRange.push({\n          text: i,\n          date,\n          state\n        })\n      }\n\n      const nextMonthNeed = 42 - this.dateRange.length\n      if (nextMonthNeed > 0) {\n        const nextMonth = this.getYearMonth(year, month + 1)\n        for (let i = 1; i <= nextMonthNeed; i++) {\n          const date = new Date(nextMonth.year, nextMonth.month, i)\n          const state = this.disabledDate(date) ? 'disabled' : 'gray'\n          this.dateRange.push({\n            text: i,\n            date,\n            state\n          })\n        }\n      }\n    }\n  }\n}\n\nconst localeNames = {}\n\n// Calling `toLocaleString()` this much appears to be expensive, so cache it:\nfunction getLocaleNames(locale) {\n  let names = localeNames[locale]\n  if (!names) {\n    const weekdayNames = []\n    for (let i = 0; i < 7; i++) {\n      const date = new Date(0, 0, i)\n      weekdayNames.push({\n        long: date.toLocaleString(locale, { weekday: 'long' }),\n        short: date.toLocaleString(locale, { weekday: 'short' })\n      })\n    }\n    const monthNames = []\n    for (let i = 1; i <= 12; i++) {\n      const date = new Date(0, i, 0)\n      monthNames.push({\n        long: date.toLocaleString(locale, { month: 'long' }),\n        short: date.toLocaleString(locale, { month: 'short' })\n      })\n    }\n    names = localeNames[locale] = {\n      weekdayNames,\n      monthNames\n    }\n  }\n  return names\n}\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-calendar {\n  min-width: 240px;\n  box-sizing: border-box;\n}\n\n.dito-calendar-popup {\n  border: $border-style;\n  border-radius: $border-radius;\n  background: $color-white;\n  box-shadow: $shadow-window;\n  z-index: $z-index-popup;\n}\n\n.dito-calendar-body {\n  padding: 0 0.5em;\n\n  span {\n    display: inline-block;\n    width: calc(100% / 7);\n    height: $input-height;\n    line-height: calc($input-height - 2 * $border-width);\n    box-sizing: border-box;\n    border-radius: $border-radius;\n    border: $border-width solid transparent;\n    text-align: center;\n  }\n\n  .dito-calendar-item-today {\n    border: $border-width solid $color-active;\n    color: $color-active;\n  }\n\n  .dito-calendar-item-active {\n    &,\n    &:hover {\n      background: $color-active;\n      color: white;\n    }\n  }\n\n  .dito-calendar-item-disabled {\n    background: white;\n    cursor: default;\n  }\n\n  .dito-calendar-item-disabled,\n  .dito-calendar-item-gray {\n    color: #999999;\n  }\n}\n\n.dito-calendar-months,\n.dito-calendar-years {\n  span {\n    width: calc(100% / 4);\n    margin: 0.5em 0;\n  }\n}\n\n.dito-calendar-years span {\n  width: calc(100% / 5);\n}\n\n.dito-calendar a,\n.dito-calendar-dates span,\n.dito-calendar-months span,\n.dito-calendar-years span {\n  @include user-select(none);\n\n  white-space: nowrap;\n  cursor: pointer;\n}\n\n.dito-calendar-header span {\n  cursor: default;\n\n  a {\n    padding: 0 0.2em;\n  }\n}\n\n.dito-calendar-dates span:hover,\n.dito-calendar-months span:hover,\n.dito-calendar-years span:hover,\n.dito-calendar:not(:hover) .dito-calendar-item-current {\n  background: $color-highlight;\n}\n\n.dito-calendar-weekdays span {\n  font-weight: bold;\n  @include user-select(none);\n}\n\n.dito-calendar-header,\n.dito-calendar-footer {\n  position: relative;\n  text-align: center;\n  height: $input-height;\n  line-height: $input-height;\n}\n\n.dito-calendar-footer {\n  border-top: $border-style;\n}\n\n.dito-calendar-header {\n  font-weight: bold;\n  border-bottom: $border-style;\n  display: flex;\n\n  > span {\n    margin: auto;\n    padding: 0 0.5em;\n  }\n\n  a {\n    font-weight: bold;\n\n    &:hover {\n      color: $color-active;\n    }\n  }\n}\n\n.dito-calendar-step-prev,\n.dito-calendar-step-next {\n  position: relative;\n  width: 5%;\n  min-width: 2em;\n  max-width: 3em;\n\n  &::after {\n    position: absolute;\n    left: 0;\n    right: 0;\n    font-size: 1.25em;\n  }\n}\n\n.dito-calendar-step-prev {\n  &::after {\n    content: '‹';\n  }\n\n  &.dito-calendar-step-year::after {\n    content: '«';\n  }\n}\n\n.dito-calendar-step-next {\n  &::after {\n    content: '›';\n  }\n\n  &.dito-calendar-step-year::after {\n    content: '»';\n  }\n}\n\n.dito-calendar-select-now {\n  &::after {\n    content: 'Now';\n  }\n}\n</style>\n","import { asArray } from '@ditojs/utils'\n\nexport function addEvents(targets, events) {\n  targets =\n    targets instanceof NodeList\n      ? Array.from(targets)\n      : asArray(targets)\n\n  for (const [type, handler] of Object.entries(events)) {\n    for (const target of targets) {\n      target.addEventListener(type, handler, false)\n    }\n  }\n\n  return {\n    remove() {\n      for (const [type, handler] of Object.entries(events)) {\n        for (const target of targets) {\n          target.removeEventListener(type, handler, false)\n        }\n      }\n    }\n  }\n}\n\nexport function combineEvents(...events) {\n  return {\n    remove() {\n      for (const event of events) {\n        event.remove()\n      }\n    }\n  }\n}\n\nexport function getKey(event) {\n  return {\n    37: 'left',\n    38: 'up',\n    39: 'right',\n    40: 'down',\n    13: 'enter'\n  }[event?.keyCode]\n}\n\nexport function getKeyNavigation(event) {\n  const key = getKey(event)\n  return {\n    hor: { left: -1, right: 1 }[key] || 0,\n    ver: { up: -1, down: 1 }[key] || 0,\n    enter: key === 'enter'\n  }\n}\n","import { isString } from '@ditojs/utils'\n\nexport function getTarget(component) {\n  const target = isString(component.target)\n    ? component.$refs[component.target]\n    : component.target\n  return target?.$el ?? target\n}\n","<!-- Derived from ATUI, and further extended: https://aliqin.github.io/atui/ -->\n<template lang=\"pug\">\n.dito-trigger-container\n  .dito-trigger(\n    v-if=\"alwaysShow\"\n    ref=\"trigger\"\n    :class=\"triggerClass\"\n  )\n    slot(name=\"trigger\")\n  .dito-trigger(\n    v-else-if=\"trigger === 'click'\"\n    ref=\"trigger\"\n    :class=\"triggerClass\"\n    @click=\"onClick\"\n  )\n    slot(name=\"trigger\")\n  .dito-trigger(\n    v-else-if=\"trigger === 'hover'\"\n    ref=\"trigger\"\n    :class=\"triggerClass\"\n    @mouseenter=\"onHover(true)\"\n    @mouseleave=\"onHover(false)\"\n  )\n    slot(name=\"trigger\")\n  .dito-trigger(\n    v-else-if=\"trigger === 'focus' || trigger === 'always'\"\n    ref=\"trigger\"\n    :class=\"triggerClass\"\n  )\n    slot(name=\"trigger\")\n  Transition(:name=\"`dito-${transition}`\")\n    .dito-popup(\n      v-if=\"trigger === 'hover'\"\n      v-show=\"showPopup\"\n      ref=\"popup\"\n      :class=\"popupClass\"\n      :style=\"popupStyle\"\n      @mouseenter=\"onHover(true)\"\n      @mouseleave=\"onHover(false)\"\n    )\n      slot(\n        v-if=\"showPopup\"\n        name=\"popup\"\n      )\n    .dito-popup(\n      v-else\n      v-show=\"showPopup\"\n      ref=\"popup\"\n      :class=\"popupClass\"\n      :style=\"popupStyle\"\n    )\n      slot(\n        v-if=\"showPopup\"\n        name=\"popup\"\n      )\n</template>\n\n<script>\nimport { hyphenate } from '@ditojs/utils'\nimport { addEvents, combineEvents } from '../utils/event.js'\nimport { getTarget } from '../utils/trigger'\n\nexport default {\n  emits: ['update:show'],\n\n  props: {\n    trigger: { type: String, default: 'click' },\n    transition: { type: String, default: 'slide' },\n    placement: { type: String, default: 'bottom' },\n    show: { type: Boolean, default: false },\n    disabled: { type: Boolean, default: false },\n    target: { type: [String, HTMLElement], default: null },\n    customClass: { type: String, default: null },\n    zIndex: { type: Number, default: 0 },\n    keepInView: { type: Boolean, default: true },\n    hideWhenClickOutside: { type: Boolean, default: true },\n    alwaysShow: { type: Boolean, default: false },\n    cover: { type: Boolean, default: false },\n    hideDelay: { type: Number, default: 0 }\n  },\n\n  data() {\n    return {\n      showPopup: this.show,\n      popupPlacement: this.placement,\n      focusEvents: null,\n      closeEvents: null,\n      popupEvents: null,\n      blurTimer: null,\n      mouseLeaveTimer: null\n    }\n  },\n\n  computed: {\n    triggerClass() {\n      return {\n        'dito-trigger-disabled': this.disabled\n      }\n    },\n\n    popupClass() {\n      const classes = {\n        [`dito-popup-${hyphenate(this.placement)}`]: true\n      }\n      if (this.customClass) {\n        classes[this.customClass] = true\n      }\n      return classes\n    },\n\n    popupStyle() {\n      return this.zIndex ? `z-index: ${this.zIndex}` : ''\n    },\n\n    triggerTarget() {\n      return getTarget(this)\n    }\n  },\n\n  watch: {\n    show(show) {\n      this.showPopup = show || this.alwaysShow\n    },\n\n    showPopup(to, from) {\n      if (to ^ from) {\n        this.$emit('update:show', to)\n        this.$nextTick(() => this.onShowPopup(to))\n      }\n    }\n  },\n\n  mounted() {\n    const { trigger, popup } = this.$refs\n    if (this.trigger === 'focus') {\n      this.focusEvents = this.addFocusEvents(this.triggerTarget ?? trigger)\n    }\n\n    if (this.hideWhenClickOutside && !this.alwaysShow) {\n      // Use 'mouseup' instead of 'click', since click appears to happen after\n      // the DOM inside of popups could change in a way so that the check\n      // `popup.contains(event.target)` would fail:\n      this.closeEvents = addEvents(window, {\n        mouseup: event => {\n          if (\n            this.showPopup &&\n            !popup.contains(event.target) &&\n            !trigger.contains(event.target) &&\n            !this.triggerTarget?.contains(event.target)\n          ) {\n            this.showPopup = false\n          }\n        },\n\n        blur: () => {\n          this.showPopup = false\n        }\n      })\n    }\n\n    if (this.alwaysShow) {\n      this.showPopup = true\n    }\n  },\n\n  created() {\n    this.showPopup = this.show\n  },\n\n  unmounted() {\n    this.focusEvents?.remove()\n    this.closeEvents?.remove()\n    this.popupEvents?.remove()\n  },\n\n  methods: {\n    updatePosition() {\n      const { trigger, popup } = this.$refs\n      if (this.show && popup.offsetWidth === 0) {\n        setTimeout(() => this.updatePosition(), 0)\n        return\n      }\n\n      const target = this.triggerTarget ?? trigger\n      // Actually resize the popup's first child, so they can set size limits.\n      const el = this.target === 'popup' ? trigger : popup.firstElementChild\n      if (el) {\n        el.style.width = getComputedStyle(target).width\n      }\n\n      const bounds = target.getBoundingClientRect()\n      const triggerLeft = bounds.left + window.scrollX\n      const triggerTop = bounds.top + window.scrollY\n      const triggerWidth = bounds.width\n      const triggerHeight = bounds.height\n      const popupWidth = popup.offsetWidth\n      const popupHeight = popup.offsetHeight\n\n      let [part1, part2] = this.popupPlacement.split('-') || []\n      if (this.keepInView) {\n        const winWidth = window.innerWidth\n        const winHeight = window.innerHeight\n        if (part1 === 'top') {\n          if (triggerTop < popupHeight) {\n            part1 = 'bottom'\n          }\n        } else if (part1 === 'bottom') {\n          if (winHeight - triggerTop - triggerHeight < popupHeight) {\n            part1 = 'top'\n          }\n        } else if (part1 === 'left') {\n          if (triggerLeft < popupWidth) {\n            part1 = 'right'\n          }\n        } else if (part1 === 'right') {\n          if (winWidth - triggerLeft - triggerWidth < popupWidth) {\n            part1 = 'left'\n          }\n        }\n\n        if (part2 === 'top') {\n          if (winHeight - triggerTop < popupHeight) {\n            part2 = 'bottom'\n          }\n        } else if (part2 === 'bottom') {\n          if (triggerTop + triggerHeight < popupHeight) {\n            part2 = 'top'\n          }\n        } else if (part2 === 'left') {\n          if (winWidth - triggerLeft < popupWidth) {\n            part2 = 'right'\n          }\n        } else if (part2 === 'right') {\n          if (triggerLeft + triggerWidth < popupWidth) {\n            part2 = 'left'\n          }\n        }\n      }\n\n      let left = 0\n      let top = 0\n      switch (part1) {\n        case 'top':\n          top -= popupHeight\n          break\n        case 'left':\n          left -= popupWidth\n          break\n        case 'right':\n          left += triggerWidth\n          break\n        case 'bottom':\n          top += triggerHeight\n          break\n      }\n      switch (part2) {\n        case 'right':\n          left -= popupWidth - triggerWidth\n          break\n        case 'bottom':\n          top -= popupHeight - triggerHeight\n          break\n      }\n      if (this.cover) {\n        if (part1 === 'top') {\n          top += triggerHeight\n        } else if (part1 === 'bottom') {\n          top -= triggerHeight\n        }\n      }\n      if (target !== trigger) {\n        const triggerBounds = trigger.getBoundingClientRect()\n        left += triggerLeft - triggerBounds.left\n        top += triggerTop - triggerBounds.top\n      }\n      popup.style.left = `${left}px`\n      popup.style.top = `${top}px`\n    },\n\n    addFocusEvents(parent) {\n      const targets = parent.querySelectorAll('input, textarea')\n      let input\n\n      return combineEvents(\n        addEvents(targets, {\n          focus: () => {\n            this.showPopup = true\n            clearTimeout(this.blurTimer)\n          },\n\n          blur: () => {\n            // Use timeout to allow clicked inputs to grab focus\n            this.blurTimer = setTimeout(() => {\n              if (!this.$refs.popup.matches(':focus-within')) {\n                this.showPopup = false\n              }\n            }, 0)\n          }\n        }),\n\n        addEvents(parent, {\n          mousedown: event => {\n            if (!event.target.matches('input, textarea, button')) {\n              event.preventDefault()\n              event.stopPropagation()\n            }\n            if (!event.target.matches('.dito-button-clear')) {\n              const trigger = this.triggerTarget ?? this.$refs.trigger\n              // Mark trigger input as readonly so it can't loose focus while\n              // user does other mouse-activities in popup.\n              input = trigger.querySelector('input, textarea')\n              if (input && !input.hasAttribute('readonly')) {\n                input.setAttribute('readonly', 'true')\n              } else {\n                input = null\n              }\n            }\n          },\n\n          mouseup: event => {\n            if (input) {\n              // Give some time for other events to update input before it\n              // becomes editable and still focused again.\n              setTimeout(() => {\n                input.removeAttribute('readonly')\n                if (!event.target.matches('input, textarea, button')) {\n                  input.focus()\n                }\n                input = null\n              }, 0)\n            }\n          }\n        })\n      )\n    },\n\n    onShowPopup(show) {\n      if (show) {\n        if (this.trigger === 'focus') {\n          this.popupEvents = this.addFocusEvents(this.$refs.popup)\n        }\n        this.updatePosition()\n      } else {\n        this.popupEvents?.remove()\n        this.popupEvents = null\n      }\n    },\n\n    onClick() {\n      if (!this.disabled) {\n        this.showPopup = true\n      }\n    },\n\n    onHover(enter) {\n      if (!this.disabled) {\n        clearTimeout(this.mouseLeaveTimer)\n        if (enter) {\n          this.showPopup = true\n        } else {\n          if (this.hideDelay) {\n            this.mouseLeaveTimer = setTimeout(() => {\n              this.showPopup = false\n            }, this.hideDelay)\n          } else {\n            this.showPopup = false\n          }\n        }\n      }\n    }\n  }\n}\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n@import '../styles/transitions';\n\n.dito-trigger-container {\n  position: relative;\n}\n\n.dito-trigger-disabled {\n  color: $color-disabled;\n  border-color: $border-color;\n  cursor: default;\n\n  * {\n    cursor: default !important;\n    @include user-select(none);\n\n    &:focus {\n      box-shadow: none;\n    }\n  }\n}\n\n.dito-popup {\n  position: absolute;\n  top: 0;\n  left: 0;\n  z-index: $z-index-popup;\n}\n</style>\n","<template lang=\"pug\">\n.dito-input(\n  :class=\"classes\"\n  @mousedown=\"onMouseDown\"\n)\n  slot(name=\"prefix\")\n  input(\n    :id=\"id\"\n    ref=\"input\"\n    v-model=\"currentValue\"\n    :type=\"type\"\n    :name=\"name\"\n    :title=\"title\"\n    :disabled=\"disabled\"\n    :readonly=\"readonly\"\n    :autofocus=\"autofocus\"\n    :placeholder=\"placeholder\"\n    :autocomplete=\"autocomplete\"\n    :aria-label=\"title\"\n    v-bind=\"attributes\"\n    @mousedown=\"onMouseDown\"\n  )\n  slot(name=\"suffix\")\n</template>\n\n<script>\nexport default {\n  emits: ['update:modelValue'],\n  inheritAttrs: false,\n\n  props: {\n    modelValue: { type: [String, Number], default: null },\n    type: { type: String, default: 'text' },\n    id: { type: String, default: null },\n    name: { type: String, default: null },\n    title: { type: String, default: null },\n    disabled: { type: Boolean, default: false },\n    readonly: { type: Boolean, default: false },\n    autofocus: { type: Boolean, default: false },\n    focused: { type: Boolean, default: false },\n    placeholder: { type: String, default: null },\n    autocomplete: { type: String, default: 'off' }\n  },\n\n  data() {\n    return {\n      currentValue: this.modelValue\n    }\n  },\n\n  computed: {\n    classes() {\n      return [\n        this.$attrs.class,\n        {\n          'dito-input--focus': this.focused\n        }\n      ]\n    },\n\n    attributes() {\n      const { class: _, ...attributes } = this.$attrs\n      return attributes\n    },\n\n    input() {\n      return this.$refs.input\n    },\n\n    size() {\n      // Determine size based on min & max settings, if they're provided.\n      const { size, min, max } = this.$attrs\n      const getLength = value => (value != null ? `${value}`.length : 0)\n      return size || getLength(min) || getLength(max) || undefined\n    }\n  },\n\n  watch: {\n    modelValue(to, from) {\n      if (to !== from) {\n        this.currentValue = to\n      }\n    },\n\n    currentValue(currentValue) {\n      if (currentValue !== this.modelValue) {\n        this.$emit('update:modelValue', currentValue)\n      }\n    }\n  },\n\n  methods: {\n    focus() {\n      this.input.focus()\n    },\n\n    blur() {\n      this.input.blur()\n    },\n\n    onMouseDown(event) {\n      if (event.target === this.input) {\n        // When directly clicking the input, do not propagate the event and\n        // avoid `preventDefault()` below, to keep supporting selection.\n        event.stopPropagation()\n      } else {\n        // When clicking outside the input, e.g. on affixes, bring the focus\n        // back to the input.\n        if (!this.disabled && !this.readonly) {\n          this.focus()\n          event.preventDefault()\n        }\n      }\n    }\n  }\n}\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-input {\n  display: inline-flex;\n  align-items: center;\n\n  @extend %input;\n\n  input {\n    // Inherit all styling from .dito-input\n    all: inherit;\n    flex: 1;\n    min-width: 0;\n    display: inline-block;\n    border: 0;\n    margin: 0;\n    padding: 0;\n  }\n}\n</style>\n","<template lang=\"pug\">\ni.dito-icon(:class=\"classes\")\n</template>\n\n<script>\nexport default {\n  props: {\n    name: {\n      type: String,\n      required: true\n    },\n    disabled: {\n      type: Boolean,\n      default: false\n    }\n  },\n\n  computed: {\n    classes() {\n      const prefix = 'dito-icon'\n      return {\n        [`${prefix}--${this.name}`]: true,\n        [`${prefix}--disabled`]: this.disabled\n      }\n    }\n  }\n}\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n// `yarn build:icons` converts the icon SVG files to silent classes inside\n// `src/styles/mixins/_icons.scss`, making them available to all other sass\n// code through `_imports`.\n// In order to be able to use them as normal CSS classes, convert them here:\n@each $name in $icons {\n  .dito-icon--#{$name} {\n    &::after {\n      @extend %icon-#{$name};\n\n      position: absolute;\n    }\n  }\n}\n\n.dito-icon {\n  position: relative;\n  width: 1em;\n  height: 1em;\n\n  @at-root .dito-input & {\n    font-style: normal;\n    border-radius: $border-radius;\n    color: $color-grey;\n    background: $color-white;\n\n    &.dito-icon--disabled {\n      color: $color-light;\n    }\n  }\n\n  @at-root .dito-input:focus-within & {\n    color: $color-active;\n  }\n}\n</style>\n","export function setSelection(input, { start, end }) {\n  if (input?.setSelectionRange) {\n    input.focus()\n    input.setSelectionRange(start, end)\n  }\n}\n\nexport function getSelection(input) {\n  return input && 'selectionStart' in input\n    ? { start: input.selectionStart, end: input.selectionEnd }\n    : null\n}\n","<!-- Derived from ATUI, and further extended: https://aliqin.github.io/atui/ -->\n<template lang=\"pug\">\nDitoTrigger.dito-date-picker(\n  ref=\"trigger\"\n  v-model:show=\"showPopup\"\n  trigger=\"focus\"\n  v-bind=\"{ transition, placement, disabled, target }\"\n)\n  template(#trigger)\n    slot(\n      v-if=\"$slots.trigger\"\n      name=\"trigger\"\n    )\n    DitoInput.dito-date-picker-input(\n      v-else\n      ref=\"input\"\n      v-model=\"currentText\"\n      type=\"text\"\n      v-bind=\"{ placeholder, disabled, focused, ...$attrs }\"\n      @focus=\"onFocus(true)\"\n      @blur=\"onFocus(false)\"\n      @keydown=\"onKeyDown\"\n      @mousedown.stop=\"onMouseDown(false)\"\n    )\n      template(#prefix)\n        slot(name=\"prefix\")\n      template(#suffix)\n        DitoIcon(\n          name=\"calendar\"\n          :disabled=\"disabled\"\n          @mousedown.prevent=\"onMouseDown(true)\"\n        )\n        slot(name=\"suffix\")\n  template(#popup)\n    DitoCalendar.dito-date-picker-popup(\n      ref=\"calendar\"\n      v-model=\"currentValue\"\n      v-bind=\"{ locale, disabledDate }\"\n      @select=\"showPopup = false\"\n    )\n</template>\n\n<script>\nimport { format, defaultFormats } from '@ditojs/utils'\nimport DitoTrigger from './DitoTrigger.vue'\nimport DitoCalendar from './DitoCalendar.vue'\nimport DitoInput from './DitoInput.vue'\nimport DitoIcon from './DitoIcon.vue'\nimport { parseDate, getDatePartAtPosition } from '../utils/date.js'\nimport { getSelection, setSelection } from '../utils/selection.js'\nimport { getKeyNavigation } from '../utils/event.js'\nimport { getTarget } from '../utils/trigger.js'\n\nexport default {\n  components: { DitoTrigger, DitoCalendar, DitoInput, DitoIcon },\n  emits: ['update:modelValue', 'update:show', 'change', 'focus', 'blur'],\n  inheritAttrs: false,\n\n  props: {\n    modelValue: { type: Date, default: null },\n    transition: { type: String, default: 'slide' },\n    placement: { type: String, default: 'bottom-left' },\n    placeholder: { type: String, default: null },\n    show: { type: Boolean, default: false },\n    disabled: { type: Boolean, default: false },\n    target: { type: [String, HTMLElement], default: 'trigger' },\n    locale: { type: String, default: 'en-US' },\n    format: {\n      type: Object,\n      default: () => ({\n        date: defaultFormats.date,\n        time: false\n      })\n    },\n    disabledDate: { type: Function, default: () => false }\n  },\n\n  data() {\n    return {\n      currentValue: this.modelValue,\n      showPopup: this.show,\n      inputFocused: false\n    }\n  },\n\n  computed: {\n    focused() {\n      return this.inputFocused || this.showPopup\n    },\n\n    input() {\n      return getTarget(this)?.querySelector('input')\n    },\n\n    formatOptions() {\n      return {\n        locale: this.locale,\n        ...this.format\n      }\n    },\n\n    currentText: {\n      get() {\n        return format(this.currentValue, this.formatOptions) || ''\n      },\n\n      set(value) {\n        const date = parseDate(value, this.formatOptions)\n        if (date) {\n          this.currentValue = date\n        }\n      }\n    }\n  },\n\n  watch: {\n    modelValue(to, from) {\n      if (+to !== +from) {\n        this.currentValue = to\n      }\n    },\n\n    currentValue(value) {\n      if (+value !== +this.modelValue) {\n        this.$emit('update:modelValue', value)\n        this.$emit('change', value)\n      }\n    },\n\n    show(show) {\n      this.showPopup = show\n    },\n\n    showPopup(to, from) {\n      if (to ^ from) {\n        this.$emit('update:show', to)\n      }\n    },\n\n    focused(to, from) {\n      if (to ^ from) {\n        this.$emit(to ? 'focus' : 'blur')\n      }\n    }\n  },\n\n  methods: {\n    onFocus(focus) {\n      this.inputFocused = focus\n      this.showPopup = focus\n    },\n\n    onKeyDown(event) {\n      const { ver: step, enter } = getKeyNavigation(event)\n      if (step || enter) {\n        event.preventDefault()\n\n        const position = getSelection(this.input)?.start\n        const getDatePart = position =>\n          getDatePartAtPosition(this.currentText, position, this.formatOptions)\n\n        if (step && !this.showPopup) {\n          this.showPopup = true\n        } else {\n          const { calendar } = this.$refs\n          if (calendar) {\n            const { name: mode, start } = getDatePart(position) || {}\n            if (\n              mode &&\n              calendar.navigate({ step, enter, mode, update: true })\n            ) {\n              this.$nextTick(() => setSelection(this.input, getDatePart(start)))\n            }\n          }\n        }\n      }\n    },\n\n    onMouseDown(toggle) {\n      this.showPopup = !this.disabled && (!toggle || !this.showPopup)\n      if (this.showPopup) {\n        this.focus()\n      }\n    },\n\n    focus() {\n      this.input.focus()\n    },\n\n    blur() {\n      this.input.blur()\n    }\n  }\n}\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-date-picker {\n  .dito-input {\n    font-variant-numeric: tabular-nums;\n    width: 100%;\n    min-width: 8em;\n  }\n}\n\n.dito-date-picker-popup {\n  margin: $popup-margin;\n}\n</style>\n","<!-- Derived from ATUI, and further extended: https://aliqin.github.io/atui/ -->\n<template lang=\"pug\">\nDitoTrigger.dito-time-picker(\n  ref=\"trigger\"\n  v-model:show=\"showPopup\"\n  trigger=\"focus\"\n  v-bind=\"{ transition, placement, disabled, target }\"\n)\n  template(#trigger)\n    slot(\n      v-if=\"$slots.trigger\"\n      name=\"trigger\"\n    )\n    DitoInput.dito-time-picker-input(\n      v-else\n      ref=\"input\"\n      v-model=\"currentText\"\n      type=\"text\"\n      v-bind=\"{ placeholder, disabled, focused, ...$attrs }\"\n      @focus=\"onFocus(true)\"\n      @blur=\"onFocus(false)\"\n      @keydown=\"onKeyDown\"\n      @mousedown.stop=\"onMouseDown(false)\"\n    )\n      template(#prefix)\n        slot(name=\"prefix\")\n      template(#suffix)\n        DitoIcon(\n          name=\"clock\"\n          :disabled=\"disabled\"\n          @mousedown.prevent=\"onMouseDown(true)\"\n        )\n        slot(name=\"suffix\")\n  template(#popup)\n    .dito-time-picker-popup\n      .dito-time-picker-panel\n        ul.dito-time-picker-hour(ref=\"hour\")\n          template(\n            v-for=\"index in 24\"\n          )\n            li(\n              v-if=\"!disabledHour(index - 1)\"\n              :class=\"{ selected: hour === index - 1 }\"\n              @click=\"hour = index - 1\"\n            ) {{ leftPad(index - 1) }}\n      .dito-time-picker-panel\n        ul.dito-time-picker-minute(ref=\"minute\")\n          template(\n            v-for=\"index in 60\"\n          )\n            li(\n              v-if=\"!disabledMinute(index - 1)\"\n              :class=\"{ selected: minute === index - 1 }\"\n              @click=\"minute = index - 1\"\n            ) {{ leftPad(index - 1) }}\n      .dito-time-picker-panel\n        ul.dito-time-picker-second(ref=\"second\")\n          template(\n            v-for=\"index in 60\"\n          )\n            li(\n              v-if=\"!disabledSecond(index - 1)\"\n              :class=\"{ selected: second === index - 1 }\"\n              @click=\"second = index - 1\"\n            ) {{ leftPad(index - 1) }}\n</template>\n\n<script>\nimport { format, defaultFormats } from '@ditojs/utils'\nimport DitoTrigger from './DitoTrigger.vue'\nimport DitoInput from './DitoInput.vue'\nimport DitoIcon from './DitoIcon.vue'\nimport { alterDate, parseDate, getDatePartAtPosition } from '../utils/date.js'\nimport { getSelection, setSelection } from '../utils/selection.js'\nimport { getKeyNavigation } from '../utils/event.js'\nimport { getTarget } from '../utils/trigger.js'\n\nexport default {\n  components: { DitoTrigger, DitoInput, DitoIcon },\n  emits: ['update:modelValue', 'update:show', 'change', 'focus', 'blur'],\n  inheritAttrs: false,\n\n  props: {\n    modelValue: { type: Date, default: null },\n    transition: { type: String, default: 'slide' },\n    placement: { type: String, default: 'bottom-left' },\n    placeholder: { type: String, default: null },\n    show: { type: Boolean, default: false },\n    disabled: { type: Boolean, default: false },\n    target: { type: [String, HTMLElement], default: 'trigger' },\n    locale: { type: String, default: 'en-US' },\n    format: {\n      type: Object,\n      default: () => ({\n        time: defaultFormats.time,\n        date: false\n      })\n    },\n    disabledHour: { type: Function, default: () => false },\n    disabledMinute: { type: Function, default: () => false },\n    disabledSecond: { type: Function, default: () => false }\n  },\n\n  data() {\n    return {\n      currentValue: this.modelValue,\n      showPopup: this.show,\n      inputFocused: false,\n      ignoreNextChange: false\n    }\n  },\n\n  computed: {\n    focused() {\n      return this.inputFocused || this.showPopup\n    },\n\n    input() {\n      return getTarget(this)?.querySelector('input')\n    },\n\n    formatOptions() {\n      return {\n        locale: this.locale,\n        ...this.format\n      }\n    },\n\n    currentText: {\n      get() {\n        return format(this.currentValue, this.formatOptions) || ''\n      },\n\n      set(value) {\n        const date = parseDate(value, this.formatOptions)\n        if (date) {\n          this.currentValue = date\n        }\n      }\n    },\n\n    currentDate() {\n      return (\n        this.currentValue ||\n        // Create a new Date() object with the time set to 0, to be used when\n        // first setting any of the times, for meaningful dates in case the\n        // object is shared with a DatePicker, e.g. through DateTimePicker.\n        alterDate(new Date(), { hour: 0, minute: 0, second: 0, millisecond: 0 })\n      )\n    },\n\n    hour: {\n      get() {\n        return this.currentDate.getHours()\n      },\n\n      set(hour) {\n        this.setTime({ hour })\n      }\n    },\n\n    minute: {\n      get() {\n        return this.currentDate.getMinutes()\n      },\n\n      set(minute) {\n        this.setTime({ minute })\n      }\n    },\n\n    second: {\n      get() {\n        return this.currentDate.getSeconds()\n      },\n\n      set(second) {\n        this.setTime({ second })\n      }\n    }\n  },\n\n  watch: {\n    modelValue(to, from) {\n      if (+to !== +from) {\n        this.currentValue = to\n        this.scrollAll(true)\n      }\n    },\n\n    currentValue(value) {\n      if (+value !== +this.modelValue) {\n        this.$emit('update:modelValue', value)\n        this.$emit('change', value)\n        this.scrollAll(true)\n      }\n    },\n\n    currentText() {\n      const { input } = this\n      const selection = getSelection(input)\n      if (\n        this.focused &&\n        !this.ignoreNextChange &&\n        selection.start === selection.end\n      ) {\n        this.$nextTick(() => setSelection(input, selection))\n      }\n      this.ignoreNextChange = false\n    },\n\n    show(show) {\n      this.showPopup = show\n    },\n\n    showPopup(to, from) {\n      if (to) {\n        this.scrollAll(false)\n      }\n      if (to ^ from) {\n        this.$emit('update:show', to)\n      }\n    },\n\n    focused(to, from) {\n      if (to ^ from) {\n        this.$emit(to ? 'focus' : 'blur')\n      }\n    }\n  },\n\n  methods: {\n    leftPad(value) {\n      return ('0' + value).slice(-2)\n    },\n\n    setTime(overrides) {\n      this.currentValue = alterDate(this.currentDate, {\n        ...overrides,\n        millisecond: 0\n      })\n    },\n\n    scrollAll(smooth) {\n      const scroll = (ref, value) => {\n        const target = this.$refs[ref]\n        if (target) {\n          const lineHeight = (\n            target.scrollHeight /\n            // First and last one add 3 times the margin.\n            (target.childElementCount + 6)\n          )\n          const top = Math.round(value * lineHeight)\n          const distance = Math.abs(target.scrollTop - top)\n          target.scrollTo({\n            top,\n            behavior: smooth && distance < 100 ? 'smooth' : 'auto'\n          })\n        }\n      }\n      this.$nextTick(() => {\n        scroll('hour', this.hour)\n        scroll('minute', this.minute)\n        scroll('second', this.second)\n      })\n    },\n\n    onFocus(focus) {\n      this.inputFocused = focus\n      this.showPopup = focus\n    },\n\n    onKeyDown(event) {\n      const { input } = this\n      const selection = getSelection(input)\n      const { ver: step, enter } = getKeyNavigation(event)\n      if (step || enter) {\n        event.preventDefault()\n\n        const getDatePart = position =>\n          getDatePartAtPosition(this.currentText, position, this.formatOptions)\n\n        if (step) {\n          if (!this.showPopup) {\n            this.showPopup = true\n          } else {\n            const { name, start } = getDatePart(selection.start) || {}\n            if (name) {\n              const value = this[name] + step\n              const count = this.$refs[name].childElementCount\n              this[name] =\n                value < 0\n                  ? value + count\n                  : value >= count\n                    ? value - count\n                    : value\n              this.ignoreNextChange = true\n              this.$nextTick(() => setSelection(input, getDatePart(start)))\n            }\n          }\n        } else if (enter) {\n          this.showPopup = false\n        }\n      } else if (selection.start === selection.end) {\n        const { value } = input\n        let pos = selection.start\n\n        const isDigit = char => !isNaN(Number(char))\n\n        if (event.key.length === 1) {\n          if (isDigit(event.key) && pos < value.length) {\n            if (\n              value[pos] === ':' &&\n              isDigit(value[pos - 1]) &&\n              isDigit(value[pos - 2])\n            ) {\n              pos++\n            }\n            // Remove next digit so the event overrides it instead of inserting\n            // new chars.\n            if (\n              isDigit(value[pos]) && (\n                isDigit(value[pos + 1]) ||\n                isDigit(value[pos - 1])\n              )\n            ) {\n              input.value = (\n                value.slice(0, pos) +\n                value.slice(pos + 1)\n              )\n              setSelection(input, { start: pos, end: pos })\n            }\n          } else {\n            const length = format(this.currentValue, this.formatOptions).length\n            if (value.length === length) {\n              event.preventDefault()\n            } else if (value.length > length) {\n              input.value = value.slice(0, length)\n              setSelection(input, selection)\n              event.preventDefault()\n            }\n          }\n        } else if (event.key === 'Backspace') {\n          if (\n            pos === 1 ||\n            [' ', ':'].includes(value[pos - 2])\n          ) {\n            if (\n              pos === value.length ||\n              value[pos] === ':'\n            ) {\n              pos--\n              input.value = (\n                value.slice(0, pos) +\n                ((value[pos - 1] ?? '') + '00') +\n                value.slice(pos + 1)\n              )\n              setSelection(input, { start: pos, end: pos })\n            } else if (\n              isDigit(value[pos]) &&\n              !isDigit(+value[pos + 1])\n            ) {\n              // When removing the first of two digits, replace with 0\n              input.value = value.slice(0, pos) + '0' + value.slice(pos)\n              setSelection(input, { start: pos, end: pos })\n            }\n          }\n        }\n      }\n    },\n\n    onMouseDown(toggle) {\n      this.showPopup = !this.disabled && (!toggle || !this.showPopup)\n      if (this.showPopup) {\n        this.focus()\n      }\n    },\n\n    focus() {\n      this.input.focus()\n    },\n\n    blur() {\n      this.input.blur()\n    }\n  }\n}\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-time-picker {\n  .dito-input {\n    width: 100%;\n    min-width: 6em;\n  }\n}\n\n.dito-time-picker-popup {\n  max-width: 160px;\n  margin: $popup-margin;\n}\n\n$time-picker-line-height: 24px;\n\n.dito-time-picker {\n  .dito-input {\n    font-variant-numeric: tabular-nums;\n    width: 100%;\n  }\n}\n\n.dito-time-picker-popup {\n  list-style: none;\n  background: $color-white;\n  border: $border-style;\n  border-radius: $border-radius;\n  box-shadow: $shadow-window;\n  overflow: hidden;\n}\n\n.dito-time-picker-popup .dito-time-picker-panel {\n  float: left;\n  border: $border-style;\n  border-width: 0 1px 0;\n  margin-left: -1px;\n  box-sizing: border-box;\n  width: calc(100% / 3 + 1px);\n  overflow: hidden;\n\n  &:last-child {\n    border-right: 0;\n  }\n\n  ul {\n    overflow-x: hidden;\n    overflow-y: auto;\n    list-style: none;\n    width: 100%;\n    margin: 0;\n    // Hide scrollbar:\n    box-sizing: content-box;\n    padding: 0 17px 0 0;\n    height: 7 * $time-picker-line-height;\n\n    & > li {\n      box-sizing: content-box;\n      background: $color-white;\n      width: 100%;\n      height: $time-picker-line-height;\n      line-height: $time-picker-line-height;\n      text-align: center;\n      font-variant-numeric: tabular-nums;\n      cursor: pointer;\n      white-space: nowrap;\n      overflow: hidden;\n      @include user-select(none);\n\n      &:first-child {\n        margin-top: 3 * $time-picker-line-height;\n      }\n\n      &:last-child {\n        margin-bottom: 3 * $time-picker-line-height;\n      }\n\n      &:hover {\n        background: $color-highlight;\n      }\n\n      &.selected,\n      &.selected:hover {\n        color: $color-text-inverted;\n        background: $color-active;\n      }\n\n      &.disabled {\n        cursor: default;\n        color: $color-disabled;\n      }\n\n      &.disabled:hover {\n        background: transparent;\n      }\n    }\n  }\n}\n</style>\n","<template lang=\"pug\">\n.dito-date-time-picker(ref=\"picker\")\n  .dito-date-time-picker__inner(\n    :class=\"{ 'dito-date-time-picker__inner--focus': focused }\"\n  )\n    DitoInput.dito-date-time-picker__input(\n      ref=\"input\"\n      v-model=\"currentText\"\n      type=\"text\"\n      v-bind=\"{ placeholder, disabled, focused, ...$attrs }\"\n      @focus=\"onFocus(true)\"\n      @blur=\"onFocus(false)\"\n      @keydown=\"onKeyDown\"\n      @mousedown.stop=\"onMouseDown(false)\"\n    )\n      template(#prefix)\n        slot(name=\"prefix\")\n      template(#suffix)\n        DitoIcon(\n          name=\"calendar\"\n          :disabled=\"disabled\"\n          @mousedown.prevent=\"onMouseDown(true)\"\n        )\n        slot(name=\"suffix\")\n    DitoDatePicker(\n      ref=\"date\"\n      v-model=\"currentValue\"\n      v-model:show=\"showDate\"\n      placement=\"bottom-left\"\n      :target=\"$refs.picker\"\n      v-bind=\"attributes\"\n    )\n      template(#trigger)\n        //- Intentionally empty\n    DitoTimePicker(\n      ref=\"time\"\n      v-model=\"currentValue\"\n      v-model:show=\"showTime\"\n      placement=\"bottom-right\"\n      :target=\"$refs.picker\"\n      v-bind=\"attributes\"\n    )\n      template(#trigger)\n        //- Intentionally empty\n</template>\n\n<script>\nimport { format, defaultFormats, assignDeeply } from '@ditojs/utils'\nimport DitoInput from './DitoInput.vue'\nimport DitoDatePicker from './DitoDatePicker.vue'\nimport DitoTimePicker from './DitoTimePicker.vue'\nimport DitoIcon from './DitoIcon.vue'\nimport { parseDate } from '../utils/date.js'\nimport { getSelection, setSelection } from '../utils/selection.js'\nimport { getKeyNavigation } from '../utils/event.js'\n\nexport default {\n  components: { DitoInput, DitoDatePicker, DitoTimePicker, DitoIcon },\n  emits: ['update:modelValue', 'change', 'focus', 'blur'],\n  inheritAttrs: false,\n\n  props: {\n    modelValue: { type: Date, default: null },\n    transition: { type: String, default: 'slide' },\n    placeholder: { type: String, default: null },\n    disabled: { type: Boolean, default: false },\n    locale: { type: String, default: 'en-US' },\n    format: { type: Object, default: null }\n  },\n\n  data() {\n    return {\n      currentValue: this.modelValue,\n      showDate: false,\n      showTime: false,\n      inputFocused: false,\n      dateFocused: false,\n      timeFocused: false,\n      closedMode: null\n    }\n  },\n\n  computed: {\n    attributes() {\n      const { transition, disabled, locale, formatOptions: format } = this\n      return { transition, disabled, locale, format }\n    },\n\n    focused() {\n      return this.inputFocused || this.showDate || this.showTime\n    },\n\n    input() {\n      return this.$refs.input.input\n    },\n\n    formatOptions() {\n      return assignDeeply(\n        {\n          locale: this.locale,\n          time: defaultFormats.time,\n          date: defaultFormats.date\n        },\n        {\n          date: {\n            month: 'short',\n            format: (value, type, options) =>\n              type === 'literal' && /\\bat\\b/.test(value)\n                ? ', '\n                : this.format?.date?.format?.(value, type, options) ?? value\n          }\n        },\n        this.format\n      )\n    },\n\n    timeIndex() {\n      const text = this.currentText\n      if (text) {\n        const time = text.match(/([\\S]+\\s*)$/)?.[1]\n        if (time) {\n          return text.length - time.length\n        }\n      }\n      return null\n    },\n\n    currentText: {\n      get() {\n        return format(this.currentValue, this.formatOptions) || ''\n      },\n\n      set(value) {\n        const date = parseDate(value, this.formatOptions)\n        if (date) {\n          const selection = getSelection(this.input)\n          this.currentValue = date\n          this.$nextTick(() => setSelection(this.input, selection))\n        }\n      }\n    }\n  },\n\n  watch: {\n    modelValue(to, from) {\n      if (+to !== +from) {\n        this.currentValue = to\n      }\n    },\n\n    currentValue(value) {\n      if (+value !== +this.modelValue) {\n        this.$emit('update:modelValue', value)\n        this.$emit('change', value)\n      }\n    },\n\n    focused(to, from) {\n      if (to ^ from) {\n        this.$emit(to ? 'focus' : 'blur')\n      }\n    }\n  },\n\n  methods: {\n    onFocus(focus) {\n      this.inputFocused = focus\n      if (focus) {\n        this.updatePopups()\n      } else {\n        this.showDate = false\n        this.showTime = false\n      }\n    },\n\n    onMouseDown(toggle) {\n      if (toggle && (this.showDate || this.showTime)) {\n        this.showDate = false\n        this.showTime = false\n      } else if (!this.disabled) {\n        this.focus()\n        requestAnimationFrame(() => this.updatePopups())\n      }\n    },\n\n    onKeyDown(event) {\n      const mode = this.getMode(event)\n      this.$refs[mode].onKeyDown(event)\n      if (event.defaultPrevented) {\n        this.closedMode = mode\n      } else if (mode !== this.closedMode) {\n        this.updatePopups(mode)\n      }\n    },\n\n    getMode(event = null) {\n      const { start } = getSelection(this.input)\n      const { hor: step } = getKeyNavigation(event)\n      return this.timeIndex === null || start + step < this.timeIndex\n        ? 'date'\n        : 'time'\n    },\n\n    updatePopups(mode = this.getMode()) {\n      if (mode) {\n        this.closedMode = null\n      }\n      this.showDate = mode === 'date'\n      this.showTime = mode === 'time'\n    },\n\n    focus() {\n      this.input.focus()\n    },\n\n    blur() {\n      this.input.blur()\n    }\n  }\n}\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-date-time-picker {\n  &__inner {\n    display: flex;\n  }\n\n  &__input {\n    flex: 1;\n    font-variant-numeric: tabular-nums;\n    min-width: 12em;\n  }\n\n  .dito-date-picker,\n  .dito-time-picker {\n    position: absolute;\n  }\n}\n</style>\n","<!-- eslint-disable vue/no-template-shadow -->\n<template lang=\"pug\">\n.dito-pagination\n  .dito-pagination-total(\n    v-if=\"showTotal\"\n  )\n    template(\n      v-if=\"total > 0\"\n    ) {{ first }} – {{ last }} / {{ total }}\n  .dito-buttons.dito-buttons--round(\n    v-if=\"numPages > 1\"\n  )\n    button.dito-button(\n      v-for=\"button in buttons\"\n      :class=\"getButtonClasses(button)\"\n      :disabled=\"button.disabled\"\n      @click=\"onClickButton(button)\"\n    )\n      span(\n        v-if=\"button.text\"\n      ) {{ button.text }}\n</template>\n\n<script>\nexport default {\n  emits: ['update:page'],\n\n  props: {\n    total: { type: Number, default: 0 },\n    page: { type: Number, default: 1 },\n    pageSize: { type: Number, default: 10 },\n    showTotal: { type: Boolean, default: true }\n  },\n\n  data() {\n    return {\n      showPrev: true,\n      showNext: true,\n      currentPage: this.page\n    }\n  },\n\n  computed: {\n    first() {\n      return (this.currentPage - 1) * this.pageSize + 1\n    },\n\n    last() {\n      return Math.min(this.first + this.pageSize - 1, this.total)\n    },\n\n    numPages() {\n      return Math.ceil(this.total / this.pageSize)\n    },\n\n    buttons() {\n      const { showPrev, showNext, currentPage, numPages } = this\n      const showLength = showPrev + showNext + 1\n\n      let start = 1\n      let end = 1\n      if (numPages <= showLength) {\n        end = numPages\n      } else if (currentPage <= showPrev + 1) {\n        end = showLength\n      } else if (currentPage >= numPages - showNext) {\n        end = numPages\n        start = numPages - showLength + 1\n      } else {\n        start = currentPage - showPrev\n        end = currentPage + showNext\n      }\n\n      const buttons = []\n      buttons.push({\n        index: currentPage - 1,\n        type: 'prev',\n        disabled: currentPage <= 1\n      })\n      if (start >= 2) {\n        buttons.push({ index: 1, text: 1 })\n      }\n      if (start > 2) {\n        buttons.push({\n          index: Math.max(1, currentPage - 10),\n          type: 'ellipsis-prev'\n        })\n      }\n      for (let i = start; i <= end; i++) {\n        buttons.push({\n          index: i,\n          text: i,\n          active: i === currentPage\n        })\n      }\n      if (end < numPages - 1) {\n        buttons.push({\n          index: Math.min(numPages, currentPage + 10),\n          type: 'ellipsis-next'\n        })\n      }\n      if (end <= numPages - 1) {\n        buttons.push({ index: numPages, text: numPages })\n      }\n      buttons.push({\n        index: currentPage + 1,\n        type: 'next',\n        disabled: currentPage >= numPages\n      })\n\n      return buttons\n    }\n  },\n\n  watch: {\n    page(page) {\n      this.currentPage = page\n    },\n\n    pageSize() {\n      if (this.currentPage > this.numPages) {\n        this.currentPage = this.numPages\n      }\n    },\n\n    currentPage(to, from) {\n      if (to !== from) {\n        this.$emit('update:page', to)\n      }\n    }\n  },\n\n  created() {\n    this.currentPage = this.page\n  },\n\n  methods: {\n    getButtonClasses(button) {\n      const prefix = 'dito-button'\n      return {\n        [`${prefix}--${button.type}`]: button.type,\n        [`${prefix}--active`]: button.active\n      }\n    },\n\n    onClickButton(button) {\n      if (\n        button.index &&\n        !button.disabled &&\n        button.index !== this.currentPage\n      ) {\n        this.currentPage = button.index\n      }\n    }\n  }\n}\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-pagination {\n  display: flex;\n\n  .dito-pagination-total {\n    @include ellipsis;\n\n    margin: 0 0.5em;\n    line-height: $input-height;\n  }\n\n  .dito-button {\n    transition:\n      all 0.3s ease,\n      color 0s,\n      background 0s,\n      border 0s;\n    font-variant-numeric: tabular-nums;\n    padding: 0 0.5em;\n\n    &--prev,\n    &--next {\n      &::before {\n        @extend %icon-arrow;\n      }\n    }\n\n    &--prev::before {\n      transform: scaleX(-1);\n    }\n\n    &--ellipsis-prev,\n    &--ellipsis-next {\n      background: none;\n      border: 0;\n      padding: 0;\n      margin: 0;\n      color: $color-text;\n\n      &::before {\n        @extend %icon-ellipsis;\n      }\n\n      &:hover::before {\n        @extend %icon-chevrons;\n      }\n\n      &:focus {\n        color: $color-active;\n      }\n\n      &:active {\n        box-shadow: none;\n      }\n    }\n\n    &--ellipsis-prev::before {\n      transform: scaleX(-1);\n    }\n  }\n}\n</style>\n","<template lang=\"pug\">\n.dito-switch(\n  :class=\"classes\"\n  :style=\"styles\"\n)\n  .dito-switch__pane\n    input(\n      :id=\"id\"\n      ref=\"input\"\n      v-bind=\"attributes\"\n      v-model=\"checked\"\n      type=\"checkbox\"\n      :name=\"name\"\n      :disabled=\"disabled\"\n    )\n    .dito-switch__button\n    span.dito-switch__label(\n      v-if=\"labels\"\n    )\n      slot(\n        v-if=\"checked\"\n        name=\"checked\"\n      ) {{ labels.checked || 'on' }}\n      slot(\n        v-else\n        name=\"unchecked\"\n      ) {{ labels.unchecked || 'off' }}\n</template>\n\n<script>\nexport default {\n  emits: ['update:modelValue', 'change'],\n  inheritAttrs: false,\n\n  props: {\n    modelValue: { type: Boolean, default: false },\n    id: { type: String, default: null },\n    name: { type: String, default: null },\n    disabled: { type: Boolean, default: false },\n    labels: { type: [Object, Boolean], default: false }\n  },\n\n  data() {\n    return {\n      checked: this.modelValue\n    }\n  },\n\n  computed: {\n    classes() {\n      const prefix = 'dito-switch'\n      return [\n        this.$attrs.class,\n        {\n          [`${prefix}--checked`]: this.checked,\n          [`${prefix}--disabled`]: this.disabled\n        }\n      ]\n    },\n\n    styles() {\n      const { labels: { checked, unchecked } = {} } = this\n      // Calculate `--switch-width` in `rem`, based on label length.\n      const length = Math.max(0, checked?.length, unchecked?.length)\n      return {\n        '--switch-width': length ? `${length * 1.5}rem` : null\n      }\n    },\n\n    attributes() {\n      const { class: _, ...attributes } = this.$attrs\n      return attributes\n    }\n  },\n\n  watch: {\n    modelValue(modelValue) {\n      this.checked = modelValue\n    },\n\n    checked(checked) {\n      if (checked !== this.modelValue) {\n        this.$emit('update:modelValue', checked)\n        this.$emit('change', checked)\n      }\n    }\n  },\n\n  methods: {\n    focus() {\n      this.$refs.input.focus()\n    }\n  }\n}\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-switch {\n  $self: &;\n\n  // Use whole multiples of `rem` for sizes and `px` margins/padding along\n  // with `calc()` to end up with even pixel sizes.\n  --switch-width: 4em;\n  --switch-height: 2em;\n  --switch-margin: 2px;\n  --switch-padding: 3px;\n  --switch-speed: 300ms;\n  --label-margin: 0.5em;\n  --width: calc(var(--switch-width) - 2 * var(--switch-margin));\n  --height: calc(var(--switch-height) - 2 * var(--switch-margin));\n  --offset: calc(var(--width) - var(--height));\n\n  display: inline-block;\n  position: relative;\n  height: var(--switch-height);\n  // To make inline labels appear on consistent baseline:\n  vertical-align: bottom;\n  @include user-select(none);\n\n  &__pane {\n    position: relative;\n    width: var(--width);\n    height: var(--height);\n  }\n\n  &__pane,\n  &__label {\n    top: 50%;\n    transform: translateY(-50%);\n  }\n\n  input {\n    cursor: pointer;\n    appearance: none;\n    width: 100%;\n    height: 100%;\n    border-radius: 1em;\n    background: $color-light;\n    transition:\n      border-color 0.3s,\n      background-color 0.3s;\n  }\n\n  &__button {\n    --size: calc(var(--height) - 2 * var(--switch-padding));\n\n    position: absolute;\n    top: var(--switch-padding);\n    left: var(--switch-padding);\n    width: var(--size);\n    height: var(--size);\n    border-radius: calc(var(--size) / 2);\n    box-sizing: border-box;\n    background: $color-white;\n    transition: transform var(--switch-speed);\n    transform: translateX(0);\n  }\n\n  &__button,\n  &__label {\n    pointer-events: none;\n  }\n\n  &__label {\n    position: absolute;\n    right: var(--label-margin);\n    text-transform: uppercase;\n    color: $color-white;\n  }\n\n  &--checked {\n    input {\n      background: $color-active;\n    }\n\n    #{$self}__button {\n      transform: translateX(var(--offset));\n    }\n\n    #{$self}__label {\n      left: var(--label-margin);\n      right: unset;\n    }\n  }\n\n  &--disabled {\n    @extend %button-disabled;\n  }\n\n  &:focus-within:not(:hover) {\n    #{$self}__button {\n      box-shadow: $shadow-focus;\n    }\n  }\n}\n</style>\n","<script>\nimport { h as createElement, Transition } from 'vue'\n\n// @vue/component\nfunction TransitionHeight({ enabled }, { slots }) {\n  return enabled\n    ? createElement(Transition, props, slots)\n    : slots.default()\n}\n\nTransitionHeight.props = {\n  enabled: { type: Boolean, default: true }\n}\n\nexport default TransitionHeight\n\nconst setStyle = (element, style) => Object.assign(element.style, style)\n\nconst nextTimeout = callback => setTimeout(callback, 0)\n\n// Force repaint to make sure the animation is triggered correctly.\nconst forceRepaint = element => getComputedStyle(element).height\n\nconst props = {\n  name: 'dito-height',\n\n  onAfterEnter(element) {\n    // A timeout before setting style is only really needed after calls to\n    // `forceRepaint()`, but using one here too preserves execution sequence so\n    // that the call from `enter()` can never outrun the one from `afterEnter()`\n    nextTimeout(() => setStyle(element, { height: null }))\n  },\n\n  onEnter(element) {\n    // For some reason we're getting two `onEnter()` calls per transition,\n    // so we need to ignore the second one. This might be linked to the use\n    // of `nextTimeout()`, which is required to get the correct value for\n    // `height`, based on `&--label-vertical` calculations.\n    const { width } = getComputedStyle(element)\n    setStyle(element, {\n      width,\n      position: 'absolute',\n      visibility: 'hidden',\n      height: 'auto'\n    })\n    nextTimeout(() => {\n      const { height } = getComputedStyle(element)\n      setStyle(element, {\n        width: null,\n        position: null,\n        visibility: null,\n        height: 0\n      })\n      forceRepaint(element)\n      nextTimeout(() => setStyle(element, { height }))\n    })\n  },\n\n  onLeave(element) {\n    const { height } = getComputedStyle(element)\n    setStyle(element, { height })\n    forceRepaint(element)\n    nextTimeout(() => setStyle(element, { height: 0 }))\n  }\n}\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n$duration: 0.15s;\n\n.dito-height-enter-active,\n.dito-height-leave-active {\n  transition: height $duration $ease-out-quart;\n  overflow: hidden;\n}\n\n.dito-height-enter-active {\n  animation: dito-slide-enter $duration $ease-out-quart;\n}\n\n.dito-height-leave-active {\n  animation: dito-slide-leave $duration $ease-out-quart;\n}\n\n.dito-height-enter-from,\n.dito-height-leave-to {\n  height: 0;\n}\n</style>\n","import { isObject } from '@ditojs/utils'\nimport { addEvents } from '@ditojs/ui/src'\n\n// @vue/component\nexport default {\n  data() {\n    return {\n      domHandlers: []\n    }\n  },\n\n  unmounted() {\n    for (const { remove } of this.domHandlers) {\n      remove()\n    }\n    this.domHandlers = []\n  },\n\n  methods: {\n    domOn(element, type, handler) {\n      const result = addEvents(\n        element,\n        isObject(type) ? type : { [type]: handler }\n      )\n      this.domHandlers.push(result)\n      return result\n    }\n  }\n}\n","export default class DitoUser {\n  hasRole(...roles) {\n    if (this.roles) {\n      for (const role of roles) {\n        if (this.roles.includes(role)) {\n          return true\n        }\n      }\n    }\n    return false\n  }\n}\n","// @vue/component\nexport default {\n  provide() {\n    return {\n      $schemaParentComponent: () => this\n    }\n  },\n\n  data() {\n    return {\n      schemaComponents: []\n    }\n  },\n\n  computed: {\n    mainSchemaComponent() {\n      return this.schemaComponents[0]\n    }\n  },\n\n  methods: {\n    // This method is called by `DitoSchema.created()/unmounted()` on its\n    // `$schemaParentComponent`, if the parent uses the `SchemaParentMixin`:\n    _registerSchemaComponent(schemaComponent, add) {\n      const { schemaComponents } = this\n      if (add) {\n        schemaComponents.push(schemaComponent)\n      } else {\n        schemaComponents.splice(schemaComponents.indexOf(schemaComponent), 1)\n      }\n    }\n  }\n}\n","import SchemaParentMixin from './SchemaParentMixin.js'\n\n// @vue/component\nexport default {\n  mixins: [SchemaParentMixin],\n\n  computed: {\n    errors() {\n      return this.schemaComponents.flatMap(({ errors }) => errors || [])\n    },\n\n    isTouched() {\n      return this.schemaComponents.some(it => it.isTouched)\n    },\n\n    isDirty() {\n      return this.schemaComponents.some(it => it.isDirty)\n    },\n\n    isValid() {\n      return this.schemaComponents.every(it => it.isValid)\n    },\n\n    isValidated() {\n      return this.schemaComponents.every(it => it.isValid)\n    }\n  },\n\n  methods: {\n    validateAll(match, notify = true) {\n      return this.schemaComponents.every(it => it.validateAll(match, notify))\n    },\n\n    verifyAll(match) {\n      return this.schemaComponents.every(it => it.verifyAll(match))\n    },\n\n    resetValidation() {\n      this.schemaComponents.forEach(it => it.resetValidation())\n    },\n\n    clearErrors() {\n      this.schemaComponents.forEach(it => it.clearErrors())\n    },\n\n    showValidationErrors(errors, focus, first = true) {\n      this.schemaComponents.forEach(\n        schemaComponent => {\n          if (schemaComponent.showValidationErrors(errors, focus, first)) {\n            first = false\n          }\n        }\n      )\n      return !first\n    }\n  }\n}\n","import ValidatorMixin from '../mixins/ValidatorMixin.js'\nimport { getCommonPrefix } from '@ditojs/utils'\n\n// @vue/component\nexport default {\n  mixins: [ValidatorMixin],\n\n  provide() {\n    return {\n      $routeComponent: () => this\n    }\n  },\n\n  data() {\n    return {\n      reload: false,\n      // Each route-component defines a store that gets passed on to its\n      // child components, so they can store values in them that live beyond\n      // their life-cycle. See: DitoPane, SourceMixin\n      store: {},\n      loadCache: {} // See TypeMixin.load()\n    }\n  },\n\n  computed: {\n    routeComponent() {\n      // Override DitoMixin's routeComponent() which uses the injected value.\n      return this\n    },\n\n    routeLevel() {\n      let level = 0\n      let routeComponent = this\n      while ((routeComponent = routeComponent.parentRouteComponent)) {\n        level++\n      }\n      return level\n    },\n\n    routeRecord() {\n      return this.$route.matched[this.routeLevel]\n    },\n\n    isLastRoute() {\n      // Returns true when this router component is the last one in the route.\n      const { matched } = this.$route\n      return this.routeRecord === matched[matched.length - 1]\n    },\n\n    isLastUnnestedRoute() {\n      // Returns true if this route component is the last one in the route that\n      // needs its own router-view (= is not nested).\n      const { matched } = this.$route\n      for (let i = matched.length - 1; i >= 0; i--) {\n        const record = matched[i]\n        if (!record.meta.nested) {\n          return this.routeRecord === record\n        }\n      }\n      return false\n    },\n\n    isNestedRoute() {\n      return this.meta.nested\n    },\n\n    isView() {\n      return false\n    },\n\n    meta() {\n      return this.routeRecord?.meta\n    },\n\n    path() {\n      return this.getRoutePath(this.routeRecord?.path)\n    },\n\n    label() {\n      return this.getLabel(this.schema)\n    },\n\n    breadcrumb() {\n      const { breadcrumb } = this.schema || {}\n      return breadcrumb || `${this.breadcrumbPrefix} ${this.label}`\n    },\n\n    breadcrumbPrefix() {\n      return ''\n    },\n\n    param() {\n      // Workaround for vue-router not being able to map multiple url parameters\n      // with the same name to multiple components, see:\n      // https://github.com/vuejs/vue-router/issues/1345\n      return this.$route.params[this.meta?.param] || null\n    },\n\n    // @overridable, see DitoForm\n    isMutating() {\n      return false\n    }\n  },\n\n  beforeRouteUpdate(to, from) {\n    return this?.beforeRouteChange(to, from)\n  },\n\n  beforeRouteLeave(to, from) {\n    return this?.beforeRouteChange(to, from)\n  },\n\n  created() {\n    // Keep a shared stack of root components for DitoTrail to use to render\n    // labels. Can't rely on $route.matched[i].instances.default unfortunately,\n    // as instances aren't immediately ready, and instances is not reactive.\n    this.appState.routeComponents.push(this)\n  },\n\n  unmounted() {\n    const { routeComponents } = this.appState\n    routeComponents.splice(routeComponents.indexOf(this), 1)\n  },\n\n  methods: {\n    beforeRouteChange(to, from) {\n      let ok = true\n      const isClosing = (\n        // Only handle this route change if the form is actually mapped to the\n        // `from` route, but include parent forms of closing nested forms as as\n        // well, by matching the the start of from/to path against `this.path`:\n        from.path.startsWith(this.path) &&\n        !to.path.startsWith(this.path) &&\n        // Exclude hash changes only (= tab changes):\n        from.path !== to.path && (\n          this.isFullRouteChange(to, from) ||\n          // Decide if we're moving towards a new nested form, or closing /\n          // replacing an already open one by comparing path lengths.\n          // The case of `=` matches the replacing of an already open one.\n          to.path.length <= from.path.length\n        )\n      )\n      if (isClosing) {\n        if (this.isMutating) {\n          // For active directly mutating (nested) forms that were not validated\n          // yet, validate them once. If the user then still wants to leave\n          // them, they can click close / navigate away again.\n          ok = (\n            this.isValidated ||\n            this.validateAll()\n          )\n        } else {\n          // The form doesn't directly mutate data. If it is dirty, ask if user\n          // wants to persist data first.\n          if (this.isDirty) {\n            ok = window.confirm(\n              `You have unsaved changes. Do you really want to ${\n                this.verbs.cancel\n              }?`\n            )\n          }\n        }\n      }\n      return ok\n    },\n\n    getRoutePath(recordPath) {\n      // Maps the route's actual path to the matched routes by counting its\n      // parts separated by '/', splitting the path into the mapped parts\n      // containing actual parameters.\n      const { path } = this.$route\n      return recordPath\n        ? path\n            .split('/')\n            .slice(0, recordPath.split('/').length)\n            .join('/')\n        : path\n    },\n\n    getChildPath(path) {\n      return `${this.path}/${path}`\n    },\n\n    isFullRouteChange(to, from) {\n      // The route path is the path up to the first / (excluding the initial /):\n      const rootPath = this.path.match(/^(\\/[^/]*)/)[1]\n      return !getCommonPrefix(to.path, from.path).startsWith(rootPath)\n    }\n  }\n}\n","<template lang=\"pug\">\ntemplate(\n  v-if=\"user && shouldRenderSchema(viewSchema)\"\n)\n  //- Only render DitoView when it is active, otherwise a normal router-view\n  //- instead, to nest further route components.\n  //- NOTE: This is different from the handling in DitoForm, where `v-show` is\n  //- used to always render forms even when other nested forms are present.\n  RouterView(\n    v-if=\"!isLastRoute\"\n    :key=\"name\"\n  )\n  .dito-view.dito-scroll-parent(\n    v-else\n    :data-resource=\"sourceSchema.path\"\n  )\n    DitoSchema(\n      :key=\"name\"\n      :schema=\"viewSchema\"\n      :data=\"data\"\n      :meta=\"meta\"\n      :store=\"getChildStore(name)\"\n      padding=\"root\"\n      :disabled=\"isLoading\"\n      scrollable\n      single\n    )\n</template>\n\n<script>\nimport DitoComponent from '../DitoComponent.js'\nimport RouteMixin from '../mixins/RouteMixin.js'\nimport {\n  isSingleComponentView,\n  someNestedSchemaComponent\n} from '../utils/schema.js'\nimport { hasResource } from '../utils/resource.js'\n\n// @vue/component\nexport default DitoComponent.component('DitoView', {\n  mixins: [RouteMixin],\n\n  provide() {\n    // Redirect $sourceComponent and $resourceComponent to the main component:\n    return {\n      $sourceComponent: () => this.mainComponent?.sourceComponent || null,\n      $resourceComponent: () => this.mainComponent?.resourceComponent || null\n    }\n  },\n\n  data() {\n    return {\n      // Updated from LoadingMixin through `setLoading(isLoading)`:\n      isLoading: false,\n      // NOTE: Data is shared across all views because the router recycles the\n      // DitoView component.\n      data: {}\n    }\n  },\n\n  computed: {\n    schema() {\n      return this.meta.schema ?? {}\n    },\n\n    name() {\n      return this.schema.name\n    },\n\n    isView() {\n      return true\n    },\n\n    isSingleComponentView() {\n      return isSingleComponentView(this.schema)\n    },\n\n    mainComponent() {\n      return this.mainSchemaComponent?.getComponentByDataPath(this.name)\n    },\n\n    viewSchema() {\n      const { component, ...schema } = this.schema\n      // Translate single-component schemas into multi-component schemas,\n      // so they can be rendered directly through DitoSchema also:\n      return this.isSingleComponentView\n        ? {\n            ...schema,\n            components: {\n              [schema.name]: {\n                name: schema.name,\n                label: false,\n                ...component\n              }\n            }\n          }\n        : schema\n    },\n\n    providesData() {\n      return someNestedSchemaComponent(this.viewSchema, hasResource)\n    }\n  },\n\n  watch: {\n    $route: {\n      // https://github.com/vuejs/vue-router/issues/3393#issuecomment-1158470149\n      flush: 'post',\n      handler(to, from) {\n        // See if the route changes completely, and clear the data if it does.\n        if (this.isFullRouteChange(to, from)) {\n          this.isLoading = false\n          this.data = {}\n        }\n      }\n    }\n  },\n\n  mounted() {\n    // Prevent bypassing of if-condition by direct URL access.\n    if (!this.shouldRenderSchema(this.viewSchema)) {\n      this.$router.replace({ path: '/' })\n    }\n  },\n\n  methods: {\n    setData(data) {\n      this.data = data\n    },\n\n    getChildPath(path) {\n      // Lists inside single-component views use the view's path for sub-paths:\n      return this.isSingleComponentView\n        ? this.path\n        : `${this.path}/${path}`\n    },\n\n    setLoading(isLoading) {\n      this.isLoading = !!isLoading\n    }\n  }\n})\n</script>\n","import { computed, customRef, effectScope, getCurrentInstance, getCurrentScope, hasInjectionContext, inject, isReactive, isRef, nextTick, onBeforeMount, onBeforeUnmount, onMounted, onScopeDispose, onUnmounted, provide, reactive, readonly, ref, shallowReadonly, shallowRef, toRef as toRef$1, toRefs as toRefs$1, toValue, unref, watch, watchEffect } from \"vue\";\n\n//#region computedEager/index.ts\n/**\n*\n* @deprecated This function will be removed in future version.\n*\n* Note: If you are using Vue 3.4+, you can straight use computed instead.\n* Because in Vue 3.4+, if computed new value does not change,\n* computed, effect, watch, watchEffect, render dependencies will not be triggered.\n* refer: https://github.com/vuejs/core/pull/5912\n*\n* @param fn effect function\n* @param options WatchOptionsBase\n* @returns readonly shallowRef\n*/\nfunction computedEager(fn, options) {\n\tvar _options$flush;\n\tconst result = shallowRef();\n\twatchEffect(() => {\n\t\tresult.value = fn();\n\t}, {\n\t\t...options,\n\t\tflush: (_options$flush = options === null || options === void 0 ? void 0 : options.flush) !== null && _options$flush !== void 0 ? _options$flush : \"sync\"\n\t});\n\treturn readonly(result);\n}\n/** @deprecated use `computedEager` instead */\nconst eagerComputed = computedEager;\n\n//#endregion\n//#region computedWithControl/index.ts\n/**\n* Explicitly define the deps of computed.\n*\n* @param source\n* @param fn\n*/\nfunction computedWithControl(source, fn, options = {}) {\n\tlet v = void 0;\n\tlet track;\n\tlet trigger;\n\tlet dirty = true;\n\tconst update = () => {\n\t\tdirty = true;\n\t\ttrigger();\n\t};\n\twatch(source, update, {\n\t\tflush: \"sync\",\n\t\t...options\n\t});\n\tconst get$1 = typeof fn === \"function\" ? fn : fn.get;\n\tconst set$1 = typeof fn === \"function\" ? void 0 : fn.set;\n\tconst result = customRef((_track, _trigger) => {\n\t\ttrack = _track;\n\t\ttrigger = _trigger;\n\t\treturn {\n\t\t\tget() {\n\t\t\t\tif (dirty) {\n\t\t\t\t\tv = get$1(v);\n\t\t\t\t\tdirty = false;\n\t\t\t\t}\n\t\t\t\ttrack();\n\t\t\t\treturn v;\n\t\t\t},\n\t\t\tset(v$1) {\n\t\t\t\tset$1 === null || set$1 === void 0 || set$1(v$1);\n\t\t\t}\n\t\t};\n\t});\n\tresult.trigger = update;\n\treturn result;\n}\n/** @deprecated use `computedWithControl` instead */\nconst controlledComputed = computedWithControl;\n\n//#endregion\n//#region tryOnScopeDispose/index.ts\n/**\n* Call onScopeDispose() if it's inside an effect scope lifecycle, if not, do nothing\n*\n* @param fn\n*/\nfunction tryOnScopeDispose(fn, failSilently) {\n\tif (getCurrentScope()) {\n\t\tonScopeDispose(fn, failSilently);\n\t\treturn true;\n\t}\n\treturn false;\n}\n\n//#endregion\n//#region createEventHook/index.ts\n/**\n* Utility for creating event hooks\n*\n* @see https://vueuse.org/createEventHook\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction createEventHook() {\n\tconst fns = /* @__PURE__ */ new Set();\n\tconst off = (fn) => {\n\t\tfns.delete(fn);\n\t};\n\tconst clear = () => {\n\t\tfns.clear();\n\t};\n\tconst on = (fn) => {\n\t\tfns.add(fn);\n\t\tconst offFn = () => off(fn);\n\t\ttryOnScopeDispose(offFn);\n\t\treturn { off: offFn };\n\t};\n\tconst trigger = (...args) => {\n\t\treturn Promise.all(Array.from(fns).map((fn) => fn(...args)));\n\t};\n\treturn {\n\t\ton,\n\t\toff,\n\t\ttrigger,\n\t\tclear\n\t};\n}\n\n//#endregion\n//#region createGlobalState/index.ts\n/**\n* Keep states in the global scope to be reusable across Vue instances.\n*\n* @see https://vueuse.org/createGlobalState\n* @param stateFactory A factory function to create the state\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction createGlobalState(stateFactory) {\n\tlet initialized = false;\n\tlet state;\n\tconst scope = effectScope(true);\n\treturn ((...args) => {\n\t\tif (!initialized) {\n\t\t\tstate = scope.run(() => stateFactory(...args));\n\t\t\tinitialized = true;\n\t\t}\n\t\treturn state;\n\t});\n}\n\n//#endregion\n//#region provideLocal/map.ts\nconst localProvidedStateMap = /* @__PURE__ */ new WeakMap();\n\n//#endregion\n//#region injectLocal/index.ts\n/**\n* On the basis of `inject`, it is allowed to directly call inject to obtain the value after call provide in the same component.\n*\n* @example\n* ```ts\n* injectLocal('MyInjectionKey', 1)\n* const injectedValue = injectLocal('MyInjectionKey') // injectedValue === 1\n* ```\n*\n* @__NO_SIDE_EFFECTS__\n*/\nconst injectLocal = (...args) => {\n\tvar _getCurrentInstance;\n\tconst key = args[0];\n\tconst instance = (_getCurrentInstance = getCurrentInstance()) === null || _getCurrentInstance === void 0 ? void 0 : _getCurrentInstance.proxy;\n\tconst owner = instance !== null && instance !== void 0 ? instance : getCurrentScope();\n\tif (owner == null && !hasInjectionContext()) throw new Error(\"injectLocal must be called in setup\");\n\tif (owner && localProvidedStateMap.has(owner) && key in localProvidedStateMap.get(owner)) return localProvidedStateMap.get(owner)[key];\n\treturn inject(...args);\n};\n\n//#endregion\n//#region provideLocal/index.ts\n/**\n* On the basis of `provide`, it is allowed to directly call inject to obtain the value after call provide in the same component.\n*\n* @example\n* ```ts\n* provideLocal('MyInjectionKey', 1)\n* const injectedValue = injectLocal('MyInjectionKey') // injectedValue === 1\n* ```\n*/\nfunction provideLocal(key, value) {\n\tvar _getCurrentInstance;\n\tconst instance = (_getCurrentInstance = getCurrentInstance()) === null || _getCurrentInstance === void 0 ? void 0 : _getCurrentInstance.proxy;\n\tconst owner = instance !== null && instance !== void 0 ? instance : getCurrentScope();\n\tif (owner == null) throw new Error(\"provideLocal must be called in setup\");\n\tif (!localProvidedStateMap.has(owner)) localProvidedStateMap.set(owner, Object.create(null));\n\tconst localProvidedState = localProvidedStateMap.get(owner);\n\tlocalProvidedState[key] = value;\n\treturn provide(key, value);\n}\n\n//#endregion\n//#region createInjectionState/index.ts\n/**\n* Create global state that can be injected into components.\n*\n* @see https://vueuse.org/createInjectionState\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction createInjectionState(composable, options) {\n\tconst key = (options === null || options === void 0 ? void 0 : options.injectionKey) || Symbol(composable.name || \"InjectionState\");\n\tconst defaultValue = options === null || options === void 0 ? void 0 : options.defaultValue;\n\tconst useProvidingState = (...args) => {\n\t\tconst state = composable(...args);\n\t\tprovideLocal(key, state);\n\t\treturn state;\n\t};\n\tconst useInjectedState = () => injectLocal(key, defaultValue);\n\treturn [useProvidingState, useInjectedState];\n}\n\n//#endregion\n//#region createRef/index.ts\n/**\n* Returns a `deepRef` or `shallowRef` depending on the `deep` param.\n*\n* @example createRef(1) // ShallowRef<number>\n* @example createRef(1, false) // ShallowRef<number>\n* @example createRef(1, true) // Ref<number>\n* @example createRef(\"string\") // ShallowRef<string>\n* @example createRef<\"A\"|\"B\">(\"A\", true) // Ref<\"A\"|\"B\">\n*\n* @param value\n* @param deep\n* @returns the `deepRef` or `shallowRef`\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction createRef(value, deep) {\n\tif (deep === true) return ref(value);\n\telse return shallowRef(value);\n}\n\n//#endregion\n//#region utils/is.ts\nconst isClient = typeof window !== \"undefined\" && typeof document !== \"undefined\";\nconst isWorker = typeof WorkerGlobalScope !== \"undefined\" && globalThis instanceof WorkerGlobalScope;\nconst isDef = (val) => typeof val !== \"undefined\";\nconst notNullish = (val) => val != null;\nconst assert = (condition, ...infos) => {\n\tif (!condition) console.warn(...infos);\n};\nconst toString = Object.prototype.toString;\nconst isObject = (val) => toString.call(val) === \"[object Object]\";\nconst now = () => Date.now();\nconst timestamp = () => +Date.now();\nconst clamp = (n, min, max) => Math.min(max, Math.max(min, n));\nconst noop = () => {};\nconst rand = (min, max) => {\n\tmin = Math.ceil(min);\n\tmax = Math.floor(max);\n\treturn Math.floor(Math.random() * (max - min + 1)) + min;\n};\nconst hasOwn = (val, key) => Object.prototype.hasOwnProperty.call(val, key);\nconst isIOS = /* @__PURE__ */ getIsIOS();\nfunction getIsIOS() {\n\tvar _window, _window2, _window3;\n\treturn isClient && !!((_window = window) === null || _window === void 0 || (_window = _window.navigator) === null || _window === void 0 ? void 0 : _window.userAgent) && (/iP(?:ad|hone|od)/.test(window.navigator.userAgent) || ((_window2 = window) === null || _window2 === void 0 || (_window2 = _window2.navigator) === null || _window2 === void 0 ? void 0 : _window2.maxTouchPoints) > 2 && /iPad|Macintosh/.test((_window3 = window) === null || _window3 === void 0 ? void 0 : _window3.navigator.userAgent));\n}\n\n//#endregion\n//#region toRef/index.ts\nfunction toRef(...args) {\n\tif (args.length !== 1) return toRef$1(...args);\n\tconst r = args[0];\n\treturn typeof r === \"function\" ? readonly(customRef(() => ({\n\t\tget: r,\n\t\tset: noop\n\t}))) : ref(r);\n}\n\n//#endregion\n//#region utils/filters.ts\n/**\n* @internal\n*/\nfunction createFilterWrapper(filter, fn) {\n\tfunction wrapper(...args) {\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tPromise.resolve(filter(() => fn.apply(this, args), {\n\t\t\t\tfn,\n\t\t\t\tthisArg: this,\n\t\t\t\targs\n\t\t\t})).then(resolve).catch(reject);\n\t\t});\n\t}\n\treturn wrapper;\n}\nconst bypassFilter = (invoke$1) => {\n\treturn invoke$1();\n};\n/**\n* Create an EventFilter that debounce the events\n*/\nfunction debounceFilter(ms, options = {}) {\n\tlet timer;\n\tlet maxTimer;\n\tlet lastRejector = noop;\n\tconst _clearTimeout = (timer$1) => {\n\t\tclearTimeout(timer$1);\n\t\tlastRejector();\n\t\tlastRejector = noop;\n\t};\n\tlet lastInvoker;\n\tconst filter = (invoke$1) => {\n\t\tconst duration = toValue(ms);\n\t\tconst maxDuration = toValue(options.maxWait);\n\t\tif (timer) _clearTimeout(timer);\n\t\tif (duration <= 0 || maxDuration !== void 0 && maxDuration <= 0) {\n\t\t\tif (maxTimer) {\n\t\t\t\t_clearTimeout(maxTimer);\n\t\t\t\tmaxTimer = void 0;\n\t\t\t}\n\t\t\treturn Promise.resolve(invoke$1());\n\t\t}\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tlastRejector = options.rejectOnCancel ? reject : resolve;\n\t\t\tlastInvoker = invoke$1;\n\t\t\tif (maxDuration && !maxTimer) maxTimer = setTimeout(() => {\n\t\t\t\tif (timer) _clearTimeout(timer);\n\t\t\t\tmaxTimer = void 0;\n\t\t\t\tresolve(lastInvoker());\n\t\t\t}, maxDuration);\n\t\t\ttimer = setTimeout(() => {\n\t\t\t\tif (maxTimer) _clearTimeout(maxTimer);\n\t\t\t\tmaxTimer = void 0;\n\t\t\t\tresolve(invoke$1());\n\t\t\t}, duration);\n\t\t});\n\t};\n\treturn filter;\n}\nfunction throttleFilter(...args) {\n\tlet lastExec = 0;\n\tlet timer;\n\tlet isLeading = true;\n\tlet lastRejector = noop;\n\tlet lastValue;\n\tlet ms;\n\tlet trailing;\n\tlet leading;\n\tlet rejectOnCancel;\n\tif (!isRef(args[0]) && typeof args[0] === \"object\") ({delay: ms, trailing = true, leading = true, rejectOnCancel = false} = args[0]);\n\telse [ms, trailing = true, leading = true, rejectOnCancel = false] = args;\n\tconst clear = () => {\n\t\tif (timer) {\n\t\t\tclearTimeout(timer);\n\t\t\ttimer = void 0;\n\t\t\tlastRejector();\n\t\t\tlastRejector = noop;\n\t\t}\n\t};\n\tconst filter = (_invoke) => {\n\t\tconst duration = toValue(ms);\n\t\tconst elapsed = Date.now() - lastExec;\n\t\tconst invoke$1 = () => {\n\t\t\treturn lastValue = _invoke();\n\t\t};\n\t\tclear();\n\t\tif (duration <= 0) {\n\t\t\tlastExec = Date.now();\n\t\t\treturn invoke$1();\n\t\t}\n\t\tif (elapsed > duration) {\n\t\t\tlastExec = Date.now();\n\t\t\tif (leading || !isLeading) invoke$1();\n\t\t} else if (trailing) lastValue = new Promise((resolve, reject) => {\n\t\t\tlastRejector = rejectOnCancel ? reject : resolve;\n\t\t\ttimer = setTimeout(() => {\n\t\t\t\tlastExec = Date.now();\n\t\t\t\tisLeading = true;\n\t\t\t\tresolve(invoke$1());\n\t\t\t\tclear();\n\t\t\t}, Math.max(0, duration - elapsed));\n\t\t});\n\t\tif (!leading && !timer) timer = setTimeout(() => isLeading = true, duration);\n\t\tisLeading = false;\n\t\treturn lastValue;\n\t};\n\treturn filter;\n}\n/**\n* EventFilter that gives extra controls to pause and resume the filter\n*\n* @param extendFilter  Extra filter to apply when the PausableFilter is active, default to none\n* @param options Options to configure the filter\n*/\nfunction pausableFilter(extendFilter = bypassFilter, options = {}) {\n\tconst { initialState = \"active\" } = options;\n\tconst isActive = toRef(initialState === \"active\");\n\tfunction pause() {\n\t\tisActive.value = false;\n\t}\n\tfunction resume() {\n\t\tisActive.value = true;\n\t}\n\tconst eventFilter = (...args) => {\n\t\tif (isActive.value) extendFilter(...args);\n\t};\n\treturn {\n\t\tisActive: readonly(isActive),\n\t\tpause,\n\t\tresume,\n\t\teventFilter\n\t};\n}\n\n//#endregion\n//#region utils/general.ts\nfunction promiseTimeout(ms, throwOnTimeout = false, reason = \"Timeout\") {\n\treturn new Promise((resolve, reject) => {\n\t\tif (throwOnTimeout) setTimeout(() => reject(reason), ms);\n\t\telse setTimeout(resolve, ms);\n\t});\n}\nfunction identity(arg) {\n\treturn arg;\n}\n/**\n* Create singleton promise function\n*\n* @example\n* ```\n* const promise = createSingletonPromise(async () => { ... })\n*\n* await promise()\n* await promise() // all of them will be bind to a single promise instance\n* await promise() // and be resolved together\n* ```\n*/\nfunction createSingletonPromise(fn) {\n\tlet _promise;\n\tfunction wrapper() {\n\t\tif (!_promise) _promise = fn();\n\t\treturn _promise;\n\t}\n\twrapper.reset = async () => {\n\t\tconst _prev = _promise;\n\t\t_promise = void 0;\n\t\tif (_prev) await _prev;\n\t};\n\treturn wrapper;\n}\nfunction invoke(fn) {\n\treturn fn();\n}\nfunction containsProp(obj, ...props) {\n\treturn props.some((k) => k in obj);\n}\nfunction increaseWithUnit(target, delta) {\n\tvar _target$match;\n\tif (typeof target === \"number\") return target + delta;\n\tconst value = ((_target$match = target.match(/^-?\\d+\\.?\\d*/)) === null || _target$match === void 0 ? void 0 : _target$match[0]) || \"\";\n\tconst unit = target.slice(value.length);\n\tconst result = Number.parseFloat(value) + delta;\n\tif (Number.isNaN(result)) return target;\n\treturn result + unit;\n}\n/**\n* Get a px value for SSR use, do not rely on this method outside of SSR as REM unit is assumed at 16px, which might not be the case on the client\n*/\nfunction pxValue(px) {\n\treturn px.endsWith(\"rem\") ? Number.parseFloat(px) * 16 : Number.parseFloat(px);\n}\n/**\n* Create a new subset object by giving keys\n*/\nfunction objectPick(obj, keys, omitUndefined = false) {\n\treturn keys.reduce((n, k) => {\n\t\tif (k in obj) {\n\t\t\tif (!omitUndefined || obj[k] !== void 0) n[k] = obj[k];\n\t\t}\n\t\treturn n;\n\t}, {});\n}\n/**\n* Create a new subset object by omit giving keys\n*/\nfunction objectOmit(obj, keys, omitUndefined = false) {\n\treturn Object.fromEntries(Object.entries(obj).filter(([key, value]) => {\n\t\treturn (!omitUndefined || value !== void 0) && !keys.includes(key);\n\t}));\n}\nfunction objectEntries(obj) {\n\treturn Object.entries(obj);\n}\nfunction toArray(value) {\n\treturn Array.isArray(value) ? value : [value];\n}\n\n//#endregion\n//#region utils/port.ts\nfunction cacheStringFunction(fn) {\n\tconst cache = Object.create(null);\n\treturn ((str) => {\n\t\treturn cache[str] || (cache[str] = fn(str));\n\t});\n}\nconst hyphenateRE = /\\B([A-Z])/g;\nconst hyphenate = cacheStringFunction((str) => str.replace(hyphenateRE, \"-$1\").toLowerCase());\nconst camelizeRE = /-(\\w)/g;\nconst camelize = cacheStringFunction((str) => {\n\treturn str.replace(camelizeRE, (_, c) => c ? c.toUpperCase() : \"\");\n});\n\n//#endregion\n//#region utils/vue.ts\nfunction getLifeCycleTarget(target) {\n\treturn target || getCurrentInstance();\n}\n\n//#endregion\n//#region createSharedComposable/index.ts\n/**\n* Make a composable function usable with multiple Vue instances.\n*\n* @see https://vueuse.org/createSharedComposable\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction createSharedComposable(composable) {\n\tif (!isClient) return composable;\n\tlet subscribers = 0;\n\tlet state;\n\tlet scope;\n\tconst dispose = () => {\n\t\tsubscribers -= 1;\n\t\tif (scope && subscribers <= 0) {\n\t\t\tscope.stop();\n\t\t\tstate = void 0;\n\t\t\tscope = void 0;\n\t\t}\n\t};\n\treturn ((...args) => {\n\t\tsubscribers += 1;\n\t\tif (!scope) {\n\t\t\tscope = effectScope(true);\n\t\t\tstate = scope.run(() => composable(...args));\n\t\t}\n\t\ttryOnScopeDispose(dispose);\n\t\treturn state;\n\t});\n}\n\n//#endregion\n//#region extendRef/index.ts\nfunction extendRef(ref$1, extend, { enumerable = false, unwrap = true } = {}) {\n\tfor (const [key, value] of Object.entries(extend)) {\n\t\tif (key === \"value\") continue;\n\t\tif (isRef(value) && unwrap) Object.defineProperty(ref$1, key, {\n\t\t\tget() {\n\t\t\t\treturn value.value;\n\t\t\t},\n\t\t\tset(v) {\n\t\t\t\tvalue.value = v;\n\t\t\t},\n\t\t\tenumerable\n\t\t});\n\t\telse Object.defineProperty(ref$1, key, {\n\t\t\tvalue,\n\t\t\tenumerable\n\t\t});\n\t}\n\treturn ref$1;\n}\n\n//#endregion\n//#region get/index.ts\nfunction get(obj, key) {\n\tif (key == null) return unref(obj);\n\treturn unref(obj)[key];\n}\n\n//#endregion\n//#region isDefined/index.ts\nfunction isDefined(v) {\n\treturn unref(v) != null;\n}\n\n//#endregion\n//#region makeDestructurable/index.ts\n/* @__NO_SIDE_EFFECTS__ */\nfunction makeDestructurable(obj, arr) {\n\tif (typeof Symbol !== \"undefined\") {\n\t\tconst clone = { ...obj };\n\t\tObject.defineProperty(clone, Symbol.iterator, {\n\t\t\tenumerable: false,\n\t\t\tvalue() {\n\t\t\t\tlet index = 0;\n\t\t\t\treturn { next: () => ({\n\t\t\t\t\tvalue: arr[index++],\n\t\t\t\t\tdone: index > arr.length\n\t\t\t\t}) };\n\t\t\t}\n\t\t});\n\t\treturn clone;\n\t} else return Object.assign([...arr], obj);\n}\n\n//#endregion\n//#region reactify/index.ts\n/**\n* Converts plain function into a reactive function.\n* The converted function accepts refs as it's arguments\n* and returns a ComputedRef, with proper typing.\n*\n* @param fn - Source function\n* @param options - Options\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction reactify(fn, options) {\n\tconst unrefFn = (options === null || options === void 0 ? void 0 : options.computedGetter) === false ? unref : toValue;\n\treturn function(...args) {\n\t\treturn computed(() => fn.apply(this, args.map((i) => unrefFn(i))));\n\t};\n}\n/** @deprecated use `reactify` instead */\nconst createReactiveFn = reactify;\n\n//#endregion\n//#region reactifyObject/index.ts\n/**\n* Apply `reactify` to an object\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction reactifyObject(obj, optionsOrKeys = {}) {\n\tlet keys = [];\n\tlet options;\n\tif (Array.isArray(optionsOrKeys)) keys = optionsOrKeys;\n\telse {\n\t\toptions = optionsOrKeys;\n\t\tconst { includeOwnProperties = true } = optionsOrKeys;\n\t\tkeys.push(...Object.keys(obj));\n\t\tif (includeOwnProperties) keys.push(...Object.getOwnPropertyNames(obj));\n\t}\n\treturn Object.fromEntries(keys.map((key) => {\n\t\tconst value = obj[key];\n\t\treturn [key, typeof value === \"function\" ? reactify(value.bind(obj), options) : value];\n\t}));\n}\n\n//#endregion\n//#region toReactive/index.ts\n/**\n* Converts ref to reactive.\n*\n* @see https://vueuse.org/toReactive\n* @param objectRef A ref of object\n*/\nfunction toReactive(objectRef) {\n\tif (!isRef(objectRef)) return reactive(objectRef);\n\treturn reactive(new Proxy({}, {\n\t\tget(_, p, receiver) {\n\t\t\treturn unref(Reflect.get(objectRef.value, p, receiver));\n\t\t},\n\t\tset(_, p, value) {\n\t\t\tif (isRef(objectRef.value[p]) && !isRef(value)) objectRef.value[p].value = value;\n\t\t\telse objectRef.value[p] = value;\n\t\t\treturn true;\n\t\t},\n\t\tdeleteProperty(_, p) {\n\t\t\treturn Reflect.deleteProperty(objectRef.value, p);\n\t\t},\n\t\thas(_, p) {\n\t\t\treturn Reflect.has(objectRef.value, p);\n\t\t},\n\t\townKeys() {\n\t\t\treturn Object.keys(objectRef.value);\n\t\t},\n\t\tgetOwnPropertyDescriptor() {\n\t\t\treturn {\n\t\t\t\tenumerable: true,\n\t\t\t\tconfigurable: true\n\t\t\t};\n\t\t}\n\t}));\n}\n\n//#endregion\n//#region reactiveComputed/index.ts\n/**\n* Computed reactive object.\n*/\nfunction reactiveComputed(fn) {\n\treturn toReactive(computed(fn));\n}\n\n//#endregion\n//#region reactiveOmit/index.ts\n/**\n* Reactively omit fields from a reactive object\n*\n* @see https://vueuse.org/reactiveOmit\n*/\nfunction reactiveOmit(obj, ...keys) {\n\tconst flatKeys = keys.flat();\n\tconst predicate = flatKeys[0];\n\treturn reactiveComputed(() => typeof predicate === \"function\" ? Object.fromEntries(Object.entries(toRefs$1(obj)).filter(([k, v]) => !predicate(toValue(v), k))) : Object.fromEntries(Object.entries(toRefs$1(obj)).filter((e) => !flatKeys.includes(e[0]))));\n}\n\n//#endregion\n//#region reactivePick/index.ts\n/**\n* Reactively pick fields from a reactive object\n*\n* @see https://vueuse.org/reactivePick\n*/\nfunction reactivePick(obj, ...keys) {\n\tconst flatKeys = keys.flat();\n\tconst predicate = flatKeys[0];\n\treturn reactiveComputed(() => typeof predicate === \"function\" ? Object.fromEntries(Object.entries(toRefs$1(obj)).filter(([k, v]) => predicate(toValue(v), k))) : Object.fromEntries(flatKeys.map((k) => [k, toRef(obj, k)])));\n}\n\n//#endregion\n//#region refAutoReset/index.ts\n/**\n* Create a ref which will be reset to the default value after some time.\n*\n* @see https://vueuse.org/refAutoReset\n* @param defaultValue The value which will be set.\n* @param afterMs      A zero-or-greater delay in milliseconds.\n*/\nfunction refAutoReset(defaultValue, afterMs = 1e4) {\n\treturn customRef((track, trigger) => {\n\t\tlet value = toValue(defaultValue);\n\t\tlet timer;\n\t\tconst resetAfter = () => setTimeout(() => {\n\t\t\tvalue = toValue(defaultValue);\n\t\t\ttrigger();\n\t\t}, toValue(afterMs));\n\t\ttryOnScopeDispose(() => {\n\t\t\tclearTimeout(timer);\n\t\t});\n\t\treturn {\n\t\t\tget() {\n\t\t\t\ttrack();\n\t\t\t\treturn value;\n\t\t\t},\n\t\t\tset(newValue) {\n\t\t\t\tvalue = newValue;\n\t\t\t\ttrigger();\n\t\t\t\tclearTimeout(timer);\n\t\t\t\ttimer = resetAfter();\n\t\t\t}\n\t\t};\n\t});\n}\n/** @deprecated use `refAutoReset` instead */\nconst autoResetRef = refAutoReset;\n\n//#endregion\n//#region useDebounceFn/index.ts\n/**\n* Debounce execution of a function.\n*\n* @see https://vueuse.org/useDebounceFn\n* @param  fn          A function to be executed after delay milliseconds debounced.\n* @param  ms          A zero-or-greater delay in milliseconds. For event callbacks, values around 100 or 250 (or even higher) are most useful.\n* @param  options     Options\n*\n* @return A new, debounce, function.\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useDebounceFn(fn, ms = 200, options = {}) {\n\treturn createFilterWrapper(debounceFilter(ms, options), fn);\n}\n\n//#endregion\n//#region refDebounced/index.ts\n/**\n* Debounce updates of a ref.\n*\n* @return A new debounced ref.\n*/\nfunction refDebounced(value, ms = 200, options = {}) {\n\tconst debounced = ref(toValue(value));\n\tconst updater = useDebounceFn(() => {\n\t\tdebounced.value = value.value;\n\t}, ms, options);\n\twatch(value, () => updater());\n\treturn shallowReadonly(debounced);\n}\n/** @deprecated use `refDebounced` instead */\nconst debouncedRef = refDebounced;\n/** @deprecated use `refDebounced` instead */\nconst useDebounce = refDebounced;\n\n//#endregion\n//#region refDefault/index.ts\n/**\n* Apply default value to a ref.\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction refDefault(source, defaultValue) {\n\treturn computed({\n\t\tget() {\n\t\t\tvar _source$value;\n\t\t\treturn (_source$value = source.value) !== null && _source$value !== void 0 ? _source$value : defaultValue;\n\t\t},\n\t\tset(value) {\n\t\t\tsource.value = value;\n\t\t}\n\t});\n}\n\n//#endregion\n//#region refManualReset/index.ts\n/**\n* Create a ref with manual reset functionality.\n*\n* @see https://vueuse.org/refManualReset\n* @param defaultValue The value which will be set.\n*/\nfunction refManualReset(defaultValue) {\n\tlet value = toValue(defaultValue);\n\tlet trigger;\n\tconst reset = () => {\n\t\tvalue = toValue(defaultValue);\n\t\ttrigger();\n\t};\n\tconst refValue = customRef((track, _trigger) => {\n\t\ttrigger = _trigger;\n\t\treturn {\n\t\t\tget() {\n\t\t\t\ttrack();\n\t\t\t\treturn value;\n\t\t\t},\n\t\t\tset(newValue) {\n\t\t\t\tvalue = newValue;\n\t\t\t\ttrigger();\n\t\t\t}\n\t\t};\n\t});\n\trefValue.reset = reset;\n\treturn refValue;\n}\n\n//#endregion\n//#region useThrottleFn/index.ts\n/**\n* Throttle execution of a function. Especially useful for rate limiting\n* execution of handlers on events like resize and scroll.\n*\n* @param   fn             A function to be executed after delay milliseconds. The `this` context and all arguments are passed through, as-is,\n*                                    to `callback` when the throttled-function is executed.\n* @param   ms             A zero-or-greater delay in milliseconds. For event callbacks, values around 100 or 250 (or even higher) are most useful.\n*                                    (default value: 200)\n*\n* @param [trailing] if true, call fn again after the time is up (default value: false)\n*\n* @param [leading] if true, call fn on the leading edge of the ms timeout (default value: true)\n*\n* @param [rejectOnCancel] if true, reject the last call if it's been cancel (default value: false)\n*\n* @return  A new, throttled, function.\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useThrottleFn(fn, ms = 200, trailing = false, leading = true, rejectOnCancel = false) {\n\treturn createFilterWrapper(throttleFilter(ms, trailing, leading, rejectOnCancel), fn);\n}\n\n//#endregion\n//#region refThrottled/index.ts\n/**\n* Throttle execution of a function. Especially useful for rate limiting\n* execution of handlers on events like resize and scroll.\n*\n* @param value Ref value to be watched with throttle effect\n* @param  delay  A zero-or-greater delay in milliseconds. For event callbacks, values around 100 or 250 (or even higher) are most useful.\n* @param trailing if true, update the value again after the delay time is up\n* @param leading if true, update the value on the leading edge of the ms timeout\n*/\nfunction refThrottled(value, delay = 200, trailing = true, leading = true) {\n\tif (delay <= 0) return value;\n\tconst throttled = ref(toValue(value));\n\tconst updater = useThrottleFn(() => {\n\t\tthrottled.value = value.value;\n\t}, delay, trailing, leading);\n\twatch(value, () => updater());\n\treturn throttled;\n}\n/** @deprecated use `refThrottled` instead */\nconst throttledRef = refThrottled;\n/** @deprecated use `refThrottled` instead */\nconst useThrottle = refThrottled;\n\n//#endregion\n//#region refWithControl/index.ts\n/**\n* Fine-grained controls over ref and its reactivity.\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction refWithControl(initial, options = {}) {\n\tlet source = initial;\n\tlet track;\n\tlet trigger;\n\tconst ref$1 = customRef((_track, _trigger) => {\n\t\ttrack = _track;\n\t\ttrigger = _trigger;\n\t\treturn {\n\t\t\tget() {\n\t\t\t\treturn get$1();\n\t\t\t},\n\t\t\tset(v) {\n\t\t\t\tset$1(v);\n\t\t\t}\n\t\t};\n\t});\n\tfunction get$1(tracking = true) {\n\t\tif (tracking) track();\n\t\treturn source;\n\t}\n\tfunction set$1(value, triggering = true) {\n\t\tvar _options$onBeforeChan, _options$onChanged;\n\t\tif (value === source) return;\n\t\tconst old = source;\n\t\tif (((_options$onBeforeChan = options.onBeforeChange) === null || _options$onBeforeChan === void 0 ? void 0 : _options$onBeforeChan.call(options, value, old)) === false) return;\n\t\tsource = value;\n\t\t(_options$onChanged = options.onChanged) === null || _options$onChanged === void 0 || _options$onChanged.call(options, value, old);\n\t\tif (triggering) trigger();\n\t}\n\t/**\n\t* Get the value without tracked in the reactivity system\n\t*/\n\tconst untrackedGet = () => get$1(false);\n\t/**\n\t* Set the value without triggering the reactivity system\n\t*/\n\tconst silentSet = (v) => set$1(v, false);\n\t/**\n\t* Get the value without tracked in the reactivity system.\n\t*\n\t* Alias for `untrackedGet()`\n\t*/\n\tconst peek = () => get$1(false);\n\t/**\n\t* Set the value without triggering the reactivity system\n\t*\n\t* Alias for `silentSet(v)`\n\t*/\n\tconst lay = (v) => set$1(v, false);\n\treturn extendRef(ref$1, {\n\t\tget: get$1,\n\t\tset: set$1,\n\t\tuntrackedGet,\n\t\tsilentSet,\n\t\tpeek,\n\t\tlay\n\t}, { enumerable: true });\n}\n/** @deprecated use `refWithControl` instead */\nconst controlledRef = refWithControl;\n\n//#endregion\n//#region set/index.ts\n/**\n*  Shorthand for `ref.value = x`\n*/\nfunction set(...args) {\n\tif (args.length === 2) {\n\t\tconst [ref$1, value] = args;\n\t\tref$1.value = value;\n\t}\n\tif (args.length === 3) {\n\t\tconst [target, key, value] = args;\n\t\ttarget[key] = value;\n\t}\n}\n\n//#endregion\n//#region watchWithFilter/index.ts\nfunction watchWithFilter(source, cb, options = {}) {\n\tconst { eventFilter = bypassFilter,...watchOptions } = options;\n\treturn watch(source, createFilterWrapper(eventFilter, cb), watchOptions);\n}\n\n//#endregion\n//#region watchPausable/index.ts\n/** @deprecated Use Vue's built-in `watch` instead. This function will be removed in future version. */\nfunction watchPausable(source, cb, options = {}) {\n\tconst { eventFilter: filter, initialState = \"active\",...watchOptions } = options;\n\tconst { eventFilter, pause, resume, isActive } = pausableFilter(filter, { initialState });\n\treturn {\n\t\tstop: watchWithFilter(source, cb, {\n\t\t\t...watchOptions,\n\t\t\teventFilter\n\t\t}),\n\t\tpause,\n\t\tresume,\n\t\tisActive\n\t};\n}\n/** @deprecated Use Vue's built-in `watch` instead. This function will be removed in future version. */\nconst pausableWatch = watchPausable;\n\n//#endregion\n//#region syncRef/index.ts\n/**\n* Two-way refs synchronization.\n* From the set theory perspective to restrict the option's type\n* Check in the following order:\n* 1. L = R\n* 2. L ∩ R ≠ ∅\n* 3. L ⊆ R\n* 4. L ∩ R = ∅\n*/\nfunction syncRef(left, right, ...[options]) {\n\tconst { flush = \"sync\", deep = false, immediate = true, direction = \"both\", transform = {} } = options || {};\n\tconst watchers = [];\n\tconst transformLTR = \"ltr\" in transform && transform.ltr || ((v) => v);\n\tconst transformRTL = \"rtl\" in transform && transform.rtl || ((v) => v);\n\tif (direction === \"both\" || direction === \"ltr\") watchers.push(watchPausable(left, (newValue) => {\n\t\twatchers.forEach((w) => w.pause());\n\t\tright.value = transformLTR(newValue);\n\t\twatchers.forEach((w) => w.resume());\n\t}, {\n\t\tflush,\n\t\tdeep,\n\t\timmediate\n\t}));\n\tif (direction === \"both\" || direction === \"rtl\") watchers.push(watchPausable(right, (newValue) => {\n\t\twatchers.forEach((w) => w.pause());\n\t\tleft.value = transformRTL(newValue);\n\t\twatchers.forEach((w) => w.resume());\n\t}, {\n\t\tflush,\n\t\tdeep,\n\t\timmediate\n\t}));\n\tconst stop = () => {\n\t\twatchers.forEach((w) => w.stop());\n\t};\n\treturn stop;\n}\n\n//#endregion\n//#region syncRefs/index.ts\n/**\n* Keep target ref(s) in sync with the source ref\n*\n* @param source source ref\n* @param targets\n*/\nfunction syncRefs(source, targets, options = {}) {\n\tconst { flush = \"sync\", deep = false, immediate = true } = options;\n\tconst targetsArray = toArray(targets);\n\treturn watch(source, (newValue) => targetsArray.forEach((target) => target.value = newValue), {\n\t\tflush,\n\t\tdeep,\n\t\timmediate\n\t});\n}\n\n//#endregion\n//#region toRefs/index.ts\n/**\n* Extended `toRefs` that also accepts refs of an object.\n*\n* @see https://vueuse.org/toRefs\n* @param objectRef A ref or normal object or array.\n* @param options Options\n*/\nfunction toRefs(objectRef, options = {}) {\n\tif (!isRef(objectRef)) return toRefs$1(objectRef);\n\tconst result = Array.isArray(objectRef.value) ? Array.from({ length: objectRef.value.length }) : {};\n\tfor (const key in objectRef.value) result[key] = customRef(() => ({\n\t\tget() {\n\t\t\treturn objectRef.value[key];\n\t\t},\n\t\tset(v) {\n\t\t\tvar _toValue;\n\t\t\tif ((_toValue = toValue(options.replaceRef)) !== null && _toValue !== void 0 ? _toValue : true) if (Array.isArray(objectRef.value)) {\n\t\t\t\tconst copy = [...objectRef.value];\n\t\t\t\tcopy[key] = v;\n\t\t\t\tobjectRef.value = copy;\n\t\t\t} else {\n\t\t\t\tconst newObject = {\n\t\t\t\t\t...objectRef.value,\n\t\t\t\t\t[key]: v\n\t\t\t\t};\n\t\t\t\tObject.setPrototypeOf(newObject, Object.getPrototypeOf(objectRef.value));\n\t\t\t\tobjectRef.value = newObject;\n\t\t\t}\n\t\t\telse objectRef.value[key] = v;\n\t\t}\n\t}));\n\treturn result;\n}\n\n//#endregion\n//#region tryOnBeforeMount/index.ts\n/**\n* Call onBeforeMount() if it's inside a component lifecycle, if not, just call the function\n*\n* @param fn\n* @param sync if set to false, it will run in the nextTick() of Vue\n* @param target\n*/\nfunction tryOnBeforeMount(fn, sync = true, target) {\n\tif (getLifeCycleTarget(target)) onBeforeMount(fn, target);\n\telse if (sync) fn();\n\telse nextTick(fn);\n}\n\n//#endregion\n//#region tryOnBeforeUnmount/index.ts\n/**\n* Call onBeforeUnmount() if it's inside a component lifecycle, if not, do nothing\n*\n* @param fn\n* @param target\n*/\nfunction tryOnBeforeUnmount(fn, target) {\n\tif (getLifeCycleTarget(target)) onBeforeUnmount(fn, target);\n}\n\n//#endregion\n//#region tryOnMounted/index.ts\n/**\n* Call onMounted() if it's inside a component lifecycle, if not, just call the function\n*\n* @param fn\n* @param sync if set to false, it will run in the nextTick() of Vue\n* @param target\n*/\nfunction tryOnMounted(fn, sync = true, target) {\n\tif (getLifeCycleTarget(target)) onMounted(fn, target);\n\telse if (sync) fn();\n\telse nextTick(fn);\n}\n\n//#endregion\n//#region tryOnUnmounted/index.ts\n/**\n* Call onUnmounted() if it's inside a component lifecycle, if not, do nothing\n*\n* @param fn\n* @param target\n*/\nfunction tryOnUnmounted(fn, target) {\n\tif (getLifeCycleTarget(target)) onUnmounted(fn, target);\n}\n\n//#endregion\n//#region until/index.ts\nfunction createUntil(r, isNot = false) {\n\tfunction toMatch(condition, { flush = \"sync\", deep = false, timeout, throwOnTimeout } = {}) {\n\t\tlet stop = null;\n\t\tconst promises = [new Promise((resolve) => {\n\t\t\tstop = watch(r, (v) => {\n\t\t\t\tif (condition(v) !== isNot) {\n\t\t\t\t\tif (stop) stop();\n\t\t\t\t\telse nextTick(() => stop === null || stop === void 0 ? void 0 : stop());\n\t\t\t\t\tresolve(v);\n\t\t\t\t}\n\t\t\t}, {\n\t\t\t\tflush,\n\t\t\t\tdeep,\n\t\t\t\timmediate: true\n\t\t\t});\n\t\t})];\n\t\tif (timeout != null) promises.push(promiseTimeout(timeout, throwOnTimeout).then(() => toValue(r)).finally(() => stop === null || stop === void 0 ? void 0 : stop()));\n\t\treturn Promise.race(promises);\n\t}\n\tfunction toBe(value, options) {\n\t\tif (!isRef(value)) return toMatch((v) => v === value, options);\n\t\tconst { flush = \"sync\", deep = false, timeout, throwOnTimeout } = options !== null && options !== void 0 ? options : {};\n\t\tlet stop = null;\n\t\tconst promises = [new Promise((resolve) => {\n\t\t\tstop = watch([r, value], ([v1, v2]) => {\n\t\t\t\tif (isNot !== (v1 === v2)) {\n\t\t\t\t\tif (stop) stop();\n\t\t\t\t\telse nextTick(() => stop === null || stop === void 0 ? void 0 : stop());\n\t\t\t\t\tresolve(v1);\n\t\t\t\t}\n\t\t\t}, {\n\t\t\t\tflush,\n\t\t\t\tdeep,\n\t\t\t\timmediate: true\n\t\t\t});\n\t\t})];\n\t\tif (timeout != null) promises.push(promiseTimeout(timeout, throwOnTimeout).then(() => toValue(r)).finally(() => {\n\t\t\tstop === null || stop === void 0 || stop();\n\t\t\treturn toValue(r);\n\t\t}));\n\t\treturn Promise.race(promises);\n\t}\n\tfunction toBeTruthy(options) {\n\t\treturn toMatch((v) => Boolean(v), options);\n\t}\n\tfunction toBeNull(options) {\n\t\treturn toBe(null, options);\n\t}\n\tfunction toBeUndefined(options) {\n\t\treturn toBe(void 0, options);\n\t}\n\tfunction toBeNaN(options) {\n\t\treturn toMatch(Number.isNaN, options);\n\t}\n\tfunction toContains(value, options) {\n\t\treturn toMatch((v) => {\n\t\t\tconst array = Array.from(v);\n\t\t\treturn array.includes(value) || array.includes(toValue(value));\n\t\t}, options);\n\t}\n\tfunction changed(options) {\n\t\treturn changedTimes(1, options);\n\t}\n\tfunction changedTimes(n = 1, options) {\n\t\tlet count = -1;\n\t\treturn toMatch(() => {\n\t\t\tcount += 1;\n\t\t\treturn count >= n;\n\t\t}, options);\n\t}\n\tif (Array.isArray(toValue(r))) return {\n\t\ttoMatch,\n\t\ttoContains,\n\t\tchanged,\n\t\tchangedTimes,\n\t\tget not() {\n\t\t\treturn createUntil(r, !isNot);\n\t\t}\n\t};\n\telse return {\n\t\ttoMatch,\n\t\ttoBe,\n\t\ttoBeTruthy,\n\t\ttoBeNull,\n\t\ttoBeNaN,\n\t\ttoBeUndefined,\n\t\tchanged,\n\t\tchangedTimes,\n\t\tget not() {\n\t\t\treturn createUntil(r, !isNot);\n\t\t}\n\t};\n}\nfunction until(r) {\n\treturn createUntil(r);\n}\n\n//#endregion\n//#region useArrayDifference/index.ts\nfunction defaultComparator(value, othVal) {\n\treturn value === othVal;\n}\n/**\n* Reactive get array difference of two array\n* @see https://vueuse.org/useArrayDifference\n* @returns - the difference of two array\n* @param args\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useArrayDifference(...args) {\n\tvar _args$, _args$2;\n\tconst list = args[0];\n\tconst values = args[1];\n\tlet compareFn = (_args$ = args[2]) !== null && _args$ !== void 0 ? _args$ : defaultComparator;\n\tconst { symmetric = false } = (_args$2 = args[3]) !== null && _args$2 !== void 0 ? _args$2 : {};\n\tif (typeof compareFn === \"string\") {\n\t\tconst key = compareFn;\n\t\tcompareFn = (value, othVal) => value[key] === othVal[key];\n\t}\n\tconst diff1 = computed(() => toValue(list).filter((x) => toValue(values).findIndex((y) => compareFn(x, y)) === -1));\n\tif (symmetric) {\n\t\tconst diff2 = computed(() => toValue(values).filter((x) => toValue(list).findIndex((y) => compareFn(x, y)) === -1));\n\t\treturn computed(() => symmetric ? [...toValue(diff1), ...toValue(diff2)] : toValue(diff1));\n\t} else return diff1;\n}\n\n//#endregion\n//#region useArrayEvery/index.ts\n/**\n* Reactive `Array.every`\n*\n* @see https://vueuse.org/useArrayEvery\n* @param list - the array was called upon.\n* @param fn - a function to test each element.\n*\n* @returns **true** if the `fn` function returns a **truthy** value for every element from the array. Otherwise, **false**.\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useArrayEvery(list, fn) {\n\treturn computed(() => toValue(list).every((element, index, array) => fn(toValue(element), index, array)));\n}\n\n//#endregion\n//#region useArrayFilter/index.ts\n/**\n* Reactive `Array.filter`\n*\n* @see https://vueuse.org/useArrayFilter\n* @param list - the array was called upon.\n* @param fn - a function that is called for every element of the given `list`. Each time `fn` executes, the returned value is added to the new array.\n*\n* @returns a shallow copy of a portion of the given array, filtered down to just the elements from the given array that pass the test implemented by the provided function. If no elements pass the test, an empty array will be returned.\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useArrayFilter(list, fn) {\n\treturn computed(() => toValue(list).map((i) => toValue(i)).filter(fn));\n}\n\n//#endregion\n//#region useArrayFind/index.ts\n/**\n* Reactive `Array.find`\n*\n* @see https://vueuse.org/useArrayFind\n* @param list - the array was called upon.\n* @param fn - a function to test each element.\n*\n* @returns the first element in the array that satisfies the provided testing function. Otherwise, undefined is returned.\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useArrayFind(list, fn) {\n\treturn computed(() => toValue(toValue(list).find((element, index, array) => fn(toValue(element), index, array))));\n}\n\n//#endregion\n//#region useArrayFindIndex/index.ts\n/**\n* Reactive `Array.findIndex`\n*\n* @see https://vueuse.org/useArrayFindIndex\n* @param list - the array was called upon.\n* @param fn - a function to test each element.\n*\n* @returns the index of the first element in the array that passes the test. Otherwise, \"-1\".\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useArrayFindIndex(list, fn) {\n\treturn computed(() => toValue(list).findIndex((element, index, array) => fn(toValue(element), index, array)));\n}\n\n//#endregion\n//#region useArrayFindLast/index.ts\nfunction findLast(arr, cb) {\n\tlet index = arr.length;\n\twhile (index-- > 0) if (cb(arr[index], index, arr)) return arr[index];\n}\n/**\n* Reactive `Array.findLast`\n*\n* @see https://vueuse.org/useArrayFindLast\n* @param list - the array was called upon.\n* @param fn - a function to test each element.\n*\n* @returns the last element in the array that satisfies the provided testing function. Otherwise, undefined is returned.\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useArrayFindLast(list, fn) {\n\treturn computed(() => toValue(!Array.prototype.findLast ? findLast(toValue(list), (element, index, array) => fn(toValue(element), index, array)) : toValue(list).findLast((element, index, array) => fn(toValue(element), index, array))));\n}\n\n//#endregion\n//#region useArrayIncludes/index.ts\nfunction isArrayIncludesOptions(obj) {\n\treturn isObject(obj) && containsProp(obj, \"formIndex\", \"comparator\");\n}\n/**\n* Reactive `Array.includes`\n*\n* @see https://vueuse.org/useArrayIncludes\n*\n* @returns true if the `value` is found in the array. Otherwise, false.\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useArrayIncludes(...args) {\n\tvar _comparator;\n\tconst list = args[0];\n\tconst value = args[1];\n\tlet comparator = args[2];\n\tlet formIndex = 0;\n\tif (isArrayIncludesOptions(comparator)) {\n\t\tvar _comparator$fromIndex;\n\t\tformIndex = (_comparator$fromIndex = comparator.fromIndex) !== null && _comparator$fromIndex !== void 0 ? _comparator$fromIndex : 0;\n\t\tcomparator = comparator.comparator;\n\t}\n\tif (typeof comparator === \"string\") {\n\t\tconst key = comparator;\n\t\tcomparator = (element, value$1) => element[key] === toValue(value$1);\n\t}\n\tcomparator = (_comparator = comparator) !== null && _comparator !== void 0 ? _comparator : ((element, value$1) => element === toValue(value$1));\n\treturn computed(() => toValue(list).slice(formIndex).some((element, index, array) => comparator(toValue(element), toValue(value), index, toValue(array))));\n}\n\n//#endregion\n//#region useArrayJoin/index.ts\n/**\n* Reactive `Array.join`\n*\n* @see https://vueuse.org/useArrayJoin\n* @param list - the array was called upon.\n* @param separator - a string to separate each pair of adjacent elements of the array. If omitted, the array elements are separated with a comma (\",\").\n*\n* @returns a string with all array elements joined. If arr.length is 0, the empty string is returned.\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useArrayJoin(list, separator) {\n\treturn computed(() => toValue(list).map((i) => toValue(i)).join(toValue(separator)));\n}\n\n//#endregion\n//#region useArrayMap/index.ts\n/**\n* Reactive `Array.map`\n*\n* @see https://vueuse.org/useArrayMap\n* @param list - the array was called upon.\n* @param fn - a function that is called for every element of the given `list`. Each time `fn` executes, the returned value is added to the new array.\n*\n* @returns a new array with each element being the result of the callback function.\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useArrayMap(list, fn) {\n\treturn computed(() => toValue(list).map((i) => toValue(i)).map(fn));\n}\n\n//#endregion\n//#region useArrayReduce/index.ts\n/**\n* Reactive `Array.reduce`\n*\n* @see https://vueuse.org/useArrayReduce\n* @param list - the array was called upon.\n* @param reducer - a \"reducer\" function.\n* @param args\n*\n* @returns the value that results from running the \"reducer\" callback function to completion over the entire array.\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useArrayReduce(list, reducer, ...args) {\n\tconst reduceCallback = (sum, value, index) => reducer(toValue(sum), toValue(value), index);\n\treturn computed(() => {\n\t\tconst resolved = toValue(list);\n\t\treturn args.length ? resolved.reduce(reduceCallback, typeof args[0] === \"function\" ? toValue(args[0]()) : toValue(args[0])) : resolved.reduce(reduceCallback);\n\t});\n}\n\n//#endregion\n//#region useArraySome/index.ts\n/**\n* Reactive `Array.some`\n*\n* @see https://vueuse.org/useArraySome\n* @param list - the array was called upon.\n* @param fn - a function to test each element.\n*\n* @returns **true** if the `fn` function returns a **truthy** value for any element from the array. Otherwise, **false**.\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useArraySome(list, fn) {\n\treturn computed(() => toValue(list).some((element, index, array) => fn(toValue(element), index, array)));\n}\n\n//#endregion\n//#region useArrayUnique/index.ts\nfunction uniq(array) {\n\treturn Array.from(new Set(array));\n}\nfunction uniqueElementsBy(array, fn) {\n\treturn array.reduce((acc, v) => {\n\t\tif (!acc.some((x) => fn(v, x, array))) acc.push(v);\n\t\treturn acc;\n\t}, []);\n}\n/**\n* reactive unique array\n* @see https://vueuse.org/useArrayUnique\n* @param list - the array was called upon.\n* @param compareFn\n* @returns A computed ref that returns a unique array of items.\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useArrayUnique(list, compareFn) {\n\treturn computed(() => {\n\t\tconst resolvedList = toValue(list).map((element) => toValue(element));\n\t\treturn compareFn ? uniqueElementsBy(resolvedList, compareFn) : uniq(resolvedList);\n\t});\n}\n\n//#endregion\n//#region useCounter/index.ts\n/**\n* Basic counter with utility functions.\n*\n* @see https://vueuse.org/useCounter\n* @param [initialValue]\n* @param options\n*/\nfunction useCounter(initialValue = 0, options = {}) {\n\tlet _initialValue = unref(initialValue);\n\tconst count = shallowRef(initialValue);\n\tconst { max = Number.POSITIVE_INFINITY, min = Number.NEGATIVE_INFINITY } = options;\n\tconst inc = (delta = 1) => count.value = Math.max(Math.min(max, count.value + delta), min);\n\tconst dec = (delta = 1) => count.value = Math.min(Math.max(min, count.value - delta), max);\n\tconst get$1 = () => count.value;\n\tconst set$1 = (val) => count.value = Math.max(min, Math.min(max, val));\n\tconst reset = (val = _initialValue) => {\n\t\t_initialValue = val;\n\t\treturn set$1(val);\n\t};\n\treturn {\n\t\tcount: shallowReadonly(count),\n\t\tinc,\n\t\tdec,\n\t\tget: get$1,\n\t\tset: set$1,\n\t\treset\n\t};\n}\n\n//#endregion\n//#region useDateFormat/index.ts\nconst REGEX_PARSE = /^(\\d{4})[-/]?(\\d{1,2})?[-/]?(\\d{0,2})[T\\s]*(\\d{1,2})?:?(\\d{1,2})?:?(\\d{1,2})?[.:]?(\\d+)?$/i;\nconst REGEX_FORMAT = /[YMDHhms]o|\\[([^\\]]+)\\]|Y{1,4}|M{1,4}|D{1,2}|d{1,4}|H{1,2}|h{1,2}|a{1,2}|A{1,2}|m{1,2}|s{1,2}|Z{1,2}|z{1,4}|SSS/g;\nfunction defaultMeridiem(hours, minutes, isLowercase, hasPeriod) {\n\tlet m = hours < 12 ? \"AM\" : \"PM\";\n\tif (hasPeriod) m = m.split(\"\").reduce((acc, curr) => acc += `${curr}.`, \"\");\n\treturn isLowercase ? m.toLowerCase() : m;\n}\nfunction formatOrdinal(num) {\n\tconst suffixes = [\n\t\t\"th\",\n\t\t\"st\",\n\t\t\"nd\",\n\t\t\"rd\"\n\t];\n\tconst v = num % 100;\n\treturn num + (suffixes[(v - 20) % 10] || suffixes[v] || suffixes[0]);\n}\nfunction formatDate(date, formatStr, options = {}) {\n\tvar _options$customMeridi;\n\tconst years = date.getFullYear();\n\tconst month = date.getMonth();\n\tconst days = date.getDate();\n\tconst hours = date.getHours();\n\tconst minutes = date.getMinutes();\n\tconst seconds = date.getSeconds();\n\tconst milliseconds = date.getMilliseconds();\n\tconst day = date.getDay();\n\tconst meridiem = (_options$customMeridi = options.customMeridiem) !== null && _options$customMeridi !== void 0 ? _options$customMeridi : defaultMeridiem;\n\tconst stripTimeZone = (dateString) => {\n\t\tvar _dateString$split$;\n\t\treturn (_dateString$split$ = dateString.split(\" \")[1]) !== null && _dateString$split$ !== void 0 ? _dateString$split$ : \"\";\n\t};\n\tconst matches = {\n\t\tYo: () => formatOrdinal(years),\n\t\tYY: () => String(years).slice(-2),\n\t\tYYYY: () => years,\n\t\tM: () => month + 1,\n\t\tMo: () => formatOrdinal(month + 1),\n\t\tMM: () => `${month + 1}`.padStart(2, \"0\"),\n\t\tMMM: () => date.toLocaleDateString(toValue(options.locales), { month: \"short\" }),\n\t\tMMMM: () => date.toLocaleDateString(toValue(options.locales), { month: \"long\" }),\n\t\tD: () => String(days),\n\t\tDo: () => formatOrdinal(days),\n\t\tDD: () => `${days}`.padStart(2, \"0\"),\n\t\tH: () => String(hours),\n\t\tHo: () => formatOrdinal(hours),\n\t\tHH: () => `${hours}`.padStart(2, \"0\"),\n\t\th: () => `${hours % 12 || 12}`.padStart(1, \"0\"),\n\t\tho: () => formatOrdinal(hours % 12 || 12),\n\t\thh: () => `${hours % 12 || 12}`.padStart(2, \"0\"),\n\t\tm: () => String(minutes),\n\t\tmo: () => formatOrdinal(minutes),\n\t\tmm: () => `${minutes}`.padStart(2, \"0\"),\n\t\ts: () => String(seconds),\n\t\tso: () => formatOrdinal(seconds),\n\t\tss: () => `${seconds}`.padStart(2, \"0\"),\n\t\tSSS: () => `${milliseconds}`.padStart(3, \"0\"),\n\t\td: () => day,\n\t\tdd: () => date.toLocaleDateString(toValue(options.locales), { weekday: \"narrow\" }),\n\t\tddd: () => date.toLocaleDateString(toValue(options.locales), { weekday: \"short\" }),\n\t\tdddd: () => date.toLocaleDateString(toValue(options.locales), { weekday: \"long\" }),\n\t\tA: () => meridiem(hours, minutes),\n\t\tAA: () => meridiem(hours, minutes, false, true),\n\t\ta: () => meridiem(hours, minutes, true),\n\t\taa: () => meridiem(hours, minutes, true, true),\n\t\tz: () => stripTimeZone(date.toLocaleDateString(toValue(options.locales), { timeZoneName: \"shortOffset\" })),\n\t\tzz: () => stripTimeZone(date.toLocaleDateString(toValue(options.locales), { timeZoneName: \"shortOffset\" })),\n\t\tzzz: () => stripTimeZone(date.toLocaleDateString(toValue(options.locales), { timeZoneName: \"shortOffset\" })),\n\t\tzzzz: () => stripTimeZone(date.toLocaleDateString(toValue(options.locales), { timeZoneName: \"longOffset\" }))\n\t};\n\treturn formatStr.replace(REGEX_FORMAT, (match, $1) => {\n\t\tvar _ref, _matches$match;\n\t\treturn (_ref = $1 !== null && $1 !== void 0 ? $1 : (_matches$match = matches[match]) === null || _matches$match === void 0 ? void 0 : _matches$match.call(matches)) !== null && _ref !== void 0 ? _ref : match;\n\t});\n}\nfunction normalizeDate(date) {\n\tif (date === null) return /* @__PURE__ */ new Date(NaN);\n\tif (date === void 0) return /* @__PURE__ */ new Date();\n\tif (date instanceof Date) return new Date(date);\n\tif (typeof date === \"string\" && !/Z$/i.test(date)) {\n\t\tconst d = date.match(REGEX_PARSE);\n\t\tif (d) {\n\t\t\tconst m = d[2] - 1 || 0;\n\t\t\tconst ms = (d[7] || \"0\").substring(0, 3);\n\t\t\treturn new Date(d[1], m, d[3] || 1, d[4] || 0, d[5] || 0, d[6] || 0, ms);\n\t\t}\n\t}\n\treturn new Date(date);\n}\n/**\n* Get the formatted date according to the string of tokens passed in.\n*\n* @see https://vueuse.org/useDateFormat\n* @param date - The date to format, can either be a `Date` object, a timestamp, or a string\n* @param formatStr - The combination of tokens to format the date\n* @param options - UseDateFormatOptions\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useDateFormat(date, formatStr = \"HH:mm:ss\", options = {}) {\n\treturn computed(() => formatDate(normalizeDate(toValue(date)), toValue(formatStr), options));\n}\n\n//#endregion\n//#region useIntervalFn/index.ts\n/**\n* Wrapper for `setInterval` with controls\n*\n* @see https://vueuse.org/useIntervalFn\n* @param cb\n* @param interval\n* @param options\n*/\nfunction useIntervalFn(cb, interval = 1e3, options = {}) {\n\tconst { immediate = true, immediateCallback = false } = options;\n\tlet timer = null;\n\tconst isActive = shallowRef(false);\n\tfunction clean() {\n\t\tif (timer) {\n\t\t\tclearInterval(timer);\n\t\t\ttimer = null;\n\t\t}\n\t}\n\tfunction pause() {\n\t\tisActive.value = false;\n\t\tclean();\n\t}\n\tfunction resume() {\n\t\tconst intervalValue = toValue(interval);\n\t\tif (intervalValue <= 0) return;\n\t\tisActive.value = true;\n\t\tif (immediateCallback) cb();\n\t\tclean();\n\t\tif (isActive.value) timer = setInterval(cb, intervalValue);\n\t}\n\tif (immediate && isClient) resume();\n\tif (isRef(interval) || typeof interval === \"function\") tryOnScopeDispose(watch(interval, () => {\n\t\tif (isActive.value && isClient) resume();\n\t}));\n\ttryOnScopeDispose(pause);\n\treturn {\n\t\tisActive: shallowReadonly(isActive),\n\t\tpause,\n\t\tresume\n\t};\n}\n\n//#endregion\n//#region useInterval/index.ts\nfunction useInterval(interval = 1e3, options = {}) {\n\tconst { controls: exposeControls = false, immediate = true, callback } = options;\n\tconst counter = shallowRef(0);\n\tconst update = () => counter.value += 1;\n\tconst reset = () => {\n\t\tcounter.value = 0;\n\t};\n\tconst controls = useIntervalFn(callback ? () => {\n\t\tupdate();\n\t\tcallback(counter.value);\n\t} : update, interval, { immediate });\n\tif (exposeControls) return {\n\t\tcounter: shallowReadonly(counter),\n\t\treset,\n\t\t...controls\n\t};\n\telse return shallowReadonly(counter);\n}\n\n//#endregion\n//#region useLastChanged/index.ts\nfunction useLastChanged(source, options = {}) {\n\tvar _options$initialValue;\n\tconst ms = shallowRef((_options$initialValue = options.initialValue) !== null && _options$initialValue !== void 0 ? _options$initialValue : null);\n\twatch(source, () => ms.value = timestamp(), options);\n\treturn shallowReadonly(ms);\n}\n\n//#endregion\n//#region useTimeoutFn/index.ts\n/**\n* Wrapper for `setTimeout` with controls.\n*\n* @param cb\n* @param interval\n* @param options\n*/\nfunction useTimeoutFn(cb, interval, options = {}) {\n\tconst { immediate = true, immediateCallback = false } = options;\n\tconst isPending = shallowRef(false);\n\tlet timer;\n\tfunction clear() {\n\t\tif (timer) {\n\t\t\tclearTimeout(timer);\n\t\t\ttimer = void 0;\n\t\t}\n\t}\n\tfunction stop() {\n\t\tisPending.value = false;\n\t\tclear();\n\t}\n\tfunction start(...args) {\n\t\tif (immediateCallback) cb();\n\t\tclear();\n\t\tisPending.value = true;\n\t\ttimer = setTimeout(() => {\n\t\t\tisPending.value = false;\n\t\t\ttimer = void 0;\n\t\t\tcb(...args);\n\t\t}, toValue(interval));\n\t}\n\tif (immediate) {\n\t\tisPending.value = true;\n\t\tif (isClient) start();\n\t}\n\ttryOnScopeDispose(stop);\n\treturn {\n\t\tisPending: shallowReadonly(isPending),\n\t\tstart,\n\t\tstop\n\t};\n}\n\n//#endregion\n//#region useTimeout/index.ts\nfunction useTimeout(interval = 1e3, options = {}) {\n\tconst { controls: exposeControls = false, callback } = options;\n\tconst controls = useTimeoutFn(callback !== null && callback !== void 0 ? callback : noop, interval, options);\n\tconst ready = computed(() => !controls.isPending.value);\n\tif (exposeControls) return {\n\t\tready,\n\t\t...controls\n\t};\n\telse return ready;\n}\n\n//#endregion\n//#region useToNumber/index.ts\n/**\n* Reactively convert a string ref to number.\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useToNumber(value, options = {}) {\n\tconst { method = \"parseFloat\", radix, nanToZero } = options;\n\treturn computed(() => {\n\t\tlet resolved = toValue(value);\n\t\tif (typeof method === \"function\") resolved = method(resolved);\n\t\telse if (typeof resolved === \"string\") resolved = Number[method](resolved, radix);\n\t\tif (nanToZero && Number.isNaN(resolved)) resolved = 0;\n\t\treturn resolved;\n\t});\n}\n\n//#endregion\n//#region useToString/index.ts\n/**\n* Reactively convert a ref to string.\n*\n* @see https://vueuse.org/useToString\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useToString(value) {\n\treturn computed(() => `${toValue(value)}`);\n}\n\n//#endregion\n//#region useToggle/index.ts\n/**\n* A boolean ref with a toggler\n*\n* @see https://vueuse.org/useToggle\n* @param [initialValue]\n* @param options\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useToggle(initialValue = false, options = {}) {\n\tconst { truthyValue = true, falsyValue = false } = options;\n\tconst valueIsRef = isRef(initialValue);\n\tconst _value = shallowRef(initialValue);\n\tfunction toggle(value) {\n\t\tif (arguments.length) {\n\t\t\t_value.value = value;\n\t\t\treturn _value.value;\n\t\t} else {\n\t\t\tconst truthy = toValue(truthyValue);\n\t\t\t_value.value = _value.value === truthy ? toValue(falsyValue) : truthy;\n\t\t\treturn _value.value;\n\t\t}\n\t}\n\tif (valueIsRef) return toggle;\n\telse return [_value, toggle];\n}\n\n//#endregion\n//#region watchArray/index.ts\n/**\n* Watch for an array with additions and removals.\n*\n* @see https://vueuse.org/watchArray\n*/\nfunction watchArray(source, cb, options) {\n\tlet oldList = (options === null || options === void 0 ? void 0 : options.immediate) ? [] : [...typeof source === \"function\" ? source() : Array.isArray(source) ? source : toValue(source)];\n\treturn watch(source, (newList, _, onCleanup) => {\n\t\tconst oldListRemains = Array.from({ length: oldList.length });\n\t\tconst added = [];\n\t\tfor (const obj of newList) {\n\t\t\tlet found = false;\n\t\t\tfor (let i = 0; i < oldList.length; i++) if (!oldListRemains[i] && obj === oldList[i]) {\n\t\t\t\toldListRemains[i] = true;\n\t\t\t\tfound = true;\n\t\t\t\tbreak;\n\t\t\t}\n\t\t\tif (!found) added.push(obj);\n\t\t}\n\t\tconst removed = oldList.filter((_$1, i) => !oldListRemains[i]);\n\t\tcb(newList, oldList, added, removed, onCleanup);\n\t\toldList = [...newList];\n\t}, options);\n}\n\n//#endregion\n//#region watchAtMost/index.ts\nfunction watchAtMost(source, cb, options) {\n\tconst { count,...watchOptions } = options;\n\tconst current = shallowRef(0);\n\tconst { stop, resume, pause } = watchWithFilter(source, (...args) => {\n\t\tcurrent.value += 1;\n\t\tif (current.value >= toValue(count)) nextTick(() => stop());\n\t\tcb(...args);\n\t}, watchOptions);\n\treturn {\n\t\tcount: current,\n\t\tstop,\n\t\tresume,\n\t\tpause\n\t};\n}\n\n//#endregion\n//#region watchDebounced/index.ts\nfunction watchDebounced(source, cb, options = {}) {\n\tconst { debounce = 0, maxWait = void 0,...watchOptions } = options;\n\treturn watchWithFilter(source, cb, {\n\t\t...watchOptions,\n\t\teventFilter: debounceFilter(debounce, { maxWait })\n\t});\n}\n/** @deprecated use `watchDebounced` instead */\nconst debouncedWatch = watchDebounced;\n\n//#endregion\n//#region watchDeep/index.ts\n/**\n* Shorthand for watching value with {deep: true}\n*\n* @see https://vueuse.org/watchDeep\n*/\nfunction watchDeep(source, cb, options) {\n\treturn watch(source, cb, {\n\t\t...options,\n\t\tdeep: true\n\t});\n}\n\n//#endregion\n//#region watchIgnorable/index.ts\nfunction watchIgnorable(source, cb, options = {}) {\n\tconst { eventFilter = bypassFilter,...watchOptions } = options;\n\tconst filteredCb = createFilterWrapper(eventFilter, cb);\n\tlet ignoreUpdates;\n\tlet ignorePrevAsyncUpdates;\n\tlet stop;\n\tif (watchOptions.flush === \"sync\") {\n\t\tlet ignore = false;\n\t\tignorePrevAsyncUpdates = () => {};\n\t\tignoreUpdates = (updater) => {\n\t\t\tignore = true;\n\t\t\tupdater();\n\t\t\tignore = false;\n\t\t};\n\t\tstop = watch(source, (...args) => {\n\t\t\tif (!ignore) filteredCb(...args);\n\t\t}, watchOptions);\n\t} else {\n\t\tconst disposables = [];\n\t\tlet ignoreCounter = 0;\n\t\tlet syncCounter = 0;\n\t\tignorePrevAsyncUpdates = () => {\n\t\t\tignoreCounter = syncCounter;\n\t\t};\n\t\tdisposables.push(watch(source, () => {\n\t\t\tsyncCounter++;\n\t\t}, {\n\t\t\t...watchOptions,\n\t\t\tflush: \"sync\"\n\t\t}));\n\t\tignoreUpdates = (updater) => {\n\t\t\tconst syncCounterPrev = syncCounter;\n\t\t\tupdater();\n\t\t\tignoreCounter += syncCounter - syncCounterPrev;\n\t\t};\n\t\tdisposables.push(watch(source, (...args) => {\n\t\t\tconst ignore = ignoreCounter > 0 && ignoreCounter === syncCounter;\n\t\t\tignoreCounter = 0;\n\t\t\tsyncCounter = 0;\n\t\t\tif (ignore) return;\n\t\t\tfilteredCb(...args);\n\t\t}, watchOptions));\n\t\tstop = () => {\n\t\t\tdisposables.forEach((fn) => fn());\n\t\t};\n\t}\n\treturn {\n\t\tstop,\n\t\tignoreUpdates,\n\t\tignorePrevAsyncUpdates\n\t};\n}\n/** @deprecated use `watchIgnorable` instead */\nconst ignorableWatch = watchIgnorable;\n\n//#endregion\n//#region watchImmediate/index.ts\n/**\n* Shorthand for watching value with {immediate: true}\n*\n* @see https://vueuse.org/watchImmediate\n*/\nfunction watchImmediate(source, cb, options) {\n\treturn watch(source, cb, {\n\t\t...options,\n\t\timmediate: true\n\t});\n}\n\n//#endregion\n//#region watchOnce/index.ts\n/**\n* Shorthand for watching value with { once: true }\n*\n* @see https://vueuse.org/watchOnce\n*/\nfunction watchOnce(source, cb, options) {\n\treturn watch(source, cb, {\n\t\t...options,\n\t\tonce: true\n\t});\n}\n\n//#endregion\n//#region watchThrottled/index.ts\nfunction watchThrottled(source, cb, options = {}) {\n\tconst { throttle = 0, trailing = true, leading = true,...watchOptions } = options;\n\treturn watchWithFilter(source, cb, {\n\t\t...watchOptions,\n\t\teventFilter: throttleFilter(throttle, trailing, leading)\n\t});\n}\n/** @deprecated use `watchThrottled` instead */\nconst throttledWatch = watchThrottled;\n\n//#endregion\n//#region watchTriggerable/index.ts\nfunction watchTriggerable(source, cb, options = {}) {\n\tlet cleanupFn;\n\tfunction onEffect() {\n\t\tif (!cleanupFn) return;\n\t\tconst fn = cleanupFn;\n\t\tcleanupFn = void 0;\n\t\tfn();\n\t}\n\t/** Register the function `cleanupFn` */\n\tfunction onCleanup(callback) {\n\t\tcleanupFn = callback;\n\t}\n\tconst _cb = (value, oldValue) => {\n\t\tonEffect();\n\t\treturn cb(value, oldValue, onCleanup);\n\t};\n\tconst res = watchIgnorable(source, _cb, options);\n\tconst { ignoreUpdates } = res;\n\tconst trigger = () => {\n\t\tlet res$1;\n\t\tignoreUpdates(() => {\n\t\t\tres$1 = _cb(getWatchSources(source), getOldValue(source));\n\t\t});\n\t\treturn res$1;\n\t};\n\treturn {\n\t\t...res,\n\t\ttrigger\n\t};\n}\nfunction getWatchSources(sources) {\n\tif (isReactive(sources)) return sources;\n\tif (Array.isArray(sources)) return sources.map((item) => toValue(item));\n\treturn toValue(sources);\n}\nfunction getOldValue(source) {\n\treturn Array.isArray(source) ? source.map(() => void 0) : void 0;\n}\n\n//#endregion\n//#region whenever/index.ts\n/**\n* Shorthand for watching value to be truthy\n*\n* @see https://vueuse.org/whenever\n*/\nfunction whenever(source, cb, options) {\n\tconst stop = watch(source, (v, ov, onInvalidate) => {\n\t\tif (v) {\n\t\t\tif (options === null || options === void 0 ? void 0 : options.once) nextTick(() => stop());\n\t\t\tcb(v, ov, onInvalidate);\n\t\t}\n\t}, {\n\t\t...options,\n\t\tonce: false\n\t});\n\treturn stop;\n}\n\n//#endregion\nexport { assert, autoResetRef, bypassFilter, camelize, clamp, computedEager, computedWithControl, containsProp, controlledComputed, controlledRef, createEventHook, createFilterWrapper, createGlobalState, createInjectionState, createReactiveFn, createRef, createSharedComposable, createSingletonPromise, debounceFilter, debouncedRef, debouncedWatch, eagerComputed, extendRef, formatDate, get, getLifeCycleTarget, hasOwn, hyphenate, identity, ignorableWatch, increaseWithUnit, injectLocal, invoke, isClient, isDef, isDefined, isIOS, isObject, isWorker, makeDestructurable, noop, normalizeDate, notNullish, now, objectEntries, objectOmit, objectPick, pausableFilter, pausableWatch, promiseTimeout, provideLocal, pxValue, rand, reactify, reactifyObject, reactiveComputed, reactiveOmit, reactivePick, refAutoReset, refDebounced, refDefault, refManualReset, refThrottled, refWithControl, set, syncRef, syncRefs, throttleFilter, throttledRef, throttledWatch, timestamp, toArray, toReactive, toRef, toRefs, tryOnBeforeMount, tryOnBeforeUnmount, tryOnMounted, tryOnScopeDispose, tryOnUnmounted, until, useArrayDifference, useArrayEvery, useArrayFilter, useArrayFind, useArrayFindIndex, useArrayFindLast, useArrayIncludes, useArrayJoin, useArrayMap, useArrayReduce, useArraySome, useArrayUnique, useCounter, useDateFormat, useDebounce, useDebounceFn, useInterval, useIntervalFn, useLastChanged, useThrottle, useThrottleFn, useTimeout, useTimeoutFn, useToNumber, useToString, useToggle, watchArray, watchAtMost, watchDebounced, watchDeep, watchIgnorable, watchImmediate, watchOnce, watchPausable, watchThrottled, watchTriggerable, watchWithFilter, whenever };","import { bypassFilter, camelize, clamp, computedWithControl, containsProp, createEventHook, createFilterWrapper, createRef, createSingletonPromise, debounceFilter, hasOwn, identity, increaseWithUnit, injectLocal, isClient, isDef, isIOS, isObject, isWorker, makeDestructurable, noop, notNullish, objectEntries, objectOmit, objectPick, pausableFilter, promiseTimeout, provideLocal, pxValue, syncRef, throttleFilter, timestamp, toArray, toRef, toRefs, tryOnMounted, tryOnScopeDispose, tryOnUnmounted, until, useDebounceFn, useIntervalFn, useThrottleFn, useTimeoutFn, watchIgnorable, watchImmediate, watchOnce, watchPausable, watchWithFilter, whenever } from \"@vueuse/shared\";\nimport { Fragment, TransitionGroup, computed, customRef, defineComponent, getCurrentInstance, getCurrentScope, h, hasInjectionContext, inject, isReadonly, isRef, markRaw, nextTick, onBeforeUpdate, onMounted, onUpdated, reactive, readonly, ref, shallowReactive, shallowReadonly, shallowRef, toRaw, toValue, unref, watch, watchEffect } from \"vue\";\n\nexport * from \"@vueuse/shared\"\n\n//#region computedAsync/index.ts\nfunction computedAsync(evaluationCallback, initialState, optionsOrRef) {\n\tvar _globalThis$reportErr;\n\tlet options;\n\tif (isRef(optionsOrRef)) options = { evaluating: optionsOrRef };\n\telse options = optionsOrRef || {};\n\tconst { lazy = false, flush = \"sync\", evaluating = void 0, shallow = true, onError = (_globalThis$reportErr = globalThis.reportError) !== null && _globalThis$reportErr !== void 0 ? _globalThis$reportErr : noop } = options;\n\tconst started = shallowRef(!lazy);\n\tconst current = shallow ? shallowRef(initialState) : ref(initialState);\n\tlet counter = 0;\n\twatchEffect(async (onInvalidate) => {\n\t\tif (!started.value) return;\n\t\tcounter++;\n\t\tconst counterAtBeginning = counter;\n\t\tlet hasFinished = false;\n\t\tif (evaluating) Promise.resolve().then(() => {\n\t\t\tevaluating.value = true;\n\t\t});\n\t\ttry {\n\t\t\tconst result = await evaluationCallback((cancelCallback) => {\n\t\t\t\tonInvalidate(() => {\n\t\t\t\t\tif (evaluating) evaluating.value = false;\n\t\t\t\t\tif (!hasFinished) cancelCallback();\n\t\t\t\t});\n\t\t\t});\n\t\t\tif (counterAtBeginning === counter) current.value = result;\n\t\t} catch (e) {\n\t\t\tonError(e);\n\t\t} finally {\n\t\t\tif (evaluating && counterAtBeginning === counter) evaluating.value = false;\n\t\t\thasFinished = true;\n\t\t}\n\t}, { flush });\n\tif (lazy) return computed(() => {\n\t\tstarted.value = true;\n\t\treturn current.value;\n\t});\n\telse return current;\n}\n/** @deprecated use `computedAsync` instead */\nconst asyncComputed = computedAsync;\n\n//#endregion\n//#region computedInject/index.ts\nfunction computedInject(key, options, defaultSource, treatDefaultAsFactory) {\n\tlet source = inject(key);\n\tif (defaultSource) source = inject(key, defaultSource);\n\tif (treatDefaultAsFactory) source = inject(key, defaultSource, treatDefaultAsFactory);\n\tif (typeof options === \"function\") return computed((oldValue) => options(source, oldValue));\n\telse return computed({\n\t\tget: (oldValue) => options.get(source, oldValue),\n\t\tset: options.set\n\t});\n}\n\n//#endregion\n//#region createReusableTemplate/index.ts\n/**\n* This function creates `define` and `reuse` components in pair,\n* It also allow to pass a generic to bind with type.\n*\n* @see https://vueuse.org/createReusableTemplate\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction createReusableTemplate(options = {}) {\n\tconst { inheritAttrs = true } = options;\n\tconst render = shallowRef();\n\tconst define = defineComponent({ setup(_, { slots }) {\n\t\treturn () => {\n\t\t\trender.value = slots.default;\n\t\t};\n\t} });\n\tconst reuse = defineComponent({\n\t\tinheritAttrs,\n\t\tprops: options.props,\n\t\tsetup(props, { attrs, slots }) {\n\t\t\treturn () => {\n\t\t\t\tvar _render$value;\n\t\t\t\tif (!render.value && true) throw new Error(\"[VueUse] Failed to find the definition of reusable template\");\n\t\t\t\tconst vnode = (_render$value = render.value) === null || _render$value === void 0 ? void 0 : _render$value.call(render, {\n\t\t\t\t\t...options.props == null ? keysToCamelKebabCase(attrs) : props,\n\t\t\t\t\t$slots: slots\n\t\t\t\t});\n\t\t\t\treturn inheritAttrs && (vnode === null || vnode === void 0 ? void 0 : vnode.length) === 1 ? vnode[0] : vnode;\n\t\t\t};\n\t\t}\n\t});\n\treturn makeDestructurable({\n\t\tdefine,\n\t\treuse\n\t}, [define, reuse]);\n}\nfunction keysToCamelKebabCase(obj) {\n\tconst newObj = {};\n\tfor (const key in obj) newObj[camelize(key)] = obj[key];\n\treturn newObj;\n}\n\n//#endregion\n//#region createTemplatePromise/index.ts\n/**\n* Creates a template promise component.\n*\n* @see https://vueuse.org/createTemplatePromise\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction createTemplatePromise(options = {}) {\n\tlet index = 0;\n\tconst instances = ref([]);\n\tfunction create(...args) {\n\t\tconst props = shallowReactive({\n\t\t\tkey: index++,\n\t\t\targs,\n\t\t\tpromise: void 0,\n\t\t\tresolve: () => {},\n\t\t\treject: () => {},\n\t\t\tisResolving: false,\n\t\t\toptions\n\t\t});\n\t\tinstances.value.push(props);\n\t\tprops.promise = new Promise((_resolve, _reject) => {\n\t\t\tprops.resolve = (v) => {\n\t\t\t\tprops.isResolving = true;\n\t\t\t\treturn _resolve(v);\n\t\t\t};\n\t\t\tprops.reject = _reject;\n\t\t}).finally(() => {\n\t\t\tprops.promise = void 0;\n\t\t\tconst index$1 = instances.value.indexOf(props);\n\t\t\tif (index$1 !== -1) instances.value.splice(index$1, 1);\n\t\t});\n\t\treturn props.promise;\n\t}\n\tfunction start(...args) {\n\t\tif (options.singleton && instances.value.length > 0) return instances.value[0].promise;\n\t\treturn create(...args);\n\t}\n\tconst component = defineComponent((_, { slots }) => {\n\t\tconst renderList = () => instances.value.map((props) => {\n\t\t\tvar _slots$default;\n\t\t\treturn h(Fragment, { key: props.key }, (_slots$default = slots.default) === null || _slots$default === void 0 ? void 0 : _slots$default.call(slots, props));\n\t\t});\n\t\tif (options.transition) return () => h(TransitionGroup, options.transition, renderList);\n\t\treturn renderList;\n\t});\n\tcomponent.start = start;\n\treturn component;\n}\n\n//#endregion\n//#region createUnrefFn/index.ts\n/**\n* Make a plain function accepting ref and raw values as arguments.\n* Returns the same value the unconverted function returns, with proper typing.\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction createUnrefFn(fn) {\n\treturn function(...args) {\n\t\treturn fn.apply(this, args.map((i) => toValue(i)));\n\t};\n}\n\n//#endregion\n//#region _configurable.ts\nconst defaultWindow = isClient ? window : void 0;\nconst defaultDocument = isClient ? window.document : void 0;\nconst defaultNavigator = isClient ? window.navigator : void 0;\nconst defaultLocation = isClient ? window.location : void 0;\n\n//#endregion\n//#region unrefElement/index.ts\n/**\n* Get the dom element of a ref of element or Vue component instance\n*\n* @param elRef\n*/\nfunction unrefElement(elRef) {\n\tvar _$el;\n\tconst plain = toValue(elRef);\n\treturn (_$el = plain === null || plain === void 0 ? void 0 : plain.$el) !== null && _$el !== void 0 ? _$el : plain;\n}\n\n//#endregion\n//#region useEventListener/index.ts\nfunction useEventListener(...args) {\n\tconst register = (el, event, listener, options) => {\n\t\tel.addEventListener(event, listener, options);\n\t\treturn () => el.removeEventListener(event, listener, options);\n\t};\n\tconst firstParamTargets = computed(() => {\n\t\tconst test = toArray(toValue(args[0])).filter((e) => e != null);\n\t\treturn test.every((e) => typeof e !== \"string\") ? test : void 0;\n\t});\n\treturn watchImmediate(() => {\n\t\tvar _firstParamTargets$va, _firstParamTargets$va2;\n\t\treturn [\n\t\t\t(_firstParamTargets$va = (_firstParamTargets$va2 = firstParamTargets.value) === null || _firstParamTargets$va2 === void 0 ? void 0 : _firstParamTargets$va2.map((e) => unrefElement(e))) !== null && _firstParamTargets$va !== void 0 ? _firstParamTargets$va : [defaultWindow].filter((e) => e != null),\n\t\t\ttoArray(toValue(firstParamTargets.value ? args[1] : args[0])),\n\t\t\ttoArray(unref(firstParamTargets.value ? args[2] : args[1])),\n\t\t\ttoValue(firstParamTargets.value ? args[3] : args[2])\n\t\t];\n\t}, ([raw_targets, raw_events, raw_listeners, raw_options], _, onCleanup) => {\n\t\tif (!(raw_targets === null || raw_targets === void 0 ? void 0 : raw_targets.length) || !(raw_events === null || raw_events === void 0 ? void 0 : raw_events.length) || !(raw_listeners === null || raw_listeners === void 0 ? void 0 : raw_listeners.length)) return;\n\t\tconst optionsClone = isObject(raw_options) ? { ...raw_options } : raw_options;\n\t\tconst cleanups = raw_targets.flatMap((el) => raw_events.flatMap((event) => raw_listeners.map((listener) => register(el, event, listener, optionsClone))));\n\t\tonCleanup(() => {\n\t\t\tcleanups.forEach((fn) => fn());\n\t\t});\n\t}, { flush: \"post\" });\n}\n\n//#endregion\n//#region onClickOutside/index.ts\nlet _iOSWorkaround = false;\nfunction onClickOutside(target, handler, options = {}) {\n\tconst { window: window$1 = defaultWindow, ignore = [], capture = true, detectIframe = false, controls = false } = options;\n\tif (!window$1) return controls ? {\n\t\tstop: noop,\n\t\tcancel: noop,\n\t\ttrigger: noop\n\t} : noop;\n\tif (isIOS && !_iOSWorkaround) {\n\t\t_iOSWorkaround = true;\n\t\tconst listenerOptions = { passive: true };\n\t\tArray.from(window$1.document.body.children).forEach((el) => el.addEventListener(\"click\", noop, listenerOptions));\n\t\twindow$1.document.documentElement.addEventListener(\"click\", noop, listenerOptions);\n\t}\n\tlet shouldListen = true;\n\tconst shouldIgnore = (event) => {\n\t\treturn toValue(ignore).some((target$1) => {\n\t\t\tif (typeof target$1 === \"string\") return Array.from(window$1.document.querySelectorAll(target$1)).some((el) => el === event.target || event.composedPath().includes(el));\n\t\t\telse {\n\t\t\t\tconst el = unrefElement(target$1);\n\t\t\t\treturn el && (event.target === el || event.composedPath().includes(el));\n\t\t\t}\n\t\t});\n\t};\n\t/**\n\t* Determines if the given target has multiple root elements.\n\t* Referenced from: https://github.com/vuejs/test-utils/blob/ccb460be55f9f6be05ab708500a41ec8adf6f4bc/src/vue-wrapper.ts#L21\n\t*/\n\tfunction hasMultipleRoots(target$1) {\n\t\tconst vm = toValue(target$1);\n\t\treturn vm && vm.$.subTree.shapeFlag === 16;\n\t}\n\tfunction checkMultipleRoots(target$1, event) {\n\t\tconst vm = toValue(target$1);\n\t\tconst children = vm.$.subTree && vm.$.subTree.children;\n\t\tif (children == null || !Array.isArray(children)) return false;\n\t\treturn children.some((child) => child.el === event.target || event.composedPath().includes(child.el));\n\t}\n\tconst listener = (event) => {\n\t\tconst el = unrefElement(target);\n\t\tif (event.target == null) return;\n\t\tif (!(el instanceof Element) && hasMultipleRoots(target) && checkMultipleRoots(target, event)) return;\n\t\tif (!el || el === event.target || event.composedPath().includes(el)) return;\n\t\tif (\"detail\" in event && event.detail === 0) shouldListen = !shouldIgnore(event);\n\t\tif (!shouldListen) {\n\t\t\tshouldListen = true;\n\t\t\treturn;\n\t\t}\n\t\thandler(event);\n\t};\n\tlet isProcessingClick = false;\n\tconst cleanup = [\n\t\tuseEventListener(window$1, \"click\", (event) => {\n\t\t\tif (!isProcessingClick) {\n\t\t\t\tisProcessingClick = true;\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\tisProcessingClick = false;\n\t\t\t\t}, 0);\n\t\t\t\tlistener(event);\n\t\t\t}\n\t\t}, {\n\t\t\tpassive: true,\n\t\t\tcapture\n\t\t}),\n\t\tuseEventListener(window$1, \"pointerdown\", (e) => {\n\t\t\tconst el = unrefElement(target);\n\t\t\tshouldListen = !shouldIgnore(e) && !!(el && !e.composedPath().includes(el));\n\t\t}, { passive: true }),\n\t\tdetectIframe && useEventListener(window$1, \"blur\", (event) => {\n\t\t\tsetTimeout(() => {\n\t\t\t\tvar _window$document$acti;\n\t\t\t\tconst el = unrefElement(target);\n\t\t\t\tif (((_window$document$acti = window$1.document.activeElement) === null || _window$document$acti === void 0 ? void 0 : _window$document$acti.tagName) === \"IFRAME\" && !(el === null || el === void 0 ? void 0 : el.contains(window$1.document.activeElement))) handler(event);\n\t\t\t}, 0);\n\t\t}, { passive: true })\n\t].filter(Boolean);\n\tconst stop = () => cleanup.forEach((fn) => fn());\n\tif (controls) return {\n\t\tstop,\n\t\tcancel: () => {\n\t\t\tshouldListen = false;\n\t\t},\n\t\ttrigger: (event) => {\n\t\t\tshouldListen = true;\n\t\t\tlistener(event);\n\t\t\tshouldListen = false;\n\t\t}\n\t};\n\treturn stop;\n}\n\n//#endregion\n//#region useMounted/index.ts\n/**\n* Mounted state in ref.\n*\n* @see https://vueuse.org/useMounted\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useMounted() {\n\tconst isMounted = shallowRef(false);\n\tconst instance = getCurrentInstance();\n\tif (instance) onMounted(() => {\n\t\tisMounted.value = true;\n\t}, instance);\n\treturn isMounted;\n}\n\n//#endregion\n//#region useSupported/index.ts\n/* @__NO_SIDE_EFFECTS__ */\nfunction useSupported(callback) {\n\tconst isMounted = useMounted();\n\treturn computed(() => {\n\t\tisMounted.value;\n\t\treturn Boolean(callback());\n\t});\n}\n\n//#endregion\n//#region useMutationObserver/index.ts\n/**\n* Watch for changes being made to the DOM tree.\n*\n* @see https://vueuse.org/useMutationObserver\n* @see https://developer.mozilla.org/en-US/docs/Web/API/MutationObserver MutationObserver MDN\n* @param target\n* @param callback\n* @param options\n*/\nfunction useMutationObserver(target, callback, options = {}) {\n\tconst { window: window$1 = defaultWindow,...mutationOptions } = options;\n\tlet observer;\n\tconst isSupported = /* @__PURE__ */ useSupported(() => window$1 && \"MutationObserver\" in window$1);\n\tconst cleanup = () => {\n\t\tif (observer) {\n\t\t\tobserver.disconnect();\n\t\t\tobserver = void 0;\n\t\t}\n\t};\n\tconst stopWatch = watch(computed(() => {\n\t\tconst items = toArray(toValue(target)).map(unrefElement).filter(notNullish);\n\t\treturn new Set(items);\n\t}), (newTargets) => {\n\t\tcleanup();\n\t\tif (isSupported.value && newTargets.size) {\n\t\t\tobserver = new MutationObserver(callback);\n\t\t\tnewTargets.forEach((el) => observer.observe(el, mutationOptions));\n\t\t}\n\t}, {\n\t\timmediate: true,\n\t\tflush: \"post\"\n\t});\n\tconst takeRecords = () => {\n\t\treturn observer === null || observer === void 0 ? void 0 : observer.takeRecords();\n\t};\n\tconst stop = () => {\n\t\tstopWatch();\n\t\tcleanup();\n\t};\n\ttryOnScopeDispose(stop);\n\treturn {\n\t\tisSupported,\n\t\tstop,\n\t\ttakeRecords\n\t};\n}\n\n//#endregion\n//#region onElementRemoval/index.ts\n/**\n* Fires when the element or any element containing it is removed.\n*\n* @param target\n* @param callback\n* @param options\n*/\nfunction onElementRemoval(target, callback, options = {}) {\n\tconst { window: window$1 = defaultWindow, document: document$1 = window$1 === null || window$1 === void 0 ? void 0 : window$1.document, flush = \"sync\" } = options;\n\tif (!window$1 || !document$1) return noop;\n\tlet stopFn;\n\tconst cleanupAndUpdate = (fn) => {\n\t\tstopFn === null || stopFn === void 0 || stopFn();\n\t\tstopFn = fn;\n\t};\n\tconst stopWatch = watchEffect(() => {\n\t\tconst el = unrefElement(target);\n\t\tif (el) {\n\t\t\tconst { stop } = useMutationObserver(document$1, (mutationsList) => {\n\t\t\t\tif (mutationsList.map((mutation) => [...mutation.removedNodes]).flat().some((node) => node === el || node.contains(el))) callback(mutationsList);\n\t\t\t}, {\n\t\t\t\twindow: window$1,\n\t\t\t\tchildList: true,\n\t\t\t\tsubtree: true\n\t\t\t});\n\t\t\tcleanupAndUpdate(stop);\n\t\t}\n\t}, { flush });\n\tconst stopHandle = () => {\n\t\tstopWatch();\n\t\tcleanupAndUpdate();\n\t};\n\ttryOnScopeDispose(stopHandle);\n\treturn stopHandle;\n}\n\n//#endregion\n//#region onKeyStroke/index.ts\nfunction createKeyPredicate(keyFilter) {\n\tif (typeof keyFilter === \"function\") return keyFilter;\n\telse if (typeof keyFilter === \"string\") return (event) => event.key === keyFilter;\n\telse if (Array.isArray(keyFilter)) return (event) => keyFilter.includes(event.key);\n\treturn () => true;\n}\nfunction onKeyStroke(...args) {\n\tlet key;\n\tlet handler;\n\tlet options = {};\n\tif (args.length === 3) {\n\t\tkey = args[0];\n\t\thandler = args[1];\n\t\toptions = args[2];\n\t} else if (args.length === 2) if (typeof args[1] === \"object\") {\n\t\tkey = true;\n\t\thandler = args[0];\n\t\toptions = args[1];\n\t} else {\n\t\tkey = args[0];\n\t\thandler = args[1];\n\t}\n\telse {\n\t\tkey = true;\n\t\thandler = args[0];\n\t}\n\tconst { target = defaultWindow, eventName = \"keydown\", passive = false, dedupe = false } = options;\n\tconst predicate = createKeyPredicate(key);\n\tconst listener = (e) => {\n\t\tif (e.repeat && toValue(dedupe)) return;\n\t\tif (predicate(e)) handler(e);\n\t};\n\treturn useEventListener(target, eventName, listener, passive);\n}\n/**\n* Listen to the keydown event of the given key.\n*\n* @see https://vueuse.org/onKeyStroke\n* @param key\n* @param handler\n* @param options\n*/\nfunction onKeyDown(key, handler, options = {}) {\n\treturn onKeyStroke(key, handler, {\n\t\t...options,\n\t\teventName: \"keydown\"\n\t});\n}\n/**\n* Listen to the keypress event of the given key.\n*\n* @see https://vueuse.org/onKeyStroke\n* @param key\n* @param handler\n* @param options\n*/\nfunction onKeyPressed(key, handler, options = {}) {\n\treturn onKeyStroke(key, handler, {\n\t\t...options,\n\t\teventName: \"keypress\"\n\t});\n}\n/**\n* Listen to the keyup event of the given key.\n*\n* @see https://vueuse.org/onKeyStroke\n* @param key\n* @param handler\n* @param options\n*/\nfunction onKeyUp(key, handler, options = {}) {\n\treturn onKeyStroke(key, handler, {\n\t\t...options,\n\t\teventName: \"keyup\"\n\t});\n}\n\n//#endregion\n//#region onLongPress/index.ts\nconst DEFAULT_DELAY = 500;\nconst DEFAULT_THRESHOLD = 10;\nfunction onLongPress(target, handler, options) {\n\tvar _options$modifiers10, _options$modifiers11;\n\tconst elementRef = computed(() => unrefElement(target));\n\tlet timeout;\n\tlet posStart;\n\tlet startTimestamp;\n\tlet hasLongPressed = false;\n\tfunction clear() {\n\t\tif (timeout) {\n\t\t\tclearTimeout(timeout);\n\t\t\ttimeout = void 0;\n\t\t}\n\t\tposStart = void 0;\n\t\tstartTimestamp = void 0;\n\t\thasLongPressed = false;\n\t}\n\tfunction getDelay(ev) {\n\t\tconst delay = options === null || options === void 0 ? void 0 : options.delay;\n\t\tif (typeof delay === \"function\") return delay(ev);\n\t\treturn delay !== null && delay !== void 0 ? delay : DEFAULT_DELAY;\n\t}\n\tfunction onRelease(ev) {\n\t\tvar _options$modifiers, _options$modifiers2, _options$modifiers3;\n\t\tconst [_startTimestamp, _posStart, _hasLongPressed] = [\n\t\t\tstartTimestamp,\n\t\t\tposStart,\n\t\t\thasLongPressed\n\t\t];\n\t\tclear();\n\t\tif (!(options === null || options === void 0 ? void 0 : options.onMouseUp) || !_posStart || !_startTimestamp) return;\n\t\tif ((options === null || options === void 0 || (_options$modifiers = options.modifiers) === null || _options$modifiers === void 0 ? void 0 : _options$modifiers.self) && ev.target !== elementRef.value) return;\n\t\tif (options === null || options === void 0 || (_options$modifiers2 = options.modifiers) === null || _options$modifiers2 === void 0 ? void 0 : _options$modifiers2.prevent) ev.preventDefault();\n\t\tif (options === null || options === void 0 || (_options$modifiers3 = options.modifiers) === null || _options$modifiers3 === void 0 ? void 0 : _options$modifiers3.stop) ev.stopPropagation();\n\t\tconst dx = ev.x - _posStart.x;\n\t\tconst dy = ev.y - _posStart.y;\n\t\tconst distance = Math.sqrt(dx * dx + dy * dy);\n\t\toptions.onMouseUp(ev.timeStamp - _startTimestamp, distance, _hasLongPressed);\n\t}\n\tfunction onDown(ev) {\n\t\tvar _options$modifiers4, _options$modifiers5, _options$modifiers6;\n\t\tif ((options === null || options === void 0 || (_options$modifiers4 = options.modifiers) === null || _options$modifiers4 === void 0 ? void 0 : _options$modifiers4.self) && ev.target !== elementRef.value) return;\n\t\tclear();\n\t\tif (options === null || options === void 0 || (_options$modifiers5 = options.modifiers) === null || _options$modifiers5 === void 0 ? void 0 : _options$modifiers5.prevent) ev.preventDefault();\n\t\tif (options === null || options === void 0 || (_options$modifiers6 = options.modifiers) === null || _options$modifiers6 === void 0 ? void 0 : _options$modifiers6.stop) ev.stopPropagation();\n\t\tposStart = {\n\t\t\tx: ev.x,\n\t\t\ty: ev.y\n\t\t};\n\t\tstartTimestamp = ev.timeStamp;\n\t\ttimeout = setTimeout(() => {\n\t\t\thasLongPressed = true;\n\t\t\thandler(ev);\n\t\t}, getDelay(ev));\n\t}\n\tfunction onMove(ev) {\n\t\tvar _options$modifiers7, _options$modifiers8, _options$modifiers9, _options$distanceThre;\n\t\tif ((options === null || options === void 0 || (_options$modifiers7 = options.modifiers) === null || _options$modifiers7 === void 0 ? void 0 : _options$modifiers7.self) && ev.target !== elementRef.value) return;\n\t\tif (!posStart || (options === null || options === void 0 ? void 0 : options.distanceThreshold) === false) return;\n\t\tif (options === null || options === void 0 || (_options$modifiers8 = options.modifiers) === null || _options$modifiers8 === void 0 ? void 0 : _options$modifiers8.prevent) ev.preventDefault();\n\t\tif (options === null || options === void 0 || (_options$modifiers9 = options.modifiers) === null || _options$modifiers9 === void 0 ? void 0 : _options$modifiers9.stop) ev.stopPropagation();\n\t\tconst dx = ev.x - posStart.x;\n\t\tconst dy = ev.y - posStart.y;\n\t\tif (Math.sqrt(dx * dx + dy * dy) >= ((_options$distanceThre = options === null || options === void 0 ? void 0 : options.distanceThreshold) !== null && _options$distanceThre !== void 0 ? _options$distanceThre : DEFAULT_THRESHOLD)) clear();\n\t}\n\tconst listenerOptions = {\n\t\tcapture: options === null || options === void 0 || (_options$modifiers10 = options.modifiers) === null || _options$modifiers10 === void 0 ? void 0 : _options$modifiers10.capture,\n\t\tonce: options === null || options === void 0 || (_options$modifiers11 = options.modifiers) === null || _options$modifiers11 === void 0 ? void 0 : _options$modifiers11.once\n\t};\n\tconst cleanup = [\n\t\tuseEventListener(elementRef, \"pointerdown\", onDown, listenerOptions),\n\t\tuseEventListener(elementRef, \"pointermove\", onMove, listenerOptions),\n\t\tuseEventListener(elementRef, [\"pointerup\", \"pointerleave\"], onRelease, listenerOptions)\n\t];\n\tconst stop = () => cleanup.forEach((fn) => fn());\n\treturn stop;\n}\n\n//#endregion\n//#region onStartTyping/index.ts\nfunction isFocusedElementEditable() {\n\tconst { activeElement, body } = document;\n\tif (!activeElement) return false;\n\tif (activeElement === body) return false;\n\tswitch (activeElement.tagName) {\n\t\tcase \"INPUT\":\n\t\tcase \"TEXTAREA\": return true;\n\t}\n\treturn activeElement.hasAttribute(\"contenteditable\");\n}\nfunction isTypedCharValid({ keyCode, metaKey, ctrlKey, altKey }) {\n\tif (metaKey || ctrlKey || altKey) return false;\n\tif (keyCode >= 48 && keyCode <= 57 || keyCode >= 96 && keyCode <= 105) return true;\n\tif (keyCode >= 65 && keyCode <= 90) return true;\n\treturn false;\n}\n/**\n* Fires when users start typing on non-editable elements.\n*\n* @see https://vueuse.org/onStartTyping\n* @param callback\n* @param options\n*/\nfunction onStartTyping(callback, options = {}) {\n\tconst { document: document$1 = defaultDocument } = options;\n\tconst keydown = (event) => {\n\t\tif (!isFocusedElementEditable() && isTypedCharValid(event)) callback(event);\n\t};\n\tif (document$1) useEventListener(document$1, \"keydown\", keydown, { passive: true });\n}\n\n//#endregion\n//#region templateRef/index.ts\n/**\n* @deprecated Use Vue's built-in `useTemplateRef` instead.\n*\n* Shorthand for binding ref to template element.\n*\n* @see https://vueuse.org/templateRef\n* @param key\n* @param initialValue\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction templateRef(key, initialValue = null) {\n\tconst instance = getCurrentInstance();\n\tlet _trigger = () => {};\n\tconst element = customRef((track, trigger) => {\n\t\t_trigger = trigger;\n\t\treturn {\n\t\t\tget() {\n\t\t\t\tvar _instance$proxy$$refs, _instance$proxy;\n\t\t\t\ttrack();\n\t\t\t\treturn (_instance$proxy$$refs = instance === null || instance === void 0 || (_instance$proxy = instance.proxy) === null || _instance$proxy === void 0 ? void 0 : _instance$proxy.$refs[key]) !== null && _instance$proxy$$refs !== void 0 ? _instance$proxy$$refs : initialValue;\n\t\t\t},\n\t\t\tset() {}\n\t\t};\n\t});\n\ttryOnMounted(_trigger);\n\tonUpdated(_trigger);\n\treturn element;\n}\n\n//#endregion\n//#region useActiveElement/index.ts\n/**\n* Reactive `document.activeElement`\n*\n* @see https://vueuse.org/useActiveElement\n* @param options\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useActiveElement(options = {}) {\n\tvar _options$document;\n\tconst { window: window$1 = defaultWindow, deep = true, triggerOnRemoval = false } = options;\n\tconst document$1 = (_options$document = options.document) !== null && _options$document !== void 0 ? _options$document : window$1 === null || window$1 === void 0 ? void 0 : window$1.document;\n\tconst getDeepActiveElement = () => {\n\t\tlet element = document$1 === null || document$1 === void 0 ? void 0 : document$1.activeElement;\n\t\tif (deep) {\n\t\t\tvar _element$shadowRoot;\n\t\t\twhile (element === null || element === void 0 ? void 0 : element.shadowRoot) element = element === null || element === void 0 || (_element$shadowRoot = element.shadowRoot) === null || _element$shadowRoot === void 0 ? void 0 : _element$shadowRoot.activeElement;\n\t\t}\n\t\treturn element;\n\t};\n\tconst activeElement = shallowRef();\n\tconst trigger = () => {\n\t\tactiveElement.value = getDeepActiveElement();\n\t};\n\tif (window$1) {\n\t\tconst listenerOptions = {\n\t\t\tcapture: true,\n\t\t\tpassive: true\n\t\t};\n\t\tuseEventListener(window$1, \"blur\", (event) => {\n\t\t\tif (event.relatedTarget !== null) return;\n\t\t\ttrigger();\n\t\t}, listenerOptions);\n\t\tuseEventListener(window$1, \"focus\", trigger, listenerOptions);\n\t}\n\tif (triggerOnRemoval) onElementRemoval(activeElement, trigger, { document: document$1 });\n\ttrigger();\n\treturn activeElement;\n}\n\n//#endregion\n//#region useRafFn/index.ts\n/**\n* Call function on every `requestAnimationFrame`. With controls of pausing and resuming.\n*\n* @see https://vueuse.org/useRafFn\n* @param fn\n* @param options\n*/\nfunction useRafFn(fn, options = {}) {\n\tconst { immediate = true, fpsLimit = null, window: window$1 = defaultWindow, once = false } = options;\n\tconst isActive = shallowRef(false);\n\tconst intervalLimit = computed(() => {\n\t\tconst limit = toValue(fpsLimit);\n\t\treturn limit ? 1e3 / limit : null;\n\t});\n\tlet previousFrameTimestamp = 0;\n\tlet rafId = null;\n\tfunction loop(timestamp$1) {\n\t\tif (!isActive.value || !window$1) return;\n\t\tif (!previousFrameTimestamp) previousFrameTimestamp = timestamp$1;\n\t\tconst delta = timestamp$1 - previousFrameTimestamp;\n\t\tif (intervalLimit.value && delta < intervalLimit.value) {\n\t\t\trafId = window$1.requestAnimationFrame(loop);\n\t\t\treturn;\n\t\t}\n\t\tpreviousFrameTimestamp = timestamp$1;\n\t\tfn({\n\t\t\tdelta,\n\t\t\ttimestamp: timestamp$1\n\t\t});\n\t\tif (once) {\n\t\t\tisActive.value = false;\n\t\t\trafId = null;\n\t\t\treturn;\n\t\t}\n\t\trafId = window$1.requestAnimationFrame(loop);\n\t}\n\tfunction resume() {\n\t\tif (!isActive.value && window$1) {\n\t\t\tisActive.value = true;\n\t\t\tpreviousFrameTimestamp = 0;\n\t\t\trafId = window$1.requestAnimationFrame(loop);\n\t\t}\n\t}\n\tfunction pause() {\n\t\tisActive.value = false;\n\t\tif (rafId != null && window$1) {\n\t\t\twindow$1.cancelAnimationFrame(rafId);\n\t\t\trafId = null;\n\t\t}\n\t}\n\tif (immediate) resume();\n\ttryOnScopeDispose(pause);\n\treturn {\n\t\tisActive: readonly(isActive),\n\t\tpause,\n\t\tresume\n\t};\n}\n\n//#endregion\n//#region useAnimate/index.ts\n/**\n* Reactive Web Animations API\n*\n* @see https://vueuse.org/useAnimate\n* @param target\n* @param keyframes\n* @param options\n*/\nfunction useAnimate(target, keyframes, options) {\n\tlet config;\n\tlet animateOptions;\n\tif (isObject(options)) {\n\t\tconfig = options;\n\t\tanimateOptions = objectOmit(options, [\n\t\t\t\"window\",\n\t\t\t\"immediate\",\n\t\t\t\"commitStyles\",\n\t\t\t\"persist\",\n\t\t\t\"onReady\",\n\t\t\t\"onError\"\n\t\t]);\n\t} else {\n\t\tconfig = { duration: options };\n\t\tanimateOptions = options;\n\t}\n\tconst { window: window$1 = defaultWindow, immediate = true, commitStyles, persist, playbackRate: _playbackRate = 1, onReady, onError = (e) => {\n\t\tconsole.error(e);\n\t} } = config;\n\tconst isSupported = /* @__PURE__ */ useSupported(() => window$1 && HTMLElement && \"animate\" in HTMLElement.prototype);\n\tconst animate = shallowRef(void 0);\n\tconst store = shallowReactive({\n\t\tstartTime: null,\n\t\tcurrentTime: null,\n\t\ttimeline: null,\n\t\tplaybackRate: _playbackRate,\n\t\tpending: false,\n\t\tplayState: immediate ? \"idle\" : \"paused\",\n\t\treplaceState: \"active\"\n\t});\n\tconst pending = computed(() => store.pending);\n\tconst playState = computed(() => store.playState);\n\tconst replaceState = computed(() => store.replaceState);\n\tconst startTime = computed({\n\t\tget() {\n\t\t\treturn store.startTime;\n\t\t},\n\t\tset(value) {\n\t\t\tstore.startTime = value;\n\t\t\tif (animate.value) animate.value.startTime = value;\n\t\t}\n\t});\n\tconst currentTime = computed({\n\t\tget() {\n\t\t\treturn store.currentTime;\n\t\t},\n\t\tset(value) {\n\t\t\tstore.currentTime = value;\n\t\t\tif (animate.value) {\n\t\t\t\tanimate.value.currentTime = value;\n\t\t\t\tsyncResume();\n\t\t\t}\n\t\t}\n\t});\n\tconst timeline = computed({\n\t\tget() {\n\t\t\treturn store.timeline;\n\t\t},\n\t\tset(value) {\n\t\t\tstore.timeline = value;\n\t\t\tif (animate.value) animate.value.timeline = value;\n\t\t}\n\t});\n\tconst playbackRate = computed({\n\t\tget() {\n\t\t\treturn store.playbackRate;\n\t\t},\n\t\tset(value) {\n\t\t\tstore.playbackRate = value;\n\t\t\tif (animate.value) animate.value.playbackRate = value;\n\t\t}\n\t});\n\tconst play = () => {\n\t\tif (animate.value) try {\n\t\t\tanimate.value.play();\n\t\t\tsyncResume();\n\t\t} catch (e) {\n\t\t\tsyncPause();\n\t\t\tonError(e);\n\t\t}\n\t\telse update();\n\t};\n\tconst pause = () => {\n\t\ttry {\n\t\t\tvar _animate$value;\n\t\t\t(_animate$value = animate.value) === null || _animate$value === void 0 || _animate$value.pause();\n\t\t\tsyncPause();\n\t\t} catch (e) {\n\t\t\tonError(e);\n\t\t}\n\t};\n\tconst reverse = () => {\n\t\tif (!animate.value) update();\n\t\ttry {\n\t\t\tvar _animate$value2;\n\t\t\t(_animate$value2 = animate.value) === null || _animate$value2 === void 0 || _animate$value2.reverse();\n\t\t\tsyncResume();\n\t\t} catch (e) {\n\t\t\tsyncPause();\n\t\t\tonError(e);\n\t\t}\n\t};\n\tconst finish = () => {\n\t\ttry {\n\t\t\tvar _animate$value3;\n\t\t\t(_animate$value3 = animate.value) === null || _animate$value3 === void 0 || _animate$value3.finish();\n\t\t\tsyncPause();\n\t\t} catch (e) {\n\t\t\tonError(e);\n\t\t}\n\t};\n\tconst cancel = () => {\n\t\ttry {\n\t\t\tvar _animate$value4;\n\t\t\t(_animate$value4 = animate.value) === null || _animate$value4 === void 0 || _animate$value4.cancel();\n\t\t\tsyncPause();\n\t\t} catch (e) {\n\t\t\tonError(e);\n\t\t}\n\t};\n\twatch(() => unrefElement(target), (el) => {\n\t\tif (el) update(true);\n\t\telse animate.value = void 0;\n\t});\n\twatch(() => keyframes, (value) => {\n\t\tif (animate.value) {\n\t\t\tupdate();\n\t\t\tconst targetEl = unrefElement(target);\n\t\t\tif (targetEl) animate.value.effect = new KeyframeEffect(targetEl, toValue(value), animateOptions);\n\t\t}\n\t}, { deep: true });\n\ttryOnMounted(() => update(true), false);\n\ttryOnScopeDispose(cancel);\n\tfunction update(init) {\n\t\tconst el = unrefElement(target);\n\t\tif (!isSupported.value || !el) return;\n\t\tif (!animate.value) animate.value = el.animate(toValue(keyframes), animateOptions);\n\t\tif (persist) animate.value.persist();\n\t\tif (_playbackRate !== 1) animate.value.playbackRate = _playbackRate;\n\t\tif (init && !immediate) animate.value.pause();\n\t\telse syncResume();\n\t\tonReady === null || onReady === void 0 || onReady(animate.value);\n\t}\n\tconst listenerOptions = { passive: true };\n\tuseEventListener(animate, [\n\t\t\"cancel\",\n\t\t\"finish\",\n\t\t\"remove\"\n\t], syncPause, listenerOptions);\n\tuseEventListener(animate, \"finish\", () => {\n\t\tvar _animate$value5;\n\t\tif (commitStyles) (_animate$value5 = animate.value) === null || _animate$value5 === void 0 || _animate$value5.commitStyles();\n\t}, listenerOptions);\n\tconst { resume: resumeRef, pause: pauseRef } = useRafFn(() => {\n\t\tif (!animate.value) return;\n\t\tstore.pending = animate.value.pending;\n\t\tstore.playState = animate.value.playState;\n\t\tstore.replaceState = animate.value.replaceState;\n\t\tstore.startTime = animate.value.startTime;\n\t\tstore.currentTime = animate.value.currentTime;\n\t\tstore.timeline = animate.value.timeline;\n\t\tstore.playbackRate = animate.value.playbackRate;\n\t}, { immediate: false });\n\tfunction syncResume() {\n\t\tif (isSupported.value) resumeRef();\n\t}\n\tfunction syncPause() {\n\t\tif (isSupported.value && window$1) window$1.requestAnimationFrame(pauseRef);\n\t}\n\treturn {\n\t\tisSupported,\n\t\tanimate,\n\t\tplay,\n\t\tpause,\n\t\treverse,\n\t\tfinish,\n\t\tcancel,\n\t\tpending,\n\t\tplayState,\n\t\treplaceState,\n\t\tstartTime,\n\t\tcurrentTime,\n\t\ttimeline,\n\t\tplaybackRate\n\t};\n}\n\n//#endregion\n//#region useAsyncQueue/index.ts\n/**\n* Asynchronous queue task controller.\n*\n* @see https://vueuse.org/useAsyncQueue\n* @param tasks\n* @param options\n*/\nfunction useAsyncQueue(tasks, options) {\n\tconst { interrupt = true, onError = noop, onFinished = noop, signal } = options || {};\n\tconst promiseState = {\n\t\taborted: \"aborted\",\n\t\tfulfilled: \"fulfilled\",\n\t\tpending: \"pending\",\n\t\trejected: \"rejected\"\n\t};\n\tconst result = reactive(Array.from(Array.from({ length: tasks.length }), () => ({\n\t\tstate: promiseState.pending,\n\t\tdata: null\n\t})));\n\tconst activeIndex = shallowRef(-1);\n\tif (!tasks || tasks.length === 0) {\n\t\tonFinished();\n\t\treturn {\n\t\t\tactiveIndex,\n\t\t\tresult\n\t\t};\n\t}\n\tfunction updateResult(state, res) {\n\t\tactiveIndex.value++;\n\t\tresult[activeIndex.value].data = res;\n\t\tresult[activeIndex.value].state = state;\n\t}\n\ttasks.reduce((prev, curr) => {\n\t\treturn prev.then((prevRes) => {\n\t\t\tvar _result$activeIndex$v;\n\t\t\tif (signal === null || signal === void 0 ? void 0 : signal.aborted) {\n\t\t\t\tupdateResult(promiseState.aborted, /* @__PURE__ */ new Error(\"aborted\"));\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tif (((_result$activeIndex$v = result[activeIndex.value]) === null || _result$activeIndex$v === void 0 ? void 0 : _result$activeIndex$v.state) === promiseState.rejected && interrupt) {\n\t\t\t\tonFinished();\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tconst done = curr(prevRes).then((currentRes) => {\n\t\t\t\tupdateResult(promiseState.fulfilled, currentRes);\n\t\t\t\tif (activeIndex.value === tasks.length - 1) onFinished();\n\t\t\t\treturn currentRes;\n\t\t\t});\n\t\t\tif (!signal) return done;\n\t\t\treturn Promise.race([done, whenAborted(signal)]);\n\t\t}).catch((e) => {\n\t\t\tif (signal === null || signal === void 0 ? void 0 : signal.aborted) {\n\t\t\t\tupdateResult(promiseState.aborted, e);\n\t\t\t\treturn e;\n\t\t\t}\n\t\t\tupdateResult(promiseState.rejected, e);\n\t\t\tonError();\n\t\t\tif (activeIndex.value === tasks.length - 1) onFinished();\n\t\t\treturn e;\n\t\t});\n\t}, Promise.resolve());\n\treturn {\n\t\tactiveIndex,\n\t\tresult\n\t};\n}\nfunction whenAborted(signal) {\n\treturn new Promise((resolve, reject) => {\n\t\tconst error = /* @__PURE__ */ new Error(\"aborted\");\n\t\tif (signal.aborted) reject(error);\n\t\telse signal.addEventListener(\"abort\", () => reject(error), { once: true });\n\t});\n}\n\n//#endregion\n//#region useAsyncState/index.ts\n/**\n* Reactive async state. Will not block your setup function and will trigger changes once\n* the promise is ready.\n*\n* @see https://vueuse.org/useAsyncState\n* @param promise         The promise / async function to be resolved\n* @param initialState    The initial state, used until the first evaluation finishes\n* @param options\n*/\nfunction useAsyncState(promise, initialState, options) {\n\tvar _globalThis$reportErr;\n\tconst { immediate = true, delay = 0, onError = (_globalThis$reportErr = globalThis.reportError) !== null && _globalThis$reportErr !== void 0 ? _globalThis$reportErr : noop, onSuccess = noop, resetOnExecute = true, shallow = true, throwError } = options !== null && options !== void 0 ? options : {};\n\tconst state = shallow ? shallowRef(initialState) : ref(initialState);\n\tconst isReady = shallowRef(false);\n\tconst isLoading = shallowRef(false);\n\tconst error = shallowRef(void 0);\n\tlet executionsCount = 0;\n\tasync function execute(delay$1 = 0, ...args) {\n\t\tconst executionId = executionsCount += 1;\n\t\tif (resetOnExecute) state.value = toValue(initialState);\n\t\terror.value = void 0;\n\t\tisReady.value = false;\n\t\tisLoading.value = true;\n\t\tif (delay$1 > 0) await promiseTimeout(delay$1);\n\t\tconst _promise = typeof promise === \"function\" ? promise(...args) : promise;\n\t\ttry {\n\t\t\tconst data = await _promise;\n\t\t\tif (executionId === executionsCount) {\n\t\t\t\tstate.value = data;\n\t\t\t\tisReady.value = true;\n\t\t\t}\n\t\t\tonSuccess(data);\n\t\t\treturn data;\n\t\t} catch (e) {\n\t\t\tif (executionId === executionsCount) error.value = e;\n\t\t\tonError(e);\n\t\t\tif (throwError) throw e;\n\t\t} finally {\n\t\t\tif (executionId === executionsCount) isLoading.value = false;\n\t\t}\n\t}\n\tif (immediate) execute(delay);\n\tconst shell = {\n\t\tstate,\n\t\tisReady,\n\t\tisLoading,\n\t\terror,\n\t\texecute,\n\t\texecuteImmediate: (...args) => execute(0, ...args)\n\t};\n\tfunction waitUntilIsLoaded() {\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tuntil(isLoading).toBe(false).then(() => resolve(shell)).catch(reject);\n\t\t});\n\t}\n\treturn {\n\t\t...shell,\n\t\tthen(onFulfilled, onRejected) {\n\t\t\treturn waitUntilIsLoaded().then(onFulfilled, onRejected);\n\t\t}\n\t};\n}\n\n//#endregion\n//#region useBase64/serialization.ts\nconst defaults = {\n\tarray: (v) => JSON.stringify(v),\n\tobject: (v) => JSON.stringify(v),\n\tset: (v) => JSON.stringify(Array.from(v)),\n\tmap: (v) => JSON.stringify(Object.fromEntries(v)),\n\tnull: () => \"\"\n};\nfunction getDefaultSerialization(target) {\n\tif (!target) return defaults.null;\n\tif (target instanceof Map) return defaults.map;\n\telse if (target instanceof Set) return defaults.set;\n\telse if (Array.isArray(target)) return defaults.array;\n\telse return defaults.object;\n}\n\n//#endregion\n//#region useBase64/index.ts\nfunction useBase64(target, options) {\n\tconst base64 = shallowRef(\"\");\n\tconst promise = shallowRef();\n\tfunction execute() {\n\t\tif (!isClient) return;\n\t\tpromise.value = new Promise((resolve, reject) => {\n\t\t\ttry {\n\t\t\t\tconst _target = toValue(target);\n\t\t\t\tif (_target == null) resolve(\"\");\n\t\t\t\telse if (typeof _target === \"string\") resolve(blobToBase64(new Blob([_target], { type: \"text/plain\" })));\n\t\t\t\telse if (_target instanceof Blob) resolve(blobToBase64(_target));\n\t\t\t\telse if (_target instanceof ArrayBuffer) resolve(window.btoa(String.fromCharCode(...new Uint8Array(_target))));\n\t\t\t\telse if (_target instanceof HTMLCanvasElement) resolve(_target.toDataURL(options === null || options === void 0 ? void 0 : options.type, options === null || options === void 0 ? void 0 : options.quality));\n\t\t\t\telse if (_target instanceof HTMLImageElement) {\n\t\t\t\t\tconst img = _target.cloneNode(false);\n\t\t\t\t\timg.crossOrigin = \"Anonymous\";\n\t\t\t\t\timgLoaded(img).then(() => {\n\t\t\t\t\t\tconst canvas = document.createElement(\"canvas\");\n\t\t\t\t\t\tconst ctx = canvas.getContext(\"2d\");\n\t\t\t\t\t\tcanvas.width = img.width;\n\t\t\t\t\t\tcanvas.height = img.height;\n\t\t\t\t\t\tctx.drawImage(img, 0, 0, canvas.width, canvas.height);\n\t\t\t\t\t\tresolve(canvas.toDataURL(options === null || options === void 0 ? void 0 : options.type, options === null || options === void 0 ? void 0 : options.quality));\n\t\t\t\t\t}).catch(reject);\n\t\t\t\t} else if (typeof _target === \"object\") {\n\t\t\t\t\tconst serialized = ((options === null || options === void 0 ? void 0 : options.serializer) || getDefaultSerialization(_target))(_target);\n\t\t\t\t\treturn resolve(blobToBase64(new Blob([serialized], { type: \"application/json\" })));\n\t\t\t\t} else reject(/* @__PURE__ */ new Error(\"target is unsupported types\"));\n\t\t\t} catch (error) {\n\t\t\t\treject(error);\n\t\t\t}\n\t\t});\n\t\tpromise.value.then((res) => {\n\t\t\tbase64.value = (options === null || options === void 0 ? void 0 : options.dataUrl) === false ? res.replace(/^data:.*?;base64,/, \"\") : res;\n\t\t});\n\t\treturn promise.value;\n\t}\n\tif (isRef(target) || typeof target === \"function\") watch(target, execute, { immediate: true });\n\telse execute();\n\treturn {\n\t\tbase64,\n\t\tpromise,\n\t\texecute\n\t};\n}\nfunction imgLoaded(img) {\n\treturn new Promise((resolve, reject) => {\n\t\tif (!img.complete) {\n\t\t\timg.onload = () => {\n\t\t\t\tresolve();\n\t\t\t};\n\t\t\timg.onerror = reject;\n\t\t} else resolve();\n\t});\n}\nfunction blobToBase64(blob) {\n\treturn new Promise((resolve, reject) => {\n\t\tconst fr = new FileReader();\n\t\tfr.onload = (e) => {\n\t\t\tresolve(e.target.result);\n\t\t};\n\t\tfr.onerror = reject;\n\t\tfr.readAsDataURL(blob);\n\t});\n}\n\n//#endregion\n//#region useBattery/index.ts\n/**\n* Reactive Battery Status API.\n*\n* @see https://vueuse.org/useBattery\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useBattery(options = {}) {\n\tconst { navigator: navigator$1 = defaultNavigator } = options;\n\tconst events$1 = [\n\t\t\"chargingchange\",\n\t\t\"chargingtimechange\",\n\t\t\"dischargingtimechange\",\n\t\t\"levelchange\"\n\t];\n\tconst isSupported = /* @__PURE__ */ useSupported(() => navigator$1 && \"getBattery\" in navigator$1 && typeof navigator$1.getBattery === \"function\");\n\tconst charging = shallowRef(false);\n\tconst chargingTime = shallowRef(0);\n\tconst dischargingTime = shallowRef(0);\n\tconst level = shallowRef(1);\n\tlet battery;\n\tfunction updateBatteryInfo() {\n\t\tcharging.value = this.charging;\n\t\tchargingTime.value = this.chargingTime || 0;\n\t\tdischargingTime.value = this.dischargingTime || 0;\n\t\tlevel.value = this.level;\n\t}\n\tif (isSupported.value) navigator$1.getBattery().then((_battery) => {\n\t\tbattery = _battery;\n\t\tupdateBatteryInfo.call(battery);\n\t\tuseEventListener(battery, events$1, updateBatteryInfo, { passive: true });\n\t});\n\treturn {\n\t\tisSupported,\n\t\tcharging,\n\t\tchargingTime,\n\t\tdischargingTime,\n\t\tlevel\n\t};\n}\n\n//#endregion\n//#region useBluetooth/index.ts\n/* @__NO_SIDE_EFFECTS__ */\nfunction useBluetooth(options) {\n\tlet { acceptAllDevices = false } = options || {};\n\tconst { filters = void 0, optionalServices = void 0, navigator: navigator$1 = defaultNavigator } = options || {};\n\tconst isSupported = /* @__PURE__ */ useSupported(() => navigator$1 && \"bluetooth\" in navigator$1);\n\tconst device = shallowRef();\n\tconst error = shallowRef(null);\n\twatch(device, () => {\n\t\tconnectToBluetoothGATTServer();\n\t});\n\tasync function requestDevice() {\n\t\tif (!isSupported.value) return;\n\t\terror.value = null;\n\t\tif (filters && filters.length > 0) acceptAllDevices = false;\n\t\ttry {\n\t\t\tdevice.value = await (navigator$1 === null || navigator$1 === void 0 ? void 0 : navigator$1.bluetooth.requestDevice({\n\t\t\t\tacceptAllDevices,\n\t\t\t\tfilters,\n\t\t\t\toptionalServices\n\t\t\t}));\n\t\t} catch (err) {\n\t\t\terror.value = err;\n\t\t}\n\t}\n\tconst server = shallowRef();\n\tconst isConnected = shallowRef(false);\n\tfunction reset() {\n\t\tisConnected.value = false;\n\t\tdevice.value = void 0;\n\t\tserver.value = void 0;\n\t}\n\tasync function connectToBluetoothGATTServer() {\n\t\terror.value = null;\n\t\tif (device.value && device.value.gatt) {\n\t\t\tuseEventListener(device, \"gattserverdisconnected\", reset, { passive: true });\n\t\t\ttry {\n\t\t\t\tserver.value = await device.value.gatt.connect();\n\t\t\t\tisConnected.value = server.value.connected;\n\t\t\t} catch (err) {\n\t\t\t\terror.value = err;\n\t\t\t}\n\t\t}\n\t}\n\ttryOnMounted(() => {\n\t\tvar _device$value$gatt;\n\t\tif (device.value) (_device$value$gatt = device.value.gatt) === null || _device$value$gatt === void 0 || _device$value$gatt.connect();\n\t});\n\ttryOnScopeDispose(() => {\n\t\tvar _device$value$gatt2;\n\t\tif (device.value) (_device$value$gatt2 = device.value.gatt) === null || _device$value$gatt2 === void 0 || _device$value$gatt2.disconnect();\n\t});\n\treturn {\n\t\tisSupported,\n\t\tisConnected: readonly(isConnected),\n\t\tdevice,\n\t\trequestDevice,\n\t\tserver,\n\t\terror\n\t};\n}\n\n//#endregion\n//#region useSSRWidth/index.ts\nconst ssrWidthSymbol = Symbol(\"vueuse-ssr-width\");\n/* @__NO_SIDE_EFFECTS__ */\nfunction useSSRWidth() {\n\tconst ssrWidth = hasInjectionContext() ? injectLocal(ssrWidthSymbol, null) : null;\n\treturn typeof ssrWidth === \"number\" ? ssrWidth : void 0;\n}\nfunction provideSSRWidth(width, app) {\n\tif (app !== void 0) app.provide(ssrWidthSymbol, width);\n\telse provideLocal(ssrWidthSymbol, width);\n}\n\n//#endregion\n//#region useMediaQuery/index.ts\n/**\n* Reactive Media Query.\n*\n* @see https://vueuse.org/useMediaQuery\n* @param query\n* @param options\n*/\nfunction useMediaQuery(query, options = {}) {\n\tconst { window: window$1 = defaultWindow, ssrWidth = /* @__PURE__ */ useSSRWidth() } = options;\n\tconst isSupported = /* @__PURE__ */ useSupported(() => window$1 && \"matchMedia\" in window$1 && typeof window$1.matchMedia === \"function\");\n\tconst ssrSupport = shallowRef(typeof ssrWidth === \"number\");\n\tconst mediaQuery = shallowRef();\n\tconst matches = shallowRef(false);\n\tconst handler = (event) => {\n\t\tmatches.value = event.matches;\n\t};\n\twatchEffect(() => {\n\t\tif (ssrSupport.value) {\n\t\t\tssrSupport.value = !isSupported.value;\n\t\t\tmatches.value = toValue(query).split(\",\").some((queryString) => {\n\t\t\t\tconst not = queryString.includes(\"not all\");\n\t\t\t\tconst minWidth = queryString.match(/\\(\\s*min-width:\\s*(-?\\d+(?:\\.\\d*)?[a-z]+\\s*)\\)/);\n\t\t\t\tconst maxWidth = queryString.match(/\\(\\s*max-width:\\s*(-?\\d+(?:\\.\\d*)?[a-z]+\\s*)\\)/);\n\t\t\t\tlet res = Boolean(minWidth || maxWidth);\n\t\t\t\tif (minWidth && res) res = ssrWidth >= pxValue(minWidth[1]);\n\t\t\t\tif (maxWidth && res) res = ssrWidth <= pxValue(maxWidth[1]);\n\t\t\t\treturn not ? !res : res;\n\t\t\t});\n\t\t\treturn;\n\t\t}\n\t\tif (!isSupported.value) return;\n\t\tmediaQuery.value = window$1.matchMedia(toValue(query));\n\t\tmatches.value = mediaQuery.value.matches;\n\t});\n\tuseEventListener(mediaQuery, \"change\", handler, { passive: true });\n\treturn computed(() => matches.value);\n}\n\n//#endregion\n//#region useBreakpoints/breakpoints.ts\n/**\n* Breakpoints from Tailwind V2\n*\n* @see https://tailwindcss.com/docs/breakpoints\n*/\nconst breakpointsTailwind = {\n\t\"sm\": 640,\n\t\"md\": 768,\n\t\"lg\": 1024,\n\t\"xl\": 1280,\n\t\"2xl\": 1536\n};\n/**\n* Breakpoints from Bootstrap V5\n*\n* @see https://getbootstrap.com/docs/5.0/layout/breakpoints\n*/\nconst breakpointsBootstrapV5 = {\n\txs: 0,\n\tsm: 576,\n\tmd: 768,\n\tlg: 992,\n\txl: 1200,\n\txxl: 1400\n};\n/**\n* Breakpoints from Vuetify V2\n*\n* @see https://v2.vuetifyjs.com/en/features/breakpoints/\n*/\nconst breakpointsVuetifyV2 = {\n\txs: 0,\n\tsm: 600,\n\tmd: 960,\n\tlg: 1264,\n\txl: 1904\n};\n/**\n* Breakpoints from Vuetify V3\n*\n* @see https://vuetifyjs.com/en/styles/float/#overview\n*/\nconst breakpointsVuetifyV3 = {\n\txs: 0,\n\tsm: 600,\n\tmd: 960,\n\tlg: 1280,\n\txl: 1920,\n\txxl: 2560\n};\n/**\n* Alias to `breakpointsVuetifyV2`\n*\n* @deprecated explictly use `breakpointsVuetifyV2` or `breakpointsVuetifyV3` instead\n*/\nconst breakpointsVuetify = breakpointsVuetifyV2;\n/**\n* Breakpoints from Ant Design\n*\n* @see https://ant.design/components/layout/#breakpoint-width\n*/\nconst breakpointsAntDesign = {\n\txs: 480,\n\tsm: 576,\n\tmd: 768,\n\tlg: 992,\n\txl: 1200,\n\txxl: 1600\n};\n/**\n* Breakpoints from Quasar V2\n*\n* @see https://quasar.dev/style/breakpoints\n*/\nconst breakpointsQuasar = {\n\txs: 0,\n\tsm: 600,\n\tmd: 1024,\n\tlg: 1440,\n\txl: 1920\n};\n/**\n* Sematic Breakpoints\n*/\nconst breakpointsSematic = {\n\tmobileS: 320,\n\tmobileM: 375,\n\tmobileL: 425,\n\ttablet: 768,\n\tlaptop: 1024,\n\tlaptopL: 1440,\n\tdesktop4K: 2560\n};\n/**\n* Breakpoints from Master CSS\n*\n* @see https://docs.master.co/css/breakpoints\n*/\nconst breakpointsMasterCss = {\n\t\"3xs\": 360,\n\t\"2xs\": 480,\n\t\"xs\": 600,\n\t\"sm\": 768,\n\t\"md\": 1024,\n\t\"lg\": 1280,\n\t\"xl\": 1440,\n\t\"2xl\": 1600,\n\t\"3xl\": 1920,\n\t\"4xl\": 2560\n};\n/**\n* Breakpoints from PrimeFlex\n*\n* @see https://primeflex.org/installation\n*/\nconst breakpointsPrimeFlex = {\n\tsm: 576,\n\tmd: 768,\n\tlg: 992,\n\txl: 1200\n};\n/**\n* Breakpoints from ElementUI/ElementPlus\n*\n* @see https://element.eleme.io/#/en-US/component/layout\n* @see https://element-plus.org/en-US/component/layout.html\n*/\nconst breakpointsElement = {\n\txs: 0,\n\tsm: 768,\n\tmd: 992,\n\tlg: 1200,\n\txl: 1920\n};\n\n//#endregion\n//#region useBreakpoints/index.ts\n/**\n* Reactively viewport breakpoints\n*\n* @see https://vueuse.org/useBreakpoints\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useBreakpoints(breakpoints, options = {}) {\n\tfunction getValue$1(k, delta) {\n\t\tlet v = toValue(breakpoints[toValue(k)]);\n\t\tif (delta != null) v = increaseWithUnit(v, delta);\n\t\tif (typeof v === \"number\") v = `${v}px`;\n\t\treturn v;\n\t}\n\tconst { window: window$1 = defaultWindow, strategy = \"min-width\", ssrWidth = /* @__PURE__ */ useSSRWidth() } = options;\n\tconst ssrSupport = typeof ssrWidth === \"number\";\n\tconst mounted = ssrSupport ? shallowRef(false) : { value: true };\n\tif (ssrSupport) tryOnMounted(() => mounted.value = !!window$1);\n\tfunction match(query, size) {\n\t\tif (!mounted.value && ssrSupport) return query === \"min\" ? ssrWidth >= pxValue(size) : ssrWidth <= pxValue(size);\n\t\tif (!window$1) return false;\n\t\treturn window$1.matchMedia(`(${query}-width: ${size})`).matches;\n\t}\n\tconst greaterOrEqual = (k) => {\n\t\treturn useMediaQuery(() => `(min-width: ${getValue$1(k)})`, options);\n\t};\n\tconst smallerOrEqual = (k) => {\n\t\treturn useMediaQuery(() => `(max-width: ${getValue$1(k)})`, options);\n\t};\n\tconst shortcutMethods = Object.keys(breakpoints).reduce((shortcuts, k) => {\n\t\tObject.defineProperty(shortcuts, k, {\n\t\t\tget: () => strategy === \"min-width\" ? greaterOrEqual(k) : smallerOrEqual(k),\n\t\t\tenumerable: true,\n\t\t\tconfigurable: true\n\t\t});\n\t\treturn shortcuts;\n\t}, {});\n\tfunction current() {\n\t\tconst points = Object.keys(breakpoints).map((k) => [\n\t\t\tk,\n\t\t\tshortcutMethods[k],\n\t\t\tpxValue(getValue$1(k))\n\t\t]).sort((a, b) => a[2] - b[2]);\n\t\treturn computed(() => points.filter(([, v]) => v.value).map(([k]) => k));\n\t}\n\treturn Object.assign(shortcutMethods, {\n\t\tgreaterOrEqual,\n\t\tsmallerOrEqual,\n\t\tgreater(k) {\n\t\t\treturn useMediaQuery(() => `(min-width: ${getValue$1(k, .1)})`, options);\n\t\t},\n\t\tsmaller(k) {\n\t\t\treturn useMediaQuery(() => `(max-width: ${getValue$1(k, -.1)})`, options);\n\t\t},\n\t\tbetween(a, b) {\n\t\t\treturn useMediaQuery(() => `(min-width: ${getValue$1(a)}) and (max-width: ${getValue$1(b, -.1)})`, options);\n\t\t},\n\t\tisGreater(k) {\n\t\t\treturn match(\"min\", getValue$1(k, .1));\n\t\t},\n\t\tisGreaterOrEqual(k) {\n\t\t\treturn match(\"min\", getValue$1(k));\n\t\t},\n\t\tisSmaller(k) {\n\t\t\treturn match(\"max\", getValue$1(k, -.1));\n\t\t},\n\t\tisSmallerOrEqual(k) {\n\t\t\treturn match(\"max\", getValue$1(k));\n\t\t},\n\t\tisInBetween(a, b) {\n\t\t\treturn match(\"min\", getValue$1(a)) && match(\"max\", getValue$1(b, -.1));\n\t\t},\n\t\tcurrent,\n\t\tactive() {\n\t\t\tconst bps = current();\n\t\t\treturn computed(() => bps.value.length === 0 ? \"\" : bps.value.at(strategy === \"min-width\" ? -1 : 0));\n\t\t}\n\t});\n}\n\n//#endregion\n//#region useBroadcastChannel/index.ts\n/**\n* Reactive BroadcastChannel\n*\n* @see https://vueuse.org/useBroadcastChannel\n* @see https://developer.mozilla.org/en-US/docs/Web/API/BroadcastChannel\n* @param options\n*\n*/\nfunction useBroadcastChannel(options) {\n\tconst { name, window: window$1 = defaultWindow } = options;\n\tconst isSupported = /* @__PURE__ */ useSupported(() => window$1 && \"BroadcastChannel\" in window$1);\n\tconst isClosed = shallowRef(false);\n\tconst channel = ref();\n\tconst data = ref();\n\tconst error = shallowRef(null);\n\tconst post = (data$1) => {\n\t\tif (channel.value) channel.value.postMessage(data$1);\n\t};\n\tconst close = () => {\n\t\tif (channel.value) channel.value.close();\n\t\tisClosed.value = true;\n\t};\n\tif (isSupported.value) tryOnMounted(() => {\n\t\terror.value = null;\n\t\tchannel.value = new BroadcastChannel(name);\n\t\tconst listenerOptions = { passive: true };\n\t\tuseEventListener(channel, \"message\", (e) => {\n\t\t\tdata.value = e.data;\n\t\t}, listenerOptions);\n\t\tuseEventListener(channel, \"messageerror\", (e) => {\n\t\t\terror.value = e;\n\t\t}, listenerOptions);\n\t\tuseEventListener(channel, \"close\", () => {\n\t\t\tisClosed.value = true;\n\t\t}, listenerOptions);\n\t});\n\ttryOnScopeDispose(() => {\n\t\tclose();\n\t});\n\treturn {\n\t\tisSupported,\n\t\tchannel,\n\t\tdata,\n\t\tpost,\n\t\tclose,\n\t\terror,\n\t\tisClosed\n\t};\n}\n\n//#endregion\n//#region useBrowserLocation/index.ts\nconst WRITABLE_PROPERTIES = [\n\t\"hash\",\n\t\"host\",\n\t\"hostname\",\n\t\"href\",\n\t\"pathname\",\n\t\"port\",\n\t\"protocol\",\n\t\"search\"\n];\n/**\n* Reactive browser location.\n*\n* @see https://vueuse.org/useBrowserLocation\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useBrowserLocation(options = {}) {\n\tconst { window: window$1 = defaultWindow } = options;\n\tconst refs = Object.fromEntries(WRITABLE_PROPERTIES.map((key) => [key, ref()]));\n\tfor (const [key, ref$1] of objectEntries(refs)) watch(ref$1, (value) => {\n\t\tif (!(window$1 === null || window$1 === void 0 ? void 0 : window$1.location) || window$1.location[key] === value) return;\n\t\twindow$1.location[key] = value;\n\t});\n\tconst buildState = (trigger) => {\n\t\tvar _window$location;\n\t\tconst { state: state$1, length } = (window$1 === null || window$1 === void 0 ? void 0 : window$1.history) || {};\n\t\tconst { origin } = (window$1 === null || window$1 === void 0 ? void 0 : window$1.location) || {};\n\t\tfor (const key of WRITABLE_PROPERTIES) refs[key].value = window$1 === null || window$1 === void 0 || (_window$location = window$1.location) === null || _window$location === void 0 ? void 0 : _window$location[key];\n\t\treturn reactive({\n\t\t\ttrigger,\n\t\t\tstate: state$1,\n\t\t\tlength,\n\t\t\torigin,\n\t\t\t...refs\n\t\t});\n\t};\n\tconst state = ref(buildState(\"load\"));\n\tif (window$1) {\n\t\tconst listenerOptions = { passive: true };\n\t\tuseEventListener(window$1, \"popstate\", () => state.value = buildState(\"popstate\"), listenerOptions);\n\t\tuseEventListener(window$1, \"hashchange\", () => state.value = buildState(\"hashchange\"), listenerOptions);\n\t}\n\treturn state;\n}\n\n//#endregion\n//#region useCached/index.ts\nfunction useCached(refValue, comparator = (a, b) => a === b, options) {\n\tconst { deepRefs = true,...watchOptions } = options || {};\n\tconst cachedValue = createRef(refValue.value, deepRefs);\n\twatch(() => refValue.value, (value) => {\n\t\tif (!comparator(value, cachedValue.value)) cachedValue.value = value;\n\t}, watchOptions);\n\treturn cachedValue;\n}\n\n//#endregion\n//#region usePermission/index.ts\n/**\n* Reactive Permissions API.\n*\n* @see https://vueuse.org/usePermission\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction usePermission(permissionDesc, options = {}) {\n\tconst { controls = false, navigator: navigator$1 = defaultNavigator } = options;\n\tconst isSupported = /* @__PURE__ */ useSupported(() => navigator$1 && \"permissions\" in navigator$1);\n\tconst permissionStatus = shallowRef();\n\tconst desc = typeof permissionDesc === \"string\" ? { name: permissionDesc } : permissionDesc;\n\tconst state = shallowRef();\n\tconst update = () => {\n\t\tvar _permissionStatus$val, _permissionStatus$val2;\n\t\tstate.value = (_permissionStatus$val = (_permissionStatus$val2 = permissionStatus.value) === null || _permissionStatus$val2 === void 0 ? void 0 : _permissionStatus$val2.state) !== null && _permissionStatus$val !== void 0 ? _permissionStatus$val : \"prompt\";\n\t};\n\tuseEventListener(permissionStatus, \"change\", update, { passive: true });\n\tconst query = createSingletonPromise(async () => {\n\t\tif (!isSupported.value) return;\n\t\tif (!permissionStatus.value) try {\n\t\t\tpermissionStatus.value = await navigator$1.permissions.query(desc);\n\t\t} catch (_unused) {\n\t\t\tpermissionStatus.value = void 0;\n\t\t} finally {\n\t\t\tupdate();\n\t\t}\n\t\tif (controls) return toRaw(permissionStatus.value);\n\t});\n\tquery();\n\tif (controls) return {\n\t\tstate,\n\t\tisSupported,\n\t\tquery\n\t};\n\telse return state;\n}\n\n//#endregion\n//#region useClipboard/index.ts\nfunction useClipboard(options = {}) {\n\tconst { navigator: navigator$1 = defaultNavigator, read = false, source, copiedDuring = 1500, legacy = false } = options;\n\tconst isClipboardApiSupported = /* @__PURE__ */ useSupported(() => navigator$1 && \"clipboard\" in navigator$1);\n\tconst permissionRead = usePermission(\"clipboard-read\");\n\tconst permissionWrite = usePermission(\"clipboard-write\");\n\tconst isSupported = computed(() => isClipboardApiSupported.value || legacy);\n\tconst text = shallowRef(\"\");\n\tconst copied = shallowRef(false);\n\tconst timeout = useTimeoutFn(() => copied.value = false, copiedDuring, { immediate: false });\n\tasync function updateText() {\n\t\tlet useLegacy = !(isClipboardApiSupported.value && isAllowed(permissionRead.value));\n\t\tif (!useLegacy) try {\n\t\t\ttext.value = await navigator$1.clipboard.readText();\n\t\t} catch (_unused) {\n\t\t\tuseLegacy = true;\n\t\t}\n\t\tif (useLegacy) text.value = legacyRead();\n\t}\n\tif (isSupported.value && read) useEventListener([\"copy\", \"cut\"], updateText, { passive: true });\n\tasync function copy(value = toValue(source)) {\n\t\tif (isSupported.value && value != null) {\n\t\t\tlet useLegacy = !(isClipboardApiSupported.value && isAllowed(permissionWrite.value));\n\t\t\tif (!useLegacy) try {\n\t\t\t\tawait navigator$1.clipboard.writeText(value);\n\t\t\t} catch (_unused2) {\n\t\t\t\tuseLegacy = true;\n\t\t\t}\n\t\t\tif (useLegacy) legacyCopy(value);\n\t\t\ttext.value = value;\n\t\t\tcopied.value = true;\n\t\t\ttimeout.start();\n\t\t}\n\t}\n\tfunction legacyCopy(value) {\n\t\tconst ta = document.createElement(\"textarea\");\n\t\tta.value = value;\n\t\tta.style.position = \"absolute\";\n\t\tta.style.opacity = \"0\";\n\t\tta.setAttribute(\"readonly\", \"\");\n\t\tdocument.body.appendChild(ta);\n\t\tta.select();\n\t\tdocument.execCommand(\"copy\");\n\t\tta.remove();\n\t}\n\tfunction legacyRead() {\n\t\tvar _document$getSelectio, _document, _document$getSelectio2;\n\t\treturn (_document$getSelectio = (_document = document) === null || _document === void 0 || (_document$getSelectio2 = _document.getSelection) === null || _document$getSelectio2 === void 0 || (_document$getSelectio2 = _document$getSelectio2.call(_document)) === null || _document$getSelectio2 === void 0 ? void 0 : _document$getSelectio2.toString()) !== null && _document$getSelectio !== void 0 ? _document$getSelectio : \"\";\n\t}\n\tfunction isAllowed(status) {\n\t\treturn status === \"granted\" || status === \"prompt\";\n\t}\n\treturn {\n\t\tisSupported,\n\t\ttext: readonly(text),\n\t\tcopied: readonly(copied),\n\t\tcopy\n\t};\n}\n\n//#endregion\n//#region useClipboardItems/index.ts\nfunction useClipboardItems(options = {}) {\n\tconst { navigator: navigator$1 = defaultNavigator, read = false, source, copiedDuring = 1500 } = options;\n\tconst isSupported = /* @__PURE__ */ useSupported(() => navigator$1 && \"clipboard\" in navigator$1);\n\tconst content = ref([]);\n\tconst copied = shallowRef(false);\n\tconst timeout = useTimeoutFn(() => copied.value = false, copiedDuring, { immediate: false });\n\tfunction updateContent() {\n\t\tif (isSupported.value) navigator$1.clipboard.read().then((items) => {\n\t\t\tcontent.value = items;\n\t\t});\n\t}\n\tif (isSupported.value && read) useEventListener([\"copy\", \"cut\"], updateContent, { passive: true });\n\tasync function copy(value = toValue(source)) {\n\t\tif (isSupported.value && value != null) {\n\t\t\tawait navigator$1.clipboard.write(value);\n\t\t\tcontent.value = value;\n\t\t\tcopied.value = true;\n\t\t\ttimeout.start();\n\t\t}\n\t}\n\treturn {\n\t\tisSupported,\n\t\tcontent: shallowReadonly(content),\n\t\tcopied: readonly(copied),\n\t\tcopy,\n\t\tread: updateContent\n\t};\n}\n\n//#endregion\n//#region useCloned/index.ts\nfunction cloneFnJSON(source) {\n\treturn JSON.parse(JSON.stringify(source));\n}\nfunction useCloned(source, options = {}) {\n\tconst cloned = ref({});\n\tconst isModified = shallowRef(false);\n\tlet _lastSync = false;\n\tconst { manual, clone = cloneFnJSON, deep = true, immediate = true } = options;\n\twatch(cloned, () => {\n\t\tif (_lastSync) {\n\t\t\t_lastSync = false;\n\t\t\treturn;\n\t\t}\n\t\tisModified.value = true;\n\t}, {\n\t\tdeep: true,\n\t\tflush: \"sync\"\n\t});\n\tfunction sync() {\n\t\t_lastSync = true;\n\t\tisModified.value = false;\n\t\tcloned.value = clone(toValue(source));\n\t}\n\tif (!manual && (isRef(source) || typeof source === \"function\")) watch(source, sync, {\n\t\t...options,\n\t\tdeep,\n\t\timmediate\n\t});\n\telse sync();\n\treturn {\n\t\tcloned,\n\t\tisModified,\n\t\tsync\n\t};\n}\n\n//#endregion\n//#region ssr-handlers.ts\nconst _global = typeof globalThis !== \"undefined\" ? globalThis : typeof window !== \"undefined\" ? window : typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : {};\nconst globalKey = \"__vueuse_ssr_handlers__\";\nconst handlers = /* @__PURE__ */ getHandlers();\nfunction getHandlers() {\n\tif (!(globalKey in _global)) _global[globalKey] = _global[globalKey] || {};\n\treturn _global[globalKey];\n}\nfunction getSSRHandler(key, fallback) {\n\treturn handlers[key] || fallback;\n}\nfunction setSSRHandler(key, fn) {\n\thandlers[key] = fn;\n}\n\n//#endregion\n//#region usePreferredDark/index.ts\n/**\n* Reactive dark theme preference.\n*\n* @see https://vueuse.org/usePreferredDark\n* @param [options]\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction usePreferredDark(options) {\n\treturn useMediaQuery(\"(prefers-color-scheme: dark)\", options);\n}\n\n//#endregion\n//#region useStorage/guess.ts\nfunction guessSerializerType(rawInit) {\n\treturn rawInit == null ? \"any\" : rawInit instanceof Set ? \"set\" : rawInit instanceof Map ? \"map\" : rawInit instanceof Date ? \"date\" : typeof rawInit === \"boolean\" ? \"boolean\" : typeof rawInit === \"string\" ? \"string\" : typeof rawInit === \"object\" ? \"object\" : !Number.isNaN(rawInit) ? \"number\" : \"any\";\n}\n\n//#endregion\n//#region useStorage/index.ts\nconst StorageSerializers = {\n\tboolean: {\n\t\tread: (v) => v === \"true\",\n\t\twrite: (v) => String(v)\n\t},\n\tobject: {\n\t\tread: (v) => JSON.parse(v),\n\t\twrite: (v) => JSON.stringify(v)\n\t},\n\tnumber: {\n\t\tread: (v) => Number.parseFloat(v),\n\t\twrite: (v) => String(v)\n\t},\n\tany: {\n\t\tread: (v) => v,\n\t\twrite: (v) => String(v)\n\t},\n\tstring: {\n\t\tread: (v) => v,\n\t\twrite: (v) => String(v)\n\t},\n\tmap: {\n\t\tread: (v) => new Map(JSON.parse(v)),\n\t\twrite: (v) => JSON.stringify(Array.from(v.entries()))\n\t},\n\tset: {\n\t\tread: (v) => new Set(JSON.parse(v)),\n\t\twrite: (v) => JSON.stringify(Array.from(v))\n\t},\n\tdate: {\n\t\tread: (v) => new Date(v),\n\t\twrite: (v) => v.toISOString()\n\t}\n};\nconst customStorageEventName = \"vueuse-storage\";\n/**\n* Reactive LocalStorage/SessionStorage.\n*\n* @see https://vueuse.org/useStorage\n*/\nfunction useStorage(key, defaults$1, storage, options = {}) {\n\tvar _options$serializer;\n\tconst { flush = \"pre\", deep = true, listenToStorageChanges = true, writeDefaults = true, mergeDefaults = false, shallow, window: window$1 = defaultWindow, eventFilter, onError = (e) => {\n\t\tconsole.error(e);\n\t}, initOnMounted } = options;\n\tconst data = (shallow ? shallowRef : ref)(typeof defaults$1 === \"function\" ? defaults$1() : defaults$1);\n\tconst keyComputed = computed(() => toValue(key));\n\tif (!storage) try {\n\t\tstorage = getSSRHandler(\"getDefaultStorage\", () => defaultWindow === null || defaultWindow === void 0 ? void 0 : defaultWindow.localStorage)();\n\t} catch (e) {\n\t\tonError(e);\n\t}\n\tif (!storage) return data;\n\tconst rawInit = toValue(defaults$1);\n\tconst type = guessSerializerType(rawInit);\n\tconst serializer = (_options$serializer = options.serializer) !== null && _options$serializer !== void 0 ? _options$serializer : StorageSerializers[type];\n\tconst { pause: pauseWatch, resume: resumeWatch } = watchPausable(data, (newValue) => write(newValue), {\n\t\tflush,\n\t\tdeep,\n\t\teventFilter\n\t});\n\twatch(keyComputed, () => update(), { flush });\n\tlet firstMounted = false;\n\tconst onStorageEvent = (ev) => {\n\t\tif (initOnMounted && !firstMounted) return;\n\t\tupdate(ev);\n\t};\n\tconst onStorageCustomEvent = (ev) => {\n\t\tif (initOnMounted && !firstMounted) return;\n\t\tupdateFromCustomEvent(ev);\n\t};\n\t/**\n\t* The custom event is needed for same-document syncing when using custom\n\t* storage backends, but it doesn't work across different documents.\n\t*\n\t* TODO: Consider implementing a BroadcastChannel-based solution that fixes this.\n\t*/\n\tif (window$1 && listenToStorageChanges) if (storage instanceof Storage) useEventListener(window$1, \"storage\", onStorageEvent, { passive: true });\n\telse useEventListener(window$1, customStorageEventName, onStorageCustomEvent);\n\tif (initOnMounted) tryOnMounted(() => {\n\t\tfirstMounted = true;\n\t\tupdate();\n\t});\n\telse update();\n\tfunction dispatchWriteEvent(oldValue, newValue) {\n\t\tif (window$1) {\n\t\t\tconst payload = {\n\t\t\t\tkey: keyComputed.value,\n\t\t\t\toldValue,\n\t\t\t\tnewValue,\n\t\t\t\tstorageArea: storage\n\t\t\t};\n\t\t\twindow$1.dispatchEvent(storage instanceof Storage ? new StorageEvent(\"storage\", payload) : new CustomEvent(customStorageEventName, { detail: payload }));\n\t\t}\n\t}\n\tfunction write(v) {\n\t\ttry {\n\t\t\tconst oldValue = storage.getItem(keyComputed.value);\n\t\t\tif (v == null) {\n\t\t\t\tdispatchWriteEvent(oldValue, null);\n\t\t\t\tstorage.removeItem(keyComputed.value);\n\t\t\t} else {\n\t\t\t\tconst serialized = serializer.write(v);\n\t\t\t\tif (oldValue !== serialized) {\n\t\t\t\t\tstorage.setItem(keyComputed.value, serialized);\n\t\t\t\t\tdispatchWriteEvent(oldValue, serialized);\n\t\t\t\t}\n\t\t\t}\n\t\t} catch (e) {\n\t\t\tonError(e);\n\t\t}\n\t}\n\tfunction read(event) {\n\t\tconst rawValue = event ? event.newValue : storage.getItem(keyComputed.value);\n\t\tif (rawValue == null) {\n\t\t\tif (writeDefaults && rawInit != null) storage.setItem(keyComputed.value, serializer.write(rawInit));\n\t\t\treturn rawInit;\n\t\t} else if (!event && mergeDefaults) {\n\t\t\tconst value = serializer.read(rawValue);\n\t\t\tif (typeof mergeDefaults === \"function\") return mergeDefaults(value, rawInit);\n\t\t\telse if (type === \"object\" && !Array.isArray(value)) return {\n\t\t\t\t...rawInit,\n\t\t\t\t...value\n\t\t\t};\n\t\t\treturn value;\n\t\t} else if (typeof rawValue !== \"string\") return rawValue;\n\t\telse return serializer.read(rawValue);\n\t}\n\tfunction update(event) {\n\t\tif (event && event.storageArea !== storage) return;\n\t\tif (event && event.key == null) {\n\t\t\tdata.value = rawInit;\n\t\t\treturn;\n\t\t}\n\t\tif (event && event.key !== keyComputed.value) return;\n\t\tpauseWatch();\n\t\ttry {\n\t\t\tconst serializedData = serializer.write(data.value);\n\t\t\tif (event === void 0 || (event === null || event === void 0 ? void 0 : event.newValue) !== serializedData) data.value = read(event);\n\t\t} catch (e) {\n\t\t\tonError(e);\n\t\t} finally {\n\t\t\tif (event) nextTick(resumeWatch);\n\t\t\telse resumeWatch();\n\t\t}\n\t}\n\tfunction updateFromCustomEvent(event) {\n\t\tupdate(event.detail);\n\t}\n\treturn data;\n}\n\n//#endregion\n//#region useColorMode/index.ts\nconst CSS_DISABLE_TRANS = \"*,*::before,*::after{-webkit-transition:none!important;-moz-transition:none!important;-o-transition:none!important;-ms-transition:none!important;transition:none!important}\";\n/**\n* Reactive color mode with auto data persistence.\n*\n* @see https://vueuse.org/useColorMode\n* @param options\n*/\nfunction useColorMode(options = {}) {\n\tconst { selector = \"html\", attribute = \"class\", initialValue = \"auto\", window: window$1 = defaultWindow, storage, storageKey = \"vueuse-color-scheme\", listenToStorageChanges = true, storageRef, emitAuto, disableTransition = true } = options;\n\tconst modes = {\n\t\tauto: \"\",\n\t\tlight: \"light\",\n\t\tdark: \"dark\",\n\t\t...options.modes || {}\n\t};\n\tconst preferredDark = usePreferredDark({ window: window$1 });\n\tconst system = computed(() => preferredDark.value ? \"dark\" : \"light\");\n\tconst store = storageRef || (storageKey == null ? toRef(initialValue) : useStorage(storageKey, initialValue, storage, {\n\t\twindow: window$1,\n\t\tlistenToStorageChanges\n\t}));\n\tconst state = computed(() => store.value === \"auto\" ? system.value : store.value);\n\tconst updateHTMLAttrs = getSSRHandler(\"updateHTMLAttrs\", (selector$1, attribute$1, value) => {\n\t\tconst el = typeof selector$1 === \"string\" ? window$1 === null || window$1 === void 0 ? void 0 : window$1.document.querySelector(selector$1) : unrefElement(selector$1);\n\t\tif (!el) return;\n\t\tconst classesToAdd = /* @__PURE__ */ new Set();\n\t\tconst classesToRemove = /* @__PURE__ */ new Set();\n\t\tlet attributeToChange = null;\n\t\tif (attribute$1 === \"class\") {\n\t\t\tconst current = value.split(/\\s/g);\n\t\t\tObject.values(modes).flatMap((i) => (i || \"\").split(/\\s/g)).filter(Boolean).forEach((v) => {\n\t\t\t\tif (current.includes(v)) classesToAdd.add(v);\n\t\t\t\telse classesToRemove.add(v);\n\t\t\t});\n\t\t} else attributeToChange = {\n\t\t\tkey: attribute$1,\n\t\t\tvalue\n\t\t};\n\t\tif (classesToAdd.size === 0 && classesToRemove.size === 0 && attributeToChange === null) return;\n\t\tlet style;\n\t\tif (disableTransition) {\n\t\t\tstyle = window$1.document.createElement(\"style\");\n\t\t\tstyle.appendChild(document.createTextNode(CSS_DISABLE_TRANS));\n\t\t\twindow$1.document.head.appendChild(style);\n\t\t}\n\t\tfor (const c of classesToAdd) el.classList.add(c);\n\t\tfor (const c of classesToRemove) el.classList.remove(c);\n\t\tif (attributeToChange) el.setAttribute(attributeToChange.key, attributeToChange.value);\n\t\tif (disableTransition) {\n\t\t\twindow$1.getComputedStyle(style).opacity;\n\t\t\tdocument.head.removeChild(style);\n\t\t}\n\t});\n\tfunction defaultOnChanged(mode) {\n\t\tvar _modes$mode;\n\t\tupdateHTMLAttrs(selector, attribute, (_modes$mode = modes[mode]) !== null && _modes$mode !== void 0 ? _modes$mode : mode);\n\t}\n\tfunction onChanged(mode) {\n\t\tif (options.onChanged) options.onChanged(mode, defaultOnChanged);\n\t\telse defaultOnChanged(mode);\n\t}\n\twatch(state, onChanged, {\n\t\tflush: \"post\",\n\t\timmediate: true\n\t});\n\ttryOnMounted(() => onChanged(state.value));\n\tconst auto = computed({\n\t\tget() {\n\t\t\treturn emitAuto ? store.value : state.value;\n\t\t},\n\t\tset(v) {\n\t\t\tstore.value = v;\n\t\t}\n\t});\n\treturn Object.assign(auto, {\n\t\tstore,\n\t\tsystem,\n\t\tstate\n\t});\n}\n\n//#endregion\n//#region useConfirmDialog/index.ts\n/**\n* Hooks for creating confirm dialogs. Useful for modal windows, popups and logins.\n*\n* @see https://vueuse.org/useConfirmDialog/\n* @param revealed `boolean` `ref` that handles a modal window\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useConfirmDialog(revealed = shallowRef(false)) {\n\tconst confirmHook = createEventHook();\n\tconst cancelHook = createEventHook();\n\tconst revealHook = createEventHook();\n\tlet _resolve = noop;\n\tconst reveal = (data) => {\n\t\trevealHook.trigger(data);\n\t\trevealed.value = true;\n\t\treturn new Promise((resolve) => {\n\t\t\t_resolve = resolve;\n\t\t});\n\t};\n\tconst confirm = (data) => {\n\t\trevealed.value = false;\n\t\tconfirmHook.trigger(data);\n\t\t_resolve({\n\t\t\tdata,\n\t\t\tisCanceled: false\n\t\t});\n\t};\n\tconst cancel = (data) => {\n\t\trevealed.value = false;\n\t\tcancelHook.trigger(data);\n\t\t_resolve({\n\t\t\tdata,\n\t\t\tisCanceled: true\n\t\t});\n\t};\n\treturn {\n\t\tisRevealed: computed(() => revealed.value),\n\t\treveal,\n\t\tconfirm,\n\t\tcancel,\n\t\tonReveal: revealHook.on,\n\t\tonConfirm: confirmHook.on,\n\t\tonCancel: cancelHook.on\n\t};\n}\n\n//#endregion\n//#region useCountdown/index.ts\nfunction getDefaultScheduler$8(options) {\n\tif (\"interval\" in options || \"immediate\" in options) {\n\t\tconst { interval = 1e3, immediate = false } = options;\n\t\treturn (cb) => useIntervalFn(cb, interval, { immediate });\n\t}\n\treturn (cb) => useIntervalFn(cb, 1e3, { immediate: false });\n}\n/**\n* Reactive countdown timer in seconds.\n*\n* @param initialCountdown\n* @param options\n*\n* @see https://vueuse.org/useCountdown\n*/\nfunction useCountdown(initialCountdown, options = {}) {\n\tconst remaining = shallowRef(toValue(initialCountdown));\n\tconst { scheduler = getDefaultScheduler$8(options), onTick, onComplete } = options;\n\tconst controls = scheduler(() => {\n\t\tconst value = remaining.value - 1;\n\t\tremaining.value = value < 0 ? 0 : value;\n\t\tonTick === null || onTick === void 0 || onTick();\n\t\tif (remaining.value <= 0) {\n\t\t\tcontrols.pause();\n\t\t\tonComplete === null || onComplete === void 0 || onComplete();\n\t\t}\n\t});\n\tconst reset = (countdown) => {\n\t\tvar _toValue;\n\t\tremaining.value = (_toValue = toValue(countdown)) !== null && _toValue !== void 0 ? _toValue : toValue(initialCountdown);\n\t};\n\tconst stop = () => {\n\t\tcontrols.pause();\n\t\treset();\n\t};\n\tconst resume = () => {\n\t\tif (!controls.isActive.value) {\n\t\t\tif (remaining.value > 0) controls.resume();\n\t\t}\n\t};\n\tconst start = (countdown) => {\n\t\treset(countdown);\n\t\tcontrols.resume();\n\t};\n\treturn {\n\t\tremaining,\n\t\treset,\n\t\tstop,\n\t\tstart,\n\t\tpause: controls.pause,\n\t\tresume,\n\t\tisActive: controls.isActive\n\t};\n}\n\n//#endregion\n//#region useCssSupports/index.ts\nfunction useCssSupports(...args) {\n\tlet options = {};\n\tif (typeof toValue(args.at(-1)) === \"object\") options = args.pop();\n\tconst [prop, value] = args;\n\tconst { window: window$1 = defaultWindow, ssrValue = false } = options;\n\tconst isMounted = useMounted();\n\treturn { isSupported: computed(() => {\n\t\tisMounted.value;\n\t\tif (!isClient) return ssrValue;\n\t\treturn args.length === 2 ? window$1 === null || window$1 === void 0 ? void 0 : window$1.CSS.supports(toValue(prop), toValue(value)) : window$1 === null || window$1 === void 0 ? void 0 : window$1.CSS.supports(toValue(prop));\n\t}) };\n}\n\n//#endregion\n//#region useCssVar/index.ts\n/**\n* Manipulate CSS variables.\n*\n* @see https://vueuse.org/useCssVar\n* @param prop\n* @param target\n* @param options\n*/\nfunction useCssVar(prop, target, options = {}) {\n\tconst { window: window$1 = defaultWindow, initialValue, observe = false } = options;\n\tconst variable = shallowRef(initialValue);\n\tconst elRef = computed(() => {\n\t\tvar _window$document;\n\t\treturn unrefElement(target) || (window$1 === null || window$1 === void 0 || (_window$document = window$1.document) === null || _window$document === void 0 ? void 0 : _window$document.documentElement);\n\t});\n\tfunction updateCssVar() {\n\t\tconst key = toValue(prop);\n\t\tconst el = toValue(elRef);\n\t\tif (el && window$1 && key) {\n\t\t\tvar _window$getComputedSt;\n\t\t\tvariable.value = ((_window$getComputedSt = window$1.getComputedStyle(el).getPropertyValue(key)) === null || _window$getComputedSt === void 0 ? void 0 : _window$getComputedSt.trim()) || variable.value || initialValue;\n\t\t}\n\t}\n\tif (observe) useMutationObserver(elRef, updateCssVar, {\n\t\tattributeFilter: [\"style\", \"class\"],\n\t\twindow: window$1\n\t});\n\twatch([elRef, () => toValue(prop)], (_, old) => {\n\t\tif (old[0] && old[1]) old[0].style.removeProperty(old[1]);\n\t\tupdateCssVar();\n\t}, { immediate: true });\n\twatch([variable, elRef], ([val, el]) => {\n\t\tconst raw_prop = toValue(prop);\n\t\tif ((el === null || el === void 0 ? void 0 : el.style) && raw_prop) if (val == null) el.style.removeProperty(raw_prop);\n\t\telse el.style.setProperty(raw_prop, val);\n\t}, { immediate: true });\n\treturn variable;\n}\n\n//#endregion\n//#region useCurrentElement/index.ts\nfunction useCurrentElement(rootComponent) {\n\tconst vm = getCurrentInstance();\n\tconst currentElement = computedWithControl(() => null, () => rootComponent ? unrefElement(rootComponent) : vm.proxy.$el);\n\tonUpdated(currentElement.trigger);\n\tonMounted(currentElement.trigger);\n\treturn currentElement;\n}\n\n//#endregion\n//#region useCycleList/index.ts\n/**\n* Cycle through a list of items\n*\n* @see https://vueuse.org/useCycleList\n*/\nfunction useCycleList(list, options) {\n\tconst state = shallowRef(getInitialValue());\n\tconst listRef = toRef(list);\n\tconst index = computed({\n\t\tget() {\n\t\t\tvar _options$fallbackInde;\n\t\t\tconst targetList = listRef.value;\n\t\t\tlet index$1 = (options === null || options === void 0 ? void 0 : options.getIndexOf) ? options.getIndexOf(state.value, targetList) : targetList.indexOf(state.value);\n\t\t\tif (index$1 < 0) index$1 = (_options$fallbackInde = options === null || options === void 0 ? void 0 : options.fallbackIndex) !== null && _options$fallbackInde !== void 0 ? _options$fallbackInde : 0;\n\t\t\treturn index$1;\n\t\t},\n\t\tset(v) {\n\t\t\tset(v);\n\t\t}\n\t});\n\tfunction set(i) {\n\t\tconst targetList = listRef.value;\n\t\tconst length = targetList.length;\n\t\tconst value = targetList[(i % length + length) % length];\n\t\tstate.value = value;\n\t\treturn value;\n\t}\n\tfunction shift(delta = 1) {\n\t\treturn set(index.value + delta);\n\t}\n\tfunction next(n = 1) {\n\t\treturn shift(n);\n\t}\n\tfunction prev(n = 1) {\n\t\treturn shift(-n);\n\t}\n\tfunction getInitialValue() {\n\t\tvar _toValue, _options$initialValue;\n\t\treturn (_toValue = toValue((_options$initialValue = options === null || options === void 0 ? void 0 : options.initialValue) !== null && _options$initialValue !== void 0 ? _options$initialValue : toValue(list)[0])) !== null && _toValue !== void 0 ? _toValue : void 0;\n\t}\n\twatch(listRef, () => set(index.value));\n\treturn {\n\t\tstate,\n\t\tindex,\n\t\tnext,\n\t\tprev,\n\t\tgo: set\n\t};\n}\n\n//#endregion\n//#region useDark/index.ts\n/**\n* Reactive dark mode with auto data persistence.\n*\n* @see https://vueuse.org/useDark\n* @param options\n*/\nfunction useDark(options = {}) {\n\tconst { valueDark = \"dark\", valueLight = \"\" } = options;\n\tconst mode = useColorMode({\n\t\t...options,\n\t\tonChanged: (mode$1, defaultHandler) => {\n\t\t\tvar _options$onChanged;\n\t\t\tif (options.onChanged) (_options$onChanged = options.onChanged) === null || _options$onChanged === void 0 || _options$onChanged.call(options, mode$1 === \"dark\", defaultHandler, mode$1);\n\t\t\telse defaultHandler(mode$1);\n\t\t},\n\t\tmodes: {\n\t\t\tdark: valueDark,\n\t\t\tlight: valueLight\n\t\t}\n\t});\n\tconst system = computed(() => mode.system.value);\n\treturn computed({\n\t\tget() {\n\t\t\treturn mode.value === \"dark\";\n\t\t},\n\t\tset(v) {\n\t\t\tconst modeVal = v ? \"dark\" : \"light\";\n\t\t\tif (system.value === modeVal) mode.value = \"auto\";\n\t\t\telse mode.value = modeVal;\n\t\t}\n\t});\n}\n\n//#endregion\n//#region useManualRefHistory/index.ts\nfunction fnBypass(v) {\n\treturn v;\n}\nfunction fnSetSource(source, value) {\n\treturn source.value = value;\n}\nfunction defaultDump(clone) {\n\treturn clone ? typeof clone === \"function\" ? clone : cloneFnJSON : fnBypass;\n}\nfunction defaultParse(clone) {\n\treturn clone ? typeof clone === \"function\" ? clone : cloneFnJSON : fnBypass;\n}\n/**\n* Track the change history of a ref, also provides undo and redo functionality.\n*\n* @see https://vueuse.org/useManualRefHistory\n* @param source\n* @param options\n*/\nfunction useManualRefHistory(source, options = {}) {\n\tconst { clone = false, dump = defaultDump(clone), parse = defaultParse(clone), setSource = fnSetSource } = options;\n\tfunction _createHistoryRecord() {\n\t\treturn markRaw({\n\t\t\tsnapshot: dump(source.value),\n\t\t\ttimestamp: timestamp()\n\t\t});\n\t}\n\tconst last = ref(_createHistoryRecord());\n\tconst undoStack = ref([]);\n\tconst redoStack = ref([]);\n\tconst _setSource = (record) => {\n\t\tsetSource(source, parse(record.snapshot));\n\t\tlast.value = record;\n\t};\n\tconst commit = () => {\n\t\tundoStack.value.unshift(last.value);\n\t\tlast.value = _createHistoryRecord();\n\t\tif (options.capacity && undoStack.value.length > options.capacity) undoStack.value.splice(options.capacity, Number.POSITIVE_INFINITY);\n\t\tif (redoStack.value.length) redoStack.value.splice(0, redoStack.value.length);\n\t};\n\tconst clear = () => {\n\t\tundoStack.value.splice(0, undoStack.value.length);\n\t\tredoStack.value.splice(0, redoStack.value.length);\n\t};\n\tconst undo = () => {\n\t\tconst state = undoStack.value.shift();\n\t\tif (state) {\n\t\t\tredoStack.value.unshift(last.value);\n\t\t\t_setSource(state);\n\t\t}\n\t};\n\tconst redo = () => {\n\t\tconst state = redoStack.value.shift();\n\t\tif (state) {\n\t\t\tundoStack.value.unshift(last.value);\n\t\t\t_setSource(state);\n\t\t}\n\t};\n\tconst reset = () => {\n\t\t_setSource(last.value);\n\t};\n\treturn {\n\t\tsource,\n\t\tundoStack,\n\t\tredoStack,\n\t\tlast,\n\t\thistory: computed(() => [last.value, ...undoStack.value]),\n\t\tcanUndo: computed(() => undoStack.value.length > 0),\n\t\tcanRedo: computed(() => redoStack.value.length > 0),\n\t\tclear,\n\t\tcommit,\n\t\treset,\n\t\tundo,\n\t\tredo\n\t};\n}\n\n//#endregion\n//#region useRefHistory/index.ts\n/**\n* Track the change history of a ref, also provides undo and redo functionality.\n*\n* @see https://vueuse.org/useRefHistory\n* @param source\n* @param options\n*/\nfunction useRefHistory(source, options = {}) {\n\tconst { deep = false, flush = \"pre\", eventFilter, shouldCommit = () => true } = options;\n\tconst { eventFilter: composedFilter, pause, resume: resumeTracking, isActive: isTracking } = pausableFilter(eventFilter);\n\tlet lastRawValue = source.value;\n\tconst { ignoreUpdates, ignorePrevAsyncUpdates, stop } = watchIgnorable(source, commit, {\n\t\tdeep,\n\t\tflush,\n\t\teventFilter: composedFilter\n\t});\n\tfunction setSource(source$1, value) {\n\t\tignorePrevAsyncUpdates();\n\t\tignoreUpdates(() => {\n\t\t\tsource$1.value = value;\n\t\t\tlastRawValue = value;\n\t\t});\n\t}\n\tconst manualHistory = useManualRefHistory(source, {\n\t\t...options,\n\t\tclone: options.clone || deep,\n\t\tsetSource\n\t});\n\tconst { clear, commit: manualCommit } = manualHistory;\n\tfunction commit() {\n\t\tignorePrevAsyncUpdates();\n\t\tif (!shouldCommit(lastRawValue, source.value)) return;\n\t\tlastRawValue = source.value;\n\t\tmanualCommit();\n\t}\n\tfunction resume(commitNow) {\n\t\tresumeTracking();\n\t\tif (commitNow) commit();\n\t}\n\tfunction batch(fn) {\n\t\tlet canceled = false;\n\t\tconst cancel = () => canceled = true;\n\t\tignoreUpdates(() => {\n\t\t\tfn(cancel);\n\t\t});\n\t\tif (!canceled) commit();\n\t}\n\tfunction dispose() {\n\t\tstop();\n\t\tclear();\n\t}\n\treturn {\n\t\t...manualHistory,\n\t\tisTracking,\n\t\tpause,\n\t\tresume,\n\t\tcommit,\n\t\tbatch,\n\t\tdispose\n\t};\n}\n\n//#endregion\n//#region useDebouncedRefHistory/index.ts\n/**\n* Shorthand for [useRefHistory](https://vueuse.org/useRefHistory) with debounce filter.\n*\n* @see https://vueuse.org/useDebouncedRefHistory\n* @param source\n* @param options\n*/\nfunction useDebouncedRefHistory(source, options = {}) {\n\tconst filter = options.debounce ? debounceFilter(options.debounce) : void 0;\n\treturn { ...useRefHistory(source, {\n\t\t...options,\n\t\teventFilter: filter\n\t}) };\n}\n\n//#endregion\n//#region useDeviceMotion/index.ts\n/**\n* Reactive DeviceMotionEvent.\n*\n* @see https://vueuse.org/useDeviceMotion\n* @param options\n*/\nfunction useDeviceMotion(options = {}) {\n\tconst { window: window$1 = defaultWindow, requestPermissions = false, eventFilter = bypassFilter } = options;\n\tconst isSupported = /* @__PURE__ */ useSupported(() => typeof DeviceMotionEvent !== \"undefined\");\n\tconst requirePermissions = /* @__PURE__ */ useSupported(() => isSupported.value && \"requestPermission\" in DeviceMotionEvent && typeof DeviceMotionEvent.requestPermission === \"function\");\n\tconst permissionGranted = shallowRef(false);\n\tconst acceleration = ref({\n\t\tx: null,\n\t\ty: null,\n\t\tz: null\n\t});\n\tconst rotationRate = ref({\n\t\talpha: null,\n\t\tbeta: null,\n\t\tgamma: null\n\t});\n\tconst interval = shallowRef(0);\n\tconst accelerationIncludingGravity = ref({\n\t\tx: null,\n\t\ty: null,\n\t\tz: null\n\t});\n\tfunction init() {\n\t\tif (window$1) useEventListener(window$1, \"devicemotion\", createFilterWrapper(eventFilter, (event) => {\n\t\t\tvar _event$acceleration, _event$acceleration2, _event$acceleration3, _event$accelerationIn, _event$accelerationIn2, _event$accelerationIn3, _event$rotationRate, _event$rotationRate2, _event$rotationRate3;\n\t\t\tacceleration.value = {\n\t\t\t\tx: ((_event$acceleration = event.acceleration) === null || _event$acceleration === void 0 ? void 0 : _event$acceleration.x) || null,\n\t\t\t\ty: ((_event$acceleration2 = event.acceleration) === null || _event$acceleration2 === void 0 ? void 0 : _event$acceleration2.y) || null,\n\t\t\t\tz: ((_event$acceleration3 = event.acceleration) === null || _event$acceleration3 === void 0 ? void 0 : _event$acceleration3.z) || null\n\t\t\t};\n\t\t\taccelerationIncludingGravity.value = {\n\t\t\t\tx: ((_event$accelerationIn = event.accelerationIncludingGravity) === null || _event$accelerationIn === void 0 ? void 0 : _event$accelerationIn.x) || null,\n\t\t\t\ty: ((_event$accelerationIn2 = event.accelerationIncludingGravity) === null || _event$accelerationIn2 === void 0 ? void 0 : _event$accelerationIn2.y) || null,\n\t\t\t\tz: ((_event$accelerationIn3 = event.accelerationIncludingGravity) === null || _event$accelerationIn3 === void 0 ? void 0 : _event$accelerationIn3.z) || null\n\t\t\t};\n\t\t\trotationRate.value = {\n\t\t\t\talpha: ((_event$rotationRate = event.rotationRate) === null || _event$rotationRate === void 0 ? void 0 : _event$rotationRate.alpha) || null,\n\t\t\t\tbeta: ((_event$rotationRate2 = event.rotationRate) === null || _event$rotationRate2 === void 0 ? void 0 : _event$rotationRate2.beta) || null,\n\t\t\t\tgamma: ((_event$rotationRate3 = event.rotationRate) === null || _event$rotationRate3 === void 0 ? void 0 : _event$rotationRate3.gamma) || null\n\t\t\t};\n\t\t\tinterval.value = event.interval;\n\t\t}), { passive: true });\n\t}\n\tconst ensurePermissions = async () => {\n\t\tif (!requirePermissions.value) permissionGranted.value = true;\n\t\tif (permissionGranted.value) return;\n\t\tif (requirePermissions.value) {\n\t\t\tconst requestPermission = DeviceMotionEvent.requestPermission;\n\t\t\ttry {\n\t\t\t\tif (await requestPermission() === \"granted\") {\n\t\t\t\t\tpermissionGranted.value = true;\n\t\t\t\t\tinit();\n\t\t\t\t}\n\t\t\t} catch (error) {\n\t\t\t\tconsole.error(error);\n\t\t\t}\n\t\t}\n\t};\n\tif (isSupported.value) if (requestPermissions && requirePermissions.value) ensurePermissions().then(() => init());\n\telse init();\n\treturn {\n\t\tacceleration,\n\t\taccelerationIncludingGravity,\n\t\trotationRate,\n\t\tinterval,\n\t\tisSupported,\n\t\trequirePermissions,\n\t\tensurePermissions,\n\t\tpermissionGranted\n\t};\n}\n\n//#endregion\n//#region useDeviceOrientation/index.ts\n/**\n* Reactive DeviceOrientationEvent.\n*\n* @see https://vueuse.org/useDeviceOrientation\n* @param options\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useDeviceOrientation(options = {}) {\n\tconst { window: window$1 = defaultWindow } = options;\n\tconst isSupported = /* @__PURE__ */ useSupported(() => window$1 && \"DeviceOrientationEvent\" in window$1);\n\tconst isAbsolute = shallowRef(false);\n\tconst alpha = shallowRef(null);\n\tconst beta = shallowRef(null);\n\tconst gamma = shallowRef(null);\n\tif (window$1 && isSupported.value) useEventListener(window$1, \"deviceorientation\", (event) => {\n\t\tisAbsolute.value = event.absolute;\n\t\talpha.value = event.alpha;\n\t\tbeta.value = event.beta;\n\t\tgamma.value = event.gamma;\n\t}, { passive: true });\n\treturn {\n\t\tisSupported,\n\t\tisAbsolute,\n\t\talpha,\n\t\tbeta,\n\t\tgamma\n\t};\n}\n\n//#endregion\n//#region useDevicePixelRatio/index.ts\n/**\n* Reactively track `window.devicePixelRatio`.\n*\n* @see https://vueuse.org/useDevicePixelRatio\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useDevicePixelRatio(options = {}) {\n\tconst { window: window$1 = defaultWindow } = options;\n\tconst pixelRatio = shallowRef(1);\n\tconst query = useMediaQuery(() => `(resolution: ${pixelRatio.value}dppx)`, options);\n\tlet stop = noop;\n\tif (window$1) stop = watchImmediate(query, () => pixelRatio.value = window$1.devicePixelRatio);\n\treturn {\n\t\tpixelRatio: readonly(pixelRatio),\n\t\tstop\n\t};\n}\n\n//#endregion\n//#region useDevicesList/index.ts\n/**\n* Reactive `enumerateDevices` listing available input/output devices\n*\n* @see https://vueuse.org/useDevicesList\n* @param options\n*/\nfunction useDevicesList(options = {}) {\n\tconst { navigator: navigator$1 = defaultNavigator, requestPermissions = false, constraints = {\n\t\taudio: true,\n\t\tvideo: true\n\t}, onUpdated: onUpdated$1 } = options;\n\tconst devices = ref([]);\n\tconst videoInputs = computed(() => devices.value.filter((i) => i.kind === \"videoinput\"));\n\tconst audioInputs = computed(() => devices.value.filter((i) => i.kind === \"audioinput\"));\n\tconst audioOutputs = computed(() => devices.value.filter((i) => i.kind === \"audiooutput\"));\n\tconst isSupported = /* @__PURE__ */ useSupported(() => navigator$1 && navigator$1.mediaDevices && navigator$1.mediaDevices.enumerateDevices);\n\tconst permissionGranted = shallowRef(false);\n\tlet stream;\n\tasync function update() {\n\t\tif (!isSupported.value) return;\n\t\tdevices.value = await navigator$1.mediaDevices.enumerateDevices();\n\t\tonUpdated$1 === null || onUpdated$1 === void 0 || onUpdated$1(devices.value);\n\t\tif (stream) {\n\t\t\tstream.getTracks().forEach((t) => t.stop());\n\t\t\tstream = null;\n\t\t}\n\t}\n\tasync function ensurePermissions() {\n\t\tconst deviceName = constraints.video ? \"camera\" : \"microphone\";\n\t\tif (!isSupported.value) return false;\n\t\tif (permissionGranted.value) return true;\n\t\tconst { state, query } = usePermission(deviceName, { controls: true });\n\t\tawait query();\n\t\tif (state.value !== \"granted\") {\n\t\t\tlet granted = true;\n\t\t\ttry {\n\t\t\t\tconst allDevices = await navigator$1.mediaDevices.enumerateDevices();\n\t\t\t\tconst hasCamera = allDevices.some((device) => device.kind === \"videoinput\");\n\t\t\t\tconst hasMicrophone = allDevices.some((device) => device.kind === \"audioinput\" || device.kind === \"audiooutput\");\n\t\t\t\tconstraints.video = hasCamera ? constraints.video : false;\n\t\t\t\tconstraints.audio = hasMicrophone ? constraints.audio : false;\n\t\t\t\tstream = await navigator$1.mediaDevices.getUserMedia(constraints);\n\t\t\t} catch (_unused) {\n\t\t\t\tstream = null;\n\t\t\t\tgranted = false;\n\t\t\t}\n\t\t\tupdate();\n\t\t\tpermissionGranted.value = granted;\n\t\t} else permissionGranted.value = true;\n\t\treturn permissionGranted.value;\n\t}\n\tif (isSupported.value) {\n\t\tif (requestPermissions) ensurePermissions();\n\t\tuseEventListener(navigator$1.mediaDevices, \"devicechange\", update, { passive: true });\n\t\tupdate();\n\t}\n\treturn {\n\t\tdevices,\n\t\tensurePermissions,\n\t\tpermissionGranted,\n\t\tvideoInputs,\n\t\taudioInputs,\n\t\taudioOutputs,\n\t\tisSupported\n\t};\n}\n\n//#endregion\n//#region useDisplayMedia/index.ts\n/**\n* Reactive `mediaDevices.getDisplayMedia` streaming\n*\n* @see https://vueuse.org/useDisplayMedia\n* @param options\n*/\nfunction useDisplayMedia(options = {}) {\n\tvar _options$enabled;\n\tconst enabled = shallowRef((_options$enabled = options.enabled) !== null && _options$enabled !== void 0 ? _options$enabled : false);\n\tconst video = options.video;\n\tconst audio = options.audio;\n\tconst { navigator: navigator$1 = defaultNavigator } = options;\n\tconst isSupported = /* @__PURE__ */ useSupported(() => {\n\t\tvar _navigator$mediaDevic;\n\t\treturn navigator$1 === null || navigator$1 === void 0 || (_navigator$mediaDevic = navigator$1.mediaDevices) === null || _navigator$mediaDevic === void 0 ? void 0 : _navigator$mediaDevic.getDisplayMedia;\n\t});\n\tconst constraint = {\n\t\taudio,\n\t\tvideo\n\t};\n\tconst stream = shallowRef();\n\tasync function _start() {\n\t\tvar _stream$value;\n\t\tif (!isSupported.value || stream.value) return;\n\t\tstream.value = await navigator$1.mediaDevices.getDisplayMedia(constraint);\n\t\t(_stream$value = stream.value) === null || _stream$value === void 0 || _stream$value.getTracks().forEach((t) => useEventListener(t, \"ended\", stop, { passive: true }));\n\t\treturn stream.value;\n\t}\n\tasync function _stop() {\n\t\tvar _stream$value2;\n\t\t(_stream$value2 = stream.value) === null || _stream$value2 === void 0 || _stream$value2.getTracks().forEach((t) => t.stop());\n\t\tstream.value = void 0;\n\t}\n\tfunction stop() {\n\t\t_stop();\n\t\tenabled.value = false;\n\t}\n\tasync function start() {\n\t\tawait _start();\n\t\tif (stream.value) enabled.value = true;\n\t\treturn stream.value;\n\t}\n\twatch(enabled, (v) => {\n\t\tif (v) _start();\n\t\telse _stop();\n\t}, { immediate: true });\n\treturn {\n\t\tisSupported,\n\t\tstream,\n\t\tstart,\n\t\tstop,\n\t\tenabled\n\t};\n}\n\n//#endregion\n//#region useDocumentVisibility/index.ts\n/**\n* Reactively track `document.visibilityState`.\n*\n* @see https://vueuse.org/useDocumentVisibility\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useDocumentVisibility(options = {}) {\n\tconst { document: document$1 = defaultDocument } = options;\n\tif (!document$1) return shallowRef(\"visible\");\n\tconst visibility = shallowRef(document$1.visibilityState);\n\tuseEventListener(document$1, \"visibilitychange\", () => {\n\t\tvisibility.value = document$1.visibilityState;\n\t}, { passive: true });\n\treturn visibility;\n}\n\n//#endregion\n//#region useDraggable/index.ts\nconst defaultScrollConfig = {\n\tspeed: 2,\n\tmargin: 30,\n\tdirection: \"both\"\n};\nfunction clampContainerScroll(container) {\n\tif (container.scrollLeft > container.scrollWidth - container.clientWidth) container.scrollLeft = Math.max(0, container.scrollWidth - container.clientWidth);\n\tif (container.scrollTop > container.scrollHeight - container.clientHeight) container.scrollTop = Math.max(0, container.scrollHeight - container.clientHeight);\n}\n/**\n* Make elements draggable.\n*\n* @see https://vueuse.org/useDraggable\n* @param target\n* @param options\n*/\nfunction useDraggable(target, options = {}) {\n\tvar _toValue, _toValue2, _toValue3, _scrollConfig$directi;\n\tconst { pointerTypes, preventDefault: preventDefault$1, stopPropagation, exact, onMove, onEnd, onStart, initialValue, axis = \"both\", draggingElement = defaultWindow, containerElement, handle: draggingHandle = target, buttons = [0], restrictInView, autoScroll = false } = options;\n\tconst position = ref((_toValue = toValue(initialValue)) !== null && _toValue !== void 0 ? _toValue : {\n\t\tx: 0,\n\t\ty: 0\n\t});\n\tconst pressedDelta = ref();\n\tconst filterEvent = (e) => {\n\t\tif (pointerTypes) return pointerTypes.includes(e.pointerType);\n\t\treturn true;\n\t};\n\tconst handleEvent = (e) => {\n\t\tif (toValue(preventDefault$1)) e.preventDefault();\n\t\tif (toValue(stopPropagation)) e.stopPropagation();\n\t};\n\tconst scrollConfig = toValue(autoScroll);\n\tconst scrollSettings = typeof scrollConfig === \"object\" ? {\n\t\tspeed: (_toValue2 = toValue(scrollConfig.speed)) !== null && _toValue2 !== void 0 ? _toValue2 : defaultScrollConfig.speed,\n\t\tmargin: (_toValue3 = toValue(scrollConfig.margin)) !== null && _toValue3 !== void 0 ? _toValue3 : defaultScrollConfig.margin,\n\t\tdirection: (_scrollConfig$directi = scrollConfig.direction) !== null && _scrollConfig$directi !== void 0 ? _scrollConfig$directi : defaultScrollConfig.direction\n\t} : defaultScrollConfig;\n\tconst getScrollAxisValues = (value) => typeof value === \"number\" ? [value, value] : [value.x, value.y];\n\tconst handleAutoScroll = (container, targetRect, position$1) => {\n\t\tconst { clientWidth, clientHeight, scrollLeft, scrollTop, scrollWidth, scrollHeight } = container;\n\t\tconst [marginX, marginY] = getScrollAxisValues(scrollSettings.margin);\n\t\tconst [speedX, speedY] = getScrollAxisValues(scrollSettings.speed);\n\t\tlet deltaX = 0;\n\t\tlet deltaY = 0;\n\t\tif (scrollSettings.direction === \"x\" || scrollSettings.direction === \"both\") {\n\t\t\tif (position$1.x < marginX && scrollLeft > 0) deltaX = -speedX;\n\t\t\telse if (position$1.x + targetRect.width > clientWidth - marginX && scrollLeft < scrollWidth - clientWidth) deltaX = speedX;\n\t\t}\n\t\tif (scrollSettings.direction === \"y\" || scrollSettings.direction === \"both\") {\n\t\t\tif (position$1.y < marginY && scrollTop > 0) deltaY = -speedY;\n\t\t\telse if (position$1.y + targetRect.height > clientHeight - marginY && scrollTop < scrollHeight - clientHeight) deltaY = speedY;\n\t\t}\n\t\tif (deltaX || deltaY) container.scrollBy({\n\t\t\tleft: deltaX,\n\t\t\ttop: deltaY,\n\t\t\tbehavior: \"auto\"\n\t\t});\n\t};\n\tlet autoScrollInterval = null;\n\tconst startAutoScroll = () => {\n\t\tconst container = toValue(containerElement);\n\t\tif (container && !autoScrollInterval) autoScrollInterval = setInterval(() => {\n\t\t\tconst targetRect = toValue(target).getBoundingClientRect();\n\t\t\tconst { x, y } = position.value;\n\t\t\tconst relativePosition = {\n\t\t\t\tx: x - container.scrollLeft,\n\t\t\t\ty: y - container.scrollTop\n\t\t\t};\n\t\t\tif (relativePosition.x >= 0 && relativePosition.y >= 0) {\n\t\t\t\thandleAutoScroll(container, targetRect, relativePosition);\n\t\t\t\trelativePosition.x += container.scrollLeft;\n\t\t\t\trelativePosition.y += container.scrollTop;\n\t\t\t\tposition.value = relativePosition;\n\t\t\t}\n\t\t}, 1e3 / 60);\n\t};\n\tconst stopAutoScroll = () => {\n\t\tif (autoScrollInterval) {\n\t\t\tclearInterval(autoScrollInterval);\n\t\t\tautoScrollInterval = null;\n\t\t}\n\t};\n\tconst isPointerNearEdge = (pointer, container, margin, targetRect) => {\n\t\tconst [marginX, marginY] = typeof margin === \"number\" ? [margin, margin] : [margin.x, margin.y];\n\t\tconst { clientWidth, clientHeight } = container;\n\t\treturn pointer.x < marginX || pointer.x + targetRect.width > clientWidth - marginX || pointer.y < marginY || pointer.y + targetRect.height > clientHeight - marginY;\n\t};\n\tconst checkAutoScroll = () => {\n\t\tif (toValue(options.disabled) || !pressedDelta.value) return;\n\t\tconst container = toValue(containerElement);\n\t\tif (!container) return;\n\t\tconst targetRect = toValue(target).getBoundingClientRect();\n\t\tconst { x, y } = position.value;\n\t\tif (isPointerNearEdge({\n\t\t\tx: x - container.scrollLeft,\n\t\t\ty: y - container.scrollTop\n\t\t}, container, scrollSettings.margin, targetRect)) startAutoScroll();\n\t\telse stopAutoScroll();\n\t};\n\tif (toValue(autoScroll)) watch(position, checkAutoScroll);\n\tconst start = (e) => {\n\t\tvar _container$getBoundin;\n\t\tif (!toValue(buttons).includes(e.button)) return;\n\t\tif (toValue(options.disabled) || !filterEvent(e)) return;\n\t\tif (toValue(exact) && e.target !== toValue(target)) return;\n\t\tconst container = toValue(containerElement);\n\t\tconst containerRect = container === null || container === void 0 || (_container$getBoundin = container.getBoundingClientRect) === null || _container$getBoundin === void 0 ? void 0 : _container$getBoundin.call(container);\n\t\tconst targetRect = toValue(target).getBoundingClientRect();\n\t\tconst pos = {\n\t\t\tx: e.clientX - (container ? targetRect.left - containerRect.left + (autoScroll ? 0 : container.scrollLeft) : targetRect.left),\n\t\t\ty: e.clientY - (container ? targetRect.top - containerRect.top + (autoScroll ? 0 : container.scrollTop) : targetRect.top)\n\t\t};\n\t\tif ((onStart === null || onStart === void 0 ? void 0 : onStart(pos, e)) === false) return;\n\t\tpressedDelta.value = pos;\n\t\thandleEvent(e);\n\t};\n\tconst move = (e) => {\n\t\tif (toValue(options.disabled) || !filterEvent(e)) return;\n\t\tif (!pressedDelta.value) return;\n\t\tconst container = toValue(containerElement);\n\t\tif (container instanceof HTMLElement) clampContainerScroll(container);\n\t\tconst targetRect = toValue(target).getBoundingClientRect();\n\t\tlet { x, y } = position.value;\n\t\tif (axis === \"x\" || axis === \"both\") {\n\t\t\tx = e.clientX - pressedDelta.value.x;\n\t\t\tif (container) x = Math.min(Math.max(0, x), container.scrollWidth - targetRect.width);\n\t\t}\n\t\tif (axis === \"y\" || axis === \"both\") {\n\t\t\ty = e.clientY - pressedDelta.value.y;\n\t\t\tif (container) y = Math.min(Math.max(0, y), container.scrollHeight - targetRect.height);\n\t\t}\n\t\tif (toValue(autoScroll) && container) {\n\t\t\tif (autoScrollInterval === null) handleAutoScroll(container, targetRect, {\n\t\t\t\tx,\n\t\t\t\ty\n\t\t\t});\n\t\t\tx += container.scrollLeft;\n\t\t\ty += container.scrollTop;\n\t\t}\n\t\tif (container && (restrictInView || autoScroll)) {\n\t\t\tif (axis !== \"y\") {\n\t\t\t\tconst relativeX = x - container.scrollLeft;\n\t\t\t\tif (relativeX < 0) x = container.scrollLeft;\n\t\t\t\telse if (relativeX > container.clientWidth - targetRect.width) x = container.clientWidth - targetRect.width + container.scrollLeft;\n\t\t\t}\n\t\t\tif (axis !== \"x\") {\n\t\t\t\tconst relativeY = y - container.scrollTop;\n\t\t\t\tif (relativeY < 0) y = container.scrollTop;\n\t\t\t\telse if (relativeY > container.clientHeight - targetRect.height) y = container.clientHeight - targetRect.height + container.scrollTop;\n\t\t\t}\n\t\t}\n\t\tposition.value = {\n\t\t\tx,\n\t\t\ty\n\t\t};\n\t\tonMove === null || onMove === void 0 || onMove(position.value, e);\n\t\thandleEvent(e);\n\t};\n\tconst end = (e) => {\n\t\tif (toValue(options.disabled) || !filterEvent(e)) return;\n\t\tif (!pressedDelta.value) return;\n\t\tpressedDelta.value = void 0;\n\t\tif (autoScroll) stopAutoScroll();\n\t\tonEnd === null || onEnd === void 0 || onEnd(position.value, e);\n\t\thandleEvent(e);\n\t};\n\tif (isClient) {\n\t\tconst config = () => {\n\t\t\tvar _options$capture;\n\t\t\treturn {\n\t\t\t\tcapture: (_options$capture = options.capture) !== null && _options$capture !== void 0 ? _options$capture : true,\n\t\t\t\tpassive: !toValue(preventDefault$1)\n\t\t\t};\n\t\t};\n\t\tuseEventListener(draggingHandle, \"pointerdown\", start, config);\n\t\tuseEventListener(draggingElement, \"pointermove\", move, config);\n\t\tuseEventListener(draggingElement, \"pointerup\", end, config);\n\t}\n\treturn {\n\t\t...toRefs(position),\n\t\tposition,\n\t\tisDragging: computed(() => !!pressedDelta.value),\n\t\tstyle: computed(() => `\n      left: ${position.value.x}px;\n      top: ${position.value.y}px;\n      ${autoScroll ? \"text-wrap: nowrap;\" : \"\"}\n    `)\n\t};\n}\n\n//#endregion\n//#region useDropZone/index.ts\nfunction useDropZone(target, options = {}) {\n\tconst isOverDropZone = shallowRef(false);\n\tconst files = shallowRef(null);\n\tlet counter = 0;\n\tlet isValid = true;\n\tif (isClient) {\n\t\tvar _options$multiple, _options$preventDefau;\n\t\tconst _options = typeof options === \"function\" ? { onDrop: options } : options;\n\t\tconst multiple = (_options$multiple = _options.multiple) !== null && _options$multiple !== void 0 ? _options$multiple : true;\n\t\tconst preventDefaultForUnhandled = (_options$preventDefau = _options.preventDefaultForUnhandled) !== null && _options$preventDefau !== void 0 ? _options$preventDefau : false;\n\t\tconst getFiles = (event) => {\n\t\t\tvar _event$dataTransfer$f, _event$dataTransfer;\n\t\t\tconst list = Array.from((_event$dataTransfer$f = (_event$dataTransfer = event.dataTransfer) === null || _event$dataTransfer === void 0 ? void 0 : _event$dataTransfer.files) !== null && _event$dataTransfer$f !== void 0 ? _event$dataTransfer$f : []);\n\t\t\treturn list.length === 0 ? null : multiple ? list : [list[0]];\n\t\t};\n\t\tconst checkDataTypes = (types) => {\n\t\t\tconst dataTypes = unref(_options.dataTypes);\n\t\t\tif (typeof dataTypes === \"function\") return dataTypes(types);\n\t\t\tif (!(dataTypes === null || dataTypes === void 0 ? void 0 : dataTypes.length)) return true;\n\t\t\tif (types.length === 0) return false;\n\t\t\treturn types.every((type) => dataTypes.some((allowedType) => type.includes(allowedType)));\n\t\t};\n\t\tconst checkValidity = (items) => {\n\t\t\tif (_options.checkValidity) return _options.checkValidity(items);\n\t\t\tconst dataTypesValid = checkDataTypes(Array.from(items !== null && items !== void 0 ? items : []).map((item) => item.type));\n\t\t\tconst multipleFilesValid = multiple || items.length <= 1;\n\t\t\treturn dataTypesValid && multipleFilesValid;\n\t\t};\n\t\tconst isSafari = () => /^(?:(?!chrome|android).)*safari/i.test(navigator.userAgent) && !(\"chrome\" in window);\n\t\tconst handleDragEvent = (event, eventType) => {\n\t\t\tvar _event$dataTransfer2, _ref;\n\t\t\tconst dataTransferItemList = (_event$dataTransfer2 = event.dataTransfer) === null || _event$dataTransfer2 === void 0 ? void 0 : _event$dataTransfer2.items;\n\t\t\tisValid = (_ref = dataTransferItemList && checkValidity(dataTransferItemList)) !== null && _ref !== void 0 ? _ref : false;\n\t\t\tif (preventDefaultForUnhandled) event.preventDefault();\n\t\t\tif (!isSafari() && !isValid) {\n\t\t\t\tif (event.dataTransfer) event.dataTransfer.dropEffect = \"none\";\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tevent.preventDefault();\n\t\t\tif (event.dataTransfer) event.dataTransfer.dropEffect = \"copy\";\n\t\t\tconst currentFiles = getFiles(event);\n\t\t\tswitch (eventType) {\n\t\t\t\tcase \"enter\":\n\t\t\t\t\tvar _options$onEnter;\n\t\t\t\t\tcounter += 1;\n\t\t\t\t\tisOverDropZone.value = true;\n\t\t\t\t\t(_options$onEnter = _options.onEnter) === null || _options$onEnter === void 0 || _options$onEnter.call(_options, null, event);\n\t\t\t\t\tbreak;\n\t\t\t\tcase \"over\":\n\t\t\t\t\tvar _options$onOver;\n\t\t\t\t\t(_options$onOver = _options.onOver) === null || _options$onOver === void 0 || _options$onOver.call(_options, null, event);\n\t\t\t\t\tbreak;\n\t\t\t\tcase \"leave\":\n\t\t\t\t\tvar _options$onLeave;\n\t\t\t\t\tcounter -= 1;\n\t\t\t\t\tif (counter === 0) isOverDropZone.value = false;\n\t\t\t\t\t(_options$onLeave = _options.onLeave) === null || _options$onLeave === void 0 || _options$onLeave.call(_options, null, event);\n\t\t\t\t\tbreak;\n\t\t\t\tcase \"drop\":\n\t\t\t\t\tcounter = 0;\n\t\t\t\t\tisOverDropZone.value = false;\n\t\t\t\t\tif (isValid) {\n\t\t\t\t\t\tvar _options$onDrop;\n\t\t\t\t\t\tfiles.value = currentFiles;\n\t\t\t\t\t\t(_options$onDrop = _options.onDrop) === null || _options$onDrop === void 0 || _options$onDrop.call(_options, currentFiles, event);\n\t\t\t\t\t}\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t};\n\t\tuseEventListener(target, \"dragenter\", (event) => handleDragEvent(event, \"enter\"));\n\t\tuseEventListener(target, \"dragover\", (event) => handleDragEvent(event, \"over\"));\n\t\tuseEventListener(target, \"dragleave\", (event) => handleDragEvent(event, \"leave\"));\n\t\tuseEventListener(target, \"drop\", (event) => handleDragEvent(event, \"drop\"));\n\t}\n\treturn {\n\t\tfiles,\n\t\tisOverDropZone\n\t};\n}\n\n//#endregion\n//#region useResizeObserver/index.ts\n/**\n* Reports changes to the dimensions of an Element's content or the border-box\n*\n* @see https://vueuse.org/useResizeObserver\n* @param target\n* @param callback\n* @param options\n*/\nfunction useResizeObserver(target, callback, options = {}) {\n\tconst { window: window$1 = defaultWindow,...observerOptions } = options;\n\tlet observer;\n\tconst isSupported = /* @__PURE__ */ useSupported(() => window$1 && \"ResizeObserver\" in window$1);\n\tconst cleanup = () => {\n\t\tif (observer) {\n\t\t\tobserver.disconnect();\n\t\t\tobserver = void 0;\n\t\t}\n\t};\n\tconst stopWatch = watch(computed(() => {\n\t\tconst _targets = toValue(target);\n\t\treturn Array.isArray(_targets) ? _targets.map((el) => unrefElement(el)) : [unrefElement(_targets)];\n\t}), (els) => {\n\t\tcleanup();\n\t\tif (isSupported.value && window$1) {\n\t\t\tobserver = new ResizeObserver(callback);\n\t\t\tfor (const _el of els) if (_el) observer.observe(_el, observerOptions);\n\t\t}\n\t}, {\n\t\timmediate: true,\n\t\tflush: \"post\"\n\t});\n\tconst stop = () => {\n\t\tcleanup();\n\t\tstopWatch();\n\t};\n\ttryOnScopeDispose(stop);\n\treturn {\n\t\tisSupported,\n\t\tstop\n\t};\n}\n\n//#endregion\n//#region useElementBounding/index.ts\n/**\n* Reactive bounding box of an HTML element.\n*\n* @see https://vueuse.org/useElementBounding\n* @param target\n*/\nfunction useElementBounding(target, options = {}) {\n\tconst { reset = true, windowResize = true, windowScroll = true, immediate = true, updateTiming = \"sync\" } = options;\n\tconst height = shallowRef(0);\n\tconst bottom = shallowRef(0);\n\tconst left = shallowRef(0);\n\tconst right = shallowRef(0);\n\tconst top = shallowRef(0);\n\tconst width = shallowRef(0);\n\tconst x = shallowRef(0);\n\tconst y = shallowRef(0);\n\tfunction recalculate() {\n\t\tconst el = unrefElement(target);\n\t\tif (!el) {\n\t\t\tif (reset) {\n\t\t\t\theight.value = 0;\n\t\t\t\tbottom.value = 0;\n\t\t\t\tleft.value = 0;\n\t\t\t\tright.value = 0;\n\t\t\t\ttop.value = 0;\n\t\t\t\twidth.value = 0;\n\t\t\t\tx.value = 0;\n\t\t\t\ty.value = 0;\n\t\t\t}\n\t\t\treturn;\n\t\t}\n\t\tconst rect = el.getBoundingClientRect();\n\t\theight.value = rect.height;\n\t\tbottom.value = rect.bottom;\n\t\tleft.value = rect.left;\n\t\tright.value = rect.right;\n\t\ttop.value = rect.top;\n\t\twidth.value = rect.width;\n\t\tx.value = rect.x;\n\t\ty.value = rect.y;\n\t}\n\tfunction update() {\n\t\tif (updateTiming === \"sync\") recalculate();\n\t\telse if (updateTiming === \"next-frame\") requestAnimationFrame(() => recalculate());\n\t}\n\tuseResizeObserver(target, update);\n\twatch(() => unrefElement(target), (ele) => !ele && update());\n\tuseMutationObserver(target, update, { attributeFilter: [\"style\", \"class\"] });\n\tif (windowScroll) useEventListener(\"scroll\", update, {\n\t\tcapture: true,\n\t\tpassive: true\n\t});\n\tif (windowResize) useEventListener(\"resize\", update, { passive: true });\n\ttryOnMounted(() => {\n\t\tif (immediate) update();\n\t});\n\treturn {\n\t\theight,\n\t\tbottom,\n\t\tleft,\n\t\tright,\n\t\ttop,\n\t\twidth,\n\t\tx,\n\t\ty,\n\t\tupdate\n\t};\n}\n\n//#endregion\n//#region useElementByPoint/index.ts\nfunction getDefaultScheduler$7(options) {\n\tif (\"interval\" in options || \"immediate\" in options) {\n\t\tconst { interval = \"requestAnimationFrame\", immediate = true } = options;\n\t\treturn interval === \"requestAnimationFrame\" ? (cb) => useRafFn(cb, { immediate }) : (cb) => useIntervalFn(cb, interval, { immediate });\n\t}\n\treturn useRafFn;\n}\n/**\n* Reactive element by point.\n*\n* @see https://vueuse.org/useElementByPoint\n* @param options - UseElementByPointOptions\n*/\nfunction useElementByPoint(options) {\n\tconst { x, y, document: document$1 = defaultDocument, multiple, scheduler = getDefaultScheduler$7(options) } = options;\n\tconst isSupported = /* @__PURE__ */ useSupported(() => {\n\t\tif (toValue(multiple)) return document$1 && \"elementsFromPoint\" in document$1;\n\t\treturn document$1 && \"elementFromPoint\" in document$1;\n\t});\n\tconst element = shallowRef(null);\n\treturn {\n\t\tisSupported,\n\t\telement,\n\t\t...scheduler(() => {\n\t\t\tvar _document$elementsFro, _document$elementFrom;\n\t\t\telement.value = toValue(multiple) ? (_document$elementsFro = document$1 === null || document$1 === void 0 ? void 0 : document$1.elementsFromPoint(toValue(x), toValue(y))) !== null && _document$elementsFro !== void 0 ? _document$elementsFro : [] : (_document$elementFrom = document$1 === null || document$1 === void 0 ? void 0 : document$1.elementFromPoint(toValue(x), toValue(y))) !== null && _document$elementFrom !== void 0 ? _document$elementFrom : null;\n\t\t})\n\t};\n}\n\n//#endregion\n//#region useElementHover/index.ts\nfunction useElementHover(el, options = {}) {\n\tconst { delayEnter = 0, delayLeave = 0, triggerOnRemoval = false, window: window$1 = defaultWindow } = options;\n\tconst isHovered = shallowRef(false);\n\tlet timer;\n\tconst toggle = (entering) => {\n\t\tconst delay = entering ? delayEnter : delayLeave;\n\t\tif (timer) {\n\t\t\tclearTimeout(timer);\n\t\t\ttimer = void 0;\n\t\t}\n\t\tif (delay) timer = setTimeout(() => isHovered.value = entering, delay);\n\t\telse isHovered.value = entering;\n\t};\n\tif (!window$1) return isHovered;\n\tuseEventListener(el, \"mouseenter\", () => toggle(true), { passive: true });\n\tuseEventListener(el, \"mouseleave\", () => toggle(false), { passive: true });\n\tif (triggerOnRemoval) onElementRemoval(computed(() => unrefElement(el)), () => toggle(false));\n\treturn isHovered;\n}\n\n//#endregion\n//#region useElementSize/index.ts\n/**\n* Reactive size of an HTML element.\n*\n* @see https://vueuse.org/useElementSize\n*/\nfunction useElementSize(target, initialSize = {\n\twidth: 0,\n\theight: 0\n}, options = {}) {\n\tconst { window: window$1 = defaultWindow, box = \"content-box\" } = options;\n\tconst isSVG = computed(() => {\n\t\tvar _unrefElement;\n\t\treturn (_unrefElement = unrefElement(target)) === null || _unrefElement === void 0 || (_unrefElement = _unrefElement.namespaceURI) === null || _unrefElement === void 0 ? void 0 : _unrefElement.includes(\"svg\");\n\t});\n\tconst width = shallowRef(initialSize.width);\n\tconst height = shallowRef(initialSize.height);\n\tconst { stop: stop1 } = useResizeObserver(target, ([entry]) => {\n\t\tconst boxSize = box === \"border-box\" ? entry.borderBoxSize : box === \"content-box\" ? entry.contentBoxSize : entry.devicePixelContentBoxSize;\n\t\tif (window$1 && isSVG.value) {\n\t\t\tconst $elem = unrefElement(target);\n\t\t\tif ($elem) {\n\t\t\t\tconst rect = $elem.getBoundingClientRect();\n\t\t\t\twidth.value = rect.width;\n\t\t\t\theight.value = rect.height;\n\t\t\t}\n\t\t} else if (boxSize) {\n\t\t\tconst formatBoxSize = toArray(boxSize);\n\t\t\twidth.value = formatBoxSize.reduce((acc, { inlineSize }) => acc + inlineSize, 0);\n\t\t\theight.value = formatBoxSize.reduce((acc, { blockSize }) => acc + blockSize, 0);\n\t\t} else {\n\t\t\twidth.value = entry.contentRect.width;\n\t\t\theight.value = entry.contentRect.height;\n\t\t}\n\t}, options);\n\ttryOnMounted(() => {\n\t\tconst ele = unrefElement(target);\n\t\tif (ele) {\n\t\t\twidth.value = \"offsetWidth\" in ele ? ele.offsetWidth : initialSize.width;\n\t\t\theight.value = \"offsetHeight\" in ele ? ele.offsetHeight : initialSize.height;\n\t\t}\n\t});\n\tconst stop2 = watch(() => unrefElement(target), (ele) => {\n\t\twidth.value = ele ? initialSize.width : 0;\n\t\theight.value = ele ? initialSize.height : 0;\n\t});\n\tfunction stop() {\n\t\tstop1();\n\t\tstop2();\n\t}\n\treturn {\n\t\twidth,\n\t\theight,\n\t\tstop\n\t};\n}\n\n//#endregion\n//#region useIntersectionObserver/index.ts\n/**\n* Detects that a target element's visibility.\n*\n* @see https://vueuse.org/useIntersectionObserver\n* @param target\n* @param callback\n* @param options\n*/\nfunction useIntersectionObserver(target, callback, options = {}) {\n\tconst { root, rootMargin, threshold = 0, window: window$1 = defaultWindow, immediate = true } = options;\n\tconst isSupported = /* @__PURE__ */ useSupported(() => window$1 && \"IntersectionObserver\" in window$1);\n\tconst targets = computed(() => {\n\t\treturn toArray(toValue(target)).map(unrefElement).filter(notNullish);\n\t});\n\tlet cleanup = noop;\n\tconst isActive = shallowRef(immediate);\n\tconst stopWatch = isSupported.value ? watch(() => [\n\t\ttargets.value,\n\t\tunrefElement(root),\n\t\ttoValue(rootMargin),\n\t\tisActive.value\n\t], ([targets$1, root$1, rootMargin$1]) => {\n\t\tcleanup();\n\t\tif (!isActive.value) return;\n\t\tif (!targets$1.length) return;\n\t\tconst observer = new IntersectionObserver(callback, {\n\t\t\troot: unrefElement(root$1),\n\t\t\trootMargin: rootMargin$1,\n\t\t\tthreshold\n\t\t});\n\t\ttargets$1.forEach((el) => el && observer.observe(el));\n\t\tcleanup = () => {\n\t\t\tobserver.disconnect();\n\t\t\tcleanup = noop;\n\t\t};\n\t}, {\n\t\timmediate,\n\t\tflush: \"post\"\n\t}) : noop;\n\tconst stop = () => {\n\t\tcleanup();\n\t\tstopWatch();\n\t\tisActive.value = false;\n\t};\n\ttryOnScopeDispose(stop);\n\treturn {\n\t\tisSupported,\n\t\tisActive,\n\t\tpause() {\n\t\t\tcleanup();\n\t\t\tisActive.value = false;\n\t\t},\n\t\tresume() {\n\t\t\tisActive.value = true;\n\t\t},\n\t\tstop\n\t};\n}\n\n//#endregion\n//#region useElementVisibility/index.ts\n/**\n* Tracks the visibility of an element within the viewport.\n*\n* @see https://vueuse.org/useElementVisibility\n*/\nfunction useElementVisibility(element, options = {}) {\n\tconst { window: window$1 = defaultWindow, scrollTarget, threshold = 0, rootMargin, once = false, initialValue = false } = options;\n\tconst elementIsVisible = shallowRef(initialValue);\n\tconst { stop } = useIntersectionObserver(element, (intersectionObserverEntries) => {\n\t\tlet isIntersecting = elementIsVisible.value;\n\t\tlet latestTime = 0;\n\t\tfor (const entry of intersectionObserverEntries) if (entry.time >= latestTime) {\n\t\t\tlatestTime = entry.time;\n\t\t\tisIntersecting = entry.isIntersecting;\n\t\t}\n\t\telementIsVisible.value = isIntersecting;\n\t\tif (once) watchOnce(elementIsVisible, () => {\n\t\t\tstop();\n\t\t});\n\t}, {\n\t\troot: scrollTarget,\n\t\twindow: window$1,\n\t\tthreshold,\n\t\trootMargin\n\t});\n\treturn elementIsVisible;\n}\n\n//#endregion\n//#region useEventBus/internal.ts\nconst events = /* @__PURE__ */ new Map();\n\n//#endregion\n//#region useEventBus/index.ts\n/* @__NO_SIDE_EFFECTS__ */\nfunction useEventBus(key) {\n\tconst scope = getCurrentScope();\n\tfunction on(listener) {\n\t\tvar _scope$cleanups;\n\t\tconst listeners = events.get(key) || /* @__PURE__ */ new Set();\n\t\tlisteners.add(listener);\n\t\tevents.set(key, listeners);\n\t\tconst _off = () => off(listener);\n\t\tscope === null || scope === void 0 || (_scope$cleanups = scope.cleanups) === null || _scope$cleanups === void 0 || _scope$cleanups.push(_off);\n\t\treturn _off;\n\t}\n\tfunction once(listener) {\n\t\tfunction _listener(...args) {\n\t\t\toff(_listener);\n\t\t\tlistener(...args);\n\t\t}\n\t\treturn on(_listener);\n\t}\n\tfunction off(listener) {\n\t\tconst listeners = events.get(key);\n\t\tif (!listeners) return;\n\t\tlisteners.delete(listener);\n\t\tif (!listeners.size) reset();\n\t}\n\tfunction reset() {\n\t\tevents.delete(key);\n\t}\n\tfunction emit(event, payload) {\n\t\tvar _events$get;\n\t\t(_events$get = events.get(key)) === null || _events$get === void 0 || _events$get.forEach((v) => v(event, payload));\n\t}\n\treturn {\n\t\ton,\n\t\tonce,\n\t\toff,\n\t\temit,\n\t\treset\n\t};\n}\n\n//#endregion\n//#region useEventSource/index.ts\nfunction resolveNestedOptions$1(options) {\n\tif (options === true) return {};\n\treturn options;\n}\n/**\n* Reactive wrapper for EventSource.\n*\n* @see https://vueuse.org/useEventSource\n* @see https://developer.mozilla.org/en-US/docs/Web/API/EventSource/EventSource EventSource\n* @param url\n* @param events\n* @param options\n*/\nfunction useEventSource(url, events$1 = [], options = {}) {\n\tconst event = shallowRef(null);\n\tconst data = shallowRef(null);\n\tconst status = shallowRef(\"CONNECTING\");\n\tconst eventSource = ref(null);\n\tconst error = shallowRef(null);\n\tconst urlRef = toRef(url);\n\tconst lastEventId = shallowRef(null);\n\tlet explicitlyClosed = false;\n\tlet retried = 0;\n\tconst { withCredentials = false, immediate = true, autoConnect = true, autoReconnect, serializer = { read: (v) => v } } = options;\n\tconst close = () => {\n\t\tif (isClient && eventSource.value) {\n\t\t\teventSource.value.close();\n\t\t\teventSource.value = null;\n\t\t\tstatus.value = \"CLOSED\";\n\t\t\texplicitlyClosed = true;\n\t\t}\n\t};\n\tconst _init = () => {\n\t\tif (explicitlyClosed || typeof urlRef.value === \"undefined\") return;\n\t\tconst es = new EventSource(urlRef.value, { withCredentials });\n\t\tstatus.value = \"CONNECTING\";\n\t\teventSource.value = es;\n\t\tes.onopen = () => {\n\t\t\tstatus.value = \"OPEN\";\n\t\t\terror.value = null;\n\t\t};\n\t\tes.onerror = (e) => {\n\t\t\tstatus.value = \"CLOSED\";\n\t\t\terror.value = e;\n\t\t\tif (es.readyState === 2 && !explicitlyClosed && autoReconnect) {\n\t\t\t\tes.close();\n\t\t\t\tconst { retries = -1, delay = 1e3, onFailed } = resolveNestedOptions$1(autoReconnect);\n\t\t\t\tretried += 1;\n\t\t\t\tif (typeof retries === \"number\" && (retries < 0 || retried < retries)) setTimeout(_init, delay);\n\t\t\t\telse if (typeof retries === \"function\" && retries()) setTimeout(_init, delay);\n\t\t\t\telse onFailed === null || onFailed === void 0 || onFailed();\n\t\t\t}\n\t\t};\n\t\tes.onmessage = (e) => {\n\t\t\tvar _serializer$read;\n\t\t\tevent.value = null;\n\t\t\tdata.value = (_serializer$read = serializer.read(e.data)) !== null && _serializer$read !== void 0 ? _serializer$read : null;\n\t\t\tlastEventId.value = e.lastEventId;\n\t\t};\n\t\tfor (const event_name of events$1) useEventListener(es, event_name, (e) => {\n\t\t\tvar _serializer$read2, _e$lastEventId;\n\t\t\tevent.value = event_name;\n\t\t\tdata.value = (_serializer$read2 = serializer.read(e.data)) !== null && _serializer$read2 !== void 0 ? _serializer$read2 : null;\n\t\t\tlastEventId.value = (_e$lastEventId = e.lastEventId) !== null && _e$lastEventId !== void 0 ? _e$lastEventId : null;\n\t\t}, { passive: true });\n\t};\n\tconst open = () => {\n\t\tif (!isClient) return;\n\t\tclose();\n\t\texplicitlyClosed = false;\n\t\tretried = 0;\n\t\t_init();\n\t};\n\tif (immediate) open();\n\tif (autoConnect) watch(urlRef, open);\n\ttryOnScopeDispose(close);\n\treturn {\n\t\teventSource,\n\t\tevent,\n\t\tdata,\n\t\tstatus,\n\t\terror,\n\t\topen,\n\t\tclose,\n\t\tlastEventId\n\t};\n}\n\n//#endregion\n//#region useEyeDropper/index.ts\n/**\n* Reactive [EyeDropper API](https://developer.mozilla.org/en-US/docs/Web/API/EyeDropper_API)\n*\n* @see https://vueuse.org/useEyeDropper\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useEyeDropper(options = {}) {\n\tconst { initialValue = \"\" } = options;\n\tconst isSupported = /* @__PURE__ */ useSupported(() => typeof window !== \"undefined\" && \"EyeDropper\" in window);\n\tconst sRGBHex = shallowRef(initialValue);\n\tasync function open(openOptions) {\n\t\tif (!isSupported.value) return;\n\t\tconst result = await new window.EyeDropper().open(openOptions);\n\t\tsRGBHex.value = result.sRGBHex;\n\t\treturn result;\n\t}\n\treturn {\n\t\tisSupported,\n\t\tsRGBHex,\n\t\topen\n\t};\n}\n\n//#endregion\n//#region useFavicon/index.ts\nfunction useFavicon(newIcon = null, options = {}) {\n\tconst { baseUrl = \"\", rel = \"icon\", document: document$1 = defaultDocument } = options;\n\tconst favicon = toRef(newIcon);\n\tconst applyIcon = (icon) => {\n\t\tconst elements = document$1 === null || document$1 === void 0 ? void 0 : document$1.head.querySelectorAll(`link[rel*=\"${rel}\"]`);\n\t\tif (!elements || elements.length === 0) {\n\t\t\tconst link = document$1 === null || document$1 === void 0 ? void 0 : document$1.createElement(\"link\");\n\t\t\tif (link) {\n\t\t\t\tlink.rel = rel;\n\t\t\t\tlink.href = `${baseUrl}${icon}`;\n\t\t\t\tlink.type = `image/${icon.split(\".\").pop()}`;\n\t\t\t\tdocument$1 === null || document$1 === void 0 || document$1.head.append(link);\n\t\t\t}\n\t\t\treturn;\n\t\t}\n\t\telements === null || elements === void 0 || elements.forEach((el) => el.href = `${baseUrl}${icon}`);\n\t};\n\twatch(favicon, (i, o) => {\n\t\tif (typeof i === \"string\" && i !== o) applyIcon(i);\n\t}, { immediate: true });\n\treturn favicon;\n}\n\n//#endregion\n//#region useFetch/index.ts\nconst payloadMapping = {\n\tjson: \"application/json\",\n\ttext: \"text/plain\"\n};\n/**\n* !!!IMPORTANT!!!\n*\n* If you update the UseFetchOptions interface, be sure to update this object\n* to include the new options\n*/\nfunction isFetchOptions(obj) {\n\treturn obj && containsProp(obj, \"immediate\", \"refetch\", \"initialData\", \"timeout\", \"beforeFetch\", \"afterFetch\", \"onFetchError\", \"fetch\", \"updateDataOnError\");\n}\nconst reAbsolute = /^(?:[a-z][a-z\\d+\\-.]*:)?\\/\\//i;\nfunction isAbsoluteURL(url) {\n\treturn reAbsolute.test(url);\n}\nfunction headersToObject(headers) {\n\tif (typeof Headers !== \"undefined\" && headers instanceof Headers) return Object.fromEntries(headers.entries());\n\treturn headers;\n}\nfunction combineCallbacks(combination, ...callbacks) {\n\tif (combination === \"overwrite\") return async (ctx) => {\n\t\tlet callback;\n\t\tfor (let i = callbacks.length - 1; i >= 0; i--) if (callbacks[i] != null) {\n\t\t\tcallback = callbacks[i];\n\t\t\tbreak;\n\t\t}\n\t\tif (callback) return {\n\t\t\t...ctx,\n\t\t\t...await callback(ctx)\n\t\t};\n\t\treturn ctx;\n\t};\n\telse return async (ctx) => {\n\t\tfor (const callback of callbacks) if (callback) ctx = {\n\t\t\t...ctx,\n\t\t\t...await callback(ctx)\n\t\t};\n\t\treturn ctx;\n\t};\n}\nfunction createFetch(config = {}) {\n\tconst _combination = config.combination || \"chain\";\n\tconst _options = config.options || {};\n\tconst _fetchOptions = config.fetchOptions || {};\n\tfunction useFactoryFetch(url, ...args) {\n\t\tconst computedUrl = computed(() => {\n\t\t\tconst baseUrl = toValue(config.baseUrl);\n\t\t\tconst targetUrl = toValue(url);\n\t\t\treturn baseUrl && !isAbsoluteURL(targetUrl) ? joinPaths(baseUrl, targetUrl) : targetUrl;\n\t\t});\n\t\tlet options = _options;\n\t\tlet fetchOptions = _fetchOptions;\n\t\tif (args.length > 0) if (isFetchOptions(args[0])) options = {\n\t\t\t...options,\n\t\t\t...args[0],\n\t\t\tbeforeFetch: combineCallbacks(_combination, _options.beforeFetch, args[0].beforeFetch),\n\t\t\tafterFetch: combineCallbacks(_combination, _options.afterFetch, args[0].afterFetch),\n\t\t\tonFetchError: combineCallbacks(_combination, _options.onFetchError, args[0].onFetchError)\n\t\t};\n\t\telse fetchOptions = {\n\t\t\t...fetchOptions,\n\t\t\t...args[0],\n\t\t\theaders: {\n\t\t\t\t...headersToObject(fetchOptions.headers) || {},\n\t\t\t\t...headersToObject(args[0].headers) || {}\n\t\t\t}\n\t\t};\n\t\tif (args.length > 1 && isFetchOptions(args[1])) options = {\n\t\t\t...options,\n\t\t\t...args[1],\n\t\t\tbeforeFetch: combineCallbacks(_combination, _options.beforeFetch, args[1].beforeFetch),\n\t\t\tafterFetch: combineCallbacks(_combination, _options.afterFetch, args[1].afterFetch),\n\t\t\tonFetchError: combineCallbacks(_combination, _options.onFetchError, args[1].onFetchError)\n\t\t};\n\t\treturn useFetch(computedUrl, fetchOptions, options);\n\t}\n\treturn useFactoryFetch;\n}\nfunction useFetch(url, ...args) {\n\tvar _defaultWindow$fetch, _globalThis;\n\tconst supportsAbort = typeof AbortController === \"function\";\n\tlet fetchOptions = {};\n\tlet options = {\n\t\timmediate: true,\n\t\trefetch: false,\n\t\ttimeout: 0,\n\t\tupdateDataOnError: false\n\t};\n\tconst config = {\n\t\tmethod: \"GET\",\n\t\ttype: \"text\",\n\t\tpayload: void 0\n\t};\n\tif (args.length > 0) if (isFetchOptions(args[0])) options = {\n\t\t...options,\n\t\t...args[0]\n\t};\n\telse fetchOptions = args[0];\n\tif (args.length > 1) {\n\t\tif (isFetchOptions(args[1])) options = {\n\t\t\t...options,\n\t\t\t...args[1]\n\t\t};\n\t}\n\tconst { fetch = (_defaultWindow$fetch = defaultWindow === null || defaultWindow === void 0 ? void 0 : defaultWindow.fetch) !== null && _defaultWindow$fetch !== void 0 ? _defaultWindow$fetch : (_globalThis = globalThis) === null || _globalThis === void 0 ? void 0 : _globalThis.fetch, initialData, timeout } = options;\n\tconst responseEvent = createEventHook();\n\tconst errorEvent = createEventHook();\n\tconst finallyEvent = createEventHook();\n\tconst isFinished = shallowRef(false);\n\tconst isFetching = shallowRef(false);\n\tconst aborted = shallowRef(false);\n\tconst statusCode = shallowRef(null);\n\tconst response = shallowRef(null);\n\tconst error = shallowRef(null);\n\tconst data = shallowRef(initialData || null);\n\tconst canAbort = computed(() => supportsAbort && isFetching.value);\n\tlet controller;\n\tlet timer;\n\tconst abort = (reason) => {\n\t\tif (supportsAbort) {\n\t\t\tcontroller === null || controller === void 0 || controller.abort(reason);\n\t\t\tcontroller = new AbortController();\n\t\t\tcontroller.signal.onabort = () => aborted.value = true;\n\t\t\tfetchOptions = {\n\t\t\t\t...fetchOptions,\n\t\t\t\tsignal: controller.signal\n\t\t\t};\n\t\t}\n\t};\n\tconst loading = (isLoading) => {\n\t\tisFetching.value = isLoading;\n\t\tisFinished.value = !isLoading;\n\t};\n\tif (timeout) timer = useTimeoutFn(abort, timeout, { immediate: false });\n\tlet executeCounter = 0;\n\tconst execute = async (throwOnFailed = false) => {\n\t\tvar _context$options;\n\t\tabort();\n\t\tloading(true);\n\t\terror.value = null;\n\t\tstatusCode.value = null;\n\t\taborted.value = false;\n\t\texecuteCounter += 1;\n\t\tconst currentExecuteCounter = executeCounter;\n\t\tconst defaultFetchOptions = {\n\t\t\tmethod: config.method,\n\t\t\theaders: {}\n\t\t};\n\t\tconst payload = toValue(config.payload);\n\t\tif (payload) {\n\t\t\tvar _payloadMapping$confi;\n\t\t\tconst headers = headersToObject(defaultFetchOptions.headers);\n\t\t\tconst proto = Object.getPrototypeOf(payload);\n\t\t\tif (!config.payloadType && payload && (proto === Object.prototype || Array.isArray(proto)) && !(payload instanceof FormData)) config.payloadType = \"json\";\n\t\t\tif (config.payloadType) headers[\"Content-Type\"] = (_payloadMapping$confi = payloadMapping[config.payloadType]) !== null && _payloadMapping$confi !== void 0 ? _payloadMapping$confi : config.payloadType;\n\t\t\tdefaultFetchOptions.body = config.payloadType === \"json\" ? JSON.stringify(payload) : payload;\n\t\t}\n\t\tlet isCanceled = false;\n\t\tconst context = {\n\t\t\turl: toValue(url),\n\t\t\toptions: {\n\t\t\t\t...defaultFetchOptions,\n\t\t\t\t...fetchOptions\n\t\t\t},\n\t\t\tcancel: () => {\n\t\t\t\tisCanceled = true;\n\t\t\t}\n\t\t};\n\t\tif (options.beforeFetch) Object.assign(context, await options.beforeFetch(context));\n\t\tif (isCanceled || !fetch) {\n\t\t\tloading(false);\n\t\t\treturn Promise.resolve(null);\n\t\t}\n\t\tlet responseData = null;\n\t\tif (timer) timer.start();\n\t\treturn fetch(context.url, {\n\t\t\t...defaultFetchOptions,\n\t\t\t...context.options,\n\t\t\theaders: {\n\t\t\t\t...headersToObject(defaultFetchOptions.headers),\n\t\t\t\t...headersToObject((_context$options = context.options) === null || _context$options === void 0 ? void 0 : _context$options.headers)\n\t\t\t}\n\t\t}).then(async (fetchResponse) => {\n\t\t\tresponse.value = fetchResponse;\n\t\t\tstatusCode.value = fetchResponse.status;\n\t\t\tresponseData = await fetchResponse.clone()[config.type]();\n\t\t\tif (!fetchResponse.ok) {\n\t\t\t\tdata.value = initialData || null;\n\t\t\t\tthrow new Error(fetchResponse.statusText);\n\t\t\t}\n\t\t\tif (options.afterFetch) ({data: responseData} = await options.afterFetch({\n\t\t\t\tdata: responseData,\n\t\t\t\tresponse: fetchResponse,\n\t\t\t\tcontext,\n\t\t\t\texecute\n\t\t\t}));\n\t\t\tdata.value = responseData;\n\t\t\tresponseEvent.trigger(fetchResponse);\n\t\t\treturn fetchResponse;\n\t\t}).catch(async (fetchError) => {\n\t\t\tlet errorData = fetchError.message || fetchError.name;\n\t\t\tif (options.onFetchError) ({error: errorData, data: responseData} = await options.onFetchError({\n\t\t\t\tdata: responseData,\n\t\t\t\terror: fetchError,\n\t\t\t\tresponse: response.value,\n\t\t\t\tcontext,\n\t\t\t\texecute\n\t\t\t}));\n\t\t\terror.value = errorData;\n\t\t\tif (options.updateDataOnError) data.value = responseData;\n\t\t\terrorEvent.trigger(fetchError);\n\t\t\tif (throwOnFailed) throw fetchError;\n\t\t\treturn null;\n\t\t}).finally(() => {\n\t\t\tif (currentExecuteCounter === executeCounter) loading(false);\n\t\t\tif (timer) timer.stop();\n\t\t\tfinallyEvent.trigger(null);\n\t\t});\n\t};\n\tconst refetch = toRef(options.refetch);\n\twatch([refetch, toRef(url)], ([refetch$1]) => refetch$1 && execute(), { deep: true });\n\tconst shell = {\n\t\tisFinished: readonly(isFinished),\n\t\tisFetching: readonly(isFetching),\n\t\tstatusCode,\n\t\tresponse,\n\t\terror,\n\t\tdata,\n\t\tcanAbort,\n\t\taborted,\n\t\tabort,\n\t\texecute,\n\t\tonFetchResponse: responseEvent.on,\n\t\tonFetchError: errorEvent.on,\n\t\tonFetchFinally: finallyEvent.on,\n\t\tget: setMethod(\"GET\"),\n\t\tput: setMethod(\"PUT\"),\n\t\tpost: setMethod(\"POST\"),\n\t\tdelete: setMethod(\"DELETE\"),\n\t\tpatch: setMethod(\"PATCH\"),\n\t\thead: setMethod(\"HEAD\"),\n\t\toptions: setMethod(\"OPTIONS\"),\n\t\tjson: setType(\"json\"),\n\t\ttext: setType(\"text\"),\n\t\tblob: setType(\"blob\"),\n\t\tarrayBuffer: setType(\"arrayBuffer\"),\n\t\tformData: setType(\"formData\")\n\t};\n\tfunction setMethod(method) {\n\t\treturn (payload, payloadType) => {\n\t\t\tif (!isFetching.value) {\n\t\t\t\tconfig.method = method;\n\t\t\t\tconfig.payload = payload;\n\t\t\t\tconfig.payloadType = payloadType;\n\t\t\t\tif (isRef(config.payload)) watch([refetch, toRef(config.payload)], ([refetch$1]) => refetch$1 && execute(), { deep: true });\n\t\t\t\treturn {\n\t\t\t\t\t...shell,\n\t\t\t\t\tthen(onFulfilled, onRejected) {\n\t\t\t\t\t\treturn waitUntilFinished().then(onFulfilled, onRejected);\n\t\t\t\t\t}\n\t\t\t\t};\n\t\t\t}\n\t\t};\n\t}\n\tfunction waitUntilFinished() {\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tuntil(isFinished).toBe(true).then(() => resolve(shell)).catch(reject);\n\t\t});\n\t}\n\tfunction setType(type) {\n\t\treturn () => {\n\t\t\tif (!isFetching.value) {\n\t\t\t\tconfig.type = type;\n\t\t\t\treturn {\n\t\t\t\t\t...shell,\n\t\t\t\t\tthen(onFulfilled, onRejected) {\n\t\t\t\t\t\treturn waitUntilFinished().then(onFulfilled, onRejected);\n\t\t\t\t\t}\n\t\t\t\t};\n\t\t\t}\n\t\t};\n\t}\n\tif (options.immediate) Promise.resolve().then(() => execute());\n\treturn {\n\t\t...shell,\n\t\tthen(onFulfilled, onRejected) {\n\t\t\treturn waitUntilFinished().then(onFulfilled, onRejected);\n\t\t}\n\t};\n}\nfunction joinPaths(start, end) {\n\tif (!start.endsWith(\"/\") && !end.startsWith(\"/\")) return `${start}/${end}`;\n\tif (start.endsWith(\"/\") && end.startsWith(\"/\")) return `${start.slice(0, -1)}${end}`;\n\treturn `${start}${end}`;\n}\n\n//#endregion\n//#region useFileDialog/index.ts\nconst DEFAULT_OPTIONS = {\n\tmultiple: true,\n\taccept: \"*\",\n\treset: false,\n\tdirectory: false\n};\nfunction prepareInitialFiles(files) {\n\tif (!files) return null;\n\tif (files instanceof FileList) return files;\n\tconst dt = new DataTransfer();\n\tfor (const file of files) dt.items.add(file);\n\treturn dt.files;\n}\n/**\n* Open file dialog with ease.\n*\n* @see https://vueuse.org/useFileDialog\n* @param options\n*/\nfunction useFileDialog(options = {}) {\n\tconst { document: document$1 = defaultDocument } = options;\n\tconst files = ref(prepareInitialFiles(options.initialFiles));\n\tconst { on: onChange, trigger: changeTrigger } = createEventHook();\n\tconst { on: onCancel, trigger: cancelTrigger } = createEventHook();\n\tconst inputRef = computed(() => {\n\t\tvar _unrefElement;\n\t\tconst input = (_unrefElement = unrefElement(options.input)) !== null && _unrefElement !== void 0 ? _unrefElement : document$1 ? document$1.createElement(\"input\") : void 0;\n\t\tif (input) {\n\t\t\tinput.type = \"file\";\n\t\t\tinput.onchange = (event) => {\n\t\t\t\tfiles.value = event.target.files;\n\t\t\t\tchangeTrigger(files.value);\n\t\t\t};\n\t\t\tinput.oncancel = () => {\n\t\t\t\tcancelTrigger();\n\t\t\t};\n\t\t}\n\t\treturn input;\n\t});\n\tconst reset = () => {\n\t\tfiles.value = null;\n\t\tif (inputRef.value && inputRef.value.value) {\n\t\t\tinputRef.value.value = \"\";\n\t\t\tchangeTrigger(null);\n\t\t}\n\t};\n\tconst applyOptions = (options$1) => {\n\t\tconst el = inputRef.value;\n\t\tif (!el) return;\n\t\tel.multiple = toValue(options$1.multiple);\n\t\tel.accept = toValue(options$1.accept);\n\t\tel.webkitdirectory = toValue(options$1.directory);\n\t\tif (hasOwn(options$1, \"capture\")) el.capture = toValue(options$1.capture);\n\t};\n\tconst open = (localOptions) => {\n\t\tconst el = inputRef.value;\n\t\tif (!el) return;\n\t\tconst mergedOptions = {\n\t\t\t...DEFAULT_OPTIONS,\n\t\t\t...options,\n\t\t\t...localOptions\n\t\t};\n\t\tapplyOptions(mergedOptions);\n\t\tif (toValue(mergedOptions.reset)) reset();\n\t\tel.click();\n\t};\n\twatchEffect(() => {\n\t\tapplyOptions(options);\n\t});\n\treturn {\n\t\tfiles: readonly(files),\n\t\topen,\n\t\treset,\n\t\tonCancel,\n\t\tonChange\n\t};\n}\n\n//#endregion\n//#region useFileSystemAccess/index.ts\nfunction useFileSystemAccess(options = {}) {\n\tconst { window: _window = defaultWindow, dataType = \"Text\" } = options;\n\tconst window$1 = _window;\n\tconst isSupported = /* @__PURE__ */ useSupported(() => window$1 && \"showSaveFilePicker\" in window$1 && \"showOpenFilePicker\" in window$1);\n\tconst fileHandle = shallowRef();\n\tconst data = shallowRef();\n\tconst file = shallowRef();\n\tconst fileName = computed(() => {\n\t\tvar _file$value$name, _file$value;\n\t\treturn (_file$value$name = (_file$value = file.value) === null || _file$value === void 0 ? void 0 : _file$value.name) !== null && _file$value$name !== void 0 ? _file$value$name : \"\";\n\t});\n\tconst fileMIME = computed(() => {\n\t\tvar _file$value$type, _file$value2;\n\t\treturn (_file$value$type = (_file$value2 = file.value) === null || _file$value2 === void 0 ? void 0 : _file$value2.type) !== null && _file$value$type !== void 0 ? _file$value$type : \"\";\n\t});\n\tconst fileSize = computed(() => {\n\t\tvar _file$value$size, _file$value3;\n\t\treturn (_file$value$size = (_file$value3 = file.value) === null || _file$value3 === void 0 ? void 0 : _file$value3.size) !== null && _file$value$size !== void 0 ? _file$value$size : 0;\n\t});\n\tconst fileLastModified = computed(() => {\n\t\tvar _file$value$lastModif, _file$value4;\n\t\treturn (_file$value$lastModif = (_file$value4 = file.value) === null || _file$value4 === void 0 ? void 0 : _file$value4.lastModified) !== null && _file$value$lastModif !== void 0 ? _file$value$lastModif : 0;\n\t});\n\tasync function open(_options = {}) {\n\t\tif (!isSupported.value) return;\n\t\tconst [handle] = await window$1.showOpenFilePicker({\n\t\t\t...toValue(options),\n\t\t\t..._options\n\t\t});\n\t\tfileHandle.value = handle;\n\t\tawait updateData();\n\t}\n\tasync function create(_options = {}) {\n\t\tif (!isSupported.value) return;\n\t\tfileHandle.value = await window$1.showSaveFilePicker({\n\t\t\t...options,\n\t\t\t..._options\n\t\t});\n\t\tdata.value = void 0;\n\t\tawait updateData();\n\t}\n\tasync function save(_options = {}) {\n\t\tif (!isSupported.value) return;\n\t\tif (!fileHandle.value) return saveAs(_options);\n\t\tif (data.value) {\n\t\t\tconst writableStream = await fileHandle.value.createWritable();\n\t\t\tawait writableStream.write(data.value);\n\t\t\tawait writableStream.close();\n\t\t}\n\t\tawait updateFile();\n\t}\n\tasync function saveAs(_options = {}) {\n\t\tif (!isSupported.value) return;\n\t\tfileHandle.value = await window$1.showSaveFilePicker({\n\t\t\t...options,\n\t\t\t..._options\n\t\t});\n\t\tif (data.value) {\n\t\t\tconst writableStream = await fileHandle.value.createWritable();\n\t\t\tawait writableStream.write(data.value);\n\t\t\tawait writableStream.close();\n\t\t}\n\t\tawait updateFile();\n\t}\n\tasync function updateFile() {\n\t\tvar _fileHandle$value;\n\t\tfile.value = await ((_fileHandle$value = fileHandle.value) === null || _fileHandle$value === void 0 ? void 0 : _fileHandle$value.getFile());\n\t}\n\tasync function updateData() {\n\t\tvar _file$value5, _file$value6;\n\t\tawait updateFile();\n\t\tconst type = toValue(dataType);\n\t\tif (type === \"Text\") data.value = await ((_file$value5 = file.value) === null || _file$value5 === void 0 ? void 0 : _file$value5.text());\n\t\telse if (type === \"ArrayBuffer\") data.value = await ((_file$value6 = file.value) === null || _file$value6 === void 0 ? void 0 : _file$value6.arrayBuffer());\n\t\telse if (type === \"Blob\") data.value = file.value;\n\t}\n\twatch(() => toValue(dataType), updateData);\n\treturn {\n\t\tisSupported,\n\t\tdata,\n\t\tfile,\n\t\tfileName,\n\t\tfileMIME,\n\t\tfileSize,\n\t\tfileLastModified,\n\t\topen,\n\t\tcreate,\n\t\tsave,\n\t\tsaveAs,\n\t\tupdateData\n\t};\n}\n\n//#endregion\n//#region useFocus/index.ts\n/**\n* Track or set the focus state of a DOM element.\n*\n* @see https://vueuse.org/useFocus\n* @param target The target element for the focus and blur events.\n* @param options\n*/\nfunction useFocus(target, options = {}) {\n\tconst { initialValue = false, focusVisible = false, preventScroll = false } = options;\n\tconst innerFocused = shallowRef(false);\n\tconst targetElement = computed(() => unrefElement(target));\n\tconst listenerOptions = { passive: true };\n\tuseEventListener(targetElement, \"focus\", (event) => {\n\t\tvar _matches, _ref;\n\t\tif (!focusVisible || ((_matches = (_ref = event.target).matches) === null || _matches === void 0 ? void 0 : _matches.call(_ref, \":focus-visible\"))) innerFocused.value = true;\n\t}, listenerOptions);\n\tuseEventListener(targetElement, \"blur\", () => innerFocused.value = false, listenerOptions);\n\tconst focused = computed({\n\t\tget: () => innerFocused.value,\n\t\tset(value) {\n\t\t\tvar _targetElement$value, _targetElement$value2;\n\t\t\tif (!value && innerFocused.value) (_targetElement$value = targetElement.value) === null || _targetElement$value === void 0 || _targetElement$value.blur();\n\t\t\telse if (value && !innerFocused.value) (_targetElement$value2 = targetElement.value) === null || _targetElement$value2 === void 0 || _targetElement$value2.focus({ preventScroll });\n\t\t}\n\t});\n\twatch(targetElement, () => {\n\t\tfocused.value = initialValue;\n\t}, {\n\t\timmediate: true,\n\t\tflush: \"post\"\n\t});\n\treturn { focused };\n}\n\n//#endregion\n//#region useFocusWithin/index.ts\nconst EVENT_FOCUS_IN = \"focusin\";\nconst EVENT_FOCUS_OUT = \"focusout\";\nconst PSEUDO_CLASS_FOCUS_WITHIN = \":focus-within\";\n/**\n* Track if focus is contained within the target element\n*\n* @see https://vueuse.org/useFocusWithin\n* @param target The target element to track\n* @param options Focus within options\n*/\nfunction useFocusWithin(target, options = {}) {\n\tconst { window: window$1 = defaultWindow } = options;\n\tconst targetElement = computed(() => unrefElement(target));\n\tconst _focused = shallowRef(false);\n\tconst focused = computed(() => _focused.value);\n\tconst activeElement = useActiveElement(options);\n\tif (!window$1 || !activeElement.value) return { focused };\n\tconst listenerOptions = { passive: true };\n\tuseEventListener(targetElement, EVENT_FOCUS_IN, () => _focused.value = true, listenerOptions);\n\tuseEventListener(targetElement, EVENT_FOCUS_OUT, () => {\n\t\tvar _targetElement$value$, _targetElement$value, _targetElement$value$2;\n\t\treturn _focused.value = (_targetElement$value$ = (_targetElement$value = targetElement.value) === null || _targetElement$value === void 0 || (_targetElement$value$2 = _targetElement$value.matches) === null || _targetElement$value$2 === void 0 ? void 0 : _targetElement$value$2.call(_targetElement$value, PSEUDO_CLASS_FOCUS_WITHIN)) !== null && _targetElement$value$ !== void 0 ? _targetElement$value$ : false;\n\t}, listenerOptions);\n\treturn { focused };\n}\n\n//#endregion\n//#region useFps/index.ts\n/* @__NO_SIDE_EFFECTS__ */\nfunction useFps(options) {\n\tvar _options$every;\n\tconst fps = shallowRef(0);\n\tif (typeof performance === \"undefined\") return fps;\n\tconst every = (_options$every = options === null || options === void 0 ? void 0 : options.every) !== null && _options$every !== void 0 ? _options$every : 10;\n\tlet last = performance.now();\n\tlet ticks = 0;\n\tuseRafFn(() => {\n\t\tticks += 1;\n\t\tif (ticks >= every) {\n\t\t\tconst now = performance.now();\n\t\t\tconst diff = now - last;\n\t\t\tfps.value = Math.round(1e3 / (diff / ticks));\n\t\t\tlast = now;\n\t\t\tticks = 0;\n\t\t}\n\t});\n\treturn fps;\n}\n\n//#endregion\n//#region useFullscreen/index.ts\nconst eventHandlers = [\n\t\"fullscreenchange\",\n\t\"webkitfullscreenchange\",\n\t\"webkitendfullscreen\",\n\t\"mozfullscreenchange\",\n\t\"MSFullscreenChange\"\n];\n/**\n* Reactive Fullscreen API.\n*\n* @see https://vueuse.org/useFullscreen\n* @param target\n* @param options\n*/\nfunction useFullscreen(target, options = {}) {\n\tconst { document: document$1 = defaultDocument, autoExit = false } = options;\n\tconst targetRef = computed(() => {\n\t\tvar _unrefElement;\n\t\treturn (_unrefElement = unrefElement(target)) !== null && _unrefElement !== void 0 ? _unrefElement : document$1 === null || document$1 === void 0 ? void 0 : document$1.documentElement;\n\t});\n\tconst isFullscreen = shallowRef(false);\n\tconst requestMethod = computed(() => {\n\t\treturn [\n\t\t\t\"requestFullscreen\",\n\t\t\t\"webkitRequestFullscreen\",\n\t\t\t\"webkitEnterFullscreen\",\n\t\t\t\"webkitEnterFullScreen\",\n\t\t\t\"webkitRequestFullScreen\",\n\t\t\t\"mozRequestFullScreen\",\n\t\t\t\"msRequestFullscreen\"\n\t\t].find((m) => document$1 && m in document$1 || targetRef.value && m in targetRef.value);\n\t});\n\tconst exitMethod = computed(() => {\n\t\treturn [\n\t\t\t\"exitFullscreen\",\n\t\t\t\"webkitExitFullscreen\",\n\t\t\t\"webkitExitFullScreen\",\n\t\t\t\"webkitCancelFullScreen\",\n\t\t\t\"mozCancelFullScreen\",\n\t\t\t\"msExitFullscreen\"\n\t\t].find((m) => document$1 && m in document$1 || targetRef.value && m in targetRef.value);\n\t});\n\tconst fullscreenEnabled = computed(() => {\n\t\treturn [\n\t\t\t\"fullScreen\",\n\t\t\t\"webkitIsFullScreen\",\n\t\t\t\"webkitDisplayingFullscreen\",\n\t\t\t\"mozFullScreen\",\n\t\t\t\"msFullscreenElement\"\n\t\t].find((m) => document$1 && m in document$1 || targetRef.value && m in targetRef.value);\n\t});\n\tconst fullscreenElementMethod = [\n\t\t\"fullscreenElement\",\n\t\t\"webkitFullscreenElement\",\n\t\t\"mozFullScreenElement\",\n\t\t\"msFullscreenElement\"\n\t].find((m) => document$1 && m in document$1);\n\tconst isSupported = /* @__PURE__ */ useSupported(() => targetRef.value && document$1 && requestMethod.value !== void 0 && exitMethod.value !== void 0 && fullscreenEnabled.value !== void 0);\n\tconst isCurrentElementFullScreen = () => {\n\t\tif (fullscreenElementMethod) return (document$1 === null || document$1 === void 0 ? void 0 : document$1[fullscreenElementMethod]) === targetRef.value;\n\t\treturn false;\n\t};\n\tconst isElementFullScreen = () => {\n\t\tif (fullscreenEnabled.value) if (document$1 && document$1[fullscreenEnabled.value] != null) return document$1[fullscreenEnabled.value];\n\t\telse {\n\t\t\tconst target$1 = targetRef.value;\n\t\t\tif ((target$1 === null || target$1 === void 0 ? void 0 : target$1[fullscreenEnabled.value]) != null) return Boolean(target$1[fullscreenEnabled.value]);\n\t\t}\n\t\treturn false;\n\t};\n\tasync function exit() {\n\t\tif (!isSupported.value || !isFullscreen.value) return;\n\t\tif (exitMethod.value) if ((document$1 === null || document$1 === void 0 ? void 0 : document$1[exitMethod.value]) != null) await document$1[exitMethod.value]();\n\t\telse {\n\t\t\tconst target$1 = targetRef.value;\n\t\t\tif ((target$1 === null || target$1 === void 0 ? void 0 : target$1[exitMethod.value]) != null) await target$1[exitMethod.value]();\n\t\t}\n\t\tisFullscreen.value = false;\n\t}\n\tasync function enter() {\n\t\tif (!isSupported.value || isFullscreen.value) return;\n\t\tif (isElementFullScreen()) await exit();\n\t\tconst target$1 = targetRef.value;\n\t\tif (requestMethod.value && (target$1 === null || target$1 === void 0 ? void 0 : target$1[requestMethod.value]) != null) {\n\t\t\tawait target$1[requestMethod.value]();\n\t\t\tisFullscreen.value = true;\n\t\t}\n\t}\n\tasync function toggle() {\n\t\tawait (isFullscreen.value ? exit() : enter());\n\t}\n\tconst handlerCallback = () => {\n\t\tconst isElementFullScreenValue = isElementFullScreen();\n\t\tif (!isElementFullScreenValue || isElementFullScreenValue && isCurrentElementFullScreen()) isFullscreen.value = isElementFullScreenValue;\n\t};\n\tconst listenerOptions = {\n\t\tcapture: false,\n\t\tpassive: true\n\t};\n\tuseEventListener(document$1, eventHandlers, handlerCallback, listenerOptions);\n\tuseEventListener(() => unrefElement(targetRef), eventHandlers, handlerCallback, listenerOptions);\n\ttryOnMounted(handlerCallback, false);\n\tif (autoExit) tryOnScopeDispose(exit);\n\treturn {\n\t\tisSupported,\n\t\tisFullscreen,\n\t\tenter,\n\t\texit,\n\t\ttoggle\n\t};\n}\n\n//#endregion\n//#region useGamepad/index.ts\n/**\n* Maps a standard standard gamepad to an Xbox 360 Controller.\n*/\nfunction mapGamepadToXbox360Controller(gamepad) {\n\treturn computed(() => {\n\t\tif (gamepad.value) return {\n\t\t\tbuttons: {\n\t\t\t\ta: gamepad.value.buttons[0],\n\t\t\t\tb: gamepad.value.buttons[1],\n\t\t\t\tx: gamepad.value.buttons[2],\n\t\t\t\ty: gamepad.value.buttons[3]\n\t\t\t},\n\t\t\tbumper: {\n\t\t\t\tleft: gamepad.value.buttons[4],\n\t\t\t\tright: gamepad.value.buttons[5]\n\t\t\t},\n\t\t\ttriggers: {\n\t\t\t\tleft: gamepad.value.buttons[6],\n\t\t\t\tright: gamepad.value.buttons[7]\n\t\t\t},\n\t\t\tstick: {\n\t\t\t\tleft: {\n\t\t\t\t\thorizontal: gamepad.value.axes[0],\n\t\t\t\t\tvertical: gamepad.value.axes[1],\n\t\t\t\t\tbutton: gamepad.value.buttons[10]\n\t\t\t\t},\n\t\t\t\tright: {\n\t\t\t\t\thorizontal: gamepad.value.axes[2],\n\t\t\t\t\tvertical: gamepad.value.axes[3],\n\t\t\t\t\tbutton: gamepad.value.buttons[11]\n\t\t\t\t}\n\t\t\t},\n\t\t\tdpad: {\n\t\t\t\tup: gamepad.value.buttons[12],\n\t\t\t\tdown: gamepad.value.buttons[13],\n\t\t\t\tleft: gamepad.value.buttons[14],\n\t\t\t\tright: gamepad.value.buttons[15]\n\t\t\t},\n\t\t\tback: gamepad.value.buttons[8],\n\t\t\tstart: gamepad.value.buttons[9]\n\t\t};\n\t\treturn null;\n\t});\n}\n/* @__NO_SIDE_EFFECTS__ */\nfunction useGamepad(options = {}) {\n\tconst { navigator: navigator$1 = defaultNavigator } = options;\n\tconst isSupported = /* @__PURE__ */ useSupported(() => navigator$1 && \"getGamepads\" in navigator$1);\n\tconst gamepads = ref([]);\n\tconst onConnectedHook = createEventHook();\n\tconst onDisconnectedHook = createEventHook();\n\tconst stateFromGamepad = (gamepad) => {\n\t\tconst hapticActuators = [];\n\t\tconst vibrationActuator = \"vibrationActuator\" in gamepad ? gamepad.vibrationActuator : null;\n\t\tif (vibrationActuator) hapticActuators.push(vibrationActuator);\n\t\tif (gamepad.hapticActuators) hapticActuators.push(...gamepad.hapticActuators);\n\t\treturn {\n\t\t\tid: gamepad.id,\n\t\t\tindex: gamepad.index,\n\t\t\tconnected: gamepad.connected,\n\t\t\tmapping: gamepad.mapping,\n\t\t\ttimestamp: gamepad.timestamp,\n\t\t\tvibrationActuator: gamepad.vibrationActuator,\n\t\t\thapticActuators,\n\t\t\taxes: gamepad.axes.map((axes) => axes),\n\t\t\tbuttons: gamepad.buttons.map((button) => ({\n\t\t\t\tpressed: button.pressed,\n\t\t\t\ttouched: button.touched,\n\t\t\t\tvalue: button.value\n\t\t\t}))\n\t\t};\n\t};\n\tconst updateGamepadState = () => {\n\t\tconst _gamepads = (navigator$1 === null || navigator$1 === void 0 ? void 0 : navigator$1.getGamepads()) || [];\n\t\tfor (const gamepad of _gamepads) if (gamepad && gamepads.value[gamepad.index]) gamepads.value[gamepad.index] = stateFromGamepad(gamepad);\n\t};\n\tconst { isActive, pause, resume } = useRafFn(updateGamepadState);\n\tconst onGamepadConnected = (gamepad) => {\n\t\tif (!gamepads.value.some(({ index }) => index === gamepad.index)) {\n\t\t\tgamepads.value.push(stateFromGamepad(gamepad));\n\t\t\tonConnectedHook.trigger(gamepad.index);\n\t\t}\n\t\tresume();\n\t};\n\tconst onGamepadDisconnected = (gamepad) => {\n\t\tgamepads.value = gamepads.value.filter((x) => x.index !== gamepad.index);\n\t\tonDisconnectedHook.trigger(gamepad.index);\n\t};\n\tconst listenerOptions = { passive: true };\n\tuseEventListener(\"gamepadconnected\", (e) => onGamepadConnected(e.gamepad), listenerOptions);\n\tuseEventListener(\"gamepaddisconnected\", (e) => onGamepadDisconnected(e.gamepad), listenerOptions);\n\ttryOnMounted(() => {\n\t\tconst _gamepads = (navigator$1 === null || navigator$1 === void 0 ? void 0 : navigator$1.getGamepads()) || [];\n\t\tfor (const gamepad of _gamepads) if (gamepad && gamepads.value[gamepad.index]) onGamepadConnected(gamepad);\n\t});\n\tpause();\n\treturn {\n\t\tisSupported,\n\t\tonConnected: onConnectedHook.on,\n\t\tonDisconnected: onDisconnectedHook.on,\n\t\tgamepads,\n\t\tpause,\n\t\tresume,\n\t\tisActive\n\t};\n}\n\n//#endregion\n//#region useGeolocation/index.ts\n/**\n* Reactive Geolocation API.\n*\n* @see https://vueuse.org/useGeolocation\n* @param options\n*/\nfunction useGeolocation(options = {}) {\n\tconst { enableHighAccuracy = true, maximumAge = 3e4, timeout = 27e3, navigator: navigator$1 = defaultNavigator, immediate = true } = options;\n\tconst isSupported = /* @__PURE__ */ useSupported(() => navigator$1 && \"geolocation\" in navigator$1);\n\tconst locatedAt = shallowRef(null);\n\tconst error = shallowRef(null);\n\tconst coords = ref({\n\t\taccuracy: 0,\n\t\tlatitude: Number.POSITIVE_INFINITY,\n\t\tlongitude: Number.POSITIVE_INFINITY,\n\t\taltitude: null,\n\t\taltitudeAccuracy: null,\n\t\theading: null,\n\t\tspeed: null\n\t});\n\tfunction updatePosition(position) {\n\t\tlocatedAt.value = position.timestamp;\n\t\tcoords.value = position.coords;\n\t\terror.value = null;\n\t}\n\tlet watcher;\n\tfunction resume() {\n\t\tif (isSupported.value) watcher = navigator$1.geolocation.watchPosition(updatePosition, (err) => error.value = err, {\n\t\t\tenableHighAccuracy,\n\t\t\tmaximumAge,\n\t\t\ttimeout\n\t\t});\n\t}\n\tif (immediate) resume();\n\tfunction pause() {\n\t\tif (watcher && navigator$1) navigator$1.geolocation.clearWatch(watcher);\n\t}\n\ttryOnScopeDispose(() => {\n\t\tpause();\n\t});\n\treturn {\n\t\tisSupported,\n\t\tcoords,\n\t\tlocatedAt,\n\t\terror,\n\t\tresume,\n\t\tpause\n\t};\n}\n\n//#endregion\n//#region useIdle/index.ts\nconst defaultEvents$1 = [\n\t\"mousemove\",\n\t\"mousedown\",\n\t\"resize\",\n\t\"keydown\",\n\t\"touchstart\",\n\t\"wheel\"\n];\nconst oneMinute = 6e4;\n/**\n* Tracks whether the user is being inactive.\n*\n* @see https://vueuse.org/useIdle\n* @param timeout default to 1 minute\n* @param options IdleOptions\n*/\nfunction useIdle(timeout = oneMinute, options = {}) {\n\tconst { initialState = false, listenForVisibilityChange = true, events: events$1 = defaultEvents$1, window: window$1 = defaultWindow, eventFilter = throttleFilter(50) } = options;\n\tconst idle = shallowRef(initialState);\n\tconst lastActive = shallowRef(timestamp());\n\tconst isPending = shallowRef(false);\n\tlet timer;\n\tconst reset = () => {\n\t\tidle.value = false;\n\t\tclearTimeout(timer);\n\t\ttimer = setTimeout(() => idle.value = true, timeout);\n\t};\n\tconst onEvent = createFilterWrapper(eventFilter, () => {\n\t\tlastActive.value = timestamp();\n\t\treset();\n\t});\n\tif (window$1) {\n\t\tconst document$1 = window$1.document;\n\t\tconst listenerOptions = { passive: true };\n\t\tfor (const event of events$1) useEventListener(window$1, event, () => {\n\t\t\tif (!isPending.value) return;\n\t\t\tonEvent();\n\t\t}, listenerOptions);\n\t\tif (listenForVisibilityChange) useEventListener(document$1, \"visibilitychange\", () => {\n\t\t\tif (document$1.hidden || !isPending.value) return;\n\t\t\tonEvent();\n\t\t}, listenerOptions);\n\t\tstart();\n\t}\n\tfunction start() {\n\t\tif (isPending.value) return;\n\t\tisPending.value = true;\n\t\tif (!initialState) reset();\n\t}\n\tfunction stop() {\n\t\tidle.value = initialState;\n\t\tclearTimeout(timer);\n\t\tisPending.value = false;\n\t}\n\treturn {\n\t\tidle,\n\t\tlastActive,\n\t\treset,\n\t\tstop,\n\t\tstart,\n\t\tisPending: shallowReadonly(isPending)\n\t};\n}\n\n//#endregion\n//#region useImage/index.ts\nasync function loadImage(options) {\n\treturn new Promise((resolve, reject) => {\n\t\tconst img = new Image();\n\t\tconst { src, srcset, sizes, class: clazz, loading, crossorigin, referrerPolicy, width, height, decoding, fetchPriority, ismap, usemap } = options;\n\t\timg.src = src;\n\t\tif (srcset != null) img.srcset = srcset;\n\t\tif (sizes != null) img.sizes = sizes;\n\t\tif (clazz != null) img.className = clazz;\n\t\tif (loading != null) img.loading = loading;\n\t\tif (crossorigin != null) img.crossOrigin = crossorigin;\n\t\tif (referrerPolicy != null) img.referrerPolicy = referrerPolicy;\n\t\tif (width != null) img.width = width;\n\t\tif (height != null) img.height = height;\n\t\tif (decoding != null) img.decoding = decoding;\n\t\tif (fetchPriority != null) img.fetchPriority = fetchPriority;\n\t\tif (ismap != null) img.isMap = ismap;\n\t\tif (usemap != null) img.useMap = usemap;\n\t\timg.onload = () => resolve(img);\n\t\timg.onerror = reject;\n\t});\n}\n/**\n* Reactive load an image in the browser, you can wait the result to display it or show a fallback.\n*\n* @see https://vueuse.org/useImage\n* @param options Image attributes, as used in the <img> tag\n* @param asyncStateOptions\n*/\nfunction useImage(options, asyncStateOptions = {}) {\n\tconst state = useAsyncState(() => loadImage(toValue(options)), void 0, {\n\t\tresetOnExecute: true,\n\t\t...asyncStateOptions\n\t});\n\twatch(() => toValue(options), () => state.execute(asyncStateOptions.delay), { deep: true });\n\treturn state;\n}\n\n//#endregion\n//#region _resolve-element.ts\n/**\n* Resolves an element from a given element, window, or document.\n*\n* @internal\n*/\nfunction resolveElement(el) {\n\tif (typeof Window !== \"undefined\" && el instanceof Window) return el.document.documentElement;\n\tif (typeof Document !== \"undefined\" && el instanceof Document) return el.documentElement;\n\treturn el;\n}\n\n//#endregion\n//#region useScroll/index.ts\n/**\n* We have to check if the scroll amount is close enough to some threshold in order to\n* more accurately calculate arrivedState. This is because scrollTop/scrollLeft are non-rounded\n* numbers, while scrollHeight/scrollWidth and clientHeight/clientWidth are rounded.\n* https://developer.mozilla.org/en-US/docs/Web/API/Element/scrollHeight#determine_if_an_element_has_been_totally_scrolled\n*/\nconst ARRIVED_STATE_THRESHOLD_PIXELS = 1;\n/**\n* Reactive scroll.\n*\n* @see https://vueuse.org/useScroll\n* @param element\n* @param options\n*/\nfunction useScroll(element, options = {}) {\n\tconst { throttle = 0, idle = 200, onStop = noop, onScroll = noop, offset = {\n\t\tleft: 0,\n\t\tright: 0,\n\t\ttop: 0,\n\t\tbottom: 0\n\t}, observe: _observe = { mutation: false }, eventListenerOptions = {\n\t\tcapture: false,\n\t\tpassive: true\n\t}, behavior = \"auto\", window: window$1 = defaultWindow, onError = (e) => {\n\t\tconsole.error(e);\n\t} } = options;\n\tconst observe = typeof _observe === \"boolean\" ? { mutation: _observe } : _observe;\n\tconst internalX = shallowRef(0);\n\tconst internalY = shallowRef(0);\n\tconst x = computed({\n\t\tget() {\n\t\t\treturn internalX.value;\n\t\t},\n\t\tset(x$1) {\n\t\t\tscrollTo(x$1, void 0);\n\t\t}\n\t});\n\tconst y = computed({\n\t\tget() {\n\t\t\treturn internalY.value;\n\t\t},\n\t\tset(y$1) {\n\t\t\tscrollTo(void 0, y$1);\n\t\t}\n\t});\n\tfunction scrollTo(_x, _y) {\n\t\tvar _ref, _toValue, _toValue2, _document;\n\t\tif (!window$1) return;\n\t\tconst _element = toValue(element);\n\t\tif (!_element) return;\n\t\t(_ref = _element instanceof Document ? window$1.document.body : _element) === null || _ref === void 0 || _ref.scrollTo({\n\t\t\ttop: (_toValue = toValue(_y)) !== null && _toValue !== void 0 ? _toValue : y.value,\n\t\t\tleft: (_toValue2 = toValue(_x)) !== null && _toValue2 !== void 0 ? _toValue2 : x.value,\n\t\t\tbehavior: toValue(behavior)\n\t\t});\n\t\tconst scrollContainer = (_element === null || _element === void 0 || (_document = _element.document) === null || _document === void 0 ? void 0 : _document.documentElement) || (_element === null || _element === void 0 ? void 0 : _element.documentElement) || _element;\n\t\tif (x != null) internalX.value = scrollContainer.scrollLeft;\n\t\tif (y != null) internalY.value = scrollContainer.scrollTop;\n\t}\n\tconst isScrolling = shallowRef(false);\n\tconst arrivedState = reactive({\n\t\tleft: true,\n\t\tright: false,\n\t\ttop: true,\n\t\tbottom: false\n\t});\n\tconst directions = reactive({\n\t\tleft: false,\n\t\tright: false,\n\t\ttop: false,\n\t\tbottom: false\n\t});\n\tconst onScrollEnd = (e) => {\n\t\tif (!isScrolling.value) return;\n\t\tisScrolling.value = false;\n\t\tdirections.left = false;\n\t\tdirections.right = false;\n\t\tdirections.top = false;\n\t\tdirections.bottom = false;\n\t\tonStop(e);\n\t};\n\tconst onScrollEndDebounced = useDebounceFn(onScrollEnd, throttle + idle);\n\tconst setArrivedState = (target) => {\n\t\tvar _document2;\n\t\tif (!window$1) return;\n\t\tconst el = (target === null || target === void 0 || (_document2 = target.document) === null || _document2 === void 0 ? void 0 : _document2.documentElement) || (target === null || target === void 0 ? void 0 : target.documentElement) || unrefElement(target);\n\t\tconst { display, flexDirection, direction } = window$1.getComputedStyle(el);\n\t\tconst directionMultipler = direction === \"rtl\" ? -1 : 1;\n\t\tconst scrollLeft = el.scrollLeft;\n\t\tdirections.left = scrollLeft < internalX.value;\n\t\tdirections.right = scrollLeft > internalX.value;\n\t\tconst left = Math.abs(scrollLeft * directionMultipler) <= (offset.left || 0);\n\t\tconst right = Math.abs(scrollLeft * directionMultipler) + el.clientWidth >= el.scrollWidth - (offset.right || 0) - ARRIVED_STATE_THRESHOLD_PIXELS;\n\t\tif (display === \"flex\" && flexDirection === \"row-reverse\") {\n\t\t\tarrivedState.left = right;\n\t\t\tarrivedState.right = left;\n\t\t} else {\n\t\t\tarrivedState.left = left;\n\t\t\tarrivedState.right = right;\n\t\t}\n\t\tinternalX.value = scrollLeft;\n\t\tlet scrollTop = el.scrollTop;\n\t\tif (target === window$1.document && !scrollTop) scrollTop = window$1.document.body.scrollTop;\n\t\tdirections.top = scrollTop < internalY.value;\n\t\tdirections.bottom = scrollTop > internalY.value;\n\t\tconst top = Math.abs(scrollTop) <= (offset.top || 0);\n\t\tconst bottom = Math.abs(scrollTop) + el.clientHeight >= el.scrollHeight - (offset.bottom || 0) - ARRIVED_STATE_THRESHOLD_PIXELS;\n\t\t/**\n\t\t* reverse columns and rows behave exactly the other way around,\n\t\t* bottom is treated as top and top is treated as the negative version of bottom\n\t\t*/\n\t\tif (display === \"flex\" && flexDirection === \"column-reverse\") {\n\t\t\tarrivedState.top = bottom;\n\t\t\tarrivedState.bottom = top;\n\t\t} else {\n\t\t\tarrivedState.top = top;\n\t\t\tarrivedState.bottom = bottom;\n\t\t}\n\t\tinternalY.value = scrollTop;\n\t};\n\tconst onScrollHandler = (e) => {\n\t\tvar _documentElement;\n\t\tif (!window$1) return;\n\t\tsetArrivedState((_documentElement = e.target.documentElement) !== null && _documentElement !== void 0 ? _documentElement : e.target);\n\t\tisScrolling.value = true;\n\t\tonScrollEndDebounced(e);\n\t\tonScroll(e);\n\t};\n\tuseEventListener(element, \"scroll\", throttle ? useThrottleFn(onScrollHandler, throttle, true, false) : onScrollHandler, eventListenerOptions);\n\ttryOnMounted(() => {\n\t\ttry {\n\t\t\tconst _element = toValue(element);\n\t\t\tif (!_element) return;\n\t\t\tsetArrivedState(_element);\n\t\t} catch (e) {\n\t\t\tonError(e);\n\t\t}\n\t});\n\tif ((observe === null || observe === void 0 ? void 0 : observe.mutation) && element != null && element !== window$1 && element !== document) useMutationObserver(element, () => {\n\t\tconst _element = toValue(element);\n\t\tif (!_element) return;\n\t\tsetArrivedState(_element);\n\t}, {\n\t\tattributes: true,\n\t\tchildList: true,\n\t\tsubtree: true\n\t});\n\tuseEventListener(element, \"scrollend\", onScrollEnd, eventListenerOptions);\n\treturn {\n\t\tx,\n\t\ty,\n\t\tisScrolling,\n\t\tarrivedState,\n\t\tdirections,\n\t\tmeasure() {\n\t\t\tconst _element = toValue(element);\n\t\t\tif (window$1 && _element) setArrivedState(_element);\n\t\t}\n\t};\n}\n\n//#endregion\n//#region useInfiniteScroll/index.ts\n/**\n* Reactive infinite scroll.\n*\n* @see https://vueuse.org/useInfiniteScroll\n*/\nfunction useInfiniteScroll(element, onLoadMore, options = {}) {\n\tvar _options$distance;\n\tconst { direction = \"bottom\", interval = 100, canLoadMore = () => true } = options;\n\tconst state = reactive(useScroll(element, {\n\t\t...options,\n\t\toffset: {\n\t\t\t[direction]: (_options$distance = options.distance) !== null && _options$distance !== void 0 ? _options$distance : 0,\n\t\t\t...options.offset\n\t\t}\n\t}));\n\tconst promise = ref();\n\tconst isLoading = computed(() => !!promise.value);\n\tconst observedElement = computed(() => {\n\t\treturn resolveElement(toValue(element));\n\t});\n\tconst isElementVisible = useElementVisibility(observedElement);\n\tconst canLoad = computed(() => {\n\t\tif (!observedElement.value) return false;\n\t\treturn canLoadMore(observedElement.value);\n\t});\n\tfunction checkAndLoad() {\n\t\tstate.measure();\n\t\tif (!observedElement.value || !isElementVisible.value || !canLoad.value || promise.value) return;\n\t\tconst { scrollHeight, clientHeight, scrollWidth, clientWidth } = observedElement.value;\n\t\tconst isNarrower = direction === \"bottom\" || direction === \"top\" ? scrollHeight <= clientHeight : scrollWidth <= clientWidth;\n\t\tif (state.arrivedState[direction] || isNarrower) promise.value = Promise.all([onLoadMore(state), new Promise((resolve) => setTimeout(resolve, interval))]).finally(() => {\n\t\t\tpromise.value = null;\n\t\t\tnextTick(() => checkAndLoad());\n\t\t});\n\t}\n\ttryOnUnmounted(watch(() => [\n\t\tstate.arrivedState[direction],\n\t\tisElementVisible.value,\n\t\tcanLoad.value\n\t], checkAndLoad, {\n\t\timmediate: true,\n\t\tflush: \"post\"\n\t}));\n\treturn {\n\t\tisLoading,\n\t\treset() {\n\t\t\tnextTick(() => checkAndLoad());\n\t\t}\n\t};\n}\n\n//#endregion\n//#region useKeyModifier/index.ts\nconst defaultEvents = [\n\t\"mousedown\",\n\t\"mouseup\",\n\t\"keydown\",\n\t\"keyup\"\n];\n/* @__NO_SIDE_EFFECTS__ */\nfunction useKeyModifier(modifier, options = {}) {\n\tconst { events: events$1 = defaultEvents, document: document$1 = defaultDocument, initial = null } = options;\n\tconst state = shallowRef(initial);\n\tif (document$1) events$1.forEach((listenerEvent) => {\n\t\tuseEventListener(document$1, listenerEvent, (evt) => {\n\t\t\tif (typeof evt.getModifierState === \"function\") state.value = evt.getModifierState(modifier);\n\t\t}, { passive: true });\n\t});\n\treturn state;\n}\n\n//#endregion\n//#region useLocalStorage/index.ts\n/**\n* Reactive LocalStorage.\n*\n* @see https://vueuse.org/useLocalStorage\n* @param key\n* @param initialValue\n* @param options\n*/\nfunction useLocalStorage(key, initialValue, options = {}) {\n\tconst { window: window$1 = defaultWindow } = options;\n\treturn useStorage(key, initialValue, window$1 === null || window$1 === void 0 ? void 0 : window$1.localStorage, options);\n}\n\n//#endregion\n//#region useMagicKeys/aliasMap.ts\nconst DefaultMagicKeysAliasMap = {\n\tctrl: \"control\",\n\tcommand: \"meta\",\n\tcmd: \"meta\",\n\toption: \"alt\",\n\tup: \"arrowup\",\n\tdown: \"arrowdown\",\n\tleft: \"arrowleft\",\n\tright: \"arrowright\"\n};\n\n//#endregion\n//#region useMagicKeys/index.ts\n/**\n* Reactive keys pressed state, with magical keys combination support.\n*\n* @see https://vueuse.org/useMagicKeys\n*/\nfunction useMagicKeys(options = {}) {\n\tconst { reactive: useReactive = false, target = defaultWindow, aliasMap = DefaultMagicKeysAliasMap, passive = true, onEventFired = noop } = options;\n\tconst current = reactive(/* @__PURE__ */ new Set());\n\tconst obj = {\n\t\ttoJSON() {\n\t\t\treturn {};\n\t\t},\n\t\tcurrent\n\t};\n\tconst refs = useReactive ? reactive(obj) : obj;\n\tconst metaDeps = /* @__PURE__ */ new Set();\n\tconst depsMap = new Map([\n\t\t[\"Meta\", metaDeps],\n\t\t[\"Shift\", /* @__PURE__ */ new Set()],\n\t\t[\"Alt\", /* @__PURE__ */ new Set()]\n\t]);\n\tconst usedKeys = /* @__PURE__ */ new Set();\n\tfunction setRefs(key, value) {\n\t\tif (key in refs) if (useReactive) refs[key] = value;\n\t\telse refs[key].value = value;\n\t}\n\tfunction reset() {\n\t\tcurrent.clear();\n\t\tfor (const key of usedKeys) setRefs(key, false);\n\t}\n\tfunction updateDeps(value, e, keys$1) {\n\t\tif (!value || typeof e.getModifierState !== \"function\") return;\n\t\tfor (const [modifier, depsSet] of depsMap) if (e.getModifierState(modifier)) {\n\t\t\tkeys$1.forEach((key) => depsSet.add(key));\n\t\t\tbreak;\n\t\t}\n\t}\n\tfunction clearDeps(value, key) {\n\t\tif (value) return;\n\t\tconst depsMapKey = `${key[0].toUpperCase()}${key.slice(1)}`;\n\t\tconst deps = depsMap.get(depsMapKey);\n\t\tif (![\"shift\", \"alt\"].includes(key) || !deps) return;\n\t\tconst depsArray = Array.from(deps);\n\t\tconst depsIndex = depsArray.indexOf(key);\n\t\tdepsArray.forEach((key$1, index) => {\n\t\t\tif (index >= depsIndex) {\n\t\t\t\tcurrent.delete(key$1);\n\t\t\t\tsetRefs(key$1, false);\n\t\t\t}\n\t\t});\n\t\tdeps.clear();\n\t}\n\tfunction updateRefs(e, value) {\n\t\tvar _e$key, _e$code;\n\t\tconst key = (_e$key = e.key) === null || _e$key === void 0 ? void 0 : _e$key.toLowerCase();\n\t\tconst values = [(_e$code = e.code) === null || _e$code === void 0 ? void 0 : _e$code.toLowerCase(), key].filter(Boolean);\n\t\tif (!key) return;\n\t\tif (key) if (value) current.add(key);\n\t\telse current.delete(key);\n\t\tfor (const key$1 of values) {\n\t\t\tusedKeys.add(key$1);\n\t\t\tsetRefs(key$1, value);\n\t\t}\n\t\tupdateDeps(value, e, [...current, ...values]);\n\t\tclearDeps(value, key);\n\t\tif (key === \"meta\" && !value) {\n\t\t\tmetaDeps.forEach((key$1) => {\n\t\t\t\tcurrent.delete(key$1);\n\t\t\t\tsetRefs(key$1, false);\n\t\t\t});\n\t\t\tmetaDeps.clear();\n\t\t}\n\t}\n\tuseEventListener(target, \"keydown\", (e) => {\n\t\tupdateRefs(e, true);\n\t\treturn onEventFired(e);\n\t}, { passive });\n\tuseEventListener(target, \"keyup\", (e) => {\n\t\tupdateRefs(e, false);\n\t\treturn onEventFired(e);\n\t}, { passive });\n\tuseEventListener(\"blur\", reset, { passive });\n\tuseEventListener(\"focus\", reset, { passive });\n\tconst proxy = new Proxy(refs, { get(target$1, prop, rec) {\n\t\tif (typeof prop !== \"string\") return Reflect.get(target$1, prop, rec);\n\t\tprop = prop.toLowerCase();\n\t\tif (prop in aliasMap) prop = aliasMap[prop];\n\t\tif (!(prop in refs)) if (/[+_-]/.test(prop)) {\n\t\t\tconst keys$1 = prop.split(/[+_-]/g).map((i) => i.trim());\n\t\t\trefs[prop] = computed(() => keys$1.map((key) => toValue(proxy[key])).every(Boolean));\n\t\t} else refs[prop] = shallowRef(false);\n\t\tconst r = Reflect.get(target$1, prop, rec);\n\t\treturn useReactive ? toValue(r) : r;\n\t} });\n\treturn proxy;\n}\n\n//#endregion\n//#region useMediaControls/index.ts\n/**\n* Automatically check if the ref exists and if it does run the cb fn\n*/\nfunction usingElRef(source, cb) {\n\tif (toValue(source)) cb(toValue(source));\n}\n/**\n* Converts a TimeRange object to an array\n*/\nfunction timeRangeToArray(timeRanges) {\n\tlet ranges = [];\n\tfor (let i = 0; i < timeRanges.length; ++i) ranges = [...ranges, [timeRanges.start(i), timeRanges.end(i)]];\n\treturn ranges;\n}\n/**\n* Converts a TextTrackList object to an array of `UseMediaTextTrack`\n*/\nfunction tracksToArray(tracks) {\n\treturn Array.from(tracks).map(({ label, kind, language, mode, activeCues, cues, inBandMetadataTrackDispatchType }, id) => ({\n\t\tid,\n\t\tlabel,\n\t\tkind,\n\t\tlanguage,\n\t\tmode,\n\t\tactiveCues,\n\t\tcues,\n\t\tinBandMetadataTrackDispatchType\n\t}));\n}\nconst defaultOptions = {\n\tsrc: \"\",\n\ttracks: []\n};\nfunction useMediaControls(target, options = {}) {\n\ttarget = toRef(target);\n\toptions = {\n\t\t...defaultOptions,\n\t\t...options\n\t};\n\tconst { document: document$1 = defaultDocument } = options;\n\tconst listenerOptions = { passive: true };\n\tconst currentTime = shallowRef(0);\n\tconst duration = shallowRef(0);\n\tconst seeking = shallowRef(false);\n\tconst volume = shallowRef(1);\n\tconst waiting = shallowRef(false);\n\tconst ended = shallowRef(false);\n\tconst playing = shallowRef(false);\n\tconst rate = shallowRef(1);\n\tconst stalled = shallowRef(false);\n\tconst buffered = ref([]);\n\tconst tracks = ref([]);\n\tconst selectedTrack = shallowRef(-1);\n\tconst isPictureInPicture = shallowRef(false);\n\tconst muted = shallowRef(false);\n\tconst supportsPictureInPicture = Boolean(document$1 && \"pictureInPictureEnabled\" in document$1);\n\tconst sourceErrorEvent = createEventHook();\n\tconst playbackErrorEvent = createEventHook();\n\t/**\n\t* Disables the specified track. If no track is specified then\n\t* all tracks will be disabled\n\t*\n\t* @param track The id of the track to disable\n\t*/\n\tconst disableTrack = (track) => {\n\t\tusingElRef(target, (el) => {\n\t\t\tif (track) {\n\t\t\t\tconst id = typeof track === \"number\" ? track : track.id;\n\t\t\t\tel.textTracks[id].mode = \"disabled\";\n\t\t\t} else for (let i = 0; i < el.textTracks.length; ++i) el.textTracks[i].mode = \"disabled\";\n\t\t\tselectedTrack.value = -1;\n\t\t});\n\t};\n\t/**\n\t* Enables the specified track and disables the\n\t* other tracks unless otherwise specified\n\t*\n\t* @param track The track of the id of the track to enable\n\t* @param disableTracks Disable all other tracks\n\t*/\n\tconst enableTrack = (track, disableTracks = true) => {\n\t\tusingElRef(target, (el) => {\n\t\t\tconst id = typeof track === \"number\" ? track : track.id;\n\t\t\tif (disableTracks) disableTrack();\n\t\t\tel.textTracks[id].mode = \"showing\";\n\t\t\tselectedTrack.value = id;\n\t\t});\n\t};\n\t/**\n\t* Toggle picture in picture mode for the player.\n\t*/\n\tconst togglePictureInPicture = () => {\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tusingElRef(target, async (el) => {\n\t\t\t\tif (supportsPictureInPicture) if (!isPictureInPicture.value) el.requestPictureInPicture().then(resolve).catch(reject);\n\t\t\t\telse document$1.exitPictureInPicture().then(resolve).catch(reject);\n\t\t\t});\n\t\t});\n\t};\n\t/**\n\t* This will automatically inject sources to the media element. The sources will be\n\t* appended as children to the media element as `<source>` elements.\n\t*/\n\twatchEffect(() => {\n\t\tif (!document$1) return;\n\t\tconst el = toValue(target);\n\t\tif (!el) return;\n\t\tconst src = toValue(options.src);\n\t\tlet sources = [];\n\t\tif (!src) return;\n\t\tif (typeof src === \"string\") sources = [{ src }];\n\t\telse if (Array.isArray(src)) sources = src;\n\t\telse if (isObject(src)) sources = [src];\n\t\tel.querySelectorAll(\"source\").forEach((e) => {\n\t\t\te.remove();\n\t\t});\n\t\tsources.forEach(({ src: src$1, type, media }) => {\n\t\t\tconst source = document$1.createElement(\"source\");\n\t\t\tsource.setAttribute(\"src\", src$1);\n\t\t\tsource.setAttribute(\"type\", type || \"\");\n\t\t\tsource.setAttribute(\"media\", media || \"\");\n\t\t\tuseEventListener(source, \"error\", sourceErrorEvent.trigger, listenerOptions);\n\t\t\tel.appendChild(source);\n\t\t});\n\t\tel.load();\n\t});\n\t/**\n\t* Apply composable state to the element, also when element is changed\n\t*/\n\twatch([target, volume], () => {\n\t\tconst el = toValue(target);\n\t\tif (!el) return;\n\t\tel.volume = volume.value;\n\t});\n\twatch([target, muted], () => {\n\t\tconst el = toValue(target);\n\t\tif (!el) return;\n\t\tel.muted = muted.value;\n\t});\n\twatch([target, rate], () => {\n\t\tconst el = toValue(target);\n\t\tif (!el) return;\n\t\tel.playbackRate = rate.value;\n\t});\n\t/**\n\t* Load Tracks\n\t*/\n\twatchEffect(() => {\n\t\tif (!document$1) return;\n\t\tconst textTracks = toValue(options.tracks);\n\t\tconst el = toValue(target);\n\t\tif (!textTracks || !textTracks.length || !el) return;\n\t\t/**\n\t\t* The MediaAPI provides an API for adding text tracks, but they don't currently\n\t\t* have an API for removing text tracks, so instead we will just create and remove\n\t\t* the tracks manually using the HTML api.\n\t\t*/\n\t\tel.querySelectorAll(\"track\").forEach((e) => e.remove());\n\t\ttextTracks.forEach(({ default: isDefault, kind, label, src, srcLang }, i) => {\n\t\t\tconst track = document$1.createElement(\"track\");\n\t\t\ttrack.default = isDefault || false;\n\t\t\ttrack.kind = kind;\n\t\t\ttrack.label = label;\n\t\t\ttrack.src = src;\n\t\t\ttrack.srclang = srcLang;\n\t\t\tif (track.default) selectedTrack.value = i;\n\t\t\tel.appendChild(track);\n\t\t});\n\t});\n\t/**\n\t* This will allow us to update the current time from the timeupdate event\n\t* without setting the medias current position, but if the user changes the\n\t* current time via the ref, then the media will seek.\n\t*\n\t* If we did not use an ignorable watch, then the current time update from\n\t* the timeupdate event would cause the media to stutter.\n\t*/\n\tconst { ignoreUpdates: ignoreCurrentTimeUpdates } = watchIgnorable(currentTime, (time) => {\n\t\tconst el = toValue(target);\n\t\tif (!el) return;\n\t\tel.currentTime = time;\n\t});\n\t/**\n\t* Using an ignorable watch so we can control the play state using a ref and not\n\t* a function\n\t*/\n\tconst { ignoreUpdates: ignorePlayingUpdates } = watchIgnorable(playing, (isPlaying) => {\n\t\tconst el = toValue(target);\n\t\tif (!el) return;\n\t\tif (isPlaying) el.play().catch((e) => {\n\t\t\tplaybackErrorEvent.trigger(e);\n\t\t\tthrow e;\n\t\t});\n\t\telse el.pause();\n\t});\n\tuseEventListener(target, \"timeupdate\", () => ignoreCurrentTimeUpdates(() => currentTime.value = toValue(target).currentTime), listenerOptions);\n\tuseEventListener(target, \"durationchange\", () => duration.value = toValue(target).duration, listenerOptions);\n\tuseEventListener(target, \"progress\", () => buffered.value = timeRangeToArray(toValue(target).buffered), listenerOptions);\n\tuseEventListener(target, \"seeking\", () => seeking.value = true, listenerOptions);\n\tuseEventListener(target, \"seeked\", () => seeking.value = false, listenerOptions);\n\tuseEventListener(target, [\"waiting\", \"loadstart\"], () => {\n\t\twaiting.value = true;\n\t\tignorePlayingUpdates(() => playing.value = false);\n\t}, listenerOptions);\n\tuseEventListener(target, \"loadeddata\", () => waiting.value = false, listenerOptions);\n\tuseEventListener(target, \"playing\", () => {\n\t\twaiting.value = false;\n\t\tended.value = false;\n\t\tignorePlayingUpdates(() => playing.value = true);\n\t}, listenerOptions);\n\tuseEventListener(target, \"ratechange\", () => rate.value = toValue(target).playbackRate, listenerOptions);\n\tuseEventListener(target, \"stalled\", () => stalled.value = true, listenerOptions);\n\tuseEventListener(target, \"ended\", () => ended.value = true, listenerOptions);\n\tuseEventListener(target, \"pause\", () => ignorePlayingUpdates(() => playing.value = false), listenerOptions);\n\tuseEventListener(target, \"play\", () => ignorePlayingUpdates(() => playing.value = true), listenerOptions);\n\tuseEventListener(target, \"enterpictureinpicture\", () => isPictureInPicture.value = true, listenerOptions);\n\tuseEventListener(target, \"leavepictureinpicture\", () => isPictureInPicture.value = false, listenerOptions);\n\tuseEventListener(target, \"volumechange\", () => {\n\t\tconst el = toValue(target);\n\t\tif (!el) return;\n\t\tvolume.value = el.volume;\n\t\tmuted.value = el.muted;\n\t}, listenerOptions);\n\t/**\n\t* The following listeners need to listen to a nested\n\t* object on the target, so we will have to use a nested\n\t* watch and manually remove the listeners\n\t*/\n\tconst listeners = [];\n\tconst stop = watch([target], () => {\n\t\tconst el = toValue(target);\n\t\tif (!el) return;\n\t\tstop();\n\t\tlisteners[0] = useEventListener(el.textTracks, \"addtrack\", () => tracks.value = tracksToArray(el.textTracks), listenerOptions);\n\t\tlisteners[1] = useEventListener(el.textTracks, \"removetrack\", () => tracks.value = tracksToArray(el.textTracks), listenerOptions);\n\t\tlisteners[2] = useEventListener(el.textTracks, \"change\", () => tracks.value = tracksToArray(el.textTracks), listenerOptions);\n\t});\n\ttryOnScopeDispose(() => listeners.forEach((listener) => listener()));\n\treturn {\n\t\tcurrentTime,\n\t\tduration,\n\t\twaiting,\n\t\tseeking,\n\t\tended,\n\t\tstalled,\n\t\tbuffered,\n\t\tplaying,\n\t\trate,\n\t\tvolume,\n\t\tmuted,\n\t\ttracks,\n\t\tselectedTrack,\n\t\tenableTrack,\n\t\tdisableTrack,\n\t\tsupportsPictureInPicture,\n\t\ttogglePictureInPicture,\n\t\tisPictureInPicture,\n\t\tonSourceError: sourceErrorEvent.on,\n\t\tonPlaybackError: playbackErrorEvent.on\n\t};\n}\n\n//#endregion\n//#region useMemoize/index.ts\n/**\n* Reactive function result cache based on arguments\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useMemoize(resolver, options) {\n\tconst initCache = () => {\n\t\tif (options === null || options === void 0 ? void 0 : options.cache) return shallowReactive(options.cache);\n\t\treturn shallowReactive(/* @__PURE__ */ new Map());\n\t};\n\tconst cache = initCache();\n\t/**\n\t* Generate key from args\n\t*/\n\tconst generateKey = (...args) => (options === null || options === void 0 ? void 0 : options.getKey) ? options.getKey(...args) : JSON.stringify(args);\n\t/**\n\t* Load data and save in cache\n\t*/\n\tconst _loadData = (key, ...args) => {\n\t\tcache.set(key, resolver(...args));\n\t\treturn cache.get(key);\n\t};\n\tconst loadData = (...args) => _loadData(generateKey(...args), ...args);\n\t/**\n\t* Delete key from cache\n\t*/\n\tconst deleteData = (...args) => {\n\t\tcache.delete(generateKey(...args));\n\t};\n\t/**\n\t* Clear cached data\n\t*/\n\tconst clearData = () => {\n\t\tcache.clear();\n\t};\n\tconst memoized = (...args) => {\n\t\tconst key = generateKey(...args);\n\t\tif (cache.has(key)) return cache.get(key);\n\t\treturn _loadData(key, ...args);\n\t};\n\tmemoized.load = loadData;\n\tmemoized.delete = deleteData;\n\tmemoized.clear = clearData;\n\tmemoized.generateKey = generateKey;\n\tmemoized.cache = cache;\n\treturn memoized;\n}\n\n//#endregion\n//#region useMemory/index.ts\nfunction getDefaultScheduler$6(options) {\n\tif (\"interval\" in options || \"immediate\" in options || \"immediateCallback\" in options) {\n\t\tconst { interval = 1e3, immediate, immediateCallback } = options;\n\t\treturn (cb) => useIntervalFn(cb, interval, {\n\t\t\timmediate,\n\t\t\timmediateCallback\n\t\t});\n\t}\n\treturn useIntervalFn;\n}\n/**\n* Reactive Memory Info.\n*\n* @see https://vueuse.org/useMemory\n* @param options\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useMemory(options = {}) {\n\tconst memory = ref();\n\tconst isSupported = /* @__PURE__ */ useSupported(() => typeof performance !== \"undefined\" && \"memory\" in performance);\n\tif (isSupported.value) {\n\t\tconst { scheduler = getDefaultScheduler$6 } = options;\n\t\tscheduler(() => {\n\t\t\tmemory.value = performance.memory;\n\t\t});\n\t}\n\treturn {\n\t\tisSupported,\n\t\tmemory\n\t};\n}\n\n//#endregion\n//#region useMouse/index.ts\nconst UseMouseBuiltinExtractors = {\n\tpage: (event) => [event.pageX, event.pageY],\n\tclient: (event) => [event.clientX, event.clientY],\n\tscreen: (event) => [event.screenX, event.screenY],\n\tmovement: (event) => event instanceof MouseEvent ? [event.movementX, event.movementY] : null\n};\n/**\n* Reactive mouse position.\n*\n* @see https://vueuse.org/useMouse\n* @param options\n*/\nfunction useMouse(options = {}) {\n\tconst { type = \"page\", touch = true, resetOnTouchEnds = false, initialValue = {\n\t\tx: 0,\n\t\ty: 0\n\t}, window: window$1 = defaultWindow, target = window$1, scroll = true, eventFilter } = options;\n\tlet _prevMouseEvent = null;\n\tlet _prevScrollX = 0;\n\tlet _prevScrollY = 0;\n\tconst x = shallowRef(initialValue.x);\n\tconst y = shallowRef(initialValue.y);\n\tconst sourceType = shallowRef(null);\n\tconst extractor = typeof type === \"function\" ? type : UseMouseBuiltinExtractors[type];\n\tconst mouseHandler = (event) => {\n\t\tconst result = extractor(event);\n\t\t_prevMouseEvent = event;\n\t\tif (result) {\n\t\t\t[x.value, y.value] = result;\n\t\t\tsourceType.value = \"mouse\";\n\t\t}\n\t\tif (window$1) {\n\t\t\t_prevScrollX = window$1.scrollX;\n\t\t\t_prevScrollY = window$1.scrollY;\n\t\t}\n\t};\n\tconst touchHandler = (event) => {\n\t\tif (event.touches.length > 0) {\n\t\t\tconst result = extractor(event.touches[0]);\n\t\t\tif (result) {\n\t\t\t\t[x.value, y.value] = result;\n\t\t\t\tsourceType.value = \"touch\";\n\t\t\t}\n\t\t}\n\t};\n\tconst scrollHandler = () => {\n\t\tif (!_prevMouseEvent || !window$1) return;\n\t\tconst pos = extractor(_prevMouseEvent);\n\t\tif (_prevMouseEvent instanceof MouseEvent && pos) {\n\t\t\tx.value = pos[0] + window$1.scrollX - _prevScrollX;\n\t\t\ty.value = pos[1] + window$1.scrollY - _prevScrollY;\n\t\t}\n\t};\n\tconst reset = () => {\n\t\tx.value = initialValue.x;\n\t\ty.value = initialValue.y;\n\t};\n\tconst mouseHandlerWrapper = eventFilter ? (event) => eventFilter(() => mouseHandler(event), {}) : (event) => mouseHandler(event);\n\tconst touchHandlerWrapper = eventFilter ? (event) => eventFilter(() => touchHandler(event), {}) : (event) => touchHandler(event);\n\tconst scrollHandlerWrapper = eventFilter ? () => eventFilter(() => scrollHandler(), {}) : () => scrollHandler();\n\tif (target) {\n\t\tconst listenerOptions = { passive: true };\n\t\tuseEventListener(target, [\"mousemove\", \"dragover\"], mouseHandlerWrapper, listenerOptions);\n\t\tif (touch && type !== \"movement\") {\n\t\t\tuseEventListener(target, [\"touchstart\", \"touchmove\"], touchHandlerWrapper, listenerOptions);\n\t\t\tif (resetOnTouchEnds) useEventListener(target, \"touchend\", reset, listenerOptions);\n\t\t}\n\t\tif (scroll && type === \"page\") useEventListener(window$1, \"scroll\", scrollHandlerWrapper, listenerOptions);\n\t}\n\treturn {\n\t\tx,\n\t\ty,\n\t\tsourceType\n\t};\n}\n\n//#endregion\n//#region useMouseInElement/index.ts\n/**\n* Reactive mouse position related to an element.\n*\n* @see https://vueuse.org/useMouseInElement\n* @param target\n* @param options\n*/\nfunction useMouseInElement(target, options = {}) {\n\tconst { windowResize = true, windowScroll = true, handleOutside = true, window: window$1 = defaultWindow } = options;\n\tconst type = options.type || \"page\";\n\tconst { x, y, sourceType } = useMouse(options);\n\tconst targetRef = shallowRef(target !== null && target !== void 0 ? target : window$1 === null || window$1 === void 0 ? void 0 : window$1.document.body);\n\tconst elementX = shallowRef(0);\n\tconst elementY = shallowRef(0);\n\tconst elementPositionX = shallowRef(0);\n\tconst elementPositionY = shallowRef(0);\n\tconst elementHeight = shallowRef(0);\n\tconst elementWidth = shallowRef(0);\n\tconst isOutside = shallowRef(true);\n\tfunction update() {\n\t\tif (!window$1) return;\n\t\tconst el = unrefElement(targetRef);\n\t\tif (!el || !(el instanceof Element)) return;\n\t\tfor (const rect of el.getClientRects()) {\n\t\t\tconst { left, top, width, height } = rect;\n\t\t\telementPositionX.value = left + (type === \"page\" ? window$1.pageXOffset : 0);\n\t\t\telementPositionY.value = top + (type === \"page\" ? window$1.pageYOffset : 0);\n\t\t\telementHeight.value = height;\n\t\t\telementWidth.value = width;\n\t\t\tconst elX = x.value - elementPositionX.value;\n\t\t\tconst elY = y.value - elementPositionY.value;\n\t\t\tisOutside.value = width === 0 || height === 0 || elX < 0 || elY < 0 || elX > width || elY > height;\n\t\t\tif (handleOutside || !isOutside.value) {\n\t\t\t\telementX.value = elX;\n\t\t\t\telementY.value = elY;\n\t\t\t}\n\t\t\tif (!isOutside.value) break;\n\t\t}\n\t}\n\tconst stopFnList = [];\n\tfunction stop() {\n\t\tstopFnList.forEach((fn) => fn());\n\t\tstopFnList.length = 0;\n\t}\n\ttryOnMounted(() => {\n\t\tupdate();\n\t});\n\tif (window$1) {\n\t\tconst { stop: stopResizeObserver } = useResizeObserver(targetRef, update);\n\t\tconst { stop: stopMutationObserver } = useMutationObserver(targetRef, update, { attributeFilter: [\"style\", \"class\"] });\n\t\tconst stopWatch = watch([\n\t\t\ttargetRef,\n\t\t\tx,\n\t\t\ty\n\t\t], update);\n\t\tstopFnList.push(stopResizeObserver, stopMutationObserver, stopWatch);\n\t\tuseEventListener(document, \"mouseleave\", () => isOutside.value = true, { passive: true });\n\t\tif (windowScroll) stopFnList.push(useEventListener(\"scroll\", update, {\n\t\t\tcapture: true,\n\t\t\tpassive: true\n\t\t}));\n\t\tif (windowResize) stopFnList.push(useEventListener(\"resize\", update, { passive: true }));\n\t}\n\treturn {\n\t\tx,\n\t\ty,\n\t\tsourceType,\n\t\telementX,\n\t\telementY,\n\t\telementPositionX,\n\t\telementPositionY,\n\t\telementHeight,\n\t\telementWidth,\n\t\tisOutside,\n\t\tstop\n\t};\n}\n\n//#endregion\n//#region useMousePressed/index.ts\n/**\n* Reactive mouse pressing state.\n*\n* @see https://vueuse.org/useMousePressed\n* @param options\n*/\nfunction useMousePressed(options = {}) {\n\tconst { touch = true, drag = true, capture = false, initialValue = false, window: window$1 = defaultWindow } = options;\n\tconst pressed = shallowRef(initialValue);\n\tconst sourceType = shallowRef(null);\n\tif (!window$1) return {\n\t\tpressed,\n\t\tsourceType\n\t};\n\tconst onPressed = (srcType) => (event) => {\n\t\tvar _options$onPressed;\n\t\tpressed.value = true;\n\t\tsourceType.value = srcType;\n\t\t(_options$onPressed = options.onPressed) === null || _options$onPressed === void 0 || _options$onPressed.call(options, event);\n\t};\n\tconst onReleased = (event) => {\n\t\tvar _options$onReleased;\n\t\tpressed.value = false;\n\t\tsourceType.value = null;\n\t\t(_options$onReleased = options.onReleased) === null || _options$onReleased === void 0 || _options$onReleased.call(options, event);\n\t};\n\tconst target = computed(() => unrefElement(options.target) || window$1);\n\tconst listenerOptions = {\n\t\tpassive: true,\n\t\tcapture\n\t};\n\tuseEventListener(target, \"mousedown\", onPressed(\"mouse\"), listenerOptions);\n\tuseEventListener(window$1, \"mouseleave\", onReleased, listenerOptions);\n\tuseEventListener(window$1, \"mouseup\", onReleased, listenerOptions);\n\tif (drag) {\n\t\tuseEventListener(target, \"dragstart\", onPressed(\"mouse\"), listenerOptions);\n\t\tuseEventListener(window$1, \"drop\", onReleased, listenerOptions);\n\t\tuseEventListener(window$1, \"dragend\", onReleased, listenerOptions);\n\t}\n\tif (touch) {\n\t\tuseEventListener(target, \"touchstart\", onPressed(\"touch\"), listenerOptions);\n\t\tuseEventListener(window$1, \"touchend\", onReleased, listenerOptions);\n\t\tuseEventListener(window$1, \"touchcancel\", onReleased, listenerOptions);\n\t}\n\treturn {\n\t\tpressed,\n\t\tsourceType\n\t};\n}\n\n//#endregion\n//#region useNavigatorLanguage/index.ts\n/**\n*\n* Reactive useNavigatorLanguage\n*\n* Detects the currently selected user language and returns a reactive language\n* @see https://vueuse.org/useNavigatorLanguage\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useNavigatorLanguage(options = {}) {\n\tconst { window: window$1 = defaultWindow } = options;\n\tconst navigator$1 = window$1 === null || window$1 === void 0 ? void 0 : window$1.navigator;\n\tconst isSupported = /* @__PURE__ */ useSupported(() => navigator$1 && \"language\" in navigator$1);\n\tconst language = shallowRef(navigator$1 === null || navigator$1 === void 0 ? void 0 : navigator$1.language);\n\tuseEventListener(window$1, \"languagechange\", () => {\n\t\tif (navigator$1) language.value = navigator$1.language;\n\t}, { passive: true });\n\treturn {\n\t\tisSupported,\n\t\tlanguage\n\t};\n}\n\n//#endregion\n//#region useNetwork/index.ts\n/**\n* Reactive Network status.\n*\n* @see https://vueuse.org/useNetwork\n* @param options\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useNetwork(options = {}) {\n\tconst { window: window$1 = defaultWindow } = options;\n\tconst navigator$1 = window$1 === null || window$1 === void 0 ? void 0 : window$1.navigator;\n\tconst isSupported = /* @__PURE__ */ useSupported(() => navigator$1 && \"connection\" in navigator$1);\n\tconst isOnline = shallowRef(true);\n\tconst saveData = shallowRef(false);\n\tconst offlineAt = shallowRef(void 0);\n\tconst onlineAt = shallowRef(void 0);\n\tconst downlink = shallowRef(void 0);\n\tconst downlinkMax = shallowRef(void 0);\n\tconst rtt = shallowRef(void 0);\n\tconst effectiveType = shallowRef(void 0);\n\tconst type = shallowRef(\"unknown\");\n\tconst connection = isSupported.value && navigator$1.connection;\n\tfunction updateNetworkInformation() {\n\t\tif (!navigator$1) return;\n\t\tisOnline.value = navigator$1.onLine;\n\t\tofflineAt.value = isOnline.value ? void 0 : Date.now();\n\t\tonlineAt.value = isOnline.value ? Date.now() : void 0;\n\t\tif (connection) {\n\t\t\tdownlink.value = connection.downlink;\n\t\t\tdownlinkMax.value = connection.downlinkMax;\n\t\t\teffectiveType.value = connection.effectiveType;\n\t\t\trtt.value = connection.rtt;\n\t\t\tsaveData.value = connection.saveData;\n\t\t\ttype.value = connection.type;\n\t\t}\n\t}\n\tconst listenerOptions = { passive: true };\n\tif (window$1) {\n\t\tuseEventListener(window$1, \"offline\", () => {\n\t\t\tisOnline.value = false;\n\t\t\tofflineAt.value = Date.now();\n\t\t}, listenerOptions);\n\t\tuseEventListener(window$1, \"online\", () => {\n\t\t\tisOnline.value = true;\n\t\t\tonlineAt.value = Date.now();\n\t\t}, listenerOptions);\n\t}\n\tif (connection) useEventListener(connection, \"change\", updateNetworkInformation, listenerOptions);\n\tupdateNetworkInformation();\n\treturn {\n\t\tisSupported,\n\t\tisOnline: readonly(isOnline),\n\t\tsaveData: readonly(saveData),\n\t\tofflineAt: readonly(offlineAt),\n\t\tonlineAt: readonly(onlineAt),\n\t\tdownlink: readonly(downlink),\n\t\tdownlinkMax: readonly(downlinkMax),\n\t\teffectiveType: readonly(effectiveType),\n\t\trtt: readonly(rtt),\n\t\ttype: readonly(type)\n\t};\n}\n\n//#endregion\n//#region useNow/index.ts\nfunction getDefaultScheduler$5(options) {\n\tif (\"interval\" in options || \"immediate\" in options) {\n\t\tconst { interval = \"requestAnimationFrame\", immediate = true } = options;\n\t\treturn interval === \"requestAnimationFrame\" ? (fn) => useRafFn(fn, { immediate }) : (fn) => useIntervalFn(fn, interval, options);\n\t}\n\treturn useRafFn;\n}\n/**\n* Reactive current Date instance.\n*\n* @see https://vueuse.org/useNow\n* @param options\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useNow(options = {}) {\n\tconst { controls: exposeControls = false, scheduler = getDefaultScheduler$5(options) } = options;\n\tconst now = ref(/* @__PURE__ */ new Date());\n\tconst update = () => now.value = /* @__PURE__ */ new Date();\n\tconst controls = scheduler(update);\n\tif (exposeControls) return {\n\t\tnow,\n\t\t...controls\n\t};\n\telse return now;\n}\n\n//#endregion\n//#region useObjectUrl/index.ts\n/**\n* Reactive URL representing an object.\n*\n* @see https://vueuse.org/useObjectUrl\n* @param object\n*/\nfunction useObjectUrl(object) {\n\tconst url = shallowRef();\n\tconst release = () => {\n\t\tif (url.value) URL.revokeObjectURL(url.value);\n\t\turl.value = void 0;\n\t};\n\twatch(() => toValue(object), (newObject) => {\n\t\trelease();\n\t\tif (newObject) url.value = URL.createObjectURL(newObject);\n\t}, { immediate: true });\n\ttryOnScopeDispose(release);\n\treturn readonly(url);\n}\n\n//#endregion\n//#region ../math/useClamp/index.ts\n/**\n* Reactively clamp a value between two other values.\n*\n* @see https://vueuse.org/useClamp\n* @param value number\n* @param min\n* @param max\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useClamp(value, min, max) {\n\tif (typeof value === \"function\" || isReadonly(value)) return computed(() => clamp(toValue(value), toValue(min), toValue(max)));\n\tconst _value = ref(value);\n\treturn computed({\n\t\tget() {\n\t\t\treturn _value.value = clamp(_value.value, toValue(min), toValue(max));\n\t\t},\n\t\tset(value$1) {\n\t\t\t_value.value = clamp(value$1, toValue(min), toValue(max));\n\t\t}\n\t});\n}\n\n//#endregion\n//#region useOffsetPagination/index.ts\nfunction useOffsetPagination(options) {\n\tconst { total = Number.POSITIVE_INFINITY, pageSize = 10, page = 1, onPageChange = noop, onPageSizeChange = noop, onPageCountChange = noop } = options;\n\tconst currentPageSize = useClamp(pageSize, 1, Number.POSITIVE_INFINITY);\n\tconst pageCount = computed(() => Math.max(1, Math.ceil(toValue(total) / toValue(currentPageSize))));\n\tconst currentPage = useClamp(page, 1, pageCount);\n\tconst isFirstPage = computed(() => currentPage.value === 1);\n\tconst isLastPage = computed(() => currentPage.value === pageCount.value);\n\tif (isRef(page)) syncRef(page, currentPage, { direction: isReadonly(page) ? \"ltr\" : \"both\" });\n\tif (isRef(pageSize)) syncRef(pageSize, currentPageSize, { direction: isReadonly(pageSize) ? \"ltr\" : \"both\" });\n\tfunction prev() {\n\t\tcurrentPage.value--;\n\t}\n\tfunction next() {\n\t\tcurrentPage.value++;\n\t}\n\tconst returnValue = {\n\t\tcurrentPage,\n\t\tcurrentPageSize,\n\t\tpageCount,\n\t\tisFirstPage,\n\t\tisLastPage,\n\t\tprev,\n\t\tnext\n\t};\n\twatch(currentPage, () => {\n\t\tonPageChange(reactive(returnValue));\n\t});\n\twatch(currentPageSize, () => {\n\t\tonPageSizeChange(reactive(returnValue));\n\t});\n\twatch(pageCount, () => {\n\t\tonPageCountChange(reactive(returnValue));\n\t});\n\treturn returnValue;\n}\n\n//#endregion\n//#region useOnline/index.ts\n/**\n* Reactive online state.\n*\n* @see https://vueuse.org/useOnline\n* @param options\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useOnline(options = {}) {\n\tconst { isOnline } = useNetwork(options);\n\treturn isOnline;\n}\n\n//#endregion\n//#region usePageLeave/index.ts\n/**\n* Reactive state to show whether mouse leaves the page.\n*\n* @see https://vueuse.org/usePageLeave\n* @param options\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction usePageLeave(options = {}) {\n\tconst { window: window$1 = defaultWindow } = options;\n\tconst isLeft = shallowRef(false);\n\tconst handler = (event) => {\n\t\tif (!window$1) return;\n\t\tevent = event || window$1.event;\n\t\tisLeft.value = !(event.relatedTarget || event.toElement);\n\t};\n\tif (window$1) {\n\t\tconst listenerOptions = { passive: true };\n\t\tuseEventListener(window$1, \"mouseout\", handler, listenerOptions);\n\t\tuseEventListener(window$1.document, \"mouseleave\", handler, listenerOptions);\n\t\tuseEventListener(window$1.document, \"mouseenter\", handler, listenerOptions);\n\t}\n\treturn isLeft;\n}\n\n//#endregion\n//#region useScreenOrientation/index.ts\n/**\n* Reactive screen orientation\n*\n* @see https://vueuse.org/useScreenOrientation\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useScreenOrientation(options = {}) {\n\tconst { window: window$1 = defaultWindow } = options;\n\tconst isSupported = /* @__PURE__ */ useSupported(() => window$1 && \"screen\" in window$1 && \"orientation\" in window$1.screen);\n\tconst screenOrientation = isSupported.value ? window$1.screen.orientation : {};\n\tconst orientation = ref(screenOrientation.type);\n\tconst angle = shallowRef(screenOrientation.angle || 0);\n\tif (isSupported.value) useEventListener(window$1, \"orientationchange\", () => {\n\t\torientation.value = screenOrientation.type;\n\t\tangle.value = screenOrientation.angle;\n\t}, { passive: true });\n\tconst lockOrientation = (type) => {\n\t\tif (isSupported.value && typeof screenOrientation.lock === \"function\") return screenOrientation.lock(type);\n\t\treturn Promise.reject(/* @__PURE__ */ new Error(\"Not supported\"));\n\t};\n\tconst unlockOrientation = () => {\n\t\tif (isSupported.value && typeof screenOrientation.unlock === \"function\") screenOrientation.unlock();\n\t};\n\treturn {\n\t\tisSupported,\n\t\torientation,\n\t\tangle,\n\t\tlockOrientation,\n\t\tunlockOrientation\n\t};\n}\n\n//#endregion\n//#region useParallax/index.ts\n/**\n* Create parallax effect easily. It uses `useDeviceOrientation` and fallback to `useMouse`\n* if orientation is not supported.\n*\n* @param target\n* @param options\n*/\nfunction useParallax(target, options = {}) {\n\tconst { deviceOrientationTiltAdjust = (i) => i, deviceOrientationRollAdjust = (i) => i, mouseTiltAdjust = (i) => i, mouseRollAdjust = (i) => i, window: window$1 = defaultWindow } = options;\n\tconst orientation = reactive(useDeviceOrientation({ window: window$1 }));\n\tconst screenOrientation = reactive(useScreenOrientation({ window: window$1 }));\n\tconst { elementX: x, elementY: y, elementWidth: width, elementHeight: height } = useMouseInElement(target, {\n\t\thandleOutside: false,\n\t\twindow: window$1\n\t});\n\tconst source = computed(() => {\n\t\tif (orientation.isSupported && (orientation.alpha != null && orientation.alpha !== 0 || orientation.gamma != null && orientation.gamma !== 0)) return \"deviceOrientation\";\n\t\treturn \"mouse\";\n\t});\n\treturn {\n\t\troll: computed(() => {\n\t\t\tif (source.value === \"deviceOrientation\") {\n\t\t\t\tlet value;\n\t\t\t\tswitch (screenOrientation.orientation) {\n\t\t\t\t\tcase \"landscape-primary\":\n\t\t\t\t\t\tvalue = orientation.gamma / 90;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase \"landscape-secondary\":\n\t\t\t\t\t\tvalue = -orientation.gamma / 90;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase \"portrait-primary\":\n\t\t\t\t\t\tvalue = -orientation.beta / 90;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase \"portrait-secondary\":\n\t\t\t\t\t\tvalue = orientation.beta / 90;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tdefault: value = -orientation.beta / 90;\n\t\t\t\t}\n\t\t\t\treturn deviceOrientationRollAdjust(value);\n\t\t\t} else return mouseRollAdjust(-(y.value - height.value / 2) / height.value);\n\t\t}),\n\t\ttilt: computed(() => {\n\t\t\tif (source.value === \"deviceOrientation\") {\n\t\t\t\tlet value;\n\t\t\t\tswitch (screenOrientation.orientation) {\n\t\t\t\t\tcase \"landscape-primary\":\n\t\t\t\t\t\tvalue = orientation.beta / 90;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase \"landscape-secondary\":\n\t\t\t\t\t\tvalue = -orientation.beta / 90;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase \"portrait-primary\":\n\t\t\t\t\t\tvalue = orientation.gamma / 90;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tcase \"portrait-secondary\":\n\t\t\t\t\t\tvalue = -orientation.gamma / 90;\n\t\t\t\t\t\tbreak;\n\t\t\t\t\tdefault: value = orientation.gamma / 90;\n\t\t\t\t}\n\t\t\t\treturn deviceOrientationTiltAdjust(value);\n\t\t\t} else return mouseTiltAdjust((x.value - width.value / 2) / width.value);\n\t\t}),\n\t\tsource\n\t};\n}\n\n//#endregion\n//#region useParentElement/index.ts\nfunction useParentElement(element = useCurrentElement()) {\n\tconst parentElement = shallowRef();\n\tconst update = () => {\n\t\tconst el = unrefElement(element);\n\t\tif (el) parentElement.value = el.parentElement;\n\t};\n\ttryOnMounted(update);\n\twatch(() => toValue(element), update);\n\treturn parentElement;\n}\n\n//#endregion\n//#region usePerformanceObserver/index.ts\n/**\n* Observe performance metrics.\n*\n* @see https://vueuse.org/usePerformanceObserver\n* @param options\n*/\nfunction usePerformanceObserver(options, callback) {\n\tconst { window: window$1 = defaultWindow, immediate = true,...performanceOptions } = options;\n\tconst isSupported = /* @__PURE__ */ useSupported(() => window$1 && \"PerformanceObserver\" in window$1);\n\tlet observer;\n\tconst stop = () => {\n\t\tobserver === null || observer === void 0 || observer.disconnect();\n\t};\n\tconst start = () => {\n\t\tif (isSupported.value) {\n\t\t\tstop();\n\t\t\tobserver = new PerformanceObserver(callback);\n\t\t\tobserver.observe(performanceOptions);\n\t\t}\n\t};\n\ttryOnScopeDispose(stop);\n\tif (immediate) start();\n\treturn {\n\t\tisSupported,\n\t\tstart,\n\t\tstop\n\t};\n}\n\n//#endregion\n//#region usePointer/index.ts\nconst defaultState = {\n\tx: 0,\n\ty: 0,\n\tpointerId: 0,\n\tpressure: 0,\n\ttiltX: 0,\n\ttiltY: 0,\n\twidth: 0,\n\theight: 0,\n\ttwist: 0,\n\tpointerType: null\n};\nconst keys = /* @__PURE__ */ Object.keys(defaultState);\n/**\n* Reactive pointer state.\n*\n* @see https://vueuse.org/usePointer\n* @param options\n*/\nfunction usePointer(options = {}) {\n\tconst { target = defaultWindow } = options;\n\tconst isInside = shallowRef(false);\n\tconst state = shallowRef(options.initialValue || {});\n\tObject.assign(state.value, defaultState, state.value);\n\tconst handler = (event) => {\n\t\tisInside.value = true;\n\t\tif (options.pointerTypes && !options.pointerTypes.includes(event.pointerType)) return;\n\t\tstate.value = objectPick(event, keys, false);\n\t};\n\tif (target) {\n\t\tconst listenerOptions = { passive: true };\n\t\tuseEventListener(target, [\n\t\t\t\"pointerdown\",\n\t\t\t\"pointermove\",\n\t\t\t\"pointerup\"\n\t\t], handler, listenerOptions);\n\t\tuseEventListener(target, \"pointerleave\", () => isInside.value = false, listenerOptions);\n\t}\n\treturn {\n\t\t...toRefs(state),\n\t\tisInside\n\t};\n}\n\n//#endregion\n//#region usePointerLock/index.ts\n/**\n* Reactive pointer lock.\n*\n* @see https://vueuse.org/usePointerLock\n* @param target\n* @param options\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction usePointerLock(target, options = {}) {\n\tconst { document: document$1 = defaultDocument } = options;\n\tconst isSupported = /* @__PURE__ */ useSupported(() => document$1 && \"pointerLockElement\" in document$1);\n\tconst element = shallowRef();\n\tconst triggerElement = shallowRef();\n\tlet targetElement;\n\tif (isSupported.value) {\n\t\tconst listenerOptions = { passive: true };\n\t\tuseEventListener(document$1, \"pointerlockchange\", () => {\n\t\t\tvar _pointerLockElement;\n\t\t\tconst currentElement = (_pointerLockElement = document$1.pointerLockElement) !== null && _pointerLockElement !== void 0 ? _pointerLockElement : element.value;\n\t\t\tif (targetElement && currentElement === targetElement) {\n\t\t\t\telement.value = document$1.pointerLockElement;\n\t\t\t\tif (!element.value) targetElement = triggerElement.value = null;\n\t\t\t}\n\t\t}, listenerOptions);\n\t\tuseEventListener(document$1, \"pointerlockerror\", () => {\n\t\t\tvar _pointerLockElement2;\n\t\t\tconst currentElement = (_pointerLockElement2 = document$1.pointerLockElement) !== null && _pointerLockElement2 !== void 0 ? _pointerLockElement2 : element.value;\n\t\t\tif (targetElement && currentElement === targetElement) {\n\t\t\t\tconst action = document$1.pointerLockElement ? \"release\" : \"acquire\";\n\t\t\t\tthrow new Error(`Failed to ${action} pointer lock.`);\n\t\t\t}\n\t\t}, listenerOptions);\n\t}\n\tasync function lock(e) {\n\t\tvar _unrefElement;\n\t\tif (!isSupported.value) throw new Error(\"Pointer Lock API is not supported by your browser.\");\n\t\ttriggerElement.value = e instanceof Event ? e.currentTarget : null;\n\t\ttargetElement = e instanceof Event ? (_unrefElement = unrefElement(target)) !== null && _unrefElement !== void 0 ? _unrefElement : triggerElement.value : unrefElement(e);\n\t\tif (!targetElement) throw new Error(\"Target element undefined.\");\n\t\ttargetElement.requestPointerLock();\n\t\treturn await until(element).toBe(targetElement);\n\t}\n\tasync function unlock() {\n\t\tif (!element.value) return false;\n\t\tdocument$1.exitPointerLock();\n\t\tawait until(element).toBeNull();\n\t\treturn true;\n\t}\n\treturn {\n\t\tisSupported,\n\t\telement,\n\t\ttriggerElement,\n\t\tlock,\n\t\tunlock\n\t};\n}\n\n//#endregion\n//#region usePointerSwipe/index.ts\n/**\n* Reactive swipe detection based on PointerEvents.\n*\n* @see https://vueuse.org/usePointerSwipe\n* @param target\n* @param options\n*/\nfunction usePointerSwipe(target, options = {}) {\n\tconst targetRef = toRef(target);\n\tconst { threshold = 50, onSwipe, onSwipeEnd, onSwipeStart, disableTextSelect = false } = options;\n\tconst posStart = reactive({\n\t\tx: 0,\n\t\ty: 0\n\t});\n\tconst updatePosStart = (x, y) => {\n\t\tposStart.x = x;\n\t\tposStart.y = y;\n\t};\n\tconst posEnd = reactive({\n\t\tx: 0,\n\t\ty: 0\n\t});\n\tconst updatePosEnd = (x, y) => {\n\t\tposEnd.x = x;\n\t\tposEnd.y = y;\n\t};\n\tconst distanceX = computed(() => posStart.x - posEnd.x);\n\tconst distanceY = computed(() => posStart.y - posEnd.y);\n\tconst { max, abs } = Math;\n\tconst isThresholdExceeded = computed(() => max(abs(distanceX.value), abs(distanceY.value)) >= threshold);\n\tconst isSwiping = shallowRef(false);\n\tconst isPointerDown = shallowRef(false);\n\tconst direction = computed(() => {\n\t\tif (!isThresholdExceeded.value) return \"none\";\n\t\tif (abs(distanceX.value) > abs(distanceY.value)) return distanceX.value > 0 ? \"left\" : \"right\";\n\t\telse return distanceY.value > 0 ? \"up\" : \"down\";\n\t});\n\tconst eventIsAllowed = (e) => {\n\t\tvar _ref, _options$pointerTypes, _options$pointerTypes2;\n\t\tconst isReleasingButton = e.buttons === 0;\n\t\tconst isPrimaryButton = e.buttons === 1;\n\t\treturn (_ref = (_options$pointerTypes = (_options$pointerTypes2 = options.pointerTypes) === null || _options$pointerTypes2 === void 0 ? void 0 : _options$pointerTypes2.includes(e.pointerType)) !== null && _options$pointerTypes !== void 0 ? _options$pointerTypes : isReleasingButton || isPrimaryButton) !== null && _ref !== void 0 ? _ref : true;\n\t};\n\tconst listenerOptions = { passive: true };\n\tconst stops = [\n\t\tuseEventListener(target, \"pointerdown\", (e) => {\n\t\t\tif (!eventIsAllowed(e)) return;\n\t\t\tisPointerDown.value = true;\n\t\t\tconst eventTarget = e.target;\n\t\t\teventTarget === null || eventTarget === void 0 || eventTarget.setPointerCapture(e.pointerId);\n\t\t\tconst { clientX: x, clientY: y } = e;\n\t\t\tupdatePosStart(x, y);\n\t\t\tupdatePosEnd(x, y);\n\t\t\tonSwipeStart === null || onSwipeStart === void 0 || onSwipeStart(e);\n\t\t}, listenerOptions),\n\t\tuseEventListener(target, \"pointermove\", (e) => {\n\t\t\tif (!eventIsAllowed(e)) return;\n\t\t\tif (!isPointerDown.value) return;\n\t\t\tconst { clientX: x, clientY: y } = e;\n\t\t\tupdatePosEnd(x, y);\n\t\t\tif (!isSwiping.value && isThresholdExceeded.value) isSwiping.value = true;\n\t\t\tif (isSwiping.value) onSwipe === null || onSwipe === void 0 || onSwipe(e);\n\t\t}, listenerOptions),\n\t\tuseEventListener(target, \"pointerup\", (e) => {\n\t\t\tif (!eventIsAllowed(e)) return;\n\t\t\tif (isSwiping.value) onSwipeEnd === null || onSwipeEnd === void 0 || onSwipeEnd(e, direction.value);\n\t\t\tisPointerDown.value = false;\n\t\t\tisSwiping.value = false;\n\t\t}, listenerOptions)\n\t];\n\ttryOnMounted(() => {\n\t\tvar _targetRef$value;\n\t\t(_targetRef$value = targetRef.value) === null || _targetRef$value === void 0 || (_targetRef$value = _targetRef$value.style) === null || _targetRef$value === void 0 || _targetRef$value.setProperty(\"touch-action\", \"pan-y\");\n\t\tif (disableTextSelect) {\n\t\t\tvar _targetRef$value2, _targetRef$value3, _targetRef$value4;\n\t\t\t(_targetRef$value2 = targetRef.value) === null || _targetRef$value2 === void 0 || (_targetRef$value2 = _targetRef$value2.style) === null || _targetRef$value2 === void 0 || _targetRef$value2.setProperty(\"-webkit-user-select\", \"none\");\n\t\t\t(_targetRef$value3 = targetRef.value) === null || _targetRef$value3 === void 0 || (_targetRef$value3 = _targetRef$value3.style) === null || _targetRef$value3 === void 0 || _targetRef$value3.setProperty(\"-ms-user-select\", \"none\");\n\t\t\t(_targetRef$value4 = targetRef.value) === null || _targetRef$value4 === void 0 || (_targetRef$value4 = _targetRef$value4.style) === null || _targetRef$value4 === void 0 || _targetRef$value4.setProperty(\"user-select\", \"none\");\n\t\t}\n\t});\n\tconst stop = () => stops.forEach((s) => s());\n\treturn {\n\t\tisSwiping: readonly(isSwiping),\n\t\tdirection: readonly(direction),\n\t\tposStart: readonly(posStart),\n\t\tposEnd: readonly(posEnd),\n\t\tdistanceX,\n\t\tdistanceY,\n\t\tstop\n\t};\n}\n\n//#endregion\n//#region usePreferredColorScheme/index.ts\n/**\n* Reactive prefers-color-scheme media query.\n*\n* @see https://vueuse.org/usePreferredColorScheme\n* @param [options]\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction usePreferredColorScheme(options) {\n\tconst isLight = useMediaQuery(\"(prefers-color-scheme: light)\", options);\n\tconst isDark = useMediaQuery(\"(prefers-color-scheme: dark)\", options);\n\treturn computed(() => {\n\t\tif (isDark.value) return \"dark\";\n\t\tif (isLight.value) return \"light\";\n\t\treturn \"no-preference\";\n\t});\n}\n\n//#endregion\n//#region usePreferredContrast/index.ts\n/**\n* Reactive prefers-contrast media query.\n*\n* @see https://vueuse.org/usePreferredContrast\n* @param [options]\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction usePreferredContrast(options) {\n\tconst isMore = useMediaQuery(\"(prefers-contrast: more)\", options);\n\tconst isLess = useMediaQuery(\"(prefers-contrast: less)\", options);\n\tconst isCustom = useMediaQuery(\"(prefers-contrast: custom)\", options);\n\treturn computed(() => {\n\t\tif (isMore.value) return \"more\";\n\t\tif (isLess.value) return \"less\";\n\t\tif (isCustom.value) return \"custom\";\n\t\treturn \"no-preference\";\n\t});\n}\n\n//#endregion\n//#region usePreferredLanguages/index.ts\n/**\n* Reactive Navigator Languages.\n*\n* @see https://vueuse.org/usePreferredLanguages\n* @param options\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction usePreferredLanguages(options = {}) {\n\tconst { window: window$1 = defaultWindow } = options;\n\tif (!window$1) return shallowRef([\"en\"]);\n\tconst navigator$1 = window$1.navigator;\n\tconst value = shallowRef(navigator$1.languages);\n\tuseEventListener(window$1, \"languagechange\", () => {\n\t\tvalue.value = navigator$1.languages;\n\t}, { passive: true });\n\treturn value;\n}\n\n//#endregion\n//#region usePreferredReducedMotion/index.ts\n/**\n* Reactive prefers-reduced-motion media query.\n*\n* @see https://vueuse.org/usePreferredReducedMotion\n* @param [options]\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction usePreferredReducedMotion(options) {\n\tconst isReduced = useMediaQuery(\"(prefers-reduced-motion: reduce)\", options);\n\treturn computed(() => {\n\t\tif (isReduced.value) return \"reduce\";\n\t\treturn \"no-preference\";\n\t});\n}\n\n//#endregion\n//#region usePreferredReducedTransparency/index.ts\n/**\n* Reactive prefers-reduced-transparency media query.\n*\n* @see https://vueuse.org/usePreferredReducedTransparency\n* @param [options]\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction usePreferredReducedTransparency(options) {\n\tconst isReduced = useMediaQuery(\"(prefers-reduced-transparency: reduce)\", options);\n\treturn computed(() => {\n\t\tif (isReduced.value) return \"reduce\";\n\t\treturn \"no-preference\";\n\t});\n}\n\n//#endregion\n//#region usePrevious/index.ts\nfunction usePrevious(value, initialValue) {\n\tconst previous = shallowRef(initialValue);\n\twatch(toRef(value), (_, oldValue) => {\n\t\tprevious.value = oldValue;\n\t}, { flush: \"sync\" });\n\treturn readonly(previous);\n}\n\n//#endregion\n//#region useScreenSafeArea/index.ts\nconst topVarName = \"--vueuse-safe-area-top\";\nconst rightVarName = \"--vueuse-safe-area-right\";\nconst bottomVarName = \"--vueuse-safe-area-bottom\";\nconst leftVarName = \"--vueuse-safe-area-left\";\n/**\n* Reactive `env(safe-area-inset-*)`\n*\n* @see https://vueuse.org/useScreenSafeArea\n*/\nfunction useScreenSafeArea() {\n\tconst top = shallowRef(\"\");\n\tconst right = shallowRef(\"\");\n\tconst bottom = shallowRef(\"\");\n\tconst left = shallowRef(\"\");\n\tif (isClient) {\n\t\tconst topCssVar = useCssVar(topVarName);\n\t\tconst rightCssVar = useCssVar(rightVarName);\n\t\tconst bottomCssVar = useCssVar(bottomVarName);\n\t\tconst leftCssVar = useCssVar(leftVarName);\n\t\ttopCssVar.value = \"env(safe-area-inset-top, 0px)\";\n\t\trightCssVar.value = \"env(safe-area-inset-right, 0px)\";\n\t\tbottomCssVar.value = \"env(safe-area-inset-bottom, 0px)\";\n\t\tleftCssVar.value = \"env(safe-area-inset-left, 0px)\";\n\t\ttryOnMounted(update);\n\t\tuseEventListener(\"resize\", useDebounceFn(update), { passive: true });\n\t}\n\tfunction update() {\n\t\ttop.value = getValue(topVarName);\n\t\tright.value = getValue(rightVarName);\n\t\tbottom.value = getValue(bottomVarName);\n\t\tleft.value = getValue(leftVarName);\n\t}\n\treturn {\n\t\ttop,\n\t\tright,\n\t\tbottom,\n\t\tleft,\n\t\tupdate\n\t};\n}\nfunction getValue(position) {\n\treturn getComputedStyle(document.documentElement).getPropertyValue(position);\n}\n\n//#endregion\n//#region useScriptTag/index.ts\n/**\n* Async script tag loading.\n*\n* @see https://vueuse.org/useScriptTag\n* @param src\n* @param onLoaded\n* @param options\n*/\nfunction useScriptTag(src, onLoaded = noop, options = {}) {\n\tconst { immediate = true, manual = false, type = \"text/javascript\", async = true, crossOrigin, referrerPolicy, noModule, defer, document: document$1 = defaultDocument, attrs = {}, nonce = void 0 } = options;\n\tconst scriptTag = shallowRef(null);\n\tlet _promise = null;\n\t/**\n\t* Load the script specified via `src`.\n\t*\n\t* @param waitForScriptLoad Whether if the Promise should resolve once the \"load\" event is emitted by the <script> attribute, or right after appending it to the DOM.\n\t* @returns Promise<HTMLScriptElement>\n\t*/\n\tconst loadScript = (waitForScriptLoad) => new Promise((resolve, reject) => {\n\t\tconst resolveWithElement = (el$1) => {\n\t\t\tscriptTag.value = el$1;\n\t\t\tresolve(el$1);\n\t\t\treturn el$1;\n\t\t};\n\t\tif (!document$1) {\n\t\t\tresolve(false);\n\t\t\treturn;\n\t\t}\n\t\tlet shouldAppend = false;\n\t\tlet el = document$1.querySelector(`script[src=\"${toValue(src)}\"]`);\n\t\tif (!el) {\n\t\t\tel = document$1.createElement(\"script\");\n\t\t\tel.type = type;\n\t\t\tel.async = async;\n\t\t\tel.src = toValue(src);\n\t\t\tif (defer) el.defer = defer;\n\t\t\tif (crossOrigin) el.crossOrigin = crossOrigin;\n\t\t\tif (noModule) el.noModule = noModule;\n\t\t\tif (referrerPolicy) el.referrerPolicy = referrerPolicy;\n\t\t\tif (nonce) el.nonce = nonce;\n\t\t\tObject.entries(attrs).forEach(([name, value]) => el === null || el === void 0 ? void 0 : el.setAttribute(name, value));\n\t\t\tshouldAppend = true;\n\t\t} else if (el.hasAttribute(\"data-loaded\")) resolveWithElement(el);\n\t\tconst listenerOptions = { passive: true };\n\t\tuseEventListener(el, \"error\", (event) => reject(event), listenerOptions);\n\t\tuseEventListener(el, \"abort\", (event) => reject(event), listenerOptions);\n\t\tuseEventListener(el, \"load\", () => {\n\t\t\tel.setAttribute(\"data-loaded\", \"true\");\n\t\t\tonLoaded(el);\n\t\t\tresolveWithElement(el);\n\t\t}, listenerOptions);\n\t\tif (shouldAppend) el = document$1.head.appendChild(el);\n\t\tif (!waitForScriptLoad) resolveWithElement(el);\n\t});\n\t/**\n\t* Exposed singleton wrapper for `loadScript`, avoiding calling it twice.\n\t*\n\t* @param waitForScriptLoad Whether if the Promise should resolve once the \"load\" event is emitted by the <script> attribute, or right after appending it to the DOM.\n\t* @returns Promise<HTMLScriptElement>\n\t*/\n\tconst load = (waitForScriptLoad = true) => {\n\t\tif (!_promise) _promise = loadScript(waitForScriptLoad);\n\t\treturn _promise;\n\t};\n\t/**\n\t* Unload the script specified by `src`.\n\t*/\n\tconst unload = () => {\n\t\tif (!document$1) return;\n\t\t_promise = null;\n\t\tif (scriptTag.value) scriptTag.value = null;\n\t\tconst el = document$1.querySelector(`script[src=\"${toValue(src)}\"]`);\n\t\tif (el) document$1.head.removeChild(el);\n\t};\n\tif (immediate && !manual) tryOnMounted(load);\n\tif (!manual) tryOnUnmounted(unload);\n\treturn {\n\t\tscriptTag,\n\t\tload,\n\t\tunload\n\t};\n}\n\n//#endregion\n//#region useScrollLock/index.ts\nfunction checkOverflowScroll(ele) {\n\tconst style = window.getComputedStyle(ele);\n\tif (style.overflowX === \"scroll\" || style.overflowY === \"scroll\" || style.overflowX === \"auto\" && ele.clientWidth < ele.scrollWidth || style.overflowY === \"auto\" && ele.clientHeight < ele.scrollHeight) return true;\n\telse {\n\t\tconst parent = ele.parentNode;\n\t\tif (!parent || parent.tagName === \"BODY\") return false;\n\t\treturn checkOverflowScroll(parent);\n\t}\n}\nfunction preventDefault(rawEvent) {\n\tconst e = rawEvent || window.event;\n\tconst _target = e.target;\n\tif (checkOverflowScroll(_target)) return false;\n\tif (e.touches.length > 1) return true;\n\tif (e.preventDefault) e.preventDefault();\n\treturn false;\n}\nconst elInitialOverflow = /* @__PURE__ */ new WeakMap();\n/**\n* Lock scrolling of the element.\n*\n* @see https://vueuse.org/useScrollLock\n* @param element\n*/\nfunction useScrollLock(element, initialState = false) {\n\tconst isLocked = shallowRef(initialState);\n\tlet stopTouchMoveListener = null;\n\tlet initialOverflow = \"\";\n\twatch(toRef(element), (el) => {\n\t\tconst target = resolveElement(toValue(el));\n\t\tif (target) {\n\t\t\tconst ele = target;\n\t\t\tif (!elInitialOverflow.get(ele)) elInitialOverflow.set(ele, ele.style.overflow);\n\t\t\tif (ele.style.overflow !== \"hidden\") initialOverflow = ele.style.overflow;\n\t\t\tif (ele.style.overflow === \"hidden\") return isLocked.value = true;\n\t\t\tif (isLocked.value) return ele.style.overflow = \"hidden\";\n\t\t}\n\t}, { immediate: true });\n\tconst lock = () => {\n\t\tconst el = resolveElement(toValue(element));\n\t\tif (!el || isLocked.value) return;\n\t\tif (isIOS) stopTouchMoveListener = useEventListener(el, \"touchmove\", (e) => {\n\t\t\tpreventDefault(e);\n\t\t}, { passive: false });\n\t\tel.style.overflow = \"hidden\";\n\t\tisLocked.value = true;\n\t};\n\tconst unlock = () => {\n\t\tconst el = resolveElement(toValue(element));\n\t\tif (!el || !isLocked.value) return;\n\t\tif (isIOS) stopTouchMoveListener === null || stopTouchMoveListener === void 0 || stopTouchMoveListener();\n\t\tel.style.overflow = initialOverflow;\n\t\telInitialOverflow.delete(el);\n\t\tisLocked.value = false;\n\t};\n\ttryOnScopeDispose(unlock);\n\treturn computed({\n\t\tget() {\n\t\t\treturn isLocked.value;\n\t\t},\n\t\tset(v) {\n\t\t\tif (v) lock();\n\t\t\telse unlock();\n\t\t}\n\t});\n}\n\n//#endregion\n//#region useSessionStorage/index.ts\n/**\n* Reactive SessionStorage.\n*\n* @see https://vueuse.org/useSessionStorage\n* @param key\n* @param initialValue\n* @param options\n*/\nfunction useSessionStorage(key, initialValue, options = {}) {\n\tconst { window: window$1 = defaultWindow } = options;\n\treturn useStorage(key, initialValue, window$1 === null || window$1 === void 0 ? void 0 : window$1.sessionStorage, options);\n}\n\n//#endregion\n//#region useShare/index.ts\n/**\n* Reactive Web Share API.\n*\n* @see https://vueuse.org/useShare\n* @param shareOptions\n* @param options\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useShare(shareOptions = {}, options = {}) {\n\tconst { navigator: navigator$1 = defaultNavigator } = options;\n\tconst _navigator = navigator$1;\n\tconst isSupported = /* @__PURE__ */ useSupported(() => _navigator && \"canShare\" in _navigator);\n\tconst share = async (overrideOptions = {}) => {\n\t\tif (isSupported.value) {\n\t\t\tconst data = {\n\t\t\t\t...toValue(shareOptions),\n\t\t\t\t...toValue(overrideOptions)\n\t\t\t};\n\t\t\tlet granted = false;\n\t\t\tif (_navigator.canShare) granted = _navigator.canShare(data);\n\t\t\tif (granted) return _navigator.share(data);\n\t\t}\n\t};\n\treturn {\n\t\tisSupported,\n\t\tshare\n\t};\n}\n\n//#endregion\n//#region useSorted/index.ts\nconst defaultSortFn = (source, compareFn) => source.sort(compareFn);\nconst defaultCompare = (a, b) => a - b;\nfunction useSorted(...args) {\n\tconst [source] = args;\n\tlet compareFn = defaultCompare;\n\tlet options = {};\n\tif (args.length === 2) if (typeof args[1] === \"object\") {\n\t\tvar _options$compareFn;\n\t\toptions = args[1];\n\t\tcompareFn = (_options$compareFn = options.compareFn) !== null && _options$compareFn !== void 0 ? _options$compareFn : defaultCompare;\n\t} else {\n\t\tvar _args$;\n\t\tcompareFn = (_args$ = args[1]) !== null && _args$ !== void 0 ? _args$ : defaultCompare;\n\t}\n\telse if (args.length > 2) {\n\t\tvar _args$2, _args$3;\n\t\tcompareFn = (_args$2 = args[1]) !== null && _args$2 !== void 0 ? _args$2 : defaultCompare;\n\t\toptions = (_args$3 = args[2]) !== null && _args$3 !== void 0 ? _args$3 : {};\n\t}\n\tconst { dirty = false, sortFn = defaultSortFn } = options;\n\tif (!dirty) return computed(() => sortFn([...toValue(source)], compareFn));\n\twatchEffect(() => {\n\t\tconst result = sortFn(toValue(source), compareFn);\n\t\tif (isRef(source)) source.value = result;\n\t\telse source.splice(0, source.length, ...result);\n\t});\n\treturn source;\n}\n\n//#endregion\n//#region useSpeechRecognition/index.ts\n/**\n* Reactive SpeechRecognition.\n*\n* @see https://vueuse.org/useSpeechRecognition\n* @see https://developer.mozilla.org/en-US/docs/Web/API/SpeechRecognition SpeechRecognition\n* @param options\n*/\nfunction useSpeechRecognition(options = {}) {\n\tconst { interimResults = true, continuous = true, maxAlternatives = 1, window: window$1 = defaultWindow } = options;\n\tconst lang = toRef(options.lang || \"en-US\");\n\tconst isListening = shallowRef(false);\n\tconst isFinal = shallowRef(false);\n\tconst result = shallowRef(\"\");\n\tconst error = shallowRef(void 0);\n\tlet recognition;\n\tconst start = () => {\n\t\tisListening.value = true;\n\t};\n\tconst stop = () => {\n\t\tisListening.value = false;\n\t};\n\tconst toggle = (value = !isListening.value) => {\n\t\tif (value) start();\n\t\telse stop();\n\t};\n\tconst SpeechRecognition = window$1 && (window$1.SpeechRecognition || window$1.webkitSpeechRecognition);\n\tconst isSupported = /* @__PURE__ */ useSupported(() => SpeechRecognition);\n\tif (isSupported.value) {\n\t\trecognition = new SpeechRecognition();\n\t\trecognition.continuous = continuous;\n\t\trecognition.interimResults = interimResults;\n\t\trecognition.lang = toValue(lang);\n\t\trecognition.maxAlternatives = maxAlternatives;\n\t\trecognition.onstart = () => {\n\t\t\tisListening.value = true;\n\t\t\tisFinal.value = false;\n\t\t};\n\t\twatch(lang, (lang$1) => {\n\t\t\tif (recognition && !isListening.value) recognition.lang = lang$1;\n\t\t});\n\t\trecognition.onresult = (event) => {\n\t\t\tconst currentResult = event.results[event.resultIndex];\n\t\t\tconst { transcript } = currentResult[0];\n\t\t\tisFinal.value = currentResult.isFinal;\n\t\t\tresult.value = transcript;\n\t\t\terror.value = void 0;\n\t\t};\n\t\trecognition.onerror = (event) => {\n\t\t\terror.value = event;\n\t\t};\n\t\trecognition.onend = () => {\n\t\t\tisListening.value = false;\n\t\t\trecognition.lang = toValue(lang);\n\t\t};\n\t\twatch(isListening, (newValue, oldValue) => {\n\t\t\tif (newValue === oldValue) return;\n\t\t\ttry {\n\t\t\t\tif (newValue) recognition.start();\n\t\t\t\telse recognition.stop();\n\t\t\t} catch (err) {\n\t\t\t\terror.value = err;\n\t\t\t}\n\t\t});\n\t}\n\ttryOnScopeDispose(() => {\n\t\tstop();\n\t});\n\treturn {\n\t\tisSupported,\n\t\tisListening,\n\t\tisFinal,\n\t\trecognition,\n\t\tresult,\n\t\terror,\n\t\ttoggle,\n\t\tstart,\n\t\tstop\n\t};\n}\n\n//#endregion\n//#region useSpeechSynthesis/index.ts\n/**\n* Reactive SpeechSynthesis.\n*\n* @see https://vueuse.org/useSpeechSynthesis\n* @see https://developer.mozilla.org/en-US/docs/Web/API/SpeechSynthesis SpeechSynthesis\n*/\nfunction useSpeechSynthesis(text, options = {}) {\n\tconst { pitch = 1, rate = 1, volume = 1, window: window$1 = defaultWindow, onBoundary } = options;\n\tconst synth = window$1 && window$1.speechSynthesis;\n\tconst isSupported = /* @__PURE__ */ useSupported(() => synth);\n\tconst isPlaying = shallowRef(false);\n\tconst status = shallowRef(\"init\");\n\tconst spokenText = toRef(text || \"\");\n\tconst lang = toRef(options.lang || \"en-US\");\n\tconst error = shallowRef(void 0);\n\tconst toggle = (value = !isPlaying.value) => {\n\t\tisPlaying.value = value;\n\t};\n\tconst bindEventsForUtterance = (utterance$1) => {\n\t\tutterance$1.lang = toValue(lang);\n\t\tutterance$1.voice = toValue(options.voice) || null;\n\t\tutterance$1.pitch = toValue(pitch);\n\t\tutterance$1.rate = toValue(rate);\n\t\tutterance$1.volume = toValue(volume);\n\t\tutterance$1.onstart = () => {\n\t\t\tisPlaying.value = true;\n\t\t\tstatus.value = \"play\";\n\t\t};\n\t\tutterance$1.onpause = () => {\n\t\t\tisPlaying.value = false;\n\t\t\tstatus.value = \"pause\";\n\t\t};\n\t\tutterance$1.onresume = () => {\n\t\t\tisPlaying.value = true;\n\t\t\tstatus.value = \"play\";\n\t\t};\n\t\tutterance$1.onend = () => {\n\t\t\tisPlaying.value = false;\n\t\t\tstatus.value = \"end\";\n\t\t};\n\t\tutterance$1.onerror = (event) => {\n\t\t\terror.value = event;\n\t\t};\n\t\tutterance$1.onboundary = (event) => {\n\t\t\tonBoundary === null || onBoundary === void 0 || onBoundary(event);\n\t\t};\n\t};\n\tconst utterance = computed(() => {\n\t\tisPlaying.value = false;\n\t\tstatus.value = \"init\";\n\t\tconst newUtterance = new SpeechSynthesisUtterance(spokenText.value);\n\t\tbindEventsForUtterance(newUtterance);\n\t\treturn newUtterance;\n\t});\n\tconst speak = () => {\n\t\tsynth.cancel();\n\t\tif (utterance) synth.speak(utterance.value);\n\t};\n\tconst stop = () => {\n\t\tsynth.cancel();\n\t\tisPlaying.value = false;\n\t};\n\tif (isSupported.value) {\n\t\tbindEventsForUtterance(utterance.value);\n\t\twatch(lang, (lang$1) => {\n\t\t\tif (utterance.value && !isPlaying.value) utterance.value.lang = lang$1;\n\t\t});\n\t\tif (options.voice) watch(options.voice, () => {\n\t\t\tsynth.cancel();\n\t\t});\n\t\twatch(isPlaying, () => {\n\t\t\tif (isPlaying.value) synth.resume();\n\t\t\telse synth.pause();\n\t\t});\n\t}\n\ttryOnScopeDispose(() => {\n\t\tisPlaying.value = false;\n\t});\n\treturn {\n\t\tisSupported,\n\t\tisPlaying,\n\t\tstatus,\n\t\tutterance,\n\t\terror,\n\t\tstop,\n\t\ttoggle,\n\t\tspeak\n\t};\n}\n\n//#endregion\n//#region useStepper/index.ts\n/* @__NO_SIDE_EFFECTS__ */\nfunction useStepper(steps, initialStep) {\n\tconst stepsRef = ref(steps);\n\tconst stepNames = computed(() => Array.isArray(stepsRef.value) ? stepsRef.value : Object.keys(stepsRef.value));\n\tconst index = ref(stepNames.value.indexOf(initialStep !== null && initialStep !== void 0 ? initialStep : stepNames.value[0]));\n\tconst current = computed(() => at(index.value));\n\tconst isFirst = computed(() => index.value === 0);\n\tconst isLast = computed(() => index.value === stepNames.value.length - 1);\n\tconst next = computed(() => stepNames.value[index.value + 1]);\n\tconst previous = computed(() => stepNames.value[index.value - 1]);\n\tfunction at(index$1) {\n\t\tif (Array.isArray(stepsRef.value)) return stepsRef.value[index$1];\n\t\treturn stepsRef.value[stepNames.value[index$1]];\n\t}\n\tfunction get(step) {\n\t\tif (!stepNames.value.includes(step)) return;\n\t\treturn at(stepNames.value.indexOf(step));\n\t}\n\tfunction goTo(step) {\n\t\tif (stepNames.value.includes(step)) index.value = stepNames.value.indexOf(step);\n\t}\n\tfunction goToNext() {\n\t\tif (isLast.value) return;\n\t\tindex.value++;\n\t}\n\tfunction goToPrevious() {\n\t\tif (isFirst.value) return;\n\t\tindex.value--;\n\t}\n\tfunction goBackTo(step) {\n\t\tif (isAfter(step)) goTo(step);\n\t}\n\tfunction isNext(step) {\n\t\treturn stepNames.value.indexOf(step) === index.value + 1;\n\t}\n\tfunction isPrevious(step) {\n\t\treturn stepNames.value.indexOf(step) === index.value - 1;\n\t}\n\tfunction isCurrent(step) {\n\t\treturn stepNames.value.indexOf(step) === index.value;\n\t}\n\tfunction isBefore(step) {\n\t\treturn index.value < stepNames.value.indexOf(step);\n\t}\n\tfunction isAfter(step) {\n\t\treturn index.value > stepNames.value.indexOf(step);\n\t}\n\treturn {\n\t\tsteps: stepsRef,\n\t\tstepNames,\n\t\tindex,\n\t\tcurrent,\n\t\tnext,\n\t\tprevious,\n\t\tisFirst,\n\t\tisLast,\n\t\tat,\n\t\tget,\n\t\tgoTo,\n\t\tgoToNext,\n\t\tgoToPrevious,\n\t\tgoBackTo,\n\t\tisNext,\n\t\tisPrevious,\n\t\tisCurrent,\n\t\tisBefore,\n\t\tisAfter\n\t};\n}\n\n//#endregion\n//#region useStorageAsync/index.ts\n/**\n* Reactive Storage in with async support.\n*\n* @see https://vueuse.org/useStorageAsync\n* @param key\n* @param initialValue\n* @param storage\n* @param options\n*/\nfunction useStorageAsync(key, initialValue, storage, options = {}) {\n\tvar _options$serializer;\n\tconst { flush = \"pre\", deep = true, listenToStorageChanges = true, writeDefaults = true, mergeDefaults = false, shallow, window: window$1 = defaultWindow, eventFilter, onError = (e) => {\n\t\tconsole.error(e);\n\t}, onReady } = options;\n\tconst rawInit = toValue(initialValue);\n\tconst type = guessSerializerType(rawInit);\n\tconst data = (shallow ? shallowRef : ref)(toValue(initialValue));\n\tconst serializer = (_options$serializer = options.serializer) !== null && _options$serializer !== void 0 ? _options$serializer : StorageSerializers[type];\n\tif (!storage) try {\n\t\tstorage = getSSRHandler(\"getDefaultStorageAsync\", () => defaultWindow === null || defaultWindow === void 0 ? void 0 : defaultWindow.localStorage)();\n\t} catch (e) {\n\t\tonError(e);\n\t}\n\tasync function read(event) {\n\t\tif (!storage || event && event.key !== key) return;\n\t\ttry {\n\t\t\tconst rawValue = event ? event.newValue : await storage.getItem(key);\n\t\t\tif (rawValue == null) {\n\t\t\t\tdata.value = rawInit;\n\t\t\t\tif (writeDefaults && rawInit !== null) await storage.setItem(key, await serializer.write(rawInit));\n\t\t\t} else if (mergeDefaults) {\n\t\t\t\tconst value = await serializer.read(rawValue);\n\t\t\t\tif (typeof mergeDefaults === \"function\") data.value = mergeDefaults(value, rawInit);\n\t\t\t\telse if (type === \"object\" && !Array.isArray(value)) data.value = {\n\t\t\t\t\t...rawInit,\n\t\t\t\t\t...value\n\t\t\t\t};\n\t\t\t\telse data.value = value;\n\t\t\t} else data.value = await serializer.read(rawValue);\n\t\t} catch (e) {\n\t\t\tonError(e);\n\t\t}\n\t}\n\tconst promise = new Promise((resolve) => {\n\t\tread().then(() => {\n\t\t\tonReady === null || onReady === void 0 || onReady(data.value);\n\t\t\tresolve(data);\n\t\t});\n\t});\n\tif (window$1 && listenToStorageChanges) useEventListener(window$1, \"storage\", (e) => Promise.resolve().then(() => read(e)), { passive: true });\n\tif (storage) watchWithFilter(data, async () => {\n\t\ttry {\n\t\t\tif (data.value == null) await storage.removeItem(key);\n\t\t\telse await storage.setItem(key, await serializer.write(data.value));\n\t\t} catch (e) {\n\t\t\tonError(e);\n\t\t}\n\t}, {\n\t\tflush,\n\t\tdeep,\n\t\teventFilter\n\t});\n\tObject.assign(data, {\n\t\tthen: promise.then.bind(promise),\n\t\tcatch: promise.catch.bind(promise)\n\t});\n\treturn data;\n}\n\n//#endregion\n//#region useStyleTag/index.ts\nlet _id = 0;\n/**\n* Inject <style> element in head.\n*\n* Overload: Omitted id\n*\n* @see https://vueuse.org/useStyleTag\n* @param css\n* @param options\n*/\nfunction useStyleTag(css, options = {}) {\n\tconst isLoaded = shallowRef(false);\n\tconst { document: document$1 = defaultDocument, immediate = true, manual = false, id = `vueuse_styletag_${++_id}` } = options;\n\tconst cssRef = shallowRef(css);\n\tlet stop = () => {};\n\tconst load = () => {\n\t\tif (!document$1) return;\n\t\tconst el = document$1.getElementById(id) || document$1.createElement(\"style\");\n\t\tif (!el.isConnected) {\n\t\t\tel.id = id;\n\t\t\tif (options.nonce) el.nonce = options.nonce;\n\t\t\tif (options.media) el.media = options.media;\n\t\t\tdocument$1.head.appendChild(el);\n\t\t}\n\t\tif (isLoaded.value) return;\n\t\tstop = watch(cssRef, (value) => {\n\t\t\tel.textContent = value;\n\t\t}, { immediate: true });\n\t\tisLoaded.value = true;\n\t};\n\tconst unload = () => {\n\t\tif (!document$1 || !isLoaded.value) return;\n\t\tstop();\n\t\tdocument$1.head.removeChild(document$1.getElementById(id));\n\t\tisLoaded.value = false;\n\t};\n\tif (immediate && !manual) tryOnMounted(load);\n\tif (!manual) tryOnScopeDispose(unload);\n\treturn {\n\t\tid,\n\t\tcss: cssRef,\n\t\tunload,\n\t\tload,\n\t\tisLoaded: readonly(isLoaded)\n\t};\n}\n\n//#endregion\n//#region useSwipe/index.ts\n/**\n* Reactive swipe detection.\n*\n* @see https://vueuse.org/useSwipe\n* @param target\n* @param options\n*/\nfunction useSwipe(target, options = {}) {\n\tconst { threshold = 50, onSwipe, onSwipeEnd, onSwipeStart, passive = true } = options;\n\tconst coordsStart = reactive({\n\t\tx: 0,\n\t\ty: 0\n\t});\n\tconst coordsEnd = reactive({\n\t\tx: 0,\n\t\ty: 0\n\t});\n\tconst diffX = computed(() => coordsStart.x - coordsEnd.x);\n\tconst diffY = computed(() => coordsStart.y - coordsEnd.y);\n\tconst { max, abs } = Math;\n\tconst isThresholdExceeded = computed(() => max(abs(diffX.value), abs(diffY.value)) >= threshold);\n\tconst isSwiping = shallowRef(false);\n\tconst direction = computed(() => {\n\t\tif (!isThresholdExceeded.value) return \"none\";\n\t\tif (abs(diffX.value) > abs(diffY.value)) return diffX.value > 0 ? \"left\" : \"right\";\n\t\telse return diffY.value > 0 ? \"up\" : \"down\";\n\t});\n\tconst getTouchEventCoords = (e) => [e.touches[0].clientX, e.touches[0].clientY];\n\tconst updateCoordsStart = (x, y) => {\n\t\tcoordsStart.x = x;\n\t\tcoordsStart.y = y;\n\t};\n\tconst updateCoordsEnd = (x, y) => {\n\t\tcoordsEnd.x = x;\n\t\tcoordsEnd.y = y;\n\t};\n\tconst listenerOptions = {\n\t\tpassive,\n\t\tcapture: !passive\n\t};\n\tconst onTouchEnd = (e) => {\n\t\tif (isSwiping.value) onSwipeEnd === null || onSwipeEnd === void 0 || onSwipeEnd(e, direction.value);\n\t\tisSwiping.value = false;\n\t};\n\tconst stops = [\n\t\tuseEventListener(target, \"touchstart\", (e) => {\n\t\t\tif (e.touches.length !== 1) return;\n\t\t\tconst [x, y] = getTouchEventCoords(e);\n\t\t\tupdateCoordsStart(x, y);\n\t\t\tupdateCoordsEnd(x, y);\n\t\t\tonSwipeStart === null || onSwipeStart === void 0 || onSwipeStart(e);\n\t\t}, listenerOptions),\n\t\tuseEventListener(target, \"touchmove\", (e) => {\n\t\t\tif (e.touches.length !== 1) return;\n\t\t\tconst [x, y] = getTouchEventCoords(e);\n\t\t\tupdateCoordsEnd(x, y);\n\t\t\tif (listenerOptions.capture && !listenerOptions.passive && Math.abs(diffX.value) > Math.abs(diffY.value)) e.preventDefault();\n\t\t\tif (!isSwiping.value && isThresholdExceeded.value) isSwiping.value = true;\n\t\t\tif (isSwiping.value) onSwipe === null || onSwipe === void 0 || onSwipe(e);\n\t\t}, listenerOptions),\n\t\tuseEventListener(target, [\"touchend\", \"touchcancel\"], onTouchEnd, listenerOptions)\n\t];\n\tconst stop = () => stops.forEach((s) => s());\n\treturn {\n\t\tisSwiping,\n\t\tdirection,\n\t\tcoordsStart,\n\t\tcoordsEnd,\n\t\tlengthX: diffX,\n\t\tlengthY: diffY,\n\t\tstop\n\t};\n}\n\n//#endregion\n//#region useTemplateRefsList/index.ts\n/* @__NO_SIDE_EFFECTS__ */\nfunction useTemplateRefsList() {\n\tconst refs = ref([]);\n\trefs.value.set = (el) => {\n\t\tif (el) refs.value.push(el);\n\t};\n\tonBeforeUpdate(() => {\n\t\trefs.value.length = 0;\n\t});\n\treturn refs;\n}\n\n//#endregion\n//#region useTextDirection/index.ts\n/**\n* Reactive dir of the element's text.\n*\n* @see https://vueuse.org/useTextDirection\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useTextDirection(options = {}) {\n\tconst { document: document$1 = defaultDocument, selector = \"html\", observe = false, initialValue = \"ltr\" } = options;\n\tfunction getValue$1() {\n\t\tvar _ref, _document$querySelect;\n\t\treturn (_ref = document$1 === null || document$1 === void 0 || (_document$querySelect = document$1.querySelector(selector)) === null || _document$querySelect === void 0 ? void 0 : _document$querySelect.getAttribute(\"dir\")) !== null && _ref !== void 0 ? _ref : initialValue;\n\t}\n\tconst dir = ref(getValue$1());\n\ttryOnMounted(() => dir.value = getValue$1());\n\tif (observe && document$1) useMutationObserver(document$1.querySelector(selector), () => dir.value = getValue$1(), { attributes: true });\n\treturn computed({\n\t\tget() {\n\t\t\treturn dir.value;\n\t\t},\n\t\tset(v) {\n\t\t\tvar _document$querySelect2, _document$querySelect3;\n\t\t\tdir.value = v;\n\t\t\tif (!document$1) return;\n\t\t\tif (dir.value) (_document$querySelect2 = document$1.querySelector(selector)) === null || _document$querySelect2 === void 0 || _document$querySelect2.setAttribute(\"dir\", dir.value);\n\t\t\telse (_document$querySelect3 = document$1.querySelector(selector)) === null || _document$querySelect3 === void 0 || _document$querySelect3.removeAttribute(\"dir\");\n\t\t}\n\t});\n}\n\n//#endregion\n//#region useTextSelection/index.ts\nfunction getRangesFromSelection(selection) {\n\tvar _selection$rangeCount;\n\tconst rangeCount = (_selection$rangeCount = selection.rangeCount) !== null && _selection$rangeCount !== void 0 ? _selection$rangeCount : 0;\n\treturn Array.from({ length: rangeCount }, (_, i) => selection.getRangeAt(i));\n}\n/**\n* Reactively track user text selection based on [`Window.getSelection`](https://developer.mozilla.org/en-US/docs/Web/API/Window/getSelection).\n*\n* @see https://vueuse.org/useTextSelection\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useTextSelection(options = {}) {\n\tvar _window$getSelection;\n\tconst { window: window$1 = defaultWindow } = options;\n\tconst selection = shallowRef((_window$getSelection = window$1 === null || window$1 === void 0 ? void 0 : window$1.getSelection()) !== null && _window$getSelection !== void 0 ? _window$getSelection : null);\n\tconst text = computed(() => {\n\t\tvar _selection$value$toSt, _selection$value;\n\t\treturn (_selection$value$toSt = (_selection$value = selection.value) === null || _selection$value === void 0 ? void 0 : _selection$value.toString()) !== null && _selection$value$toSt !== void 0 ? _selection$value$toSt : \"\";\n\t});\n\tconst ranges = computed(() => selection.value ? getRangesFromSelection(selection.value) : []);\n\tconst rects = computed(() => ranges.value.map((range) => range.getBoundingClientRect()));\n\tfunction onSelectionChange() {\n\t\tselection.value = null;\n\t\tif (window$1) selection.value = window$1.getSelection();\n\t}\n\tif (window$1) useEventListener(window$1.document, \"selectionchange\", onSelectionChange, { passive: true });\n\treturn {\n\t\ttext,\n\t\trects,\n\t\tranges,\n\t\tselection\n\t};\n}\n\n//#endregion\n//#region useTextareaAutosize/index.ts\n/**\n* Call window.requestAnimationFrame(), if not available, just call the function\n*\n* @param window\n* @param fn\n*/\nfunction tryRequestAnimationFrame(window$1 = defaultWindow, fn) {\n\tif (window$1 && typeof window$1.requestAnimationFrame === \"function\") window$1.requestAnimationFrame(fn);\n\telse fn();\n}\nfunction useTextareaAutosize(options = {}) {\n\tvar _options$input, _options$styleProp;\n\tconst { window: window$1 = defaultWindow } = options;\n\tconst textarea = toRef(options === null || options === void 0 ? void 0 : options.element);\n\tconst input = toRef((_options$input = options === null || options === void 0 ? void 0 : options.input) !== null && _options$input !== void 0 ? _options$input : \"\");\n\tconst styleProp = (_options$styleProp = options === null || options === void 0 ? void 0 : options.styleProp) !== null && _options$styleProp !== void 0 ? _options$styleProp : \"height\";\n\tconst textareaScrollHeight = shallowRef(1);\n\tconst textareaOldWidth = shallowRef(0);\n\tfunction triggerResize() {\n\t\tvar _textarea$value;\n\t\tif (!textarea.value) return;\n\t\tlet height = \"\";\n\t\ttextarea.value.style[styleProp] = \"1px\";\n\t\ttextareaScrollHeight.value = (_textarea$value = textarea.value) === null || _textarea$value === void 0 ? void 0 : _textarea$value.scrollHeight;\n\t\tconst _styleTarget = toValue(options === null || options === void 0 ? void 0 : options.styleTarget);\n\t\tif (_styleTarget) _styleTarget.style[styleProp] = `${textareaScrollHeight.value}px`;\n\t\telse height = `${textareaScrollHeight.value}px`;\n\t\ttextarea.value.style[styleProp] = height;\n\t}\n\twatch([input, textarea], () => nextTick(triggerResize), { immediate: true });\n\twatch(textareaScrollHeight, () => {\n\t\tvar _options$onResize;\n\t\treturn options === null || options === void 0 || (_options$onResize = options.onResize) === null || _options$onResize === void 0 ? void 0 : _options$onResize.call(options);\n\t});\n\tuseResizeObserver(textarea, ([{ contentRect }]) => {\n\t\tif (textareaOldWidth.value === contentRect.width) return;\n\t\ttryRequestAnimationFrame(window$1, () => {\n\t\t\ttextareaOldWidth.value = contentRect.width;\n\t\t\ttriggerResize();\n\t\t});\n\t});\n\tif (options === null || options === void 0 ? void 0 : options.watch) watch(options.watch, triggerResize, {\n\t\timmediate: true,\n\t\tdeep: true\n\t});\n\treturn {\n\t\ttextarea,\n\t\tinput,\n\t\ttriggerResize\n\t};\n}\n\n//#endregion\n//#region useThrottledRefHistory/index.ts\n/**\n* Shorthand for [useRefHistory](https://vueuse.org/useRefHistory) with throttled filter.\n*\n* @see https://vueuse.org/useThrottledRefHistory\n* @param source\n* @param options\n*/\nfunction useThrottledRefHistory(source, options = {}) {\n\tconst { throttle = 200, trailing = true } = options;\n\tconst filter = throttleFilter(throttle, trailing);\n\treturn { ...useRefHistory(source, {\n\t\t...options,\n\t\teventFilter: filter\n\t}) };\n}\n\n//#endregion\n//#region useTimeAgo/index.ts\nconst DEFAULT_UNITS = [\n\t{\n\t\tmax: 6e4,\n\t\tvalue: 1e3,\n\t\tname: \"second\"\n\t},\n\t{\n\t\tmax: 276e4,\n\t\tvalue: 6e4,\n\t\tname: \"minute\"\n\t},\n\t{\n\t\tmax: 72e6,\n\t\tvalue: 36e5,\n\t\tname: \"hour\"\n\t},\n\t{\n\t\tmax: 5184e5,\n\t\tvalue: 864e5,\n\t\tname: \"day\"\n\t},\n\t{\n\t\tmax: 24192e5,\n\t\tvalue: 6048e5,\n\t\tname: \"week\"\n\t},\n\t{\n\t\tmax: 28512e6,\n\t\tvalue: 2592e6,\n\t\tname: \"month\"\n\t},\n\t{\n\t\tmax: Number.POSITIVE_INFINITY,\n\t\tvalue: 31536e6,\n\t\tname: \"year\"\n\t}\n];\nconst DEFAULT_MESSAGES = {\n\tjustNow: \"just now\",\n\tpast: (n) => n.match(/\\d/) ? `${n} ago` : n,\n\tfuture: (n) => n.match(/\\d/) ? `in ${n}` : n,\n\tmonth: (n, past) => n === 1 ? past ? \"last month\" : \"next month\" : `${n} month${n > 1 ? \"s\" : \"\"}`,\n\tyear: (n, past) => n === 1 ? past ? \"last year\" : \"next year\" : `${n} year${n > 1 ? \"s\" : \"\"}`,\n\tday: (n, past) => n === 1 ? past ? \"yesterday\" : \"tomorrow\" : `${n} day${n > 1 ? \"s\" : \"\"}`,\n\tweek: (n, past) => n === 1 ? past ? \"last week\" : \"next week\" : `${n} week${n > 1 ? \"s\" : \"\"}`,\n\thour: (n) => `${n} hour${n > 1 ? \"s\" : \"\"}`,\n\tminute: (n) => `${n} minute${n > 1 ? \"s\" : \"\"}`,\n\tsecond: (n) => `${n} second${n > 1 ? \"s\" : \"\"}`,\n\tinvalid: \"\"\n};\nfunction DEFAULT_FORMATTER(date) {\n\treturn date.toISOString().slice(0, 10);\n}\nfunction getDefaultScheduler$4(options) {\n\tif (\"updateInterval\" in options) {\n\t\tconst { updateInterval = 3e4 } = options;\n\t\treturn (cb) => useIntervalFn(cb, updateInterval);\n\t}\n\treturn (cb) => useIntervalFn(cb, 3e4);\n}\n/**\n* Reactive time ago formatter.\n*\n* @see https://vueuse.org/useTimeAgo\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useTimeAgo(time, options = {}) {\n\tconst { controls: exposeControls = false, scheduler = getDefaultScheduler$4(options) } = options;\n\tconst { now,...controls } = useNow({\n\t\tscheduler,\n\t\tcontrols: true\n\t});\n\tconst timeAgo = computed(() => formatTimeAgo(new Date(toValue(time)), options, toValue(now)));\n\tif (exposeControls) return {\n\t\ttimeAgo,\n\t\t...controls\n\t};\n\telse return timeAgo;\n}\nfunction formatTimeAgo(from, options = {}, now = Date.now()) {\n\tconst { max, messages = DEFAULT_MESSAGES, fullDateFormatter = DEFAULT_FORMATTER, units = DEFAULT_UNITS, showSecond = false, rounding = \"round\" } = options;\n\tconst roundFn = typeof rounding === \"number\" ? (n) => +n.toFixed(rounding) : Math[rounding];\n\tconst diff = +now - +from;\n\tconst absDiff = Math.abs(diff);\n\tfunction getValue$1(diff$1, unit) {\n\t\treturn roundFn(Math.abs(diff$1) / unit.value);\n\t}\n\tfunction format(diff$1, unit) {\n\t\tconst val = getValue$1(diff$1, unit);\n\t\tconst past = diff$1 > 0;\n\t\tconst str = applyFormat(unit.name, val, past);\n\t\treturn applyFormat(past ? \"past\" : \"future\", str, past);\n\t}\n\tfunction applyFormat(name, val, isPast) {\n\t\tconst formatter = messages[name];\n\t\tif (typeof formatter === \"function\") return formatter(val, isPast);\n\t\treturn formatter.replace(\"{0}\", val.toString());\n\t}\n\tif (absDiff < 6e4 && !showSecond) return messages.justNow;\n\tif (typeof max === \"number\" && absDiff > max) return fullDateFormatter(new Date(from));\n\tif (typeof max === \"string\") {\n\t\tvar _units$find;\n\t\tconst unitMax = (_units$find = units.find((i) => i.name === max)) === null || _units$find === void 0 ? void 0 : _units$find.max;\n\t\tif (unitMax && absDiff > unitMax) return fullDateFormatter(new Date(from));\n\t}\n\tfor (const [idx, unit] of units.entries()) {\n\t\tif (getValue$1(diff, unit) <= 0 && units[idx - 1]) return format(diff, units[idx - 1]);\n\t\tif (absDiff < unit.max) return format(diff, unit);\n\t}\n\treturn messages.invalid;\n}\n\n//#endregion\n//#region useTimeAgoIntl/index.ts\nconst UNITS = [\n\t{\n\t\tname: \"year\",\n\t\tms: 31536e6\n\t},\n\t{\n\t\tname: \"month\",\n\t\tms: 2592e6\n\t},\n\t{\n\t\tname: \"week\",\n\t\tms: 6048e5\n\t},\n\t{\n\t\tname: \"day\",\n\t\tms: 864e5\n\t},\n\t{\n\t\tname: \"hour\",\n\t\tms: 36e5\n\t},\n\t{\n\t\tname: \"minute\",\n\t\tms: 6e4\n\t},\n\t{\n\t\tname: \"second\",\n\t\tms: 1e3\n\t}\n];\nfunction getDefaultScheduler$3(options) {\n\tif (\"updateInterval\" in options) {\n\t\tconst { updateInterval = 3e4 } = options;\n\t\treturn (cb) => useIntervalFn(cb, updateInterval);\n\t}\n\treturn (cb) => useIntervalFn(cb, 3e4);\n}\nfunction useTimeAgoIntl(time, options = {}) {\n\tconst { controls: exposeControls = false, scheduler = getDefaultScheduler$3(options) } = options;\n\tconst { now,...controls } = useNow({\n\t\tscheduler,\n\t\tcontrols: true\n\t});\n\tconst result = computed(() => getTimeAgoIntlResult(new Date(toValue(time)), options, toValue(now)));\n\tconst parts = computed(() => result.value.parts);\n\tconst timeAgoIntl = computed(() => formatTimeAgoIntlParts(parts.value, {\n\t\t...options,\n\t\tlocale: result.value.resolvedLocale\n\t}));\n\treturn exposeControls ? {\n\t\ttimeAgoIntl,\n\t\tparts,\n\t\t...controls\n\t} : timeAgoIntl;\n}\n/**\n* Non-reactive version of useTimeAgoIntl\n*/\nfunction formatTimeAgoIntl(from, options = {}, now = Date.now()) {\n\tconst { parts, resolvedLocale } = getTimeAgoIntlResult(from, options, now);\n\treturn formatTimeAgoIntlParts(parts, {\n\t\t...options,\n\t\tlocale: resolvedLocale\n\t});\n}\n/**\n* Get parts from `Intl.RelativeTimeFormat.formatToParts`.\n*/\nfunction getTimeAgoIntlResult(from, options = {}, now = Date.now()) {\n\tvar _options$units;\n\tconst { locale, relativeTimeFormatOptions = { numeric: \"auto\" } } = options;\n\tconst rtf = new Intl.RelativeTimeFormat(locale, relativeTimeFormatOptions);\n\tconst { locale: resolvedLocale } = rtf.resolvedOptions();\n\tconst diff = +from - +now;\n\tconst absDiff = Math.abs(diff);\n\tconst units = (_options$units = options.units) !== null && _options$units !== void 0 ? _options$units : UNITS;\n\tfor (const { name, ms } of units) if (absDiff >= ms) return {\n\t\tresolvedLocale,\n\t\tparts: rtf.formatToParts(Math.round(diff / ms), name)\n\t};\n\treturn {\n\t\tresolvedLocale,\n\t\tparts: rtf.formatToParts(0, units[units.length - 1].name)\n\t};\n}\n/**\n* Format parts into a string\n*/\nfunction formatTimeAgoIntlParts(parts, options = {}) {\n\tconst { insertSpace = true, joinParts, locale } = options;\n\tif (typeof joinParts === \"function\") return joinParts(parts, locale);\n\tif (!insertSpace) return parts.map((part) => part.value).join(\"\");\n\treturn parts.map((part) => part.value.trim()).join(\" \");\n}\n\n//#endregion\n//#region useTimeoutPoll/index.ts\nfunction useTimeoutPoll(fn, interval, options = {}) {\n\tconst { immediate = true, immediateCallback = false } = options;\n\tconst { start } = useTimeoutFn(loop, interval, { immediate });\n\tconst isActive = shallowRef(false);\n\tasync function loop() {\n\t\tif (!isActive.value) return;\n\t\tawait fn();\n\t\tstart();\n\t}\n\tfunction resume() {\n\t\tif (!isActive.value) {\n\t\t\tisActive.value = true;\n\t\t\tif (immediateCallback) fn();\n\t\t\tstart();\n\t\t}\n\t}\n\tfunction pause() {\n\t\tisActive.value = false;\n\t}\n\tif (immediate && isClient) resume();\n\ttryOnScopeDispose(pause);\n\treturn {\n\t\tisActive,\n\t\tpause,\n\t\tresume\n\t};\n}\n\n//#endregion\n//#region useTimestamp/index.ts\nfunction getDefaultScheduler$2(options) {\n\tif (\"interval\" in options || \"immediate\" in options) {\n\t\tconst { interval = \"requestAnimationFrame\", immediate = true } = options;\n\t\treturn interval === \"requestAnimationFrame\" ? (cb) => useRafFn(cb, { immediate }) : (cb) => useIntervalFn(cb, interval, { immediate });\n\t}\n\treturn useRafFn;\n}\nfunction useTimestamp(options = {}) {\n\tconst { controls: exposeControls = false, offset = 0, scheduler = getDefaultScheduler$2(options), callback } = options;\n\tconst ts = shallowRef(timestamp() + offset);\n\tconst update = () => ts.value = timestamp() + offset;\n\tconst controls = scheduler(callback ? () => {\n\t\tupdate();\n\t\tcallback(ts.value);\n\t} : update);\n\tif (exposeControls) return {\n\t\ttimestamp: ts,\n\t\t...controls\n\t};\n\telse return ts;\n}\n\n//#endregion\n//#region useTitle/index.ts\nfunction useTitle(newTitle = null, options = {}) {\n\tvar _document$title, _ref;\n\tconst { document: document$1 = defaultDocument, restoreOnUnmount = (t) => t } = options;\n\tconst originalTitle = (_document$title = document$1 === null || document$1 === void 0 ? void 0 : document$1.title) !== null && _document$title !== void 0 ? _document$title : \"\";\n\tconst title = toRef((_ref = newTitle !== null && newTitle !== void 0 ? newTitle : document$1 === null || document$1 === void 0 ? void 0 : document$1.title) !== null && _ref !== void 0 ? _ref : null);\n\tconst isReadonly$1 = !!(newTitle && typeof newTitle === \"function\");\n\tfunction format(t) {\n\t\tif (!(\"titleTemplate\" in options)) return t;\n\t\tconst template = options.titleTemplate || \"%s\";\n\t\treturn typeof template === \"function\" ? template(t) : toValue(template).replace(/%s/g, t);\n\t}\n\twatch(title, (newValue, oldValue) => {\n\t\tif (newValue !== oldValue && document$1) document$1.title = format(newValue !== null && newValue !== void 0 ? newValue : \"\");\n\t}, { immediate: true });\n\tif (options.observe && !options.titleTemplate && document$1 && !isReadonly$1) {\n\t\tvar _document$head;\n\t\tuseMutationObserver((_document$head = document$1.head) === null || _document$head === void 0 ? void 0 : _document$head.querySelector(\"title\"), () => {\n\t\t\tif (document$1 && document$1.title !== title.value) title.value = format(document$1.title);\n\t\t}, { childList: true });\n\t}\n\ttryOnScopeDispose(() => {\n\t\tif (restoreOnUnmount) {\n\t\t\tconst restoredTitle = restoreOnUnmount(originalTitle, title.value || \"\");\n\t\t\tif (restoredTitle != null && document$1) document$1.title = restoredTitle;\n\t\t}\n\t});\n\treturn title;\n}\n\n//#endregion\n//#region useTransition/index.ts\nconst _TransitionPresets = {\n\teaseInSine: [\n\t\t.12,\n\t\t0,\n\t\t.39,\n\t\t0\n\t],\n\teaseOutSine: [\n\t\t.61,\n\t\t1,\n\t\t.88,\n\t\t1\n\t],\n\teaseInOutSine: [\n\t\t.37,\n\t\t0,\n\t\t.63,\n\t\t1\n\t],\n\teaseInQuad: [\n\t\t.11,\n\t\t0,\n\t\t.5,\n\t\t0\n\t],\n\teaseOutQuad: [\n\t\t.5,\n\t\t1,\n\t\t.89,\n\t\t1\n\t],\n\teaseInOutQuad: [\n\t\t.45,\n\t\t0,\n\t\t.55,\n\t\t1\n\t],\n\teaseInCubic: [\n\t\t.32,\n\t\t0,\n\t\t.67,\n\t\t0\n\t],\n\teaseOutCubic: [\n\t\t.33,\n\t\t1,\n\t\t.68,\n\t\t1\n\t],\n\teaseInOutCubic: [\n\t\t.65,\n\t\t0,\n\t\t.35,\n\t\t1\n\t],\n\teaseInQuart: [\n\t\t.5,\n\t\t0,\n\t\t.75,\n\t\t0\n\t],\n\teaseOutQuart: [\n\t\t.25,\n\t\t1,\n\t\t.5,\n\t\t1\n\t],\n\teaseInOutQuart: [\n\t\t.76,\n\t\t0,\n\t\t.24,\n\t\t1\n\t],\n\teaseInQuint: [\n\t\t.64,\n\t\t0,\n\t\t.78,\n\t\t0\n\t],\n\teaseOutQuint: [\n\t\t.22,\n\t\t1,\n\t\t.36,\n\t\t1\n\t],\n\teaseInOutQuint: [\n\t\t.83,\n\t\t0,\n\t\t.17,\n\t\t1\n\t],\n\teaseInExpo: [\n\t\t.7,\n\t\t0,\n\t\t.84,\n\t\t0\n\t],\n\teaseOutExpo: [\n\t\t.16,\n\t\t1,\n\t\t.3,\n\t\t1\n\t],\n\teaseInOutExpo: [\n\t\t.87,\n\t\t0,\n\t\t.13,\n\t\t1\n\t],\n\teaseInCirc: [\n\t\t.55,\n\t\t0,\n\t\t1,\n\t\t.45\n\t],\n\teaseOutCirc: [\n\t\t0,\n\t\t.55,\n\t\t.45,\n\t\t1\n\t],\n\teaseInOutCirc: [\n\t\t.85,\n\t\t0,\n\t\t.15,\n\t\t1\n\t],\n\teaseInBack: [\n\t\t.36,\n\t\t0,\n\t\t.66,\n\t\t-.56\n\t],\n\teaseOutBack: [\n\t\t.34,\n\t\t1.56,\n\t\t.64,\n\t\t1\n\t],\n\teaseInOutBack: [\n\t\t.68,\n\t\t-.6,\n\t\t.32,\n\t\t1.6\n\t]\n};\n/**\n* Common transitions\n*\n* @see https://easings.net\n*/\nconst TransitionPresets = /* @__PURE__ */ Object.assign({}, { linear: identity }, _TransitionPresets);\n/**\n* Create an easing function from cubic bezier points.\n*/\nfunction createEasingFunction([p0, p1, p2, p3]) {\n\tconst a = (a1, a2) => 1 - 3 * a2 + 3 * a1;\n\tconst b = (a1, a2) => 3 * a2 - 6 * a1;\n\tconst c = (a1) => 3 * a1;\n\tconst calcBezier = (t, a1, a2) => ((a(a1, a2) * t + b(a1, a2)) * t + c(a1)) * t;\n\tconst getSlope = (t, a1, a2) => 3 * a(a1, a2) * t * t + 2 * b(a1, a2) * t + c(a1);\n\tconst getTforX = (x) => {\n\t\tlet aGuessT = x;\n\t\tfor (let i = 0; i < 4; ++i) {\n\t\t\tconst currentSlope = getSlope(aGuessT, p0, p2);\n\t\t\tif (currentSlope === 0) return aGuessT;\n\t\t\tconst currentX = calcBezier(aGuessT, p0, p2) - x;\n\t\t\taGuessT -= currentX / currentSlope;\n\t\t}\n\t\treturn aGuessT;\n\t};\n\treturn (x) => p0 === p1 && p2 === p3 ? x : calcBezier(getTforX(x), p1, p3);\n}\nfunction lerp(a, b, alpha) {\n\treturn a + alpha * (b - a);\n}\nfunction defaultInterpolation(a, b, t) {\n\tconst aVal = toValue(a);\n\tconst bVal = toValue(b);\n\tif (typeof aVal === \"number\" && typeof bVal === \"number\") return lerp(aVal, bVal, t);\n\tif (Array.isArray(aVal) && Array.isArray(bVal)) return aVal.map((v, i) => lerp(v, toValue(bVal[i]), t));\n\tthrow new TypeError(\"Unknown transition type, specify an interpolation function.\");\n}\nfunction normalizeEasing(easing) {\n\tvar _toValue;\n\treturn typeof easing === \"function\" ? easing : (_toValue = toValue(easing)) !== null && _toValue !== void 0 ? _toValue : identity;\n}\n/**\n* Transition from one value to another.\n*\n* @param source\n* @param from\n* @param to\n* @param options\n*/\nfunction transition(source, from, to, options = {}) {\n\tvar _toValue2;\n\tconst { window: window$1 = defaultWindow } = options;\n\tconst fromVal = toValue(from);\n\tconst toVal = toValue(to);\n\tconst duration = (_toValue2 = toValue(options.duration)) !== null && _toValue2 !== void 0 ? _toValue2 : 1e3;\n\tconst startedAt = Date.now();\n\tconst endAt = Date.now() + duration;\n\tconst interpolation = typeof options.interpolation === \"function\" ? options.interpolation : defaultInterpolation;\n\tconst trans = typeof options.easing !== \"undefined\" ? normalizeEasing(options.easing) : normalizeEasing(options.transition);\n\tconst ease = typeof trans === \"function\" ? trans : createEasingFunction(trans);\n\treturn new Promise((resolve) => {\n\t\tsource.value = fromVal;\n\t\tconst tick = () => {\n\t\t\tvar _options$abort;\n\t\t\tif ((_options$abort = options.abort) === null || _options$abort === void 0 ? void 0 : _options$abort.call(options)) {\n\t\t\t\tresolve();\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tconst now = Date.now();\n\t\t\tsource.value = interpolation(fromVal, toVal, ease((now - startedAt) / duration));\n\t\t\tif (now < endAt) window$1 === null || window$1 === void 0 || window$1.requestAnimationFrame(tick);\n\t\t\telse {\n\t\t\t\tsource.value = toVal;\n\t\t\t\tresolve();\n\t\t\t}\n\t\t};\n\t\ttick();\n\t});\n}\n/**\n* Transition from one value to another.\n* @deprecated The `executeTransition` function is deprecated, use `transition` instead.\n*\n* @param source\n* @param from\n* @param to\n* @param options\n*/\nfunction executeTransition(source, from, to, options = {}) {\n\treturn transition(source, from, to, options);\n}\n/**\n* Follow value with a transition.\n*\n* @see https://vueuse.org/useTransition\n* @param source\n* @param options\n*/\nfunction useTransition(source, options = {}) {\n\tlet currentId = 0;\n\tconst sourceVal = () => {\n\t\tconst v = toValue(source);\n\t\treturn typeof options.interpolation === \"undefined\" && Array.isArray(v) ? v.map(toValue) : v;\n\t};\n\tconst outputRef = shallowRef(sourceVal());\n\twatch(sourceVal, async (to) => {\n\t\tvar _options$onStarted, _options$onFinished;\n\t\tif (toValue(options.disabled)) return;\n\t\tconst id = ++currentId;\n\t\tif (options.delay) await promiseTimeout(toValue(options.delay));\n\t\tif (id !== currentId) return;\n\t\t(_options$onStarted = options.onStarted) === null || _options$onStarted === void 0 || _options$onStarted.call(options);\n\t\tawait transition(outputRef, outputRef.value, to, {\n\t\t\t...options,\n\t\t\tabort: () => {\n\t\t\t\tvar _options$abort2;\n\t\t\t\treturn id !== currentId || ((_options$abort2 = options.abort) === null || _options$abort2 === void 0 ? void 0 : _options$abort2.call(options));\n\t\t\t}\n\t\t});\n\t\t(_options$onFinished = options.onFinished) === null || _options$onFinished === void 0 || _options$onFinished.call(options);\n\t}, { deep: true });\n\twatch(() => toValue(options.disabled), (disabled) => {\n\t\tif (disabled) {\n\t\t\tcurrentId++;\n\t\t\toutputRef.value = sourceVal();\n\t\t}\n\t});\n\ttryOnScopeDispose(() => {\n\t\tcurrentId++;\n\t});\n\treturn computed(() => toValue(options.disabled) ? sourceVal() : outputRef.value);\n}\n\n//#endregion\n//#region useUrlSearchParams/index.ts\n/**\n* Reactive URLSearchParams\n*\n* @see https://vueuse.org/useUrlSearchParams\n* @param mode\n* @param options\n*/\nfunction useUrlSearchParams(mode = \"history\", options = {}) {\n\tconst { initialValue = {}, removeNullishValues = true, removeFalsyValues = false, write: enableWrite = true, writeMode = \"replace\", window: window$1 = defaultWindow, stringify = (params) => params.toString() } = options;\n\tif (!window$1) return reactive(initialValue);\n\tconst state = reactive({});\n\tfunction getRawParams() {\n\t\tif (mode === \"history\") return window$1.location.search || \"\";\n\t\telse if (mode === \"hash\") {\n\t\t\tconst hash = window$1.location.hash || \"\";\n\t\t\tconst index = hash.indexOf(\"?\");\n\t\t\treturn index > 0 ? hash.slice(index) : \"\";\n\t\t} else return (window$1.location.hash || \"\").replace(/^#/, \"\");\n\t}\n\tfunction constructQuery(params) {\n\t\tconst stringified = stringify(params);\n\t\tif (mode === \"history\") return `${stringified ? `?${stringified}` : \"\"}${window$1.location.hash || \"\"}`;\n\t\tif (mode === \"hash-params\") return `${window$1.location.search || \"\"}${stringified ? `#${stringified}` : \"\"}`;\n\t\tconst hash = window$1.location.hash || \"#\";\n\t\tconst index = hash.indexOf(\"?\");\n\t\tif (index > 0) return `${window$1.location.search || \"\"}${hash.slice(0, index)}${stringified ? `?${stringified}` : \"\"}`;\n\t\treturn `${window$1.location.search || \"\"}${hash}${stringified ? `?${stringified}` : \"\"}`;\n\t}\n\tfunction read() {\n\t\treturn new URLSearchParams(getRawParams());\n\t}\n\tfunction updateState(params) {\n\t\tconst unusedKeys = new Set(Object.keys(state));\n\t\tfor (const key of params.keys()) {\n\t\t\tconst paramsForKey = params.getAll(key);\n\t\t\tstate[key] = paramsForKey.length > 1 ? paramsForKey : params.get(key) || \"\";\n\t\t\tunusedKeys.delete(key);\n\t\t}\n\t\tArray.from(unusedKeys).forEach((key) => delete state[key]);\n\t}\n\tconst { pause, resume } = watchPausable(state, () => {\n\t\tconst params = new URLSearchParams(\"\");\n\t\tObject.keys(state).forEach((key) => {\n\t\t\tconst mapEntry = state[key];\n\t\t\tif (Array.isArray(mapEntry)) mapEntry.forEach((value) => params.append(key, value));\n\t\t\telse if (removeNullishValues && mapEntry == null) params.delete(key);\n\t\t\telse if (removeFalsyValues && !mapEntry) params.delete(key);\n\t\t\telse params.set(key, mapEntry);\n\t\t});\n\t\twrite(params, false);\n\t}, { deep: true });\n\tfunction write(params, shouldUpdate, shouldWriteHistory = true) {\n\t\tpause();\n\t\tif (shouldUpdate) updateState(params);\n\t\tif (writeMode === \"replace\") window$1.history.replaceState(window$1.history.state, window$1.document.title, window$1.location.pathname + constructQuery(params));\n\t\telse if (shouldWriteHistory) window$1.history.pushState(window$1.history.state, window$1.document.title, window$1.location.pathname + constructQuery(params));\n\t\tnextTick(() => resume());\n\t}\n\tfunction onChanged() {\n\t\tif (!enableWrite) return;\n\t\twrite(read(), true, false);\n\t}\n\tconst listenerOptions = { passive: true };\n\tuseEventListener(window$1, \"popstate\", onChanged, listenerOptions);\n\tif (mode !== \"history\") useEventListener(window$1, \"hashchange\", onChanged, listenerOptions);\n\tconst initial = read();\n\tif (initial.keys().next().value) updateState(initial);\n\telse Object.assign(state, initialValue);\n\treturn state;\n}\n\n//#endregion\n//#region useUserMedia/index.ts\n/**\n* Reactive `mediaDevices.getUserMedia` streaming\n*\n* @see https://vueuse.org/useUserMedia\n* @param options\n*/\nfunction useUserMedia(options = {}) {\n\tvar _options$enabled, _options$autoSwitch;\n\tconst enabled = shallowRef((_options$enabled = options.enabled) !== null && _options$enabled !== void 0 ? _options$enabled : false);\n\tconst autoSwitch = shallowRef((_options$autoSwitch = options.autoSwitch) !== null && _options$autoSwitch !== void 0 ? _options$autoSwitch : true);\n\tconst constraints = ref(options.constraints);\n\tconst { navigator: navigator$1 = defaultNavigator } = options;\n\tconst isSupported = /* @__PURE__ */ useSupported(() => {\n\t\tvar _navigator$mediaDevic;\n\t\treturn navigator$1 === null || navigator$1 === void 0 || (_navigator$mediaDevic = navigator$1.mediaDevices) === null || _navigator$mediaDevic === void 0 ? void 0 : _navigator$mediaDevic.getUserMedia;\n\t});\n\tconst stream = shallowRef();\n\tfunction getDeviceOptions(type) {\n\t\tswitch (type) {\n\t\t\tcase \"video\":\n\t\t\t\tif (constraints.value) return constraints.value.video || false;\n\t\t\t\tbreak;\n\t\t\tcase \"audio\":\n\t\t\t\tif (constraints.value) return constraints.value.audio || false;\n\t\t\t\tbreak;\n\t\t}\n\t}\n\tasync function _start() {\n\t\tif (!isSupported.value || stream.value) return;\n\t\tstream.value = await navigator$1.mediaDevices.getUserMedia({\n\t\t\tvideo: getDeviceOptions(\"video\"),\n\t\t\taudio: getDeviceOptions(\"audio\")\n\t\t});\n\t\treturn stream.value;\n\t}\n\tfunction _stop() {\n\t\tvar _stream$value;\n\t\t(_stream$value = stream.value) === null || _stream$value === void 0 || _stream$value.getTracks().forEach((t) => t.stop());\n\t\tstream.value = void 0;\n\t}\n\tfunction stop() {\n\t\t_stop();\n\t\tenabled.value = false;\n\t}\n\tasync function start() {\n\t\tawait _start();\n\t\tif (stream.value) enabled.value = true;\n\t\treturn stream.value;\n\t}\n\tasync function restart() {\n\t\t_stop();\n\t\treturn await start();\n\t}\n\twatch(enabled, (v) => {\n\t\tif (v) _start();\n\t\telse _stop();\n\t}, { immediate: true });\n\twatch(constraints, () => {\n\t\tif (autoSwitch.value && stream.value) restart();\n\t}, {\n\t\timmediate: true,\n\t\tdeep: true\n\t});\n\ttryOnScopeDispose(() => {\n\t\tstop();\n\t});\n\treturn {\n\t\tisSupported,\n\t\tstream,\n\t\tstart,\n\t\tstop,\n\t\trestart,\n\t\tconstraints,\n\t\tenabled,\n\t\tautoSwitch\n\t};\n}\n\n//#endregion\n//#region useVModel/index.ts\n/**\n* Shorthand for v-model binding, props + emit -> ref\n*\n* @see https://vueuse.org/useVModel\n* @param props\n* @param key (default 'modelValue')\n* @param emit\n* @param options\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useVModel(props, key, emit, options = {}) {\n\tvar _vm$$emit, _vm$proxy;\n\tconst { clone = false, passive = false, eventName, deep = false, defaultValue, shouldEmit } = options;\n\tconst vm = getCurrentInstance();\n\tconst _emit = emit || (vm === null || vm === void 0 ? void 0 : vm.emit) || (vm === null || vm === void 0 || (_vm$$emit = vm.$emit) === null || _vm$$emit === void 0 ? void 0 : _vm$$emit.bind(vm)) || (vm === null || vm === void 0 || (_vm$proxy = vm.proxy) === null || _vm$proxy === void 0 || (_vm$proxy = _vm$proxy.$emit) === null || _vm$proxy === void 0 ? void 0 : _vm$proxy.bind(vm === null || vm === void 0 ? void 0 : vm.proxy));\n\tlet event = eventName;\n\tif (!key) key = \"modelValue\";\n\tevent = event || `update:${key.toString()}`;\n\tconst cloneFn = (val) => !clone ? val : typeof clone === \"function\" ? clone(val) : cloneFnJSON(val);\n\tconst getValue$1 = () => isDef(props[key]) ? cloneFn(props[key]) : defaultValue;\n\tconst triggerEmit = (value) => {\n\t\tif (shouldEmit) {\n\t\t\tif (shouldEmit(value)) _emit(event, value);\n\t\t} else _emit(event, value);\n\t};\n\tif (passive) {\n\t\tconst proxy = ref(getValue$1());\n\t\tlet isUpdating = false;\n\t\twatch(() => props[key], (v) => {\n\t\t\tif (!isUpdating) {\n\t\t\t\tisUpdating = true;\n\t\t\t\tproxy.value = cloneFn(v);\n\t\t\t\tnextTick(() => isUpdating = false);\n\t\t\t}\n\t\t});\n\t\twatch(proxy, (v) => {\n\t\t\tif (!isUpdating && (v !== props[key] || deep)) triggerEmit(v);\n\t\t}, { deep });\n\t\treturn proxy;\n\t} else return computed({\n\t\tget() {\n\t\t\treturn getValue$1();\n\t\t},\n\t\tset(value) {\n\t\t\ttriggerEmit(value);\n\t\t}\n\t});\n}\n\n//#endregion\n//#region useVModels/index.ts\n/**\n* Shorthand for props v-model binding. Think like `toRefs(props)` but changes will also emit out.\n*\n* @see https://vueuse.org/useVModels\n* @param props\n* @param emit\n* @param options\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useVModels(props, emit, options = {}) {\n\tconst ret = {};\n\tfor (const key in props) ret[key] = useVModel(props, key, emit, options);\n\treturn ret;\n}\n\n//#endregion\n//#region useVibrate/index.ts\nfunction getDefaultScheduler$1(options = { interval: 0 }) {\n\tconst { interval } = options;\n\tif (interval === 0) return;\n\treturn (fn) => useIntervalFn(fn, interval, {\n\t\timmediate: false,\n\t\timmediateCallback: false\n\t});\n}\n/**\n* Reactive vibrate\n*\n* @see https://vueuse.org/useVibrate\n* @see https://developer.mozilla.org/en-US/docs/Web/API/Vibration_API\n* @param options\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useVibrate(options) {\n\tconst { pattern = [], scheduler = getDefaultScheduler$1(options), navigator: navigator$1 = defaultNavigator } = options || {};\n\tconst isSupported = /* @__PURE__ */ useSupported(() => typeof navigator$1 !== \"undefined\" && \"vibrate\" in navigator$1);\n\tconst patternRef = toRef(pattern);\n\tconst vibrate = (pattern$1 = patternRef.value) => {\n\t\tif (isSupported.value) navigator$1.vibrate(pattern$1);\n\t};\n\tconst intervalControls = scheduler === null || scheduler === void 0 ? void 0 : scheduler(vibrate);\n\tconst stop = () => {\n\t\tif (isSupported.value) navigator$1.vibrate(0);\n\t\tintervalControls === null || intervalControls === void 0 || intervalControls.pause();\n\t};\n\treturn {\n\t\tisSupported,\n\t\tpattern,\n\t\tintervalControls,\n\t\tvibrate,\n\t\tstop\n\t};\n}\n\n//#endregion\n//#region useVirtualList/index.ts\n/**\n* Please consider using [`vue-virtual-scroller`](https://github.com/Akryum/vue-virtual-scroller) if you are looking for more features.\n*/\nfunction useVirtualList(list, options) {\n\tconst { containerStyle, wrapperProps, scrollTo, calculateRange, currentList, containerRef } = \"itemHeight\" in options ? useVerticalVirtualList(options, list) : useHorizontalVirtualList(options, list);\n\treturn {\n\t\tlist: currentList,\n\t\tscrollTo,\n\t\tcontainerProps: {\n\t\t\tref: containerRef,\n\t\t\tonScroll: () => {\n\t\t\t\tcalculateRange();\n\t\t\t},\n\t\t\tstyle: containerStyle\n\t\t},\n\t\twrapperProps\n\t};\n}\nfunction useVirtualListResources(list) {\n\tconst containerRef = shallowRef(null);\n\tconst size = useElementSize(containerRef);\n\tconst currentList = ref([]);\n\tconst source = shallowRef(list);\n\treturn {\n\t\tstate: ref({\n\t\t\tstart: 0,\n\t\t\tend: 10\n\t\t}),\n\t\tsource,\n\t\tcurrentList,\n\t\tsize,\n\t\tcontainerRef\n\t};\n}\nfunction createGetViewCapacity(state, source, itemSize) {\n\treturn (containerSize) => {\n\t\tif (typeof itemSize === \"number\") return Math.ceil(containerSize / itemSize);\n\t\tconst { start = 0 } = state.value;\n\t\tlet sum = 0;\n\t\tlet capacity = 0;\n\t\tfor (let i = start; i < source.value.length; i++) {\n\t\t\tconst size = itemSize(i);\n\t\t\tsum += size;\n\t\t\tcapacity = i;\n\t\t\tif (sum > containerSize) break;\n\t\t}\n\t\treturn capacity - start;\n\t};\n}\nfunction createGetOffset(source, itemSize) {\n\treturn (scrollDirection) => {\n\t\tif (typeof itemSize === \"number\") return Math.floor(scrollDirection / itemSize) + 1;\n\t\tlet sum = 0;\n\t\tlet offset = 0;\n\t\tfor (let i = 0; i < source.value.length; i++) {\n\t\t\tconst size = itemSize(i);\n\t\t\tsum += size;\n\t\t\tif (sum >= scrollDirection) {\n\t\t\t\toffset = i;\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t\treturn offset + 1;\n\t};\n}\nfunction createCalculateRange(type, overscan, getOffset, getViewCapacity, { containerRef, state, currentList, source }) {\n\treturn () => {\n\t\tconst element = containerRef.value;\n\t\tif (element) {\n\t\t\tconst offset = getOffset(type === \"vertical\" ? element.scrollTop : element.scrollLeft);\n\t\t\tconst viewCapacity = getViewCapacity(type === \"vertical\" ? element.clientHeight : element.clientWidth);\n\t\t\tconst from = offset - overscan;\n\t\t\tconst to = offset + viewCapacity + overscan;\n\t\t\tstate.value = {\n\t\t\t\tstart: from < 0 ? 0 : from,\n\t\t\t\tend: to > source.value.length ? source.value.length : to\n\t\t\t};\n\t\t\tcurrentList.value = source.value.slice(state.value.start, state.value.end).map((ele, index) => ({\n\t\t\t\tdata: ele,\n\t\t\t\tindex: index + state.value.start\n\t\t\t}));\n\t\t}\n\t};\n}\nfunction createGetDistance(itemSize, source) {\n\treturn (index) => {\n\t\tif (typeof itemSize === \"number\") return index * itemSize;\n\t\treturn source.value.slice(0, index).reduce((sum, _, i) => sum + itemSize(i), 0);\n\t};\n}\nfunction useWatchForSizes(size, list, containerRef, calculateRange) {\n\twatch([\n\t\tsize.width,\n\t\tsize.height,\n\t\t() => toValue(list),\n\t\tcontainerRef\n\t], () => {\n\t\tcalculateRange();\n\t});\n}\nfunction createComputedTotalSize(itemSize, source) {\n\treturn computed(() => {\n\t\tif (typeof itemSize === \"number\") return source.value.length * itemSize;\n\t\treturn source.value.reduce((sum, _, index) => sum + itemSize(index), 0);\n\t});\n}\nconst scrollToDictionaryForElementScrollKey = {\n\thorizontal: \"scrollLeft\",\n\tvertical: \"scrollTop\"\n};\nfunction createScrollTo(type, calculateRange, getDistance, containerRef) {\n\treturn (index) => {\n\t\tif (containerRef.value) {\n\t\t\tcontainerRef.value[scrollToDictionaryForElementScrollKey[type]] = getDistance(index);\n\t\t\tcalculateRange();\n\t\t}\n\t};\n}\nfunction useHorizontalVirtualList(options, list) {\n\tconst resources = useVirtualListResources(list);\n\tconst { state, source, currentList, size, containerRef } = resources;\n\tconst containerStyle = { overflowX: \"auto\" };\n\tconst { itemWidth, overscan = 5 } = options;\n\tconst getViewCapacity = createGetViewCapacity(state, source, itemWidth);\n\tconst calculateRange = createCalculateRange(\"horizontal\", overscan, createGetOffset(source, itemWidth), getViewCapacity, resources);\n\tconst getDistanceLeft = createGetDistance(itemWidth, source);\n\tconst offsetLeft = computed(() => getDistanceLeft(state.value.start));\n\tconst totalWidth = createComputedTotalSize(itemWidth, source);\n\tuseWatchForSizes(size, list, containerRef, calculateRange);\n\treturn {\n\t\tscrollTo: createScrollTo(\"horizontal\", calculateRange, getDistanceLeft, containerRef),\n\t\tcalculateRange,\n\t\twrapperProps: computed(() => {\n\t\t\treturn { style: {\n\t\t\t\theight: \"100%\",\n\t\t\t\twidth: `${totalWidth.value - offsetLeft.value}px`,\n\t\t\t\tmarginLeft: `${offsetLeft.value}px`,\n\t\t\t\tdisplay: \"flex\"\n\t\t\t} };\n\t\t}),\n\t\tcontainerStyle,\n\t\tcurrentList,\n\t\tcontainerRef\n\t};\n}\nfunction useVerticalVirtualList(options, list) {\n\tconst resources = useVirtualListResources(list);\n\tconst { state, source, currentList, size, containerRef } = resources;\n\tconst containerStyle = { overflowY: \"auto\" };\n\tconst { itemHeight, overscan = 5 } = options;\n\tconst getViewCapacity = createGetViewCapacity(state, source, itemHeight);\n\tconst calculateRange = createCalculateRange(\"vertical\", overscan, createGetOffset(source, itemHeight), getViewCapacity, resources);\n\tconst getDistanceTop = createGetDistance(itemHeight, source);\n\tconst offsetTop = computed(() => getDistanceTop(state.value.start));\n\tconst totalHeight = createComputedTotalSize(itemHeight, source);\n\tuseWatchForSizes(size, list, containerRef, calculateRange);\n\treturn {\n\t\tcalculateRange,\n\t\tscrollTo: createScrollTo(\"vertical\", calculateRange, getDistanceTop, containerRef),\n\t\tcontainerStyle,\n\t\twrapperProps: computed(() => {\n\t\t\treturn { style: {\n\t\t\t\twidth: \"100%\",\n\t\t\t\theight: `${totalHeight.value - offsetTop.value}px`,\n\t\t\t\tmarginTop: `${offsetTop.value}px`\n\t\t\t} };\n\t\t}),\n\t\tcurrentList,\n\t\tcontainerRef\n\t};\n}\n\n//#endregion\n//#region useWakeLock/index.ts\n/**\n* Reactive Screen Wake Lock API.\n*\n* @see https://vueuse.org/useWakeLock\n* @param options\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useWakeLock(options = {}) {\n\tconst { navigator: navigator$1 = defaultNavigator, document: document$1 = defaultDocument } = options;\n\tconst requestedType = shallowRef(false);\n\tconst sentinel = shallowRef(null);\n\tconst documentVisibility = useDocumentVisibility({ document: document$1 });\n\tconst isSupported = /* @__PURE__ */ useSupported(() => navigator$1 && \"wakeLock\" in navigator$1);\n\tconst isActive = computed(() => !!sentinel.value && documentVisibility.value === \"visible\");\n\tif (isSupported.value) {\n\t\tuseEventListener(sentinel, \"release\", () => {\n\t\t\tvar _sentinel$value$type, _sentinel$value;\n\t\t\trequestedType.value = (_sentinel$value$type = (_sentinel$value = sentinel.value) === null || _sentinel$value === void 0 ? void 0 : _sentinel$value.type) !== null && _sentinel$value$type !== void 0 ? _sentinel$value$type : false;\n\t\t}, { passive: true });\n\t\twhenever(() => documentVisibility.value === \"visible\" && (document$1 === null || document$1 === void 0 ? void 0 : document$1.visibilityState) === \"visible\" && requestedType.value, (type) => {\n\t\t\trequestedType.value = false;\n\t\t\tforceRequest(type);\n\t\t});\n\t}\n\tasync function forceRequest(type) {\n\t\tvar _sentinel$value2;\n\t\tawait ((_sentinel$value2 = sentinel.value) === null || _sentinel$value2 === void 0 ? void 0 : _sentinel$value2.release());\n\t\tsentinel.value = isSupported.value ? await navigator$1.wakeLock.request(type) : null;\n\t}\n\tasync function request(type) {\n\t\tif (documentVisibility.value === \"visible\") await forceRequest(type);\n\t\telse requestedType.value = type;\n\t}\n\tasync function release() {\n\t\trequestedType.value = false;\n\t\tconst s = sentinel.value;\n\t\tsentinel.value = null;\n\t\tawait (s === null || s === void 0 ? void 0 : s.release());\n\t}\n\treturn {\n\t\tsentinel,\n\t\tisSupported,\n\t\tisActive,\n\t\trequest,\n\t\tforceRequest,\n\t\trelease\n\t};\n}\n\n//#endregion\n//#region useWebNotification/index.ts\n/**\n* Reactive useWebNotification\n*\n* @see https://vueuse.org/useWebNotification\n* @see https://developer.mozilla.org/en-US/docs/Web/API/notification\n*/\nfunction useWebNotification(options = {}) {\n\tconst { window: window$1 = defaultWindow, requestPermissions: _requestForPermissions = true } = options;\n\tconst defaultWebNotificationOptions = options;\n\tconst isSupported = /* @__PURE__ */ useSupported(() => {\n\t\tif (!window$1 || !(\"Notification\" in window$1)) return false;\n\t\tif (Notification.permission === \"granted\") return true;\n\t\ttry {\n\t\t\tconst notification$1 = new Notification(\"\");\n\t\t\tnotification$1.onshow = () => {\n\t\t\t\tnotification$1.close();\n\t\t\t};\n\t\t} catch (e) {\n\t\t\tif (e.name === \"TypeError\") return false;\n\t\t}\n\t\treturn true;\n\t});\n\tconst permissionGranted = shallowRef(isSupported.value && \"permission\" in Notification && Notification.permission === \"granted\");\n\tconst notification = ref(null);\n\tconst ensurePermissions = async () => {\n\t\tif (!isSupported.value) return;\n\t\tif (!permissionGranted.value && Notification.permission !== \"denied\") {\n\t\t\tif (await Notification.requestPermission() === \"granted\") permissionGranted.value = true;\n\t\t}\n\t\treturn permissionGranted.value;\n\t};\n\tconst { on: onClick, trigger: clickTrigger } = createEventHook();\n\tconst { on: onShow, trigger: showTrigger } = createEventHook();\n\tconst { on: onError, trigger: errorTrigger } = createEventHook();\n\tconst { on: onClose, trigger: closeTrigger } = createEventHook();\n\tconst show = async (overrides) => {\n\t\tif (!isSupported.value || !permissionGranted.value) return;\n\t\tconst options$1 = Object.assign({}, defaultWebNotificationOptions, overrides);\n\t\tnotification.value = new Notification(options$1.title || \"\", options$1);\n\t\tnotification.value.onclick = clickTrigger;\n\t\tnotification.value.onshow = showTrigger;\n\t\tnotification.value.onerror = errorTrigger;\n\t\tnotification.value.onclose = closeTrigger;\n\t\treturn notification.value;\n\t};\n\tconst close = () => {\n\t\tif (notification.value) notification.value.close();\n\t\tnotification.value = null;\n\t};\n\tif (_requestForPermissions) tryOnMounted(ensurePermissions);\n\ttryOnScopeDispose(close);\n\tif (isSupported.value && window$1) {\n\t\tconst document$1 = window$1.document;\n\t\tuseEventListener(document$1, \"visibilitychange\", (e) => {\n\t\t\te.preventDefault();\n\t\t\tif (document$1.visibilityState === \"visible\") close();\n\t\t});\n\t}\n\treturn {\n\t\tisSupported,\n\t\tnotification,\n\t\tensurePermissions,\n\t\tpermissionGranted,\n\t\tshow,\n\t\tclose,\n\t\tonClick,\n\t\tonShow,\n\t\tonError,\n\t\tonClose\n\t};\n}\n\n//#endregion\n//#region useWebSocket/index.ts\nconst DEFAULT_PING_MESSAGE = \"ping\";\nfunction resolveNestedOptions(options) {\n\tif (options === true) return {};\n\treturn options;\n}\nfunction getDefaultScheduler(options) {\n\tif (\"interval\" in options) {\n\t\tconst { interval = 1e3 } = options;\n\t\treturn (cb) => useIntervalFn(cb, interval, { immediate: false });\n\t}\n\treturn (cb) => useIntervalFn(cb, 1e3, { immediate: false });\n}\n/**\n* Reactive WebSocket client.\n*\n* @see https://vueuse.org/useWebSocket\n* @param url\n*/\nfunction useWebSocket(url, options = {}) {\n\tconst { onConnected, onDisconnected, onError, onMessage, immediate = true, autoConnect = true, autoClose = true, protocols = [] } = options;\n\tconst data = ref(null);\n\tconst status = shallowRef(\"CLOSED\");\n\tconst wsRef = ref();\n\tconst urlRef = toRef(url);\n\tlet heartbeatPause;\n\tlet heartbeatResume;\n\tlet explicitlyClosed = false;\n\tlet retried = 0;\n\tlet bufferedData = [];\n\tlet retryTimeout;\n\tlet pongTimeoutWait;\n\tconst _sendBuffer = () => {\n\t\tif (bufferedData.length && wsRef.value && status.value === \"OPEN\") {\n\t\t\tfor (const buffer of bufferedData) wsRef.value.send(buffer);\n\t\t\tbufferedData = [];\n\t\t}\n\t};\n\tconst resetRetry = () => {\n\t\tif (retryTimeout != null) {\n\t\t\tclearTimeout(retryTimeout);\n\t\t\tretryTimeout = void 0;\n\t\t}\n\t};\n\tconst resetHeartbeat = () => {\n\t\tclearTimeout(pongTimeoutWait);\n\t\tpongTimeoutWait = void 0;\n\t};\n\tconst close = (code = 1e3, reason) => {\n\t\tresetRetry();\n\t\tif (!isClient && !isWorker || !wsRef.value) return;\n\t\texplicitlyClosed = true;\n\t\tresetHeartbeat();\n\t\theartbeatPause === null || heartbeatPause === void 0 || heartbeatPause();\n\t\twsRef.value.close(code, reason);\n\t\twsRef.value = void 0;\n\t};\n\tconst send = (data$1, useBuffer = true) => {\n\t\tif (!wsRef.value || status.value !== \"OPEN\") {\n\t\t\tif (useBuffer) bufferedData.push(data$1);\n\t\t\treturn false;\n\t\t}\n\t\t_sendBuffer();\n\t\twsRef.value.send(data$1);\n\t\treturn true;\n\t};\n\tconst _init = () => {\n\t\tif (explicitlyClosed || typeof urlRef.value === \"undefined\") return;\n\t\tconst ws = new WebSocket(urlRef.value, protocols);\n\t\twsRef.value = ws;\n\t\tstatus.value = \"CONNECTING\";\n\t\tws.onopen = () => {\n\t\t\tstatus.value = \"OPEN\";\n\t\t\tretried = 0;\n\t\t\tonConnected === null || onConnected === void 0 || onConnected(ws);\n\t\t\theartbeatResume === null || heartbeatResume === void 0 || heartbeatResume();\n\t\t\t_sendBuffer();\n\t\t};\n\t\tws.onclose = (ev) => {\n\t\t\tstatus.value = \"CLOSED\";\n\t\t\tresetHeartbeat();\n\t\t\theartbeatPause === null || heartbeatPause === void 0 || heartbeatPause();\n\t\t\tonDisconnected === null || onDisconnected === void 0 || onDisconnected(ws, ev);\n\t\t\tif (!explicitlyClosed && options.autoReconnect && (wsRef.value == null || ws === wsRef.value)) {\n\t\t\t\tconst { retries = -1, delay = 1e3, onFailed } = resolveNestedOptions(options.autoReconnect);\n\t\t\t\tif ((typeof retries === \"function\" ? retries : () => typeof retries === \"number\" && (retries < 0 || retried < retries))(retried)) {\n\t\t\t\t\tretried += 1;\n\t\t\t\t\tconst delayTime = typeof delay === \"function\" ? delay(retried) : delay;\n\t\t\t\t\tretryTimeout = setTimeout(_init, delayTime);\n\t\t\t\t} else onFailed === null || onFailed === void 0 || onFailed();\n\t\t\t}\n\t\t};\n\t\tws.onerror = (e) => {\n\t\t\tonError === null || onError === void 0 || onError(ws, e);\n\t\t};\n\t\tws.onmessage = (e) => {\n\t\t\tif (options.heartbeat) {\n\t\t\t\tresetHeartbeat();\n\t\t\t\tconst { message = DEFAULT_PING_MESSAGE, responseMessage = message } = resolveNestedOptions(options.heartbeat);\n\t\t\t\tif (e.data === toValue(responseMessage)) return;\n\t\t\t}\n\t\t\tdata.value = e.data;\n\t\t\tonMessage === null || onMessage === void 0 || onMessage(ws, e);\n\t\t};\n\t};\n\tif (options.heartbeat) {\n\t\tconst { message = DEFAULT_PING_MESSAGE, scheduler = getDefaultScheduler(resolveNestedOptions(options.heartbeat)), pongTimeout = 1e3 } = resolveNestedOptions(options.heartbeat);\n\t\tconst { pause, resume } = scheduler(() => {\n\t\t\tsend(toValue(message), false);\n\t\t\tif (pongTimeoutWait != null) return;\n\t\t\tpongTimeoutWait = setTimeout(() => {\n\t\t\t\tclose();\n\t\t\t\texplicitlyClosed = false;\n\t\t\t}, pongTimeout);\n\t\t});\n\t\theartbeatPause = pause;\n\t\theartbeatResume = resume;\n\t}\n\tif (autoClose) {\n\t\tif (isClient) useEventListener(\"beforeunload\", () => close(), { passive: true });\n\t\ttryOnScopeDispose(close);\n\t}\n\tconst open = () => {\n\t\tif (!isClient && !isWorker) return;\n\t\tclose();\n\t\texplicitlyClosed = false;\n\t\tretried = 0;\n\t\t_init();\n\t};\n\tif (immediate) open();\n\tif (autoConnect) watch(urlRef, open);\n\treturn {\n\t\tdata,\n\t\tstatus,\n\t\tclose,\n\t\tsend,\n\t\topen,\n\t\tws: wsRef\n\t};\n}\n\n//#endregion\n//#region useWebWorker/index.ts\nfunction useWebWorker(arg0, workerOptions, options) {\n\tconst { window: window$1 = defaultWindow } = options !== null && options !== void 0 ? options : {};\n\tconst data = ref(null);\n\tconst worker = shallowRef();\n\tconst post = (...args) => {\n\t\tif (!worker.value) return;\n\t\tworker.value.postMessage(...args);\n\t};\n\tconst terminate = function terminate$1() {\n\t\tif (!worker.value) return;\n\t\tworker.value.terminate();\n\t};\n\tif (window$1) {\n\t\tif (typeof arg0 === \"string\") worker.value = new Worker(arg0, workerOptions);\n\t\telse if (typeof arg0 === \"function\") worker.value = arg0();\n\t\telse worker.value = arg0;\n\t\tworker.value.onmessage = (e) => {\n\t\t\tdata.value = e.data;\n\t\t};\n\t\ttryOnScopeDispose(() => {\n\t\t\tif (worker.value) worker.value.terminate();\n\t\t});\n\t}\n\treturn {\n\t\tdata,\n\t\tpost,\n\t\tterminate,\n\t\tworker\n\t};\n}\n\n//#endregion\n//#region useWebWorkerFn/lib/depsParser.ts\n/**\n*\n* Concatenates the dependencies into a comma separated string.\n* this string will then be passed as an argument to the \"importScripts\" function\n*\n* @param deps array of string\n* @param localDeps array of function\n* @returns a string composed by the concatenation of the array\n* elements \"deps\" and \"importScripts\".\n*\n* @example\n* depsParser(['demo1', 'demo2']) // return importScripts('demo1', 'demo2')\n*/\nfunction depsParser(deps, localDeps) {\n\tif (deps.length === 0 && localDeps.length === 0) return \"\";\n\tconst depsString = deps.map((dep) => `'${dep}'`).toString();\n\tconst depsFunctionString = localDeps.filter((dep) => typeof dep === \"function\").map((fn) => {\n\t\tconst str = fn.toString();\n\t\tif (str.trim().startsWith(\"function\")) return str;\n\t\telse return `const ${fn.name} = ${str}`;\n\t}).join(\";\");\n\tconst importString = `importScripts(${depsString});`;\n\treturn `${depsString.trim() === \"\" ? \"\" : importString} ${depsFunctionString}`;\n}\nvar depsParser_default = depsParser;\n\n//#endregion\n//#region useWebWorkerFn/lib/jobRunner.ts\n/**\n* This function accepts as a parameter a function \"userFunc\"\n* And as a result returns an anonymous function.\n* This anonymous function, accepts as arguments,\n* the parameters to pass to the function \"useArgs\" and returns a Promise\n* This function can be used as a wrapper, only inside a Worker\n* because it depends by \"postMessage\".\n*\n* @param userFunc {Function} fn the function to run with web worker\n*\n* @returns returns a function that accepts the parameters\n* to be passed to the \"userFunc\" function\n*/\nfunction jobRunner(userFunc) {\n\treturn (e) => {\n\t\tconst userFuncArgs = e.data[0];\n\t\treturn Promise.resolve(userFunc.apply(void 0, userFuncArgs)).then((result) => {\n\t\t\tpostMessage([\"SUCCESS\", result]);\n\t\t}).catch((error) => {\n\t\t\tpostMessage([\"ERROR\", error]);\n\t\t});\n\t};\n}\nvar jobRunner_default = jobRunner;\n\n//#endregion\n//#region useWebWorkerFn/lib/createWorkerBlobUrl.ts\n/**\n* Converts the \"fn\" function into the syntax needed to be executed within a web worker\n*\n* @param fn the function to run with web worker\n* @param deps array of strings, imported into the worker through \"importScripts\"\n* @param localDeps array of function, local dependencies\n*\n* @returns a blob url, containing the code of \"fn\" as a string\n*\n* @example\n* createWorkerBlobUrl((a,b) => a+b, [])\n* // return \"onmessage=return Promise.resolve((a,b) => a + b)\n* .then(postMessage(['SUCCESS', result]))\n* .catch(postMessage(['ERROR', error])\"\n*/\nfunction createWorkerBlobUrl(fn, deps, localDeps) {\n\tconst blobCode = `${depsParser_default(deps, localDeps)}; onmessage=(${jobRunner_default})(${fn})`;\n\tconst blob = new Blob([blobCode], { type: \"text/javascript\" });\n\treturn URL.createObjectURL(blob);\n}\nvar createWorkerBlobUrl_default = createWorkerBlobUrl;\n\n//#endregion\n//#region useWebWorkerFn/index.ts\n/**\n* Run expensive function without blocking the UI, using a simple syntax that makes use of Promise.\n*\n* @see https://vueuse.org/useWebWorkerFn\n* @param fn\n* @param options\n*/\nfunction useWebWorkerFn(fn, options = {}) {\n\tconst { dependencies = [], localDependencies = [], timeout, window: window$1 = defaultWindow } = options;\n\tconst worker = ref();\n\tconst workerStatus = shallowRef(\"PENDING\");\n\tconst promise = ref({});\n\tconst timeoutId = shallowRef();\n\tconst workerTerminate = (status = \"PENDING\") => {\n\t\tif (worker.value && worker.value._url && window$1) {\n\t\t\tworker.value.terminate();\n\t\t\tURL.revokeObjectURL(worker.value._url);\n\t\t\tpromise.value = {};\n\t\t\tworker.value = void 0;\n\t\t\twindow$1.clearTimeout(timeoutId.value);\n\t\t\tworkerStatus.value = status;\n\t\t}\n\t};\n\tworkerTerminate();\n\ttryOnScopeDispose(workerTerminate);\n\tconst generateWorker = () => {\n\t\tconst blobUrl = createWorkerBlobUrl_default(fn, dependencies, localDependencies);\n\t\tconst newWorker = new Worker(blobUrl);\n\t\tnewWorker._url = blobUrl;\n\t\tnewWorker.onmessage = (e) => {\n\t\t\tconst { resolve = () => {}, reject = () => {} } = promise.value;\n\t\t\tconst [status, result] = e.data;\n\t\t\tswitch (status) {\n\t\t\t\tcase \"SUCCESS\":\n\t\t\t\t\tresolve(result);\n\t\t\t\t\tworkerTerminate(status);\n\t\t\t\t\tbreak;\n\t\t\t\tdefault:\n\t\t\t\t\treject(result);\n\t\t\t\t\tworkerTerminate(\"ERROR\");\n\t\t\t\t\tbreak;\n\t\t\t}\n\t\t};\n\t\tnewWorker.onerror = (e) => {\n\t\t\tconst { reject = () => {} } = promise.value;\n\t\t\te.preventDefault();\n\t\t\treject(e);\n\t\t\tworkerTerminate(\"ERROR\");\n\t\t};\n\t\tif (timeout) timeoutId.value = setTimeout(() => workerTerminate(\"TIMEOUT_EXPIRED\"), timeout);\n\t\treturn newWorker;\n\t};\n\tconst callWorker = (...fnArgs) => new Promise((resolve, reject) => {\n\t\tvar _worker$value;\n\t\tpromise.value = {\n\t\t\tresolve,\n\t\t\treject\n\t\t};\n\t\t(_worker$value = worker.value) === null || _worker$value === void 0 || _worker$value.postMessage([[...fnArgs]]);\n\t\tworkerStatus.value = \"RUNNING\";\n\t});\n\tconst workerFn = (...fnArgs) => {\n\t\tif (workerStatus.value === \"RUNNING\") {\n\t\t\tconsole.error(\"[useWebWorkerFn] You can only run one instance of the worker at a time.\");\n\t\t\treturn Promise.reject();\n\t\t}\n\t\tworker.value = generateWorker();\n\t\treturn callWorker(...fnArgs);\n\t};\n\treturn {\n\t\tworkerFn,\n\t\tworkerStatus,\n\t\tworkerTerminate\n\t};\n}\n\n//#endregion\n//#region useWindowFocus/index.ts\n/**\n* Reactively track window focus with `window.onfocus` and `window.onblur`.\n*\n* @see https://vueuse.org/useWindowFocus\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useWindowFocus(options = {}) {\n\tconst { window: window$1 = defaultWindow } = options;\n\tif (!window$1) return shallowRef(false);\n\tconst focused = shallowRef(window$1.document.hasFocus());\n\tconst listenerOptions = { passive: true };\n\tuseEventListener(window$1, \"blur\", () => {\n\t\tfocused.value = false;\n\t}, listenerOptions);\n\tuseEventListener(window$1, \"focus\", () => {\n\t\tfocused.value = true;\n\t}, listenerOptions);\n\treturn focused;\n}\n\n//#endregion\n//#region useWindowScroll/index.ts\n/**\n* Reactive window scroll.\n*\n* @see https://vueuse.org/useWindowScroll\n* @param options\n*/\nfunction useWindowScroll(options = {}) {\n\tconst { window: window$1 = defaultWindow,...rest } = options;\n\treturn useScroll(window$1, rest);\n}\n\n//#endregion\n//#region useWindowSize/index.ts\n/**\n* Reactive window size.\n*\n* @see https://vueuse.org/useWindowSize\n* @param options\n*\n* @__NO_SIDE_EFFECTS__\n*/\nfunction useWindowSize(options = {}) {\n\tconst { window: window$1 = defaultWindow, initialWidth = Number.POSITIVE_INFINITY, initialHeight = Number.POSITIVE_INFINITY, listenOrientation = true, includeScrollbar = true, type = \"inner\" } = options;\n\tconst width = shallowRef(initialWidth);\n\tconst height = shallowRef(initialHeight);\n\tconst update = () => {\n\t\tif (window$1) if (type === \"outer\") {\n\t\t\twidth.value = window$1.outerWidth;\n\t\t\theight.value = window$1.outerHeight;\n\t\t} else if (type === \"visual\" && window$1.visualViewport) {\n\t\t\tconst { width: visualViewportWidth, height: visualViewportHeight, scale } = window$1.visualViewport;\n\t\t\twidth.value = Math.round(visualViewportWidth * scale);\n\t\t\theight.value = Math.round(visualViewportHeight * scale);\n\t\t} else if (includeScrollbar) {\n\t\t\twidth.value = window$1.innerWidth;\n\t\t\theight.value = window$1.innerHeight;\n\t\t} else {\n\t\t\twidth.value = window$1.document.documentElement.clientWidth;\n\t\t\theight.value = window$1.document.documentElement.clientHeight;\n\t\t}\n\t};\n\tupdate();\n\ttryOnMounted(update);\n\tconst listenerOptions = { passive: true };\n\tuseEventListener(\"resize\", update, listenerOptions);\n\tif (window$1 && type === \"visual\" && window$1.visualViewport) useEventListener(window$1.visualViewport, \"resize\", update, listenerOptions);\n\tif (listenOrientation) watch(useMediaQuery(\"(orientation: portrait)\"), () => update());\n\treturn {\n\t\twidth,\n\t\theight\n\t};\n}\n\n//#endregion\nexport { DefaultMagicKeysAliasMap, StorageSerializers, TransitionPresets, asyncComputed, breakpointsAntDesign, breakpointsBootstrapV5, breakpointsElement, breakpointsMasterCss, breakpointsPrimeFlex, breakpointsQuasar, breakpointsSematic, breakpointsTailwind, breakpointsVuetify, breakpointsVuetifyV2, breakpointsVuetifyV3, cloneFnJSON, computedAsync, computedInject, createFetch, createReusableTemplate, createTemplatePromise, createUnrefFn, customStorageEventName, defaultDocument, defaultLocation, defaultNavigator, defaultWindow, executeTransition, formatTimeAgo, formatTimeAgoIntl, formatTimeAgoIntlParts, getSSRHandler, mapGamepadToXbox360Controller, onClickOutside, onElementRemoval, onKeyDown, onKeyPressed, onKeyStroke, onKeyUp, onLongPress, onStartTyping, provideSSRWidth, setSSRHandler, templateRef, transition, unrefElement, useActiveElement, useAnimate, useAsyncQueue, useAsyncState, useBase64, useBattery, useBluetooth, useBreakpoints, useBroadcastChannel, useBrowserLocation, useCached, useClipboard, useClipboardItems, useCloned, useColorMode, useConfirmDialog, useCountdown, useCssSupports, useCssVar, useCurrentElement, useCycleList, useDark, useDebouncedRefHistory, useDeviceMotion, useDeviceOrientation, useDevicePixelRatio, useDevicesList, useDisplayMedia, useDocumentVisibility, useDraggable, useDropZone, useElementBounding, useElementByPoint, useElementHover, useElementSize, useElementVisibility, useEventBus, useEventListener, useEventSource, useEyeDropper, useFavicon, useFetch, useFileDialog, useFileSystemAccess, useFocus, useFocusWithin, useFps, useFullscreen, useGamepad, useGeolocation, useIdle, useImage, useInfiniteScroll, useIntersectionObserver, useKeyModifier, useLocalStorage, useMagicKeys, useManualRefHistory, useMediaControls, useMediaQuery, useMemoize, useMemory, useMounted, useMouse, useMouseInElement, useMousePressed, useMutationObserver, useNavigatorLanguage, useNetwork, useNow, useObjectUrl, useOffsetPagination, useOnline, usePageLeave, useParallax, useParentElement, usePerformanceObserver, usePermission, usePointer, usePointerLock, usePointerSwipe, usePreferredColorScheme, usePreferredContrast, usePreferredDark, usePreferredLanguages, usePreferredReducedMotion, usePreferredReducedTransparency, usePrevious, useRafFn, useRefHistory, useResizeObserver, useSSRWidth, useScreenOrientation, useScreenSafeArea, useScriptTag, useScroll, useScrollLock, useSessionStorage, useShare, useSorted, useSpeechRecognition, useSpeechSynthesis, useStepper, useStorage, useStorageAsync, useStyleTag, useSupported, useSwipe, useTemplateRefsList, useTextDirection, useTextSelection, useTextareaAutosize, useThrottledRefHistory, useTimeAgo, useTimeAgoIntl, useTimeoutPoll, useTimestamp, useTitle, useTransition, useUrlSearchParams, useUserMedia, useVModel, useVModels, useVibrate, useVirtualList, useWakeLock, useWebNotification, useWebSocket, useWebWorker, useWebWorkerFn, useWindowFocus, useWindowScroll, useWindowSize };","import { notNullish } from \"@vueuse/shared\";\nimport { computed, shallowRef, toValue, watch } from \"vue\";\nimport { toArray, tryOnScopeDispose as tryOnScopeDispose$1, unrefElement } from \"@vueuse/core\";\nimport { createFocusTrap } from \"focus-trap\";\n\n//#region useFocusTrap/index.ts\n/**\n* Reactive focus-trap\n*\n* @see https://vueuse.org/useFocusTrap\n*/\nfunction useFocusTrap(target, options = {}) {\n\tlet trap;\n\tconst { immediate,...focusTrapOptions } = options;\n\tconst hasFocus = shallowRef(false);\n\tconst isPaused = shallowRef(false);\n\tconst activate = (opts) => trap && trap.activate(opts);\n\tconst deactivate = (opts) => trap && trap.deactivate(opts);\n\tconst pause = () => {\n\t\tif (trap) {\n\t\t\ttrap.pause();\n\t\t\tisPaused.value = true;\n\t\t}\n\t};\n\tconst unpause = () => {\n\t\tif (trap) {\n\t\t\ttrap.unpause();\n\t\t\tisPaused.value = false;\n\t\t}\n\t};\n\twatch(computed(() => {\n\t\treturn toArray(toValue(target)).map((el) => {\n\t\t\tconst _el = toValue(el);\n\t\t\treturn typeof _el === \"string\" ? _el : unrefElement(_el);\n\t\t}).filter(notNullish);\n\t}), (els) => {\n\t\tif (!els.length) return;\n\t\tif (!trap) {\n\t\t\ttrap = createFocusTrap(els, {\n\t\t\t\t...focusTrapOptions,\n\t\t\t\tonActivate() {\n\t\t\t\t\thasFocus.value = true;\n\t\t\t\t\tif (options.onActivate) options.onActivate();\n\t\t\t\t},\n\t\t\t\tonDeactivate() {\n\t\t\t\t\thasFocus.value = false;\n\t\t\t\t\tif (options.onDeactivate) options.onDeactivate();\n\t\t\t\t}\n\t\t\t});\n\t\t\tif (immediate) activate();\n\t\t} else {\n\t\t\tconst isActive = trap === null || trap === void 0 ? void 0 : trap.active;\n\t\t\ttrap === null || trap === void 0 || trap.updateContainerElements(els);\n\t\t\tif (!isActive && immediate) activate();\n\t\t}\n\t}, { flush: \"post\" });\n\ttryOnScopeDispose$1(() => deactivate());\n\treturn {\n\t\thasFocus,\n\t\tisPaused,\n\t\tactivate,\n\t\tdeactivate,\n\t\tpause,\n\t\tunpause\n\t};\n}\n\n//#endregion\nexport { useFocusTrap as t };","import { t as useFocusTrap } from \"../useFocusTrap-lXZ_YG-8.js\";\nimport { defineComponent, h, reactive, shallowRef } from \"vue\";\n\n//#region useFocusTrap/component.ts\nconst UseFocusTrap = /* @__PURE__ */ defineComponent((props, { slots }) => {\n\tconst target = shallowRef();\n\tconst data = reactive(useFocusTrap(target, props.options));\n\treturn () => {\n\t\tif (slots.default) return h(props.as || \"div\", { ref: target }, slots.default(data));\n\t};\n}, {\n\tname: \"UseFocusTrap\",\n\tprops: [\"as\", \"options\"]\n});\n\n//#endregion\nexport { UseFocusTrap };","<template lang=\"pug\">\n.dito-dialog(\n  ref=\"dialog\"\n  role=\"dialog\"\n  aria-expanded=\"true\"\n  aria-modal=\"true\"\n  :style=\"{ '--width': settings.width ? `${settings.width}px` : null }\"\n  @mouseup=\"onMouseUp\"\n)\n  UseFocusTrap.dito-dialog__focus-trap(:options=\"focusTrapOptions\")\n    form.dito-scroll-parent(\n      @submit.prevent=\"submit\"\n      @keydown.enter=\"onEnter\"\n    )\n      // Add an invisible button that prevents the clearable buttons from being\n      // pressed when the user presses the Enter key:\n      button(\n        v-show=\"false\"\n      )\n      DitoSchema(\n        :schema=\"schema\"\n        :data=\"dialogData\"\n        padding=\"root\"\n        scrollable\n        generateLabels\n      )\n        template(#buttons)\n          DitoButtons.dito-buttons--large(\n            :buttons=\"buttonSchemas\"\n            :data=\"dialogData\"\n          )\n</template>\n\n<script>\nimport { clone } from '@ditojs/utils'\nimport DitoComponent from '../DitoComponent.js'\nimport DomMixin from '../mixins/DomMixin.js'\nimport { getButtonSchemas } from '../utils/schema.js'\nimport { UseFocusTrap } from '@vueuse/integrations/useFocusTrap/component'\n\n// @vue/component\nexport default DitoComponent.component('DitoDialog', {\n  mixins: [DomMixin],\n  components: { UseFocusTrap },\n  emits: ['remove'],\n\n  provide() {\n    return {\n      $dialogComponent: () => this\n    }\n  },\n\n  props: {\n    components: { type: Object, required: true },\n    buttons: { type: Object, required: true },\n    promise: { type: Object, required: true },\n    data: { type: Object, default: () => ({}) },\n    settings: {\n      type: Object,\n      default: () => ({\n        width: 480,\n        clickToClose: false\n      })\n    }\n  },\n\n  data() {\n    // Make sure dialog data contains all the expected keys\n    const dialogData = clone(this.data)\n    for (const key in this.components) {\n      if (!(key in dialogData)) {\n        dialogData[key] = null\n      }\n    }\n    return {\n      dialogData\n    }\n  },\n\n  computed: {\n    dialogComponent() {\n      return this\n    },\n\n    schema() {\n      return {\n        type: 'dialog',\n        components: this.components\n      }\n    },\n\n    buttonSchemas() {\n      return Object.fromEntries(\n        Object.entries(getButtonSchemas(this.buttons)).map(\n          // Process the button schemas to add default click events\n          // for both 'submit' and 'cancel' buttons:\n          ([key, schema]) => {\n            if (key === 'cancel' && !schema.events) {\n              schema = {\n                ...schema,\n                events: {\n                  click: () => this.cancel()\n                }\n              }\n            }\n            return [key, schema]\n          }\n        )\n      )\n    },\n\n    focusTrapOptions() {\n      return {\n        immediate: true,\n        fallbackFocus: () => this.$refs.dialog,\n        onDeactivate: this.cancel\n      }\n    },\n\n    hasButtons() {\n      return Object.keys(this.buttonSchemas).length > 0\n    },\n\n    hasCancel() {\n      return !!this.buttonSchemas.cancel\n    }\n  },\n\n  mounted() {\n    this.domOn(window, {\n      keyup: event => {\n        if ((this.hasCancel || !this.hasButtons) && event.keyCode === 27) {\n          this.cancel()\n        }\n      }\n    })\n  },\n\n  methods: {\n    remove() {\n      this.$emit('remove')\n    },\n\n    resolve(value) {\n      this.promise.resolve(value)\n      this.remove()\n    },\n\n    reject(value) {\n      this.promise.reject(value)\n      this.remove()\n    },\n\n    onEnter(event) {\n      // Handle Enter key on input fields to submit the form. This also handles\n      // password managers (e.g. 1Password) that simulate an untrusted Enter\n      // keypress to submit, which browsers ignore.\n      if (event.target instanceof HTMLInputElement) {\n        this.submit()\n      }\n    },\n\n    submit() {\n      this.resolve(this.dialogData)\n    },\n\n    cancel() {\n      // When cancelling, resolve as `undefined` so we can have dialogs\n      // returning null as a defined value as well.\n      this.resolve(undefined)\n    },\n\n    close() {\n      this.cancel()\n    },\n\n    onMouseUp() {\n      if (this.settings.clickToClose) {\n        this.close()\n      }\n    }\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-dialog {\n  position: fixed;\n  display: flex;\n  inset: 0;\n  z-index: $z-index-dialog;\n  padding: $content-padding;\n  align-items: center;\n  justify-content: center;\n  // Prevent scrolling of the page behind the dialog:\n  overflow: hidden;\n  background: rgb(0, 0, 0, 0.2);\n\n  &__focus-trap {\n    display: flex;\n    max-height: 100%;\n  }\n\n  // Place cancel button visually first even though submit comes first in DOM,\n  // so that password managers (e.g. 1Password) find the submit button first.\n  .dito-container:has(.dito-button--cancel) {\n    order: -1;\n  }\n\n  // TODO: `&__inner`\n  form {\n    position: relative;\n    display: flex;\n    box-sizing: border-box;\n    background: white;\n    border-radius: $border-radius;\n    max-width: var(--width, 480px);\n    max-height: 100%;\n    box-shadow: 0 20px 60px -2px rgb(27, 33, 58, 0.4);\n  }\n}\n\n.dito-dialog-enter-active,\n.dito-dialog-leave-active {\n  transition: opacity 0.15s;\n\n  form {\n    transition: transform 0.25s;\n  }\n}\n\n.dito-dialog-enter-from,\n.dito-dialog-leave-to {\n  opacity: 0;\n\n  form {\n    transform: translateY(-20px);\n  }\n}\n</style>\n","<template lang=\"pug\">\n.dito-root(\n  :data-agent-browser=\"appState.agent.browser\"\n  :data-agent-platform=\"appState.agent.platform\"\n  :data-agent-version=\"appState.agent.versionNumber\"\n)\n  Transition(name=\"dito-drag\")\n    .dito-drag-overlay(\n      v-if=\"isDraggingFiles\"\n    )\n  TransitionGroup(name=\"dito-dialog\")\n    DitoDialog(\n      v-for=\"(dialog, key) in dialogs\"\n      :key=\"key\"\n      :components=\"dialog.components\"\n      :buttons=\"dialog.buttons\"\n      :promise=\"dialog.promise\"\n      :data=\"dialog.data\"\n      :settings=\"dialog.settings\"\n      @remove=\"removeDialog(key)\"\n    )\n  DitoNavigation\n  main.dito-page.dito-scroll-parent(\n    v-resize=\"onResizePage\"\n    :class=\"pageClasses\"\n  )\n    DitoHeader(\n      :spinner=\"options.spinner\"\n      :isLoading=\"isLoading\"\n    )\n    RouterView\n  DitoSidebar\n    DitoAccount(\n      v-if=\"user\"\n    )\n    a.dito-login(\n      v-else-if=\"allowLogin\"\n      @click=\"rootComponent.login()\"\n    )\n      span Login\n  DitoNotifications(ref=\"notifications\")\n</template>\n\n<script>\nimport { delegate as tippyDelegate } from 'tippy.js'\nimport { mapConcurrently } from '@ditojs/utils'\nimport DitoComponent from '../DitoComponent.js'\nimport DomMixin from '../mixins/DomMixin.js'\nimport DitoUser from '../DitoUser.js'\nimport DitoView from '../components/DitoView.vue'\nimport DitoDialog from './DitoDialog.vue'\nimport {\n  processView,\n  resolveViews,\n  processSchemaComponents\n} from '../utils/schema.js'\n\n// @vue/component\nexport default DitoComponent.component('DitoRoot', {\n  mixins: [DomMixin],\n  components: { DitoDialog },\n\n  provide() {\n    return {\n      $views: () => this.resolvedViews\n    }\n  },\n\n  props: {\n    unresolvedViews: { type: [Object, Function, Promise], required: true },\n    options: { type: Object, default: () => ({}) }\n  },\n\n  data() {\n    return {\n      resolvedViews: {},\n      removeRoutes: null,\n      dialogs: {},\n      pageWidth: 0,\n      loadingCount: 0,\n      allowLogin: false,\n      isDraggingFiles: false\n    }\n  },\n\n  computed: {\n    notifications() {\n      return this.isMounted && this.$refs.notifications\n    },\n\n    isLoading() {\n      return this.loadingCount > 0\n    },\n\n    pageClasses() {\n      const prefix = 'dito-page'\n      // NOTE: Keep synced with $content-width in SCSS:\n      const contentWidth = 900\n      return [\n        this.appState.pageClass,\n        {\n          [`${prefix}--width-80`]: this.pageWidth <= contentWidth * 0.8,\n          [`${prefix}--width-60`]: this.pageWidth <= contentWidth * 0.6\n        }\n      ]\n    }\n  },\n\n  created() {\n    this.appState.title = document.title || 'Dito.js Admin'\n    // With hot-reloading, it looks like destroyed hooks aren't always called\n    // for route components so reset the array of registered components instead.\n    this.appState.routeComponents = []\n  },\n\n  async mounted() {\n    this.setupDragAndDrop()\n\n    tippyDelegate(this.$el, {\n      target: '.dito-info',\n      theme: 'info',\n      animation: 'shift-away-subtle',\n      interactive: true,\n      delay: 250,\n      zIndex: 1,\n      appendTo: node => node.closest('.dito-pane'),\n      onShow: instance => instance.setContent(instance.reference.dataset.info)\n    })\n\n    // Clear the label marked as active on all mouse and keyboard events, except\n    // the ones that DitoLabel itself intercepts.\n    this.domOn(document, {\n      click: event => {\n        if (!event.target.closest('.dito-label')) {\n          this.appState.activeLabel = null\n        }\n      },\n\n      keyup: event => {\n        if (event.code === 'Tab') {\n          this.appState.activeLabel = null\n        }\n      }\n    })\n\n    try {\n      this.allowLogin = false\n      if (await this.fetchUser()) {\n        await this.resolveViews()\n      } else {\n        await this.login()\n      }\n    } catch (err) {\n      console.error(err)\n    }\n    this.allowLogin = true\n  },\n\n  methods: {\n    setupDragAndDrop() {\n      // This code only happens the visual effects around dragging and dropping\n      // files into a `DitoTypeUpload` component. The actual uploading is\n      // handled by the `DitoTypeUpload` component itself.\n\n      let dragCount = 0\n      let uploads = []\n\n      const toggleDropTargetClass = enabled => {\n        for (const upload of uploads) {\n          upload\n            .closest('.dito-container')\n            .classList.toggle('dito-drop-target', enabled)\n        }\n        if (!enabled) {\n          uploads = []\n        }\n      }\n\n      const setDraggingFiles = enabled => {\n        this.isDraggingFiles = enabled\n        if (enabled) {\n          toggleDropTargetClass(true)\n        } else {\n          setTimeout(() => toggleDropTargetClass(false), 150)\n        }\n      }\n\n      this.domOn(document, {\n        dragenter: event => {\n          if (!dragCount && event.dataTransfer) {\n            uploads = document.querySelectorAll('.dito-upload')\n            const hasUploads = uploads.length > 0\n            event.dataTransfer.effectAllowed = hasUploads ? 'copy' : 'none'\n            if (hasUploads) {\n              setDraggingFiles(true)\n            } else {\n              event.preventDefault()\n              event.stopPropagation()\n              return\n            }\n          }\n          dragCount++\n        },\n\n        dragleave: event => {\n          dragCount--\n          if (!dragCount && event.dataTransfer) {\n            setDraggingFiles(false)\n          }\n        },\n\n        dragover: event => {\n          if (event.dataTransfer) {\n            const canDrop = event.target.closest(\n              '.dito-container:has(.dito-upload)'\n            )\n            event.dataTransfer.dropEffect = canDrop ? 'copy' : 'none'\n            if (!canDrop) {\n              event.preventDefault()\n              event.stopPropagation()\n            }\n          }\n        },\n\n        drop: event => {\n          dragCount = 0\n          if (event.dataTransfer) {\n            setDraggingFiles(false)\n          }\n        }\n      })\n    },\n\n    notify({ type = 'info', title, text, error, duration } = {}) {\n      this.notifications.notify({ type, title, text, error, duration })\n    },\n\n    closeNotifications() {\n      this.notifications.destroyAll()\n    },\n\n    registerLoading(isLoading) {\n      this.loadingCount += isLoading ? 1 : -1\n    },\n\n    showDialog({ components, buttons, data, settings }) {\n      // Shows a dito-dialog component and wraps it in a promise so that the\n      // buttons in the dialog can use `dialog.resolve()` and `dialog.reject()`\n      // to close the modal dialog and resolve / reject the promise at once.\n      return new Promise(\n        async (resolve, reject) => {\n          // Process components to resolve async schemas.\n          const routes = []\n          await processSchemaComponents(\n            this.api,\n            { type: 'dialog', components },\n            routes,\n            0\n          )\n          if (routes.length > 0) {\n            throw new Error(\n              'Dialogs do not support components that produce routes'\n            )\n          }\n          const key = `dialog-${++dialogId}`\n          this.dialogs[key] = {\n            components,\n            buttons,\n            data,\n            settings,\n            promise: { resolve, reject }\n          }\n        }\n      )\n    },\n\n    removeDialog(key) {\n      delete this.dialogs[key]\n    },\n\n    async login() {\n      this.allowLogin = true\n      const {\n        additionalComponents,\n        redirectAfterLogin\n      } = this.options.login || {}\n      const loginData = await this.showDialog({\n        components: {\n          username: {\n            type: 'text',\n            autofocus: true\n          },\n          password: {\n            type: 'password'\n          },\n          ...additionalComponents\n        },\n        // NOTE: Login must come before cancel in DOM order so that password\n        // managers (e.g. 1Password) target the submit button instead of cancel.\n        // DitoDialog uses CSS order to visually place cancel first.\n        buttons: {\n          login: {\n            type: 'submit',\n            text: 'Login'\n          },\n\n          cancel: {\n            type: 'button',\n            text: 'Cancel'\n            // NOTE: The click event is added in DitoDialog.buttonSchemas()\n          }\n        }\n      })\n      if (loginData) {\n        try {\n          const response = await this.sendRequest({\n            resource: this.api.users.login,\n            data: loginData,\n            internal: true\n          })\n          if (redirectAfterLogin) {\n            location.replace(redirectAfterLogin)\n          } else {\n            this.setUser(response.data.user)\n            await this.resolveViews()\n          }\n        } catch (err) {\n          const error = err.response?.data?.error || err\n          this.notify({\n            type: 'error',\n            error,\n            title: 'Authentication Error',\n            text: error\n          })\n          this.login()\n        }\n      }\n    },\n\n    navigateHome() {\n      return this.navigate('/')\n    },\n\n    async logout() {\n      try {\n        const response = await this.sendRequest({\n          resource: this.api.users.logout,\n          internal: true\n        })\n        if (response.data.success) {\n          this.setUser(null)\n          this.navigateHome()\n        }\n      } catch (err) {\n        console.error(err)\n      }\n    },\n\n    async fetchUser() {\n      let user = null\n      try {\n        const response = await this.sendRequest({\n          resource: this.api.users.session,\n          internal: true\n        })\n        user = response.data.user || null\n      } catch (err) {\n        const error = err.response?.data?.error || err\n        this.notify({\n          type: 'error',\n          error,\n          title: 'Authentication Error',\n          text: error\n        })\n      }\n      this.setUser(user)\n      return user\n    },\n\n    setUser(user) {\n      this.appState.user = (\n        user &&\n        Object.setPrototypeOf(user, DitoUser.prototype)\n      )\n      // Clear resolved views when user is logged out.\n      if (!user) {\n        this.resolvedViews = {}\n        this.navigateHome()\n      }\n    },\n\n    async ensureUser() {\n      if (!(await this.fetchUser())) {\n        await this.login()\n      }\n    },\n\n    async resolveViews() {\n      try {\n        this.resolvedViews = await resolveViews(this.unresolvedViews)\n      } catch (error) {\n        if (!error.request) {\n          console.error(error)\n        }\n        return this.login()\n      }\n      // Collect all routes from the root schema components\n      const routes = await mapConcurrently(\n        Object.entries(this.resolvedViews),\n        ([name, schema]) => processView(DitoView, this.api, schema, name)\n      )\n      // Now that the routes are loaded, replace all existing routes with the\n      // new routes, and restore the current path.\n      const { fullPath } = this.$route\n      this.removeRoutes?.()\n      this.removeRoutes = addRoutes(this.$router, [\n        {\n          name: 'root',\n          path: '/',\n          components: {}\n        },\n        ...routes.flat()\n      ])\n      this.$router.replace(fullPath)\n    },\n\n    onResizePage({ contentRect: { width } }) {\n      this.pageWidth = width\n    }\n  }\n})\n\nlet dialogId = 0\n\nfunction addRoutes(router, routes) {\n  const removers = []\n  for (const route of routes) {\n    removers.push(\n      router.addRoute(route)\n    )\n  }\n\n  return () => {\n    for (const remove of removers) {\n      remove()\n    }\n  }\n}\n</script>\n\n<style lang=\"scss\">\n@import '../styles/style';\n\n.dito-app,\n.dito-root {\n  width: 100%;\n  height: 100%;\n  display: flex;\n}\n\n.dito-page {\n  --max-content-width: #{$content-width};\n  --max-page-width: calc(var(--max-content-width) + 2 * #{$content-padding});\n\n  flex: 0 1 var(--max-page-width);\n  background: $content-color-background;\n  min-width: 0%;\n  max-width: var(--max-page-width);\n  overflow: visible; // For .dito-header full-width background.\n\n  &--wide {\n    --max-content-width: #{$content-width-wide};\n  }\n}\n\n.dito-account,\n.dito-login {\n  cursor: pointer;\n}\n\n.dito-drag-overlay {\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100%;\n  height: 100%;\n  z-index: $z-index-drag-overlay;\n  background: rgb(0, 0, 0, 0.25);\n  pointer-events: none;\n  backdrop-filter: blur(8px);\n}\n\n.dito-drop-target {\n  --shadow-alpha: 0.25;\n\n  background: $content-color-background;\n  border-radius: $border-radius;\n  z-index: $z-index-drag-overlay + 1;\n  filter: drop-shadow(0 4px 8px rgb(0, 0, 0, var(--shadow-alpha)));\n}\n\n.dito-drag-enter-active,\n.dito-drag-leave-active {\n  $duration: 0.15s;\n\n  transition:\n    opacity $duration,\n    backdrop-filter $duration;\n\n  ~ * .dito-drop-target {\n    transition: filter $duration;\n  }\n}\n\n.dito-drag-enter-from,\n.dito-drag-leave-to {\n  opacity: 0;\n  backdrop-filter: blur(0);\n\n  ~ * .dito-drop-target {\n    --shadow-alpha: 0;\n  }\n}\n</style>\n","<template lang=\"pug\">\nul.dito-menu(\n  v-resize=\"onResize\"\n  :style=\"{ '--width': width ? `${width}px` : null }\"\n)\n  li.dito-menu__item(\n    v-for=\"item in items\"\n  )\n    template(\n      v-if=\"shouldShowItem(item)\"\n    )\n      a.dito-menu__link(\n        :href=\"getItemHref(item)\"\n        :class=\"{ 'dito-menu__link--active': isActiveItem(item) }\"\n        @click.prevent.stop=\"onClickItem(item)\"\n      ) {{ getLabel(item) }}\n      DitoMenu.dito-menu__sub(\n        v-if=\"item.items\"\n        :items=\"item.items\"\n        :path=\"getItemPath(item, false)\"\n      )\n</template>\n\n<script>\nimport DitoComponent from '../DitoComponent.js'\n\n// @vue/component\nexport default DitoComponent.component('DitoMenu', {\n  props: {\n    items: {\n      type: [Object, Array],\n      default: () => []\n    },\n    path: {\n      type: String,\n      default: ''\n    }\n  },\n\n  data() {\n    return {\n      width: 0\n    }\n  },\n\n  methods: {\n    shouldShowItem(item) {\n      return (\n        this.shouldRenderSchema(item) && (\n          !item.items ||\n          Object.values(item.items).some(this.shouldRenderSchema)\n        )\n      )\n    },\n\n    onResize({ contentRect: { width } }) {\n      if (width) {\n        this.width = width\n      }\n    },\n\n    getItemPath(item, firstChild) {\n      const path = item.path ? `${this.path}/${item.path}` : null\n      return firstChild && path && item.items\n        ? `${path}${this.getItemPath(Object.values(item.items)[0], false)}`\n        : path\n    },\n\n    getItemHref(item) {\n      const path = this.getItemPath(item, true)\n      return path ? this.$router.resolve(path).href : null\n    },\n\n    isActiveItem(item) {\n      return (\n        this.$route.path.startsWith(this.getItemPath(item, false)) ||\n        item.items && Object.values(item.items).some(this.isActiveItem)\n      )\n    },\n\n    onClickItem(item) {\n      const path = this.getItemPath(item, true)\n      if (path) {\n        this.$router.push({ path, force: true })\n      }\n    }\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@use 'sass:color';\n@import '../styles/_imports';\n\n.dito-menu {\n  $self: &;\n  $item-height: $menu-font-size + 2 * $menu-padding-ver;\n\n  --menu-active-color: #{$color-white};\n  --menu-active-background: #{$color-active};\n\n  border-right: $border-style;\n  padding: 0 $menu-spacing;\n\n  &__item {\n    &:has(#{$self}__sub):not(:has(#{$self}__link--active)) {\n      // Pop-out sub-menus on hover:\n      &:hover {\n        > #{$self}__link {\n          background: $color-lightest;\n        }\n\n        #{$self}__sub {\n          display: block;\n          position: absolute;\n          width: var(--width);\n          z-index: $z-index-header;\n          transform: translateX(calc(var(--width) + 2 * $menu-spacing))\n            translateY(-$item-height);\n\n          #{$self}__item:first-child {\n            #{$self}__link {\n              margin-top: 0;\n            }\n          }\n\n          &::before {\n            // Fill the gap to not loose the hover when moving over it.\n            content: '';\n            position: absolute;\n            top: 0;\n            left: -2 * $menu-spacing;\n            width: 2 * $menu-spacing;\n            height: $item-height;\n            opacity: 0;\n          }\n        }\n\n        #{$self}__sub {\n          box-shadow: $shadow-window;\n        }\n      }\n    }\n  }\n\n  &__link {\n    display: block;\n    padding: $menu-padding;\n    line-height: $menu-line-height;\n    border-radius: $border-radius;\n    margin-top: $menu-spacing;\n\n    &:focus:not(:active, &--active) {\n      box-shadow: $shadow-focus;\n    }\n\n    &:hover {\n      background: rgb(255, 255, 255, 0.5);\n    }\n\n    &--active {\n      &,\n      &:hover {\n        color: var(--menu-active-color);\n        background: var(--menu-active-background);\n      }\n\n      &:has(+ #{$self}__sub) {\n        --menu-active-background: #{color.adjust($color-active, $alpha: -0.3)};\n      }\n    }\n  }\n\n  &__sub {\n    display: none;\n    border-right: 0;\n    padding: 0;\n    border-radius: $border-radius;\n    background: $color-lightest;\n  }\n\n  &__link--active + &__sub {\n    display: block;\n  }\n}\n</style>\n","<template lang=\"pug\">\n.dito-trail\n  ul\n    li(\n      v-for=\"component in trail\"\n    )\n      a.dito-trail__link(\n        :class=\"{ 'dito-trail__link--active': component.path === $route.path }\"\n        :href=\"getComponentHref(component)\"\n        @click.prevent.stop=\"onClickComponent(component)\"\n      )\n        span.dito-trail__text(\n          :class=\"{ 'dito-trail__text--dirty': component.isDirty }\"\n        )\n          | {{ component.breadcrumb }}\n  slot\n</template>\n\n<script>\nimport DitoComponent from '../DitoComponent.js'\n\n// @vue/component\nexport default DitoComponent.component('DitoTrail', {\n  computed: {\n    trail() {\n      return this.appState.routeComponents.filter(\n        component => !!component.routeRecord\n      )\n    }\n  },\n\n  methods: {\n    getComponentPath(component) {\n      // Do the same as in `DitoMenu`: Link menu items to the first children.\n      const { schema } = component\n      return schema.type === 'menu'\n        ? Object.values(schema.items)[0].fullPath\n        : component.path\n    },\n\n    getComponentHref(component) {\n      return this.$router.resolve(this.getComponentPath(component)).href\n    },\n\n    onClickComponent(component) {\n      this.$router.push({\n        path: this.getComponentPath(component),\n        force: true\n      })\n    }\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-trail {\n  $self: &;\n\n  display: flex;\n  box-sizing: border-box;\n  height: 3em;\n\n  ul {\n    display: flex;\n  }\n\n  li {\n    white-space: nowrap;\n  }\n\n  &__link {\n    position: relative;\n    display: block;\n\n    &:hover {\n      #{$self}__text {\n        color: $color-light;\n      }\n    }\n  }\n\n  &__text--dirty {\n    &::after {\n      content: '';\n      display: inline-block;\n      background-color: $color-white;\n      width: 8px;\n      height: 8px;\n      margin: 2px;\n      margin-left: 0.5em;\n      border-radius: 100%;\n    }\n  }\n\n  li:not(:last-child) &__link {\n    $angle: 33deg;\n\n    &::before,\n    &::after {\n      position: absolute;\n      content: '';\n      width: 1px;\n      height: 0.75em;\n      right: -0.25em;\n      background: $color-white;\n      opacity: 0.5;\n    }\n\n    &::before {\n      top: 50%;\n      transform: rotate($angle);\n      transform-origin: top;\n    }\n\n    &::after {\n      bottom: 50%;\n      transform: rotate(-$angle);\n      transform-origin: bottom;\n    }\n  }\n}\n</style>\n","<template lang=\"pug\">\nnav.dito-header\n  DitoTrail\n    DitoSpinner(\n      v-if=\"isLoading\"\n      :size=\"spinner?.size\"\n      :color=\"spinner?.color\"\n    )\n  //- Teleport target for `.dito-schema-header`:\n  .dito-header__teleport\n  slot\n</template>\n\n<script>\nimport DitoComponent from '../DitoComponent.js'\n\n// @vue/component\nexport default DitoComponent.component('DitoHeader', {\n  props: {\n    spinner: {\n      type: Object,\n      default: null\n    },\n    isLoading: {\n      type: Boolean,\n      default: false\n    }\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-header {\n  position: relative;\n  background: $color-black;\n  font-size: $header-font-size;\n  line-height: $header-line-height;\n  z-index: $z-index-header;\n  @include user-select(none);\n\n  &::after {\n    // Set the full-width header background to the header color.\n    content: '';\n    inset: 0;\n    width: 100vw;\n    position: absolute;\n    background: inherit;\n    z-index: -1;\n  }\n\n  span {\n    display: inline-block;\n    padding: $header-padding;\n    color: $color-white;\n\n    &:empty {\n      &::after {\n        content: '\\200b';\n      }\n    }\n  }\n\n  &__teleport {\n    // Align the teleported schema headers on top of to the header menu.\n    position: absolute;\n    inset: 0;\n    display: flex;\n    justify-content: flex-end;\n    padding: 0 $header-padding-hor;\n    // Turn off pointer events so that DitoTrail keeps receiving events...\n    pointer-events: none;\n    // ...but move them to the children.\n    > * {\n      pointer-events: auto;\n    }\n\n    .dito-button {\n      margin: 0 0 $tab-margin $tab-margin;\n    }\n  }\n}\n</style>\n","<template lang=\"pug\">\nnav.dito-navigation.dito-scroll-parent\n  h1\n    RouterLink.dito-link(to=\"/\") {{ appState.title }}\n  DitoMenu.dito-scroll(:items=\"views\")\n</template>\n\n<script>\nimport DitoComponent from '../DitoComponent.js'\n\n// @vue/component\nexport default DitoComponent.component('DitoNavigation', {})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-navigation {\n  @include user-select(none);\n\n  flex: 0 0 min-content;\n  font-size: $menu-font-size;\n  white-space: nowrap;\n  background: $color-lighter;\n\n  h1 {\n    display: block;\n    line-height: $header-line-height;\n    font-weight: bold;\n    background: $color-darker;\n    border-right: $border-width solid $color-darkest;\n    color: $color-white;\n\n    .dito-link {\n      display: block;\n      padding: $header-padding;\n    }\n  }\n}\n</style>\n","<template lang=\"pug\">\n.dito-notifications\n  .dito-header\n    span\n  .dito-notifications__inner\n    VueNotifications(\n      ref=\"notifications\"\n      classes=\"dito-notification\"\n      :dangerouslySetInnerHtml=\"true\"\n      position=\"\"\n      width=\"\"\n    )\n</template>\n\n<script>\nimport DitoComponent from '../DitoComponent.js'\nimport { asArray, stripHtml } from '@ditojs/utils'\n\n// @vue/component\nexport default DitoComponent.component('DitoNotifications', {\n  notifications() {\n    return this.isMounted && this.$refs.notifications\n  },\n\n  methods: {\n    notify({ type = 'info', title, text, error, duration } = {}) {\n      title ||= (\n        {\n          warning: 'Warning',\n          error: 'Error',\n          info: 'Information',\n          success: 'Success'\n        }[type] ||\n        'Notification'\n      )\n      text = `<p>${\n        asArray(text).join('</p> <p>')\n      }</p>`.replace(/\\n|\\r\\n|\\r/g, '<br>')\n      const log = (\n        {\n          warning: 'warn',\n          error: 'error',\n          info: 'log',\n          success: 'log'\n        }[type] ||\n        'error'\n      )\n      // eslint-disable-next-line no-console\n      console[log](\n        ...[\n          stripHtml(text),\n          ...(type === 'error' && error ? [error] : [])\n        ]\n      )\n      const { notifications = true } = this.api\n      if (notifications) {\n        // Calculate display-duration for the notification based on its content\n        // and the setting of the `durationFactor` configuration. It defines the\n        // amount of milliseconds multiplied with the amount of characters\n        // displayed in the notification, plus 40 (40 + title + message):\n        const { durationFactor = 20 } = notifications\n        duration ??= (40 + text.length + title.length) * durationFactor\n        this.$notify({\n          type,\n          title,\n          text,\n          duration: duration === 0 ? -1 : duration // < 0 -> <= 0 = sticky\n        })\n      }\n    },\n\n    destroyAll() {\n      this.notifications.destroyAll()\n    }\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@use 'sass:color';\n@import '../styles/_imports';\n\n@mixin type($background) {\n  background: color.adjust($background, $lightness: 5%);\n  color: $color-white;\n  border-left: 12px solid color.adjust($background, $lightness: -10%);\n}\n\n.dito-notifications {\n  $notification-width: 300px;\n\n  flex: 1;\n  z-index: $z-index-notifications;\n  box-sizing: border-box;\n  margin-left: $form-spacing;\n  // For the `@container` rule to work:\n  container-type: inline-size;\n\n  .dito-header {\n    span {\n      padding-left: 0;\n      padding-right: 0;\n    }\n  }\n\n  &__inner {\n    position: relative;\n  }\n\n  .vue-notification-group {\n    position: absolute;\n    left: 0;\n    top: 0;\n    width: $notification-width;\n\n    @container (width < #{$notification-width + $content-padding}) {\n      left: unset;\n      right: $content-padding;\n    }\n  }\n\n  .vue-notification-wrapper {\n    overflow: visible;\n  }\n\n  .dito-notification {\n    padding: 8px;\n    margin: $content-padding 0;\n    font-size: inherit;\n    color: $color-white;\n    border-radius: $border-radius;\n    box-shadow: $shadow-window;\n\n    .notification-title {\n      font-weight: bold;\n      padding-bottom: 8px;\n    }\n\n    .notification-content {\n      overflow: hidden;\n      word-break: break-all;\n\n      p {\n        margin: 0;\n\n        & + p {\n          margin-top: 8px;\n        }\n      }\n    }\n\n    &,\n    &.info {\n      @include type($color-active);\n    }\n\n    &.success {\n      @include type($color-success);\n    }\n\n    &.warning {\n      @include type($color-warning);\n    }\n\n    &.error {\n      @include type($color-error);\n    }\n  }\n}\n</style>\n","<template lang=\"pug\">\naside.dito-sidebar.dito-scroll-parent(\n  v-resize=\"onResizeSidebar\"\n  :class=\"classes\"\n)\n  nav.dito-header\n    slot\n  .dito-sidebar__teleport.dito-scroll\n</template>\n\n<script>\nimport DitoComponent from '../DitoComponent.js'\n\n// @vue/component\nexport default DitoComponent.component('DitoSidebar', {\n  data() {\n    return {\n      sidebarWidth: 0\n    }\n  },\n\n  computed: {\n    classes() {\n      const prefix = 'dito-sidebar'\n      // NOTE: Keep synced with $sidebar-max-width in SCSS:\n      const sidebarWidth = 360\n      return {\n        [`${prefix}--width-99`]: this.sidebarWidth < sidebarWidth,\n        [`${prefix}--width-60`]: this.sidebarWidth <= sidebarWidth * 0.6\n      }\n    }\n  },\n\n  methods: {\n    onResizeSidebar({ contentRect: { width } }) {\n      this.sidebarWidth = width\n    }\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-sidebar {\n  flex: 0 1 $sidebar-max-width;\n  max-width: $sidebar-max-width;\n  min-width: $sidebar-min-width;\n}\n</style>\n","import DomMixin from './DomMixin.js'\n\n// @vue/component\nexport default {\n  mixins: [DomMixin],\n\n  data() {\n    return {\n      pulldown: {\n        open: false,\n        startTime: 0,\n        checkTime: true,\n        events: {\n          mousedown: () => {\n            this.setPulldownOpen(false)\n            this.pulldown.handlers.remove()\n          },\n\n          mouseup: () => {\n            if (this.onPulldownMouseUp()) {\n              this.pulldown.handlers.remove()\n            }\n          }\n        },\n        handlers: null\n      }\n    }\n  },\n\n  methods: {\n    onPulldownMouseDown(value = null) {\n      if (value === null) {\n        this.setPulldownOpen(true)\n        this.checkTime = true\n      } else {\n        this.checkTime = false\n      }\n    },\n\n    onPulldownMouseUp(value = null) {\n      const { startTime } = this.pulldown\n      if (!this.checkTime || startTime && (Date.now() - startTime > 250)) {\n        this.setPulldownOpen(false)\n        if (value !== null) {\n          this.onPulldownSelect(value)\n        }\n        return true\n      }\n    },\n\n    onPulldownSelect(/* value */) {\n      // NOTE: To be overridden.\n    },\n\n    setPulldownOpen(open) {\n      this.pulldown.open = open\n      this.pulldown.startTime = open ? Date.now() : 0\n      if (open) {\n        this.pulldown.handlers = this.domOn(document, this.pulldown.events)\n      }\n    }\n  }\n}\n","<template lang=\"pug\">\n.dito-account\n  a(\n    @mousedown.stop=\"onPulldownMouseDown()\"\n  )\n    span {{ user.username }}\n  ul.dito-pulldown(:class=\"{ 'dito-pulldown--open': pulldown.open }\")\n    li(\n      v-for=\"(label, value) of items\"\n    )\n      a.dito-pulldown__item(\n        @mousedown.stop=\"onPulldownMouseDown(value)\"\n        @mouseup=\"onPulldownMouseUp(value)\"\n      ) {{ label }}\n</template>\n\n<script>\nimport DitoComponent from '../DitoComponent.js'\nimport PulldownMixin from '../mixins/PulldownMixin.js'\n\n// @vue/component\nexport default DitoComponent.component('DitoAccount', {\n  mixins: [PulldownMixin],\n\n  data() {\n    return {\n      items: {\n        settings: 'Settings',\n        logout: 'Logout'\n      }\n    }\n  },\n\n  methods: {\n    onPulldownSelect(value) {\n      switch (value) {\n        case 'logout':\n          this.rootComponent.logout()\n          break\n        case 'settings':\n          console.info('TODO: Implement Settings')\n          break\n      }\n    }\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-account {\n  position: relative;\n  display: inline-block;\n\n  .dito-pulldown {\n    top: $pulldown-padding-ver;\n  }\n}\n</style>\n","<template lang=\"pug\">\n.dito-spinner(\n  v-show=\"loading\"\n  :style=\"{ '--color': color, '--size': size, '--margin': margin }\"\n)\n  .dito-spinner__pulse.dito-spinner__pulse1\n  .dito-spinner__pulse.dito-spinner__pulse2\n  .dito-spinner__pulse.dito-spinner__pulse3\n</template>\n\n<script>\nimport DitoComponent from '../DitoComponent.js'\n\n// @vue/component\nexport default DitoComponent.component('DitoSpinner', {\n  props: {\n    loading: {\n      type: Boolean,\n      default: true\n    },\n    color: {\n      type: String,\n      default: null\n    },\n    size: {\n      type: String,\n      default: null\n    },\n    margin: {\n      type: String,\n      default: null\n    }\n  }\n})\n</script>\n\n<style lang=\"scss\">\n.dito-spinner {\n  --color: #999999;\n  --size: 8px;\n  --margin: 2px;\n\n  display: flex;\n  align-items: center;\n\n  &__pulse {\n    display: inline-block;\n    background: var(--color);\n    width: var(--size);\n    height: var(--size);\n    margin: var(--margin);\n    border-radius: 100%;\n    animation: dito-spinner-pulse 0.75s cubic-bezier(0.2, 0.68, 0.18, 1.08) 0s\n      infinite both;\n  }\n\n  &__pulse1 {\n    animation-delay: 0.12s;\n  }\n\n  &__pulse2 {\n    animation-delay: 0.24s;\n  }\n\n  &__pulse3 {\n    animation-delay: 0.36s;\n  }\n}\n\n@keyframes dito-spinner-pulse {\n  0%,\n  80% {\n    transform: scale(1);\n    opacity: 1;\n  }\n\n  45% {\n    transform: scale(0.1);\n    opacity: 0.7;\n  }\n}\n\n@keyframes dito-spinner-pulse {\n  0%,\n  80% {\n    transform: scale(1);\n    opacity: 1;\n  }\n\n  45% {\n    transform: scale(0.1);\n    opacity: 0.7;\n  }\n}\n</style>\n","<template lang=\"pug\">\ncomponent(\n  v-if=\"item.type === 'text'\"\n  :is=\"item.as || 'div'\"\n) {{ item.text }}\ncomponent(\n  v-else-if=\"item.type === 'html'\"\n  :is=\"item.as || 'div'\"\n  v-html=\"item.html\"\n)\nDitoSpinner(\n  v-else-if=\"item.type === 'spinner'\"\n  :size=\"item.size\"\n  :color=\"item.color\"\n)\nDitoIcon(\n  v-else-if=\"item.type === 'icon'\"\n  :name=\"item.name\"\n  :disabled=\"item.disabled\"\n)\ncomponent(\n  v-else-if=\"item.type === 'component'\"\n  :is=\"item.component\"\n  v-bind=\"item.props\"\n)\n</template>\n\n<script>\nimport DitoComponent from '../DitoComponent.js'\nimport DitoSpinner from './DitoSpinner.vue'\nimport { DitoIcon } from '@ditojs/ui/src'\n\nexport default DitoComponent.component('DitoAffix', {\n  components: { DitoSpinner, DitoIcon },\n\n  props: {\n    item: { type: Object, required: true },\n    parentContext: { type: Object, required: true }\n  },\n\n  computed: {\n    // Override DitoMixin's context with the parent's context\n    context() {\n      return this.parentContext\n    }\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-affix {\n  &--html,\n  &--text {\n    display: inline-block;\n  }\n\n  &--ellipsis {\n    @include ellipsis;\n\n    flex: 1;\n    display: block;\n    min-width: 0;\n    width: 0;\n  }\n}\n</style>\n","<template lang=\"pug\">\n.dito-affixes(\n  v-if=\"hasContent\"\n  :class=\"classes\"\n)\n  slot(name=\"prepend\")\n  DitoAffix.dito-affix(\n    v-for=\"(item, index) in visibleItems\"\n    :key=\"index\"\n    :class=\"getItemClasses(item)\"\n    :style=\"item.style\"\n    :item=\"item\"\n    :parentContext=\"parentContext\"\n  )\n  button.dito-affixes__clear(\n    v-if=\"clearable\"\n    type=\"button\"\n    title=\"Clear\"\n    :disabled=\"disabled\"\n    @click.stop=\"$emit('clear')\"\n    @mousedown.stop\n  )\n  slot(name=\"append\")\n  .dito-info(\n    v-if=\"inlineInfo\"\n    :data-info=\"inlineInfo\"\n  )\n</template>\n\n<script>\nimport DitoComponent from '../DitoComponent.js'\nimport DitoAffix from './DitoAffix.vue'\nimport { asArray, isString } from '@ditojs/utils'\nimport { hasSlotContent } from '@ditojs/ui/src'\nimport { shouldRenderSchema } from '../utils/schema.js'\n\nexport default DitoComponent.component('DitoAffixes', {\n  components: { DitoAffix },\n  emits: ['clear'],\n\n  props: {\n    items: { type: [String, Object, Array], default: null },\n    mode: { type: String, default: null },\n    position: { type: String, default: null },\n    absolute: { type: Boolean, default: false },\n    clearable: { type: Boolean, default: false },\n    disabled: { type: Boolean, default: false },\n    inlineInfo: { type: String, default: null },\n    parentContext: { type: Object, required: true }\n  },\n\n  computed: {\n    // Override DitoMixin's context with the parent's context\n    context() {\n      return this.parentContext\n    },\n\n    processedItems() {\n      return asArray(this.items)\n        .filter(Boolean)\n        .map(item =>\n          isString(item)\n            ? { type: 'text', text: item }\n            : item.type\n              ? item\n              : item.text != null\n                ? { type: 'text', ...item }\n                : item.html != null\n                  ? { type: 'html', ...item }\n                  : item\n        )\n    },\n\n    visibleItems() {\n      return this.processedItems.filter(item =>\n        shouldRenderSchema(item, this.context)\n      )\n    },\n\n    classes() {\n      const prefix = 'dito-affixes'\n      return {\n        [`${prefix}--${this.position}`]: this.position,\n        [`${prefix}--${this.mode}`]: this.mode,\n        [`${prefix}--absolute`]: this.absolute\n      }\n    },\n\n    hasContent() {\n      return (\n        this.visibleItems.length > 0 ||\n        this.clearable ||\n        this.inlineInfo ||\n        hasSlotContent(this.$slots.prepend) ||\n        hasSlotContent(this.$slots.append)\n      )\n    }\n  },\n\n  methods: {\n    getItemClasses(item) {\n      const prefix = 'dito-affix'\n      return [\n        {\n          [`${prefix}--${item.type}`]: item.type,\n          [`${prefix}--ellipsis`]: (\n            this.mode === 'ellipsis' && ['text', 'html'].includes(item.type)\n          )\n        },\n        item.class\n      ]\n    }\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-affixes {\n  $self: &;\n\n  @include user-select(none);\n\n  display: flex;\n  align-items: center;\n  gap: $input-padding-hor;\n\n  &--absolute {\n    position: absolute;\n    inset: $border-width;\n    margin: $input-padding-ver $input-padding-hor;\n    pointer-events: none;\n\n    > * {\n      pointer-events: auto;\n    }\n\n    &#{$self}--prefix {\n      right: unset;\n    }\n\n    &#{$self}--suffix {\n      left: unset;\n    }\n  }\n\n  &--ellipsis {\n    flex: 1;\n  }\n\n  &--input {\n    color: $color-grey;\n\n    .dito-icon--disabled {\n      color: $color-light;\n    }\n\n    @at-root .dito-component:not(:has(.dito-component)):focus-within & {\n      color: $color-active;\n    }\n  }\n\n  &__clear {\n    --size: #{calc($input-height - 4 * $border-width)};\n\n    display: none;\n    position: relative;\n    cursor: pointer;\n    width: var(--size);\n    height: var(--size);\n    border-radius: $border-radius;\n    margin: (-$input-padding-ver + $border-width)\n      (-$input-padding-hor + $border-width);\n    padding: 0;\n    border: 0;\n\n    @at-root .dito-component:not(:has(.dito-component)):hover & {\n      display: block;\n    }\n\n    &::before {\n      @extend %icon-clear;\n\n      color: $color-grey;\n    }\n\n    &:hover::before {\n      color: $color-black;\n    }\n  }\n\n  // Hide other affixes when clear button is shown\n  // prettier-ignore\n  @at-root .dito-component:hover:not(:has(.dito-component))\n        #{$self}:has(#{$self}__clear) > *:not(#{$self}__clear) {\n      display: none;\n    }\n}\n</style>\n","<template lang=\"pug\">\ncomponent.dito-label(\n  v-if=\"text || collapsible\"\n  :is=\"collapsible ? 'button' : 'div'\"\n  :type=\"collapsible ? 'button' : null\"\n  v-bind=\"attributes\"\n  :class=\"{ 'dito-label--active': isActive }\"\n)\n  .dito-chevron(\n    v-if=\"collapsible\"\n    :class=\"{ 'dito-chevron--open': !collapsed }\"\n  )\n  .dito-label__inner(\n    v-if=\"text || prefixes.length > 0 || suffixes.length > 0\"\n  )\n    DitoAffixes(\n      :items=\"prefixes\"\n      position=\"prefix\"\n      :parentContext=\"context\"\n    )\n    label(\n      v-if=\"text\"\n      :for=\"dataPath\"\n      v-html=\"text\"\n    )\n    DitoAffixes(\n      :items=\"suffixes\"\n      mode=\"ellipsis\"\n      position=\"suffix\"\n      :parentContext=\"context\"\n    )\n    .dito-info(\n      v-if=\"info\"\n      :data-info=\"info\"\n    )\n</template>\n\n<script>\nimport DitoComponent from '../DitoComponent.js'\nimport DitoAffixes from './DitoAffixes.vue'\nimport { isObject, asArray } from '@ditojs/utils'\n\n// @vue/component\nexport default DitoComponent.component('DitoLabel', {\n  components: { DitoAffixes },\n\n  emits: ['open'],\n\n  props: {\n    label: { type: [String, Object], default: null },\n    dataPath: { type: String, default: null },\n    collapsed: { type: Boolean, default: false },\n    collapsible: { type: Boolean, default: false },\n    info: { type: String, default: null }\n  },\n\n  computed: {\n    text() {\n      const { label } = this\n      return isObject(label) ? label?.text : label\n    },\n\n    prefixes() {\n      return asArray(this.label?.prefix)\n    },\n\n    suffixes() {\n      return asArray(this.label?.suffix)\n    },\n\n    attributes() {\n      return this.collapsible ? { onClick: this.onClick } : {}\n    },\n\n    isActive() {\n      return this.appState.activeLabel === this\n    }\n  },\n\n  methods: {\n    onClick() {\n      this.appState.activeLabel = this\n      this.$emit('open', this.collapsed)\n    }\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-label {\n  $self: &;\n\n  // For buttons and chevron to align right:\n  display: flex;\n  position: relative;\n  // Vertically center all items in the label, e.g. chevron, edit-buttons.\n  align-items: center;\n  min-height: $input-height;\n  margin-right: $form-spacing-half; // When inlined.\n\n  &:has(.dito-schema-header) {\n    // The container's label is used as teleport for a nested section or object\n    // label. Hide `&__inner`, as it is be duplicated inside the nested label.\n    > #{$self}__inner {\n      display: none;\n    }\n  }\n\n  &:not(:has(+ .dito-tabs)) {\n    // Take full width but only if there aren't also tabs to be centered.\n    flex: 1;\n  }\n\n  &__inner {\n    flex: 1 0 0%;\n    display: flex;\n    align-items: center;\n    overflow: hidden;\n    gap: $input-padding-hor;\n  }\n\n  label {\n    @include ellipsis;\n\n    cursor: inherit;\n    font-weight: bold;\n    line-height: $input-height;\n  }\n\n  // Fix alignment of sub and sup elements in label content.\n  sub,\n  sup {\n    display: inline-block;\n    vertical-align: baseline;\n  }\n\n  sub {\n    transform: translateY(4px);\n  }\n\n  sup {\n    transform: translateY(-4px);\n  }\n\n  .dito-buttons {\n    // Move the label padding inside .dito-buttons, so that it captures all\n    // near mouse events:\n    margin: calc(-1 * var(--label-padding));\n    margin-left: 0;\n    padding: var(--label-padding);\n  }\n\n  &--fill {\n    width: 100%;\n\n    // In order for ellipsis to work on labels without affecting other layout,\n    // we need to position it absolutely inside its container. But we can only\n    // do so if there is't also a chevron or other UX elements besides it.\n    &:has(> #{$self}__inner:only-child) {\n      flex: 1; // When in `.dito-schema-header`.\n\n      > #{$self}__inner {\n        position: absolute;\n        inset: 0;\n      }\n    }\n\n    &::after {\n      // Since <label> uses `position: absolute`, set content to a zero-width\n      // space on its parent to enforce the right text height in the container\n      content: '\\200b'; // zero-width space;\n    }\n  }\n\n  .dito-info {\n    margin-left: 0.35em;\n  }\n\n  @at-root button#{&} {\n    border: 0;\n    padding: 0;\n    background: none;\n    text-align: start;\n\n    &:hover {\n      .dito-chevron {\n        color: $color-darker;\n      }\n    }\n\n    &:focus:not(:active, &--active) {\n      .dito-chevron {\n        -webkit-text-stroke: $border-width $color-active;\n      }\n    }\n  }\n}\n</style>\n","import DitoContext from '../DitoContext.js'\nimport {\n  getItemFormSchema,\n  getItemId,\n  getItemUid,\n  isListSource\n} from '../utils/schema.js'\nimport { appendDataPath } from '../utils/data.js'\nimport { isObject, isString, isFunction } from '@ditojs/utils'\n\n// @vue/component\nexport default {\n  methods: {\n    getItemFormSchema,\n\n    getItemUid,\n\n    getItemId(sourceSchema, item, index = null) {\n      return this.isTransient && index !== null\n        ? String(index)\n        : getItemId(sourceSchema, item)\n    },\n\n    getItemDataPath(sourceSchema, index) {\n      let { dataPath } = this\n      if (sourceSchema !== this.schema) {\n        dataPath = appendDataPath(dataPath, sourceSchema.name)\n      }\n      if (index != null) {\n        dataPath = appendDataPath(dataPath, index)\n      }\n      return dataPath\n    },\n\n    getItemStore(sourceSchema, item, index) {\n      return this.getChildStore(this.getItemUid(sourceSchema, item), index)\n    },\n\n    removeItemStore(sourceSchema, item, index) {\n      this.removeChildStore(this.getItemUid(sourceSchema, item), index)\n    },\n\n    findItemIdIndex(sourceSchema, data, itemId) {\n      const index = this.isTransient\n        ? // For transient data, the index is used as the id\n          itemId\n        : data?.findIndex(\n            (item, index) => (\n              this.getItemId(sourceSchema, item, index) === itemId\n            )\n          )\n      return index !== -1 ? index : null\n    },\n\n    getItemLabel(sourceSchema, item, {\n      index = null,\n      extended = false,\n      asObject = false\n    } = {}) {\n      const { itemLabel } = sourceSchema\n      if (!item || !extended && itemLabel === false) {\n        return null\n      }\n\n      let dataPath\n      const getDataPath = () =>\n        (dataPath ??= this.getItemDataPath(sourceSchema, index))\n\n      let formLabel\n      const getFormLabel = () =>\n        (formLabel ??= this.getLabel(\n          getItemFormSchema(sourceSchema, item, this.context)\n        ))\n\n      let text\n      let prefix\n      let suffix\n      if (isFunction(itemLabel)) {\n        const label = itemLabel.call(\n          this,\n          new DitoContext(this, {\n            nested: false,\n            data: item,\n            value: item,\n            index,\n\n            get dataPath() {\n              return getDataPath()\n            },\n\n            get formLabel() {\n              return getFormLabel()\n            }\n          })\n        )\n        if (isObject(label)) {\n          ;({ text, prefix, suffix } = label)\n        } else {\n          text = label\n        }\n        // It's up to `itemLabel()` entirely to produce the label:\n        extended = false\n      } else if (isString(itemLabel) && !(itemLabel in item)) {\n        // `itemLabel` can be both a key, or simply a label.\n        text = itemLabel\n      } else {\n        // Look up the name on the item, by these rules:\n        // 1. If `itemLabel` is a string, use it as the property key\n        // 2. Otherwise, if there are columns, use the value of the first\n        // 3. Otherwise, see if the item has a property named 'name'\n        const { columns } = sourceSchema\n        const key = (\n          isString(itemLabel) && itemLabel ||\n          isListSource(sourceSchema) && columns && Object.keys(columns)[0] ||\n          'name'\n        )\n        text = item[key]\n      }\n      const hadLabel = !!text\n      // If no label was found so far, try to produce one from the index.\n      if (text == null) {\n        // Always use extended style when auto-generating labels from index/id:\n        extended = true\n        text =\n          isListSource(sourceSchema) && index !== null\n            ? (text = `${index + 1}`)\n            : ''\n      }\n      if (extended) {\n        const formLabel = getFormLabel()\n        if (formLabel) {\n          // If a label was provided, put in quotes when prefixed with the\n          // form label for the extended style:\n          text = `${formLabel} ${hadLabel ? `'${text}'` : text}`\n        }\n      }\n      return asObject\n        ? text || prefix || suffix\n          ? { text, prefix, suffix }\n          : null\n        : text\n    }\n  }\n}\n","<template lang=\"pug\">\nslot(name=\"prepend\")\n.dito-schema(\n  :class=\"{ 'dito-scroll-parent': scrollable, 'dito-schema--open': opened }\"\n  v-bind=\"$attrs\"\n)\n  Teleport(\n    v-if=\"isPopulated && panelEntries.length > 0\"\n    to=\".dito-sidebar__teleport\"\n  )\n    DitoPanels(\n      v-if=\"active\"\n      :panels=\"panelEntries\"\n      :data=\"data\"\n      :meta=\"meta\"\n      :store=\"store\"\n      :disabled=\"disabled\"\n    )\n  Teleport(\n    v-if=\"hasHeader\"\n    :to=\"headerTeleport\"\n    :disabled=\"!headerTeleport\"\n  )\n    .dito-schema-header(\n      v-if=\"active\"\n    )\n      DitoLabel(\n        v-if=\"hasLabel\"\n        :label=\"label\"\n        :info=\"info\"\n        :dataPath=\"dataPath\"\n        :collapsible=\"collapsible\"\n        :collapsed=\"!opened\"\n        @open=\"onOpen\"\n      )\n      Transition(\n        v-if=\"tabs\"\n        name=\"dito-fade\"\n      )\n        DitoTabs(\n          v-if=\"opened\"\n          v-model=\"selectedTab\"\n          :tabs=\"tabs\"\n        )\n      DitoClipboard(\n        v-if=\"clipboard\"\n        :clipboard=\"clipboard\"\n        :schema=\"schema\"\n      )\n      slot(name=\"edit-buttons\")\n  TransitionHeight(:enabled=\"inlined\")\n    .dito-schema-content(\n      v-if=\"opened\"\n      ref=\"content\"\n      :class=\"{ 'dito-scroll': scrollable }\"\n    )\n      template(\n        v-if=\"hasTabs\"\n      )\n        template(\n          v-for=\"(tabSchema, tab) in tabs\"\n          :key=\"tab\"\n        )\n          //- TODO: Switch to v-if instead of v-show, once validation is\n          //- decoupled from components.\n          DitoPane.dito-pane__tab(\n            v-show=\"selectedTab === tab\"\n            ref=\"tabs\"\n            :tab=\"tab\"\n            :schema=\"tabSchema\"\n            :dataPath=\"dataPath\"\n            :data=\"data\"\n            :meta=\"meta\"\n            :store=\"store\"\n            :padding=\"padding\"\n            :single=\"single && !inlined && !hasMainPane\"\n            :disabled=\"disabled\"\n            :compact=\"compact\"\n            :generateLabels=\"generateLabels\"\n            :accumulatedBasis=\"accumulatedBasis\"\n          )\n      DitoPane.dito-pane__main(\n        v-if=\"hasMainPane\"\n        ref=\"components\"\n        :schema=\"schema\"\n        :dataPath=\"dataPath\"\n        :data=\"data\"\n        :meta=\"meta\"\n        :store=\"store\"\n        :padding=\"padding\"\n        :single=\"single && !inlined && !hasTabs\"\n        :disabled=\"disabled\"\n        :compact=\"compact\"\n        :generateLabels=\"generateLabels\"\n        :accumulatedBasis=\"accumulatedBasis\"\n      )\n      slot(\n        v-if=\"!inlined && isPopulated\"\n        name=\"buttons\"\n      )\n  slot(\n    v-if=\"inlined && !hasHeader\"\n    name=\"edit-buttons\"\n  )\nslot(name=\"append\")\n</template>\n\n<script>\nimport {\n  isObject,\n  isArray,\n  isFunction,\n  isRegExp,\n  equals,\n  parseDataPath,\n  normalizeDataPath,\n  labelize\n} from '@ditojs/utils'\nimport { TransitionHeight } from '@ditojs/ui/src'\nimport DitoComponent from '../DitoComponent.js'\nimport ContextMixin from '../mixins/ContextMixin.js'\nimport ItemMixin from '../mixins/ItemMixin.js'\nimport { appendDataPath } from '../utils/data.js'\nimport {\n  getNamedSchemas,\n  getPanelEntries,\n  setDefaultValues,\n  processData,\n  isEmptySchema,\n  isNested\n} from '../utils/schema.js'\nimport { getSchemaAccessor, getStoreAccessor } from '../utils/accessor.js'\n\n// @vue/component\nexport default DitoComponent.component('DitoSchema', {\n  mixins: [ContextMixin, ItemMixin],\n  components: { TransitionHeight },\n  inheritAttrs: false,\n\n  provide() {\n    return {\n      $schemaComponent: () => this\n    }\n  },\n\n  inject: [\n    '$schemaParentComponent'\n  ],\n\n  props: {\n    schema: { type: Object, required: true },\n    // `dataSchema` is only provided for panels, where the panel schema\n    // is different from the data schema for panels without own data.\n    dataSchema: { type: Object, default: props => props.schema },\n    dataPath: { type: String, default: '' },\n    data: { type: Object, default: null },\n    meta: { type: Object, default: () => ({}) },\n    store: { type: Object, default: () => ({}) },\n    label: { type: [String, Object], default: null },\n    info: { type: String, default: null },\n    single: { type: Boolean, default: false },\n    padding: { type: String, default: null },\n    active: { type: Boolean, default: true },\n    inlined: { type: Boolean, default: false },\n    disabled: { type: Boolean, default: false },\n    compact: { type: Boolean, default: false },\n    collapsed: { type: Boolean, default: false },\n    collapsible: { type: Boolean, default: false },\n    scrollable: { type: Boolean, default: false },\n    hasOwnData: { type: Boolean, default: false },\n    generateLabels: { type: Boolean, default: false },\n    labelNode: { type: HTMLElement, default: null },\n    accumulatedBasis: { type: Number, default: 1 }\n  },\n\n  data() {\n    const { data } = this.schema\n    return {\n      // Allow schema to provide more data through `schema.data`, vue-style:\n      ...(\n        data && isFunction(data)\n          ? data(this.context)\n          : data\n      ),\n      selectedTab: null,\n      componentsRegistry: {},\n      panesRegistry: {},\n      panelsRegistry: {},\n      scrollPositions: {}\n    }\n  },\n\n  computed: {\n    nested() {\n      // For `ContextMixin`:\n      return false\n    },\n\n    schemaComponent() {\n      // Override DitoMixin's schemaComponent() which uses the injected value.\n      return this\n    },\n\n    parentSchemaComponent() {\n      // Don't return the actual parent schema is this schema handles its own\n      // data. This prevents delegating events to the parent, and registering\n      // components with the parent that would cause it to set isDirty flags.\n      return this.hasOwnData ? null : this.parentComponent.schemaComponent\n    },\n\n    panelEntries() {\n      return getPanelEntries(this.schema.panels, this.dataPath)\n    },\n\n    tabs() {\n      return getNamedSchemas(this.schema.tabs)\n    },\n\n    defaultTab() {\n      let first = null\n      if (this.tabs) {\n        const tabs = Object.values(this.tabs).filter(this.shouldRenderSchema)\n        for (const { name, defaultTab } of tabs) {\n          if (isFunction(defaultTab) ? defaultTab(this.context) : defaultTab) {\n            return name\n          }\n          first ??= name\n        }\n      }\n      return first\n    },\n\n    routeTab() {\n      return this.$route.hash?.slice(1) || null\n    },\n\n    clipboard() {\n      return this.schema?.clipboard ?? null\n    },\n\n    hasHeader() {\n      return this.hasLabel || this.hasTabs || !!this.clipboard\n    },\n\n    headerTeleport() {\n      return this.isTopLevelSchema\n        ? '.dito-header__teleport'\n        : this.labelNode\n    },\n\n    // @override\n    processedData() {\n      // TODO: Fix side-effects\n      return this.processData({ target: 'server', schemaOnly: true })\n    },\n\n    clipboardData: {\n      get() {\n        // TODO: Fix side-effects\n        return this.processData({ target: 'clipboard', schemaOnly: true })\n      },\n\n      set(data) {\n        this.setData(data)\n      }\n    },\n\n    clipboardItem() {\n      return this.clipboardData\n    },\n\n    formLabel() {\n      return this.getLabel(\n        this.getItemFormSchema(this.sourceSchema, this.data, this.context)\n      )\n    },\n\n    isNested() {\n      return isNested(this.schema)\n    },\n\n    isDirty() {\n      return this.someComponent(it => it.isDirty)\n    },\n\n    isTouched() {\n      return this.someComponent(it => it.isTouched)\n    },\n\n    isValid() {\n      return this.everyComponent(it => it.isValid)\n    },\n\n    isValidated() {\n      return this.everyComponent(it => it.isValidated)\n    },\n\n    hasErrors() {\n      return this.someComponent(it => it.hasErrors)\n    },\n\n    hasData() {\n      return !!this.data\n    },\n\n    hasLabel() {\n      return !!this.label || this.collapsible\n    },\n\n    hasTabs() {\n      return !!this.tabs\n    },\n\n    isTopLevelSchema() {\n      return !this.isNested && !this.inlined\n    },\n\n    hasTopLevelTabs() {\n      return this.hasTabs && this.isTopLevelSchema\n    },\n\n    hasMainPane() {\n      const { components } = this.schema\n      return !!components && Object.keys(components).length > 0\n    },\n\n    opened: getStoreAccessor('opened', {\n      default() {\n        return !this.collapsed\n      }\n    }),\n\n    components() {\n      return Object.values(this.componentsRegistry)\n    },\n\n    panes() {\n      return Object.values(this.panesRegistry)\n    },\n\n    panels() {\n      return Object.values(this.panelsRegistry)\n    },\n\n    componentsByDataPath() {\n      return this._listEntriesByDataPath(this.componentsRegistry)\n    },\n\n    panesByDataPath() {\n      return this._listEntriesByDataPath(this.panesRegistry)\n    },\n\n    panelsByDataPath() {\n      return this._listEntriesByDataPath(this.panelsRegistry)\n    },\n\n    wide: getSchemaAccessor('wide', {\n      type: Boolean,\n      default: false\n    })\n  },\n\n  watch: {\n    schema: {\n      immediate: true,\n      handler(schema) {\n        // For forms with type depending on loaded data, we need to wait for the\n        // actual schema to become ready before setting up schema related things\n        if (!isEmptySchema(schema)) {\n          this.setupSchema()\n        }\n      }\n    },\n\n    routeTab: {\n      immediate: true,\n      // https://github.com/vuejs/vue-router/issues/3393#issuecomment-1158470149\n      flush: 'post',\n      handler(routeTab) {\n        // Remember the current path to know if tab changes should still be\n        // handled, but remove the trailing `/create` or `/:id` from it so that\n        // tabs informs that stay open after creation still work.\n        if (this.hasTopLevelTabs) {\n          this.selectedTab = routeTab\n        }\n      }\n    },\n\n    selectedTab(newTab, oldTab) {\n      if (this.scrollable) {\n        const { content } = this.$refs\n        this.scrollPositions[oldTab] = content.scrollTop\n        this.$nextTick(() => {\n          content.scrollTop = this.scrollPositions[newTab] ?? 0\n        })\n      }\n      if (this.hasTopLevelTabs) {\n        const tab = this.shouldRenderSchema(this.tabs[newTab])\n          ? newTab\n          : this.defaultTab\n        this.$router.replace({\n          query: this.$route.query,\n          hash: tab ? `#${tab}` : null\n        })\n      }\n      if (this.hasErrors) {\n        this.repositionErrors()\n      }\n    }\n  },\n\n  created() {\n    this._register(true)\n    if (this.scrollable && this.wide) {\n      this.appState.pageClass = 'dito-page--wide'\n    }\n  },\n\n  mounted() {\n    this.selectedTab = this.routeTab || this.defaultTab\n  },\n\n  unmounted() {\n    this.emitEvent('destroy')\n    this._register(false)\n    if (this.scrollable && this.wide) {\n      this.appState.pageClass = null\n    }\n  },\n\n  methods: {\n    setupSchema() {\n      this.setupSchemaFields()\n      // Delegate change events through to parent schema:\n      this.delegate('change', this.parentSchemaComponent)\n      this.emitEvent('initialize') // Not `'create'`, since that's for data.\n    },\n\n    getComponentsByDataPath(dataPath) {\n      return this._getEntriesByDataPath(this.componentsByDataPath, dataPath)\n    },\n\n    getComponentByDataPath(dataPath) {\n      return this.getComponentsByDataPath(dataPath)[0] || null\n    },\n\n    getComponentsByName(dataPath) {\n      return this._getEntriesByName(this.componentsByDataPath, dataPath)\n    },\n\n    getComponentByName(name) {\n      return this.getComponentsByName(name)[0] || null\n    },\n\n    getComponents(dataPathOrName) {\n      return this._getEntries(this.componentsByDataPath, dataPathOrName)\n    },\n\n    getComponent(dataPathOrName) {\n      return this.getComponents(dataPathOrName)[0] || null\n    },\n\n    getPanelsByDataPath(dataPath) {\n      return this._getEntriesByDataPath(this.panelsByDataPath, dataPath)\n    },\n\n    getPanelByDataPath(dataPath) {\n      return this.getPanelsByDataPath(dataPath)[0] || null\n    },\n\n    getPanels(dataPathOrName) {\n      return this._getEntries(this.panelsByDataPath, dataPathOrName)\n    },\n\n    getPanel(dataPathOrName) {\n      return this.getPanels(dataPathOrName)[0] || null\n    },\n\n    someComponent(callback) {\n      return this.isPopulated && this.components.some(callback)\n    },\n\n    everyComponent(callback) {\n      return this.isPopulated && this.components.every(callback)\n    },\n\n    onOpen(open) {\n      this.emitEvent('open', { context: { open } })\n      // Prevent closing the schema with invalid data, since the in-component\n      // validation will not be executed once it's closed.\n\n      // TODO: Move validation out of components, to schema, just like\n      // processing, and use `showValidationErrors()` for the resulting errors,\n      // then remove this requirement, since we can validate closed forms and\n      // schemas then.\n      if (!this.opened || open || this.validateAll()) {\n        this.opened = open\n      }\n    },\n\n    onChange() {\n      this.emitEvent('change')\n    },\n\n    resetValidation() {\n      for (const component of this.components) {\n        component.resetValidation()\n      }\n    },\n\n    clearErrors() {\n      for (const component of this.components) {\n        component.clearErrors()\n      }\n    },\n\n    repositionErrors() {\n      // Fire a fake scroll event to force the repositioning of error tooltips,\n      // as otherwise they sometimes don't show up in the right place initially\n      // when changing tabs.\n      const scrollContainer = this.$refs.content.closest('.dito-scroll')\n      const dispatch = () => scrollContainer.dispatchEvent(new Event('scroll'))\n      dispatch()\n      // This is required to handle `&--label-vertical` based layout changes.\n      setTimeout(dispatch, 0)\n    },\n\n    focus() {\n      this.opened = true\n      return this.parentSchemaComponent?.focus()\n    },\n\n    validateAll(match, notify = true) {\n      const { componentsByDataPath } = this\n      let dataPaths\n      if (match) {\n        const check = isFunction(match)\n          ? match\n          : isRegExp(match)\n            ? field => match.test(field)\n            : null\n        dataPaths = check\n          ? Object.keys(componentsByDataPath).filter(check)\n          : isArray(match)\n            ? match\n            : [match]\n      }\n      if (notify) {\n        this.clearErrors()\n      }\n      let isValid = true\n      let first = true\n      dataPaths ||= Object.keys(componentsByDataPath)\n      for (const dataPath of dataPaths) {\n        const components = this.getComponentsByDataPath(dataPath)\n        for (const component of components) {\n          if (!component.validate(notify)) {\n            // Focus first error field\n            if (notify && first) {\n              component.scrollIntoView()\n            }\n            first = false\n            isValid = false\n          }\n        }\n      }\n      if (notify && !isValid) {\n        this.notifyErrors()\n      }\n      return isValid\n    },\n\n    verifyAll(match) {\n      return this.validateAll(match, false)\n    },\n\n    async showValidationErrors(errors, focus, first = true) {\n      this.clearErrors()\n      const unmatched = []\n      const wasFirst = first\n      for (const [dataPath, errs] of Object.entries(errors)) {\n        // If the schema is a data-root, prefix its own dataPath to all errors,\n        // since the data that it sends and validates will be unprefixed.\n        const fullDataPath = this.hasOwnData\n          ? appendDataPath(this.dataPath, dataPath)\n          : dataPath\n        // console.log(this, this.dataPath, this.hasOwnData, fullDataPath)\n        // Convert from JavaScript property access notation, to our own form\n        // of relative JSON pointers as data-paths:\n        const dataPathParts = parseDataPath(fullDataPath)\n        let found = false\n        const components = this.getComponentsByDataPath(dataPathParts)\n        for (const component of components) {\n          if (component.showValidationErrors(errs, first && focus)) {\n            found = true\n            first = false\n            break\n          }\n        }\n        if (!found) {\n          // Couldn't find a component in an active form for the given dataPath.\n          // See if we can find a component serving a part of the dataPath,\n          // and take it from there:\n          const property = dataPathParts.pop()\n          while (dataPathParts.length > 0) {\n            const components = this.getComponentsByDataPath(dataPathParts)\n            for (const component of components) {\n              const navigated = await component.navigateToComponent?.(\n                fullDataPath,\n                subComponents => {\n                  let found = false\n                  for (const component of subComponents) {\n                    const matched = Object.fromEntries(\n                      Object.entries(errors).filter(\n                        ([dataPath]) =>\n                          normalizeDataPath(dataPath).startsWith(\n                            component.dataPath\n                          )\n                      )\n                    )\n                    if (\n                      Object.keys(matched).length > 0 &&\n                      component.showValidationErrors(matched, first && focus)\n                    ) {\n                      found = true\n                      first = false\n                      break\n                    }\n                  }\n                  return found\n                }\n              )\n              if (navigated) {\n                // Found a nested form to display at least parts fo the errors.\n                // We can't show all errors at once, so we're done. Don't call\n                // `notifyErrors()` yet, as we can only display it once\n                // `showValidationErrors()` was called from `DitoForm.mounted()`\n                return\n              }\n            }\n            // Still here, so keep removing the last part until we find a match.\n            dataPathParts.pop()\n          }\n          // When the error can't be matched, add it to a list of unmatched\n          // errors with decent message, to report at the end.\n          const field = labelize(property)\n          for (const err of errs) {\n            const prefix = field\n              ? `The field ${field}`\n              : `The ${this.formLabel}`\n            unmatched.push(`${prefix} ${err.message}`)\n          }\n        }\n        first = false\n      }\n      if (wasFirst && !first) {\n        this.notifyErrors(unmatched.join('\\n'))\n      }\n      return !first\n    },\n\n    notifyErrors(message) {\n      this.notify({\n        type: 'error',\n        title: 'Validation Errors',\n        text: message || 'Please correct the highlighted errors.'\n      })\n    },\n\n    resetData() {\n      // We can't set `this.data = ...` because it's a property, but we can set\n      // all known properties on it to the values returned by\n      // `setDefaultValues()`, as they are all reactive already from the starts:\n      // eslint-disable-next-line vue/no-mutating-props\n      Object.assign(this.data, setDefaultValues(this.dataSchema, {}, this))\n      this.clearErrors()\n    },\n\n    setData(data) {\n      for (const name in data) {\n        if (name in this.data) {\n          if (!equals(this.data[name], data[name])) {\n            // eslint-disable-next-line vue/no-mutating-props\n            this.data[name] = data[name]\n            for (const component of this.getComponentsByName(name)) {\n              component.markDirty()\n            }\n          }\n        }\n      }\n    },\n\n    filterData(data) {\n      // Filters out arrays and objects that are backed by data resources\n      // themselves, as those are already taken care of through their own API\n      // resource end-points and shouldn't be set.\n      const localData = {}\n      const foreignData = {}\n      for (const [name, value] of Object.entries(data)) {\n        if (isArray(value) || isObject(value)) {\n          const components = this.getComponentsByName(name)\n          if (components.some(component => component.providesData)) {\n            foreignData[name] = value\n            continue\n          }\n        }\n        localData[name] = value\n      }\n      return { localData, foreignData }\n    },\n\n    processData({ target = 'clipboard', schemaOnly = true } = {}) {\n      return processData(\n        this.dataSchema,\n        this.sourceSchema,\n        this.data,\n        this.dataPath,\n        {\n          // Needed for DitoContext handling inside `processData` and\n          // `processSchemaData()`:\n          rootData: this.rootData,\n          component: this,\n          schemaOnly,\n          target\n        }\n      )\n    },\n\n    _register(add) {\n      // `$schemaParentComponent()` is only set if one of the ancestors uses\n      // the `SchemaParentMixin`:\n      this.$schemaParentComponent()?._registerSchemaComponent(this, add)\n    },\n\n    _registerComponent(component, add) {\n      this._registerEntry(this.componentsRegistry, component, add)\n      // Only register with the parent if schema shares data with it.\n      this.parentSchemaComponent?._registerComponent(component, add)\n    },\n\n    _registerPane(pane, add) {\n      this._registerEntry(this.panesRegistry, pane, add)\n    },\n\n    _registerPanel(panel, add) {\n      this._registerEntry(this.panelsRegistry, panel, add)\n    },\n\n    _registerEntry(registry, entry, add) {\n      const uid = entry.$uid\n      if (add) {\n        registry[uid] = entry\n      } else {\n        delete registry[uid]\n      }\n    },\n\n    _listEntriesByDataPath(registry) {\n      return Object.values(registry).reduce((entriesByDataPath, entry) => {\n        // Multiple entries can be linked to the same data-path, e.g. when\n        // there are tabs. Link each data-path to an array of entries.\n        const { dataPath } = entry\n        const entries = (entriesByDataPath[dataPath] ||= [])\n        entries.push(entry)\n        return entriesByDataPath\n      }, {})\n    },\n\n    _getEntries(entriesByDataPath, dataPath) {\n      return normalizeDataPath(dataPath).startsWith(this.dataPath)\n        ? this._getEntriesByDataPath(entriesByDataPath, dataPath)\n        : this._getEntriesByName(entriesByDataPath, dataPath)\n    },\n\n    _getEntriesByDataPath(entriesByDataPath, dataPath) {\n      return entriesByDataPath[normalizeDataPath(dataPath)] || []\n    },\n\n    _getEntriesByName(entriesByDataPath, name) {\n      return entriesByDataPath[appendDataPath(this.dataPath, name)] || []\n    }\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-schema {\n  box-sizing: border-box;\n\n  > .dito-schema-header + .dito-schema-content > .dito-pane {\n    margin-top: $form-spacing-half;\n  }\n\n  &:has(> .dito-schema-content + .dito-edit-buttons) {\n    // Display the inlined edit buttons to the right of the schema:\n    display: flex;\n    flex-direction: row;\n    align-items: stretch;\n\n    > .dito-edit-buttons {\n      flex: 1 0 0%;\n      margin-left: $form-spacing;\n    }\n  }\n\n  > .dito-schema-content {\n    flex: 0 1 100%;\n    max-width: 100%;\n    // So that schema buttons can be sticky to the bottom.\n    // NOTE: We also need grid for `TransitionHeight` to work well. Switching\n    // to flex box here causes jumpy collapsing transitions.\n    display: grid;\n    grid-template-rows: min-content;\n    grid-template-columns: 100%;\n\n    > :only-child {\n      grid-row-end: none;\n    }\n  }\n}\n\n.dito-schema-header {\n  display: flex;\n  justify-content: space-between;\n\n  .dito-header & {\n    // When teleported into main header.\n    align-items: flex-end;\n  }\n\n  .dito-label & {\n    // When teleported into container label.\n    flex: 1;\n  }\n\n  > .dito-label {\n    margin-bottom: 0;\n  }\n\n  > .dito-buttons {\n    margin-left: var(--button-margin, 0);\n  }\n}\n</style>\n","<template lang=\"pug\">\nDitoSchema.dito-schema-inlined(\n  :schema=\"schema\"\n  :dataPath=\"dataPath\"\n  :data=\"data\"\n  :meta=\"meta\"\n  :store=\"store\"\n  :label=\"isCompact ? null : label\"\n  :info=\"info\"\n  :padding=\"padding ?? 'inlined'\"\n  :inlined=\"true\"\n  :disabled=\"disabled\"\n  :compact=\"isCompact\"\n  :collapsed=\"collapsed\"\n  :collapsible=\"collapsible\"\n  :generateLabels=\"!isCompact\"\n  :labelNode=\"labelNode\"\n  :accumulatedBasis=\"accumulatedBasis\"\n)\n  //- Render dito-edit-buttons for inlined schemas separately from all\n  //- others in `TypeList` as a scope, for better handling of layout.\n  template(#edit-buttons)\n    DitoEditButtons(\n      v-if=\"deletable || draggable || editable\"\n      :schema=\"schema\"\n      :dataPath=\"dataPath\"\n      :data=\"data\"\n      :meta=\"meta\"\n      :store=\"store\"\n      :disabled=\"disabled\"\n      :deletable=\"deletable\"\n      :draggable=\"draggable\"\n      :editable=\"editable\"\n      :editPath=\"editPath\"\n      @delete=\"$emit('delete')\"\n    )\n</template>\n\n<script>\nimport DitoComponent from '../DitoComponent.js'\nimport { isCompact } from '../utils/schema.js'\n// @vue/component\nexport default DitoComponent.component('DitoSchemaInlined', {\n  emits: ['delete'],\n\n  props: {\n    schema: { type: Object, required: true },\n    dataPath: { type: String, required: true },\n    data: { type: Object, required: true },\n    meta: { type: Object, required: true },\n    store: { type: Object, required: true },\n    label: { type: [String, Object], default: null },\n    info: { type: String, default: null },\n    padding: { type: String, default: null },\n    disabled: { type: Boolean, required: true },\n    collapsed: { type: Boolean, default: false },\n    collapsible: { type: Boolean, default: false },\n    draggable: { type: Boolean, default: false },\n    editable: { type: Boolean, default: false },\n    deletable: { type: Boolean, default: false },\n    editPath: { type: String, default: null },\n    labelNode: { type: HTMLElement, default: null },\n    accumulatedBasis: { type: Number, default: null }\n  },\n\n  computed: {\n    isCompact() {\n      return isCompact(this.schema)\n    },\n\n    hasLabel() {\n      return !this.isCompact && !!this.label\n    }\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-schema-inlined {\n  // Use grid layout for two reasons: For `TransitionHeight` to work smoothly,\n  // and to align the header above the content when the header is not teleported\n  // outside of the schema.\n  display: grid;\n  grid-template-rows: min-content;\n  grid-template-columns: 100%;\n\n  &:not(:hover, .dito-schema--open) {\n    > .dito-schema-header {\n      > .dito-clipboard {\n        display: none;\n      }\n    }\n  }\n}\n</style>\n","<!-- eslint-disable vue/no-template-shadow -->\n<template lang=\"pug\">\n.dito-pane(\n  v-if=\"isPopulated && componentSchemas.length > 0\"\n  v-resize=\"onResizePane\"\n  :class=\"classes\"\n)\n  template(\n    v-for=`{\n      schema,\n      dataPath,\n      nestedDataPath,\n      nested,\n      store\n    }, index in componentSchemas`\n  )\n    //- Use <span> for .dito-pane__break so we can use the\n    //- `.dito-container:first-of-type` selector.\n    span.dito-pane__break(\n      v-if=\"['before', 'both'].includes(schema.break)\"\n    )\n    DitoContainer(\n      v-if=\"shouldRenderSchema(schema)\"\n      ref=\"containers\"\n      :key=\"nestedDataPath\"\n      :data-index=\"index\"\n      :schema=\"schema\"\n      :dataPath=\"dataPath\"\n      :data=\"data\"\n      :meta=\"meta\"\n      :store=\"store\"\n      :single=\"isSingleComponent\"\n      :nested=\"nested\"\n      :disabled=\"disabled\"\n      :compact=\"compact\"\n      :generateLabels=\"generateLabels\"\n      :verticalLabels=\"isInLabeledRow(index)\"\n      :accumulatedBasis=\"accumulatedBasis\"\n    )\n    span.dito-pane__break(\n      v-if=\"['after', 'both'].includes(schema.break)\"\n    )\n</template>\n\n<script>\nimport DitoComponent from '../DitoComponent.js'\nimport ContextMixin from '../mixins/ContextMixin.js'\nimport { appendDataPath } from '../utils/data.js'\nimport { isNested } from '../utils/schema.js'\n\n// @vue/component\nexport default DitoComponent.component('DitoPane', {\n  mixins: [ContextMixin],\n\n  provide() {\n    return {\n      $tabComponent: () => this.tabComponent\n    }\n  },\n\n  props: {\n    schema: { type: Object, required: true },\n    dataPath: { type: String, default: '' },\n    data: { type: Object, default: null },\n    meta: { type: Object, required: true },\n    store: { type: Object, required: true },\n    tab: { type: String, default: null },\n    single: { type: Boolean, default: false },\n    padding: { type: String, default: null },\n    disabled: { type: Boolean, default: false },\n    compact: { type: Boolean, default: false },\n    generateLabels: { type: Boolean, default: false },\n    accumulatedBasis: { type: Number, default: null }\n  },\n\n  data() {\n    return {\n      positions: []\n    }\n  },\n\n  computed: {\n    nested() {\n      // For `ContextMixin`:\n      return false\n    },\n\n    classes() {\n      const prefix = 'dito-pane'\n      return {\n        [`${prefix}--single`]: this.isSingleComponent,\n        [`${prefix}--padding-${this.padding}`]: !!this.padding\n      }\n    },\n\n    tabComponent() {\n      return this.tab ? this : this.$tabComponent()\n    },\n\n    componentSchemas() {\n      // Compute a components list which has the dataPath baked into its keys\n      // and adds the key as the name to each component, used for labels, etc.\n      // NOTE: schema can be null while multi-form lists load their data,\n      // because only the available data will determine the type of form.\n      // When editing primitive values through a form, do not append 'name' to\n      // the component's dataPath so it can be mapped to from validation errors.\n      // NOTE: Not all schemas / components have a sourceSchema, e.g. dialogs.\n      const wrapPrimitives = this.sourceSchema?.wrapPrimitives\n      return Object.entries(this.schema?.components || {}).map(\n        ([name, schema]) => {\n          // Always add name to component schema, but clone it first to avoid\n          // mutating the original schema potentially used in multiple places.\n          schema = { ...schema, name }\n          // Share dataPath and store with parent if not nested:\n          const nested = isNested(schema)\n          const nestedDataPath = appendDataPath(this.dataPath, name)\n          return {\n            schema,\n            dataPath:\n              nested && !wrapPrimitives\n                ? nestedDataPath\n                : this.dataPath,\n            nestedDataPath,\n            nested,\n            store: this.getChildStore(name)\n          }\n        }\n      )\n    },\n\n    isSingleComponent() {\n      return this.single && this.componentSchemas.length === 1\n    },\n\n    verticalLabelsByIndices() {\n      const { positions } = this\n\n      const isLastInRow = index => (\n        positions[index] && (\n          index === positions.length - 1 ||\n          findNextPosition(index).top > positions[index].top\n        )\n      )\n\n      const findNextPosition = index => {\n        for (let i = index + 1; i < positions.length; i++) {\n          if (positions[i]) return positions[i]\n        }\n        return 0\n      }\n\n      const rows = []\n      let row = []\n      for (let index = 0; index < positions.length; index++) {\n        row.push(index)\n        if (isLastInRow(index)) {\n          rows.push(row)\n          row = []\n        }\n      }\n      if (row.length > 0) {\n        rows.push(row)\n      }\n\n      const verticalLabelsByIndices = []\n\n      for (const row of rows) {\n        let hasLabelsInRow = false\n        for (const index of row) {\n          const position = this.positions[index]\n          if (\n            position?.height > 2 && (\n              position.node.matches(':has(> .dito-label)') ||\n              position.node\n                .closest('.dito-container')\n                .matches('.dito-container--label-vertical')\n            )\n          ) {\n            // TODO: Handle nested schemas, e.g. 'section' or 'object' and\n            // detect labels there too.\n            hasLabelsInRow = true\n            break\n          }\n        }\n        for (const index of row) {\n          verticalLabelsByIndices[index] = hasLabelsInRow\n        }\n      }\n\n      return verticalLabelsByIndices\n    }\n  },\n\n  watch: {\n    'componentSchemas.length'(length) {\n      this.positions.length = length\n    }\n  },\n\n  created() {\n    this._register(true)\n  },\n\n  unmounted() {\n    this._register(false)\n  },\n\n  methods: {\n    _register(add) {\n      this.schemaComponent._registerPane(this, add)\n    },\n\n    focus() {\n      if (this.tab) {\n        return this.$router.push({ hash: `#${this.tab}` })\n      }\n    },\n\n    onResizePane() {\n      this.$nextTick(() => {\n        for (const container of this.$refs.containers) {\n          const node = container.$el\n          const index = +node.dataset.index\n          const bounds = node.getBoundingClientRect()\n          const style = getComputedStyle(node)\n          const padding = parseFloat(style.padding)\n          const fontSize = parseFloat(style.fontSize)\n          const height = bounds.height - 2 * padding\n          this.positions[index] =\n            height <= 0\n              ? null\n              : {\n                  top: bounds.y,\n                  height: height / fontSize,\n                  node\n                }\n        }\n      })\n    },\n\n    isInLabeledRow(index) {\n      return !!this.verticalLabelsByIndices[index]\n    }\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-pane {\n  $self: &;\n  $root-padding: $content-padding - $form-spacing-half;\n\n  --pane-padding: 0px;\n  --container-padding: #{$form-spacing-half};\n\n  display: flex;\n  position: relative;\n  flex-flow: row wrap;\n  align-items: flex-start;\n  align-content: flex-start;\n  // Remove the padding added by `.dito-container` inside `.dito-pane`:\n  margin: -$form-spacing-half;\n  padding: var(--pane-padding);\n  // Use `flex: 0%` for all `.dito-pane` except `.dito-pane__main`,\n  // so that the `.dito-buttons--main` can be moved all the way to the bottom.\n  flex: 0%;\n\n  &__main {\n    flex: 100%;\n  }\n\n  &--padding-root {\n    // A root-level pane inside a scroll view. Clear negative margin from above.\n    margin: 0;\n    // Move the negative margin used to remove the padding added by\n    // `.dito-container` inside `.dito-pane` to the padding:\n    --pane-padding: #{$root-padding};\n\n    &#{$self}--single {\n      --pane-padding: #{$content-padding};\n      --container-padding: 0px;\n    }\n\n    &:has(> .dito-container--label-vertical:first-of-type) {\n      // Reduce top spacing when the first row has labels.\n      margin-top: -$form-spacing-half;\n    }\n\n    // Display a ruler between tabbed components and towards the .dito-buttons\n    &__tab + &__main {\n      &::before {\n        // Use a pseudo element to display a ruler with proper margins\n        display: block;\n        content: '';\n        width: 100%;\n        border-bottom: $border-style;\n        // Shift ruler up by $root-padding to exclude removed $form-spacing-half\n        margin: (-$root-padding) $form-spacing-half $root-padding;\n        padding: $form-spacing-half;\n      }\n    }\n\n    &__main + .dito-buttons--main {\n      // Needed forms with sticky main buttons.\n      margin: $content-padding;\n      margin-bottom: 0;\n    }\n  }\n\n  &--padding-inlined {\n    --pane-padding: 0px;\n  }\n\n  &--padding-nested {\n    --pane-padding: #{$form-spacing};\n\n    &:has(> .dito-container--label-vertical:first-of-type) {\n      // Reduce top spacing when the first row has labels.\n      padding-top: $form-spacing-half;\n    }\n  }\n\n  &__break {\n    // `&_break` is rendered as <span> so we can use the\n    // `.dito-container:first-of-type` selector to match the first container\n    // even if it has a break before it.\n    display: block;\n    flex: 100%;\n    height: 0;\n  }\n}\n</style>\n","import { isString } from '@ditojs/utils'\n\nexport function parseFraction(value) {\n  const match = (\n    isString(value) &&\n    value.match(/^\\s*([+-]?\\d+)\\s*\\/\\s*([+-]?\\d+)\\s*$/)\n  )\n  if (match) {\n    const [, dividend, divisor] = match\n    return parseFloat(dividend) / parseFloat(divisor)\n  } else {\n    return parseFloat(value)\n  }\n}\n","<template lang=\"pug\">\n.dito-container(\n  v-show=\"componentVisible\"\n  :class=\"containerClasses\"\n  :style=\"containerStyles\"\n)\n  Teleport(\n    v-if=\"isMounted && panelEntries.length > 0\"\n    to=\".dito-sidebar__teleport\"\n  )\n    DitoPanels(\n      :panels=\"panelEntries\"\n      :data=\"data\"\n      :meta=\"meta\"\n      :store=\"store\"\n      :disabled=\"disabled\"\n    )\n  DitoLabel(\n    v-if=\"hasLabel\"\n    :class=\"labelClasses\"\n    :dataPath=\"labelDataPath\"\n    :label=\"label\"\n    :info=\"info\"\n  )\n  component.dito-component(\n    v-if=\"!(hasLabel && isLabel)\"\n    :is=\"typeComponent\"\n    ref=\"component\"\n    :class=\"componentClasses\"\n    :schema=\"schema\"\n    :dataPath=\"dataPath\"\n    :data=\"data\"\n    :meta=\"meta\"\n    :store=\"store\"\n    :width=\"width\"\n    :label=\"label\"\n    :single=\"single\"\n    :nested=\"nested\"\n    :accumulatedBasis=\"combinedBasis\"\n    @errors=\"onErrors\"\n    @update:component=\"value => (component = value)\"\n  )\n  DitoErrors(:errors=\"errors\")\n</template>\n\n<script>\nimport { isString, isNumber } from '@ditojs/utils'\nimport DitoComponent from '../DitoComponent.js'\nimport ValueMixin from '../mixins/ValueMixin.js'\nimport ContextMixin from '../mixins/ContextMixin.js'\nimport DitoContext from '../DitoContext.js'\nimport { getSchemaAccessor } from '../utils/accessor.js'\nimport {\n  getAllPanelEntries,\n  getTypeComponent,\n  hasLabel,\n  omitSpacing\n} from '../utils/schema.js'\nimport { parseFraction } from '../utils/math.js'\n\n// @vue/component\nexport default DitoComponent.component('DitoContainer', {\n  mixins: [ValueMixin, ContextMixin],\n  props: {\n    schema: { type: Object, required: true },\n    dataPath: { type: String, default: '' },\n    data: { type: [Object, Array], required: true },\n    meta: { type: Object, required: true },\n    store: { type: Object, required: true },\n    single: { type: Boolean, default: false },\n    nested: { type: Boolean, default: true },\n    disabled: { type: Boolean, required: true },\n    compact: { type: Boolean, default: false },\n    generateLabels: { type: Boolean, default: false },\n    verticalLabels: { type: Boolean, default: false },\n    accumulatedBasis: { type: Number, default: null }\n  },\n\n  data() {\n    return {\n      errors: null,\n      // The nested type component instance, for context-based schema accessor\n      // evaluation.\n      component: null\n    }\n  },\n\n  computed: {\n    context() {\n      return new DitoContext(\n        // When available, use the type component for context-based schema\n        // accessors, but fall back to container.\n        // TODO: Consider architectural inversion to eliminate timing issues:\n        // - Type components render DitoContainer at their root\n        // - Pass type component content through container's default slot\n        // - DitoPane/DitoButtons render type components directly\n        // - Eliminates need for component instance synchronization\n        // - Provides true synchronous access to component context\n        this.component ?? this,\n        { nested: this.nested }\n      )\n    },\n\n    name() {\n      return this.schema.name\n    },\n\n    type() {\n      return this.schema.type\n    },\n\n    typeComponent() {\n      return getTypeComponent(this.type)\n    },\n\n    isLabel() {\n      return this.type === 'label'\n    },\n\n    hasLabel() {\n      return hasLabel(this.schema, this.generateLabels)\n    },\n\n    label() {\n      return this.hasLabel ? this.getLabel(this.schema) : null\n    },\n\n    labelDataPath() {\n      // Unnested types don't have a dataPath for themselves, don't use it:\n      return this.nested ? this.dataPath : null\n    },\n\n    info: getSchemaAccessor('info', {\n      type: String,\n      default: null\n    }),\n\n    width: getSchemaAccessor('width', {\n      type: [String, Number],\n      default() {\n        return this.typeComponent?.defaultWidth\n      },\n      get(width) {\n        // Use 100% == 1.0 as default width when nothing is set:\n        return width === undefined\n          ? 1.0\n          : isString(width)\n            ? width.match(/^\\s*[<>]?\\s*(.*)$/)[1] // Remove width operator\n            : width\n      }\n    }),\n\n    widthOperator: getSchemaAccessor('width', {\n      type: String,\n      get(width) {\n        return isString(width)\n          ? width.match(/^\\s*([<>]?)/)[1] || null\n          : null\n      }\n    }),\n\n    componentVisible: getSchemaAccessor('visible', {\n      type: Boolean,\n      default() {\n        return this.typeComponent?.defaultVisible\n      }\n    }),\n\n    componentDisabled: getSchemaAccessor('disabled', {\n      type: Boolean,\n      default: false,\n      get(disabled) {\n        return disabled || this.disabled\n      }\n    }),\n\n    flexGrow() {\n      // Interpret '>50%' as '50%, flex-grow: 1`\n      return (\n        this.widthOperator === '>' ||\n        this.width === 'fill'\n      )\n    },\n\n    flexShrink() {\n      // Interpret '<50%' as '50%, flex-shrink: 1`\n      return this.widthOperator === '<'\n    },\n\n    flexBasis() {\n      const width = this.width\n      // 'auto' = no fitting:\n      return [null, 'auto', 'fill'].includes(width)\n        ? 'auto'\n        : /%$/.test(width)\n          ? parseFloat(width) / 100 // percentage -> fraction\n          : /[a-z]/.test(width)\n            ? width // native units\n            : parseFraction(width) // fraction\n    },\n\n    combinedBasis() {\n      const { accumulatedBasis, flexBasis } = this\n      return isNumber(accumulatedBasis) && isNumber(flexBasis)\n        ? accumulatedBasis * flexBasis\n        : null\n    },\n\n    containerClasses() {\n      const { class: classes } = this.schema\n      const prefix = 'dito-container'\n      return {\n        [`${prefix}--disabled`]: this.componentDisabled,\n        [`${prefix}--has-errors`]: !!this.errors,\n        [`${prefix}--single`]: this.single,\n        [`${prefix}--compact`]: this.compact,\n        [`${prefix}--label-vertical`]: this.verticalLabels,\n        [`${prefix}--omit-spacing`]: omitSpacing(this.schema),\n        ...(isString(classes) ? { [classes]: true } : classes)\n      }\n    },\n\n    containerStyles() {\n      const { flexBasis, combinedBasis } = this\n      return {\n        '--grow': this.flexGrow ? 1 : 0,\n        '--shrink': this.flexShrink ? 1 : 0,\n        '--basis': isNumber(flexBasis) ? `${flexBasis * 100}%` : flexBasis,\n        '--basis-mobile':\n          isNumber(combinedBasis) && combinedBasis <= 0.25\n            ? `${flexBasis * 200}%`\n            : null\n      }\n    },\n\n    componentClasses() {\n      return {\n        'dito-component--single': this.single,\n        ...this.getLayoutClasses('dito-component')\n      }\n    },\n\n    labelClasses() {\n      return {\n        'dito-label--visible': this.isLabel,\n        ...this.getLayoutClasses('dito-label')\n      }\n    },\n\n    panelEntries() {\n      return getAllPanelEntries(\n        this.api,\n        this.schema,\n        this.dataPath,\n        this.$refs.component,\n        this.tabComponent\n      )\n    }\n  },\n\n  methods: {\n    getLayoutClasses(prefix) {\n      return {\n        [`${prefix}--fill`]: this.width === 'fill' || this.flexBasis !== 'auto',\n        [`${prefix}--grow`]: this.flexGrow,\n        [`${prefix}--shrink`]: this.flexShrink\n      }\n    },\n\n    onErrors(errors) {\n      this.errors = errors\n    }\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-container {\n  --grow: 0;\n  --shrink: 1;\n  --basis: auto;\n\n  position: relative;\n  display: flex;\n  flex: var(--grow) var(--shrink) var(--basis);\n  flex-flow: column;\n  align-items: flex-start;\n  box-sizing: border-box;\n  // To prevent list tables from blowing out of their flex box containers.\n  max-width: 100%;\n  // Cannot use margin here as it needs to be part of box-sizing for\n  // percentages in flex-basis to work.\n  padding: var(--container-padding);\n\n  > .dito-label:not(.dito-label--visible):only-child {\n    // Used e.g. when sources hide themselves due to maxDepth, but the label\n    // is rendered above it.\n    display: none;\n  }\n\n  &:empty {\n    padding: 0;\n  }\n\n  .dito-pane > & {\n    .dito-page--width-80 & {\n      flex-grow: 1;\n      flex-basis: var(--basis-mobile, var(--basis));\n      // DEBUG: background: yellow;\n    }\n\n    .dito-page--width-60 & {\n      flex-basis: calc(2 * var(--basis));\n      // DEBUG: background: orange;\n    }\n\n    .dito-sidebar--width-99 & {\n      flex-grow: 1;\n      // DEBUG: background: yellow;\n    }\n\n    .dito-sidebar--width-60 & {\n      flex-basis: calc(2 * var(--basis));\n      // DEBUG: background: orange;\n    }\n  }\n\n  &--single {\n    height: 100%; // So that list buttons can be sticky at the bottom;\n  }\n\n  &--label-vertical {\n    // For plain components without labels in rows with other components that\n    // have labels, add some spacing to the top to align with the other\n    // components (e.g.  buttons):\n    > .dito-component:first-child:not(.dito-section, .dito-list, .dito-object) {\n      margin-top: $input-height;\n    }\n  }\n\n  &--compact:not(&--label-vertical) {\n    // Display labels in compact schema as inline-blocks, to allow compact\n    // layouts with `width: 'auto'` elements:\n    display: flex;\n    flex-flow: row wrap;\n    align-items: center;\n  }\n\n  &--omit-spacing {\n    padding: 0;\n\n    > .dito-label {\n      margin: $form-spacing-half $form-spacing-half 0;\n    }\n  }\n}\n\n.dito-component {\n  position: relative;\n\n  &--fill {\n    width: 100%;\n\n    &.dito-checkbox,\n    &.dito-radio-button {\n      // WebKit doesn't like changed width on checkboxes and radios, override:\n      display: inline-block;\n      width: auto;\n    }\n  }\n}\n</style>\n","<template lang=\"pug\">\n.dito-tabs\n  template(\n    v-for=\"(tabSchema, key) in tabs\"\n  )\n    a.dito-tabs__link(\n      v-if=\"shouldRenderSchema(tabSchema)\"\n      :key=\"key\"\n      :class=\"{ 'dito-tabs__link--active': modelValue === key }\"\n      @click=\"$emit('update:modelValue', key)\"\n    ) {{ getLabel(tabSchema, key) }}\n</template>\n\n<script>\nimport DitoComponent from '../DitoComponent.js'\n\n// @vue/component\nexport default DitoComponent.component('DitoTabs', {\n  emits: ['update:modelValue'],\n  props: {\n    tabs: { type: Object, default: null },\n    modelValue: { type: String, default: null }\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@use 'sass:color';\n@import '../styles/_imports';\n\n.dito-tabs {\n  display: flex;\n\n  &__link {\n    @include user-select(none);\n\n    display: block;\n    white-space: nowrap;\n\n    &:hover {\n      background: $color-white;\n    }\n\n    // When in main header:\n    .dito-header & {\n      background: $color-light;\n      padding: $tab-padding-ver $tab-padding-hor;\n      margin-left: $tab-margin;\n      border-top-left-radius: $tab-radius;\n      border-top-right-radius: $tab-radius;\n\n      &:active {\n        background: $color-lightest;\n      }\n\n      &--active {\n        background: $color-lightest;\n      }\n    }\n\n    // When inside a inline schema:\n    .dito-schema-inlined &,\n    .dito-label & {\n      background: $color-lighter;\n      border: $border-style;\n      padding: $input-padding;\n      margin-left: -$border-width;\n      white-space: nowrap;\n\n      &:first-child {\n        border-top-left-radius: $tab-radius;\n        border-bottom-left-radius: $tab-radius;\n      }\n\n      &:last-child {\n        border-top-right-radius: $tab-radius;\n        border-bottom-right-radius: $tab-radius;\n      }\n\n      &:active {\n        background: $color-lighter;\n      }\n\n      &--active {\n        background: $color-active;\n        border-color: color.adjust($color-active, $lightness: -10%);\n        color: $color-white;\n        z-index: 1;\n      }\n    }\n  }\n\n  .dito-schema & {\n    // Push clipboard to the right in the flex layout, see:\n    // https://codepen.io/tholex/pen/hveBx/\n    margin-left: auto;\n\n    &:last-child {\n      margin-right: auto;\n    }\n  }\n}\n</style>\n","<template lang=\"pug\">\n//- Only show panels in tabs when the tabs are also visible.\ncomponent.dito-panel(\n  v-if=\"shouldRenderSchema(panelSchema)\"\n  v-show=\"visible && (!panelTabComponent || panelTabComponent.visible)\"\n  :is=\"panelTag\"\n  @submit.prevent\n)\n  DitoSchema.dito-panel__schema(\n    :schema=\"panelSchema\"\n    :dataSchema=\"panelDataSchema\"\n    :dataPath=\"panelDataPath\"\n    :data=\"panelData\"\n    :meta=\"meta\"\n    :store=\"store\"\n    padding=\"nested\"\n    :disabled=\"disabled\"\n    :hasOwnData=\"hasOwnData\"\n    generateLabels\n  )\n    template(#prepend)\n      h2.dito-panel__header(:class=\"{ 'dito-panel__header--sticky': sticky }\")\n        span {{ getLabel(schema) }}\n        DitoButtons.dito-buttons--small(\n          :buttons=\"panelButtonSchemas\"\n          :dataPath=\"panelDataPath\"\n          :data=\"panelData\"\n          :meta=\"meta\"\n          :store=\"store\"\n          :disabled=\"disabled\"\n        )\n    template(#buttons)\n      DitoButtons(\n        :buttons=\"buttonSchemas\"\n        :dataPath=\"panelDataPath\"\n        :data=\"panelData\"\n        :meta=\"meta\"\n        :store=\"store\"\n        :disabled=\"disabled\"\n      )\n</template>\n\n<script>\nimport { isFunction } from '@ditojs/utils'\nimport DitoComponent from '../DitoComponent.js'\nimport ContextMixin from '../mixins/ContextMixin.js'\nimport ValidatorMixin from '../mixins/ValidatorMixin.js'\nimport { getButtonSchemas } from '../utils/schema.js'\nimport { getSchemaAccessor } from '../utils/accessor.js'\n\n// @vue/component\nexport default DitoComponent.component('DitoPanel', {\n  mixins: [ContextMixin, ValidatorMixin],\n\n  provide() {\n    return {\n      $panelComponent: () => this,\n      $tabComponent: () => this.panelTabComponent\n    }\n  },\n\n  props: {\n    schema: { type: Object, required: true },\n    dataPath: { type: String, required: true },\n    data: { type: Object, required: true },\n    meta: { type: Object, required: true },\n    store: { type: Object, required: true },\n    disabled: { type: Boolean, required: true },\n    panelTabComponent: { type: Object, default: null }\n  },\n\n  data() {\n    return {\n      ownData: null\n    }\n  },\n\n  computed: {\n    nested() {\n      // For `ContextMixin`:\n      return true\n    },\n\n    panelComponent() {\n      return this\n    },\n\n    tabComponent() {\n      return this.panelTabComponent\n    },\n\n    buttonSchemas() {\n      return getButtonSchemas(this.schema.buttons)\n    },\n\n    panelButtonSchemas() {\n      return getButtonSchemas(this.schema.panelButtons)\n    },\n\n    hasOwnData() {\n      return !!this.ownData\n    },\n\n    panelData() {\n      return this.ownData || this.data\n    },\n\n    panelSchema() {\n      if (this.hasOwnData) {\n        return this.schema\n      } else {\n        // Remove `data` from the schema, so that DitoSchema isn't using it to\n        // produce its own data. See $filters panel for more details on data.\n        const { data, ...schema } = this.schema\n        return schema\n      }\n    },\n\n    panelTag() {\n      // Panels that provide their own data need their own form.\n      return this.hasOwnData ? 'form' : 'div'\n    },\n\n    panelDataSchema() {\n      return this.hasOwnData ? this.schema : this.schemaComponent.schema\n    },\n\n    panelDataPath() {\n      // If the panel provides its own data, then it needs to prefix all\n      // components with its data-path, but if it shares data with the schema\n      // component, then it should share the data-path name space too.\n      return this.hasOwnData ? this.dataPath : this.schemaComponent.dataPath\n    },\n\n    visible: getSchemaAccessor('visible', {\n      type: Boolean,\n      default: true\n    }),\n\n    sticky: getSchemaAccessor('sticky', {\n      type: Boolean,\n      default: false\n    })\n  },\n\n  created() {\n    this._register(true)\n    // NOTE: This is not the same as `schema.data` handling in DitoSchema,\n    // where the data is added to the actual component.\n    const { data } = this.schema\n    if (data) {\n      this.ownData = isFunction(data)\n        ? data(this.context)\n        : data\n    }\n  },\n\n  unmounted() {\n    this._register(false)\n  },\n\n  methods: {\n    _register(add) {\n      // Register the panels so that other components can find them by their\n      // data-path, e.g. in TypeList.onFilterErrors()\n      this.schemaComponent._registerPanel(this, add)\n    }\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-panel {\n  &:not(:last-child) {\n    margin-bottom: $content-padding;\n  }\n\n  &__header {\n    display: block;\n    position: relative;\n    box-sizing: border-box;\n    padding: $input-padding;\n    background: $button-color;\n    border: $border-style;\n    border-top-left-radius: $border-radius;\n    border-top-right-radius: $border-radius;\n\n    &--sticky {\n      $margin: $input-height-factor * $line-height * $font-size-small +\n        $form-spacing;\n\n      position: sticky;\n      top: $content-padding;\n      margin-bottom: $margin;\n      z-index: 1;\n\n      & + * {\n        margin-top: -$margin;\n      }\n\n      &::before {\n        content: '';\n        display: block;\n        position: absolute;\n        background: $content-color-background;\n        left: 0;\n        right: 0;\n        height: $content-padding;\n        top: -$content-padding;\n        margin: -$border-width;\n      }\n    }\n\n    .dito-buttons {\n      position: absolute;\n      right: $input-padding-ver;\n      top: 50%;\n      transform: translateY(-50%);\n    }\n  }\n\n  &__schema {\n    font-size: $font-size-small;\n    background: $content-color-background;\n    border: $border-style;\n    border-top: 0;\n    border-bottom-left-radius: $border-radius;\n    border-bottom-right-radius: $border-radius;\n\n    > .dito-schema-content {\n      .dito-object {\n        border: none;\n        padding: 0;\n      }\n\n      > .dito-buttons {\n        --button-margin: #{$form-spacing};\n\n        padding: $form-spacing;\n\n        .dito-container {\n          padding: 0;\n        }\n      }\n    }\n\n    .dito-label {\n      label {\n        font-weight: normal;\n      }\n    }\n  }\n}\n</style>\n","<template lang=\"pug\">\n.dito-panels(\n  v-if=\"panels.length > 0\"\n)\n  template(\n    v-for=\"{ schema, dataPath, tabComponent } in panels\"\n  )\n    DitoPanel(\n      v-if=\"shouldRenderSchema(schema)\"\n      :key=\"getPanelKey(dataPath, tabComponent)\"\n      :schema=\"schema\"\n      :dataPath=\"dataPath\"\n      :data=\"data\"\n      :meta=\"meta\"\n      :store=\"getChildStore(schema.name)\"\n      :disabled=\"schema.disabled ?? disabled\"\n      :panelTabComponent=\"tabComponent\"\n    )\n</template>\n\n<script>\nimport DitoComponent from '../DitoComponent.js'\nimport ContextMixin from '../mixins/ContextMixin.js'\n\n// @vue/component\nexport default DitoComponent.component('DitoPanels', {\n  mixins: [ContextMixin],\n\n  props: {\n    panels: { type: Array, default: null },\n    data: { type: Object, required: true },\n    meta: { type: Object, required: true },\n    store: { type: Object, required: true },\n    disabled: { type: Boolean, required: true }\n  },\n\n  computed: {\n    nested() {\n      // For `ContextMixin`:\n      return false\n    }\n  },\n\n  methods: {\n    getPanelKey(dataPath, tabComponent) {\n      // Allow separate tabs to use panels of the same name, by\n      // prefixing their key with the tab name.\n      return tabComponent ? `${tabComponent.tab}_${dataPath}` : dataPath\n    }\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-panels {\n  margin: $content-padding;\n  margin-left: $form-spacing;\n}\n</style>\n","<template lang=\"pug\">\n.dito-buttons(\n  v-if=\"buttonSchemas || hasSlotContent($slots.default)\"\n)\n  template(\n    v-for=\"(buttonSchema, buttonDataPath) in buttonSchemas\"\n  )\n    DitoContainer(\n      v-if=\"shouldRenderSchema(buttonSchema)\"\n      :key=\"buttonDataPath\"\n      :schema=\"buttonSchema\"\n      :dataPath=\"buttonDataPath\"\n      :data=\"data\"\n      :meta=\"meta\"\n      :nested=\"nested\"\n      :store=\"getChildStore(buttonSchema.name)\"\n      :disabled=\"disabled\"\n    )\n  template(\n    v-for=\"vnode of $slots.default?.()\"\n  )\n    //- Render each node in the default slot through `dito-vnode`,\n    //- so it can be wrapped in a `.dito-container` class.\n    .dito-container(\n      v-if=\"hasVNodeContent(vnode)\"\n    )\n      DitoVnode(:vnode=\"vnode\")\n</template>\n\n<script>\nimport DitoComponent from '../DitoComponent.js'\nimport ContextMixin from '../mixins/ContextMixin.js'\nimport { appendDataPath } from '../utils/data.js'\nimport { hasSlotContent, hasVNodeContent } from '@ditojs/ui/src'\n\n// @vue/component\nexport default DitoComponent.component('DitoButtons', {\n  mixins: [ContextMixin],\n\n  provide: {\n    $tabComponent: () => null\n  },\n\n  props: {\n    buttons: { type: Object, default: null },\n    dataPath: { type: String, default: '' },\n    data: { type: [Object, Array], default: null },\n    meta: { type: Object, default: () => ({}) },\n    store: { type: Object, default: () => ({}) },\n    nested: { type: Boolean, default: true },\n    disabled: { type: Boolean, default: false }\n  },\n\n  computed: {\n    buttonSchemas() {\n      // Compute a buttons list which has the dataPath baked into its keys.\n      const { dataPath, buttons } = this\n      return buttons\n        ? Object.values(buttons).reduce((schemas, button) => {\n            schemas[appendDataPath(dataPath, button.name)] = button\n            return schemas\n          }, {})\n        : null\n    }\n  },\n\n  methods: {\n    hasSlotContent,\n    hasVNodeContent\n  }\n})\n</script>\n\n<style lang=\"scss\">\n.dito-buttons {\n  > .dito-container {\n    padding: 0;\n  }\n}\n</style>\n","<template lang=\"pug\">\n//- Set `@click.stop` to prevent click events from bubbling to dito-label.\nDitoButtons.dito-edit-buttons.dito-buttons--round(\n  :buttons=\"buttons\"\n  :dataPath=\"dataPath\"\n  :data=\"data\"\n  :meta=\"meta\"\n  :store=\"store\"\n  :nested=\"nested\"\n  @click.stop\n)\n  //- Firefox doesn't like <button> here, so use <a> instead:\n  a.dito-button(\n    v-if=\"draggable\"\n    :class=\"{ 'dito-button--disabled': isDraggableDisabled }\"\n    v-bind=\"getButtonAttributes(verbs.drag)\"\n  )\n  RouterLink.dito-button(\n    v-if=\"editable\"\n    :class=\"{ 'dito-button--disabled': isEditableDisabled }\"\n    :to=\"editPath ? { path: editPath } : {}\"\n    v-bind=\"getButtonAttributes(verbs.edit)\"\n  )\n  DitoCreateButton(\n    v-if=\"creatable\"\n    :schema=\"schema\"\n    :dataPath=\"dataPath\"\n    :data=\"data\"\n    :meta=\"meta\"\n    :store=\"store\"\n    :nested=\"nested\"\n    :path=\"createPath\"\n    :verb=\"verbs.create\"\n    :text=\"createButtonText\"\n    :disabled=\"isCreatableDisabled\"\n  )\n  button.dito-button(\n    v-if=\"deletable\"\n    type=\"button\"\n    :disabled=\"isDeletableDisabled\"\n    v-bind=\"getButtonAttributes(verbs.delete)\"\n    @click=\"$emit('delete')\"\n  )\n</template>\n\n<script>\nimport DitoComponent from '../DitoComponent.js'\nimport ContextMixin from '../mixins/ContextMixin.js'\nimport { capitalize } from '@ditojs/utils'\n\n// @vue/component\nexport default DitoComponent.component('DitoEditButtons', {\n  mixins: [ContextMixin],\n  emits: ['delete'],\n\n  props: {\n    buttons: { type: Object, default: null },\n    schema: { type: Object, required: true },\n    dataPath: { type: String, required: true },\n    data: { type: [Object, Array], default: null },\n    meta: { type: Object, required: true },\n    store: { type: Object, required: true },\n    nested: { type: Boolean, default: false },\n    disabled: { type: Boolean, required: true },\n    draggable: { type: Boolean, default: false },\n    editable: { type: Boolean, default: false },\n    creatable: { type: Boolean, default: false },\n    deletable: { type: Boolean, default: false },\n    editPath: { type: String, default: null },\n    createPath: { type: String, default: null }\n  },\n\n  computed: {\n    formLabel() {\n      return this.getLabel(this.schema.form)\n    },\n\n    isDraggableDisabled() {\n      return this.disabled || !this.hasSchemaOption('draggable')\n    },\n\n    isDeletableDisabled() {\n      return this.disabled || !this.hasSchemaOption('deletable')\n    },\n\n    isEditableDisabled() {\n      return (\n        this.disabled ||\n        !this.editPath ||\n        !this.hasSchemaOption('editable')\n      )\n    },\n\n    isCreatableDisabled() {\n      return (\n        this.disabled ||\n        !this.createPath ||\n        !this.hasSchemaOption('creatable')\n      )\n    },\n\n    createButtonText() {\n      return (\n        // Allow schema to override create button through creatable object:\n        this.schema.creatable?.label || (\n          // Auto-generate create button labels from from labels for list\n          // sources with only one form:\n          this.formLabel &&\n          `${capitalize(this.verbs.create)} ${this.formLabel}`\n        ) ||\n        null\n      )\n    }\n  },\n\n  methods: {\n    hasSchemaOption(name) {\n      // All options can be disabled on a per-form basis by setting\n      // `schema[name]` to `false` or a callback returning `false`.\n      return this.getSchemaValue(name, {\n        type: Boolean,\n        default: true\n      })\n    }\n  }\n})\n</script>\n\n<style lang=\"scss\">\n.dito-edit-buttons {\n  // Override cursor from collapsible dito-label:\n  cursor: default;\n  flex: none;\n}\n</style>\n","<template lang=\"pug\">\n.dito-create-button\n  button.dito-button(\n    v-if=\"creatableForm\"\n    :type=\"isInlined ? 'button' : 'submit'\"\n    :disabled=\"disabled\"\n    v-bind=\"getButtonAttributes(verb)\"\n    @click=\"createItem(creatableForm)\"\n  ) {{ text }}\n  template(\n    v-else-if=\"creatableForms\"\n  )\n    button.dito-button(\n      type=\"button\"\n      :disabled=\"disabled\"\n      v-bind=\"getButtonAttributes(verb)\"\n      @mousedown.stop=\"onPulldownMouseDown()\"\n    ) {{ text }}\n    ul.dito-pulldown(:class=\"{ 'dito-pulldown--open': pulldown.open }\")\n      li(\n        v-for=\"(form, type) in creatableForms\"\n        v-show=\"shouldShowSchema(form)\"\n      )\n        a.dito-pulldown__item(\n          :class=`{\n            'dito-pulldown__item--disabled': shouldDisableSchema(form)\n          }`\n          @mousedown.stop=\"onPulldownMouseDown(type)\"\n          @mouseup=\"onPulldownMouseUp(type)\"\n        ) {{ getLabel(form) }}\n</template>\n\n<script>\nimport DitoComponent from '../DitoComponent.js'\nimport ContextMixin from '../mixins/ContextMixin.js'\nimport PulldownMixin from '../mixins/PulldownMixin.js'\nimport { getFormSchemas, isInlined } from '../utils/schema.js'\n\n// @vue/component\nexport default DitoComponent.component('DitoCreateButton', {\n  mixins: [ContextMixin, PulldownMixin],\n\n  props: {\n    schema: { type: Object, required: true },\n    // The next four props are there for `DitoContext` and the `context()`\n    // getter in `DitoMixin`.\n    // TODO: Should they be moved to shared mixin that defines them as required\n    // and also provides the `context()` getter, perhaps `ContextMixin`?\n    // `schema` could be included as well, and `ContextMixin` could be used in\n    // `DitoForm`, `DitoView`, `DitoPanel`, `DitoSchema`, `DitoEditButtons`,\n    // etc? But the problem with the root components is that they don't have\n    // these props. We could add a `contextAttributes()` getter for easy passing\n    // on as `v-bind=\"contextAttributes\"`.\n    dataPath: { type: String, required: true },\n    data: { type: [Object, Array], default: null },\n    meta: { type: Object, required: true },\n    store: { type: Object, required: true },\n    nested: { type: Boolean, default: false },\n    path: { type: String, required: true },\n    verb: { type: String, required: true },\n    text: { type: String, default: null },\n    disabled: { type: Boolean, required: true }\n  },\n\n  computed: {\n    forms() {\n      return getFormSchemas(this.schema, this.context)\n    },\n\n    creatableForms() {\n      const entries = Object.entries(this.forms).filter(\n        ([, form]) => this.isFormCreatable(form)\n      )\n      return entries.length > 0\n        ? Object.fromEntries(entries)\n        : null\n    },\n\n    creatableForm() {\n      const forms = this.creatableForms\n      return forms && Object.keys(forms).length === 1 && forms.default || null\n    },\n\n    isInlined() {\n      return isInlined(this.schema)\n    }\n  },\n\n  methods: {\n    isFormCreatable(form) {\n      // Forms can be excluded from the list by providing `if: false` or\n      // `creatable: false`.\n      return (\n        this.shouldRenderSchema(form) &&\n        this.getSchemaValue('creatable', {\n          type: Boolean,\n          default: true,\n          schema: form\n        })\n      )\n    },\n\n    createItem(form, type = null) {\n      if (!this.shouldDisableSchema(form)) {\n        if (this.isInlined) {\n          this.sourceComponent.createItem(form, type)\n        } else {\n          const { creatable } = this.schema\n          const query = {\n            ...(type && { type }),\n            ...creatable?.query?.(this.context)\n          }\n          this.$router.push({\n            path: `${this.path}/create`,\n            query\n          })\n        }\n      } else {\n        throw new Error('Not allowed to create item for given form')\n      }\n    },\n\n    onPulldownSelect(type) {\n      this.createItem(this.forms[type], type)\n      this.setPulldownOpen(false)\n    }\n  }\n})\n</script>\n\n<style lang=\"scss\">\n.dito-create-button {\n  position: relative;\n\n  .dito-pulldown {\n    right: 0;\n\n    .dito-buttons--sticky & {\n      top: unset;\n      right: unset;\n      bottom: 0;\n      left: 0;\n    }\n  }\n}\n</style>\n","<template lang=\"pug\">\n.dito-clipboard.dito-buttons.dito-buttons--round(\n  v-if=\"clipboard\"\n)\n  button.dito-button.dito-button--copy(\n    ref=\"copyData\"\n    type=\"button\"\n    title=\"Copy Data\"\n    :disabled=\"!copyEnabled\"\n    @click=\"onCopy\"\n  )\n  button.dito-button.dito-button--paste(\n    type=\"button\"\n    title=\"Paste Data\"\n    :disabled=\"!pasteEnabled\"\n    @click=\"onPaste\"\n  )\n</template>\n\n<script>\nimport { isObject, clone, deindent } from '@ditojs/utils'\nimport DitoComponent from '../DitoComponent.js'\nimport DomMixin from '../mixins/DomMixin.js'\nimport DitoContext from '../DitoContext.js'\n\n// @vue/component\nexport default DitoComponent.component('DitoClipboard', {\n  mixins: [DomMixin],\n\n  props: {\n    clipboard: { type: [Boolean, Object], required: true },\n    schema: { type: Object, required: true }\n  },\n\n  data() {\n    return {\n      copyEnabled: false,\n      pasteEnabled: false\n    }\n  },\n\n  computed: {\n    clipboardOptions() {\n      return isObject(this.clipboard) ? this.clipboard : {}\n    },\n\n    copyData() {\n      const { copy } = this.clipboardOptions\n      return copy\n        ? clipboardData =>\n            copy.call(this, new DitoContext(this, { clipboardData }))\n        : clipboardData => clone(clipboardData)\n    },\n\n    pasteData() {\n      const { paste } = this.clipboardOptions\n      return paste\n        ? clipboardData =>\n            paste.call(this, new DitoContext(this, { clipboardData }))\n        : clipboardData => clipboardData\n    }\n  },\n\n  watch: {\n    // Check right away also in case there's already data (e.g. create form):\n    'parentComponent.hasData': {\n      immediate: true,\n      handler: 'updateCopy'\n    },\n\n    'appState.clipboardData': {\n      immediate: true,\n      handler: 'updatePaste'\n    }\n  },\n\n  mounted() {\n    // Check clipboard content whenever something gets copied or the window gets\n    // (re)activated, as those are the moments when the clipboard can change:\n    this.domOn(document, { copy: this.updatePaste })\n    this.domOn(window, { focus: this.updatePaste })\n  },\n\n  methods: {\n    checkClipboardData(clipboardData) {\n      const { $schema, ...data } = clipboardData || {}\n      return $schema === this.schema.name ? data : null\n    },\n\n    async getClipboardData(report) {\n      // Use the internal clipboard as fallback.\n      let { clipboardData } = this.appState\n      try {\n        const json = await navigator.clipboard?.readText?.()\n        if (json) {\n          clipboardData = JSON.parse(json)\n        }\n      } catch (err) {\n        if (report) {\n          console.error(err, err.name, err.message)\n          if (err.name === 'SyntaxError') {\n            alert(deindent`\n              The data in the clipboard appears to be malformed:\n              ${err.message}\n            `)\n          }\n        }\n      }\n      return this.checkClipboardData(clipboardData)\n    },\n\n    updateCopy() {\n      this.copyEnabled = this.parentComponent.hasData\n    },\n\n    async updatePaste() {\n      this.pasteEnabled = !!this.checkClipboardData(this.appState.clipboardData)\n      if (!this.pasteEnabled && this.appState.agent.chrome) {\n        // See if the clipboard content is valid JSON data that is compatible\n        // with the current target schema, and only then activate the pasting:\n        const data = await this.getClipboardData(false) // Don't report\n        this.pasteEnabled = !!data\n      }\n    },\n\n    async onCopy() {\n      let data = this.parentComponent.clipboardData\n      try {\n        if (data) {\n          data = {\n            $schema: this.schema.name,\n            ...this.copyData(data)\n          }\n        }\n        // Keep an internal clipboard as fallback.\n        this.appState.clipboardData = data\n        this.pasteEnabled = true\n        try {\n          const json = JSON.stringify(data, null, 2)\n          await navigator.clipboard?.writeText?.(json)\n        } catch (err) {\n          console.error(err, err.name, err.message)\n        }\n      } catch (error) {\n        console.error(error)\n        alert(error.message)\n      }\n    },\n\n    async onPaste() {\n      let data = await this.getClipboardData(true) // Report\n      try {\n        data = data && this.pasteData(data)\n        if (data) {\n          this.parentComponent.clipboardData = data\n        }\n      } catch (error) {\n        console.error(error)\n        alert(error.message)\n      }\n    }\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-clipboard {\n  display: flex;\n\n  .dito-schema & {\n    // Push clipboard to the right in the flex layout, see:\n    // https://codepen.io/tholex/pen/hveBx/\n    margin-left: auto;\n  }\n\n  .dito-header & {\n    margin-left: 0;\n\n    .dito-button {\n      margin: 0 0 $tab-margin $tab-margin;\n    }\n  }\n}\n</style>\n","// @vue/component\nexport default {\n  data() {\n    return {\n      isLoading: false\n    }\n  },\n\n  methods: {\n    setLoading(isLoading, { updateRoot = false, updateView = false } = {}) {\n      if (!this.isLoading ^ !isLoading) {\n        // Boolean xor\n        this.isLoading = !!isLoading\n        if (updateRoot) {\n          this.rootComponent.registerLoading(isLoading)\n        }\n        if (updateView) {\n          this.viewComponent.setLoading(this.isLoading)\n        }\n      }\n    }\n  }\n}\n","import ItemMixin from './ItemMixin.js'\nimport LoadingMixin from './LoadingMixin.js'\nimport { setDefaultValues } from '../utils/schema.js'\nimport { assignDeeply, isObject, isString, labelize } from '@ditojs/utils'\nimport { getResource } from '../utils/resource.js'\nimport DitoContext from '../DitoContext.js'\n\n// @vue/component\nexport default {\n  mixins: [ItemMixin, LoadingMixin],\n\n  provide() {\n    return {\n      $resourceComponent: () => this,\n      // Pass local verbs overrides on to children, see verbs() computed prop.\n      $verbs: () => this.verbs,\n      $isPopulated: () => this.hasData\n    }\n  },\n\n  data() {\n    return {\n      loadedData: null,\n      abortController: null\n    }\n  },\n\n  computed: {\n    resourceComponent() {\n      return this\n    },\n\n    resource() {\n      return this.getResource()\n    },\n\n    providesData() {\n      // This component is a data-source if it has an associated API resource:\n      return !!this.resource\n    },\n\n    linksToView() {\n      // Returns `false`here, but is overridden to return `true` in\n      // `SourceMixin` for component that do not provide their own data, but\n      // edit their items through a linked view.  In this case, real ids need to\n      // be used.\n      return false\n    },\n\n    isTransient() {\n      // Check the form that this component belongs to as well, since it may be\n      // in creation mode, which makes it transient.\n      // NOTE: This does not loop endlessly because DitoForm redefines\n      // `isTransient()` to only return `!this.providesData`.\n      const form = this.formComponent\n      return (\n        !this.providesData &&\n        !this.linksToView ||\n        form && (\n          form.isTransient ||\n          form.isCreating\n        )\n      )\n    },\n\n    transientNote() {\n      return (\n        this.isTransient && (\n          '<b>Note</b>: the parent still needs to be saved ' +\n          'in order to persist this change.'\n        )\n      )\n    },\n\n    shouldLoad() {\n      return (\n        !this.isTransient &&\n        !this.isLoading\n      )\n    },\n\n    // @overridable\n    hasData() {\n      // Base definition, will be overridden by DitoForm and SourceMixin\n      return !!this.loadedData\n    },\n\n    verbs() {\n      // The actual code is the `getVerbs()` method, for easier overriding of\n      // this computed property in components that use the ResourceMixin.\n      return this.getVerbs()\n    },\n\n    paginationRange() {\n      // Only apply pagination to lists.\n      const { paginate: amount } = this.sourceSchema\n      if (this.isListSource && amount) {\n        const { page = 0 } = this.query || {}\n        const start = page * amount\n        return [start, start + amount - 1]\n      }\n      return null\n    },\n\n    queryParams() {\n      const range = this.paginationRange\n      const { page, ...query } = this.query || {}\n      return {\n        ...query, // Query may override scope.\n        ...(range && {\n          // Pass pagination as range, so that we automatically get Objection's\n          // results counting:\n          range: range.join(',')\n        })\n      }\n    }\n  },\n\n  created() {\n    // When creating nested data, we still need to call setupData()\n    if (this.providesData || this.isCreating) {\n      this.setupData()\n    }\n  },\n\n  methods: {\n    getResource({ method = 'get', child } = {}) {\n      // Returns the resource object representing the resource for the\n      // associated source schema.\n      const resource = this.sourceSchema?.resource\n      return getResource(resource, {\n        type: 'collection',\n        method,\n        parent: this.parentResourceComponent?.getResource({\n          method,\n          child: resource\n        }) ?? null,\n        child\n      })\n    },\n\n    getVerbs() {\n      const verbs = this.$verbs()\n      return this.isTransient\n        ? {\n            ...verbs,\n            // Override default verbs with their transient versions:\n            create: 'add',\n            created: 'added',\n            save: 'apply',\n            saved: 'applied',\n            delete: 'remove',\n            deleted: 'removed'\n          }\n        : verbs\n    },\n\n    // @overridable\n    clearData() {\n      this.loadedData = null\n    },\n\n    // @overridable\n    setData(data) {\n      this.loadedData = data\n    },\n\n    setupData() {\n      // Actual code is in separate function so it's easer to override\n      // `setupData()` and and call `ensureData()` from the overrides,\n      // see DitoForm and SourceMixin.\n      this.ensureData()\n    },\n\n    ensureData() {\n      if (this.shouldLoad) {\n        if (this.hasData) {\n          this.reloadData()\n        } else {\n          this.loadData(true)\n        }\n      }\n    },\n\n    reloadData() {\n      this.loadData(false)\n    },\n\n    loadData(clear) {\n      if (!this.isTransient) {\n        if (clear) {\n          this.clearData()\n        }\n        this.requestData()\n      }\n    },\n\n    createData(schema, type) {\n      return setDefaultValues(schema, type ? { type } : {}, this)\n    },\n\n    requestData() {\n      const query = this.queryParams\n      this.handleRequest({ method: 'get', query }, (err, response) => {\n        if (err) {\n          if (response) {\n            const { data } = response\n            if (\n              data?.type === 'FilterValidation' &&\n              this.onFilterErrors?.(data.errors)\n            ) {\n              return true\n            } else if (this.isUnauthorizedError(response)) {\n              // TODO: Can we really swallow these errors?\n              // Is calling `ensureUser()` in `onBeforeRequest()` enough?\n              return true\n            }\n          }\n        } else {\n          this.setData(response.data)\n          this.emitSchemaEvent('load')\n        }\n      })\n    },\n\n    isValidationError(response) {\n      return response?.status === 400\n    },\n\n    isUnauthorizedError(response) {\n      return response?.status === 401\n    },\n\n    async handleRequest(\n      {\n        method,\n        resource = this.getResource({ method }),\n        query,\n        data\n      },\n      callback\n    ) {\n      const loadingOptions = {\n        updateRoot: true, // Display spinner in header when loading in resources\n        updateView: this.isInView // Notify view of loading for view components\n      }\n      this.abortController?.abort()\n      const controller = new AbortController()\n      this.abortController = controller\n      const { signal } = controller\n      method = resource.method || method\n      const request = { method, resource, query, data, signal }\n      this.setLoading(true, loadingOptions)\n      try {\n        const response = await this.sendRequest(request)\n        // Pass both request and response to the callback, so they can be\n        // exposed to further callbacks through DitoContext.\n        callback(null, response)\n      } catch (error) {\n        if (error.name !== 'AbortError') {\n          // If callback returns true, errors were already handled.\n          const { response } = error\n          if (!callback(error, response)) {\n            const data = response?.data\n            const title = isString(data?.type)\n              ? labelize(data.type)\n              : 'Error'\n            const text = data?.message ?? error\n            this.notify({ type: 'error', error, title, text })\n          }\n        }\n      }\n      if (this.abortController === controller) {\n        // Only clear the loading state if this is still the current request.\n        this.abortController = null\n        this.setLoading(false, loadingOptions)\n      }\n    },\n\n    getPayloadData(button, method) {\n      // Convention: only post, put and patch requests pass the data as payload.\n      return (\n        ['post', 'put', 'patch'].includes(method) && (\n          // TODO: Use `handleDataSchema()` asynchronously here instead, to\n          // offer the same amount of possibilities for data loading.\n          button.getSchemaValue(['resource', 'data']) ||\n          button.processedItem\n        )\n      )\n    },\n\n    async submit(button) {\n      let { resource } = button.schema\n      resource = getResource(resource, {\n        parent: this.getResource({\n          method: resource?.method,\n          child: resource\n        })\n      })\n      if (resource) {\n        const { method } = resource\n        const data = this.getPayloadData(button, method)\n        return this.submitResource(button, resource, method, data)\n      }\n      return false\n    },\n\n    async submitResource(button, resource, method, data, {\n      setData = false,\n      onSuccess,\n      onError,\n      notifySuccess = () =>\n        this.notify({\n          type: 'success',\n          title: 'Request Successful',\n          text: 'Request was successfully sent.'\n        }),\n      notifyError = error =>\n        this.notify({\n          type: 'error',\n          error,\n          title: 'Request Error',\n          text: [\n            `Unable to send request${error ? ':' : ''}`,\n            error?.message || error\n          ]\n        })\n    } = {}) {\n      return new Promise(resolve => {\n        this.handleRequest(\n          { method, resource, data },\n          async (err, response) => {\n            const data = response?.data\n            if (err) {\n              // See if we're dealing with a Dito.js validation error:\n              const errors = this.isValidationError(response) && data.errors\n              if (errors) {\n                await this.showValidationErrors(errors, true)\n              } else {\n                const error = isObject(data) ? data : err\n                onError?.(error)\n                await this.emitButtonEvent(button, 'error', {\n                  notify: notifyError,\n                  error\n                })\n              }\n              resolve(false)\n            } else {\n              // Update the underlying data before calling `notify()` or\n              // `this.itemLabel`, so id is set after creating new items.\n              if (setData && data) {\n                // Preserve the foreign data entries when updating the data.\n                const { foreignData } = this.mainSchemaComponent.filterData(\n                  this.data\n                )\n                // Tell the parent route to reload its data, so that it can\n                // update its foreign data entries.\n                const parentMeta = this.parentRouteComponent?.routeRecord?.meta\n                if (parentMeta) {\n                  parentMeta.reload = true\n                }\n                this.setData(assignDeeply({}, foreignData, data))\n              }\n              onSuccess?.()\n              await this.emitButtonEvent(button, 'success', {\n                notify: notifySuccess\n              })\n              resolve(true)\n            }\n          }\n        )\n      })\n    },\n\n    async emitButtonEvent(button, event, { notify, error }) {\n      // Create the context outside of `emitEvent()`, so that\n      // `context.wasNotified` can be checked after.\n      const context = new DitoContext(button, {\n        nested: false,\n        data: this.data,\n        itemLabel: this.itemLabel,\n        error\n      })\n      const res = await button.emitEvent(event, { context })\n      if (\n        notify &&\n        // Prevent default if anything was returned from the event handler.\n        res === undefined &&\n        // Do not display default notification if the event handler already\n        // displayed a notification.\n        !context.wasNotified\n      ) {\n        notify(error)\n      }\n      return res\n    }\n  }\n}\n","export function resolvePath(path) {\n  // For paths staring with `/`, we can use the native `URL()` class to resolve\n  // the path, which will also handle `..` and `.` segments:\n  return new URL(`file:${path}`).pathname\n}\n","<template lang=\"pug\">\n.dito-form.dito-scroll-parent(\n  :class=\"{ 'dito-form-nested': isNestedRoute }\"\n  :data-resource=\"sourceSchema.path\"\n)\n  //- Only render a router-view here if this isn't the last data route and not a\n  //- nested form route, which will appear elsewhere in its own view.\n  RouterView(\n    v-if=\"!isLastUnnestedRoute && !isNestedRoute\"\n    v-show=\"!isActiveRoute\"\n  )\n  //- NOTE: Nested form components are kept alive by using `v-show` instead of\n  //- `v-if` here, so event handling and other things still work with nested\n  //- editing.\n  DitoFormInner(\n    v-show=\"isActiveRoute\"\n    :nested=\"isNestedRoute\"\n  )\n    //- Prevent implicit submission of the form, for example when typing enter\n    //- in an input field.\n    //- https://stackoverflow.com/a/51507806\n    button(\n      v-show=\"false\"\n      type=\"submit\"\n      disabled\n    )\n    DitoSchema(\n      :schema=\"schema\"\n      :dataPath=\"dataPath\"\n      :data=\"data\"\n      :meta=\"meta\"\n      :store=\"store\"\n      :padding=\"isNestedRoute ? 'nested' : 'root'\"\n      :active=\"isActiveRoute\"\n      :disabled=\"isLoading\"\n      :scrollable=\"!isNestedRoute\"\n      generateLabels\n    )\n      template(#buttons)\n        DitoButtons.dito-buttons--round.dito-buttons--large.dito-buttons--main(\n          :class=\"{ 'dito-buttons--sticky': !isNestedRoute }\"\n          :buttons=\"buttonSchemas\"\n          :dataPath=\"dataPath\"\n          :data=\"data\"\n          :meta=\"meta\"\n          :store=\"store\"\n          :disabled=\"isLoading\"\n        )\n</template>\n\n<script>\nimport { clone, capitalize, parseDataPath, assignDeeply } from '@ditojs/utils'\nimport DitoComponent from '../DitoComponent.js'\nimport RouteMixin from '../mixins/RouteMixin.js'\nimport ResourceMixin from '../mixins/ResourceMixin.js'\nimport { getResource, getMemberResource } from '../utils/resource.js'\nimport { getButtonSchemas, isObjectSource } from '../utils/schema.js'\nimport { resolvePath } from '../utils/path.js'\n\n// @vue/component\nexport default DitoComponent.component('DitoForm', {\n  mixins: [RouteMixin, ResourceMixin],\n\n  data() {\n    return {\n      createdData: null,\n      clonedData: undefined,\n      sourceKey: null,\n      isForm: true\n    }\n  },\n\n  computed: {\n    verbs() {\n      // Add submit / submitted to the verbs returned by ResourceMixin\n      // NOTE: These get passed on to children through:\n      // `provide() ... { $verbs: () => this.verbs }` in ResourceMixin\n      const verbs = this.getVerbs()\n      const { isCreating, providesData } = this\n      return {\n        ...verbs,\n        submit: isCreating ? verbs.create : verbs.save,\n        submitted: isCreating ? verbs.created : verbs.saved,\n        cancel: providesData ? verbs.cancel : verbs.close,\n        cancelled: providesData ? verbs.cancelled : verbs.closed\n      }\n    },\n\n    schema() {\n      return this.getItemFormSchema(\n        this.sourceSchema,\n        this.data || (\n          this.creationType\n            ? // If there is no data yet but the type to create a new item is\n              // is specified, provide a temporary empty object with just the\n              // type set, so `getItemFormSchema()` can determine the form.\n              { type: this.creationType }\n            : null\n        ),\n        this.context\n      )\n    },\n\n    buttonSchemas() {\n      return getButtonSchemas(\n        assignDeeply(\n          {\n            cancel: {\n              type: 'button',\n              events: {\n                click: () => this.cancel()\n              }\n            },\n\n            submit: !this.isMutating && {\n              type: 'submit',\n              // Submit buttons close the form by default:\n              closeForm: true,\n              events: {\n                click: ({ component: button }) => button.submit()\n              }\n            }\n          },\n          this.schema.buttons\n        )\n      )\n    },\n\n    isActiveRoute() {\n      return this.isLastRoute || this.isLastUnnestedRoute\n    },\n\n    isTransient() {\n      return !this.providesData\n    },\n\n    isCreating() {\n      // this.param is inherited from RouteMixin\n      return this.param === 'create'\n    },\n\n    isDirty() {\n      return !this.isMutating && !!this.mainSchemaComponent?.isDirty\n    },\n\n    isMutating() {\n      // When `sourceSchema.mutate` is true, the form edits the inherited data\n      // directly instead of making a copy for persistence upon submission.\n      // See `inheritedData()` computed property for more details.\n      return !!this.sourceSchema.mutate\n    },\n\n    selectedTab() {\n      return this.mainSchemaComponent?.selectedTab || null\n    },\n\n    creationType() {\n      // The type of form to create, if there are multiple forms to choose from.\n      return this.$route.query.type\n    },\n\n    itemId() {\n      return this.isCreating\n        ? null\n        : this.param ?? null\n    },\n\n    method() {\n      return this.isCreating ? 'post' : 'patch'\n    },\n\n    breadcrumbPrefix() {\n      return capitalize(this.isCreating ? this.verbs.create : this.verbs.edit)\n    },\n\n    data() {\n      // Return different data \"containers\" based on different scenarios:\n      // 1. createdData, if we're in a form for a newly created object.\n      // 2. loadedData, if the form itself is the root of the data (e.g. when\n      //    directly loading an editing root).\n      // 3. The data inherited from the parent, which itself may be either a\n      //    view that loaded the data, or a form that either loaded the data, or\n      //    also inherited it from its parent. Note that we use a clone of it,\n      //    so, data changes aren't applied until setSourceData() is called.\n      return this.createdData || this.loadedData || this.inheritedData || null\n    },\n\n    dataPath() {\n      return this.getDataPathFrom(this.dataComponent)\n    },\n\n    sourceData() {\n      // Possible parents are DitoForm for forms, or DitoView for root lists.\n      // Both have a data property which abstracts away loading and inheriting\n      // of data.\n      // Forms that are about to be destroyed due to navigation loose their\n      // route-record, but might still trigger this getter. Filter those out.\n      let data = this.routeRecord ? this.parentRouteComponent.data : null\n      if (data) {\n        // Handle nested data by splitting the dataPath, iterate through the\n        // actual data and look nest child-data up.\n        const dataParts = parseDataPath(\n          this.getDataPathFrom(this.parentRouteComponent)\n        )\n        // Compare dataParts against matched routePath parts, to identify those\n        // parts that need to be treated like ids and mapped to indices in data.\n        const pathParts = this.routeRecord.path.split('/')\n        const routeParts = pathParts.slice(pathParts.length - dataParts.length)\n        // TODO: Fix side-effects\n        // eslint-disable-next-line vue/no-side-effects-in-computed-properties\n        this.sourceKey = null\n        const lastDataPart = dataParts[dataParts.length - 1]\n        if (isObjectSource(this.sourceSchema) && lastDataPart === 'create') {\n          // If we have an object source and are creating, the dataPath needs to\n          // be shortened by the 'create' entry. This isn't needed for list\n          // sources, as there the parameter is actually mapped to the item id.\n          dataParts.length--\n        }\n        for (let i = 0, l = dataParts.length; i < l && data; i++) {\n          const dataPart = dataParts[i]\n          // If this is an :id part, find the index of the item with given id.\n          const key = /^:id/.test(routeParts[i])\n            ? dataPart === 'create'\n              ? null // There's no index for entries about to be created\n              : this.findItemIdIndex(this.sourceSchema, data, dataPart)\n            : dataPart\n          // Skip the final lookup but remember `sourceKey`, as we want the\n          // parent data so we can replace the entry at `sourceKey` on it.\n          if (i === l - 1) {\n            // TODO: Fix side-effects\n            // eslint-disable-next-line max-len\n            // eslint-disable-next-line vue/no-side-effects-in-computed-properties\n            this.sourceKey = key\n          } else {\n            data = data[key]\n          }\n        }\n      }\n      return data\n    },\n\n    inheritedData() {\n      // Data inherited from parent, and cloned to protect against reactive\n      // changes until changes are applied through setSourceData(), unless\n      // `sourceSchema.mutate` is true, in which case data is mutated directly.\n      if (\n        this.isTransient &&\n        this.clonedData === undefined &&\n        this.sourceData &&\n        this.sourceKey !== null\n      ) {\n        let data = this.sourceData[this.sourceKey]\n        if (!this.isMutating) {\n          // Use a trick to store cloned inherited data in clonedData, to make\n          // it reactive and prevent it from being cloned multiple times.\n          // TODO: Fix side-effects\n          // eslint-disable-next-line vue/no-side-effects-in-computed-properties\n          this.clonedData = data = clone(data)\n        }\n        if (\n          data === null &&\n          !this.isCreating &&\n          isObjectSource(this.sourceSchema)\n        ) {\n          // If data of an object source is null, redirect to its create route.\n          // TODO: Fix side-effects\n          // eslint-disable-next-line vue/no-side-effects-in-computed-properties\n          this.$router.push({ path: `${this.path}/create` })\n        }\n        return data\n      }\n      return this.clonedData\n    },\n\n    // @override ResourceMixin.hasData()\n    hasData() {\n      return !!this.data\n    },\n\n    itemLabel() {\n      return this.getItemLabel(this.sourceSchema, this.data, { extended: true })\n    }\n  },\n\n  watch: {\n    $route: {\n      // https://github.com/vuejs/vue-router/issues/3393#issuecomment-1158470149\n      flush: 'post',\n      handler(to, from) {\n        // Reload form data when navigating to a different entity in same form.\n        const param = this.meta?.param\n        if (\n          param &&\n          this.providesData &&\n          // TODO: See if we can remove this due to `flush: 'post'`.\n          from.matched[0].path === to.matched[0].path && // Staying on same form\n          from.params[param] !== 'create' && // But haven't been creating\n          to.params[param] !== from.params[param] // Going to a different entity\n        ) {\n          this.loadData(true)\n        }\n      }\n    },\n\n    sourceData: 'clearClonedData',\n    // Needed for the 'create' redirect in `inheritedData()` to work:\n    create: 'setupData'\n  },\n\n  methods: {\n    emitSchemaEvent(event, params) {\n      return this.mainSchemaComponent?.emitEvent(event, params)\n    },\n\n    getDataPathFrom(routeComponent) {\n      // Get the data path by denormalizePath the relative route path\n      return this.api.denormalizePath(\n        this.path\n          // DitoViews have nested routes, so don't remove their path.\n          .slice((routeComponent.isView ? 0 : routeComponent.path.length) + 1)\n      )\n    },\n\n    // @override ResourceMixin.getResource()\n    getResource(options) {\n      const resource = ResourceMixin.methods.getResource.call(this, options)\n      return getMemberResource(this.itemId, resource) || resource\n    },\n\n    // @override ResourceMixin.setupData()\n    setupData() {\n      if (this.isCreating) {\n        this.createdData ||= this.createData(this.schema, this.creationType)\n      } else {\n        this.ensureData()\n      }\n    },\n\n    setSourceData(data) {\n      if (this.sourceData && this.sourceKey !== null) {\n        const { mainSchemaComponent } = this\n        this.sourceData[this.sourceKey] =\n          mainSchemaComponent.filterData(data).localData\n        mainSchemaComponent.onChange()\n        return true\n      }\n      return false\n    },\n\n    addSourceData(data) {\n      return isObjectSource(this.sourceSchema)\n        ? this.setSourceData(data)\n        : !!this.sourceData?.push(data)\n    },\n\n    // @override ResourceMixin.clearData()\n    clearData() {\n      this.setData(null)\n    },\n\n    // @override ResourceMixin.setData()\n    setData(data) {\n      // setData() is called after submit when data has changed.\n      if (this.isTransient) {\n        // For components with transient data, modify this.sourceData.\n        this.setSourceData(data)\n      } else {\n        this.createdData = null\n        this.loadedData = data\n      }\n    },\n\n    clearClonedData(to, from) {\n      // Only clear if the watched sourceData itself changes in the form.\n      if (to !== from) {\n        this.clonedData = undefined\n      }\n    },\n\n    async cancel() {\n      return this.close()\n    },\n\n    async close() {\n      return this.navigate(this.parentRouteComponent.path)\n    },\n\n    getSubmitVerb(present = true) {\n      return this.isCreating\n        ? present\n          ? 'create'\n          : 'created'\n        : present\n          ? 'submit'\n          : 'submitted'\n    },\n\n    async submit(button, { validate = true, closeForm = false } = {}) {\n      if (validate && !this.validateAll()) {\n        return false\n      }\n\n      const getVerb = present => this.verbs[this.getSubmitVerb(present)]\n\n      // Allow buttons to override both method and resource path to submit to:\n      let { method } = this\n      let resource = this.getResource({ method })\n      const buttonResource = getResource(button.schema.resource, {\n        parent: resource\n      })\n      resource = buttonResource || resource\n      method = resource?.method || method\n      const data = this.getPayloadData(button, method)\n      let success\n      if (!buttonResource && this.isTransient) {\n        success = await this.submitTransient(button, resource, method, data, {\n          onSuccess: () => this.emitSchemaEvent(this.getSubmitVerb()),\n          onError: error =>\n            this.emitSchemaEvent('error', {\n              context: { error }\n            }),\n          notifySuccess: () => {\n            const verb = getVerb(false)\n            this.notify({\n              type: 'info',\n              title: this.isCreating\n                ? `Item ${capitalize(verb)}`\n                : `Change ${capitalize(verb)}`,\n              text: [\n                this.isCreating\n                  ? `${this.itemLabel} was ${verb}.`\n                  : `Changes to ${this.itemLabel} were ${verb}.`,\n                this.transientNote\n              ]\n            })\n          },\n          notifyError: error => {\n            const verb = getVerb(true)\n            this.notify({\n              type: 'error',\n              error,\n              title: 'Request Error',\n              text: `Unable to ${verb} ${this.itemLabel}.`\n            })\n          }\n        })\n      } else {\n        success = await this.submitResource(button, resource, method, data, {\n          setData: true,\n          onSuccess: () => this.emitSchemaEvent(this.getSubmitVerb()),\n          onError: error =>\n            this.emitSchemaEvent('error', {\n              context: { error }\n            }),\n          notifySuccess: () => {\n            const verb = getVerb(false)\n            this.notify({\n              type: 'success',\n              title: `Successfully ${capitalize(verb)}`,\n              text: `${this.itemLabel} was ${verb}.`\n            })\n          },\n          notifyError: error => {\n            const verb = getVerb(true)\n            this.notify({\n              type: 'error',\n              error,\n              title: 'Request Error',\n              text: [\n                `Unable to ${verb} ${this.itemLabel}${error ? ':' : ''}`,\n                error?.message || error\n              ]\n            })\n          }\n        })\n      }\n      if (success) {\n        this.resetValidation()\n        if (closeForm || button.closeForm) {\n          this.close()\n        } else if (this.isCreating) {\n          // Redirect to the form editing the newly created item:\n          const id = this.getItemId(this.schema, this.data)\n          this.$router.replace({\n            path: resolvePath(`${this.path}/../${id}`),\n            // Preserve hash for tabs:\n            hash: this.$route.hash\n          })\n        }\n      }\n      return success\n    },\n\n    async submitTransient(button, _resource, _method, data, {\n      onSuccess,\n      onError,\n      notifySuccess,\n      notifyError\n    }) {\n      // Handle the default \"submitting\" of transient, nested data:\n      const success = this.isCreating\n        ? this.addSourceData(data)\n        : this.setSourceData(data)\n      if (success) {\n        onSuccess?.()\n        await this.emitButtonEvent(button, 'success', {\n          notify: notifySuccess\n        })\n      } else {\n        const error = 'Could not submit transient item'\n        onError?.(error)\n        await this.emitButtonEvent(button, 'error', {\n          notify: notifyError,\n          error\n        })\n      }\n      return success\n    }\n  }\n})\n</script>\n","<template lang=\"pug\">\n//- Use a <div> for nested forms, as we shouldn't nest actual <form> tags.\ndiv(\n  v-if=\"nested\"\n)\n  slot\nform.dito-scroll-parent(\n  v-else\n  @submit.prevent\n)\n  slot\n</template>\n\n<script>\nimport DitoComponent from '../DitoComponent.js'\n\n// @vue/component\nexport default DitoComponent.component('DitoFormInner', {\n  props: {\n    nested: {\n      type: Boolean,\n      default: false\n    }\n  }\n})\n</script>\n","<script>\nimport DitoComponent from '../DitoComponent.js'\nimport DitoForm from './DitoForm.vue'\n\n// @vue/component\nexport default DitoComponent.component('DitoFormNested', {\n  extends: DitoForm\n})\n</script>\n\n<style lang=\"scss\">\n.dito-form-nested {\n  // No scrolling inside nested forms, and prevent open .multiselect from\n  // being cropped.\n  overflow: visible;\n}\n</style>\n","<template lang=\"pug\">\n.dito-errors(\n  v-if=\"errors\"\n)\n  ul\n    li(\n      v-for=\"error of errors\"\n    ) {{ error }}\n</template>\n\n<script>\nimport tippy from 'tippy.js'\nimport DitoComponent from '../DitoComponent.js'\nimport { markRaw } from 'vue'\n\n// @vue/component\nexport default DitoComponent.component('DitoErrors', {\n  props: {\n    errors: { type: Array, default: null }\n  },\n\n  data() {\n    return {\n      tip: null\n    }\n  },\n\n  watch: {\n    errors() {\n      this.$nextTick(this.updateErrors)\n    }\n  },\n\n  unmounted() {\n    this.tip?.destroy()\n  },\n\n  methods: {\n    updateErrors() {\n      let { tip } = this\n      tip?.hide()\n      if (this.errors) {\n        tip = this.tip ??= markRaw(tippy(this.$el.closest('.dito-container')))\n        tip.setProps({\n          content: this.errors.join('\\n'),\n          theme: 'error',\n          trigger: 'manual',\n          appendTo: 'parent',\n          placement: 'bottom-start',\n          animation: 'shift-away-subtle',\n          popperOptions: {\n            modifiers: [\n              {\n                name: 'flip',\n                enabled: false\n              }\n            ]\n          },\n          interactive: true,\n          hideOnClick: false,\n          offset: [3, 3], // 1/2 form-spacing\n          zIndex: 1\n        })\n        tip.popper.addEventListener('mousedown', () => tip.hide())\n        tip.show()\n      }\n    }\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-errors {\n  position: absolute;\n  visibility: hidden;\n\n  ul {\n    color: $color-error;\n  }\n}\n</style>\n","<template lang=\"pug\">\n.dito-scopes\n  RouterLink(\n    v-for=\"(scope, key) in scopes\"\n    :key=\"key\"\n    v-slot=\"{ navigate }\"\n    :to=\"getScopeLink(scope)\"\n    custom\n  )\n    button.dito-button(\n      type=\"button\"\n      :class=\"{ 'dito-button--selected': scope.name === query.scope }\"\n      :title=\"scope.hint || getLabel(scope)\"\n      @click=\"navigate\"\n    ) {{ getLabel(scope) }}\n</template>\n\n<script>\nimport DitoComponent from '../DitoComponent.js'\n\n// @vue/component\nexport default DitoComponent.component('DitoScopes', {\n  props: {\n    query: { type: Object, required: true },\n    scopes: { type: Object, required: true }\n  },\n\n  methods: {\n    getScopeLink(scope) {\n      const query = { ...this.query, scope: scope.name }\n      if (query.page) {\n        query.page = 0\n      }\n      return this.getQueryLink(query)\n    }\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-scopes {\n  white-space: nowrap;\n  display: flex;\n\n  .dito-button {\n    @include ellipsis;\n\n    border-radius: 0;\n    // A bit more than the width of ellipsis, to prevent replacing short words\n    // with ellipsis.\n    min-width: 3em;\n    flex: 0 1 auto;\n\n    &:first-child {\n      border-top-left-radius: 1em;\n      border-bottom-left-radius: 1em;\n      padding-left: 1em;\n    }\n\n    &:last-child {\n      border-top-right-radius: 1em;\n      border-bottom-right-radius: 1em;\n      padding-right: 1em;\n    }\n\n    & + .dito-button {\n      margin-left: -1px;\n    } // Don't cover the focused border of buttons:\n    &:focus {\n      z-index: 1;\n    }\n  }\n}\n</style>\n","<template lang=\"pug\">\nPagination(\n  v-model:page=\"page\"\n  :pageSize=\"limit\"\n  :total=\"total\"\n)\n</template>\n\n<script>\nimport { DitoPagination as Pagination } from '@ditojs/ui/src'\nimport DitoComponent from '../DitoComponent.js'\n\n// @vue/component\nexport default DitoComponent.component('DitoPagination', {\n  components: { Pagination },\n\n  props: {\n    query: { type: Object, required: true },\n    limit: { type: Number, required: true },\n    total: { type: Number, required: true }\n  },\n\n  computed: {\n    page: {\n      get() {\n        return (+this.query.page || 0) + 1\n      },\n\n      set(page) {\n        if (this.page !== page) {\n          this.$router.push(\n            this.getQueryLink({\n              ...this.query,\n              page: page - 1\n            })\n          )\n        }\n      }\n    }\n  }\n})\n</script>\n","// @vue/component\nexport default {\n  data() {\n    return {\n      isDragging: false\n    }\n  },\n\n  methods: {\n    getDraggableOptions(forceFallback = false) {\n      const prefix = 'dito-draggable'\n      return {\n        animation: 150,\n        handle: '.dito-button--drag',\n        dragClass: `${prefix}__drag`,\n        chosenClass: `${prefix}__chosen`,\n        ghostClass: `${prefix}__ghost`,\n        fallbackClass: `${prefix}__fallback`,\n        forceFallback,\n        onStart: this.onStartDrag,\n        onEnd: this.onEndDrag\n      }\n    },\n\n    onStartDrag() {\n      this.isDragging = true\n    },\n\n    onEndDrag({ oldIndex, newIndex }) {\n      this.isDragging = false\n      if (oldIndex !== newIndex) {\n        this.onChange()\n      }\n    },\n\n    updateOrder(sourceSchema, list, paginationRange) {\n      const { orderKey } = sourceSchema\n      if (orderKey) {\n        // Reorder the changed entries by their order key, taking pagination\n        // offsets into account:\n        const offset = paginationRange?.[0] || 0\n        for (let i = 0; i < list.length; i++) {\n          list[i][orderKey] = i + offset\n        }\n      }\n      return list\n    }\n  }\n}\n","<template lang=\"pug\">\n.dito-tree-item(\n  :id=\"dataPath\"\n  :class=`{\n    'dito-tree-item--dragging': isDragging,\n    'dito-tree-item--active': active\n  }`\n  :style=\"level > 0 && { '--level': level }\"\n  :data-path=\"path\"\n)\n  .dito-tree-header(\n    v-if=\"label\"\n  )\n    .dito-tree-branch(\n      v-if=\"numEntries\"\n      @click.stop=\"opened = !opened\"\n    )\n      .dito-chevron(\n        v-if=\"numEntries\"\n        :class=\"{ 'dito-chevron--open': opened }\"\n      )\n      .dito-tree-label(\n        v-html=\"label\"\n      )\n      .dito-tree-info(\n        v-if=\"details\"\n      ) {{ details }}\n    .dito-tree-leaf(\n      v-else\n    )\n      .dito-tree-label(\n        v-html=\"label\"\n      )\n    .dito-buttons.dito-buttons--small(\n      v-if=\"hasEditButtons\"\n    )\n      //- Firefox doesn't like <button> here, so use <a> instead:\n      a.dito-button(\n        v-if=\"draggable\"\n        v-bind=\"getButtonAttributes(verbs.drag)\"\n      )\n      button.dito-button(\n        v-if=\"editable\"\n        type=\"button\"\n        v-bind=\"getButtonAttributes(verbs.edit)\"\n        @click=\"onEdit\"\n      )\n      button.dito-button(\n        v-if=\"deletable\"\n        type=\"button\"\n        v-bind=\"getButtonAttributes(verbs.delete)\"\n        @click=\"onDelete\"\n      )\n  table.dito-properties(\n    v-if=\"properties\"\n    v-show=\"opened\"\n  )\n    tr(\n      v-for=\"property in properties\"\n    )\n      td\n        DitoLabel(\n          v-if=\"property.label !== false\"\n          :dataPath=\"getPropertyDataPath(property)\"\n          :label=\"getLabel(property)\"\n        )\n      DitoTableCell(\n        :cell=\"property\"\n        :schema=\"property\"\n        :dataPath=\"getPropertyDataPath(property)\"\n        :data=\"data\"\n        :meta=\"nestedMeta\"\n        :store=\"store\"\n        :disabled=\"disabled\"\n      )\n  DitoDraggable(\n    v-if=\"childrenSchema\"\n    v-show=\"opened\"\n    :options=\"getDraggableOptions(true)\"\n    :draggable=\"childrenDraggable\"\n    :modelValue=\"updateOrder(childrenSchema, childrenList)\"\n    @update:modelValue=\"value => (childrenList = value)\"\n  )\n    DitoTreeItem(\n      v-for=\"(item, index) in childrenItems\"\n      :key=\"getItemUid(childrenSchema, item.data)\"\n      :schema=\"childrenSchema\"\n      :dataPath=\"getItemDataPath(childrenSchema, index)\"\n      :data=\"item.data\"\n      :path=\"item.path\"\n      :open=\"item.open\"\n      :active=\"item.active\"\n      :draggable=\"childrenDraggable\"\n      :label=\"getItemLabel(childrenSchema, item.data, { index })\"\n      :level=\"level + 1\"\n    )\n    //- TODO: Convert dito-tree-item to use dito-label internally, and then\n    //- pass `asObject: true` in the `getItemLabel()` call above.\n</template>\n\n<script>\nimport DitoComponent from '../DitoComponent.js'\nimport ItemMixin from '../mixins/ItemMixin'\nimport SortableMixin from '../mixins/SortableMixin.js'\nimport { appendDataPath } from '../utils/data.js'\nimport { getSchemaAccessor } from '../utils/accessor.js'\nimport { getNamedSchemas, hasFormSchema } from '../utils/schema.js'\n\n// @vue/component\nexport default DitoComponent.component('DitoTreeItem', {\n  mixins: [ItemMixin, SortableMixin],\n  emits: ['update:data'],\n  inject: ['container'],\n\n  props: {\n    schema: { type: Object, required: true },\n    dataPath: { type: String, required: true },\n    data: { type: [Array, Object], default: null },\n    path: { type: String, default: '' },\n    open: { type: Boolean, default: false },\n    active: { type: Boolean, default: false },\n    draggable: { type: Boolean, default: false },\n    label: { type: String, default: null },\n    level: { type: Number, default: 0 }\n  },\n\n  data() {\n    return {\n      opened: this.open || this.schema.open\n    }\n  },\n\n  computed: {\n    meta() {\n      return this.container.meta\n    },\n\n    store() {\n      return this.container.store\n    },\n\n    disabled() {\n      return this.container.disabled\n    },\n\n    nestedMeta() {\n      return {\n        ...this.meta,\n        schema: this.schema\n      }\n    },\n\n    properties() {\n      return getNamedSchemas(this.schema.properties)\n    },\n\n    // TODO: Should this be named `sourceSchema` instead? Use SourceMixin?\n    childrenSchema() {\n      return this.schema.children\n    },\n\n    childrenList: {\n      get() {\n        const name = this.childrenSchema?.name\n        return name && this.data[name]\n      },\n\n      set(value) {\n        const name = this.childrenSchema?.name\n        if (name) {\n          this.updateOrder(this.childrenSchema, value)\n          // eslint-disable-next-line vue/no-mutating-props\n          this.data[name] = value\n          this.$emit('update:data', value)\n        }\n      }\n    },\n\n    childrenDraggable() {\n      return (\n        this.childrenList?.length > 1 &&\n        this.getSchemaValue('draggable', {\n          type: Boolean,\n          default: false,\n          schema: this.childrenSchema\n        })\n      )\n    },\n\n    numChildren() {\n      return this.childrenList?.length || 0\n    },\n\n    numProperties() {\n      return this.properties?.length || 0\n    },\n\n    numEntries() {\n      return this.numProperties + this.numChildren\n    },\n\n    childrenItems() {\n      const { childrenSchema, childrenList } = this\n      if (childrenSchema && childrenList) {\n        const { editPath } = this.container\n        const childrenOpen = !this.path && childrenSchema.open\n        // Build a children list with child meta information for the template.\n        return childrenList.map((data, index) => {\n          const path = (\n            childrenSchema.path &&\n            `${this.path}/${childrenSchema.path}/${index}`\n          )\n          const open = (\n            childrenOpen ||\n            // Only count as \"in edit path\" when it's not the full edit path.\n            editPath.startsWith(path) && path.length < editPath.length\n          )\n          const active = editPath === path\n          return { data, path, open, active }\n        })\n      }\n      return []\n    },\n\n    details() {\n      const { numChildren } = this\n      return (\n        numChildren &&\n        `${numChildren} ${\n          numChildren === 1 ? 'item' : 'items'\n        }`\n      )\n    },\n\n    hasEditButtons() {\n      return this.draggable || this.editable || this.deletable\n    },\n\n    // TODO: Support creatable!\n    // TODO: Add support for creatable, editable and deletable overrides on the\n    // associated forms, just like in `TypeList` and `TypeObject`, through\n    // `DitoEditButtons`. It would be best to use `DitoEditButtons` here too.\n    creatable: getSchemaAccessor('creatable', {\n      type: Boolean,\n      default: false,\n      get(creatable) {\n        return creatable && hasFormSchema(this.schema)\n      }\n    }),\n\n    editable: getSchemaAccessor('editable', {\n      type: Boolean,\n      default: false,\n      get(editable) {\n        return editable && hasFormSchema(this.schema)\n      }\n    }),\n\n    deletable: getSchemaAccessor('deletable', {\n      type: Boolean,\n      default: false\n    })\n  },\n\n  methods: {\n    getPropertyDataPath(property) {\n      return appendDataPath(this.dataPath, property.name)\n    },\n\n    editPath(path) {\n      // All we got to do is push the right edit path to the router, the rest\n      // is handled by our routes, allowing reloads as well.\n      this.$router.push({\n        path: `${this.container.path}${path}`,\n        // Preserve current query\n        query: this.$route.query\n      })\n    },\n\n    onEdit() {\n      this.editPath(this.path)\n    },\n\n    onDelete() {\n      // TODO: Implement!\n    },\n\n    onChange() {\n      this.container.onChange()\n    },\n\n    // @override\n    onEndDrag(event) {\n      SortableMixin.methods.onEndDrag.call(this, event)\n      const { item } = event\n      // Preserve active state of edited sub-items, by editing their new path.\n      if (item.classList.contains('dito-tree-item--active')) {\n        this.$nextTick(() => {\n          this.editPath(event.item.dataset.path)\n        })\n      }\n    }\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-tree-item {\n  --chevron-indent: #{$chevron-indent};\n\n  overflow: hidden;\n\n  > .dito-tree-header {\n    > .dito-tree-branch,\n    > .dito-tree-leaf {\n      // Use `--level` CSS variable to calculated the accumulated indent\n      // padding directly instead of having it accumulate in nested CSS.\n      // This way, we can keep the &--active area cover the full width:\n      padding-left: calc(var(--chevron-indent) * (var(--level, 1) - 1));\n    }\n  }\n\n  .dito-tree-branch {\n    cursor: pointer;\n  }\n\n  .dito-tree-header {\n    display: flex;\n    justify-content: space-between;\n  }\n\n  .dito-tree-branch,\n  .dito-tree-leaf {\n    display: flex;\n    flex: auto;\n    overflow: hidden;\n    min-width: 0;\n    position: relative;\n    margin: 1px 0;\n    @include user-select(none);\n  }\n\n  .dito-tree-label {\n    display: flex;\n    align-items: baseline;\n    gap: 0.25em;\n    overflow: hidden;\n    white-space: nowrap;\n  }\n\n  .dito-tree-info {\n    white-space: nowrap;\n  }\n\n  .dito-tree-info {\n    padding-left: 0.35em;\n    color: rgba($color-black, 0.2);\n  }\n\n  .dito-buttons {\n    flex: auto;\n    display: flex;\n    visibility: hidden;\n    height: 100%;\n    margin: 1px;\n    margin-right: 0;\n  }\n\n  .dito-tree-header:hover {\n    > .dito-buttons {\n      visibility: visible;\n    } // Hide buttons during dragging\n  }\n\n  &--dragging {\n    .dito-tree-header {\n      > .dito-buttons {\n        visibility: hidden;\n      }\n    }\n  }\n\n  &--active {\n    > .dito-tree-header {\n      background: $color-active;\n      padding: 0 $input-padding-hor;\n      margin: 0 (-$input-padding-hor);\n\n      > .dito-tree-branch {\n        > .dito-chevron::before {\n          color: $color-white;\n        }\n      }\n\n      > * > .dito-tree-label {\n        color: $color-white;\n      }\n    }\n  }\n\n  .dito-properties {\n    display: block;\n    margin-left: $chevron-indent;\n\n    > tr {\n      vertical-align: baseline;\n    }\n\n    .dito-label {\n      margin: 0;\n\n      &::after {\n        content: ': ';\n      }\n    }\n  }\n}\n</style>\n","<template lang=\"pug\">\nthead.dito-table-head\n  tr\n    template(\n      v-for=\"column in columns\"\n    )\n      th(\n        v-if=\"shouldRenderSchema(column)\"\n        :class=\"getColumnClass(column)\"\n      )\n        RouterLink(\n          v-if=\"column.sortable\"\n          v-slot=\"{ navigate }\"\n          :to=\"getSortLink(column)\"\n          custom\n        )\n          button.dito-button(\n            type=\"button\"\n            :class=\"getSortClass(column)\"\n            @click=\"navigate\"\n          )\n            .dito-button__order-arrows\n            span {{ getLabel(column) }}\n        span(\n          v-else\n        ) {{ getLabel(column) }}\n    th(\n      v-if=\"hasEditButtons\"\n    )\n      //- Empty <span> is needed for styling, see _table.scss\n      span\n</template>\n\n<script>\nimport DitoComponent from '../DitoComponent.js'\nimport { hyphenate } from '@ditojs/utils'\n\n// @vue/component\nexport default DitoComponent.component('DitoTableHead', {\n  props: {\n    query: { type: Object, required: true },\n    columns: { type: Object, required: true },\n    hasEditButtons: { type: Boolean, required: true }\n  },\n\n  computed: {\n    sort() {\n      const order = (this.query.order || '').split(/\\s+/)\n      return {\n        name: order[0],\n        order: order[1]\n      }\n    }\n  },\n\n  methods: {\n    getColumnClass(column) {\n      return `dito-column--${hyphenate(column.name)}`\n    },\n\n    getSortClass(column) {\n      return this.sort.name === column.name\n        ? `dito-button--selected dito-button--order-${this.sort.order}`\n        : null\n    },\n\n    getSortLink(column) {\n      // Toggle order if the same column is clicked again.\n      const order =\n        this.sort.name === column.name && this.sort.order === 'asc'\n          ? 'desc'\n          : 'asc'\n      return this.getQueryLink({\n        ...this.query,\n        order: `${column.name} ${order}`\n      })\n    }\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-table-head {\n  @include user-select(none);\n\n  tr {\n    th {\n      padding: 0;\n      font-weight: normal;\n      text-align: left;\n      white-space: nowrap;\n\n      .dito-button {\n        // Convention: Nested spans handle padding, see below\n        display: block; // Override default inline-flex positioning.\n        padding: 0;\n        width: 100%;\n        text-align: inherit;\n        border-radius: 0;\n      }\n\n      span {\n        display: inline-block;\n        // Convention: Nested spans handle padding\n        padding: $input-padding;\n\n        &:empty::after {\n          // Prevent empty <th> from collapsing\n          content: '\\200b'; // zero-width space;\n        }\n      }\n\n      > span {\n        display: block;\n      }\n    }\n  }\n}\n</style>\n","<template lang=\"pug\">\ntd(\n  :class=\"cell.class\"\n  :style=\"cell.style\"\n)\n  //- TODO: Implement inlined components in cell mode!\n  component(\n    v-if=\"cell.component\"\n    :is=\"cell.component\"\n    :schema=\"schema\"\n    :dataPath=\"dataPath\"\n    :data=\"data\"\n    :meta=\"meta\"\n    :store=\"store\"\n    :nested=\"nested\"\n    :disabled=\"disabled\"\n  )\n  span(\n    v-else\n    v-html=\"renderCell(data)\"\n  )\n</template>\n\n<script>\nimport DitoComponent from '../DitoComponent.js'\nimport DitoContext from '../DitoContext.js'\nimport ContextMixin from '../mixins/ContextMixin.js'\nimport { appendDataPath } from '../utils/data.js'\nimport { escapeHtml } from '@ditojs/utils'\n\n// @vue/component\nexport default DitoComponent.component('DitoTableCell', {\n  mixins: [ContextMixin],\n\n  props: {\n    cell: { type: Object, required: true },\n    schema: { type: Object, required: true },\n    dataPath: { type: String, required: true },\n    data: { type: Object, required: true },\n    meta: { type: Object, required: true },\n    store: { type: Object, required: true },\n    nested: { type: Boolean, default: true },\n    disabled: { type: Boolean, default: false }\n  },\n\n  methods: {\n    renderCell(item) {\n      const { name, render } = this.cell\n      const value = item[name]\n      return render\n        ? render.call(\n            this,\n            new DitoContext(this, {\n              name,\n              value,\n              data: item,\n              dataPath: appendDataPath(this.dataPath, name)\n            })\n          )\n        : escapeHtml(value)\n    }\n  }\n})\n</script>\n","<template lang=\"pug\">\n.dito-upload-file\n  .dito-thumbnail(\n    v-if=\"thumbnail\"\n    :class=\"`dito-thumbnail--${thumbnail}`\"\n  )\n    .dito-thumbnail__inner\n      img(\n        v-if=\"source\"\n        :src=\"source\"\n        crossorigin=\"anonymous\"\n      )\n      .dito-thumbnail__type(\n        v-else\n      )\n        span {{ type }}\n  span {{ file.name }}\n</template>\n\n<script>\nimport DitoComponent from '../DitoComponent.js'\n\n// @vue/component\nexport default DitoComponent.component('DitoUploadFile', {\n  props: {\n    file: { type: Object, required: true },\n    thumbnail: { type: String, default: null },\n    thumbnailUrl: { type: String, default: null }\n  },\n\n  data() {\n    return {\n      uploadUrl: null\n    }\n  },\n\n  computed: {\n    type() {\n      return (\n        TYPES[this.file.type] ||\n        this.file.name.split('.').pop().toUpperCase()\n      )\n    },\n\n    source() {\n      return this.uploadUrl || this.thumbnailUrl\n    }\n  },\n\n  watch: {\n    'file.upload.file': {\n      immediate: true,\n      handler(file) {\n        if (this.thumbnail && file?.type.startsWith('image/')) {\n          const reader = new FileReader()\n          reader.onload = () => {\n            this.uploadUrl = reader.result\n          }\n          reader.readAsDataURL(file)\n        } else {\n          this.uploadUrl = null\n        }\n      }\n    }\n  }\n})\n\nconst TYPES = {\n  'text/plain': 'TXT',\n  'text/html': 'HTML',\n  'text/css': 'CSS',\n  'text/javascript': 'JS',\n  'image/jpeg': 'JPG',\n  'image/png': 'PNG',\n  'image/gif': 'GIF',\n  'image/svg+xml': 'SVG',\n  'movie/mp4': 'MP4',\n  'audio/mpeg': 'MP3',\n  'application/json': 'JSON',\n  'application/xml': 'XML',\n  'application/pdf': 'PDF',\n  'application/zip': 'ZIP'\n}\n</script>\n\n<style lang=\"scss\">\n@use 'sass:math';\n@import '../styles/_imports';\n\n.dito-upload-file {\n  display: flex;\n  align-items: center;\n  justify-content: flex-start;\n}\n\n.dito-thumbnail {\n  $self: &;\n\n  // Small size by default\n  --max-size: #{1 * $input-height};\n  --corner-size: calc(var(--max-size) / 5);\n  --shadow-size: 1px;\n  --min-size: calc(2 * var(--corner-size));\n  --margin: 0em;\n  --drop-shadow: drop-shadow(\n    0 calc(var(--shadow-size) * 0.75) var(--shadow-size)\n      #{rgba($color-black, 0.4)}\n  );\n\n  position: relative;\n  margin: var(--margin);\n  margin-right: 0.5em;\n  filter: var(--drop-shadow);\n\n  &--small {\n    --max-size: #{1 * $input-height};\n    --margin: 0em;\n    --shadow-size: 1px;\n  }\n\n  &--medium {\n    --max-size: #{2 * $input-height};\n    --margin: 0.25em;\n    --shadow-size: 1.5px;\n  }\n\n  &--large {\n    --max-size: #{4 * $input-height};\n    --margin: 0.5em;\n    --shadow-size: 2.5px;\n  }\n\n  &__inner {\n    background: #ffffff;\n    clip-path: polygon(\n      0 0,\n      calc(100% - var(--corner-size)) 0,\n      100% var(--corner-size),\n      100% 100%,\n      0 100%\n    );\n\n    &::after {\n      content: '';\n      position: absolute;\n      top: 0;\n      right: 0;\n      width: var(--corner-size);\n      height: var(--corner-size);\n      background: linear-gradient(45deg, #ffffff, #eeeeee 40%, #dddddd 50%);\n      filter: var(--drop-shadow);\n    }\n  }\n\n  &__type {\n    --font-size: var(--corner-size);\n\n    display: flex;\n    align-items: center;\n    justify-content: center;\n    min-width: var(--min-size);\n    min-height: var(--max-size);\n    aspect-ratio: 3 / 4;\n\n    span {\n      --color: #{$color-grey};\n\n      font-size: min(var(--font-size), #{1.25 * $font-size});\n      color: var(--color);\n\n      #{$self}:not(#{$self}--small) & {\n        padding: 0 calc(var(--font-size) / 4);\n        border-radius: calc(var(--font-size) / 4);\n        background: var(--color);\n        color: #ffffff;\n      }\n\n      #{$self}--medium & {\n        --color: #{$color-light};\n      }\n\n      #{$self}--large & {\n        --color: #{$color-lighter};\n      }\n    }\n  }\n\n  img {\n    display: block;\n    // SVG images need 100% settings to scale into the container.\n    width: 100%;\n    height: 100%;\n    min-width: var(--min-size);\n    min-height: var(--min-size);\n    max-width: var(--max-size);\n    max-height: var(--max-size);\n  }\n}\n</style>\n","import { computed, isRef, nextTick, toValue, watch } from \"vue\";\nimport { defaultDocument, tryOnMounted, tryOnScopeDispose, unrefElement } from \"@vueuse/core\";\nimport Sortable from \"sortablejs\";\n\n//#region useSortable/index.ts\n/**\n* Wrapper for sortablejs.\n* @param el\n* @param list\n* @param options\n*/\nfunction useSortable(el, list, options = {}) {\n\tlet sortable;\n\tconst { document = defaultDocument, watchElement = false,...resetOptions } = options;\n\tconst defaultOptions = { onUpdate: (e) => {\n\t\tmoveArrayElement(list, e.oldIndex, e.newIndex, e);\n\t} };\n\tconst element = computed(() => typeof el === \"string\" ? document === null || document === void 0 ? void 0 : document.querySelector(el) : unrefElement(el));\n\tconst cleanup = () => {\n\t\tsortable === null || sortable === void 0 || sortable.destroy();\n\t\tsortable = void 0;\n\t};\n\tconst initSortable = (target) => {\n\t\tif (!target || sortable !== void 0) return;\n\t\tsortable = new Sortable(target, {\n\t\t\t...defaultOptions,\n\t\t\t...resetOptions\n\t\t});\n\t};\n\tconst start = () => {\n\t\tconst target = element.value;\n\t\tif (target) initSortable(target);\n\t};\n\tconst option = (name, value) => {\n\t\tif (value !== void 0) sortable === null || sortable === void 0 || sortable.option(name, value);\n\t\telse return sortable === null || sortable === void 0 ? void 0 : sortable.option(name);\n\t};\n\tlet stopWatch;\n\tif (watchElement && typeof el !== \"string\") stopWatch = watch(element, (newElement) => {\n\t\tcleanup();\n\t\tif (newElement) initSortable(newElement);\n\t}, {\n\t\timmediate: true,\n\t\tflush: \"post\"\n\t});\n\telse tryOnMounted(start);\n\tconst stop = () => {\n\t\tcleanup();\n\t};\n\ttryOnScopeDispose(() => {\n\t\tstopWatch === null || stopWatch === void 0 || stopWatch();\n\t\tcleanup();\n\t});\n\treturn {\n\t\tstop,\n\t\tstart,\n\t\toption\n\t};\n}\n/**\n* Inserts a element into the DOM at a given index.\n* @param parentElement\n* @param element\n* @param {number} index\n* @see https://github.com/Alfred-Skyblue/vue-draggable-plus/blob/a3829222095e1949bf2c9a20979d7b5930e66f14/src/utils/index.ts#L81C1-L94C2\n*/\nfunction insertNodeAt(parentElement, element, index) {\n\tconst refElement = parentElement.children[index];\n\tparentElement.insertBefore(element, refElement);\n}\n/**\n* Removes a node from the DOM.\n* @param {Node} node\n* @see https://github.com/Alfred-Skyblue/vue-draggable-plus/blob/a3829222095e1949bf2c9a20979d7b5930e66f14/src/utils/index.ts#L96C1-L102C2\n*/\nfunction removeNode(node) {\n\tif (node.parentNode) node.parentNode.removeChild(node);\n}\nfunction moveArrayElement(list, from, to, e = null) {\n\tif (e != null) {\n\t\tremoveNode(e.item);\n\t\tinsertNodeAt(e.from, e.item, from);\n\t}\n\tconst _valueIsRef = isRef(list);\n\tconst array = _valueIsRef ? [...toValue(list)] : toValue(list);\n\tif (to >= 0 && to < array.length) {\n\t\tconst element = array.splice(from, 1)[0];\n\t\tnextTick(() => {\n\t\t\tarray.splice(to, 0, element);\n\t\t\tif (_valueIsRef) list.value = array;\n\t\t});\n\t}\n}\n\n//#endregion\nexport { useSortable as i, moveArrayElement as n, removeNode as r, insertNodeAt as t };","import { i as useSortable } from \"../useSortable-Cc5LKbDD.js\";\nimport { defineComponent, h, reactive, shallowRef } from \"vue\";\nimport { useVModel } from \"@vueuse/core\";\n\n//#region useSortable/component.ts\nconst UseSortable = /* @__PURE__ */ defineComponent((props, { slots }) => {\n\tconst list = useVModel(props, \"modelValue\");\n\tconst target = shallowRef();\n\tconst data = reactive(useSortable(target, list, props.options));\n\treturn () => {\n\t\tif (slots.default) return h(props.as || \"div\", { ref: target }, slots.default(data));\n\t};\n}, {\n\tname: \"UseSortable\",\n\tprops: [\n\t\t\"as\",\n\t\t\"modelValue\",\n\t\t\"options\"\n\t]\n});\n\n//#endregion\nexport { UseSortable };","<template lang=\"pug\">\nUseSortable.dito-draggable(\n  v-if=\"draggable\"\n  :class=\"{ 'dito-draggable--dragging': isDragging }\"\n  :as=\"as\"\n  :modelValue=\"modelValue\"\n  :options=\"{ ...options, onStart, onEnd }\"\n  @update:modelValue=\"$emit('update:modelValue', $event)\"\n)\n  slot\ncomponent(\n  v-else\n  :is=\"as\"\n)\n  slot\n</template>\n\n<script>\nimport DitoComponent from '../DitoComponent'\nimport DomMixin from '../mixins/DomMixin.js'\nimport { UseSortable } from '@vueuse/integrations/useSortable/component'\n\n// @vue/component\nexport default DitoComponent.component('DitoDraggable', {\n  mixins: [DomMixin],\n  components: { UseSortable },\n  emits: ['update:modelValue'],\n\n  props: {\n    modelValue: {\n      type: Array,\n      required: true\n    },\n    as: {\n      type: String,\n      default: 'div'\n    },\n    options: {\n      type: Object,\n      required: true\n    },\n    draggable: {\n      type: Boolean,\n      default: true\n    }\n  },\n\n  data() {\n    return {\n      mouseEvents: null,\n      isDragging: false\n    }\n  },\n\n  methods: {\n    onStart(event) {\n      this.options.onStart?.(event)\n      this.isDragging = true\n      this.mouseEvents?.remove()\n    },\n\n    onEnd(event) {\n      this.options.onEnd?.(event)\n      // Keep `isDragging` true until the next mouse interaction so that\n      // confused hover states are cleared before removing the hover catcher.\n      this.mouseEvents = this.domOn(document, {\n        mousedown: this.onMouse,\n        mousemove: this.onMouse,\n        mouseleave: this.onMouse\n      })\n    },\n\n    onMouse() {\n      this.isDragging = false\n      this.mouseEvents?.remove()\n      this.mouseEvents = null\n    }\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-draggable {\n  // Overlay a hover catcher while we're dragging to prevent hover states from\n  // getting stuck / confused. Safari struggles with this, so disable it there.\n  @include browser-query(('chrome', 'firefox')) {\n    &:has(&__chosen),\n    &--dragging {\n      > * {\n        position: relative;\n\n        > :first-child::after {\n          content: '';\n          position: absolute;\n          inset: 0;\n        }\n      }\n    }\n  }\n\n  &__fallback {\n    filter: drop-shadow(0 2px 4px $color-shadow);\n\n    // Nested <td> need to also switch to `display: flex` style during dragging.\n    &,\n    td {\n      display: flex;\n\n      > * {\n        flex: 1;\n      }\n    }\n  }\n}\n</style>\n","<script>\nimport DitoComponent from '../DitoComponent.js'\n\n// @vue/component\nfunction DitoVNode({ vnode }) {\n  return vnode\n}\n\nDitoVNode.props = {\n  vnode: { type: Object, required: true }\n}\n\nexport default DitoComponent.component('DitoVnode', DitoVNode)\n</script>\n","// DitoTypeComponent is the abstract base component for all other type\n// components inside the types/ folder. There's also a separate concrete\n// `DitoTypeComponent.vue` component, use to render `{ type: 'component' }`\nimport { asArray, camelize } from '@ditojs/utils'\nimport DitoComponent from './DitoComponent.js'\nimport TypeMixin from './mixins/TypeMixin.js'\nimport { registerTypeComponent, getTypeComponent } from './utils/schema.js'\n\n// @vue/component\nexport default {\n  extends: DitoComponent,\n  mixins: [TypeMixin],\n\n  nativeField: false,\n  textField: false,\n  // Set reasonable defaults for all of these that are used by most type\n  // components. These only need defining in sub-classes when they differ.\n  defaultValue: null,\n  defaultNested: true,\n  defaultVisible: true,\n  defaultMultiple: false,\n  generateLabel: true,\n  excludeValue: false,\n  ignoreMissingValue: null,\n  omitSpacing: false,\n\n  component: DitoComponent.component,\n\n  get: getTypeComponent,\n\n  register(types, definition = {}) {\n    types = asArray(types)\n    const component = this.component(\n      `DitoType${camelize(types[0], true)}`,\n      definition\n    )\n    for (const type of types) {\n      registerTypeComponent(type, component)\n    }\n    return component\n  }\n}\n","<template lang=\"pug\">\nDitoButton.dito-button(\n  :id=\"dataPath\"\n  ref=\"element\"\n  :type=\"type\"\n  :text=\"text\"\n  :title=\"title\"\n  :disabled=\"disabled\"\n  :class=\"buttonClass\"\n  v-bind=\"attributes\"\n)\n  template(#prefix)\n    DitoAffixes(\n      v-if=\"prefixes.length > 0\"\n      :items=\"prefixes\"\n      position=\"prefix\"\n      :disabled=\"disabled\"\n      :parentContext=\"context\"\n    )\n  template(#suffix)\n    DitoAffixes(\n      v-if=\"suffixes.length > 0\"\n      :items=\"suffixes\"\n      position=\"suffix\"\n      :disabled=\"disabled\"\n      :parentContext=\"context\"\n    )\n    .dito-info(\n      v-if=\"!label && info\"\n      :data-info=\"info\"\n    )\n</template>\n\n<script>\nimport DitoTypeComponent from '../DitoTypeComponent.js'\nimport DitoAffixes from '../components/DitoAffixes.vue'\nimport { DitoButton } from '@ditojs/ui/src'\nimport { getSchemaAccessor } from '../utils/accessor.js'\nimport { hasResource } from '../utils/resource.js'\nimport { labelize, asArray } from '@ditojs/utils'\n\nexport default DitoTypeComponent.register(\n  ['button', 'submit'],\n  // @vue/component\n  {\n    components: { DitoAffixes, DitoButton },\n    defaultValue: () => undefined, // Callback to override `defaultValue: null`\n    excludeValue: true,\n    defaultWidth: 'auto',\n    generateLabel: false,\n\n    data() {\n      return {\n        isRunning: false\n      }\n    },\n\n    computed: {\n      verb() {\n        return this.verbs[this.name]\n      },\n\n      buttonClass() {\n        return this.verb ? `dito-button--${this.verb}` : null\n      },\n\n      text: getSchemaAccessor('text', {\n        type: String\n      }),\n\n      title() {\n        return this.text || labelize(this.verb)\n      },\n\n      prefixes() {\n        return asArray(this.schema.prefix)\n      },\n\n      suffixes() {\n        return asArray(this.schema.suffix)\n      },\n\n      closeForm: getSchemaAccessor('closeForm', {\n        type: Boolean,\n        default: false\n      })\n    },\n\n    methods: {\n      // @override\n      getEvents() {\n        const { onFocus, onBlur, onClick } = this\n        return { onFocus, onBlur, onClick }\n      },\n\n      async submit(options) {\n        return this.resourceComponent?.submit(this, options)\n      },\n\n      async onClick() {\n        this.isRunning = true\n        try {\n          const res = await this.emitEvent('click', {\n            parent: this.schemaComponent\n          })\n          // Have buttons that define resources call `this.submit()` by default:\n          if (\n            res === undefined && // Meaning: don't prevent default.\n            hasResource(this.schema)\n          ) {\n            await this.submit()\n          }\n        } catch (error) {\n          const res = await this.emitEvent('error', { error })\n          if (res === undefined) {\n            if (error instanceof AggregateError) {\n              for (const err of error.errors) {\n                this.notify({ type: 'error', text: err })\n              }\n            } else {\n              this.notify({ type: 'error', text: error })\n            }\n          }\n        } finally {\n          this.isRunning = false\n        }\n      }\n    }\n  }\n)\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-button {\n  $self: &;\n\n  &__text {\n    @include ellipsis;\n  }\n}\n</style>\n","<template lang=\"pug\">\n.dito-checkbox\n  input(\n    :id=\"dataPath\"\n    ref=\"element\"\n    v-model=\"value\"\n    type=\"checkbox\"\n    v-bind=\"attributes\"\n  )\n</template>\n\n<script>\nimport DitoTypeComponent from '../DitoTypeComponent.js'\n\n// @vue/component\nexport default DitoTypeComponent.register('checkbox', {\n  nativeField: true\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-checkbox {\n  @extend %input-borderless;\n}\n</style>\n","import {\n  isObject,\n  isFunction,\n  isPromise,\n  normalizeDataPath,\n  getValueAtDataPath\n} from '@ditojs/utils'\nimport { markRaw, ref } from 'vue'\nimport LoadingMixin from './LoadingMixin.js'\n\n// @vue/component\nexport default {\n  mixins: [LoadingMixin],\n\n  data() {\n    return {\n      isLoading: false,\n      asyncDataEntries: markRaw({})\n    }\n  },\n\n  methods: {\n    handleDataSchema(schema, name, loadingOptions) {\n      if (!isObject(schema)) {\n        schema = { data: schema }\n      }\n      let { data = undefined, dataPath = null } = schema\n      // Create a reactive entry for the async data, if it doesn't exist yet.\n      // NOTE: `markRaw()` is used to avoid reactivity on `asyncDataEntries`\n      // itself, as reactivity is only desired on `reactiveVersion`, which is\n      // used to trigger controlled reevaluation of the computed getter.\n      const asyncEntry = (this.asyncDataEntries[name] ??= {\n        reactiveVersion: ref(1),\n        dependencyFunction: null,\n        resolvedData: undefined,\n        resolving: false,\n        resolved: false\n      })\n      // If the data callback provided a dependency function when it was called,\n      // cal it in every call of `handleDataSchema()` to force Vue to keep track\n      // of the async dependencies. Also access `reactiveVersion.value` right\n      // away, to ensure that the reactive property is tracked as a dependency:\n      asyncEntry.reactiveVersion.value &&\n      asyncEntry.dependencyFunction?.(this.context)\n\n      if (asyncEntry.resolved) {\n        // If the data was resolved already, return it and clear the resolved\n        // value. This works because Vue caches the result of computed getters\n        // and only reevaluates if one of the dependencies changed. This is to\n        // ensure that a cached value here doesn't block / override\n        // reevaluation when a dependency changes:\n        const { resolvedData } = asyncEntry\n        asyncEntry.resolvedData = undefined\n        asyncEntry.resolved = false\n        return resolvedData\n      }\n      // Avoid calling the data function twice:\n      if (asyncEntry.resolving) {\n        data = null\n      } else if (data) {\n        if (isFunction(data)) {\n          const result = data(this.context)\n          // If the result of the data function is another function, then the\n          // first data function is there to track dependencies and the real\n          // data loading happens in the function that it returned. Keep track\n          // it in `dependencyFunction` so it can be called on each call of\n          // `handleDataSchema()` to keep the dependencies intact, and call\n          // the function that it returned once to get the actual data:\n          if (isFunction(result)) {\n            asyncEntry.dependencyFunction = data\n            data = result(this.context)\n          } else {\n            data = result\n          }\n        }\n        // NOTE: If the data is not a promise, it is resolved already.\n        if (isPromise(data)) {\n          // If the data is asynchronous, it can't be returned straight away.\n          // But we can cheat using computed properties and `resolvedData`,\n          // which is going to receive the loaded data asynchronously,\n          // triggering a recompute of the computed property that calls\n          // `handleDataSchema()`.\n          asyncEntry.resolving = true\n          this.resolveData(data, loadingOptions)\n            .then(data => {\n              asyncEntry.resolvedData = data\n              asyncEntry.resolving = false\n              asyncEntry.resolved = true\n              // Trigger reevaluation of the computed getter by increasing the\n              // `reactiveVersion` value.\n              asyncEntry.reactiveVersion.value++\n            })\n            .catch(error => {\n              console.error(error)\n              asyncEntry.resolving = false\n            })\n          // Clear data until promise is resolved and `resolvedData` is set\n          data = null\n        }\n      } else if (dataPath) {\n        data = getValueAtDataPath(\n          this.rootData,\n          normalizeDataPath(`${this.dataPath}/${dataPath}`)\n        )\n      }\n      return data\n    },\n\n    async resolveData(load, loadingOptions = {}) {\n      // Use a timeout to allow already resolved promises to return data without\n      // showing a loading indicator.\n      let clearLoading = false\n      const timer = setTimeout(() => {\n        this.setLoading(true, loadingOptions)\n        clearLoading = true\n      }, 0)\n      let data = null\n      try {\n        data = await (isFunction(load) ? load() : load)\n      } catch (error) {\n        this.addError(error.message || error)\n      }\n      if (clearLoading) {\n        this.setLoading(false, loadingOptions)\n      } else {\n        clearTimeout(timer)\n      }\n      return data\n    }\n  }\n}\n","import DitoContext from '../DitoContext.js'\nimport DataMixin from './DataMixin.js'\nimport {\n  hasViewSchema,\n  getViewEditPath,\n  getMultipleValue\n} from '../utils/schema.js'\nimport { getSchemaAccessor } from '../utils/accessor.js'\nimport { setTemporaryId, isReference } from '../utils/data.js'\nimport {\n  isObject,\n  isArray,\n  isString,\n  isFunction,\n  normalizeDataPath,\n  labelize,\n  debounceAsync\n} from '@ditojs/utils'\n\n// @vue/component\nexport default {\n  mixins: [DataMixin],\n\n  computed: {\n    // @overridable\n    multiple() {\n      return getMultipleValue(this.schema)\n    },\n\n    selectedValue: {\n      get() {\n        const convertValue = value => {\n          const val = this.relate\n            ? this.getValueForOption(value)\n            : value\n\n          return this.hasOptions\n            ? this.getOptionForValue(val)\n              ? val\n              : null\n            : value\n        }\n\n        const value =\n          this.multiple && isArray(this.value)\n            ? this.value.map(convertValue).filter(value => value !== null)\n            : convertValue(this.value)\n\n        if (\n          // As soon as the options are available, and...\n          this.hasOptions && (\n            // ...if the value is forced to null because a disappeared option...\n            value === null && this.value !== null ||\n            // ...or if the value is a reference, replace it with its option\n            // value, so that it'll hold actual data, not just a reference id.\n            isReference(this.value)\n          )\n        ) {\n          // TODO: Fix side-effects\n          // eslint-disable-next-line vue/no-side-effects-in-computed-properties\n          this.selectedValue = value\n        }\n        return value\n      },\n\n      set(value) {\n        const convertValue = value =>\n          this.relate\n            ? this.getOptionForValue(value)\n            : value\n\n        this.value =\n          this.multiple && isArray(value)\n            ? value.map(convertValue)\n            : convertValue(value)\n      }\n    },\n\n    selectedOption() {\n      return this.getOptionForValue(this.selectedValue)\n    },\n\n    options() {\n      const data = this.handleDataSchema(this.schema.options, 'options') ?? []\n      if (!isArray(data)) {\n        throw new Error(`Invalid options data, should be array: ${data}`)\n      }\n      return this.processOptions(data)\n    },\n\n    activeOptions() {\n      // This is overridden in `TypeMultiselect` to return the `searchedOptions`\n      // when a search filter was applied.\n      return this.options\n    },\n\n    hasOptions() {\n      return this.activeOptions.length > 0\n    },\n\n    relate: getSchemaAccessor('relate', {\n      // TODO: Convert to `relateBy: 'id'`\n      type: Boolean,\n      default: false,\n      // We cannot use schema accessor callback magic for `relate` as we need\n      // this outside of the component's life-span, see `processData()` below.\n      callback: false\n    }),\n\n    groupBy: getSchemaAccessor('groupBy', {\n      type: String,\n      default: null\n    }),\n\n    // TODO: Rename to `options.labelKey` / `optionLabelKey`?\n    optionLabel: getSchemaAccessor('options.label', {\n      type: [String, Function],\n      default: null,\n      get(label) {\n        // If no `label` was provided but the options are objects, assume a\n        // default value of 'label':\n        return (\n          label ||\n          this.getOptionKey('label') ||\n          null\n        )\n      }\n    }),\n\n    // TODO: Rename to `options.valueKey` / `optionValueKey`?\n    optionValue: getSchemaAccessor('options.value', {\n      type: [String, Function],\n      default: null,\n      get(value) {\n        // If no `label` was provided but the options are objects, assume a\n        // default value of 'value':\n        return (\n          value ||\n          this.relate && 'id' ||\n          this.getOptionKey('value') ||\n          null\n        )\n      }\n    }),\n\n    optionEquals: getSchemaAccessor('options.equals', {\n      type: Function,\n      default: null\n    }),\n\n    // TODO: Consider moving search to `options.search`?\n    searchFilter: getSchemaAccessor('search', {\n      type: [Object, Function],\n      default: null,\n      get(search) {\n        if (search) {\n          const { filter, debounce } = isFunction(search)\n            ? { filter: search }\n            : search\n          return debounce ? debounceAsync(filter, debounce) : filter\n        }\n      }\n    }),\n\n    editable: getSchemaAccessor('editable', {\n      type: Boolean,\n      default: false,\n      get(editable) {\n        return (\n          editable &&\n          hasViewSchema(this.schema, this.context)\n        )\n      }\n    }),\n\n    editPath() {\n      return this.editable && this.selectedValue\n        ? getViewEditPath(this.schema, this.selectedValue, this.context)\n        : null\n    },\n\n    groupByLabel() {\n      return this.groupBy ? 'label' : null\n    },\n\n    groupByOptions() {\n      return this.groupBy ? 'options' : null\n    }\n  },\n\n  methods: {\n    getOptionKey(key) {\n      const [option] = this.activeOptions\n      return isObject(option) && key in option ? key : null\n    },\n\n    processOptions(options) {\n      if (options.length) {\n        if (this.relate) {\n          // If ids are missing and we want to relate, set temporary ids.\n          // NOTE: We need to modify the actual data, making a copy won't work\n          // as it won't propagate.\n          // NOTE: This only makes sense if the data is from the graph that\n          // we're currently editing.\n          for (const option of options) {\n            if (!('id' in option)) {\n              // TODO: Fix side-effects\n              setTemporaryId(option, 'id')\n            }\n          }\n        }\n        if (this.groupBy) {\n          const grouped = {}\n          options = options.reduce(\n            (results, option) => {\n              const group = option[this.groupBy]\n              let entry = grouped[group]\n              if (!entry) {\n                entry = grouped[group] = {\n                  [this.groupByLabel]: group,\n                  [this.groupByOptions]: []\n                }\n                results.push(entry)\n              }\n              entry[this.groupByOptions].push(option)\n              return results\n            },\n            []\n          )\n        }\n      }\n      return options\n    },\n\n    getOptionForValue(value) {\n      const findOption = (options, value, groupBy) => {\n        // Search for the option object with the given value and return the\n        // whole object.\n        for (const option of options) {\n          if (groupBy) {\n            const found = findOption(option.options, value, null)\n            if (found) {\n              return found\n            }\n          } else {\n            const matches = this.optionEquals\n              ? this.optionEquals(new DitoContext(this, { value, option }))\n              : value === this.getValueForOption(option)\n            if (matches) {\n              return option\n            }\n          }\n        }\n      }\n\n      return this.optionValue\n        ? findOption(this.activeOptions, value, this.groupBy)\n        : value\n    },\n\n    getValueForOption(option) {\n      const { optionValue } = this\n      return isString(optionValue)\n        ? option?.[optionValue] ?? null\n        : isFunction(optionValue)\n          ? optionValue(new DitoContext(this, { option }))\n          : option\n    },\n\n    getLabelForOption(option) {\n      const { optionLabel } = this\n      return isString(optionLabel)\n        ? option?.[optionLabel]\n        : isFunction(optionLabel)\n          ? optionLabel(new DitoContext(this, { option }))\n          : labelize(`${option}`)\n    }\n  },\n\n  processValue({ schema, value, dataPath }, graph) {\n    if (schema.relate) {\n      // For internally relating data (`schema.options.dataPath`), we need to\n      // process both the options (for '#ref') and the value ('#id').\n      // See `DataMixin.handleDataSchema()`:\n      const path = schema.options?.dataPath\n      const relatedDataPath = path\n        ? normalizeDataPath(`${dataPath}/${path}`)\n        : null\n      graph.addRelation(dataPath, relatedDataPath, schema)\n      if (relatedDataPath) {\n        graph.setSourceRelated(relatedDataPath)\n      }\n      // Convert relating objects to a shallow copy with only the id left.\n      // TODO: Convert to using `relateBy`:\n      const processRelate = value => (value ? { id: value.id } : value)\n      // Selected options can be both objects & arrays, e.g. 'checkboxes':\n      value =\n        getMultipleValue(schema) && isArray(value)\n          ? value.map(processRelate)\n          : processRelate(value)\n    }\n    return value\n  }\n}\n","<template lang=\"pug\">\nul.dito-checkboxes(\n  :id=\"dataPath\"\n  :class=\"`dito-layout--${schema.layout || 'vertical'}`\"\n)\n  li(\n    v-for=\"option in options\"\n  )\n    label\n      .dito-checkbox\n        input(\n          ref=\"element\"\n          v-model=\"selectedOptions\"\n          type=\"checkbox\"\n          :value=\"getValueForOption(option)\"\n          v-bind=\"attributes\"\n        )\n        span {{ getLabelForOption(option) }}\n</template>\n\n<script>\nimport DitoTypeComponent from '../DitoTypeComponent.js'\nimport OptionsMixin from '../mixins/OptionsMixin.js'\n\n// @vue/component\nexport default DitoTypeComponent.register('checkboxes', {\n  mixins: [OptionsMixin],\n\n  nativeField: true,\n  defaultValue: [],\n  defaultWidth: 'auto',\n  defaultMultiple: true,\n\n  computed: {\n    // @override\n    multiple() {\n      return true\n    },\n\n    selectedOptions: {\n      get() {\n        return (this.selectedValue || []).filter(value => value)\n      },\n\n      set(option) {\n        this.selectedValue = option || []\n      }\n    }\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-checkboxes {\n  label {\n    @extend %input-borderless;\n  }\n\n  input {\n    margin-right: $form-spacing;\n  }\n}\n</style>\n","<template lang=\"pug\">\n.dito-code(\n  :id=\"dataPath\"\n  :style=\"style\"\n)\n  .dito-code__editor(ref=\"editor\")\n  .dito-resize(\n    v-if=\"resizable\"\n    @mousedown.stop.prevent=\"onDragResize\"\n  )\n</template>\n\n<script>\nimport DitoTypeComponent from '../DitoTypeComponent.js'\nimport DomMixin from '../mixins/DomMixin.js'\nimport { getSchemaAccessor } from '../utils/accessor.js'\nimport CodeFlask from 'codeflask'\n\n// @vue/component\nexport default DitoTypeComponent.register('code', {\n  mixins: [DomMixin],\n\n  data() {\n    return {\n      height: null\n    }\n  },\n\n  computed: {\n    lines: getSchemaAccessor('lines', {\n      type: Number,\n      default: 3\n    }),\n\n    language: getSchemaAccessor('language', {\n      type: String,\n      default: 'javascript'\n    }),\n\n    indentSize: getSchemaAccessor('indentSize', {\n      type: Number,\n      default: 2\n    }),\n\n    resizable: getSchemaAccessor('resizable', {\n      type: Boolean,\n      default: false\n    }),\n\n    style() {\n      return {\n        height: this.height || `calc(${this.lines}em * var(--line-height))`\n      }\n    }\n  },\n\n  mounted() {\n    const flask = new CodeFlask(this.$refs.editor, {\n      language: this.language,\n      indentSize: this.indentSize,\n      lineNumbers: false\n    })\n\n    let changed = false\n    let ignoreWatch = false\n    let ignoreUpdate = false\n\n    const onChange = () => {\n      if (!this.focused && changed) {\n        changed = false\n        this.onChange()\n      }\n    }\n\n    const onFocus = () => this.onFocus()\n\n    const onBlur = () => {\n      this.onBlur()\n      onChange()\n    }\n\n    this.domOn(this.$refs.editor.querySelector('textarea'), {\n      focus: onFocus,\n      blur: onBlur\n    })\n\n    const setCode = code => {\n      if (code !== flask.code) {\n        ignoreUpdate = true\n        flask.updateCode(code)\n      }\n    }\n\n    const setValue = value => {\n      if (value !== this.value) {\n        ignoreWatch = true\n        this.value = value\n        changed = true\n        onChange()\n      }\n    }\n\n    flask.onUpdate(value => {\n      if (ignoreUpdate) {\n        ignoreUpdate = false\n      } else {\n        setValue(value)\n      }\n    })\n\n    this.$watch('value', value => {\n      if (ignoreWatch) {\n        ignoreWatch = false\n      } else {\n        setCode(value || '')\n      }\n    })\n\n    this.$watch('language', language => {\n      flask.updateLanguage(language)\n    })\n\n    setCode(this.value || '')\n  },\n\n  methods: {\n    focusElement() {\n      this.$el.querySelector('textarea')?.focus()\n    },\n\n    blurElement() {\n      this.$el.querySelector('textarea')?.blur()\n    },\n\n    onDragResize(event) {\n      const getPoint = ({ clientX: x, clientY: y }) => ({ x, y })\n\n      let prevY = getPoint(event).y\n      let height = parseFloat(getComputedStyle(this.$el).height)\n\n      const mousemove = event => {\n        const { y } = getPoint(event)\n        height += y - prevY\n        prevY = y\n        this.height = `${Math.max(height, 0)}px`\n      }\n\n      const handlers = this.domOn(document, {\n        mousemove,\n\n        mouseup(event) {\n          mousemove(event)\n          handlers.remove()\n        }\n      })\n    }\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-code {\n  @extend %input;\n\n  position: relative;\n  // For proper sizing of content along with :style=\"style\" setting above,\n  // for proper line-height calculation.\n  padding: $input-padding;\n  min-height: calc(1em * var(--line-height) + 2 * $input-padding-ver);\n\n  .codeflask {\n    background: none;\n    // Ignore the parent padding defined above which is only needed to set\n    // the desired height with :style=\"style\".\n    top: 0;\n    left: 0;\n\n    &__textarea,\n    &__pre {\n      // Use same padding as .dito-code\n      padding: $input-padding;\n    }\n\n    &__textarea,\n    &__code,\n    &__lines {\n      font-family: $font-family-mono;\n      font-size: var(--font-size);\n      line-height: var(--line-height);\n    }\n\n    &__lines {\n      padding: $input-padding;\n    }\n  }\n}\n</style>\n","<template lang=\"pug\">\nDitoTrigger.dito-color(\n  v-model:show=\"showPopup\"\n  trigger=\"focus\"\n)\n  template(#trigger)\n    DitoInput(\n      :id=\"dataPath\"\n      ref=\"element\"\n      v-model=\"hexValue\"\n      type=\"input\"\n      size=\"8\"\n      :focused=\"showPopup\"\n      v-bind=\"attributes\"\n    )\n      template(#prefix)\n        DitoAffixes(\n          :items=\"schema.prefix\"\n          position=\"prefix\"\n          mode=\"input\"\n          :disabled=\"disabled\"\n          :parentContext=\"context\"\n        )\n      template(#suffix)\n        DitoAffixes(\n          :items=\"schema.suffix\"\n          position=\"suffix\"\n          mode=\"input\"\n          :clearable=\"showClearButton\"\n          :disabled=\"disabled\"\n          :inlineInfo=\"inlineInfo\"\n          :parentContext=\"context\"\n          @clear=\"clear\"\n        )\n          template(#append)\n            .dito-color__preview(\n              v-if=\"value\"\n            )\n              div(:style=\"{ background: `#${hexValue || '00000000'}` }\")\n  template(#popup)\n    SketchPicker.dito-color__picker(\n      v-model=\"colorValue\"\n      :disableAlpha=\"!alpha\"\n      :disableFields=\"!inputs\"\n      :presetColors=\"presets\"\n    )\n</template>\n\n<script>\nimport tinycolor from 'tinycolor2'\nimport { Sketch as SketchPicker } from '@lk77/vue3-color'\nimport { isObject, isString } from '@ditojs/utils'\nimport { DitoTrigger, DitoInput } from '@ditojs/ui/src'\nimport DitoTypeComponent from '../DitoTypeComponent.js'\nimport DitoAffixes from '../components/DitoAffixes.vue'\nimport { getSchemaAccessor } from '../utils/accessor.js'\n\n// Monkey-patch the `SketchPicker's` `hex` computed property to return lowercase\n// hex values instead of uppercase ones.\nconst { hex } = SketchPicker.computed\nSketchPicker.computed.hex = function () {\n  return hex.call(this).toLowerCase()\n}\n\n// @vue/component\nexport default DitoTypeComponent.register('color', {\n  components: { DitoTrigger, DitoInput, DitoAffixes, SketchPicker },\n\n  data() {\n    return {\n      showPopup: false,\n      convertedValue: null\n    }\n  },\n\n  computed: {\n    canUpdateValue() {\n      return !this.focused || this.readonly\n    },\n\n    colorValue: {\n      get() {\n        return (\n          this.convertedValue ||\n          this.value ||\n          (this.colorFormat === 'hex' ? '' : {})\n        )\n      },\n\n      set(value) {\n        this.value = convertColor(value, this.colorFormat)\n      }\n    },\n\n    hexValue: {\n      get() {\n        const color = tinycolor(this.value)\n        return color.isValid()\n          ? color\n              .toString(color.getAlpha() < 1 ? 'hex8' : 'hex6')\n              .slice(1)\n              .toLowerCase()\n          : null\n      },\n\n      set(value) {\n        const color = tinycolor(value)\n        if (color.isValid()) {\n          const convertedValue = convertColor(value, this.colorFormat)\n          if (this.canUpdateValue) {\n            this.value = convertedValue\n          } else {\n            // Store to change later, once `canUpdateValue` is true again.\n            // See `watch` below.\n            this.convertedValue = convertedValue\n          }\n        }\n      }\n    },\n\n    // TODO: `format` clashes with TypeMixin.format()`, which shall be renamed\n    // soon to `formatValue()`. Rename `colorFormat` back to `format` after.\n    colorFormat: getSchemaAccessor('format', {\n      type: String,\n      default: 'hex'\n    }),\n\n    // TODO: Rename to `showAlpha`?\n    alpha: getSchemaAccessor('alpha', {\n      type: Boolean,\n      default: false\n    }),\n\n    // TODO: Rename to `showInputs`?\n    inputs: getSchemaAccessor('inputs', {\n      type: Boolean,\n      default: true\n    }),\n\n    presets: getSchemaAccessor('presets', {\n      type: Array,\n      default: [\n        '#ffffff',\n        '#c3c3c3',\n        '#7f7f7f',\n        '#000000',\n        '#880015',\n        '#ed1c24',\n        '#ff7f27',\n        '#fff200',\n\n        '#22b14c',\n        '#00a2e8',\n        '#3f48cc',\n        '#a349a4',\n        '#b97a57',\n        '#ffaec9',\n        '#ffc90e',\n        '#00000000'\n      ]\n    })\n  },\n\n  watch: {\n    value: 'onChange',\n\n    canUpdateValue(canUpdateValue) {\n      if (canUpdateValue && this.convertedValue !== null) {\n        this.value = this.convertedValue\n        this.convertedValue = null\n      }\n    }\n  }\n})\n\nfunction convertColor(color, format) {\n  return isObject(color) // a vue3-color color object\n    ? toVue3ColorFormat(color, format)\n    : toTinyColorFormat(tinycolor(color), format)\n}\n\nfunction toVue3ColorFormat(color, format) {\n  const value =\n    color[\n      {\n        hex: color?.a < 1 ? 'hex8' : 'hex',\n        rgb: 'rgba'\n      }[format] ||\n      format\n    ]\n  return isString(value) && value[0] === '#' ? value.toLowerCase() : value\n}\n\n// This should really be in tinycolor, but it only has the string equivalent\n// of it.\nfunction toTinyColorFormat(color, format) {\n  switch (format) {\n    case 'rgb':\n      return color.toRgb()\n    case 'prgb':\n      return color.toPercentageRgb()\n    case 'name':\n      return color.toName()\n    case 'hsl':\n      return color.toHsl()\n    case 'hsv':\n      return color.toHsv()\n    case 'hex3':\n      return `#${color.toHex(true)}`\n    case 'hex4':\n      return `#${color.toHex8(true)}`\n    case 'hex8':\n      return `#${color.toHex8()}`\n    case 'hex':\n    case 'hex6':\n    default:\n      // Preserve alpha channel if present\n      return color.getAlpha() < 1\n        ? `#${color.toHex8()}`\n        : `#${color.toHex()}`\n  }\n}\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n$color-swatch-width: $pattern-transparency-size;\n$color-swatch-radius: $border-radius - $border-width;\n\n.dito-color {\n  .dito-input {\n    display: flex;\n    position: relative;\n\n    input {\n      box-sizing: border-box;\n      font-variant-numeric: tabular-nums;\n      padding-right: $color-swatch-width;\n    }\n  }\n\n  &__picker {\n    margin: $popup-margin;\n    border: $border-style;\n    border-radius: $border-radius;\n    background: $color-white;\n    box-shadow: $shadow-window;\n  }\n\n  &__preview {\n    background: $pattern-transparency;\n    margin: (-$input-padding-ver) (-$input-padding-hor);\n    margin-left: 0;\n    border-left: $border-style;\n\n    &,\n    div {\n      width: $color-swatch-width;\n      height: calc($input-height - 2 * $border-width);\n      border-top-right-radius: $color-swatch-radius;\n      border-bottom-right-radius: $color-swatch-radius;\n    }\n  }\n\n  // Inherit input focus state\n  .dito-input:focus-within &__preview,\n  .dito-input--focus &__preview {\n    border-left-color: $color-active;\n  }\n}\n</style>\n","<template lang=\"pug\">\ncomponent(\n  :is=\"schema.component\"\n  v-bind=\"$props\"\n)\n</template>\n\n<script>\n// This is the general purpose 'component' type, which can resolve to any custom\n// component through `schema.component`, see `resolveSchemaComponent()`. This\n// can be used to nest arbitrary vue components in schema:\n// {\n//   type: 'component',\n//   component: import('./component')\n// }\n\nimport DitoTypeComponent from '../DitoTypeComponent.js'\nimport { resolveSchemaComponent } from '../utils/schema.js'\n\n// @vue/component\nexport default DitoTypeComponent.register('component', {\n  // Override the standard `defaultValue: null` to not set any data for custom\n  // components, unless they provide a default value.\n  defaultValue: () => undefined, // Callback to override `defaultValue: null`\n  ignoreMissingValue: ({ schema }) => !('default' in schema),\n\n  async processSchema(api, schema) {\n    await resolveSchemaComponent(schema)\n  }\n})\n</script>\n","<template lang=\"pug\">\n//- TODO: Find a better way to trigger evaluation of `value` that dose not\n//- involve actually rendering it when the component is not visible.\ninput.dito-text.dito-input(\n  :id=\"dataPath\"\n  ref=\"element\"\n  :name=\"name\"\n  type=\"text\"\n  :value=\"value\"\n  :disabled=\"disabled\"\n  :readonly=\"true\"\n)\n</template>\n\n<script>\nimport DitoTypeComponent from '../DitoTypeComponent.js'\nimport ValueMixin from '../mixins/ValueMixin.js'\nimport DataMixin from '../mixins/DataMixin.js'\n\nexport default DitoTypeComponent.register(\n  ['computed', 'data', 'hidden'],\n  // @vue/component\n  {\n    mixins: [DataMixin],\n\n    defaultValue: () => undefined, // Callback to override `defaultValue: null`\n    defaultVisible: false,\n\n    computed: {\n      value: {\n        get() {\n          const { schema } = this\n          if (schema.data || schema.dataPath) {\n            const value = this.handleDataSchema(schema, 'value')\n            // TODO: Fix side-effects\n            // eslint-disable-next-line max-len\n            // eslint-disable-next-line vue/no-side-effects-in-computed-properties\n            this.data[this.name] = value\n          }\n          return ValueMixin.computed.value.get.call(this)\n        },\n\n        set(value) {\n          ValueMixin.computed.value.set.call(this, value)\n        }\n      }\n    }\n  }\n)\n</script>\n","<template lang=\"pug\">\n.dito-date\n  component(\n    :is=\"getComponent(type)\"\n    :id=\"dataPath\"\n    ref=\"element\"\n    v-model=\"dateValue\"\n    :locale=\"locale\"\n    :format=\"formats\"\n    v-bind=\"attributes\"\n  )\n    template(#prefix)\n      DitoAffixes(\n        :items=\"schema.prefix\"\n        position=\"prefix\"\n        mode=\"input\"\n        absolute\n        :disabled=\"disabled\"\n        :parentContext=\"context\"\n      )\n    template(#suffix)\n      DitoAffixes(\n        :items=\"schema.suffix\"\n        position=\"suffix\"\n        mode=\"input\"\n        absolute\n        :clearable=\"showClearButton\"\n        :disabled=\"disabled\"\n        :inlineInfo=\"inlineInfo\"\n        :parentContext=\"context\"\n        @clear=\"clear\"\n      )\n</template>\n\n<script>\nimport DitoTypeComponent from '../DitoTypeComponent.js'\nimport { getSchemaAccessor } from '../utils/accessor.js'\nimport DitoAffixes from '../components/DitoAffixes.vue'\nimport {\n  DitoDatePicker,\n  DitoTimePicker,\n  DitoDateTimePicker\n} from '@ditojs/ui/src'\nimport { isDate, assignDeeply } from '@ditojs/utils'\n\nexport default DitoTypeComponent.register(\n  ['date', 'datetime', 'time'],\n  // @vue/component\n  {\n    components: { DitoAffixes },\n    // TODO: This is only here so we get placeholder added. Come up with a\n    // better way to support attributes per component (a list of actually\n    // supported attributes)\n    nativeField: true,\n    textField: true,\n\n    computed: {\n      dateValue: {\n        get() {\n          const { value } = this\n          return value ? new Date(value) : value\n        },\n\n        set(value) {\n          this.value = value\n        }\n      },\n\n      // TODO: Rename to `format`, once `schema.format()` was removed to\n      // `formatValue()`.\n      formats: getSchemaAccessor('formats', {\n        type: Object,\n        default: null,\n        get(formats) {\n          const { date, time } = assignDeeply({}, this.api.formats, formats)\n          return {\n            date: ['date', 'datetime'].includes(this.type) ? date : null,\n            time: ['time', 'datetime'].includes(this.type) ? time : null\n          }\n        }\n      })\n    },\n\n    methods: {\n      getComponent(type) {\n        return {\n          date: DitoDatePicker,\n          time: DitoTimePicker,\n          datetime: DitoDateTimePicker\n        }[type]\n      }\n    },\n\n    processValue({ value }) {\n      return isDate(value) ? value.toISOString() : value\n    }\n  }\n)\n</script>\n","import { isArray } from '@ditojs/utils'\n\nexport function formatQuery(query) {\n  const entries = query\n    ? isArray(query)\n      ? query\n      : Object.entries(query)\n    : []\n  return (\n    new URLSearchParams(\n      // Expand array values into multiple entries under the same key, so\n      // `formatQuery({ foo: [1, 2], bar: 3 })` => 'foo=1&foo=2&bar=3'.\n      entries.reduce(\n        (entries, [key, value]) => {\n          if (isArray(value)) {\n            for (const val of value) {\n              // Prevent null or undefined values from becoming strings,\n              // but since they're entries in an array, we still include them.\n              entries.push([key, val ?? ''])\n            }\n          } else if (value != null) {\n            entries.push([key, value])\n          }\n          return entries\n        },\n        []\n      )\n    )\n      .toString()\n      // decode all these encoded characters to have the same behavior as\n      // vue-router's own query encoding.\n      .replaceAll(/%(?:21|24|28|29|2C|2F|3A|3B|3D|3F|40)/g, decodeURIComponent)\n  )\n}\n\nexport function replaceRoute({ path, query, hash }) {\n  // Preserve `history.state`, see:\n  // https://router.vuejs.org/guide/migration/#usage-of-history-state\n  const { location } = window\n  history.replaceState(\n    history.state,\n    null,\n    `${\n      location.origin\n    }${\n      path ?? location.pathname\n    }?${\n      query ? formatQuery(query) : location.search.slice(1)\n    }${\n      hash ?? location.hash\n    }`\n  )\n}\n","import DitoComponent from '../DitoComponent.js'\nimport ItemMixin from './ItemMixin.js'\nimport ResourceMixin from './ResourceMixin.js'\nimport SchemaParentMixin from '../mixins/SchemaParentMixin.js'\nimport { getSchemaAccessor, getStoreAccessor } from '../utils/accessor.js'\nimport { getMemberResource } from '../utils/resource.js'\nimport { replaceRoute } from '../utils/route.js'\nimport {\n  processRouteSchema,\n  processForms,\n  getNamedSchemas,\n  getButtonSchemas,\n  hasFormSchema,\n  getFormSchemas,\n  getViewSchema,\n  getViewPath,\n  isCompact,\n  isInlined,\n  isObjectSource,\n  isListSource\n} from '../utils/schema.js'\nimport {\n  isObject,\n  isString,\n  isArray,\n  isNumber,\n  equals,\n  parseDataPath,\n  normalizeDataPath\n} from '@ditojs/utils'\nimport { raw } from '@ditojs/ui'\n\n// @vue/component\nexport default {\n  mixins: [ItemMixin, ResourceMixin, SchemaParentMixin],\n\n  defaultValue: context => (isListSource(context.schema) ? [] : null),\n  // Exclude all sources that have their own resource handling the data.\n  excludeValue: context => !!context.schema.resource,\n\n  provide() {\n    return {\n      $sourceComponent: () => this\n    }\n  },\n\n  data() {\n    return {\n      wrappedPrimitives: null,\n      unwrappingPrimitives: raw(false)\n    }\n  },\n\n  computed: {\n    sourceComponent() {\n      return this\n    },\n\n    isObjectSource() {\n      return isObjectSource(this.type)\n    },\n\n    isListSource() {\n      return isListSource(this.type)\n    },\n\n    // @override ResourceMixin.hasData()\n    hasData() {\n      return !!this.value\n    },\n\n    shouldRender() {\n      return this.sourceDepth < this.maxDepth\n    },\n\n    isReady() {\n      // Lists that have no data and no associated resource should still render,\n      // as they may be getting their data elsewhere, e.g. `compute()`.\n      return (\n        this.shouldRender &&\n        (this.hasData || !this.providesData)\n      )\n    },\n\n    isInView() {\n      return !!this.viewComponent\n    },\n\n    wrapPrimitives() {\n      return this.schema.wrapPrimitives\n    },\n\n    listData: {\n      get() {\n        let data = this.value\n        if (this.isObjectSource) {\n          // Convert to list array.\n          data = data != null ? [data] : []\n        } else {\n          // If data gets inherited from parent, unwrapping is not happening\n          // at the root in `setData()`, but here instead.\n          data = this.unwrapListData(data) || data\n        }\n        data ||= []\n        const { wrapPrimitives } = this\n        if (wrapPrimitives) {\n          if (this.unwrappingPrimitives.value) {\n            // We're done unwrapping once `listData` is reevaluated, so set\n            // this to `false` again. See `wrappedPrimitives` watcher above.\n            // TODO: Fix side-effects\n            // eslint-disable-next-line max-len\n            // eslint-disable-next-line vue/no-side-effects-in-computed-properties\n            this.unwrappingPrimitives.value = false\n          } else {\n            // Convert data to a list of wrapped primitives, and return it.\n            // TODO: Fix side-effects\n            // eslint-disable-next-line max-len\n            // eslint-disable-next-line vue/no-side-effects-in-computed-properties\n            this.wrappedPrimitives = data.map(value => ({\n              [wrapPrimitives]: value\n            }))\n          }\n          return this.wrappedPrimitives\n        }\n        return data\n      },\n\n      set(data) {\n        if (this.wrapPrimitives) {\n          this.wrappedPrimitives = data\n        } else {\n          this.value = this.isObjectSource\n            ? data?.length > 0\n              ? data[0]\n              : null\n            : data\n        }\n      }\n    },\n\n    objectData: {\n      get() {\n        // Always go through `listData` internally, which does all the\n        // processing of `wrapPrimitives`, etc.\n        return this.listData[0] || null\n      },\n\n      set(data) {\n        this.listData = data ? [data] : []\n      }\n    },\n\n    sourceSchema() {\n      // The sourceSchema of a list is the list's schema itself.\n      return this.schema\n    },\n\n    sourceDepth() {\n      return this.$route.matched.reduce(\n        (depth, record) => (\n          depth + (record.meta.schema === this.sourceSchema ? 1 : 0)\n        ),\n        0\n      )\n    },\n\n    path() {\n      // This is used in TypeList for DitoFormChooser.\n      return this.routeComponent.getChildPath(this.schema.path)\n    },\n\n    defaultQuery() {\n      const { defaultOrder: order } = this\n      return order ? { order } : {}\n    },\n\n    query: getStoreAccessor('query', {\n      get(query) {\n        return {\n          ...this.defaultQuery,\n          ...query\n        }\n      },\n\n      set(query) {\n        // Always keep the displayed query parameters in sync with the stored\n        // ones. Use scope and page from the list schema as defaults, but allow\n        // the route query parameters to override them.\n        const {\n          scope = this.defaultScope?.name,\n          page = this.schema.page,\n          type\n        } = this.query\n        // Preserve / merge currently stored values, including any custom query\n        // parameters added by creatable.query\n        query = {\n          ...this.query,\n          ...(scope != null && { scope }),\n          ...(page != null && { page }),\n          ...(type != null && { type }),\n          ...query\n        }\n        if (!equals(query, this.$route.query)) {\n          // Change the route query parameters, but don't trigger a route\n          // change, as that would cause the list to reload.\n          replaceRoute({ query })\n        }\n        return query // Let getStoreAccessor() do the actual setting\n      }\n    }),\n\n    total: getStoreAccessor('total'),\n\n    columns() {\n      return getNamedSchemas(this.schema.columns)\n    },\n\n    scopes() {\n      return getNamedSchemas(this.schema.scopes)\n    },\n\n    defaultScope() {\n      let first = null\n      if (this.scopes) {\n        for (const scope of Object.values(this.scopes)) {\n          if (scope.defaultScope) {\n            return scope\n          }\n          if (!first) {\n            first = scope\n          }\n        }\n      }\n      return first\n    },\n\n    defaultOrder() {\n      if (this.columns) {\n        for (const column of Object.values(this.columns)) {\n          const { defaultSort } = column\n          if (defaultSort) {\n            const direction = isString(defaultSort) ? defaultSort : 'asc'\n            return `${column.name} ${direction}`\n          }\n        }\n      }\n      return null\n    },\n\n    nestedMeta() {\n      return {\n        ...this.meta,\n        schema: this.schema\n      }\n    },\n\n    forms() {\n      return Object.values(getFormSchemas(this.schema, this.context))\n    },\n\n    // Returns the linked view schema if this source edits it its items through\n    // a linked view.\n    view() {\n      return getViewSchema(this.schema, this.context)\n    },\n\n    linksToView() {\n      return !!this.view\n    },\n\n    buttonSchemas() {\n      return getButtonSchemas(this.schema.buttons)\n    },\n\n    isCompact() {\n      return this.forms.every(isCompact)\n    },\n\n    isInlined() {\n      return isInlined(this.schema)\n    },\n\n    paginate: getSchemaAccessor('paginate', {\n      type: Number\n    }),\n\n    render: getSchemaAccessor('render', {\n      type: Function,\n      default: null\n    }),\n\n    creatable: getSchemaAccessor('creatable', {\n      type: Boolean,\n      default: false,\n      get(creatable) {\n        return creatable && hasFormSchema(this.schema)\n          ? this.isObjectSource\n            ? !this.value\n            : true\n          : false\n      }\n    }),\n\n    editable: getSchemaAccessor('editable', {\n      type: Boolean,\n      default: false,\n      get(editable) {\n        return editable && !this.isInlined\n      }\n    }),\n\n    deletable: getSchemaAccessor('deletable', {\n      type: Boolean,\n      default: false\n    }),\n\n    draggable: getSchemaAccessor('draggable', {\n      type: Boolean,\n      default: false,\n      get(draggable) {\n        return this.isListSource && this.listData.length > 1 && draggable\n      }\n    }),\n\n    collapsible: getSchemaAccessor('collapsible', {\n      type: Boolean,\n      default: false,\n      get(collapsible) {\n        return collapsible && this.isInlined\n      }\n    }),\n\n    collapsed: getSchemaAccessor('collapsed', {\n      type: Boolean,\n      default: false,\n      get(collapsed) {\n        return collapsed && this.collapsible\n      }\n    }),\n\n    maxDepth: getSchemaAccessor('maxDepth', {\n      type: Number,\n      default: 1\n    }),\n\n    createPath() {\n      if (this.creatable) {\n        return (\n          getViewPath(this.schema, this.context) ||\n          this.path\n        )\n      }\n      return null\n    }\n  },\n\n  watch: {\n    $route: {\n      // https://github.com/vuejs/vue-router/issues/3393#issuecomment-1158470149\n      flush: 'post',\n      handler(to, from) {\n        if (this.providesData) {\n          if (\n            from.path === to.path &&\n            from.hash === to.hash\n          ) {\n            // Paths and hashes remain the same, so only queries have changed.\n            // Update filter and reload data without clearing.\n            this.query = to.query\n            this.loadData(false)\n          } else if (\n            this.meta.reload &&\n            from.path !== to.path &&\n            from.path.startsWith(to.path)\n          ) {\n            // Reload the source when navigating back to a parent-route after\n            // changing data in a child-route.\n            this.meta.reload = false\n            this.loadData(false)\n          }\n        }\n      }\n    },\n\n    wrappedPrimitives: {\n      deep: true,\n      handler(to, from) {\n        const { wrapPrimitives } = this\n        // Skip the initial setting of wrappedPrimitives array\n        if (wrapPrimitives && from !== null) {\n          // Whenever the wrappedPrimitives change, map their values back to the\n          // array of primitives, in a primitive way :)\n          // But set `unwrappingPrimitives` to true, so the `listData` computed\n          // property knows about it, which sets it to `false` again.\n          this.unwrappingPrimitives.value = true\n          this.value = to.map(object => object[wrapPrimitives])\n        }\n      }\n    }\n  },\n\n  methods: {\n    setupData() {\n      this.query = this.$route.query\n      this.ensureData()\n    },\n\n    // @override ResourceMixin.clearData()\n    clearData() {\n      this.total = 0\n      this.value = null\n    },\n\n    // @override ResourceMixin.setData()\n    setData(data) {\n      // When new data is loaded, we can store it right back in the data of the\n      // view or form that created this list component.\n      // Support two formats for list data:\n      // - Array: `[...]`\n      // - Object: `{ results: [...], total }`, see `unwrapListData()`\n      if (\n        !data ||\n        this.isListSource && isArray(data) ||\n        this.isObjectSource && isObject(data)\n      ) {\n        this.value = data\n      } else if (this.unwrapListData(data)) {\n        // The format didn't match, see if we received a `{ results, total }`\n        // object, in which case `this.value` was already set by\n        // `unwrapListData()` and we're done now.\n      } else if (isObject(data) && this.isInView) {\n        // The controller is sending data for a full multi-component view,\n        // including the nested list data.\n        this.viewComponent.setData(data)\n      }\n    },\n\n    unwrapListData(data) {\n      if (\n        this.isListSource &&\n        isObject(data) &&\n        isNumber(data.total) &&\n        isArray(data.results)\n      ) {\n        // If @ditojs/server sends data in the form of `{ results, total }`\n        // replace the value with result, but remember the total in the store.\n        this.total = data.total\n        this.value = data.results\n        return this.value\n      }\n    },\n\n    createItem(schema, type) {\n      const item = this.createData(schema, type)\n      if (this.isObjectSource) {\n        this.objectData = item\n      } else {\n        this.listData.push(item)\n      }\n      if (this.collapsible) {\n        this.$nextTick(() => this.openSchemaComponent(-1))\n      }\n      this.onChange()\n      return item\n    },\n\n    removeItem(item, index) {\n      let removed = false\n      if (this.isObjectSource) {\n        this.objectData = null\n        removed = true\n      } else {\n        const { listData } = this\n        if (index >= 0) {\n          listData.splice(index, 1)\n          removed = true\n        }\n      }\n      if (removed) {\n        this.removeItemStore(this.schema, item, index)\n        this.onChange()\n      }\n    },\n\n    deleteItem(item, index) {\n      const label = (\n        item &&\n        this.getItemLabel(this.schema, item, {\n          index,\n          extended: true\n        })\n      )\n\n      const notify = () =>\n        this.notify({\n          type: this.isTransient ? 'info' : 'success',\n          title: 'Successfully Removed',\n          text: [\n            `${label} was ${this.verbs.deleted}.`,\n            this.transientNote\n          ]\n        })\n\n      if (\n        item &&\n        window.confirm(\n          `Do you really want to ${this.verbs.delete} ${label}?`\n        )\n      ) {\n        if (this.isTransient) {\n          this.removeItem(item, index)\n          notify()\n        } else {\n          const itemId = this.getItemId(this.schema, item, index)\n          const method = 'delete'\n          const resource = getMemberResource(\n            itemId,\n            this.getResource({ method })\n          )\n          if (resource) {\n            this.handleRequest({ method, resource }, err => {\n              if (!err) {\n                this.removeItem(item, index)\n                notify()\n              }\n              this.reloadData()\n            })\n          }\n        }\n      }\n    },\n\n    getSchemaComponent(index) {\n      const { schemaComponents } = this\n      const { length } = schemaComponents\n      return schemaComponents[((index % length) + length) % length]\n    },\n\n    openSchemaComponent(index) {\n      const schemaComponent = this.getSchemaComponent(index)\n      if (schemaComponent) {\n        schemaComponent.opened = true\n      }\n    },\n\n    async navigateToComponent(dataPath, onComplete) {\n      if (this.collapsible) {\n        const index = dataPath.startsWith(this.dataPath)\n          ? this.isListSource\n            ? parseDataPath(dataPath.slice(this.dataPath.length + 1))[0] ?? null\n            : 0\n          : null\n        if (index !== null && isNumber(+index)) {\n          const schemaComponent = this.getSchemaComponent(+index)\n          if (schemaComponent) {\n            const { opened } = schemaComponent\n            if (!opened) {\n              schemaComponent.opened = true\n              await this.$nextTick()\n            }\n            const components = schemaComponent.getComponentsByDataPath(dataPath)\n            if (components.length > 0 && (onComplete?.(components) ?? true)) {\n              return true\n            } else {\n              schemaComponent.opened = opened\n            }\n          }\n        }\n      }\n      return this.navigateToRouteComponent(dataPath, onComplete)\n    },\n\n    navigateToRouteComponent(dataPath, onComplete) {\n      return new Promise((resolve, reject) => {\n        const callOnComplete = () => {\n          // Retrieve the last route component, which will be the component that\n          // we just navigated to, and pass it on to `onComplete()`\n          const { routeComponents } = this.appState\n          const routeComponent = routeComponents[routeComponents.length - 1]\n          resolve(onComplete?.([routeComponent]) ?? true)\n        }\n\n        const dataPathParts = parseDataPath(dataPath)\n        // See if we can find a route that can serve part of the given dataPath,\n        // and take it from there:\n        while (dataPathParts.length > 0) {\n          const path = this.routeComponent.getChildPath(\n            this.api.normalizePath(normalizeDataPath(dataPathParts))\n          )\n          // See if there actually is a route for this sub-component:\n          const { matched } = this.$router.resolve(path)\n          if (matched.length && matched[0].name !== 'catch-all') {\n            if (this.$route.path === path) {\n              // We're already there, so just call `onComplete()`:\n              callOnComplete()\n            } else {\n              // Navigate to the component's path, then call `onComplete()`_:\n              this.$router\n                .push({ path })\n                .catch(reject)\n                // Wait for the last route component to be mounted in the next\n                // tick before calling `onComplete()`\n                .then(() => {\n                  this.$nextTick(callOnComplete)\n                })\n            }\n            return\n          }\n          // Keep removing the last part until we find a match.\n          dataPathParts.pop()\n        }\n        resolve(false)\n      })\n    }\n  }, // end of `methods`\n\n  async processSchema(\n    api,\n    schema,\n    name,\n    routes,\n    level,\n    nested = false,\n    flatten = false,\n    process = null\n  ) {\n    processRouteSchema(api, schema, name)\n    const inlined = isInlined(schema)\n    if (inlined && schema.resource) {\n      throw new Error(\n        `Nested ${\n          this.isListSource\n            ? 'lists'\n            : this.isObjectSource\n              ? 'objects'\n              : 'schema'\n        } cannot load data from their own resources`\n      )\n    }\n    // Use differently named url parameters on each nested level for id as\n    // otherwise they would clash and override each other inside $route.params\n    // See: https://github.com/vuejs/vue-router/issues/1345\n    const param = `id${level + 1}`\n    const meta = {\n      api,\n      schema\n    }\n    const formMeta = {\n      ...meta,\n      // When children are flattened (e.g. tree-lists), include the `flatten`\n      // setting also, for flattening below.\n      flatten,\n      nested,\n      param\n    }\n    const childRoutes = await processForms(api, schema, level)\n    if (process) {\n      await process(childRoutes, level + 1)\n    }\n    // Inlined forms don't need to actually add routes.\n    if (hasFormSchema(schema) && !inlined) {\n      // Lists in single-component-views (level === 0) use their view's path,\n      // while all others need their path prefixed with the parent's path:\n      const sourcePath = level === 0 ? '' : schema.path\n      const formRoute = {\n        path: getPathWithParam(\n          sourcePath,\n          // Object sources don't need id params in their form paths, as they\n          // directly edit one object.\n          isListSource(schema) ? param : null\n        ),\n        component: DitoComponent.component(\n          nested ? 'DitoFormNested' : 'DitoForm'\n        ),\n        meta: formMeta\n      }\n      if (isObjectSource(schema)) {\n        // Also add a param route, simply to handle '/create' links the same\n        // way that lists do, where it overlaps with :id for item ids.\n        routes.push({\n          ...formRoute,\n          path: getPathWithParam(sourcePath, param)\n        })\n      }\n      if (sourcePath) {\n        // Just redirect back to the parent when a nested source route is hit.\n        routes.push({\n          path: sourcePath,\n          redirect: '.',\n          meta\n        })\n      }\n      // Partition childRoutes into those that need flattening (e.g. tree-lists)\n      // and those that don't, and process each group separately after.\n      const [flatRoutes, subRoutes] = childRoutes.reduce(\n        (res, route) => {\n          res[route.meta.flatten ? 0 : 1].push(route)\n          return res\n        },\n        [[], []]\n      )\n      if (subRoutes.length) {\n        formRoute.children = subRoutes\n      }\n      routes.push(formRoute)\n      // Add the prefixed formRoutes with their children for nested lists.\n      if (flatRoutes.length) {\n        for (const childRoute of flatRoutes) {\n          routes.push({\n            ...(childRoute.redirect ? childRoute : formRoute),\n            path: `${formRoute.path}/${childRoute.path}`,\n            meta: {\n              ...childRoute.meta,\n              flatten\n            }\n          })\n        }\n      }\n    }\n  },\n\n  processValue({ schema, value, dataPath }, graph) {\n    graph.addSource(dataPath, schema)\n    return value\n  }\n}\n\nfunction getPathWithParam(path, param) {\n  return param\n    ? path\n      ? `${path}/:${param}`\n      : `:${param}`\n    : path\n}\n","import { isArray, asArray, labelize } from '@ditojs/utils'\nimport { getNamedSchemas, processNestedSchemaDefaults } from './schema'\n\nexport const filterComponents = {\n  'text'(filter) {\n    const options = [\n      {\n        label: 'contains',\n        value: 'contains'\n      },\n      {\n        label: 'equals',\n        value: 'equals'\n      },\n      {\n        label: 'starts with',\n        value: 'starts-with'\n      },\n      {\n        label: 'ends with',\n        value: 'ends-with'\n      }\n    ]\n    return {\n      operator: filter.operators\n        ? {\n            type: 'select',\n            width: '2/5',\n            options: isArray(filter.operators)\n              ? options.filter(\n                  option => filter.operators.includes(option.value)\n                )\n              : options,\n            clearable: true\n          }\n        : null,\n      text: {\n        type: 'text',\n        width: filter.operators ? '3/5' : 'fill',\n        clearable: true\n      }\n    }\n  },\n\n  'date-range'() {\n    const datetime = {\n      type: 'datetime',\n      width: '1/2',\n      formats: {\n        // Use shorter date format in date-range filters:\n        date: {\n          day: '2-digit',\n          month: '2-digit',\n          year: 'numeric'\n        }\n      },\n      clearable: true\n    }\n    return {\n      from: datetime,\n      to: datetime\n    }\n  }\n}\n\nexport function createFiltersPanel(api, filters, dataPath, query) {\n  const { sticky, ...filterSchemas } = filters\n  const panel = {\n    type: 'panel',\n    label: 'Filters',\n    name: '$filters',\n    // Override the default value\n    disabled: false,\n    sticky,\n\n    // NOTE: On panels, the data() callback does something else than on normal\n    // schema: It produces the `data` property to be passed to the panel's\n    // schema, not the data to be used for the panel component directly.\n    data() {\n      return parseFiltersData(\n        panel,\n        query.value\n      )\n    },\n\n    components: createFiltersComponents(filterSchemas),\n    buttons: createFiltersButtons(false),\n    panelButtons: createFiltersButtons(true),\n\n    events: {\n      change() {\n        this.applyFilters()\n      }\n    },\n\n    computed: {\n      filters() {\n        return formatFiltersData(this.schema, this.data)\n      },\n\n      hasFilters() {\n        return this.filters.length > 0\n      }\n    },\n\n    methods: {\n      applyFilters() {\n        query.value = {\n          ...query.value,\n          filter: this.filters,\n          // Clear pagination when applying or clearing filters:\n          page: undefined\n        }\n      },\n\n      clearFilters() {\n        this.resetData()\n        this.applyFilters()\n      }\n    }\n  }\n  processNestedSchemaDefaults(api, panel)\n  return panel\n}\n\nfunction createFiltersButtons(small) {\n  return {\n    clear: {\n      type: 'button',\n      text: small ? null : 'Clear',\n      disabled: ({ schemaComponent }) => !schemaComponent.hasFilters,\n      events: {\n        click({ schemaComponent }) {\n          // Since panel buttons are outside of the schema, we need to use the\n          // schema component received from the initialize event below:\n          schemaComponent.clearFilters()\n        }\n      }\n    },\n\n    submit: {\n      type: 'submit',\n      text: small ? null : 'Filter',\n      visible: !small,\n      events: {\n        click({ schemaComponent }) {\n          schemaComponent.applyFilters()\n        }\n      }\n    }\n  }\n}\n\nfunction getDataName(filterName) {\n  // Prefix filter data keys with '$' to avoid conflicts with other data keys:\n  return `$${filterName}`\n}\n\nfunction getFilterName(dataName) {\n  return dataName.startsWith('$') ? dataName.slice(1) : null\n}\n\nfunction createFiltersComponents(filters) {\n  const comps = {}\n  for (const filter of Object.values(getNamedSchemas(filters) || {})) {\n    // Support both custom forms and default filter components, through the\n    // `filterComponents` registry. Even for default filters, still use the\n    // properties in `filter` as the base for `form`, so things like `label`\n    // can be changed on the resulting form.\n    const { filter: type, width, ...form } = filter\n    const components = type\n      ? filterComponents[type]?.(filter)\n      : filter.components\n    if (components) {\n      form.type = 'form'\n      form.components = {}\n      // Convert labels to placeholders:\n      for (const [key, component] of Object.entries(components)) {\n        if (component) {\n          const label = component.label || labelize(component.name || key)\n          form.components[key] = {\n            ...component,\n            label: false,\n            placeholder: label\n          }\n        }\n      }\n      comps[getDataName(filter.name)] = {\n        label: form.label ?? labelize(filter.name),\n        type: 'object',\n        width,\n        default: () => ({}),\n        form,\n        inlined: true\n      }\n    } else {\n      throw new Error(\n        `Invalid filter '${filter.name}': Unknown filter type '${type}'.`\n      )\n    }\n  }\n  return comps\n}\n\nfunction getComponentsForFilter(schema, dataName) {\n  const component = schema.components[dataName]\n  return component?.form?.components\n}\n\nfunction formatFiltersData(schema, data) {\n  const filters = []\n  for (const dataName in data) {\n    const entry = data[dataName]\n    if (entry) {\n      // Map components sequence to arguments:\n      const args = Object.keys(\n        getComponentsForFilter(schema, dataName)\n      ).map(\n        key => entry[key] ?? null\n      )\n      // Only apply filter if there are some arguments that aren't null:\n      if (args.some(value => value !== null)) {\n        filters.push(\n          `${\n            getFilterName(dataName)\n          }:${\n            args.map(JSON.stringify).join(',')\n          }`\n        )\n      }\n    }\n  }\n  return filters\n}\n\nfunction parseFiltersData(schema, query) {\n  const filters = {}\n  // Same as @ditojs/server's QueryParameters.filter: Translate the string data\n  // from $route.query back to param lists per filter:\n  if (query) {\n    for (const filter of asArray(query.filter)) {\n      const [, filterName, json] = filter.match(/^(\\w+):(.*)$/)\n      try {\n        filters[filterName] = asArray(JSON.parse(`[${json}]`))\n      } catch {}\n    }\n  }\n  const filtersData = {}\n  for (const dataName in schema.components) {\n    const data = {}\n    // If we have retrieved params from the query, fetch the associated\n    // form components so we can map the values back to object keys:\n    const args = filters[getFilterName(dataName)]\n    if (args) {\n      const components = getComponentsForFilter(schema, dataName)\n      if (components) {\n        let index = 0\n        for (const key in components) {\n          data[key] = args[index++]\n        }\n      }\n    }\n    filtersData[dataName] = data\n  }\n  return filtersData\n}\n","<template lang=\"pug\">\n.dito-list(\n  v-if=\"isReady\"\n  :id=\"dataPath\"\n)\n  .dito-list__header(\n    v-if=\"scopes || hasPagination\"\n  )\n    DitoScopes(\n      v-if=\"scopes\"\n      :query=\"query\"\n      :scopes=\"scopes\"\n    )\n    //- When there's only pagination without scopes, we need a good ol' spacer\n    //- div, for the layout not to break...\n    .dito-spacer(\n      v-else-if=\"hasPagination\"\n    )\n    DitoPagination(\n      v-if=\"hasPagination\"\n      :query=\"query\"\n      :limit=\"paginate\"\n      :total=\"total || 0\"\n    )\n  table.dito-table(\n    :class=`{\n      'dito-table--separators': isInlined,\n      'dito-table--larger-padding': hasEditButtons && !isInlined,\n      'dito-table--alternate-colors': !isInlined,\n      'dito-table--even-count': hasEvenCount\n    }`\n  )\n    DitoTableHead(\n      v-if=\"columns\"\n      :query=\"query\"\n      :columns=\"columns\"\n      :hasEditButtons=\"hasEditButtons\"\n    )\n    DitoDraggable(\n      as=\"tbody\"\n      :options=\"getDraggableOptions()\"\n      :draggable=\"draggable\"\n      :modelValue=\"updateOrder(sourceSchema, listData, paginationRange)\"\n      @update:modelValue=\"value => (listData = value)\"\n    )\n      tr(\n        v-for=\"(item, index) in listData\"\n        :id=\"getDataPath(index)\"\n        :key=\"getItemUid(schema, item)\"\n      )\n        template(\n          v-if=\"columns\"\n        )\n          template(\n            v-for=\"column in columns\"\n          )\n            DitoTableCell(\n              v-if=\"shouldRenderSchema(column)\"\n              :key=\"column.name\"\n              :class=\"getCellClass(column)\"\n              :cell=\"column\"\n              :schema=\"schema\"\n              :dataPath=\"getDataPath(index)\"\n              :data=\"item\"\n              :meta=\"nestedMeta\"\n              :store=\"store\"\n              :nested=\"false\"\n              :disabled=\"disabled || isLoading\"\n            )\n        template(\n          v-else\n        )\n          td\n            DitoSchemaInlined(\n              v-if=\"isInlined\"\n              :label=\"getItemLabel(schema, item, { index, asObject: true })\"\n              :schema=\"getItemFormSchema(schema, item, context)\"\n              :dataPath=\"getDataPath(index)\"\n              :data=\"item\"\n              :meta=\"nestedMeta\"\n              :store=\"getItemStore(schema, item, index)\"\n              :disabled=\"disabled || isLoading\"\n              :collapsed=\"collapsed\"\n              :collapsible=\"collapsible\"\n              :deletable=\"deletable\"\n              :draggable=\"draggable\"\n              :editable=\"editable\"\n              :editPath=\"getEditPath(item, index)\"\n              @delete=\"deleteItem(item, index)\"\n            )\n            component(\n              v-else-if=\"schema.component\"\n              :is=\"schema.component\"\n              :dataPath=\"getDataPath(index)\"\n              :data=\"item\"\n              :nested=\"false\"\n            )\n            span(\n              v-else-if=\"render\"\n              v-html=\"render(getContext(item, index))\"\n            )\n            span(\n              v-else\n              v-html=\"getItemLabel(schema, item, { index })\"\n            )\n        td.dito-table__buttons(\n          v-if=\"hasCellEditButtons\"\n        )\n          DitoEditButtons(\n            nested\n            :schema=\"getItemFormSchema(schema, item, context)\"\n            :dataPath=\"getDataPath(index)\"\n            :data=\"item\"\n            :meta=\"nestedMeta\"\n            :store=\"getItemStore(schema, item, index)\"\n            :disabled=\"disabled || isLoading\"\n            :deletable=\"deletable\"\n            :draggable=\"draggable\"\n            :editable=\"editable\"\n            :editPath=\"getEditPath(item, index)\"\n            @delete=\"deleteItem(item, index)\"\n          )\n    //- Render create buttons inside table when not in a single component view:\n    tfoot(\n      v-if=\"hasListButtons && !single\"\n    )\n      tr\n        td.dito-table__buttons(:colspan=\"numColumns\")\n          DitoEditButtons(\n            :buttons=\"buttonSchemas\"\n            :schema=\"schema\"\n            :dataPath=\"dataPath\"\n            :data=\"data\"\n            :meta=\"meta\"\n            :store=\"store\"\n            :nested=\"nested\"\n            :disabled=\"disabled || isLoading\"\n            :creatable=\"creatable\"\n            :createPath=\"createPath\"\n          )\n  //- Render create buttons outside table when in a single component view:\n  DitoEditButtons.dito-buttons--large.dito-buttons--main.dito-buttons--sticky(\n    v-if=\"hasListButtons && single\"\n    :buttons=\"buttonSchemas\"\n    :schema=\"schema\"\n    :dataPath=\"dataPath\"\n    :data=\"listData\"\n    :meta=\"meta\"\n    :store=\"store\"\n    :disabled=\"disabled || isLoading\"\n    :creatable=\"creatable\"\n    :createPath=\"createPath\"\n  )\n</template>\n\n<script>\nimport DitoTypeComponent from '../DitoTypeComponent.js'\nimport DitoContext from '../DitoContext.js'\nimport SourceMixin from '../mixins/SourceMixin.js'\nimport SortableMixin from '../mixins/SortableMixin.js'\nimport {\n  getViewEditPath,\n  resolveSchemaComponent,\n  resolveSchemaComponents\n} from '../utils/schema.js'\nimport { createFiltersPanel } from '../utils/filter.js'\nimport { appendDataPath } from '../utils/data.js'\nimport { pickBy, equals, hyphenate } from '@ditojs/utils'\nimport { computed } from 'vue'\n\n// @vue/component\nexport default DitoTypeComponent.register('list', {\n  mixins: [SourceMixin, SortableMixin],\n\n  getSourceType(type) {\n    // No need for transformation here. See TypeTreeList for details.\n    return type\n  },\n\n  getPanelSchema(api, schema, dataPath, component) {\n    const { filters } = schema\n    // See if this list component wants to display a filter panel, and if so,\n    // create the panel schema for it through `getFiltersPanel()`.\n    if (filters) {\n      return createFiltersPanel(\n        api,\n        filters,\n        dataPath,\n        // Pass a computed value to get / set the query, see getFiltersPanel()\n        computed({\n          get() {\n            return component.query\n          },\n\n          set(query) {\n            // Filter out undefined values for comparing with equals()\n            const filter = obj => pickBy(obj, value => value !== undefined)\n            if (!equals(filter(query), filter(component.query))) {\n              component.query = query\n              component.loadData(false)\n            }\n          }\n        })\n      )\n    }\n  },\n\n  computed: {\n    hasPagination() {\n      return !!this.paginate\n    },\n\n    hasListButtons() {\n      return !!(this.buttonSchemas || this.creatable)\n    },\n\n    hasEditButtons() {\n      const { listData } = this\n      return (\n        listData.length > 0 && (\n          this.editable ||\n          this.deletable ||\n          this.draggable\n        )\n      )\n    },\n\n    hasCellEditButtons() {\n      return !this.isInlined && this.hasEditButtons\n    },\n\n    hasEvenCount() {\n      return !(this.listData.length % 2)\n    },\n\n    numColumns() {\n      return (\n        (this.columns ? Object.keys(this.columns).length : 1) +\n        (this.hasCellEditButtons ? 1 : 0)\n      )\n    }\n  },\n\n  methods: {\n    getDataPath(index) {\n      return appendDataPath(this.dataPath, index)\n    },\n\n    getEditPath(item, index) {\n      if (this.editable) {\n        const id = this.getItemId(this.schema, item, index)\n        return (\n          getViewEditPath(this.schema, id, this.context) ||\n          `${this.path}/${id}`\n        )\n      }\n      return null\n    },\n\n    getCellClass(column) {\n      return `dito-cell--${hyphenate(column.name)}`\n    },\n\n    getContext(item, index) {\n      return new DitoContext(this, {\n        data: item,\n        value: item,\n        index,\n        dataPath: this.getDataPath(index)\n      })\n    },\n\n    onFilterErrors(errors) {\n      const filtersDataPath = appendDataPath(this.dataPath, '$filters')\n      const panel = this.schemaComponent.getPanelByDataPath(filtersDataPath)\n      if (panel) {\n        panel.showValidationErrors(errors, true)\n        return true\n      }\n    }\n  },\n\n  async processSchema(\n    api,\n    schema,\n    name,\n    routes,\n    level,\n    nested = false,\n    flatten = false,\n    process = null\n  ) {\n    await Promise.all([\n      resolveSchemaComponent(schema),\n      resolveSchemaComponents(schema.columns),\n      SourceMixin.processSchema(\n        api,\n        schema,\n        name,\n        routes,\n        level,\n        nested,\n        flatten,\n        process\n      )\n    ])\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-list {\n  $self: &;\n\n  position: relative;\n\n  &__header {\n    display: flex;\n    justify-content: space-between;\n    padding-bottom: $content-padding-half;\n    @include user-select(none);\n\n    &:empty {\n      display: none;\n    }\n\n    .dito-scopes,\n    .dito-pagination {\n      display: flex;\n      flex: 0 1 auto;\n      min-width: 0;\n    }\n  }\n\n  &.dito-component--single {\n    // So that list buttons can be sticky to the bottom:\n    display: grid;\n    grid-template-rows: min-content;\n    height: 100%;\n\n    // Make single list header, navigation and buttons sticky to the top and\n    // bottom:\n    #{$self}__header {\n      position: sticky;\n      top: 0;\n      margin-top: -$content-padding;\n      padding-top: $content-padding;\n      background: $content-color-background;\n      z-index: 1;\n\n      + .dito-table {\n        .dito-table-head {\n          position: sticky;\n          top: calc($input-height + $content-padding + $content-padding-half);\n          background: $content-color-background;\n          z-index: 1;\n        }\n      }\n    }\n  }\n}\n</style>\n","<template lang=\"pug\">\nDitoLabel.dito-label-component(\n  :label=\"value\"\n  :dataPath=\"dataPath\"\n)\n</template>\n\n<script>\nimport DitoTypeComponent from '../DitoTypeComponent.js'\n\n// @vue/component\nexport default DitoTypeComponent.register('label', {\n  excludeValue: true,\n  generateLabel: false\n})\n</script>\n\n<style lang=\"scss\">\n.dito-label-component {\n  display: flex;\n  height: 2em;\n}\n</style>\n","import OrderedMap from 'orderedmap';\n\nfunction findDiffStart(a, b, pos) {\n    for (let i = 0;; i++) {\n        if (i == a.childCount || i == b.childCount)\n            return a.childCount == b.childCount ? null : pos;\n        let childA = a.child(i), childB = b.child(i);\n        if (childA == childB) {\n            pos += childA.nodeSize;\n            continue;\n        }\n        if (!childA.sameMarkup(childB))\n            return pos;\n        if (childA.isText && childA.text != childB.text) {\n            for (let j = 0; childA.text[j] == childB.text[j]; j++)\n                pos++;\n            return pos;\n        }\n        if (childA.content.size || childB.content.size) {\n            let inner = findDiffStart(childA.content, childB.content, pos + 1);\n            if (inner != null)\n                return inner;\n        }\n        pos += childA.nodeSize;\n    }\n}\nfunction findDiffEnd(a, b, posA, posB) {\n    for (let iA = a.childCount, iB = b.childCount;;) {\n        if (iA == 0 || iB == 0)\n            return iA == iB ? null : { a: posA, b: posB };\n        let childA = a.child(--iA), childB = b.child(--iB), size = childA.nodeSize;\n        if (childA == childB) {\n            posA -= size;\n            posB -= size;\n            continue;\n        }\n        if (!childA.sameMarkup(childB))\n            return { a: posA, b: posB };\n        if (childA.isText && childA.text != childB.text) {\n            let same = 0, minSize = Math.min(childA.text.length, childB.text.length);\n            while (same < minSize && childA.text[childA.text.length - same - 1] == childB.text[childB.text.length - same - 1]) {\n                same++;\n                posA--;\n                posB--;\n            }\n            return { a: posA, b: posB };\n        }\n        if (childA.content.size || childB.content.size) {\n            let inner = findDiffEnd(childA.content, childB.content, posA - 1, posB - 1);\n            if (inner)\n                return inner;\n        }\n        posA -= size;\n        posB -= size;\n    }\n}\n\n/**\nA fragment represents a node's collection of child nodes.\n\nLike nodes, fragments are persistent data structures, and you\nshould not mutate them or their content. Rather, you create new\ninstances whenever needed. The API tries to make this easy.\n*/\nclass Fragment {\n    /**\n    @internal\n    */\n    constructor(\n    /**\n    The child nodes in this fragment.\n    */\n    content, size) {\n        this.content = content;\n        this.size = size || 0;\n        if (size == null)\n            for (let i = 0; i < content.length; i++)\n                this.size += content[i].nodeSize;\n    }\n    /**\n    Invoke a callback for all descendant nodes between the given two\n    positions (relative to start of this fragment). Doesn't descend\n    into a node when the callback returns `false`.\n    */\n    nodesBetween(from, to, f, nodeStart = 0, parent) {\n        for (let i = 0, pos = 0; pos < to; i++) {\n            let child = this.content[i], end = pos + child.nodeSize;\n            if (end > from && f(child, nodeStart + pos, parent || null, i) !== false && child.content.size) {\n                let start = pos + 1;\n                child.nodesBetween(Math.max(0, from - start), Math.min(child.content.size, to - start), f, nodeStart + start);\n            }\n            pos = end;\n        }\n    }\n    /**\n    Call the given callback for every descendant node. `pos` will be\n    relative to the start of the fragment. The callback may return\n    `false` to prevent traversal of a given node's children.\n    */\n    descendants(f) {\n        this.nodesBetween(0, this.size, f);\n    }\n    /**\n    Extract the text between `from` and `to`. See the same method on\n    [`Node`](https://prosemirror.net/docs/ref/#model.Node.textBetween).\n    */\n    textBetween(from, to, blockSeparator, leafText) {\n        let text = \"\", first = true;\n        this.nodesBetween(from, to, (node, pos) => {\n            let nodeText = node.isText ? node.text.slice(Math.max(from, pos) - pos, to - pos)\n                : !node.isLeaf ? \"\"\n                    : leafText ? (typeof leafText === \"function\" ? leafText(node) : leafText)\n                        : node.type.spec.leafText ? node.type.spec.leafText(node)\n                            : \"\";\n            if (node.isBlock && (node.isLeaf && nodeText || node.isTextblock) && blockSeparator) {\n                if (first)\n                    first = false;\n                else\n                    text += blockSeparator;\n            }\n            text += nodeText;\n        }, 0);\n        return text;\n    }\n    /**\n    Create a new fragment containing the combined content of this\n    fragment and the other.\n    */\n    append(other) {\n        if (!other.size)\n            return this;\n        if (!this.size)\n            return other;\n        let last = this.lastChild, first = other.firstChild, content = this.content.slice(), i = 0;\n        if (last.isText && last.sameMarkup(first)) {\n            content[content.length - 1] = last.withText(last.text + first.text);\n            i = 1;\n        }\n        for (; i < other.content.length; i++)\n            content.push(other.content[i]);\n        return new Fragment(content, this.size + other.size);\n    }\n    /**\n    Cut out the sub-fragment between the two given positions.\n    */\n    cut(from, to = this.size) {\n        if (from == 0 && to == this.size)\n            return this;\n        let result = [], size = 0;\n        if (to > from)\n            for (let i = 0, pos = 0; pos < to; i++) {\n                let child = this.content[i], end = pos + child.nodeSize;\n                if (end > from) {\n                    if (pos < from || end > to) {\n                        if (child.isText)\n                            child = child.cut(Math.max(0, from - pos), Math.min(child.text.length, to - pos));\n                        else\n                            child = child.cut(Math.max(0, from - pos - 1), Math.min(child.content.size, to - pos - 1));\n                    }\n                    result.push(child);\n                    size += child.nodeSize;\n                }\n                pos = end;\n            }\n        return new Fragment(result, size);\n    }\n    /**\n    @internal\n    */\n    cutByIndex(from, to) {\n        if (from == to)\n            return Fragment.empty;\n        if (from == 0 && to == this.content.length)\n            return this;\n        return new Fragment(this.content.slice(from, to));\n    }\n    /**\n    Create a new fragment in which the node at the given index is\n    replaced by the given node.\n    */\n    replaceChild(index, node) {\n        let current = this.content[index];\n        if (current == node)\n            return this;\n        let copy = this.content.slice();\n        let size = this.size + node.nodeSize - current.nodeSize;\n        copy[index] = node;\n        return new Fragment(copy, size);\n    }\n    /**\n    Create a new fragment by prepending the given node to this\n    fragment.\n    */\n    addToStart(node) {\n        return new Fragment([node].concat(this.content), this.size + node.nodeSize);\n    }\n    /**\n    Create a new fragment by appending the given node to this\n    fragment.\n    */\n    addToEnd(node) {\n        return new Fragment(this.content.concat(node), this.size + node.nodeSize);\n    }\n    /**\n    Compare this fragment to another one.\n    */\n    eq(other) {\n        if (this.content.length != other.content.length)\n            return false;\n        for (let i = 0; i < this.content.length; i++)\n            if (!this.content[i].eq(other.content[i]))\n                return false;\n        return true;\n    }\n    /**\n    The first child of the fragment, or `null` if it is empty.\n    */\n    get firstChild() { return this.content.length ? this.content[0] : null; }\n    /**\n    The last child of the fragment, or `null` if it is empty.\n    */\n    get lastChild() { return this.content.length ? this.content[this.content.length - 1] : null; }\n    /**\n    The number of child nodes in this fragment.\n    */\n    get childCount() { return this.content.length; }\n    /**\n    Get the child node at the given index. Raise an error when the\n    index is out of range.\n    */\n    child(index) {\n        let found = this.content[index];\n        if (!found)\n            throw new RangeError(\"Index \" + index + \" out of range for \" + this);\n        return found;\n    }\n    /**\n    Get the child node at the given index, if it exists.\n    */\n    maybeChild(index) {\n        return this.content[index] || null;\n    }\n    /**\n    Call `f` for every child node, passing the node, its offset\n    into this parent node, and its index.\n    */\n    forEach(f) {\n        for (let i = 0, p = 0; i < this.content.length; i++) {\n            let child = this.content[i];\n            f(child, p, i);\n            p += child.nodeSize;\n        }\n    }\n    /**\n    Find the first position at which this fragment and another\n    fragment differ, or `null` if they are the same.\n    */\n    findDiffStart(other, pos = 0) {\n        return findDiffStart(this, other, pos);\n    }\n    /**\n    Find the first position, searching from the end, at which this\n    fragment and the given fragment differ, or `null` if they are\n    the same. Since this position will not be the same in both\n    nodes, an object with two separate positions is returned.\n    */\n    findDiffEnd(other, pos = this.size, otherPos = other.size) {\n        return findDiffEnd(this, other, pos, otherPos);\n    }\n    /**\n    Find the index and inner offset corresponding to a given relative\n    position in this fragment. The result object will be reused\n    (overwritten) the next time the function is called. @internal\n    */\n    findIndex(pos) {\n        if (pos == 0)\n            return retIndex(0, pos);\n        if (pos == this.size)\n            return retIndex(this.content.length, pos);\n        if (pos > this.size || pos < 0)\n            throw new RangeError(`Position ${pos} outside of fragment (${this})`);\n        for (let i = 0, curPos = 0;; i++) {\n            let cur = this.child(i), end = curPos + cur.nodeSize;\n            if (end >= pos) {\n                if (end == pos)\n                    return retIndex(i + 1, end);\n                return retIndex(i, curPos);\n            }\n            curPos = end;\n        }\n    }\n    /**\n    Return a debugging string that describes this fragment.\n    */\n    toString() { return \"<\" + this.toStringInner() + \">\"; }\n    /**\n    @internal\n    */\n    toStringInner() { return this.content.join(\", \"); }\n    /**\n    Create a JSON-serializeable representation of this fragment.\n    */\n    toJSON() {\n        return this.content.length ? this.content.map(n => n.toJSON()) : null;\n    }\n    /**\n    Deserialize a fragment from its JSON representation.\n    */\n    static fromJSON(schema, value) {\n        if (!value)\n            return Fragment.empty;\n        if (!Array.isArray(value))\n            throw new RangeError(\"Invalid input for Fragment.fromJSON\");\n        return new Fragment(value.map(schema.nodeFromJSON));\n    }\n    /**\n    Build a fragment from an array of nodes. Ensures that adjacent\n    text nodes with the same marks are joined together.\n    */\n    static fromArray(array) {\n        if (!array.length)\n            return Fragment.empty;\n        let joined, size = 0;\n        for (let i = 0; i < array.length; i++) {\n            let node = array[i];\n            size += node.nodeSize;\n            if (i && node.isText && array[i - 1].sameMarkup(node)) {\n                if (!joined)\n                    joined = array.slice(0, i);\n                joined[joined.length - 1] = node\n                    .withText(joined[joined.length - 1].text + node.text);\n            }\n            else if (joined) {\n                joined.push(node);\n            }\n        }\n        return new Fragment(joined || array, size);\n    }\n    /**\n    Create a fragment from something that can be interpreted as a\n    set of nodes. For `null`, it returns the empty fragment. For a\n    fragment, the fragment itself. For a node or array of nodes, a\n    fragment containing those nodes.\n    */\n    static from(nodes) {\n        if (!nodes)\n            return Fragment.empty;\n        if (nodes instanceof Fragment)\n            return nodes;\n        if (Array.isArray(nodes))\n            return this.fromArray(nodes);\n        if (nodes.attrs)\n            return new Fragment([nodes], nodes.nodeSize);\n        throw new RangeError(\"Can not convert \" + nodes + \" to a Fragment\" +\n            (nodes.nodesBetween ? \" (looks like multiple versions of prosemirror-model were loaded)\" : \"\"));\n    }\n}\n/**\nAn empty fragment. Intended to be reused whenever a node doesn't\ncontain anything (rather than allocating a new empty fragment for\neach leaf node).\n*/\nFragment.empty = new Fragment([], 0);\nconst found = { index: 0, offset: 0 };\nfunction retIndex(index, offset) {\n    found.index = index;\n    found.offset = offset;\n    return found;\n}\n\nfunction compareDeep(a, b) {\n    if (a === b)\n        return true;\n    if (!(a && typeof a == \"object\") ||\n        !(b && typeof b == \"object\"))\n        return false;\n    let array = Array.isArray(a);\n    if (Array.isArray(b) != array)\n        return false;\n    if (array) {\n        if (a.length != b.length)\n            return false;\n        for (let i = 0; i < a.length; i++)\n            if (!compareDeep(a[i], b[i]))\n                return false;\n    }\n    else {\n        for (let p in a)\n            if (!(p in b) || !compareDeep(a[p], b[p]))\n                return false;\n        for (let p in b)\n            if (!(p in a))\n                return false;\n    }\n    return true;\n}\n\n/**\nA mark is a piece of information that can be attached to a node,\nsuch as it being emphasized, in code font, or a link. It has a\ntype and optionally a set of attributes that provide further\ninformation (such as the target of the link). Marks are created\nthrough a `Schema`, which controls which types exist and which\nattributes they have.\n*/\nclass Mark {\n    /**\n    @internal\n    */\n    constructor(\n    /**\n    The type of this mark.\n    */\n    type, \n    /**\n    The attributes associated with this mark.\n    */\n    attrs) {\n        this.type = type;\n        this.attrs = attrs;\n    }\n    /**\n    Given a set of marks, create a new set which contains this one as\n    well, in the right position. If this mark is already in the set,\n    the set itself is returned. If any marks that are set to be\n    [exclusive](https://prosemirror.net/docs/ref/#model.MarkSpec.excludes) with this mark are present,\n    those are replaced by this one.\n    */\n    addToSet(set) {\n        let copy, placed = false;\n        for (let i = 0; i < set.length; i++) {\n            let other = set[i];\n            if (this.eq(other))\n                return set;\n            if (this.type.excludes(other.type)) {\n                if (!copy)\n                    copy = set.slice(0, i);\n            }\n            else if (other.type.excludes(this.type)) {\n                return set;\n            }\n            else {\n                if (!placed && other.type.rank > this.type.rank) {\n                    if (!copy)\n                        copy = set.slice(0, i);\n                    copy.push(this);\n                    placed = true;\n                }\n                if (copy)\n                    copy.push(other);\n            }\n        }\n        if (!copy)\n            copy = set.slice();\n        if (!placed)\n            copy.push(this);\n        return copy;\n    }\n    /**\n    Remove this mark from the given set, returning a new set. If this\n    mark is not in the set, the set itself is returned.\n    */\n    removeFromSet(set) {\n        for (let i = 0; i < set.length; i++)\n            if (this.eq(set[i]))\n                return set.slice(0, i).concat(set.slice(i + 1));\n        return set;\n    }\n    /**\n    Test whether this mark is in the given set of marks.\n    */\n    isInSet(set) {\n        for (let i = 0; i < set.length; i++)\n            if (this.eq(set[i]))\n                return true;\n        return false;\n    }\n    /**\n    Test whether this mark has the same type and attributes as\n    another mark.\n    */\n    eq(other) {\n        return this == other ||\n            (this.type == other.type && compareDeep(this.attrs, other.attrs));\n    }\n    /**\n    Convert this mark to a JSON-serializeable representation.\n    */\n    toJSON() {\n        let obj = { type: this.type.name };\n        for (let _ in this.attrs) {\n            obj.attrs = this.attrs;\n            break;\n        }\n        return obj;\n    }\n    /**\n    Deserialize a mark from JSON.\n    */\n    static fromJSON(schema, json) {\n        if (!json)\n            throw new RangeError(\"Invalid input for Mark.fromJSON\");\n        let type = schema.marks[json.type];\n        if (!type)\n            throw new RangeError(`There is no mark type ${json.type} in this schema`);\n        let mark = type.create(json.attrs);\n        type.checkAttrs(mark.attrs);\n        return mark;\n    }\n    /**\n    Test whether two sets of marks are identical.\n    */\n    static sameSet(a, b) {\n        if (a == b)\n            return true;\n        if (a.length != b.length)\n            return false;\n        for (let i = 0; i < a.length; i++)\n            if (!a[i].eq(b[i]))\n                return false;\n        return true;\n    }\n    /**\n    Create a properly sorted mark set from null, a single mark, or an\n    unsorted array of marks.\n    */\n    static setFrom(marks) {\n        if (!marks || Array.isArray(marks) && marks.length == 0)\n            return Mark.none;\n        if (marks instanceof Mark)\n            return [marks];\n        let copy = marks.slice();\n        copy.sort((a, b) => a.type.rank - b.type.rank);\n        return copy;\n    }\n}\n/**\nThe empty set of marks.\n*/\nMark.none = [];\n\n/**\nError type raised by [`Node.replace`](https://prosemirror.net/docs/ref/#model.Node.replace) when\ngiven an invalid replacement.\n*/\nclass ReplaceError extends Error {\n}\n/*\nReplaceError = function(this: any, message: string) {\n  let err = Error.call(this, message)\n  ;(err as any).__proto__ = ReplaceError.prototype\n  return err\n} as any\n\nReplaceError.prototype = Object.create(Error.prototype)\nReplaceError.prototype.constructor = ReplaceError\nReplaceError.prototype.name = \"ReplaceError\"\n*/\n/**\nA slice represents a piece cut out of a larger document. It\nstores not only a fragment, but also the depth up to which nodes on\nboth side are ‘open’ (cut through).\n*/\nclass Slice {\n    /**\n    Create a slice. When specifying a non-zero open depth, you must\n    make sure that there are nodes of at least that depth at the\n    appropriate side of the fragment—i.e. if the fragment is an\n    empty paragraph node, `openStart` and `openEnd` can't be greater\n    than 1.\n    \n    It is not necessary for the content of open nodes to conform to\n    the schema's content constraints, though it should be a valid\n    start/end/middle for such a node, depending on which sides are\n    open.\n    */\n    constructor(\n    /**\n    The slice's content.\n    */\n    content, \n    /**\n    The open depth at the start of the fragment.\n    */\n    openStart, \n    /**\n    The open depth at the end.\n    */\n    openEnd) {\n        this.content = content;\n        this.openStart = openStart;\n        this.openEnd = openEnd;\n    }\n    /**\n    The size this slice would add when inserted into a document.\n    */\n    get size() {\n        return this.content.size - this.openStart - this.openEnd;\n    }\n    /**\n    @internal\n    */\n    insertAt(pos, fragment) {\n        let content = insertInto(this.content, pos + this.openStart, fragment);\n        return content && new Slice(content, this.openStart, this.openEnd);\n    }\n    /**\n    @internal\n    */\n    removeBetween(from, to) {\n        return new Slice(removeRange(this.content, from + this.openStart, to + this.openStart), this.openStart, this.openEnd);\n    }\n    /**\n    Tests whether this slice is equal to another slice.\n    */\n    eq(other) {\n        return this.content.eq(other.content) && this.openStart == other.openStart && this.openEnd == other.openEnd;\n    }\n    /**\n    @internal\n    */\n    toString() {\n        return this.content + \"(\" + this.openStart + \",\" + this.openEnd + \")\";\n    }\n    /**\n    Convert a slice to a JSON-serializable representation.\n    */\n    toJSON() {\n        if (!this.content.size)\n            return null;\n        let json = { content: this.content.toJSON() };\n        if (this.openStart > 0)\n            json.openStart = this.openStart;\n        if (this.openEnd > 0)\n            json.openEnd = this.openEnd;\n        return json;\n    }\n    /**\n    Deserialize a slice from its JSON representation.\n    */\n    static fromJSON(schema, json) {\n        if (!json)\n            return Slice.empty;\n        let openStart = json.openStart || 0, openEnd = json.openEnd || 0;\n        if (typeof openStart != \"number\" || typeof openEnd != \"number\")\n            throw new RangeError(\"Invalid input for Slice.fromJSON\");\n        return new Slice(Fragment.fromJSON(schema, json.content), openStart, openEnd);\n    }\n    /**\n    Create a slice from a fragment by taking the maximum possible\n    open value on both side of the fragment.\n    */\n    static maxOpen(fragment, openIsolating = true) {\n        let openStart = 0, openEnd = 0;\n        for (let n = fragment.firstChild; n && !n.isLeaf && (openIsolating || !n.type.spec.isolating); n = n.firstChild)\n            openStart++;\n        for (let n = fragment.lastChild; n && !n.isLeaf && (openIsolating || !n.type.spec.isolating); n = n.lastChild)\n            openEnd++;\n        return new Slice(fragment, openStart, openEnd);\n    }\n}\n/**\nThe empty slice.\n*/\nSlice.empty = new Slice(Fragment.empty, 0, 0);\nfunction removeRange(content, from, to) {\n    let { index, offset } = content.findIndex(from), child = content.maybeChild(index);\n    let { index: indexTo, offset: offsetTo } = content.findIndex(to);\n    if (offset == from || child.isText) {\n        if (offsetTo != to && !content.child(indexTo).isText)\n            throw new RangeError(\"Removing non-flat range\");\n        return content.cut(0, from).append(content.cut(to));\n    }\n    if (index != indexTo)\n        throw new RangeError(\"Removing non-flat range\");\n    return content.replaceChild(index, child.copy(removeRange(child.content, from - offset - 1, to - offset - 1)));\n}\nfunction insertInto(content, dist, insert, parent) {\n    let { index, offset } = content.findIndex(dist), child = content.maybeChild(index);\n    if (offset == dist || child.isText) {\n        if (parent && !parent.canReplace(index, index, insert))\n            return null;\n        return content.cut(0, dist).append(insert).append(content.cut(dist));\n    }\n    let inner = insertInto(child.content, dist - offset - 1, insert, child);\n    return inner && content.replaceChild(index, child.copy(inner));\n}\nfunction replace($from, $to, slice) {\n    if (slice.openStart > $from.depth)\n        throw new ReplaceError(\"Inserted content deeper than insertion position\");\n    if ($from.depth - slice.openStart != $to.depth - slice.openEnd)\n        throw new ReplaceError(\"Inconsistent open depths\");\n    return replaceOuter($from, $to, slice, 0);\n}\nfunction replaceOuter($from, $to, slice, depth) {\n    let index = $from.index(depth), node = $from.node(depth);\n    if (index == $to.index(depth) && depth < $from.depth - slice.openStart) {\n        let inner = replaceOuter($from, $to, slice, depth + 1);\n        return node.copy(node.content.replaceChild(index, inner));\n    }\n    else if (!slice.content.size) {\n        return close(node, replaceTwoWay($from, $to, depth));\n    }\n    else if (!slice.openStart && !slice.openEnd && $from.depth == depth && $to.depth == depth) { // Simple, flat case\n        let parent = $from.parent, content = parent.content;\n        return close(parent, content.cut(0, $from.parentOffset).append(slice.content).append(content.cut($to.parentOffset)));\n    }\n    else {\n        let { start, end } = prepareSliceForReplace(slice, $from);\n        return close(node, replaceThreeWay($from, start, end, $to, depth));\n    }\n}\nfunction checkJoin(main, sub) {\n    if (!sub.type.compatibleContent(main.type))\n        throw new ReplaceError(\"Cannot join \" + sub.type.name + \" onto \" + main.type.name);\n}\nfunction joinable($before, $after, depth) {\n    let node = $before.node(depth);\n    checkJoin(node, $after.node(depth));\n    return node;\n}\nfunction addNode(child, target) {\n    let last = target.length - 1;\n    if (last >= 0 && child.isText && child.sameMarkup(target[last]))\n        target[last] = child.withText(target[last].text + child.text);\n    else\n        target.push(child);\n}\nfunction addRange($start, $end, depth, target) {\n    let node = ($end || $start).node(depth);\n    let startIndex = 0, endIndex = $end ? $end.index(depth) : node.childCount;\n    if ($start) {\n        startIndex = $start.index(depth);\n        if ($start.depth > depth) {\n            startIndex++;\n        }\n        else if ($start.textOffset) {\n            addNode($start.nodeAfter, target);\n            startIndex++;\n        }\n    }\n    for (let i = startIndex; i < endIndex; i++)\n        addNode(node.child(i), target);\n    if ($end && $end.depth == depth && $end.textOffset)\n        addNode($end.nodeBefore, target);\n}\nfunction close(node, content) {\n    node.type.checkContent(content);\n    return node.copy(content);\n}\nfunction replaceThreeWay($from, $start, $end, $to, depth) {\n    let openStart = $from.depth > depth && joinable($from, $start, depth + 1);\n    let openEnd = $to.depth > depth && joinable($end, $to, depth + 1);\n    let content = [];\n    addRange(null, $from, depth, content);\n    if (openStart && openEnd && $start.index(depth) == $end.index(depth)) {\n        checkJoin(openStart, openEnd);\n        addNode(close(openStart, replaceThreeWay($from, $start, $end, $to, depth + 1)), content);\n    }\n    else {\n        if (openStart)\n            addNode(close(openStart, replaceTwoWay($from, $start, depth + 1)), content);\n        addRange($start, $end, depth, content);\n        if (openEnd)\n            addNode(close(openEnd, replaceTwoWay($end, $to, depth + 1)), content);\n    }\n    addRange($to, null, depth, content);\n    return new Fragment(content);\n}\nfunction replaceTwoWay($from, $to, depth) {\n    let content = [];\n    addRange(null, $from, depth, content);\n    if ($from.depth > depth) {\n        let type = joinable($from, $to, depth + 1);\n        addNode(close(type, replaceTwoWay($from, $to, depth + 1)), content);\n    }\n    addRange($to, null, depth, content);\n    return new Fragment(content);\n}\nfunction prepareSliceForReplace(slice, $along) {\n    let extra = $along.depth - slice.openStart, parent = $along.node(extra);\n    let node = parent.copy(slice.content);\n    for (let i = extra - 1; i >= 0; i--)\n        node = $along.node(i).copy(Fragment.from(node));\n    return { start: node.resolveNoCache(slice.openStart + extra),\n        end: node.resolveNoCache(node.content.size - slice.openEnd - extra) };\n}\n\n/**\nYou can [_resolve_](https://prosemirror.net/docs/ref/#model.Node.resolve) a position to get more\ninformation about it. Objects of this class represent such a\nresolved position, providing various pieces of context\ninformation, and some helper methods.\n\nThroughout this interface, methods that take an optional `depth`\nparameter will interpret undefined as `this.depth` and negative\nnumbers as `this.depth + value`.\n*/\nclass ResolvedPos {\n    /**\n    @internal\n    */\n    constructor(\n    /**\n    The position that was resolved.\n    */\n    pos, \n    /**\n    @internal\n    */\n    path, \n    /**\n    The offset this position has into its parent node.\n    */\n    parentOffset) {\n        this.pos = pos;\n        this.path = path;\n        this.parentOffset = parentOffset;\n        this.depth = path.length / 3 - 1;\n    }\n    /**\n    @internal\n    */\n    resolveDepth(val) {\n        if (val == null)\n            return this.depth;\n        if (val < 0)\n            return this.depth + val;\n        return val;\n    }\n    /**\n    The parent node that the position points into. Note that even if\n    a position points into a text node, that node is not considered\n    the parent—text nodes are ‘flat’ in this model, and have no content.\n    */\n    get parent() { return this.node(this.depth); }\n    /**\n    The root node in which the position was resolved.\n    */\n    get doc() { return this.node(0); }\n    /**\n    The ancestor node at the given level. `p.node(p.depth)` is the\n    same as `p.parent`.\n    */\n    node(depth) { return this.path[this.resolveDepth(depth) * 3]; }\n    /**\n    The index into the ancestor at the given level. If this points\n    at the 3rd node in the 2nd paragraph on the top level, for\n    example, `p.index(0)` is 1 and `p.index(1)` is 2.\n    */\n    index(depth) { return this.path[this.resolveDepth(depth) * 3 + 1]; }\n    /**\n    The index pointing after this position into the ancestor at the\n    given level.\n    */\n    indexAfter(depth) {\n        depth = this.resolveDepth(depth);\n        return this.index(depth) + (depth == this.depth && !this.textOffset ? 0 : 1);\n    }\n    /**\n    The (absolute) position at the start of the node at the given\n    level.\n    */\n    start(depth) {\n        depth = this.resolveDepth(depth);\n        return depth == 0 ? 0 : this.path[depth * 3 - 1] + 1;\n    }\n    /**\n    The (absolute) position at the end of the node at the given\n    level.\n    */\n    end(depth) {\n        depth = this.resolveDepth(depth);\n        return this.start(depth) + this.node(depth).content.size;\n    }\n    /**\n    The (absolute) position directly before the wrapping node at the\n    given level, or, when `depth` is `this.depth + 1`, the original\n    position.\n    */\n    before(depth) {\n        depth = this.resolveDepth(depth);\n        if (!depth)\n            throw new RangeError(\"There is no position before the top-level node\");\n        return depth == this.depth + 1 ? this.pos : this.path[depth * 3 - 1];\n    }\n    /**\n    The (absolute) position directly after the wrapping node at the\n    given level, or the original position when `depth` is `this.depth + 1`.\n    */\n    after(depth) {\n        depth = this.resolveDepth(depth);\n        if (!depth)\n            throw new RangeError(\"There is no position after the top-level node\");\n        return depth == this.depth + 1 ? this.pos : this.path[depth * 3 - 1] + this.path[depth * 3].nodeSize;\n    }\n    /**\n    When this position points into a text node, this returns the\n    distance between the position and the start of the text node.\n    Will be zero for positions that point between nodes.\n    */\n    get textOffset() { return this.pos - this.path[this.path.length - 1]; }\n    /**\n    Get the node directly after the position, if any. If the position\n    points into a text node, only the part of that node after the\n    position is returned.\n    */\n    get nodeAfter() {\n        let parent = this.parent, index = this.index(this.depth);\n        if (index == parent.childCount)\n            return null;\n        let dOff = this.pos - this.path[this.path.length - 1], child = parent.child(index);\n        return dOff ? parent.child(index).cut(dOff) : child;\n    }\n    /**\n    Get the node directly before the position, if any. If the\n    position points into a text node, only the part of that node\n    before the position is returned.\n    */\n    get nodeBefore() {\n        let index = this.index(this.depth);\n        let dOff = this.pos - this.path[this.path.length - 1];\n        if (dOff)\n            return this.parent.child(index).cut(0, dOff);\n        return index == 0 ? null : this.parent.child(index - 1);\n    }\n    /**\n    Get the position at the given index in the parent node at the\n    given depth (which defaults to `this.depth`).\n    */\n    posAtIndex(index, depth) {\n        depth = this.resolveDepth(depth);\n        let node = this.path[depth * 3], pos = depth == 0 ? 0 : this.path[depth * 3 - 1] + 1;\n        for (let i = 0; i < index; i++)\n            pos += node.child(i).nodeSize;\n        return pos;\n    }\n    /**\n    Get the marks at this position, factoring in the surrounding\n    marks' [`inclusive`](https://prosemirror.net/docs/ref/#model.MarkSpec.inclusive) property. If the\n    position is at the start of a non-empty node, the marks of the\n    node after it (if any) are returned.\n    */\n    marks() {\n        let parent = this.parent, index = this.index();\n        // In an empty parent, return the empty array\n        if (parent.content.size == 0)\n            return Mark.none;\n        // When inside a text node, just return the text node's marks\n        if (this.textOffset)\n            return parent.child(index).marks;\n        let main = parent.maybeChild(index - 1), other = parent.maybeChild(index);\n        // If the `after` flag is true of there is no node before, make\n        // the node after this position the main reference.\n        if (!main) {\n            let tmp = main;\n            main = other;\n            other = tmp;\n        }\n        // Use all marks in the main node, except those that have\n        // `inclusive` set to false and are not present in the other node.\n        let marks = main.marks;\n        for (var i = 0; i < marks.length; i++)\n            if (marks[i].type.spec.inclusive === false && (!other || !marks[i].isInSet(other.marks)))\n                marks = marks[i--].removeFromSet(marks);\n        return marks;\n    }\n    /**\n    Get the marks after the current position, if any, except those\n    that are non-inclusive and not present at position `$end`. This\n    is mostly useful for getting the set of marks to preserve after a\n    deletion. Will return `null` if this position is at the end of\n    its parent node or its parent node isn't a textblock (in which\n    case no marks should be preserved).\n    */\n    marksAcross($end) {\n        let after = this.parent.maybeChild(this.index());\n        if (!after || !after.isInline)\n            return null;\n        let marks = after.marks, next = $end.parent.maybeChild($end.index());\n        for (var i = 0; i < marks.length; i++)\n            if (marks[i].type.spec.inclusive === false && (!next || !marks[i].isInSet(next.marks)))\n                marks = marks[i--].removeFromSet(marks);\n        return marks;\n    }\n    /**\n    The depth up to which this position and the given (non-resolved)\n    position share the same parent nodes.\n    */\n    sharedDepth(pos) {\n        for (let depth = this.depth; depth > 0; depth--)\n            if (this.start(depth) <= pos && this.end(depth) >= pos)\n                return depth;\n        return 0;\n    }\n    /**\n    Returns a range based on the place where this position and the\n    given position diverge around block content. If both point into\n    the same textblock, for example, a range around that textblock\n    will be returned. If they point into different blocks, the range\n    around those blocks in their shared ancestor is returned. You can\n    pass in an optional predicate that will be called with a parent\n    node to see if a range into that parent is acceptable.\n    */\n    blockRange(other = this, pred) {\n        if (other.pos < this.pos)\n            return other.blockRange(this);\n        for (let d = this.depth - (this.parent.inlineContent || this.pos == other.pos ? 1 : 0); d >= 0; d--)\n            if (other.pos <= this.end(d) && (!pred || pred(this.node(d))))\n                return new NodeRange(this, other, d);\n        return null;\n    }\n    /**\n    Query whether the given position shares the same parent node.\n    */\n    sameParent(other) {\n        return this.pos - this.parentOffset == other.pos - other.parentOffset;\n    }\n    /**\n    Return the greater of this and the given position.\n    */\n    max(other) {\n        return other.pos > this.pos ? other : this;\n    }\n    /**\n    Return the smaller of this and the given position.\n    */\n    min(other) {\n        return other.pos < this.pos ? other : this;\n    }\n    /**\n    @internal\n    */\n    toString() {\n        let str = \"\";\n        for (let i = 1; i <= this.depth; i++)\n            str += (str ? \"/\" : \"\") + this.node(i).type.name + \"_\" + this.index(i - 1);\n        return str + \":\" + this.parentOffset;\n    }\n    /**\n    @internal\n    */\n    static resolve(doc, pos) {\n        if (!(pos >= 0 && pos <= doc.content.size))\n            throw new RangeError(\"Position \" + pos + \" out of range\");\n        let path = [];\n        let start = 0, parentOffset = pos;\n        for (let node = doc;;) {\n            let { index, offset } = node.content.findIndex(parentOffset);\n            let rem = parentOffset - offset;\n            path.push(node, index, start + offset);\n            if (!rem)\n                break;\n            node = node.child(index);\n            if (node.isText)\n                break;\n            parentOffset = rem - 1;\n            start += offset + 1;\n        }\n        return new ResolvedPos(pos, path, parentOffset);\n    }\n    /**\n    @internal\n    */\n    static resolveCached(doc, pos) {\n        let cache = resolveCache.get(doc);\n        if (cache) {\n            for (let i = 0; i < cache.elts.length; i++) {\n                let elt = cache.elts[i];\n                if (elt.pos == pos)\n                    return elt;\n            }\n        }\n        else {\n            resolveCache.set(doc, cache = new ResolveCache);\n        }\n        let result = cache.elts[cache.i] = ResolvedPos.resolve(doc, pos);\n        cache.i = (cache.i + 1) % resolveCacheSize;\n        return result;\n    }\n}\nclass ResolveCache {\n    constructor() {\n        this.elts = [];\n        this.i = 0;\n    }\n}\nconst resolveCacheSize = 12, resolveCache = new WeakMap();\n/**\nRepresents a flat range of content, i.e. one that starts and\nends in the same node.\n*/\nclass NodeRange {\n    /**\n    Construct a node range. `$from` and `$to` should point into the\n    same node until at least the given `depth`, since a node range\n    denotes an adjacent set of nodes in a single parent node.\n    */\n    constructor(\n    /**\n    A resolved position along the start of the content. May have a\n    `depth` greater than this object's `depth` property, since\n    these are the positions that were used to compute the range,\n    not re-resolved positions directly at its boundaries.\n    */\n    $from, \n    /**\n    A position along the end of the content. See\n    caveat for [`$from`](https://prosemirror.net/docs/ref/#model.NodeRange.$from).\n    */\n    $to, \n    /**\n    The depth of the node that this range points into.\n    */\n    depth) {\n        this.$from = $from;\n        this.$to = $to;\n        this.depth = depth;\n    }\n    /**\n    The position at the start of the range.\n    */\n    get start() { return this.$from.before(this.depth + 1); }\n    /**\n    The position at the end of the range.\n    */\n    get end() { return this.$to.after(this.depth + 1); }\n    /**\n    The parent node that the range points into.\n    */\n    get parent() { return this.$from.node(this.depth); }\n    /**\n    The start index of the range in the parent node.\n    */\n    get startIndex() { return this.$from.index(this.depth); }\n    /**\n    The end index of the range in the parent node.\n    */\n    get endIndex() { return this.$to.indexAfter(this.depth); }\n}\n\nconst emptyAttrs = Object.create(null);\n/**\nThis class represents a node in the tree that makes up a\nProseMirror document. So a document is an instance of `Node`, with\nchildren that are also instances of `Node`.\n\nNodes are persistent data structures. Instead of changing them, you\ncreate new ones with the content you want. Old ones keep pointing\nat the old document shape. This is made cheaper by sharing\nstructure between the old and new data as much as possible, which a\ntree shape like this (without back pointers) makes easy.\n\n**Do not** directly mutate the properties of a `Node` object. See\n[the guide](https://prosemirror.net/docs/guide/#doc) for more information.\n*/\nclass Node {\n    /**\n    @internal\n    */\n    constructor(\n    /**\n    The type of node that this is.\n    */\n    type, \n    /**\n    An object mapping attribute names to values. The kind of\n    attributes allowed and required are\n    [determined](https://prosemirror.net/docs/ref/#model.NodeSpec.attrs) by the node type.\n    */\n    attrs, \n    // A fragment holding the node's children.\n    content, \n    /**\n    The marks (things like whether it is emphasized or part of a\n    link) applied to this node.\n    */\n    marks = Mark.none) {\n        this.type = type;\n        this.attrs = attrs;\n        this.marks = marks;\n        this.content = content || Fragment.empty;\n    }\n    /**\n    The array of this node's child nodes.\n    */\n    get children() { return this.content.content; }\n    /**\n    The size of this node, as defined by the integer-based [indexing\n    scheme](https://prosemirror.net/docs/guide/#doc.indexing). For text nodes, this is the\n    amount of characters. For other leaf nodes, it is one. For\n    non-leaf nodes, it is the size of the content plus two (the\n    start and end token).\n    */\n    get nodeSize() { return this.isLeaf ? 1 : 2 + this.content.size; }\n    /**\n    The number of children that the node has.\n    */\n    get childCount() { return this.content.childCount; }\n    /**\n    Get the child node at the given index. Raises an error when the\n    index is out of range.\n    */\n    child(index) { return this.content.child(index); }\n    /**\n    Get the child node at the given index, if it exists.\n    */\n    maybeChild(index) { return this.content.maybeChild(index); }\n    /**\n    Call `f` for every child node, passing the node, its offset\n    into this parent node, and its index.\n    */\n    forEach(f) { this.content.forEach(f); }\n    /**\n    Invoke a callback for all descendant nodes recursively between\n    the given two positions that are relative to start of this\n    node's content. The callback is invoked with the node, its\n    position relative to the original node (method receiver),\n    its parent node, and its child index. When the callback returns\n    false for a given node, that node's children will not be\n    recursed over. The last parameter can be used to specify a\n    starting position to count from.\n    */\n    nodesBetween(from, to, f, startPos = 0) {\n        this.content.nodesBetween(from, to, f, startPos, this);\n    }\n    /**\n    Call the given callback for every descendant node. Doesn't\n    descend into a node when the callback returns `false`.\n    */\n    descendants(f) {\n        this.nodesBetween(0, this.content.size, f);\n    }\n    /**\n    Concatenates all the text nodes found in this fragment and its\n    children.\n    */\n    get textContent() {\n        return (this.isLeaf && this.type.spec.leafText)\n            ? this.type.spec.leafText(this)\n            : this.textBetween(0, this.content.size, \"\");\n    }\n    /**\n    Get all text between positions `from` and `to`. When\n    `blockSeparator` is given, it will be inserted to separate text\n    from different block nodes. If `leafText` is given, it'll be\n    inserted for every non-text leaf node encountered, otherwise\n    [`leafText`](https://prosemirror.net/docs/ref/#model.NodeSpec.leafText) will be used.\n    */\n    textBetween(from, to, blockSeparator, leafText) {\n        return this.content.textBetween(from, to, blockSeparator, leafText);\n    }\n    /**\n    Returns this node's first child, or `null` if there are no\n    children.\n    */\n    get firstChild() { return this.content.firstChild; }\n    /**\n    Returns this node's last child, or `null` if there are no\n    children.\n    */\n    get lastChild() { return this.content.lastChild; }\n    /**\n    Test whether two nodes represent the same piece of document.\n    */\n    eq(other) {\n        return this == other || (this.sameMarkup(other) && this.content.eq(other.content));\n    }\n    /**\n    Compare the markup (type, attributes, and marks) of this node to\n    those of another. Returns `true` if both have the same markup.\n    */\n    sameMarkup(other) {\n        return this.hasMarkup(other.type, other.attrs, other.marks);\n    }\n    /**\n    Check whether this node's markup correspond to the given type,\n    attributes, and marks.\n    */\n    hasMarkup(type, attrs, marks) {\n        return this.type == type &&\n            compareDeep(this.attrs, attrs || type.defaultAttrs || emptyAttrs) &&\n            Mark.sameSet(this.marks, marks || Mark.none);\n    }\n    /**\n    Create a new node with the same markup as this node, containing\n    the given content (or empty, if no content is given).\n    */\n    copy(content = null) {\n        if (content == this.content)\n            return this;\n        return new Node(this.type, this.attrs, content, this.marks);\n    }\n    /**\n    Create a copy of this node, with the given set of marks instead\n    of the node's own marks.\n    */\n    mark(marks) {\n        return marks == this.marks ? this : new Node(this.type, this.attrs, this.content, marks);\n    }\n    /**\n    Create a copy of this node with only the content between the\n    given positions. If `to` is not given, it defaults to the end of\n    the node.\n    */\n    cut(from, to = this.content.size) {\n        if (from == 0 && to == this.content.size)\n            return this;\n        return this.copy(this.content.cut(from, to));\n    }\n    /**\n    Cut out the part of the document between the given positions, and\n    return it as a `Slice` object.\n    */\n    slice(from, to = this.content.size, includeParents = false) {\n        if (from == to)\n            return Slice.empty;\n        let $from = this.resolve(from), $to = this.resolve(to);\n        let depth = includeParents ? 0 : $from.sharedDepth(to);\n        let start = $from.start(depth), node = $from.node(depth);\n        let content = node.content.cut($from.pos - start, $to.pos - start);\n        return new Slice(content, $from.depth - depth, $to.depth - depth);\n    }\n    /**\n    Replace the part of the document between the given positions with\n    the given slice. The slice must 'fit', meaning its open sides\n    must be able to connect to the surrounding content, and its\n    content nodes must be valid children for the node they are placed\n    into. If any of this is violated, an error of type\n    [`ReplaceError`](https://prosemirror.net/docs/ref/#model.ReplaceError) is thrown.\n    */\n    replace(from, to, slice) {\n        return replace(this.resolve(from), this.resolve(to), slice);\n    }\n    /**\n    Find the node directly after the given position.\n    */\n    nodeAt(pos) {\n        for (let node = this;;) {\n            let { index, offset } = node.content.findIndex(pos);\n            node = node.maybeChild(index);\n            if (!node)\n                return null;\n            if (offset == pos || node.isText)\n                return node;\n            pos -= offset + 1;\n        }\n    }\n    /**\n    Find the (direct) child node after the given offset, if any,\n    and return it along with its index and offset relative to this\n    node.\n    */\n    childAfter(pos) {\n        let { index, offset } = this.content.findIndex(pos);\n        return { node: this.content.maybeChild(index), index, offset };\n    }\n    /**\n    Find the (direct) child node before the given offset, if any,\n    and return it along with its index and offset relative to this\n    node.\n    */\n    childBefore(pos) {\n        if (pos == 0)\n            return { node: null, index: 0, offset: 0 };\n        let { index, offset } = this.content.findIndex(pos);\n        if (offset < pos)\n            return { node: this.content.child(index), index, offset };\n        let node = this.content.child(index - 1);\n        return { node, index: index - 1, offset: offset - node.nodeSize };\n    }\n    /**\n    Resolve the given position in the document, returning an\n    [object](https://prosemirror.net/docs/ref/#model.ResolvedPos) with information about its context.\n    */\n    resolve(pos) { return ResolvedPos.resolveCached(this, pos); }\n    /**\n    @internal\n    */\n    resolveNoCache(pos) { return ResolvedPos.resolve(this, pos); }\n    /**\n    Test whether a given mark or mark type occurs in this document\n    between the two given positions.\n    */\n    rangeHasMark(from, to, type) {\n        let found = false;\n        if (to > from)\n            this.nodesBetween(from, to, node => {\n                if (type.isInSet(node.marks))\n                    found = true;\n                return !found;\n            });\n        return found;\n    }\n    /**\n    True when this is a block (non-inline node)\n    */\n    get isBlock() { return this.type.isBlock; }\n    /**\n    True when this is a textblock node, a block node with inline\n    content.\n    */\n    get isTextblock() { return this.type.isTextblock; }\n    /**\n    True when this node allows inline content.\n    */\n    get inlineContent() { return this.type.inlineContent; }\n    /**\n    True when this is an inline node (a text node or a node that can\n    appear among text).\n    */\n    get isInline() { return this.type.isInline; }\n    /**\n    True when this is a text node.\n    */\n    get isText() { return this.type.isText; }\n    /**\n    True when this is a leaf node.\n    */\n    get isLeaf() { return this.type.isLeaf; }\n    /**\n    True when this is an atom, i.e. when it does not have directly\n    editable content. This is usually the same as `isLeaf`, but can\n    be configured with the [`atom` property](https://prosemirror.net/docs/ref/#model.NodeSpec.atom)\n    on a node's spec (typically used when the node is displayed as\n    an uneditable [node view](https://prosemirror.net/docs/ref/#view.NodeView)).\n    */\n    get isAtom() { return this.type.isAtom; }\n    /**\n    Return a string representation of this node for debugging\n    purposes.\n    */\n    toString() {\n        if (this.type.spec.toDebugString)\n            return this.type.spec.toDebugString(this);\n        let name = this.type.name;\n        if (this.content.size)\n            name += \"(\" + this.content.toStringInner() + \")\";\n        return wrapMarks(this.marks, name);\n    }\n    /**\n    Get the content match in this node at the given index.\n    */\n    contentMatchAt(index) {\n        let match = this.type.contentMatch.matchFragment(this.content, 0, index);\n        if (!match)\n            throw new Error(\"Called contentMatchAt on a node with invalid content\");\n        return match;\n    }\n    /**\n    Test whether replacing the range between `from` and `to` (by\n    child index) with the given replacement fragment (which defaults\n    to the empty fragment) would leave the node's content valid. You\n    can optionally pass `start` and `end` indices into the\n    replacement fragment.\n    */\n    canReplace(from, to, replacement = Fragment.empty, start = 0, end = replacement.childCount) {\n        let one = this.contentMatchAt(from).matchFragment(replacement, start, end);\n        let two = one && one.matchFragment(this.content, to);\n        if (!two || !two.validEnd)\n            return false;\n        for (let i = start; i < end; i++)\n            if (!this.type.allowsMarks(replacement.child(i).marks))\n                return false;\n        return true;\n    }\n    /**\n    Test whether replacing the range `from` to `to` (by index) with\n    a node of the given type would leave the node's content valid.\n    */\n    canReplaceWith(from, to, type, marks) {\n        if (marks && !this.type.allowsMarks(marks))\n            return false;\n        let start = this.contentMatchAt(from).matchType(type);\n        let end = start && start.matchFragment(this.content, to);\n        return end ? end.validEnd : false;\n    }\n    /**\n    Test whether the given node's content could be appended to this\n    node. If that node is empty, this will only return true if there\n    is at least one node type that can appear in both nodes (to avoid\n    merging completely incompatible nodes).\n    */\n    canAppend(other) {\n        if (other.content.size)\n            return this.canReplace(this.childCount, this.childCount, other.content);\n        else\n            return this.type.compatibleContent(other.type);\n    }\n    /**\n    Check whether this node and its descendants conform to the\n    schema, and raise an exception when they do not.\n    */\n    check() {\n        this.type.checkContent(this.content);\n        this.type.checkAttrs(this.attrs);\n        let copy = Mark.none;\n        for (let i = 0; i < this.marks.length; i++) {\n            let mark = this.marks[i];\n            mark.type.checkAttrs(mark.attrs);\n            copy = mark.addToSet(copy);\n        }\n        if (!Mark.sameSet(copy, this.marks))\n            throw new RangeError(`Invalid collection of marks for node ${this.type.name}: ${this.marks.map(m => m.type.name)}`);\n        this.content.forEach(node => node.check());\n    }\n    /**\n    Return a JSON-serializeable representation of this node.\n    */\n    toJSON() {\n        let obj = { type: this.type.name };\n        for (let _ in this.attrs) {\n            obj.attrs = this.attrs;\n            break;\n        }\n        if (this.content.size)\n            obj.content = this.content.toJSON();\n        if (this.marks.length)\n            obj.marks = this.marks.map(n => n.toJSON());\n        return obj;\n    }\n    /**\n    Deserialize a node from its JSON representation.\n    */\n    static fromJSON(schema, json) {\n        if (!json)\n            throw new RangeError(\"Invalid input for Node.fromJSON\");\n        let marks = undefined;\n        if (json.marks) {\n            if (!Array.isArray(json.marks))\n                throw new RangeError(\"Invalid mark data for Node.fromJSON\");\n            marks = json.marks.map(schema.markFromJSON);\n        }\n        if (json.type == \"text\") {\n            if (typeof json.text != \"string\")\n                throw new RangeError(\"Invalid text node in JSON\");\n            return schema.text(json.text, marks);\n        }\n        let content = Fragment.fromJSON(schema, json.content);\n        let node = schema.nodeType(json.type).create(json.attrs, content, marks);\n        node.type.checkAttrs(node.attrs);\n        return node;\n    }\n}\nNode.prototype.text = undefined;\nclass TextNode extends Node {\n    /**\n    @internal\n    */\n    constructor(type, attrs, content, marks) {\n        super(type, attrs, null, marks);\n        if (!content)\n            throw new RangeError(\"Empty text nodes are not allowed\");\n        this.text = content;\n    }\n    toString() {\n        if (this.type.spec.toDebugString)\n            return this.type.spec.toDebugString(this);\n        return wrapMarks(this.marks, JSON.stringify(this.text));\n    }\n    get textContent() { return this.text; }\n    textBetween(from, to) { return this.text.slice(from, to); }\n    get nodeSize() { return this.text.length; }\n    mark(marks) {\n        return marks == this.marks ? this : new TextNode(this.type, this.attrs, this.text, marks);\n    }\n    withText(text) {\n        if (text == this.text)\n            return this;\n        return new TextNode(this.type, this.attrs, text, this.marks);\n    }\n    cut(from = 0, to = this.text.length) {\n        if (from == 0 && to == this.text.length)\n            return this;\n        return this.withText(this.text.slice(from, to));\n    }\n    eq(other) {\n        return this.sameMarkup(other) && this.text == other.text;\n    }\n    toJSON() {\n        let base = super.toJSON();\n        base.text = this.text;\n        return base;\n    }\n}\nfunction wrapMarks(marks, str) {\n    for (let i = marks.length - 1; i >= 0; i--)\n        str = marks[i].type.name + \"(\" + str + \")\";\n    return str;\n}\n\n/**\nInstances of this class represent a match state of a node type's\n[content expression](https://prosemirror.net/docs/ref/#model.NodeSpec.content), and can be used to\nfind out whether further content matches here, and whether a given\nposition is a valid end of the node.\n*/\nclass ContentMatch {\n    /**\n    @internal\n    */\n    constructor(\n    /**\n    True when this match state represents a valid end of the node.\n    */\n    validEnd) {\n        this.validEnd = validEnd;\n        /**\n        @internal\n        */\n        this.next = [];\n        /**\n        @internal\n        */\n        this.wrapCache = [];\n    }\n    /**\n    @internal\n    */\n    static parse(string, nodeTypes) {\n        let stream = new TokenStream(string, nodeTypes);\n        if (stream.next == null)\n            return ContentMatch.empty;\n        let expr = parseExpr(stream);\n        if (stream.next)\n            stream.err(\"Unexpected trailing text\");\n        let match = dfa(nfa(expr));\n        checkForDeadEnds(match, stream);\n        return match;\n    }\n    /**\n    Match a node type, returning a match after that node if\n    successful.\n    */\n    matchType(type) {\n        for (let i = 0; i < this.next.length; i++)\n            if (this.next[i].type == type)\n                return this.next[i].next;\n        return null;\n    }\n    /**\n    Try to match a fragment. Returns the resulting match when\n    successful.\n    */\n    matchFragment(frag, start = 0, end = frag.childCount) {\n        let cur = this;\n        for (let i = start; cur && i < end; i++)\n            cur = cur.matchType(frag.child(i).type);\n        return cur;\n    }\n    /**\n    @internal\n    */\n    get inlineContent() {\n        return this.next.length != 0 && this.next[0].type.isInline;\n    }\n    /**\n    Get the first matching node type at this match position that can\n    be generated.\n    */\n    get defaultType() {\n        for (let i = 0; i < this.next.length; i++) {\n            let { type } = this.next[i];\n            if (!(type.isText || type.hasRequiredAttrs()))\n                return type;\n        }\n        return null;\n    }\n    /**\n    @internal\n    */\n    compatible(other) {\n        for (let i = 0; i < this.next.length; i++)\n            for (let j = 0; j < other.next.length; j++)\n                if (this.next[i].type == other.next[j].type)\n                    return true;\n        return false;\n    }\n    /**\n    Try to match the given fragment, and if that fails, see if it can\n    be made to match by inserting nodes in front of it. When\n    successful, return a fragment of inserted nodes (which may be\n    empty if nothing had to be inserted). When `toEnd` is true, only\n    return a fragment if the resulting match goes to the end of the\n    content expression.\n    */\n    fillBefore(after, toEnd = false, startIndex = 0) {\n        let seen = [this];\n        function search(match, types) {\n            let finished = match.matchFragment(after, startIndex);\n            if (finished && (!toEnd || finished.validEnd))\n                return Fragment.from(types.map(tp => tp.createAndFill()));\n            for (let i = 0; i < match.next.length; i++) {\n                let { type, next } = match.next[i];\n                if (!(type.isText || type.hasRequiredAttrs()) && seen.indexOf(next) == -1) {\n                    seen.push(next);\n                    let found = search(next, types.concat(type));\n                    if (found)\n                        return found;\n                }\n            }\n            return null;\n        }\n        return search(this, []);\n    }\n    /**\n    Find a set of wrapping node types that would allow a node of the\n    given type to appear at this position. The result may be empty\n    (when it fits directly) and will be null when no such wrapping\n    exists.\n    */\n    findWrapping(target) {\n        for (let i = 0; i < this.wrapCache.length; i += 2)\n            if (this.wrapCache[i] == target)\n                return this.wrapCache[i + 1];\n        let computed = this.computeWrapping(target);\n        this.wrapCache.push(target, computed);\n        return computed;\n    }\n    /**\n    @internal\n    */\n    computeWrapping(target) {\n        let seen = Object.create(null), active = [{ match: this, type: null, via: null }];\n        while (active.length) {\n            let current = active.shift(), match = current.match;\n            if (match.matchType(target)) {\n                let result = [];\n                for (let obj = current; obj.type; obj = obj.via)\n                    result.push(obj.type);\n                return result.reverse();\n            }\n            for (let i = 0; i < match.next.length; i++) {\n                let { type, next } = match.next[i];\n                if (!type.isLeaf && !type.hasRequiredAttrs() && !(type.name in seen) && (!current.type || next.validEnd)) {\n                    active.push({ match: type.contentMatch, type, via: current });\n                    seen[type.name] = true;\n                }\n            }\n        }\n        return null;\n    }\n    /**\n    The number of outgoing edges this node has in the finite\n    automaton that describes the content expression.\n    */\n    get edgeCount() {\n        return this.next.length;\n    }\n    /**\n    Get the _n_​th outgoing edge from this node in the finite\n    automaton that describes the content expression.\n    */\n    edge(n) {\n        if (n >= this.next.length)\n            throw new RangeError(`There's no ${n}th edge in this content match`);\n        return this.next[n];\n    }\n    /**\n    @internal\n    */\n    toString() {\n        let seen = [];\n        function scan(m) {\n            seen.push(m);\n            for (let i = 0; i < m.next.length; i++)\n                if (seen.indexOf(m.next[i].next) == -1)\n                    scan(m.next[i].next);\n        }\n        scan(this);\n        return seen.map((m, i) => {\n            let out = i + (m.validEnd ? \"*\" : \" \") + \" \";\n            for (let i = 0; i < m.next.length; i++)\n                out += (i ? \", \" : \"\") + m.next[i].type.name + \"->\" + seen.indexOf(m.next[i].next);\n            return out;\n        }).join(\"\\n\");\n    }\n}\n/**\n@internal\n*/\nContentMatch.empty = new ContentMatch(true);\nclass TokenStream {\n    constructor(string, nodeTypes) {\n        this.string = string;\n        this.nodeTypes = nodeTypes;\n        this.inline = null;\n        this.pos = 0;\n        this.tokens = string.split(/\\s*(?=\\b|\\W|$)/);\n        if (this.tokens[this.tokens.length - 1] == \"\")\n            this.tokens.pop();\n        if (this.tokens[0] == \"\")\n            this.tokens.shift();\n    }\n    get next() { return this.tokens[this.pos]; }\n    eat(tok) { return this.next == tok && (this.pos++ || true); }\n    err(str) { throw new SyntaxError(str + \" (in content expression '\" + this.string + \"')\"); }\n}\nfunction parseExpr(stream) {\n    let exprs = [];\n    do {\n        exprs.push(parseExprSeq(stream));\n    } while (stream.eat(\"|\"));\n    return exprs.length == 1 ? exprs[0] : { type: \"choice\", exprs };\n}\nfunction parseExprSeq(stream) {\n    let exprs = [];\n    do {\n        exprs.push(parseExprSubscript(stream));\n    } while (stream.next && stream.next != \")\" && stream.next != \"|\");\n    return exprs.length == 1 ? exprs[0] : { type: \"seq\", exprs };\n}\nfunction parseExprSubscript(stream) {\n    let expr = parseExprAtom(stream);\n    for (;;) {\n        if (stream.eat(\"+\"))\n            expr = { type: \"plus\", expr };\n        else if (stream.eat(\"*\"))\n            expr = { type: \"star\", expr };\n        else if (stream.eat(\"?\"))\n            expr = { type: \"opt\", expr };\n        else if (stream.eat(\"{\"))\n            expr = parseExprRange(stream, expr);\n        else\n            break;\n    }\n    return expr;\n}\nfunction parseNum(stream) {\n    if (/\\D/.test(stream.next))\n        stream.err(\"Expected number, got '\" + stream.next + \"'\");\n    let result = Number(stream.next);\n    stream.pos++;\n    return result;\n}\nfunction parseExprRange(stream, expr) {\n    let min = parseNum(stream), max = min;\n    if (stream.eat(\",\")) {\n        if (stream.next != \"}\")\n            max = parseNum(stream);\n        else\n            max = -1;\n    }\n    if (!stream.eat(\"}\"))\n        stream.err(\"Unclosed braced range\");\n    return { type: \"range\", min, max, expr };\n}\nfunction resolveName(stream, name) {\n    let types = stream.nodeTypes, type = types[name];\n    if (type)\n        return [type];\n    let result = [];\n    for (let typeName in types) {\n        let type = types[typeName];\n        if (type.isInGroup(name))\n            result.push(type);\n    }\n    if (result.length == 0)\n        stream.err(\"No node type or group '\" + name + \"' found\");\n    return result;\n}\nfunction parseExprAtom(stream) {\n    if (stream.eat(\"(\")) {\n        let expr = parseExpr(stream);\n        if (!stream.eat(\")\"))\n            stream.err(\"Missing closing paren\");\n        return expr;\n    }\n    else if (!/\\W/.test(stream.next)) {\n        let exprs = resolveName(stream, stream.next).map(type => {\n            if (stream.inline == null)\n                stream.inline = type.isInline;\n            else if (stream.inline != type.isInline)\n                stream.err(\"Mixing inline and block content\");\n            return { type: \"name\", value: type };\n        });\n        stream.pos++;\n        return exprs.length == 1 ? exprs[0] : { type: \"choice\", exprs };\n    }\n    else {\n        stream.err(\"Unexpected token '\" + stream.next + \"'\");\n    }\n}\n// Construct an NFA from an expression as returned by the parser. The\n// NFA is represented as an array of states, which are themselves\n// arrays of edges, which are `{term, to}` objects. The first state is\n// the entry state and the last node is the success state.\n//\n// Note that unlike typical NFAs, the edge ordering in this one is\n// significant, in that it is used to contruct filler content when\n// necessary.\nfunction nfa(expr) {\n    let nfa = [[]];\n    connect(compile(expr, 0), node());\n    return nfa;\n    function node() { return nfa.push([]) - 1; }\n    function edge(from, to, term) {\n        let edge = { term, to };\n        nfa[from].push(edge);\n        return edge;\n    }\n    function connect(edges, to) {\n        edges.forEach(edge => edge.to = to);\n    }\n    function compile(expr, from) {\n        if (expr.type == \"choice\") {\n            return expr.exprs.reduce((out, expr) => out.concat(compile(expr, from)), []);\n        }\n        else if (expr.type == \"seq\") {\n            for (let i = 0;; i++) {\n                let next = compile(expr.exprs[i], from);\n                if (i == expr.exprs.length - 1)\n                    return next;\n                connect(next, from = node());\n            }\n        }\n        else if (expr.type == \"star\") {\n            let loop = node();\n            edge(from, loop);\n            connect(compile(expr.expr, loop), loop);\n            return [edge(loop)];\n        }\n        else if (expr.type == \"plus\") {\n            let loop = node();\n            connect(compile(expr.expr, from), loop);\n            connect(compile(expr.expr, loop), loop);\n            return [edge(loop)];\n        }\n        else if (expr.type == \"opt\") {\n            return [edge(from)].concat(compile(expr.expr, from));\n        }\n        else if (expr.type == \"range\") {\n            let cur = from;\n            for (let i = 0; i < expr.min; i++) {\n                let next = node();\n                connect(compile(expr.expr, cur), next);\n                cur = next;\n            }\n            if (expr.max == -1) {\n                connect(compile(expr.expr, cur), cur);\n            }\n            else {\n                for (let i = expr.min; i < expr.max; i++) {\n                    let next = node();\n                    edge(cur, next);\n                    connect(compile(expr.expr, cur), next);\n                    cur = next;\n                }\n            }\n            return [edge(cur)];\n        }\n        else if (expr.type == \"name\") {\n            return [edge(from, undefined, expr.value)];\n        }\n        else {\n            throw new Error(\"Unknown expr type\");\n        }\n    }\n}\nfunction cmp(a, b) { return b - a; }\n// Get the set of nodes reachable by null edges from `node`. Omit\n// nodes with only a single null-out-edge, since they may lead to\n// needless duplicated nodes.\nfunction nullFrom(nfa, node) {\n    let result = [];\n    scan(node);\n    return result.sort(cmp);\n    function scan(node) {\n        let edges = nfa[node];\n        if (edges.length == 1 && !edges[0].term)\n            return scan(edges[0].to);\n        result.push(node);\n        for (let i = 0; i < edges.length; i++) {\n            let { term, to } = edges[i];\n            if (!term && result.indexOf(to) == -1)\n                scan(to);\n        }\n    }\n}\n// Compiles an NFA as produced by `nfa` into a DFA, modeled as a set\n// of state objects (`ContentMatch` instances) with transitions\n// between them.\nfunction dfa(nfa) {\n    let labeled = Object.create(null);\n    return explore(nullFrom(nfa, 0));\n    function explore(states) {\n        let out = [];\n        states.forEach(node => {\n            nfa[node].forEach(({ term, to }) => {\n                if (!term)\n                    return;\n                let set;\n                for (let i = 0; i < out.length; i++)\n                    if (out[i][0] == term)\n                        set = out[i][1];\n                nullFrom(nfa, to).forEach(node => {\n                    if (!set)\n                        out.push([term, set = []]);\n                    if (set.indexOf(node) == -1)\n                        set.push(node);\n                });\n            });\n        });\n        let state = labeled[states.join(\",\")] = new ContentMatch(states.indexOf(nfa.length - 1) > -1);\n        for (let i = 0; i < out.length; i++) {\n            let states = out[i][1].sort(cmp);\n            state.next.push({ type: out[i][0], next: labeled[states.join(\",\")] || explore(states) });\n        }\n        return state;\n    }\n}\nfunction checkForDeadEnds(match, stream) {\n    for (let i = 0, work = [match]; i < work.length; i++) {\n        let state = work[i], dead = !state.validEnd, nodes = [];\n        for (let j = 0; j < state.next.length; j++) {\n            let { type, next } = state.next[j];\n            nodes.push(type.name);\n            if (dead && !(type.isText || type.hasRequiredAttrs()))\n                dead = false;\n            if (work.indexOf(next) == -1)\n                work.push(next);\n        }\n        if (dead)\n            stream.err(\"Only non-generatable nodes (\" + nodes.join(\", \") + \") in a required position (see https://prosemirror.net/docs/guide/#generatable)\");\n    }\n}\n\n// For node types where all attrs have a default value (or which don't\n// have any attributes), build up a single reusable default attribute\n// object, and use it for all nodes that don't specify specific\n// attributes.\nfunction defaultAttrs(attrs) {\n    let defaults = Object.create(null);\n    for (let attrName in attrs) {\n        let attr = attrs[attrName];\n        if (!attr.hasDefault)\n            return null;\n        defaults[attrName] = attr.default;\n    }\n    return defaults;\n}\nfunction computeAttrs(attrs, value) {\n    let built = Object.create(null);\n    for (let name in attrs) {\n        let given = value && value[name];\n        if (given === undefined) {\n            let attr = attrs[name];\n            if (attr.hasDefault)\n                given = attr.default;\n            else\n                throw new RangeError(\"No value supplied for attribute \" + name);\n        }\n        built[name] = given;\n    }\n    return built;\n}\nfunction checkAttrs(attrs, values, type, name) {\n    for (let name in values)\n        if (!(name in attrs))\n            throw new RangeError(`Unsupported attribute ${name} for ${type} of type ${name}`);\n    for (let name in attrs) {\n        let attr = attrs[name];\n        if (attr.validate)\n            attr.validate(values[name]);\n    }\n}\nfunction initAttrs(typeName, attrs) {\n    let result = Object.create(null);\n    if (attrs)\n        for (let name in attrs)\n            result[name] = new Attribute(typeName, name, attrs[name]);\n    return result;\n}\n/**\nNode types are objects allocated once per `Schema` and used to\n[tag](https://prosemirror.net/docs/ref/#model.Node.type) `Node` instances. They contain information\nabout the node type, such as its name and what kind of node it\nrepresents.\n*/\nclass NodeType {\n    /**\n    @internal\n    */\n    constructor(\n    /**\n    The name the node type has in this schema.\n    */\n    name, \n    /**\n    A link back to the `Schema` the node type belongs to.\n    */\n    schema, \n    /**\n    The spec that this type is based on\n    */\n    spec) {\n        this.name = name;\n        this.schema = schema;\n        this.spec = spec;\n        /**\n        The set of marks allowed in this node. `null` means all marks\n        are allowed.\n        */\n        this.markSet = null;\n        this.groups = spec.group ? spec.group.split(\" \") : [];\n        this.attrs = initAttrs(name, spec.attrs);\n        this.defaultAttrs = defaultAttrs(this.attrs);\n        this.contentMatch = null;\n        this.inlineContent = null;\n        this.isBlock = !(spec.inline || name == \"text\");\n        this.isText = name == \"text\";\n    }\n    /**\n    True if this is an inline type.\n    */\n    get isInline() { return !this.isBlock; }\n    /**\n    True if this is a textblock type, a block that contains inline\n    content.\n    */\n    get isTextblock() { return this.isBlock && this.inlineContent; }\n    /**\n    True for node types that allow no content.\n    */\n    get isLeaf() { return this.contentMatch == ContentMatch.empty; }\n    /**\n    True when this node is an atom, i.e. when it does not have\n    directly editable content.\n    */\n    get isAtom() { return this.isLeaf || !!this.spec.atom; }\n    /**\n    Return true when this node type is part of the given\n    [group](https://prosemirror.net/docs/ref/#model.NodeSpec.group).\n    */\n    isInGroup(group) {\n        return this.groups.indexOf(group) > -1;\n    }\n    /**\n    The node type's [whitespace](https://prosemirror.net/docs/ref/#model.NodeSpec.whitespace) option.\n    */\n    get whitespace() {\n        return this.spec.whitespace || (this.spec.code ? \"pre\" : \"normal\");\n    }\n    /**\n    Tells you whether this node type has any required attributes.\n    */\n    hasRequiredAttrs() {\n        for (let n in this.attrs)\n            if (this.attrs[n].isRequired)\n                return true;\n        return false;\n    }\n    /**\n    Indicates whether this node allows some of the same content as\n    the given node type.\n    */\n    compatibleContent(other) {\n        return this == other || this.contentMatch.compatible(other.contentMatch);\n    }\n    /**\n    @internal\n    */\n    computeAttrs(attrs) {\n        if (!attrs && this.defaultAttrs)\n            return this.defaultAttrs;\n        else\n            return computeAttrs(this.attrs, attrs);\n    }\n    /**\n    Create a `Node` of this type. The given attributes are\n    checked and defaulted (you can pass `null` to use the type's\n    defaults entirely, if no required attributes exist). `content`\n    may be a `Fragment`, a node, an array of nodes, or\n    `null`. Similarly `marks` may be `null` to default to the empty\n    set of marks.\n    */\n    create(attrs = null, content, marks) {\n        if (this.isText)\n            throw new Error(\"NodeType.create can't construct text nodes\");\n        return new Node(this, this.computeAttrs(attrs), Fragment.from(content), Mark.setFrom(marks));\n    }\n    /**\n    Like [`create`](https://prosemirror.net/docs/ref/#model.NodeType.create), but check the given content\n    against the node type's content restrictions, and throw an error\n    if it doesn't match.\n    */\n    createChecked(attrs = null, content, marks) {\n        content = Fragment.from(content);\n        this.checkContent(content);\n        return new Node(this, this.computeAttrs(attrs), content, Mark.setFrom(marks));\n    }\n    /**\n    Like [`create`](https://prosemirror.net/docs/ref/#model.NodeType.create), but see if it is\n    necessary to add nodes to the start or end of the given fragment\n    to make it fit the node. If no fitting wrapping can be found,\n    return null. Note that, due to the fact that required nodes can\n    always be created, this will always succeed if you pass null or\n    `Fragment.empty` as content.\n    */\n    createAndFill(attrs = null, content, marks) {\n        attrs = this.computeAttrs(attrs);\n        content = Fragment.from(content);\n        if (content.size) {\n            let before = this.contentMatch.fillBefore(content);\n            if (!before)\n                return null;\n            content = before.append(content);\n        }\n        let matched = this.contentMatch.matchFragment(content);\n        let after = matched && matched.fillBefore(Fragment.empty, true);\n        if (!after)\n            return null;\n        return new Node(this, attrs, content.append(after), Mark.setFrom(marks));\n    }\n    /**\n    Returns true if the given fragment is valid content for this node\n    type.\n    */\n    validContent(content) {\n        let result = this.contentMatch.matchFragment(content);\n        if (!result || !result.validEnd)\n            return false;\n        for (let i = 0; i < content.childCount; i++)\n            if (!this.allowsMarks(content.child(i).marks))\n                return false;\n        return true;\n    }\n    /**\n    Throws a RangeError if the given fragment is not valid content for this\n    node type.\n    @internal\n    */\n    checkContent(content) {\n        if (!this.validContent(content))\n            throw new RangeError(`Invalid content for node ${this.name}: ${content.toString().slice(0, 50)}`);\n    }\n    /**\n    @internal\n    */\n    checkAttrs(attrs) {\n        checkAttrs(this.attrs, attrs, \"node\", this.name);\n    }\n    /**\n    Check whether the given mark type is allowed in this node.\n    */\n    allowsMarkType(markType) {\n        return this.markSet == null || this.markSet.indexOf(markType) > -1;\n    }\n    /**\n    Test whether the given set of marks are allowed in this node.\n    */\n    allowsMarks(marks) {\n        if (this.markSet == null)\n            return true;\n        for (let i = 0; i < marks.length; i++)\n            if (!this.allowsMarkType(marks[i].type))\n                return false;\n        return true;\n    }\n    /**\n    Removes the marks that are not allowed in this node from the given set.\n    */\n    allowedMarks(marks) {\n        if (this.markSet == null)\n            return marks;\n        let copy;\n        for (let i = 0; i < marks.length; i++) {\n            if (!this.allowsMarkType(marks[i].type)) {\n                if (!copy)\n                    copy = marks.slice(0, i);\n            }\n            else if (copy) {\n                copy.push(marks[i]);\n            }\n        }\n        return !copy ? marks : copy.length ? copy : Mark.none;\n    }\n    /**\n    @internal\n    */\n    static compile(nodes, schema) {\n        let result = Object.create(null);\n        nodes.forEach((name, spec) => result[name] = new NodeType(name, schema, spec));\n        let topType = schema.spec.topNode || \"doc\";\n        if (!result[topType])\n            throw new RangeError(\"Schema is missing its top node type ('\" + topType + \"')\");\n        if (!result.text)\n            throw new RangeError(\"Every schema needs a 'text' type\");\n        for (let _ in result.text.attrs)\n            throw new RangeError(\"The text node type should not have attributes\");\n        return result;\n    }\n}\nfunction validateType(typeName, attrName, type) {\n    let types = type.split(\"|\");\n    return (value) => {\n        let name = value === null ? \"null\" : typeof value;\n        if (types.indexOf(name) < 0)\n            throw new RangeError(`Expected value of type ${types} for attribute ${attrName} on type ${typeName}, got ${name}`);\n    };\n}\n// Attribute descriptors\nclass Attribute {\n    constructor(typeName, attrName, options) {\n        this.hasDefault = Object.prototype.hasOwnProperty.call(options, \"default\");\n        this.default = options.default;\n        this.validate = typeof options.validate == \"string\" ? validateType(typeName, attrName, options.validate) : options.validate;\n    }\n    get isRequired() {\n        return !this.hasDefault;\n    }\n}\n// Marks\n/**\nLike nodes, marks (which are associated with nodes to signify\nthings like emphasis or being part of a link) are\n[tagged](https://prosemirror.net/docs/ref/#model.Mark.type) with type objects, which are\ninstantiated once per `Schema`.\n*/\nclass MarkType {\n    /**\n    @internal\n    */\n    constructor(\n    /**\n    The name of the mark type.\n    */\n    name, \n    /**\n    @internal\n    */\n    rank, \n    /**\n    The schema that this mark type instance is part of.\n    */\n    schema, \n    /**\n    The spec on which the type is based.\n    */\n    spec) {\n        this.name = name;\n        this.rank = rank;\n        this.schema = schema;\n        this.spec = spec;\n        this.attrs = initAttrs(name, spec.attrs);\n        this.excluded = null;\n        let defaults = defaultAttrs(this.attrs);\n        this.instance = defaults ? new Mark(this, defaults) : null;\n    }\n    /**\n    Create a mark of this type. `attrs` may be `null` or an object\n    containing only some of the mark's attributes. The others, if\n    they have defaults, will be added.\n    */\n    create(attrs = null) {\n        if (!attrs && this.instance)\n            return this.instance;\n        return new Mark(this, computeAttrs(this.attrs, attrs));\n    }\n    /**\n    @internal\n    */\n    static compile(marks, schema) {\n        let result = Object.create(null), rank = 0;\n        marks.forEach((name, spec) => result[name] = new MarkType(name, rank++, schema, spec));\n        return result;\n    }\n    /**\n    When there is a mark of this type in the given set, a new set\n    without it is returned. Otherwise, the input set is returned.\n    */\n    removeFromSet(set) {\n        for (var i = 0; i < set.length; i++)\n            if (set[i].type == this) {\n                set = set.slice(0, i).concat(set.slice(i + 1));\n                i--;\n            }\n        return set;\n    }\n    /**\n    Tests whether there is a mark of this type in the given set.\n    */\n    isInSet(set) {\n        for (let i = 0; i < set.length; i++)\n            if (set[i].type == this)\n                return set[i];\n    }\n    /**\n    @internal\n    */\n    checkAttrs(attrs) {\n        checkAttrs(this.attrs, attrs, \"mark\", this.name);\n    }\n    /**\n    Queries whether a given mark type is\n    [excluded](https://prosemirror.net/docs/ref/#model.MarkSpec.excludes) by this one.\n    */\n    excludes(other) {\n        return this.excluded.indexOf(other) > -1;\n    }\n}\n/**\nA document schema. Holds [node](https://prosemirror.net/docs/ref/#model.NodeType) and [mark\ntype](https://prosemirror.net/docs/ref/#model.MarkType) objects for the nodes and marks that may\noccur in conforming documents, and provides functionality for\ncreating and deserializing such documents.\n\nWhen given, the type parameters provide the names of the nodes and\nmarks in this schema.\n*/\nclass Schema {\n    /**\n    Construct a schema from a schema [specification](https://prosemirror.net/docs/ref/#model.SchemaSpec).\n    */\n    constructor(spec) {\n        /**\n        The [linebreak\n        replacement](https://prosemirror.net/docs/ref/#model.NodeSpec.linebreakReplacement) node defined\n        in this schema, if any.\n        */\n        this.linebreakReplacement = null;\n        /**\n        An object for storing whatever values modules may want to\n        compute and cache per schema. (If you want to store something\n        in it, try to use property names unlikely to clash.)\n        */\n        this.cached = Object.create(null);\n        let instanceSpec = this.spec = {};\n        for (let prop in spec)\n            instanceSpec[prop] = spec[prop];\n        instanceSpec.nodes = OrderedMap.from(spec.nodes),\n            instanceSpec.marks = OrderedMap.from(spec.marks || {}),\n            this.nodes = NodeType.compile(this.spec.nodes, this);\n        this.marks = MarkType.compile(this.spec.marks, this);\n        let contentExprCache = Object.create(null);\n        for (let prop in this.nodes) {\n            if (prop in this.marks)\n                throw new RangeError(prop + \" can not be both a node and a mark\");\n            let type = this.nodes[prop], contentExpr = type.spec.content || \"\", markExpr = type.spec.marks;\n            type.contentMatch = contentExprCache[contentExpr] ||\n                (contentExprCache[contentExpr] = ContentMatch.parse(contentExpr, this.nodes));\n            type.inlineContent = type.contentMatch.inlineContent;\n            if (type.spec.linebreakReplacement) {\n                if (this.linebreakReplacement)\n                    throw new RangeError(\"Multiple linebreak nodes defined\");\n                if (!type.isInline || !type.isLeaf)\n                    throw new RangeError(\"Linebreak replacement nodes must be inline leaf nodes\");\n                this.linebreakReplacement = type;\n            }\n            type.markSet = markExpr == \"_\" ? null :\n                markExpr ? gatherMarks(this, markExpr.split(\" \")) :\n                    markExpr == \"\" || !type.inlineContent ? [] : null;\n        }\n        for (let prop in this.marks) {\n            let type = this.marks[prop], excl = type.spec.excludes;\n            type.excluded = excl == null ? [type] : excl == \"\" ? [] : gatherMarks(this, excl.split(\" \"));\n        }\n        this.nodeFromJSON = json => Node.fromJSON(this, json);\n        this.markFromJSON = json => Mark.fromJSON(this, json);\n        this.topNodeType = this.nodes[this.spec.topNode || \"doc\"];\n        this.cached.wrappings = Object.create(null);\n    }\n    /**\n    Create a node in this schema. The `type` may be a string or a\n    `NodeType` instance. Attributes will be extended with defaults,\n    `content` may be a `Fragment`, `null`, a `Node`, or an array of\n    nodes.\n    */\n    node(type, attrs = null, content, marks) {\n        if (typeof type == \"string\")\n            type = this.nodeType(type);\n        else if (!(type instanceof NodeType))\n            throw new RangeError(\"Invalid node type: \" + type);\n        else if (type.schema != this)\n            throw new RangeError(\"Node type from different schema used (\" + type.name + \")\");\n        return type.createChecked(attrs, content, marks);\n    }\n    /**\n    Create a text node in the schema. Empty text nodes are not\n    allowed.\n    */\n    text(text, marks) {\n        let type = this.nodes.text;\n        return new TextNode(type, type.defaultAttrs, text, Mark.setFrom(marks));\n    }\n    /**\n    Create a mark with the given type and attributes.\n    */\n    mark(type, attrs) {\n        if (typeof type == \"string\")\n            type = this.marks[type];\n        return type.create(attrs);\n    }\n    /**\n    @internal\n    */\n    nodeType(name) {\n        let found = this.nodes[name];\n        if (!found)\n            throw new RangeError(\"Unknown node type: \" + name);\n        return found;\n    }\n}\nfunction gatherMarks(schema, marks) {\n    let found = [];\n    for (let i = 0; i < marks.length; i++) {\n        let name = marks[i], mark = schema.marks[name], ok = mark;\n        if (mark) {\n            found.push(mark);\n        }\n        else {\n            for (let prop in schema.marks) {\n                let mark = schema.marks[prop];\n                if (name == \"_\" || (mark.spec.group && mark.spec.group.split(\" \").indexOf(name) > -1))\n                    found.push(ok = mark);\n            }\n        }\n        if (!ok)\n            throw new SyntaxError(\"Unknown mark type: '\" + marks[i] + \"'\");\n    }\n    return found;\n}\n\nfunction isTagRule(rule) { return rule.tag != null; }\nfunction isStyleRule(rule) { return rule.style != null; }\n/**\nA DOM parser represents a strategy for parsing DOM content into a\nProseMirror document conforming to a given schema. Its behavior is\ndefined by an array of [rules](https://prosemirror.net/docs/ref/#model.ParseRule).\n*/\nclass DOMParser {\n    /**\n    Create a parser that targets the given schema, using the given\n    parsing rules.\n    */\n    constructor(\n    /**\n    The schema into which the parser parses.\n    */\n    schema, \n    /**\n    The set of [parse rules](https://prosemirror.net/docs/ref/#model.ParseRule) that the parser\n    uses, in order of precedence.\n    */\n    rules) {\n        this.schema = schema;\n        this.rules = rules;\n        /**\n        @internal\n        */\n        this.tags = [];\n        /**\n        @internal\n        */\n        this.styles = [];\n        let matchedStyles = this.matchedStyles = [];\n        rules.forEach(rule => {\n            if (isTagRule(rule)) {\n                this.tags.push(rule);\n            }\n            else if (isStyleRule(rule)) {\n                let prop = /[^=]*/.exec(rule.style)[0];\n                if (matchedStyles.indexOf(prop) < 0)\n                    matchedStyles.push(prop);\n                this.styles.push(rule);\n            }\n        });\n        // Only normalize list elements when lists in the schema can't directly contain themselves\n        this.normalizeLists = !this.tags.some(r => {\n            if (!/^(ul|ol)\\b/.test(r.tag) || !r.node)\n                return false;\n            let node = schema.nodes[r.node];\n            return node.contentMatch.matchType(node);\n        });\n    }\n    /**\n    Parse a document from the content of a DOM node.\n    */\n    parse(dom, options = {}) {\n        let context = new ParseContext(this, options, false);\n        context.addAll(dom, Mark.none, options.from, options.to);\n        return context.finish();\n    }\n    /**\n    Parses the content of the given DOM node, like\n    [`parse`](https://prosemirror.net/docs/ref/#model.DOMParser.parse), and takes the same set of\n    options. But unlike that method, which produces a whole node,\n    this one returns a slice that is open at the sides, meaning that\n    the schema constraints aren't applied to the start of nodes to\n    the left of the input and the end of nodes at the end.\n    */\n    parseSlice(dom, options = {}) {\n        let context = new ParseContext(this, options, true);\n        context.addAll(dom, Mark.none, options.from, options.to);\n        return Slice.maxOpen(context.finish());\n    }\n    /**\n    @internal\n    */\n    matchTag(dom, context, after) {\n        for (let i = after ? this.tags.indexOf(after) + 1 : 0; i < this.tags.length; i++) {\n            let rule = this.tags[i];\n            if (matches(dom, rule.tag) &&\n                (rule.namespace === undefined || dom.namespaceURI == rule.namespace) &&\n                (!rule.context || context.matchesContext(rule.context))) {\n                if (rule.getAttrs) {\n                    let result = rule.getAttrs(dom);\n                    if (result === false)\n                        continue;\n                    rule.attrs = result || undefined;\n                }\n                return rule;\n            }\n        }\n    }\n    /**\n    @internal\n    */\n    matchStyle(prop, value, context, after) {\n        for (let i = after ? this.styles.indexOf(after) + 1 : 0; i < this.styles.length; i++) {\n            let rule = this.styles[i], style = rule.style;\n            if (style.indexOf(prop) != 0 ||\n                rule.context && !context.matchesContext(rule.context) ||\n                // Test that the style string either precisely matches the prop,\n                // or has an '=' sign after the prop, followed by the given\n                // value.\n                style.length > prop.length &&\n                    (style.charCodeAt(prop.length) != 61 || style.slice(prop.length + 1) != value))\n                continue;\n            if (rule.getAttrs) {\n                let result = rule.getAttrs(value);\n                if (result === false)\n                    continue;\n                rule.attrs = result || undefined;\n            }\n            return rule;\n        }\n    }\n    /**\n    @internal\n    */\n    static schemaRules(schema) {\n        let result = [];\n        function insert(rule) {\n            let priority = rule.priority == null ? 50 : rule.priority, i = 0;\n            for (; i < result.length; i++) {\n                let next = result[i], nextPriority = next.priority == null ? 50 : next.priority;\n                if (nextPriority < priority)\n                    break;\n            }\n            result.splice(i, 0, rule);\n        }\n        for (let name in schema.marks) {\n            let rules = schema.marks[name].spec.parseDOM;\n            if (rules)\n                rules.forEach(rule => {\n                    insert(rule = copy(rule));\n                    if (!(rule.mark || rule.ignore || rule.clearMark))\n                        rule.mark = name;\n                });\n        }\n        for (let name in schema.nodes) {\n            let rules = schema.nodes[name].spec.parseDOM;\n            if (rules)\n                rules.forEach(rule => {\n                    insert(rule = copy(rule));\n                    if (!(rule.node || rule.ignore || rule.mark))\n                        rule.node = name;\n                });\n        }\n        return result;\n    }\n    /**\n    Construct a DOM parser using the parsing rules listed in a\n    schema's [node specs](https://prosemirror.net/docs/ref/#model.NodeSpec.parseDOM), reordered by\n    [priority](https://prosemirror.net/docs/ref/#model.GenericParseRule.priority).\n    */\n    static fromSchema(schema) {\n        return schema.cached.domParser ||\n            (schema.cached.domParser = new DOMParser(schema, DOMParser.schemaRules(schema)));\n    }\n}\nconst blockTags = {\n    address: true, article: true, aside: true, blockquote: true, canvas: true,\n    dd: true, div: true, dl: true, fieldset: true, figcaption: true, figure: true,\n    footer: true, form: true, h1: true, h2: true, h3: true, h4: true, h5: true,\n    h6: true, header: true, hgroup: true, hr: true, li: true, noscript: true, ol: true,\n    output: true, p: true, pre: true, section: true, table: true, tfoot: true, ul: true\n};\nconst ignoreTags = {\n    head: true, noscript: true, object: true, script: true, style: true, title: true\n};\nconst listTags = { ol: true, ul: true };\n// Using a bitfield for node context options\nconst OPT_PRESERVE_WS = 1, OPT_PRESERVE_WS_FULL = 2, OPT_OPEN_LEFT = 4;\nfunction wsOptionsFor(type, preserveWhitespace, base) {\n    if (preserveWhitespace != null)\n        return (preserveWhitespace ? OPT_PRESERVE_WS : 0) |\n            (preserveWhitespace === \"full\" ? OPT_PRESERVE_WS_FULL : 0);\n    return type && type.whitespace == \"pre\" ? OPT_PRESERVE_WS | OPT_PRESERVE_WS_FULL : base & ~OPT_OPEN_LEFT;\n}\nclass NodeContext {\n    constructor(type, attrs, marks, solid, match, options) {\n        this.type = type;\n        this.attrs = attrs;\n        this.marks = marks;\n        this.solid = solid;\n        this.options = options;\n        this.content = [];\n        // Marks applied to the node's children\n        this.activeMarks = Mark.none;\n        this.match = match || (options & OPT_OPEN_LEFT ? null : type.contentMatch);\n    }\n    findWrapping(node) {\n        if (!this.match) {\n            if (!this.type)\n                return [];\n            let fill = this.type.contentMatch.fillBefore(Fragment.from(node));\n            if (fill) {\n                this.match = this.type.contentMatch.matchFragment(fill);\n            }\n            else {\n                let start = this.type.contentMatch, wrap;\n                if (wrap = start.findWrapping(node.type)) {\n                    this.match = start;\n                    return wrap;\n                }\n                else {\n                    return null;\n                }\n            }\n        }\n        return this.match.findWrapping(node.type);\n    }\n    finish(openEnd) {\n        if (!(this.options & OPT_PRESERVE_WS)) { // Strip trailing whitespace\n            let last = this.content[this.content.length - 1], m;\n            if (last && last.isText && (m = /[ \\t\\r\\n\\u000c]+$/.exec(last.text))) {\n                let text = last;\n                if (last.text.length == m[0].length)\n                    this.content.pop();\n                else\n                    this.content[this.content.length - 1] = text.withText(text.text.slice(0, text.text.length - m[0].length));\n            }\n        }\n        let content = Fragment.from(this.content);\n        if (!openEnd && this.match)\n            content = content.append(this.match.fillBefore(Fragment.empty, true));\n        return this.type ? this.type.create(this.attrs, content, this.marks) : content;\n    }\n    inlineContext(node) {\n        if (this.type)\n            return this.type.inlineContent;\n        if (this.content.length)\n            return this.content[0].isInline;\n        return node.parentNode && !blockTags.hasOwnProperty(node.parentNode.nodeName.toLowerCase());\n    }\n}\nclass ParseContext {\n    constructor(\n    // The parser we are using.\n    parser, \n    // The options passed to this parse.\n    options, isOpen) {\n        this.parser = parser;\n        this.options = options;\n        this.isOpen = isOpen;\n        this.open = 0;\n        this.localPreserveWS = false;\n        let topNode = options.topNode, topContext;\n        let topOptions = wsOptionsFor(null, options.preserveWhitespace, 0) | (isOpen ? OPT_OPEN_LEFT : 0);\n        if (topNode)\n            topContext = new NodeContext(topNode.type, topNode.attrs, Mark.none, true, options.topMatch || topNode.type.contentMatch, topOptions);\n        else if (isOpen)\n            topContext = new NodeContext(null, null, Mark.none, true, null, topOptions);\n        else\n            topContext = new NodeContext(parser.schema.topNodeType, null, Mark.none, true, null, topOptions);\n        this.nodes = [topContext];\n        this.find = options.findPositions;\n        this.needsBlock = false;\n    }\n    get top() {\n        return this.nodes[this.open];\n    }\n    // Add a DOM node to the content. Text is inserted as text node,\n    // otherwise, the node is passed to `addElement` or, if it has a\n    // `style` attribute, `addElementWithStyles`.\n    addDOM(dom, marks) {\n        if (dom.nodeType == 3)\n            this.addTextNode(dom, marks);\n        else if (dom.nodeType == 1)\n            this.addElement(dom, marks);\n    }\n    addTextNode(dom, marks) {\n        let value = dom.nodeValue;\n        let top = this.top, preserveWS = (top.options & OPT_PRESERVE_WS_FULL) ? \"full\"\n            : this.localPreserveWS || (top.options & OPT_PRESERVE_WS) > 0;\n        let { schema } = this.parser;\n        if (preserveWS === \"full\" ||\n            top.inlineContext(dom) ||\n            /[^ \\t\\r\\n\\u000c]/.test(value)) {\n            if (!preserveWS) {\n                value = value.replace(/[ \\t\\r\\n\\u000c]+/g, \" \");\n                // If this starts with whitespace, and there is no node before it, or\n                // a hard break, or a text node that ends with whitespace, strip the\n                // leading space.\n                if (/^[ \\t\\r\\n\\u000c]/.test(value) && this.open == this.nodes.length - 1) {\n                    let nodeBefore = top.content[top.content.length - 1];\n                    let domNodeBefore = dom.previousSibling;\n                    if (!nodeBefore ||\n                        (domNodeBefore && domNodeBefore.nodeName == 'BR') ||\n                        (nodeBefore.isText && /[ \\t\\r\\n\\u000c]$/.test(nodeBefore.text)))\n                        value = value.slice(1);\n                }\n            }\n            else if (preserveWS === \"full\") {\n                value = value.replace(/\\r\\n?/g, \"\\n\");\n            }\n            else if (schema.linebreakReplacement && /[\\r\\n]/.test(value) && this.top.findWrapping(schema.linebreakReplacement.create())) {\n                let lines = value.split(/\\r?\\n|\\r/);\n                for (let i = 0; i < lines.length; i++) {\n                    if (i)\n                        this.insertNode(schema.linebreakReplacement.create(), marks, true);\n                    if (lines[i])\n                        this.insertNode(schema.text(lines[i]), marks, !/\\S/.test(lines[i]));\n                }\n                value = \"\";\n            }\n            else {\n                value = value.replace(/\\r?\\n|\\r/g, \" \");\n            }\n            if (value)\n                this.insertNode(schema.text(value), marks, !/\\S/.test(value));\n            this.findInText(dom);\n        }\n        else {\n            this.findInside(dom);\n        }\n    }\n    // Try to find a handler for the given tag and use that to parse. If\n    // none is found, the element's content nodes are added directly.\n    addElement(dom, marks, matchAfter) {\n        let outerWS = this.localPreserveWS, top = this.top;\n        if (dom.tagName == \"PRE\" || /pre/.test(dom.style && dom.style.whiteSpace))\n            this.localPreserveWS = true;\n        let name = dom.nodeName.toLowerCase(), ruleID;\n        if (listTags.hasOwnProperty(name) && this.parser.normalizeLists)\n            normalizeList(dom);\n        let rule = (this.options.ruleFromNode && this.options.ruleFromNode(dom)) ||\n            (ruleID = this.parser.matchTag(dom, this, matchAfter));\n        out: if (rule ? rule.ignore : ignoreTags.hasOwnProperty(name)) {\n            this.findInside(dom);\n            this.ignoreFallback(dom, marks);\n        }\n        else if (!rule || rule.skip || rule.closeParent) {\n            if (rule && rule.closeParent)\n                this.open = Math.max(0, this.open - 1);\n            else if (rule && rule.skip.nodeType)\n                dom = rule.skip;\n            let sync, oldNeedsBlock = this.needsBlock;\n            if (blockTags.hasOwnProperty(name)) {\n                if (top.content.length && top.content[0].isInline && this.open) {\n                    this.open--;\n                    top = this.top;\n                }\n                sync = true;\n                if (!top.type)\n                    this.needsBlock = true;\n            }\n            else if (!dom.firstChild) {\n                this.leafFallback(dom, marks);\n                break out;\n            }\n            let innerMarks = rule && rule.skip ? marks : this.readStyles(dom, marks);\n            if (innerMarks)\n                this.addAll(dom, innerMarks);\n            if (sync)\n                this.sync(top);\n            this.needsBlock = oldNeedsBlock;\n        }\n        else {\n            let innerMarks = this.readStyles(dom, marks);\n            if (innerMarks)\n                this.addElementByRule(dom, rule, innerMarks, rule.consuming === false ? ruleID : undefined);\n        }\n        this.localPreserveWS = outerWS;\n    }\n    // Called for leaf DOM nodes that would otherwise be ignored\n    leafFallback(dom, marks) {\n        if (dom.nodeName == \"BR\" && this.top.type && this.top.type.inlineContent)\n            this.addTextNode(dom.ownerDocument.createTextNode(\"\\n\"), marks);\n    }\n    // Called for ignored nodes\n    ignoreFallback(dom, marks) {\n        // Ignored BR nodes should at least create an inline context\n        if (dom.nodeName == \"BR\" && (!this.top.type || !this.top.type.inlineContent))\n            this.findPlace(this.parser.schema.text(\"-\"), marks, true);\n    }\n    // Run any style parser associated with the node's styles. Either\n    // return an updated array of marks, or null to indicate some of the\n    // styles had a rule with `ignore` set.\n    readStyles(dom, marks) {\n        let styles = dom.style;\n        // Because many properties will only show up in 'normalized' form\n        // in `style.item` (i.e. text-decoration becomes\n        // text-decoration-line, text-decoration-color, etc), we directly\n        // query the styles mentioned in our rules instead of iterating\n        // over the items.\n        if (styles && styles.length)\n            for (let i = 0; i < this.parser.matchedStyles.length; i++) {\n                let name = this.parser.matchedStyles[i], value = styles.getPropertyValue(name);\n                if (value)\n                    for (let after = undefined;;) {\n                        let rule = this.parser.matchStyle(name, value, this, after);\n                        if (!rule)\n                            break;\n                        if (rule.ignore)\n                            return null;\n                        if (rule.clearMark)\n                            marks = marks.filter(m => !rule.clearMark(m));\n                        else\n                            marks = marks.concat(this.parser.schema.marks[rule.mark].create(rule.attrs));\n                        if (rule.consuming === false)\n                            after = rule;\n                        else\n                            break;\n                    }\n            }\n        return marks;\n    }\n    // Look up a handler for the given node. If none are found, return\n    // false. Otherwise, apply it, use its return value to drive the way\n    // the node's content is wrapped, and return true.\n    addElementByRule(dom, rule, marks, continueAfter) {\n        let sync, nodeType;\n        if (rule.node) {\n            nodeType = this.parser.schema.nodes[rule.node];\n            if (!nodeType.isLeaf) {\n                let inner = this.enter(nodeType, rule.attrs || null, marks, rule.preserveWhitespace);\n                if (inner) {\n                    sync = true;\n                    marks = inner;\n                }\n            }\n            else if (!this.insertNode(nodeType.create(rule.attrs), marks, dom.nodeName == \"BR\")) {\n                this.leafFallback(dom, marks);\n            }\n        }\n        else {\n            let markType = this.parser.schema.marks[rule.mark];\n            marks = marks.concat(markType.create(rule.attrs));\n        }\n        let startIn = this.top;\n        if (nodeType && nodeType.isLeaf) {\n            this.findInside(dom);\n        }\n        else if (continueAfter) {\n            this.addElement(dom, marks, continueAfter);\n        }\n        else if (rule.getContent) {\n            this.findInside(dom);\n            rule.getContent(dom, this.parser.schema).forEach(node => this.insertNode(node, marks, false));\n        }\n        else {\n            let contentDOM = dom;\n            if (typeof rule.contentElement == \"string\")\n                contentDOM = dom.querySelector(rule.contentElement);\n            else if (typeof rule.contentElement == \"function\")\n                contentDOM = rule.contentElement(dom);\n            else if (rule.contentElement)\n                contentDOM = rule.contentElement;\n            this.findAround(dom, contentDOM, true);\n            this.addAll(contentDOM, marks);\n            this.findAround(dom, contentDOM, false);\n        }\n        if (sync && this.sync(startIn))\n            this.open--;\n    }\n    // Add all child nodes between `startIndex` and `endIndex` (or the\n    // whole node, if not given). If `sync` is passed, use it to\n    // synchronize after every block element.\n    addAll(parent, marks, startIndex, endIndex) {\n        let index = startIndex || 0;\n        for (let dom = startIndex ? parent.childNodes[startIndex] : parent.firstChild, end = endIndex == null ? null : parent.childNodes[endIndex]; dom != end; dom = dom.nextSibling, ++index) {\n            this.findAtPoint(parent, index);\n            this.addDOM(dom, marks);\n        }\n        this.findAtPoint(parent, index);\n    }\n    // Try to find a way to fit the given node type into the current\n    // context. May add intermediate wrappers and/or leave non-solid\n    // nodes that we're in.\n    findPlace(node, marks, cautious) {\n        let route, sync;\n        for (let depth = this.open, penalty = 0; depth >= 0; depth--) {\n            let cx = this.nodes[depth];\n            let found = cx.findWrapping(node);\n            if (found && (!route || route.length > found.length + penalty)) {\n                route = found;\n                sync = cx;\n                if (!found.length)\n                    break;\n            }\n            if (cx.solid) {\n                if (cautious)\n                    break;\n                penalty += 2;\n            }\n        }\n        if (!route)\n            return null;\n        this.sync(sync);\n        for (let i = 0; i < route.length; i++)\n            marks = this.enterInner(route[i], null, marks, false);\n        return marks;\n    }\n    // Try to insert the given node, adjusting the context when needed.\n    insertNode(node, marks, cautious) {\n        if (node.isInline && this.needsBlock && !this.top.type) {\n            let block = this.textblockFromContext();\n            if (block)\n                marks = this.enterInner(block, null, marks);\n        }\n        let innerMarks = this.findPlace(node, marks, cautious);\n        if (innerMarks) {\n            this.closeExtra();\n            let top = this.top;\n            if (top.match)\n                top.match = top.match.matchType(node.type);\n            let nodeMarks = Mark.none;\n            for (let m of innerMarks.concat(node.marks))\n                if (top.type ? top.type.allowsMarkType(m.type) : markMayApply(m.type, node.type))\n                    nodeMarks = m.addToSet(nodeMarks);\n            top.content.push(node.mark(nodeMarks));\n            return true;\n        }\n        return false;\n    }\n    // Try to start a node of the given type, adjusting the context when\n    // necessary.\n    enter(type, attrs, marks, preserveWS) {\n        let innerMarks = this.findPlace(type.create(attrs), marks, false);\n        if (innerMarks)\n            innerMarks = this.enterInner(type, attrs, marks, true, preserveWS);\n        return innerMarks;\n    }\n    // Open a node of the given type\n    enterInner(type, attrs, marks, solid = false, preserveWS) {\n        this.closeExtra();\n        let top = this.top;\n        top.match = top.match && top.match.matchType(type);\n        let options = wsOptionsFor(type, preserveWS, top.options);\n        if ((top.options & OPT_OPEN_LEFT) && top.content.length == 0)\n            options |= OPT_OPEN_LEFT;\n        let applyMarks = Mark.none;\n        marks = marks.filter(m => {\n            if (top.type ? top.type.allowsMarkType(m.type) : markMayApply(m.type, type)) {\n                applyMarks = m.addToSet(applyMarks);\n                return false;\n            }\n            return true;\n        });\n        this.nodes.push(new NodeContext(type, attrs, applyMarks, solid, null, options));\n        this.open++;\n        return marks;\n    }\n    // Make sure all nodes above this.open are finished and added to\n    // their parents\n    closeExtra(openEnd = false) {\n        let i = this.nodes.length - 1;\n        if (i > this.open) {\n            for (; i > this.open; i--)\n                this.nodes[i - 1].content.push(this.nodes[i].finish(openEnd));\n            this.nodes.length = this.open + 1;\n        }\n    }\n    finish() {\n        this.open = 0;\n        this.closeExtra(this.isOpen);\n        return this.nodes[0].finish(!!(this.isOpen || this.options.topOpen));\n    }\n    sync(to) {\n        for (let i = this.open; i >= 0; i--) {\n            if (this.nodes[i] == to) {\n                this.open = i;\n                return true;\n            }\n            else if (this.localPreserveWS) {\n                this.nodes[i].options |= OPT_PRESERVE_WS;\n            }\n        }\n        return false;\n    }\n    get currentPos() {\n        this.closeExtra();\n        let pos = 0;\n        for (let i = this.open; i >= 0; i--) {\n            let content = this.nodes[i].content;\n            for (let j = content.length - 1; j >= 0; j--)\n                pos += content[j].nodeSize;\n            if (i)\n                pos++;\n        }\n        return pos;\n    }\n    findAtPoint(parent, offset) {\n        if (this.find)\n            for (let i = 0; i < this.find.length; i++) {\n                if (this.find[i].node == parent && this.find[i].offset == offset)\n                    this.find[i].pos = this.currentPos;\n            }\n    }\n    findInside(parent) {\n        if (this.find)\n            for (let i = 0; i < this.find.length; i++) {\n                if (this.find[i].pos == null && parent.nodeType == 1 && parent.contains(this.find[i].node))\n                    this.find[i].pos = this.currentPos;\n            }\n    }\n    findAround(parent, content, before) {\n        if (parent != content && this.find)\n            for (let i = 0; i < this.find.length; i++) {\n                if (this.find[i].pos == null && parent.nodeType == 1 && parent.contains(this.find[i].node)) {\n                    let pos = content.compareDocumentPosition(this.find[i].node);\n                    if (pos & (before ? 2 : 4))\n                        this.find[i].pos = this.currentPos;\n                }\n            }\n    }\n    findInText(textNode) {\n        if (this.find)\n            for (let i = 0; i < this.find.length; i++) {\n                if (this.find[i].node == textNode)\n                    this.find[i].pos = this.currentPos - (textNode.nodeValue.length - this.find[i].offset);\n            }\n    }\n    // Determines whether the given context string matches this context.\n    matchesContext(context) {\n        if (context.indexOf(\"|\") > -1)\n            return context.split(/\\s*\\|\\s*/).some(this.matchesContext, this);\n        let parts = context.split(\"/\");\n        let option = this.options.context;\n        let useRoot = !this.isOpen && (!option || option.parent.type == this.nodes[0].type);\n        let minDepth = -(option ? option.depth + 1 : 0) + (useRoot ? 0 : 1);\n        let match = (i, depth) => {\n            for (; i >= 0; i--) {\n                let part = parts[i];\n                if (part == \"\") {\n                    if (i == parts.length - 1 || i == 0)\n                        continue;\n                    for (; depth >= minDepth; depth--)\n                        if (match(i - 1, depth))\n                            return true;\n                    return false;\n                }\n                else {\n                    let next = depth > 0 || (depth == 0 && useRoot) ? this.nodes[depth].type\n                        : option && depth >= minDepth ? option.node(depth - minDepth).type\n                            : null;\n                    if (!next || (next.name != part && !next.isInGroup(part)))\n                        return false;\n                    depth--;\n                }\n            }\n            return true;\n        };\n        return match(parts.length - 1, this.open);\n    }\n    textblockFromContext() {\n        let $context = this.options.context;\n        if ($context)\n            for (let d = $context.depth; d >= 0; d--) {\n                let deflt = $context.node(d).contentMatchAt($context.indexAfter(d)).defaultType;\n                if (deflt && deflt.isTextblock && deflt.defaultAttrs)\n                    return deflt;\n            }\n        for (let name in this.parser.schema.nodes) {\n            let type = this.parser.schema.nodes[name];\n            if (type.isTextblock && type.defaultAttrs)\n                return type;\n        }\n    }\n}\n// Kludge to work around directly nested list nodes produced by some\n// tools and allowed by browsers to mean that the nested list is\n// actually part of the list item above it.\nfunction normalizeList(dom) {\n    for (let child = dom.firstChild, prevItem = null; child; child = child.nextSibling) {\n        let name = child.nodeType == 1 ? child.nodeName.toLowerCase() : null;\n        if (name && listTags.hasOwnProperty(name) && prevItem) {\n            prevItem.appendChild(child);\n            child = prevItem;\n        }\n        else if (name == \"li\") {\n            prevItem = child;\n        }\n        else if (name) {\n            prevItem = null;\n        }\n    }\n}\n// Apply a CSS selector.\nfunction matches(dom, selector) {\n    return (dom.matches || dom.msMatchesSelector || dom.webkitMatchesSelector || dom.mozMatchesSelector).call(dom, selector);\n}\nfunction copy(obj) {\n    let copy = {};\n    for (let prop in obj)\n        copy[prop] = obj[prop];\n    return copy;\n}\n// Used when finding a mark at the top level of a fragment parse.\n// Checks whether it would be reasonable to apply a given mark type to\n// a given node, by looking at the way the mark occurs in the schema.\nfunction markMayApply(markType, nodeType) {\n    let nodes = nodeType.schema.nodes;\n    for (let name in nodes) {\n        let parent = nodes[name];\n        if (!parent.allowsMarkType(markType))\n            continue;\n        let seen = [], scan = (match) => {\n            seen.push(match);\n            for (let i = 0; i < match.edgeCount; i++) {\n                let { type, next } = match.edge(i);\n                if (type == nodeType)\n                    return true;\n                if (seen.indexOf(next) < 0 && scan(next))\n                    return true;\n            }\n        };\n        if (scan(parent.contentMatch))\n            return true;\n    }\n}\n\n/**\nA DOM serializer knows how to convert ProseMirror nodes and\nmarks of various types to DOM nodes.\n*/\nclass DOMSerializer {\n    /**\n    Create a serializer. `nodes` should map node names to functions\n    that take a node and return a description of the corresponding\n    DOM. `marks` does the same for mark names, but also gets an\n    argument that tells it whether the mark's content is block or\n    inline content (for typical use, it'll always be inline). A mark\n    serializer may be `null` to indicate that marks of that type\n    should not be serialized.\n    */\n    constructor(\n    /**\n    The node serialization functions.\n    */\n    nodes, \n    /**\n    The mark serialization functions.\n    */\n    marks) {\n        this.nodes = nodes;\n        this.marks = marks;\n    }\n    /**\n    Serialize the content of this fragment to a DOM fragment. When\n    not in the browser, the `document` option, containing a DOM\n    document, should be passed so that the serializer can create\n    nodes.\n    */\n    serializeFragment(fragment, options = {}, target) {\n        if (!target)\n            target = doc(options).createDocumentFragment();\n        let top = target, active = [];\n        fragment.forEach(node => {\n            if (active.length || node.marks.length) {\n                let keep = 0, rendered = 0;\n                while (keep < active.length && rendered < node.marks.length) {\n                    let next = node.marks[rendered];\n                    if (!this.marks[next.type.name]) {\n                        rendered++;\n                        continue;\n                    }\n                    if (!next.eq(active[keep][0]) || next.type.spec.spanning === false)\n                        break;\n                    keep++;\n                    rendered++;\n                }\n                while (keep < active.length)\n                    top = active.pop()[1];\n                while (rendered < node.marks.length) {\n                    let add = node.marks[rendered++];\n                    let markDOM = this.serializeMark(add, node.isInline, options);\n                    if (markDOM) {\n                        active.push([add, top]);\n                        top.appendChild(markDOM.dom);\n                        top = markDOM.contentDOM || markDOM.dom;\n                    }\n                }\n            }\n            top.appendChild(this.serializeNodeInner(node, options));\n        });\n        return target;\n    }\n    /**\n    @internal\n    */\n    serializeNodeInner(node, options) {\n        let { dom, contentDOM } = renderSpec(doc(options), this.nodes[node.type.name](node), null, node.attrs);\n        if (contentDOM) {\n            if (node.isLeaf)\n                throw new RangeError(\"Content hole not allowed in a leaf node spec\");\n            this.serializeFragment(node.content, options, contentDOM);\n        }\n        return dom;\n    }\n    /**\n    Serialize this node to a DOM node. This can be useful when you\n    need to serialize a part of a document, as opposed to the whole\n    document. To serialize a whole document, use\n    [`serializeFragment`](https://prosemirror.net/docs/ref/#model.DOMSerializer.serializeFragment) on\n    its [content](https://prosemirror.net/docs/ref/#model.Node.content).\n    */\n    serializeNode(node, options = {}) {\n        let dom = this.serializeNodeInner(node, options);\n        for (let i = node.marks.length - 1; i >= 0; i--) {\n            let wrap = this.serializeMark(node.marks[i], node.isInline, options);\n            if (wrap) {\n                (wrap.contentDOM || wrap.dom).appendChild(dom);\n                dom = wrap.dom;\n            }\n        }\n        return dom;\n    }\n    /**\n    @internal\n    */\n    serializeMark(mark, inline, options = {}) {\n        let toDOM = this.marks[mark.type.name];\n        return toDOM && renderSpec(doc(options), toDOM(mark, inline), null, mark.attrs);\n    }\n    static renderSpec(doc, structure, xmlNS = null, blockArraysIn) {\n        return renderSpec(doc, structure, xmlNS, blockArraysIn);\n    }\n    /**\n    Build a serializer using the [`toDOM`](https://prosemirror.net/docs/ref/#model.NodeSpec.toDOM)\n    properties in a schema's node and mark specs.\n    */\n    static fromSchema(schema) {\n        return schema.cached.domSerializer ||\n            (schema.cached.domSerializer = new DOMSerializer(this.nodesFromSchema(schema), this.marksFromSchema(schema)));\n    }\n    /**\n    Gather the serializers in a schema's node specs into an object.\n    This can be useful as a base to build a custom serializer from.\n    */\n    static nodesFromSchema(schema) {\n        let result = gatherToDOM(schema.nodes);\n        if (!result.text)\n            result.text = node => node.text;\n        return result;\n    }\n    /**\n    Gather the serializers in a schema's mark specs into an object.\n    */\n    static marksFromSchema(schema) {\n        return gatherToDOM(schema.marks);\n    }\n}\nfunction gatherToDOM(obj) {\n    let result = {};\n    for (let name in obj) {\n        let toDOM = obj[name].spec.toDOM;\n        if (toDOM)\n            result[name] = toDOM;\n    }\n    return result;\n}\nfunction doc(options) {\n    return options.document || window.document;\n}\nconst suspiciousAttributeCache = new WeakMap();\nfunction suspiciousAttributes(attrs) {\n    let value = suspiciousAttributeCache.get(attrs);\n    if (value === undefined)\n        suspiciousAttributeCache.set(attrs, value = suspiciousAttributesInner(attrs));\n    return value;\n}\nfunction suspiciousAttributesInner(attrs) {\n    let result = null;\n    function scan(value) {\n        if (value && typeof value == \"object\") {\n            if (Array.isArray(value)) {\n                if (typeof value[0] == \"string\") {\n                    if (!result)\n                        result = [];\n                    result.push(value);\n                }\n                else {\n                    for (let i = 0; i < value.length; i++)\n                        scan(value[i]);\n                }\n            }\n            else {\n                for (let prop in value)\n                    scan(value[prop]);\n            }\n        }\n    }\n    scan(attrs);\n    return result;\n}\nfunction renderSpec(doc, structure, xmlNS, blockArraysIn) {\n    if (typeof structure == \"string\")\n        return { dom: doc.createTextNode(structure) };\n    if (structure.nodeType != null)\n        return { dom: structure };\n    if (structure.dom && structure.dom.nodeType != null)\n        return structure;\n    let tagName = structure[0], suspicious;\n    if (typeof tagName != \"string\")\n        throw new RangeError(\"Invalid array passed to renderSpec\");\n    if (blockArraysIn && (suspicious = suspiciousAttributes(blockArraysIn)) &&\n        suspicious.indexOf(structure) > -1)\n        throw new RangeError(\"Using an array from an attribute object as a DOM spec. This may be an attempted cross site scripting attack.\");\n    let space = tagName.indexOf(\" \");\n    if (space > 0) {\n        xmlNS = tagName.slice(0, space);\n        tagName = tagName.slice(space + 1);\n    }\n    let contentDOM;\n    let dom = (xmlNS ? doc.createElementNS(xmlNS, tagName) : doc.createElement(tagName));\n    let attrs = structure[1], start = 1;\n    if (attrs && typeof attrs == \"object\" && attrs.nodeType == null && !Array.isArray(attrs)) {\n        start = 2;\n        for (let name in attrs)\n            if (attrs[name] != null) {\n                let space = name.indexOf(\" \");\n                if (space > 0)\n                    dom.setAttributeNS(name.slice(0, space), name.slice(space + 1), attrs[name]);\n                else if (name == \"style\" && dom.style)\n                    dom.style.cssText = attrs[name];\n                else\n                    dom.setAttribute(name, attrs[name]);\n            }\n    }\n    for (let i = start; i < structure.length; i++) {\n        let child = structure[i];\n        if (child === 0) {\n            if (i < structure.length - 1 || i > start)\n                throw new RangeError(\"Content hole must be the only child of its parent node\");\n            return { dom, contentDOM: dom };\n        }\n        else {\n            let { dom: inner, contentDOM: innerContent } = renderSpec(doc, child, xmlNS, blockArraysIn);\n            dom.appendChild(inner);\n            if (innerContent) {\n                if (contentDOM)\n                    throw new RangeError(\"Multiple content holes\");\n                contentDOM = innerContent;\n            }\n        }\n    }\n    return { dom, contentDOM };\n}\n\nexport { ContentMatch, DOMParser, DOMSerializer, Fragment, Mark, MarkType, Node, NodeRange, NodeType, ReplaceError, ResolvedPos, Schema, Slice };\n","<template lang=\"pug\">\n.dito-markup(:id=\"dataPath\")\n  .dito-buttons.dito-buttons--toolbar(\n    v-if=\"groupedButtons.length > 0\"\n  )\n    .dito-buttons__group(\n      v-for=\"buttons in groupedButtons\"\n    )\n      button.dito-button(\n        v-for=\"{ name, icon, isActive, onClick } in buttons\"\n        :key=\"name\"\n        :class=\"{ 'dito-button--active': isActive }\"\n        @click=\"onClick\"\n      )\n        DitoIcon(:name=\"icon\")\n  EditorContent.dito-markup-editor(\n    ref=\"editor\"\n    :editor=\"editor\"\n    :style=\"styles\"\n  )\n  .dito-resize(\n    v-if=\"resizable\"\n    @mousedown.stop.prevent=\"onDragResize\"\n  )\n</template>\n\n<script>\nimport DitoTypeComponent from '../DitoTypeComponent.js'\nimport DomMixin from '../mixins/DomMixin.js'\nimport { getSchemaAccessor } from '../utils/accessor.js'\n// Tiptap:\nimport { Editor, EditorContent, Mark, getMarkAttributes } from '@tiptap/vue-3'\nimport { Slice, Fragment } from '@tiptap/pm/model'\n// Essentials:\nimport { Document } from '@tiptap/extension-document'\nimport { Text } from '@tiptap/extension-text'\n// Marks:\nimport { Bold } from '@tiptap/extension-bold'\nimport { Code } from '@tiptap/extension-code'\nimport { Italic } from '@tiptap/extension-italic'\nimport { Link } from '@tiptap/extension-link'\nimport { Strike } from '@tiptap/extension-strike'\nimport { Subscript } from '@tiptap/extension-subscript'\nimport { Superscript } from '@tiptap/extension-superscript'\nimport { Underline } from '@tiptap/extension-underline'\n// Nodes:\nimport { Blockquote } from '@tiptap/extension-blockquote'\nimport { CodeBlock } from '@tiptap/extension-code-block'\nimport { HardBreak } from '@tiptap/extension-hard-break'\nimport { Heading } from '@tiptap/extension-heading'\nimport { Paragraph } from '@tiptap/extension-paragraph'\nimport { HorizontalRule } from '@tiptap/extension-horizontal-rule'\nimport { OrderedList } from '@tiptap/extension-ordered-list'\nimport { BulletList } from '@tiptap/extension-bullet-list'\nimport { ListItem } from '@tiptap/extension-list-item'\nimport { Footnotes, FootnoteReference, Footnote } from 'tiptap-footnotes'\n// TODO:\n// import { Image } from '@tiptap/extension-image'\n// import { Mention } from '@tiptap/extension-mention'\n// import { CodeBlockHighlight } from '@tiptap/extension-code-block-highlight'\n// import { Table } from '@tiptap/extension-table'\n// import { TableCell } from '@tiptap/extension-table-cell'\n// import { TableHeader } from '@tiptap/extension-table-header'\n// import { TableNodes } from '@tiptap/extension-table-nodes'\n// import { TableRow } from '@tiptap/extension-table-row'\n// import { TaskList } from '@tiptap/extension-task-list'\n// import { TaskItem } from '@tiptap/extension-task-item'\n// Tools:\nimport { History } from '@tiptap/extension-history'\n\nimport { DitoIcon } from '@ditojs/ui/src'\nimport { isArray, isObject, hyphenate, debounce, camelize } from '@ditojs/utils'\n\n// @vue/component\nexport default DitoTypeComponent.register('markup', {\n  mixins: [DomMixin],\n  components: {\n    EditorContent,\n    DitoIcon\n  },\n\n  data() {\n    return {\n      editor: null,\n      height: null\n    }\n  },\n\n  computed: {\n    lines() {\n      return this.schema.lines || 10\n    },\n\n    hardBreak() {\n      return !!this.schema.hardBreak\n    },\n\n    styles() {\n      return {\n        height: this.height || `calc(${this.lines}em * var(--line-height))`\n      }\n    },\n\n    markButtons() {\n      return this.getButtons('marks', {\n        bold: true,\n        italic: true,\n        underline: true,\n        strike: true,\n        small: true,\n        code: true,\n        subscript: true,\n        superscript: true,\n        link: {\n          onClick: editor => this.onClickLink(editor)\n        }\n      })\n    },\n\n    basicNodeButtons() {\n      return this.getButtons('nodes', {\n        paragraph: {\n          command: 'setParagraph'\n        },\n        heading: {\n          attribute: 'level',\n          values: [1, 2, 3, 4, 5, 6]\n        }\n      })\n    },\n\n    advancedNodeButtons() {\n      return this.getButtons('nodes', {\n        bulletList: true,\n        orderedList: true,\n        blockquote: true,\n        codeBlock: true\n      })\n    },\n\n    toolButtons() {\n      return this.getButtons('tools', {\n        undo: true,\n        redo: true,\n        footnotes: {\n          command: 'addFootnote'\n        }\n      })\n    },\n\n    groupedButtons() {\n      return [\n        this.markButtons,\n        this.basicNodeButtons,\n        this.advancedNodeButtons,\n        this.toolButtons\n      ].filter(buttons => buttons.length > 0)\n    },\n\n    parseOptions() {\n      return {\n        preserveWhitespace: {\n          'collapse': false,\n          'preserve': true,\n          'preserve-all': 'full'\n        }[this.whitespace]\n      }\n    },\n\n    editorOptions() {\n      return {\n        editable: !this.readyonly,\n        autoFocus: this.autofocus,\n        disableInputRules: !this.enableRules.input,\n        disablePasteRules: !this.enableRules.paste,\n        parseOptions: this.parseOptions,\n        editorProps: this.hardBreak\n          ? {\n              handlePaste: (view, event, slice) => {\n                const nodes = []\n\n                slice.content.forEach((node, offset, index) => {\n                  if (index > 0 && node.type.name === 'paragraph') {\n                    // Add hard break between paragraphs\n                    nodes.push(view.state.schema.nodes.hardBreak.create())\n                  }\n\n                  // Extract content from paragraphs, keep other nodes as-is\n                  if (node.type.name === 'paragraph') {\n                    node.content.forEach(child => nodes.push(child))\n                  } else {\n                    nodes.push(node)\n                  }\n                })\n\n                const paragraph = view.state.schema.nodes.paragraph.create(\n                  null,\n                  Fragment.from(nodes)\n                )\n\n                view.dispatch(\n                  view.state.tr.replaceSelection(\n                    new Slice(Fragment.from(paragraph), 0, 0)\n                  )\n                )\n\n                return true\n              }\n            }\n          : {}\n      }\n    },\n\n    resizable: getSchemaAccessor('resizable', {\n      type: Boolean,\n      default: false\n    }),\n\n    whitespace: getSchemaAccessor('whitespace', {\n      type: String,\n      default: 'collapse'\n      // Possible values are: 'collapse', 'preserve', 'preserve-all'\n    }),\n\n    enableRules: getSchemaAccessor('enableRules', {\n      type: [Object, Boolean],\n      default: false,\n      get(enableRules) {\n        return isObject(enableRules)\n          ? enableRules\n          : {\n              input: !!enableRules,\n              paste: !!enableRules\n            }\n      }\n    })\n  },\n\n  watch: {\n    readyonly: 'updateEditorOptions',\n    autofocus: 'updateEditorOptions',\n    enableRules: 'updateEditorOptions'\n  },\n\n  created() {\n    let changed = false\n    let ignoreWatch = false\n\n    const onFocus = () => this.onFocus()\n\n    const onBlur = () => {\n      this.onBlur()\n      updateValue()\n    }\n\n    const onUpdate = () => {\n      setValueDebounced()\n      this.onInput()\n    }\n\n    const setValueDebounced = debounce(() => {\n      ignoreWatch = true\n      updateValue()\n    }, 100)\n\n    const updateValue = () => {\n      const content = this.editor.getHTML()\n      const value = this.hardBreak\n        ? content.replace(/^<p>(.*?)<\\/p>$/s, '$1')\n        : content\n      if (value !== this.value) {\n        changed = true\n        this.value = value\n      }\n      if (!this.focused && changed) {\n        this.onChange()\n        changed = false\n      }\n    }\n\n    this.$watch('value', value => {\n      if (ignoreWatch) {\n        ignoreWatch = false\n      } else {\n        const content = this.hardBreak\n          ? `<p>${value}</p>`\n          : value\n        this.editor.commands.setContent(content, {\n          emitUpdate: false,\n          parseOptions: this.parseOptions\n        })\n      }\n    })\n\n    this.editor = new Editor({\n      ...this.editorOptions,\n      onFocus,\n      onBlur,\n      onUpdate,\n      extensions: this.getExtensions(),\n      content: this.value || ''\n    })\n  },\n\n  unmounted() {\n    this.editor.destroy()\n  },\n\n  methods: {\n    onDragResize(event) {\n      const getPoint = ({ clientX: x, clientY: y }) => ({ x, y })\n\n      let prevY = getPoint(event).y\n      let height = parseFloat(getComputedStyle(this.$refs.editor.$el).height)\n\n      const mousemove = event => {\n        const { y } = getPoint(event)\n        height += y - prevY\n        prevY = y\n        this.height = `${Math.max(height, 0)}px`\n      }\n\n      const handlers = this.domOn(document, {\n        mousemove,\n\n        mouseup(event) {\n          mousemove(event)\n          handlers.remove()\n        }\n      })\n    },\n\n    updateEditorOptions() {\n      this.editor.setOptions(this.editorOptions)\n    },\n\n    async onClickLink(editor) {\n      const attributes = await this.rootComponent.showDialog({\n        components: {\n          DitoIcon,\n          href: {\n            type: 'url',\n            label: 'Link',\n            autofocus: true\n          },\n          title: {\n            type: 'text',\n            label: 'Title'\n          }\n        },\n        buttons: {\n          cancel: {},\n          apply: { type: 'submit' },\n          remove: {\n            events: {\n              click({ dialogComponent }) {\n                dialogComponent.resolve(null)\n              }\n            }\n          }\n        },\n        data: getMarkAttributes(this.editor.state, 'link')\n      })\n      if (attributes) {\n        let { href, title } = attributes\n        if (href) {\n          // See if `href` can be parsed as a URL, and if not,\n          // prefix it with a default protocol.\n          try {\n            new URL(href)\n          } catch {\n            href = `https://${href}`\n          }\n        }\n        editor.commands.setLink({ href, title })\n      } else if (attributes === null) {\n        editor.commands.unsetLink()\n      }\n    },\n\n    getExtensions() {\n      const {\n        marks = {},\n        nodes = {},\n        tools = {}\n      } = this.schema\n      return [\n        // Essentials:\n        tools.footnotes\n          ? Document.extend({ content: 'block+ footnotes?' })\n          : Document,\n\n        Text,\n        Paragraph, // button can be controlled, but node needs to be on.\n\n        // Marks: `schema.marks`\n        marks.bold && Bold,\n        marks.italic && Italic,\n        marks.underline && Underline,\n        marks.strike && Strike,\n        marks.small && Small,\n        marks.code && Code,\n        marks.subscript && Superscript,\n        marks.superscript && Subscript,\n        marks.link && LinkWithTitle,\n\n        // Nodes: `schema.nodes`\n        nodes.blockquote && Blockquote,\n        nodes.codeBlock && CodeBlock,\n        nodes.heading && Heading.configure({ levels: nodes.heading }),\n        nodes.horizontalRule && HorizontalRule,\n        (nodes.orderedList || nodes.bulletList) && ListItem,\n        nodes.bulletList && BulletList,\n        nodes.orderedList && OrderedList,\n\n        // Footnotes:\n        ...(tools.footnotes ? [Footnotes, Footnote, FootnoteReference] : []),\n\n        // TODO:\n        // nodes.todoList && TodoItem,\n        // nodes.todoList && TodoList,\n\n        // Tools: `schema.tools`\n        tools.history && History,\n\n        HardBreak.extend({\n          addKeyboardShortcuts: () => {\n            const setHardBreak = () => this.editor.commands.setHardBreak()\n            return {\n              'Mod-Enter': setHardBreak,\n              'Shift-Enter': setHardBreak,\n              ...(this.hardBreak ? { Enter: setHardBreak } : null)\n            }\n          }\n        })\n      ].filter(extension => !!extension)\n    },\n\n    getButtons(settingsName, descriptions) {\n      const list = []\n      const { commands } = this.editor\n\n      const addButton = ({ name, icon, command, attributes, onClick }) => {\n        list.push({\n          name,\n          icon,\n          isActive: this.editor.isActive(name, attributes),\n          onClick: () => {\n            command ??=\n              name in commands\n                ? name\n                : `toggle${camelize(name, true)}`\n            if (command in commands) {\n              const apply = attributes =>\n                this.editor.chain()[command](attributes).focus().run()\n              onClick\n                ? onClick(this.editor, attributes)\n                : apply(attributes)\n            }\n          }\n        })\n      }\n\n      const settings = this.schema[settingsName]\n      if (settings) {\n        for (const [name, description] of Object.entries(descriptions)) {\n          const settingName = ['undo', 'redo'].includes(name) ? 'history' : name\n          const setting = settings[settingName]\n          const icon = hyphenate(name)\n          if (setting) {\n            if (description === true) {\n              addButton({ name, icon })\n            } else if (isObject(description)) {\n              const { command, attribute, values, onClick } = description\n              if (attribute) {\n                if (isArray(values) && isArray(setting)) {\n                  // Support heading level attrs:\n                  for (const value of values) {\n                    if (setting.includes(value)) {\n                      addButton({\n                        name,\n                        icon: `${icon}-${value}`,\n                        command,\n                        attributes: { [attribute]: value },\n                        onClick\n                      })\n                    }\n                  }\n                }\n              } else {\n                addButton({ name, icon, command, onClick })\n              }\n            }\n          }\n        }\n      }\n      return list\n    },\n\n    focusElement() {\n      this.editor.commands.focus()\n    },\n\n    blurElement() {\n      this.editor.commands.blur()\n    }\n  }\n})\n\nconst Small = Mark.create({\n  name: 'small',\n\n  parseHTML() {\n    return [{ tag: 'small' }]\n  },\n\n  renderHTML() {\n    return ['small', 0]\n  },\n\n  addCommands() {\n    return {\n      setSmall:\n        attributes =>\n        ({ commands }) => {\n          return commands.setMark(this.name, attributes)\n        },\n      toggleSmall:\n        attributes =>\n        ({ commands }) => {\n          return commands.toggleMark(this.name, attributes)\n        },\n      unsetSmall:\n        () =>\n        ({ commands }) => {\n          return commands.unsetMark(this.name)\n        }\n    }\n  }\n})\n\nconst LinkWithTitle = Link.extend({\n  inclusive: false,\n\n  addAttributes() {\n    return {\n      href: {\n        default: null\n      },\n      title: {\n        default: null\n      }\n    }\n  },\n\n  parseHTML() {\n    return [\n      {\n        tag: 'a',\n        getAttrs: element => ({\n          href: element.getAttribute('href'),\n          title: element.getAttribute('title')\n        })\n      }\n    ]\n  },\n\n  renderHTML({ HTMLAttributes }) {\n    return ['a', HTMLAttributes, 0]\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-markup {\n  @extend %input;\n\n  position: relative;\n\n  .ProseMirror {\n    height: 100%;\n    outline: none;\n  }\n\n  .dito-markup-editor {\n    overflow-y: scroll;\n    margin-top: $input-padding-ver;\n    // Move padding \"inside\" editor to correctly position scrollbar\n    margin-right: -$input-padding-hor;\n    padding-right: $input-padding-hor;\n  }\n\n  .dito-buttons--toolbar {\n    margin: 0;\n  }\n\n  h1,\n  h2,\n  h3,\n  p,\n  ul,\n  ol,\n  pre,\n  blockquote {\n    margin: 1rem 0;\n\n    &:first-child {\n      margin-top: 0;\n    }\n\n    &:last-child {\n      margin-bottom: 0;\n    }\n  }\n\n  h1,\n  h2,\n  h3 {\n    font-weight: bold;\n  }\n\n  h1 {\n    font-size: 1.4rem;\n  }\n\n  h2 {\n    font-size: 1.2rem;\n  }\n\n  ul {\n    list-style: disc;\n  }\n\n  code {\n    font-family: $font-family-mono;\n  }\n\n  pre {\n    padding: 0.7rem 1rem;\n    border-radius: $border-radius;\n    background: $color-darker;\n    color: $color-white;\n    overflow-x: auto;\n\n    code {\n      display: block;\n    }\n  }\n\n  p code {\n    display: inline-block;\n    padding: 0 0.3rem;\n    border-radius: $border-radius;\n    background: $color-lighter;\n  }\n\n  a {\n    pointer-events: none;\n    cursor: default;\n    color: blue;\n    text-decoration: underline;\n  }\n\n  ul,\n  ol {\n    padding-left: 2rem;\n  }\n\n  li {\n    & > p,\n    & > ol,\n    & > ul {\n      margin: 0;\n    }\n  }\n\n  blockquote {\n    border-left: 3px solid $color-lighter;\n    padding-left: 1em;\n    font-style: italic;\n\n    p {\n      margin: 0;\n    }\n  }\n\n  ol.footnotes {\n    margin-top: 1em;\n    padding: 1em 0;\n    list-style-type: decimal;\n    padding-left: 2em;\n\n    &:has(li) {\n      border-top: 1px solid $color-light;\n    }\n  }\n}\n</style>\n","<template lang=\"pug\">\n.dito-multiselect\n  .dito-multiselect__inner\n    DitoAffixes(\n      :items=\"schema.prefix\"\n      position=\"prefix\"\n      mode=\"input\"\n      absolute\n      :disabled=\"disabled\"\n      :parentContext=\"context\"\n    )\n    VueMultiselect(\n      ref=\"element\"\n      v-model=\"selectedOptions\"\n      :class=\"multiselectClasses\"\n      :showLabels=\"false\"\n      :placeholder=\"placeholder\"\n      tagPlaceholder=\"Press enter to add new tag\"\n      :options=\"populate && activeOptions || []\"\n      :customLabel=\"getLabelForOption\"\n      :trackBy=\"optionValue\"\n      :groupLabel=\"groupByLabel\"\n      :groupValues=\"groupByOptions\"\n      :multiple=\"multiple\"\n      :taggable=\"taggable\"\n      :searchable=\"searchable\"\n      :internalSearch=\"!searchFilter\"\n      :preserveSearch=\"!!searchFilter\"\n      :clearOnSelect=\"!searchFilter\"\n      :closeOnSelect=\"!stayOpen\"\n      :loading=\"isLoading\"\n      v-bind=\"attributes\"\n      @open=\"onOpen\"\n      @close=\"onClose\"\n      @tag=\"onAddTag\"\n      @search-change=\"onSearchChange\"\n    )\n    DitoAffixes(\n      :items=\"schema.suffix\"\n      position=\"suffix\"\n      mode=\"input\"\n      absolute\n      :clearable=\"showClearButton\"\n      :disabled=\"disabled\"\n      :inlineInfo=\"inlineInfo\"\n      :parentContext=\"context\"\n      @clear=\"clear\"\n    )\n  //- Edit button is never disabled, even if the field is disabled.\n  DitoEditButtons(\n    v-if=\"editable\"\n    :schema=\"schema\"\n    :dataPath=\"dataPath\"\n    :data=\"data\"\n    :meta=\"meta\"\n    :store=\"store\"\n    :disabled=\"false\"\n    :editable=\"editable\"\n    :editPath=\"editPath\"\n  )\n</template>\n\n<script>\nimport DitoTypeComponent from '../DitoTypeComponent.js'\nimport DitoContext from '../DitoContext.js'\nimport TypeMixin from '../mixins/TypeMixin.js'\nimport OptionsMixin from '../mixins/OptionsMixin.js'\nimport DitoAffixes from '../components/DitoAffixes.vue'\nimport VueMultiselect from 'vue-multiselect'\nimport { getSchemaAccessor } from '../utils/accessor.js'\nimport { isBoolean } from '@ditojs/utils'\n\n// @vue/component\nexport default DitoTypeComponent.register('multiselect', {\n  mixins: [OptionsMixin],\n  components: { DitoAffixes, VueMultiselect },\n\n  data() {\n    return {\n      searchedOptions: null,\n      populate: false\n    }\n  },\n\n  computed: {\n    selectedOptions: {\n      get() {\n        return this.multiple\n          ? (this.selectedValue || [])\n              .map(\n                // If an option cannot be found, we may be in taggable mode and\n                // can add it.\n                value => (\n                  this.getOptionForValue(value) || this.addTagOption(value)\n                )\n              )\n              // Filter out options that we couldn't match.\n              // TODO: Should we display an error instead?\n              .filter(Boolean)\n          : this.selectedOption\n      },\n\n      set(option) {\n        // Convert value to options object, since vue-multiselect can't map that\n        // itself unfortunately. `track-by` is used for :key mapping it seems.\n        this.selectedValue = this.multiple\n          ? (option || []).map(value => this.getValueForOption(value))\n          : this.getValueForOption(option)\n        this.onChange()\n      }\n    },\n\n    activeOptions() {\n      return this.searchedOptions || this.options\n    },\n\n    // @override\n    multiple: getSchemaAccessor('multiple', {\n      type: Boolean,\n      default: false\n    }),\n\n    searchable: getSchemaAccessor('searchable', {\n      type: Boolean,\n      default: false\n    }),\n\n    taggable: getSchemaAccessor('taggable', {\n      type: Boolean,\n      default: false\n    }),\n\n    stayOpen: getSchemaAccessor('stayOpen', {\n      type: Boolean,\n      default: false\n    }),\n\n    multiselectClasses() {\n      const prefix = 'multiselect'\n      return {\n        [`${prefix}--multiple`]: this.multiple,\n        [`${prefix}--loading`]: this.isLoading,\n        [`${prefix}--highlight`]: this.showHighlight\n      }\n    },\n\n    placeholder() {\n      let { placeholder, searchable, taggable } = this.schema\n      if (isBoolean(placeholder)) {\n        placeholder = placeholder ? undefined : null\n      }\n      return placeholder === undefined\n        ? searchable && taggable\n          ? `Search or add a ${this.label}`\n          : searchable\n            ? `Select or search ${this.label}`\n            : undefined\n        : placeholder\n    },\n\n    showHighlight() {\n      return this.isMounted && this.$refs.element.pointerDirty\n    }\n  },\n\n  mounted() {\n    if (this.autofocus) {\n      // vue-multiselect doesn't support the autofocus attribute. We need to\n      // handle it here.\n      this.focus()\n    }\n  },\n\n  methods: {\n    addTagOption(tag) {\n      if (this.taggable) {\n        const { optionLabel, optionValue } = this\n        const option =\n          optionLabel && optionValue\n            ? {\n                [optionLabel]: tag,\n                // TODO: Define a simple schema option to convert the tag value\n                // to something else, e.g. `toTag: tag => underscore(tag)`\n                [optionValue]: tag\n              }\n            : tag\n        this.options.push(option)\n        return option\n      }\n    },\n\n    focusElement() {\n      this.$refs.element.activate()\n    },\n\n    blurElement() {\n      this.$refs.element.deactivate()\n    },\n\n    onOpen() {\n      this.populate = true\n    },\n\n    onClose() {\n      // Since we don't fire blur events while the multiselect is open (see\n      // below), we need to do it here, when it's actually closed.\n      if (this.focused) {\n        this.onBlur()\n      }\n    },\n\n    onBlur() {\n      if (!this.$refs.element.isOpen) {\n        TypeMixin.methods.onBlur.call(this)\n      }\n    },\n\n    onAddTag(tag) {\n      const option = this.addTagOption(tag)\n      if (option) {\n        this.value ??= []\n        this.value.push(this.getValueForOption(option))\n      }\n    },\n\n    async onSearchChange(searchTerm) {\n      if (this.searchFilter) {\n        if (searchTerm) {\n          // Set `searchedOptions` to an empty array, before it will be\n          // populated asynchronously with the actual results.\n          this.searchedOptions = []\n          this.searchedOptions = await this.resolveData(\n            () => this.searchFilter(new DitoContext(this, { searchTerm }))\n          )\n        } else {\n          // Clear `searchedOptions` when the query is cleared.\n          this.searchedOptions = null\n        }\n      }\n    }\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n@import 'vue-multiselect/dist/vue-multiselect.css';\n\n$spinner-width: $select-arrow-width;\n$tag-icon-width: 1.8em;\n$tag-margin: 2px;\n$tag-padding: 3px;\n$tag-line-height: 1em;\n\n.dito-multiselect {\n  display: inline-flex;\n  position: relative;\n\n  &__inner {\n    flex: 1;\n    position: relative;\n    display: flex;\n    align-items: center;\n  }\n\n  .dito-edit-buttons {\n    margin-left: $form-spacing-half;\n  }\n\n  .multiselect {\n    $self: last-selector(&);\n\n    --input-width: 100%;\n\n    font-size: inherit;\n    min-height: inherit;\n    color: $color-black;\n\n    &--multiple {\n      --input-width: auto;\n    }\n\n    &__tags {\n      display: flex;\n      font-size: inherit;\n      min-height: inherit;\n      overflow: auto;\n      padding: 0 $spinner-width 0 0;\n      // So tags can float on multiple lines and have proper margins:\n      padding-bottom: $tag-margin;\n\n      .dito-container--has-errors & {\n        border-color: $color-error;\n      }\n    }\n\n    &__tag {\n      float: left;\n      margin: $tag-margin 0 0 $tag-margin;\n      border-radius: 1em;\n      padding: $tag-padding $tag-icon-width $tag-padding 0.8em;\n      line-height: $tag-line-height;\n      height: calc($input-height - 2 * $tag-padding);\n    }\n\n    &__tags-wrap {\n      overflow: auto;\n      line-height: 0;\n    }\n\n    &__single,\n    &__placeholder,\n    &__input {\n      @include ellipsis;\n\n      flex: 1 0 0%;\n      width: 0;\n      min-height: 0;\n      margin: 0 0 1px 0;\n      font-size: inherit;\n      line-height: inherit;\n      // Sadly, vue-select sets style=\"padding: ...;\" in addition to using\n      // classes, so `!important` is necessary:\n      padding: $input-padding !important;\n      // So input can float next to tags and have proper margins with\n      // &__tags:\n      padding-bottom: 0 !important;\n      background: none;\n    }\n\n    &__placeholder,\n    &__input::placeholder {\n      color: $color-placeholder;\n    }\n\n    &__placeholder {\n      &::after {\n        // Enforce actual line-height for positioning.\n        content: '\\200b';\n      }\n    }\n\n    &__select,\n    &__spinner {\n      padding: 0;\n      // $border-width to prevent masking border with &__spinner\n      top: $border-width;\n      right: $border-width;\n      bottom: $border-width;\n      height: inherit;\n      border-radius: $border-radius;\n    }\n\n    &__select {\n      width: $select-arrow-width;\n\n      &::before {\n        @include arrow($select-arrow-size);\n\n        bottom: $select-arrow-bottom;\n        right: $select-arrow-right;\n      }\n    }\n\n    &__spinner {\n      width: $spinner-width;\n\n      &::before,\n      &::after {\n        // Change the width of the loading spinner\n        border-width: 3px;\n        border-top-color: $color-active;\n        inset: 0;\n        margin: auto;\n      }\n    }\n\n    &__option {\n      $option: last-selector(&);\n\n      min-height: unset;\n      height: unset;\n      line-height: $line-height;\n      padding: $input-padding;\n\n      &::after {\n        // Instruction text for options (e.g. \"Press enter to add new tag\")\n        position: static;\n        height: auto;\n        line-height: inherit;\n        padding-left: $input-padding-hor;\n      }\n\n      // Only show the highlight once the pulldown has received mouse or\n      // keyboard interaction, in which case `&--highlight` will be set,\n      // which is controlled by `pointerDirty` in vue-multiselect.\n      // Until then, clear the highlight style, but only if it isn't also\n      // disabled or selected, in which case we want to keep the style.\n      @at-root #{$self}:not(#{$self}--highlight)\n          #{$option}:not(#{$option}--disabled):not(#{$option}--selected) {\n        color: $color-text;\n        background: transparent;\n      }\n\n      &--highlight {\n        &::after {\n          background: transparent;\n          color: $color-white;\n        }\n\n        @at-root #{$self}#{$self}--highlight #{last-selector(&)} {\n          color: $color-text-inverted;\n          background: $color-active;\n        }\n      }\n\n      &--selected {\n        font-weight: normal;\n        color: $color-text;\n        background: $color-highlight;\n\n        @at-root #{$self}#{$self}--highlight &#{$option}--highlight {\n          color: $color-text-inverted;\n        }\n      }\n\n      &--disabled {\n        background: none;\n        color: $color-disabled;\n      }\n    }\n\n    &__tag {\n      color: $color-text-inverted;\n      background: $color-active;\n    }\n\n    &__tag-icon {\n      background: none;\n      border-radius: 1em;\n      width: $tag-icon-width;\n      margin: 0;\n\n      &::after {\n        @extend %icon-clear;\n\n        font-size: 0.9em;\n        color: $color-text-inverted;\n      }\n\n      &:hover::after {\n        color: $color-text;\n      }\n    }\n\n    &__tags,\n    &__content-wrapper {\n      border: $border-style;\n      border-radius: $border-radius;\n    }\n\n    &__content-wrapper {\n      z-index: $z-index-popup;\n      border-color: $color-active;\n    }\n\n    &:not(&--above) #{$self}__content-wrapper {\n      margin: (-$border-width) 0 0;\n      border-top-color: $border-color;\n      border-top-left-radius: 0;\n      border-top-right-radius: 0;\n    }\n\n    &--above #{$self}__content-wrapper {\n      margin: 0 0 (-$border-width);\n      border-bottom-color: $border-color;\n      border-bottom-left-radius: 0;\n      border-bottom-right-radius: 0;\n    }\n\n    &--active {\n      #{$self}__placeholder {\n        // Don't use `display: none` to hide place-holder, as the layout would\n        // collapse.\n        display: inline-block;\n        visibility: hidden;\n      }\n\n      #{$self}__single,\n      #{$self}__input {\n        // Sadly, vue-select sets `style=\"width\"` in addition to using classes\n        // so `!important` is necessary:\n        width: var(--input-width) !important;\n      }\n\n      #{$self}__tags {\n        border-color: $color-active;\n        border-bottom-left-radius: 0;\n        border-bottom-right-radius: 0;\n      }\n\n      &#{$self}--above {\n        #{$self}__tags {\n          border-radius: $border-radius;\n          border-top-left-radius: 0;\n          border-top-right-radius: 0;\n        }\n      }\n    }\n\n    &--loading {\n      #{$self}__tags {\n        border-radius: $border-radius;\n      }\n\n      #{$self}__content-wrapper {\n        display: none;\n      }\n    }\n  }\n}\n</style>\n","import { getSchemaAccessor } from '../utils/accessor.js'\nimport { isArray } from '@ditojs/utils'\n\n// @vue/component\nexport default {\n  computed: {\n    inputValue: {\n      get() {\n        return this.value !== null ? this.value : ''\n      },\n\n      set(value) {\n        this.value =\n          value !== ''\n            ? this.isInteger\n              ? Number(value)\n              : parseFloat(value)\n            : null\n      }\n    },\n\n    // @overridable\n    isInteger() {\n      return false\n    },\n\n    stepValue() {\n      // Don't show steps if the input is also clearable, since the step buttons\n      // would collide with the clear button.\n      return this.step == null && !this.isInteger\n        ? 'any'\n        : this.step\n    },\n\n    decimals: getSchemaAccessor('decimals', {\n      type: Number\n    }),\n\n    step: getSchemaAccessor('step', {\n      type: Number,\n      get(step) {\n        // For integers, round the steps to the next bigger integer value:\n        return this.isInteger && step != null ? Math.ceil(step) : step\n      }\n    }),\n\n    min: getSchemaAccessor('min', {\n      type: Number,\n      get(min) {\n        min =\n          min === undefined\n            ? this.getSchemaValue('range', { type: Array })?.[0]\n            : min\n        return this.isInteger && min != null ? Math.floor(min) : min\n      }\n    }),\n\n    max: getSchemaAccessor('max', {\n      type: Number,\n      get(max) {\n        max =\n          max === undefined\n            ? this.getSchemaValue('range', { type: Array })?.[1]\n            : max\n        return this.isInteger && max != null ? Math.ceil(max) : max\n      }\n    }),\n\n    range: getSchemaAccessor('range', {\n      type: Array,\n      get() {\n        // `this.min`, `this.max` already support `schema.range`,\n        // so redirect there.\n        const { min, max } = this\n        return min != null && max != null ? [min, max] : undefined\n      },\n\n      set(range) {\n        // Provide a setter that delegates to `[this.min, this.max]`,\n        // since those already handle `schema.range`.\n        if (isArray(range)) {\n          ;[this.min, this.max] = range\n        }\n      }\n    })\n  },\n\n  methods: {\n    getValidations() {\n      const validations = {}\n      const { range, min, max, decimals, step } = this\n      if (range) {\n        validations.range = range\n      } else {\n        if (min != null) {\n          validations.min = min\n        }\n        if (max != null) {\n          validations.max = max\n        }\n      }\n      if (decimals != null) {\n        validations.decimals = decimals\n      } else if (step) {\n        const decimals = (`${step}`.split('.')[1] || '').length\n        if (decimals > 0) {\n          validations.decimals = decimals\n        } else {\n          validations.integer = true\n        }\n      }\n      if (this.isInteger) {\n        validations.integer = true\n      }\n      return validations\n    }\n  }\n}\n","<template lang=\"pug\">\nDitoInput.dito-number(\n  :id=\"dataPath\"\n  ref=\"element\"\n  v-model=\"inputValue\"\n  type=\"number\"\n  v-bind=\"attributes\"\n  :min=\"min\"\n  :max=\"max\"\n  :step=\"stepValue\"\n)\n  template(#prefix)\n    DitoAffixes(\n      :items=\"schema.prefix\"\n      position=\"prefix\"\n      mode=\"input\"\n      :disabled=\"disabled\"\n      :parentContext=\"context\"\n    )\n  template(#suffix)\n    DitoAffixes(\n      :items=\"schema.suffix\"\n      position=\"suffix\"\n      mode=\"input\"\n      :clearable=\"showClearButton\"\n      :disabled=\"disabled\"\n      :inlineInfo=\"inlineInfo\"\n      :parentContext=\"context\"\n      @clear=\"clear\"\n    )\n</template>\n\n<script>\nimport DitoTypeComponent from '../DitoTypeComponent.js'\nimport NumberMixin from '../mixins/NumberMixin.js'\nimport DitoAffixes from '../components/DitoAffixes.vue'\nimport { DitoInput } from '@ditojs/ui/src'\n\nexport default DitoTypeComponent.register(\n  ['number', 'integer'],\n  // @vue/component\n  {\n    mixins: [NumberMixin],\n    components: { DitoInput, DitoAffixes },\n    nativeField: true,\n    textField: true,\n\n    computed: {\n      isInteger() {\n        return this.type === 'integer'\n      }\n    }\n  }\n)\n</script>\n\n<style lang=\"scss\">\n// Only show spin buttons if the number component defines a step size.\ninput[type='number']:not([step]) {\n  &::-webkit-inner-spin-button,\n  &::-webkit-outer-spin-button {\n    -webkit-appearance: none;\n    margin: 0;\n  }\n}\n</style>\n","<template lang=\"pug\">\n.dito-object(\n  v-if=\"isReady\"\n  :id=\"dataPath\"\n)\n  .dito-object-content(\n    v-if=\"objectData\"\n  )\n    //- Support the same rendering options as TypeList:\n    DitoSchemaInlined(\n      v-if=\"isInlined\"\n      :label=\"objectLabel\"\n      :schema=\"getItemFormSchema(schema, objectData, context)\"\n      :dataPath=\"dataPath\"\n      :data=\"objectData\"\n      :meta=\"nestedMeta\"\n      :store=\"store\"\n      :disabled=\"disabled || isLoading\"\n      :collapsed=\"collapsed\"\n      :collapsible=\"collapsible\"\n      :deletable=\"objectData && deletable\"\n      :editable=\"objectData && editable\"\n      :editPath=\"path\"\n      :accumulatedBasis=\"accumulatedBasis\"\n      @delete=\"deleteItem(objectData)\"\n    )\n    component(\n      v-else-if=\"schema.component\"\n      :is=\"schema.component\"\n      :dataPath=\"dataPath\"\n      :data=\"objectData\"\n      :nested=\"false\"\n    )\n    span(\n      v-else-if=\"render\"\n      v-html=\"render(getContext())\"\n    )\n    span(\n      v-else\n      v-html=\"getItemLabel(schema, objectData)\"\n    )\n  //- NOTE: `DitoEditButtons` here only handle the create button outside of the\n  //- schema, the edit buttons inside are handled by `DitoSchemaInlined`.\n  DitoEditButtons(\n    :buttons=\"buttonSchemas\"\n    :schema=\"schema\"\n    :dataPath=\"dataPath\"\n    :data=\"objectData\"\n    :path=\"path\"\n    :meta=\"meta\"\n    :store=\"store\"\n    :disabled=\"disabled || isLoading\"\n    :creatable=\"creatable\"\n    :createPath=\"createPath\"\n  )\n</template>\n\n<script>\nimport DitoTypeComponent from '../DitoTypeComponent.js'\nimport DitoContext from '../DitoContext.js'\nimport SourceMixin from '../mixins/SourceMixin.js'\nimport { resolveSchemaComponent } from '../utils/schema.js'\n\n// @vue/component\nexport default DitoTypeComponent.register('object', {\n  mixins: [SourceMixin],\n\n  getSourceType(type) {\n    // No need for transformation here. See TypeTreeList for details.\n    return type\n  },\n\n  computed: {\n    objectLabel() {\n      // Only show a label if the object is collapsible.\n      return this.collapsible\n        ? this.getItemLabel(this.schema, this.objectData, { asObject: true })\n        : null\n    }\n  },\n\n  methods: {\n    getContext() {\n      return new DitoContext(this, { data: this.objectData })\n    }\n  },\n\n  async processSchema(\n    api,\n    schema,\n    name,\n    routes,\n    level,\n    nested = false,\n    flatten = false,\n    process = null\n  ) {\n    await Promise.all([\n      resolveSchemaComponent(schema),\n      SourceMixin.processSchema(\n        api,\n        schema,\n        name,\n        routes,\n        level,\n        nested,\n        flatten,\n        process\n      )\n    ])\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-object {\n  display: flex;\n  border: $border-style;\n  border-radius: $border-radius;\n  margin: 0;\n  padding: $form-spacing;\n  box-sizing: border-box;\n  min-width: min-content;\n\n  .dito-object-content {\n    flex: 0 1 100%;\n  }\n\n  > .dito-edit-buttons {\n    flex: 1 0 0%;\n    margin-left: $form-spacing;\n  }\n}\n</style>\n","<script>\nimport DitoTypeComponent from '../DitoTypeComponent.js'\n\n// @vue/component\nexport default DitoTypeComponent.register('panel', {\n  defaultValue: () => undefined, // Callback to override `defaultValue: null`\n  excludeValue: true,\n  generateLabel: false,\n  omitSpacing: true,\n\n  getPanelSchema(api, schema) {\n    // For a TypePanel, the component schema is also the panel schema, but\n    // remove the added name, so it doesn't get appended twice to data-path.\n    const { name, ...panel } = schema\n    return panel\n  }\n})\n</script>\n","<template lang=\"pug\">\nprogress.dito-progress(\n  :id=\"dataPath\"\n  ref=\"element\"\n  :value=\"progressValue\"\n  :max=\"progressMax\"\n  v-bind=\"attributes\"\n)\n</template>\n\n<script>\nimport DitoTypeComponent from '../DitoTypeComponent.js'\nimport NumberMixin from '../mixins/NumberMixin.js'\n\n// @vue/component\nexport default DitoTypeComponent.register('progress', {\n  mixins: [NumberMixin],\n  computed: {\n    progressValue() {\n      let { value, range, step } = this\n      if (value !== null) {\n        if (range) {\n          value -= range[0]\n        }\n        if (step) {\n          value = Math.round(value / step) * step\n        }\n      } else {\n        value = ''\n      }\n      return value\n    },\n\n    progressMax() {\n      const { range } = this\n      return range ? range[1] - range[0] : null\n    }\n  }\n})\n</script>\n","<template lang=\"pug\">\nul.dito-radio-buttons(\n  :id=\"dataPath\"\n  :class=\"`dito-layout--${schema.layout || 'vertical'}`\"\n)\n  li(\n    v-for=\"option in options\"\n  )\n    label\n      input.dito-radio-button(\n        ref=\"element\"\n        v-model=\"selectedValue\"\n        type=\"radio\"\n        :value=\"getValueForOption(option)\"\n        v-bind=\"attributes\"\n      )\n      | {{ getLabelForOption(option) }}\n</template>\n\n<script>\nimport DitoTypeComponent from '../DitoTypeComponent.js'\nimport OptionsMixin from '../mixins/OptionsMixin.js'\n\n// @vue/component\nexport default DitoTypeComponent.register('radio', {\n  mixins: [OptionsMixin],\n\n  nativeField: true,\n  defaultWidth: 'auto'\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-radio-buttons {\n  label {\n    @extend %input-borderless;\n  }\n\n  .dito-radio-button {\n    margin-right: $form-spacing;\n  }\n}\n</style>\n","<template lang=\"pug\">\n.dito-section(:class=\"{ 'dito-section--labelled': hasLabel }\")\n  DitoSchemaInlined.dito-section__schema(\n    :schema=\"getItemFormSchema(schema, item, context)\"\n    :dataPath=\"dataPath\"\n    :data=\"item\"\n    :meta=\"meta\"\n    :store=\"store\"\n    :label=\"label\"\n    :info=\"info\"\n    :padding=\"hasLabel ? 'nested' : 'inlined'\"\n    :disabled=\"disabled\"\n    :collapsed=\"collapsed\"\n    :collapsible=\"collapsible\"\n    :labelNode=\"labelNode\"\n  )\n</template>\n\n<script>\nimport DitoTypeComponent from '../DitoTypeComponent.js'\nimport { getSchemaAccessor } from '../utils/accessor.js'\nimport { getItemFormSchema, processSchemaComponents } from '../utils/schema.js'\n\n// @vue/component\nexport default DitoTypeComponent.register('section', {\n  defaultValue: () => undefined, // Callback to override `defaultValue: null`\n  ignoreMissingValue: ({ schema }) => !schema.nested && !('default' in schema),\n  defaultNested: false,\n  generateLabel: false,\n\n  computed: {\n    item() {\n      return this.nested ? this.value : this.data\n    },\n\n    hasLabel() {\n      return !!this.schema.label\n    },\n\n    collapsible: getSchemaAccessor('collapsible', {\n      type: Boolean,\n      default: false\n    }),\n\n    collapsed: getSchemaAccessor('collapsed', {\n      type: Boolean,\n      default: false,\n      get(collapsed) {\n        return collapsed && this.collapsible\n      }\n    })\n  },\n\n  methods: {\n    getItemFormSchema\n  },\n\n  async processSchema(api, schema, name, routes, level) {\n    // Process section components so their forms get resolved too.\n    await processSchemaComponents(api, schema, routes, level)\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-section {\n  &--labelled {\n    border: $border-width solid transparent;\n    border-radius: $border-radius;\n    transition: border-color 0.2s $ease-out-quart;\n    margin-top: $form-spacing-half;\n\n    &:has(.dito-schema--open) {\n      border-color: $border-color;\n    }\n  }\n}\n</style>\n","<template lang=\"pug\">\n//- Nesting is needed to make an arrow appear over the select item:\n.dito-select\n  .dito-select__inner\n    DitoAffixes(\n      :items=\"schema.prefix\"\n      position=\"prefix\"\n      mode=\"input\"\n      absolute\n      :disabled=\"disabled\"\n      :parentContext=\"context\"\n    )\n    select(\n      :id=\"dataPath\"\n      ref=\"element\"\n      v-model=\"selectedValue\"\n      v-bind=\"attributes\"\n      @mousedown=\"populate = true\"\n      @focus=\"populate = true\"\n    )\n      template(\n        v-if=\"populate\"\n      )\n        template(\n          v-for=\"option in options\"\n        )\n          optgroup(\n            v-if=\"groupBy\"\n            :label=\"option[groupByLabel]\"\n          )\n            option(\n              v-for=\"opt in option[groupByOptions]\"\n              :value=\"getValueForOption(opt)\"\n            ) {{ getLabelForOption(opt) }}\n          option(\n            v-else\n            :value=\"getValueForOption(option)\"\n          ) {{ getLabelForOption(option) }}\n      template(\n        v-else-if=\"selectedOption\"\n      )\n        option(:value=\"selectedValue\") {{ getLabelForOption(selectedOption) }}\n    DitoAffixes(\n      :items=\"schema.suffix\"\n      position=\"suffix\"\n      mode=\"input\"\n      absolute\n      :clearable=\"showClearButton\"\n      :disabled=\"disabled\"\n      :inlineInfo=\"inlineInfo\"\n      :parentContext=\"context\"\n      @clear=\"clear\"\n    )\n  //- Edit button is never disabled, even if the field is disabled.\n  DitoEditButtons(\n    v-if=\"editable\"\n    :schema=\"schema\"\n    :dataPath=\"dataPath\"\n    :data=\"data\"\n    :meta=\"meta\"\n    :store=\"store\"\n    :disabled=\"false\"\n    :editable=\"editable\"\n    :editPath=\"editPath\"\n  )\n</template>\n\n<script>\nimport DitoTypeComponent from '../DitoTypeComponent.js'\nimport OptionsMixin from '../mixins/OptionsMixin.js'\nimport DitoAffixes from '../components/DitoAffixes.vue'\n\n// @vue/component\nexport default DitoTypeComponent.register('select', {\n  mixins: [OptionsMixin],\n  components: { DitoAffixes },\n\n  nativeField: true,\n\n  data() {\n    return {\n      // Disable lazy-population for now.\n      // TODO: Set to `false` Once lineto e2e tests address their issues.\n      populate: true\n    }\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-select {\n  display: inline-flex;\n  position: relative;\n\n  select {\n    @extend %input;\n\n    padding-right: $select-arrow-width;\n  }\n\n  // `&___inner` is needed to make the edit buttons appear to the right of the\n  // select:\n  &__inner {\n    flex: 1;\n    position: relative;\n\n    &::before {\n      @include arrow($select-arrow-size);\n\n      position: absolute;\n      bottom: $select-arrow-bottom;\n      right: $select-arrow-right;\n\n      .dito-container--disabled & {\n        border-color: $color-disabled;\n      }\n    }\n  }\n\n  .dito-edit-buttons {\n    margin-left: $form-spacing-half;\n  }\n\n  // Handle width fill separately due to required nesting of select:\n  &.dito-component--fill {\n    select {\n      width: 100%;\n    }\n  }\n}\n</style>\n","<template lang=\"pug\">\n.dito-slider\n  input.dito-range(\n    :id=\"dataPath\"\n    ref=\"element\"\n    v-model=\"inputValue\"\n    type=\"range\"\n    v-bind=\"attributes\"\n    :min=\"min\"\n    :max=\"max\"\n    :step=\"stepValue\"\n  )\n  DitoInput.dito-number(\n    v-if=\"input\"\n    v-model=\"inputValue\"\n    type=\"number\"\n    v-bind=\"attributes\"\n    :min=\"min\"\n    :max=\"max\"\n    :step=\"stepValue\"\n  )\n</template>\n\n<script>\nimport DitoTypeComponent from '../DitoTypeComponent.js'\nimport NumberMixin from '../mixins/NumberMixin.js'\nimport { getSchemaAccessor } from '../utils/accessor.js'\nimport { DitoInput } from '@ditojs/ui/src'\n\n// @vue/component\nexport default DitoTypeComponent.register('slider', {\n  mixins: [NumberMixin],\n  components: { DitoInput },\n  nativeField: true,\n\n  computed: {\n    // TODO: Rename to `showInput`?\n    input: getSchemaAccessor('input', {\n      type: Boolean,\n      default: true\n    })\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-slider {\n  @extend %input;\n\n  display: flex;\n\n  .dito-range {\n    flex: auto;\n    height: calc(1em * var(--line-height));\n  }\n\n  .dito-number {\n    border: 0;\n    padding: 0;\n    text-align: right;\n    font-variant-numeric: tabular-nums;\n  }\n}\n</style>\n","<!-- eslint-disable vue/valid-template-root -->\n<template lang=\"pug\"></template>\n<script>\nimport DitoTypeComponent from '../DitoTypeComponent.js'\n// @vue/component\nexport default DitoTypeComponent.register('spacer', {\n  defaultValue: () => undefined, // Callback to override `defaultValue: null`\n  excludeValue: true,\n  generateLabel: false\n})\n</script>\n","<template lang=\"pug\">\nDitoSwitch.dito-switch(\n  :id=\"dataPath\"\n  ref=\"element\"\n  v-model=\"value\"\n  :labels=\"labels\"\n  v-bind=\"attributes\"\n)\n</template>\n\n<script>\nimport DitoTypeComponent from '../DitoTypeComponent.js'\nimport { DitoSwitch } from '@ditojs/ui/src'\n\n// @vue/component\nexport default DitoTypeComponent.register('switch', {\n  defaultValue: false,\n  defaultWidth: 'auto',\n\n  components: {\n    DitoSwitch\n  },\n\n  computed: {\n    labels() {\n      return this.schema.labels\n    }\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-switch {\n  .dito-switch-label {\n    font-size: $font-size-small;\n  }\n}\n</style>\n","import { isString } from '@ditojs/utils'\nimport { getDefaultValue } from '../utils/schema.js'\nimport { getSchemaAccessor } from '../utils/accessor.js'\n\n// @vue/component\nexport default {\n  computed: {\n    trim: getSchemaAccessor('trim', {\n      type: Boolean,\n      default: false\n    })\n  },\n\n  processValue(context) {\n    let { schema, value } = context\n    if (schema.trim && value != null && isString(value)) {\n      // Text fields don't necessarily have a `String` value when `format()`\n      // without `parse()` is used.\n      value = value.trim()\n    }\n    if (value === '') {\n      value = getDefaultValue(schema, context)\n    }\n    return value\n  }\n}\n","<template lang=\"pug\">\nDitoInput.dito-text(\n  :id=\"dataPath\"\n  ref=\"element\"\n  v-model=\"inputValue\"\n  :type=\"inputType\"\n  v-bind=\"attributes\"\n)\n  template(#prefix)\n    DitoAffixes(\n      :items=\"schema.prefix\"\n      position=\"prefix\"\n      mode=\"input\"\n      :disabled=\"disabled\"\n      :parentContext=\"context\"\n    )\n  template(#suffix)\n    DitoAffixes(\n      :items=\"schema.suffix\"\n      position=\"suffix\"\n      mode=\"input\"\n      :clearable=\"showClearButton\"\n      :disabled=\"disabled\"\n      :inlineInfo=\"inlineInfo\"\n      :parentContext=\"context\"\n      @clear=\"clear\"\n    )\n</template>\n\n<script>\nimport DitoTypeComponent from '../DitoTypeComponent.js'\nimport TextMixin from '../mixins/TextMixin'\nimport DitoAffixes from '../components/DitoAffixes.vue'\nimport { DitoInput } from '@ditojs/ui/src'\n\nconst maskedPassword = '****************'\n\nexport default DitoTypeComponent.register(\n  [\n    'text',\n    'email',\n    'url',\n    'hostname',\n    'domain',\n    'tel',\n    'password',\n    'creditcard'\n  ],\n  // @vue/component\n  {\n    mixins: [TextMixin],\n    components: { DitoInput, DitoAffixes },\n    nativeField: true,\n    textField: true,\n    ignoreMissingValue: ({ schema }) => schema.type === 'password',\n\n    computed: {\n      inputType() {\n        return (\n          {\n            creditcard: 'text',\n            hostname: 'text',\n            domain: 'text'\n          }[this.type] ||\n          this.type\n        )\n      },\n\n      inputValue: {\n        get() {\n          return (\n            this.type === 'password' &&\n            this.value === undefined &&\n            !this.focused\n          )\n            ? maskedPassword\n            : this.value\n        },\n\n        set(value) {\n          this.value = value\n        }\n      }\n    },\n\n    methods: {\n      getValidations() {\n        const rule = {\n          email: 'email',\n          url: 'url',\n          hostname: 'hostname',\n          domain: 'domain',\n          password: 'password',\n          creditcard: 'creditcard'\n        }[this.type]\n        return rule ? { [rule]: true } : {}\n      }\n    }\n  }\n)\n</script>\n","<template lang=\"pug\">\ntextarea.dito-textarea.dito-input(\n  :id=\"dataPath\"\n  ref=\"element\"\n  v-model=\"value\"\n  v-bind=\"attributes\"\n  :rows=\"lines\"\n  :class=\"{ 'dito-textarea--resizable': resizable }\"\n)\n</template>\n\n<script>\nimport DitoTypeComponent from '../DitoTypeComponent.js'\nimport TextMixin from '../mixins/TextMixin'\nimport { getSchemaAccessor } from '../utils/accessor.js'\n\n// @vue/component\nexport default DitoTypeComponent.register('textarea', {\n  mixins: [TextMixin],\n  nativeField: true,\n  textField: true,\n\n  computed: {\n    lines() {\n      return this.schema.lines || 4\n    },\n\n    resizable: getSchemaAccessor('resizable', {\n      type: Boolean,\n      default: false\n    })\n  }\n})\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-textarea {\n  display: block;\n  resize: none;\n  min-height: calc(1em * var(--line-height) + #{2 * $input-padding-ver});\n\n  &--resizable {\n    resize: vertical;\n  }\n}\n</style>\n","<template lang=\"pug\">\n.dito-tree-list\n  DitoScopes(\n    v-if=\"scopes\"\n    :query=\"query\"\n    :scopes=\"scopes\"\n  )\n  .dito-tree-panel\n    DitoTreeItem(\n      :schema=\"treeSchema\"\n      :dataPath=\"treeDataPath\"\n      :data=\"treeData\"\n      :draggable=\"draggable\"\n      :open=\"true\"\n      @update:data=\"data => (value = data)\"\n    )\n    .dito-tree-form-container(\n      v-if=\"editPath && hasEditableForms\"\n    )\n      //- Include a router-view for the optional DitoFormInlined\n      RouterView\n</template>\n\n<script>\nimport DitoTypeComponent from '../DitoTypeComponent.js'\nimport SourceMixin from '../mixins/SourceMixin.js'\nimport {\n  hasFormSchema,\n  getFormSchemas,\n  resolveSchemaComponents\n} from '../utils/schema.js'\n\nexport default DitoTypeComponent.register(\n  ['tree-list', 'tree-object'],\n  // @vue/component\n  {\n    mixins: [SourceMixin],\n\n    provide() {\n      return { container: this }\n    },\n\n    getSourceType(type) {\n      return type === 'tree-object' ? 'object' : 'list'\n    },\n\n    computed: {\n      path() {\n        // Accessed from DitoTreeItem through `container.path`:\n        return this.formComponent?.path\n      },\n\n      editPath() {\n        // Accessed from DitoTreeItem through `container.editPath`:\n        const path = this.$route.path.slice(this.path?.length)\n        return path.startsWith(`/${this.schema.path}`) ? path : ''\n      },\n\n      treeData() {\n        return this.isListSource\n          ? { [this.name]: this.value }\n          : this.value\n      },\n\n      treeDataPath() {\n        // Remove `name` from `dataPath`, as it is added\n        // to `treeData` and `treeSchema`\n        return this.isListSource\n          ? this.dataPath.slice(0, this.dataPath.length - this.name.length)\n          : this.dataPath\n      },\n\n      treeSchema() {\n        return this.isListSource\n          ? {\n              children: {\n                name: this.name,\n                ...this.schema\n              }\n            }\n          : this.schema\n      },\n\n      hasEditableForms() {\n        const hasEditableForms = schema => {\n          return (\n            hasFormSchema(schema) && (\n              this.getSchemaValue('editable', {\n                type: Boolean,\n                default: false,\n                schema\n              }) ||\n              schema.children &&\n              hasEditableForms(schema.children)\n            )\n          )\n        }\n        return hasEditableForms(this.schema)\n      }\n    },\n\n    async processSchema(\n      api,\n      schema,\n      name,\n      routes,\n      level,\n      nested = true,\n      flatten = false,\n      process = null\n    ) {\n      await Promise.all([\n        resolveSchemaComponents(schema.properties),\n        SourceMixin.processSchema(\n          api,\n          schema,\n          name,\n          routes,\n          level,\n          nested,\n          flatten,\n          // Pass process() to add more routes to childRoutes:\n          (childRoutes, level) => {\n            const { children } = schema\n            if (children) {\n              // Add `type` to the nested tree list.\n              children.type = 'tree-list'\n              // Recursively call `processSchema()` for the nested tree list:\n              return this.processSchema(\n                api,\n                children,\n                children.name,\n                childRoutes,\n                level,\n                nested,\n                true, // Pass `true` for `flatten` in tree lists.\n                process\n              )\n            }\n          }\n        )\n      ])\n    },\n\n    getFormSchemasForProcessing(schema, context) {\n      // Convert nested children schema to stand-alone schema component,\n      // present in each of the forms, as required by `processSchemaData()`\n      const { children } = schema\n      return getFormSchemas(\n        schema,\n        context,\n        children\n          ? form => ({\n              ...form,\n              components: {\n                ...form.components,\n                [children.name]: children\n              }\n            })\n          : null\n      )\n    }\n  }\n)\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-tree-list {\n  @extend %field;\n\n  .dito-tree-panel {\n    display: flex;\n    justify-content: space-between;\n\n    > .dito-tree-item {\n      flex: 1 1 25%;\n    }\n\n    > .dito-tree-form-container {\n      flex: 0 1 75%;\n      align-self: stretch;\n      background: $content-color-background;\n      border-left: $border-style;\n      border-top-right-radius: $border-radius - 1;\n      border-bottom-right-radius: $border-radius - 1;\n      margin: (-$input-padding-ver) (-$input-padding-hor);\n      margin-left: $input-padding-hor;\n    }\n  }\n}\n</style>\n","import { filesize } from 'filesize'\n\nexport function formatFileSize(size) {\n  return filesize(size, { base: 10 })\n}\n","<template lang=\"pug\">\n.dito-upload\n  //- In order to handle upload buttons in multiple possible places, depending\n  //- on whether they handle single or multiple uploads, render the upload\n  //- component invisibly at the root, and delegate the click events to it from\n  //- the buttons rendered further below. Luckily this works surprisingly well.\n  VueUpload.dito-upload__input(\n    ref=\"upload\"\n    v-model=\"uploads\"\n    :inputId=\"dataPath\"\n    :name=\"dataPath\"\n    :disabled=\"disabled\"\n    :postAction=\"uploadPath\"\n    :extensions=\"extensions\"\n    :accept=\"accept\"\n    :multiple=\"multiple\"\n    :size=\"maxSize\"\n    :drop=\"$el?.closest('.dito-container')\"\n    :dropDirectory=\"true\"\n    @input-filter=\"onInputFilter\"\n    @input-file=\"onInputFile\"\n  )\n  table.dito-table.dito-table--separators.dito-table--background\n    //- Styling comes from `DitoTableHead`\n    thead.dito-table-head\n      tr\n        th\n          span File\n        th\n          span Size\n        th\n          span Status\n        th\n          span\n    DitoDraggable(\n      v-model=\"files\"\n      as=\"tbody\"\n      :options=\"getDraggableOptions()\"\n      :draggable=\"draggable\"\n    )\n      template(\n        v-if=\"multiple || !isUploadActive\"\n      )\n        tr(\n          v-for=\"(file, index) in files\"\n          :key=\"file.name\"\n        )\n          td(\n            v-if=\"render\"\n            v-html=\"renderFile(file, index)\"\n          )\n          td(\n            v-else-if=\"downloadUrls[index]\"\n          )\n            a(\n              :download=\"file.name\"\n              :href=\"downloadUrls[index]\"\n              target=\"_blank\"\n              @click.prevent=\"onClickDownload(file, index)\"\n            )\n              DitoUploadFile(\n                :file=\"file\"\n                :thumbnail=\"thumbnails\"\n                :thumbnailUrl=\"thumbnailUrls[index]\"\n              )\n          td(\n            v-else\n          )\n            DitoUploadFile(\n              :file=\"file\"\n              :thumbnail=\"thumbnails\"\n              :thumbnailUrl=\"thumbnailUrls[index]\"\n            )\n          td.dito-upload__size {{ formatFileSize(file.size) }}\n          td.dito-upload__status\n            template(\n              v-if=\"file.upload\"\n            )\n              template(\n                v-if=\"file.upload.error\"\n              )\n                | Error: {{ file.upload.error }}\n              template(\n                v-else-if=\"file.upload.active\"\n              )\n                | Uploading...\n              template(\n                v-else-if=\"file.upload.success\"\n              )\n                | Uploaded\n            template(\n              v-else\n            )\n              | Stored\n          td.dito-table__buttons\n            .dito-buttons.dito-buttons--round\n              button.dito-button.dito-button--upload(\n                v-if=\"!multiple\"\n                :title=\"uploadTitle\"\n                @click=\"onClickUpload\"\n              )\n              //- Firefox doesn't like <button> here, so use <a> instead:\n              a.dito-button(\n                v-if=\"draggable\"\n                v-bind=\"getButtonAttributes(verbs.drag)\"\n              )\n              button.dito-button(\n                v-if=\"deletable\"\n                type=\"button\"\n                v-bind=\"getButtonAttributes(verbs.delete)\"\n                @click=\"deleteFile(file, index)\"\n              )\n    tfoot(\n      v-if=\"multiple || isUploadActive || !hasFiles\"\n    )\n      tr\n        td(:colspan=\"4\")\n          .dito-upload-footer\n            progress.dito-progress(\n              v-if=\"isUploadActive\"\n              :value=\"uploadProgress\"\n              max=\"100\"\n            )\n            .dito-buttons.dito-buttons--round\n              button.dito-button(\n                v-if=\"isUploadActive\"\n                type=\"button\"\n                @click.prevent=\"upload.active = false\"\n              ) Cancel\n              button.dito-button.dito-button--upload(\n                v-if=\"multiple || !hasFiles\"\n                :title=\"uploadTitle\"\n                @click=\"onClickUpload\"\n              )\n</template>\n\n<script>\nimport DitoTypeComponent from '../DitoTypeComponent.js'\nimport DitoContext from '../DitoContext.js'\nimport SortableMixin from '../mixins/SortableMixin.js'\nimport parseFileSize from 'filesize-parser'\nimport { getSchemaAccessor } from '../utils/accessor.js'\nimport { formatFileSize } from '../utils/units.js'\nimport { appendDataPath } from '../utils/data.js'\nimport { isArray, asArray } from '@ditojs/utils'\nimport VueUpload from 'vue-upload-component'\n\n// @vue/component\nexport default DitoTypeComponent.register('upload', {\n  mixins: [SortableMixin],\n  components: { VueUpload },\n\n  data() {\n    return {\n      uploads: []\n    }\n  },\n\n  computed: {\n    upload() {\n      return this.$refs.upload\n    },\n\n    uploadTitle() {\n      return this.multiple ? 'Upload Files' : 'Upload File'\n    },\n\n    files() {\n      return asFiles(this.value)\n    },\n\n    downloadUrls() {\n      return this.files.map((file, index) => this.getDownloadUrl(file, index))\n    },\n\n    thumbnailUrls() {\n      return this.files.map((file, index) => this.getThumbnailUrl(file, index))\n    },\n\n    multiple: getSchemaAccessor('multiple', {\n      type: Boolean,\n      default: false,\n      // No callback as it's used in `processValue()`\n      callback: false\n    }),\n\n    extensions: getSchemaAccessor('extensions', {\n      type: [Array, String, RegExp]\n    }),\n\n    accept: getSchemaAccessor('accept', {\n      type: Array,\n      get(accept) {\n        return isArray(accept) ? accept.join(',') : accept\n      }\n    }),\n\n    maxSize: getSchemaAccessor('maxSize', {\n      type: [String, Number],\n      get(maxSize) {\n        return maxSize ? parseFileSize(maxSize) : undefined\n      }\n    }),\n\n    draggable: getSchemaAccessor('draggable', {\n      type: Boolean,\n      default: false,\n      get(draggable) {\n        return draggable && this.files.length > 1\n      }\n    }),\n\n    deletable: getSchemaAccessor('deletable', {\n      type: Boolean,\n      default: false\n    }),\n\n    render: getSchemaAccessor('render', {\n      type: Function,\n      default: null\n    }),\n\n    thumbnails: getSchemaAccessor('thumbnails', {\n      type: [Boolean, String],\n      default(thumbnails) {\n        return thumbnails ?? !!this.schema.thumbnailUrl\n      },\n      get(thumbnails) {\n        return thumbnails === true ? 'medium' : thumbnails || null\n      }\n    }),\n\n    hasFiles() {\n      return this.files.length > 0\n    },\n\n    hasUploads() {\n      return this.uploads.length > 0\n    },\n\n    isUploadReady() {\n      return (\n        this.hasUploads &&\n        !(this.upload.active || this.upload.uploaded)\n      )\n    },\n\n    isUploadActive() {\n      return this.hasUploads && this.upload.active\n    },\n\n    uploadProgress() {\n      return (\n        this.uploads.reduce((total, file) => total + +file.progress, 0) /\n        this.uploads.length\n      )\n    },\n\n    uploadPath() {\n      return this.getResourceUrl({\n        type: 'upload',\n        method: 'post',\n        path: this.api.normalizePath(this.dataPath)\n      })\n    }\n  },\n\n  watch: {\n    isUploadReady(ready) {\n      if (ready) {\n        // Auto-upload.\n        this.$nextTick(() => {\n          this.upload.active = true\n        })\n      }\n    }\n  },\n\n  methods: {\n    formatFileSize,\n\n    getFileContext(file, index) {\n      return this.multiple\n        ? new DitoContext(this, {\n            value: file,\n            data: this.files,\n            index,\n            dataPath: appendDataPath(this.dataPath, index)\n          })\n        : this.context\n    },\n\n    renderFile(file, index) {\n      return this.render(this.getFileContext(file, index))\n    },\n\n    getDownloadUrl(file, index) {\n      return file.url\n        ? file.url\n        : !file.upload || file.upload.success\n          ? this.getSchemaValue('downloadUrl', {\n              type: 'String',\n              default: null,\n              context: this.getFileContext(file, index)\n            })\n          : null\n    },\n\n    getThumbnailUrl(file, index) {\n      return !file.upload || file.upload.success\n        ? this.getSchemaValue('thumbnailUrl', {\n            type: 'String',\n            default: null,\n            context: this.getFileContext(file, index)\n          }) || (\n            file.type.startsWith('image/')\n              ? file.url\n              : null\n          )\n        : null\n    },\n\n    deleteFile(file, index) {\n      const { name } = file\n\n      if (\n        file &&\n        window.confirm(\n          `Do you really want to ${this.verbs.remove} ${name}?`\n        )\n      ) {\n        if (this.multiple) {\n          this.value.splice(index, 1)\n        } else {\n          this.value = null\n        }\n        if (file.upload) {\n          this.upload.remove(file.upload)\n        }\n        this.onChange()\n        this.notify({\n          type: 'info',\n          title: 'Successfully Removed',\n          text: `${name} was ${this.verbs.deleted}.`\n        })\n      }\n    },\n\n    getFileIndex(file) {\n      return this.multiple && this.value\n        ? this.value.findIndex(it => it.id === file.id)\n        : -1\n    },\n\n    addFile(file) {\n      if (this.multiple) {\n        if (this.value) {\n          this.value.push(file)\n        } else {\n          this.value = [file]\n        }\n      } else {\n        this.value = file\n      }\n    },\n\n    replaceFile(file, newFile) {\n      if (this.multiple) {\n        const index = this.getFileIndex(file)\n        if (index >= 0) {\n          if (newFile) {\n            this.value[index] = newFile\n          } else {\n            this.value.splice(index, 1)\n          }\n        }\n      } else {\n        this.value = newFile\n      }\n    },\n\n    removeFile(file) {\n      this.replaceFile(file, null)\n    },\n\n    onInputFile(newFile, oldFile) {\n      if (newFile && !oldFile) {\n        const { id, name, size } = newFile\n        this.addFile({ id, name, size, upload: newFile })\n      }\n      if (newFile && oldFile) {\n        const { success, error } = newFile\n        if (success) {\n          this.onChange()\n          const file = newFile.response[0]\n          if (file) {\n            file.upload = newFile\n            // Replace the upload file object with the file object received\n            // from the upload response.\n            this.replaceFile(newFile, file)\n          } else {\n            this.removeFile(newFile)\n          }\n        } else if (error) {\n          this.removeFile(newFile)\n          const text = (\n            {\n              abort: 'Upload aborted',\n              denied: 'Upload denied',\n              extension: `Unsupported file-type: ${newFile.name}`,\n              network: 'Network error encountered during upload',\n              server: 'Server error occurred during upload',\n              size: `File is too large: ${formatFileSize(newFile.size)}`,\n              timeout: 'Timeout occurred during upload'\n            }[error] ||\n            `Unknown File Upload Error: '${error}'`\n          )\n          this.notify({\n            type: 'error',\n            error,\n            title: 'File Upload Error',\n            text\n          })\n        }\n      }\n    },\n\n    onInputFilter(newFile /*, oldFile, prevent */) {\n      const xhr = newFile?.xhr\n      if (this.api.cors?.credentials && xhr && !xhr.withCredentials) {\n        xhr.withCredentials = true\n      }\n    },\n\n    async onClickDownload(file, index) {\n      try {\n        const response = await fetch(this.downloadUrls[index])\n        const blob = await response.blob()\n        this.download({\n          filename: file.name,\n          url: URL.createObjectURL(blob)\n        })\n      } catch (error) {\n        console.error(error)\n      }\n    },\n\n    onClickUpload(event) {\n      // Delegate the click event to the hidden file input.\n      this.upload.$el.querySelector('input').dispatchEvent(\n        new event.constructor(event.type, event)\n      )\n    }\n  },\n\n  processValue({ schema, value }) {\n    // Filter out all newly added files that weren't actually uploaded.\n    const files = asFiles(value)\n      .map(({ upload, ...file }) => (!upload || upload.success ? file : null))\n      .filter(file => file)\n    return schema.multiple ? files : files[0] || null\n  }\n})\n\nfunction asFiles(value) {\n  return value ? asArray(value) : []\n}\n</script>\n\n<style lang=\"scss\">\n@import '../styles/_imports';\n\n.dito-upload {\n  .dito-table {\n    tr,\n    .dito-table__buttons {\n      vertical-align: middle;\n    }\n  }\n\n  &__size,\n  &__status {\n    white-space: nowrap;\n  }\n\n  & &__input {\n    // See `onClickUpload()` method for details.\n    display: block;\n    pointer-events: none;\n  }\n\n  &__footer {\n    display: flex;\n    justify-content: flex-end;\n    align-items: center;\n\n    .dito-progress {\n      flex: auto;\n      margin-right: $form-spacing;\n    }\n  }\n}\n</style>\n","import { asArray } from '@ditojs/utils'\n\nexport default {\n  mounted(node, binding) {\n    observeResize(node, binding.value, binding.arg)\n  },\n\n  unmounted(node, binding) {\n    unobserveResize(node, binding.value, binding.arg)\n  }\n}\n\nexport function observeResize(node, handler, options) {\n  Observer.getObserver(options).observe(node, handler)\n}\n\nexport function unobserveResize(node, handler, options) {\n  Observer.getObserver(options).unobserve(node, handler)\n}\n\nexport const isResizeSupported = typeof ResizeObserver !== 'undefined'\n\nconst observers = {}\n\nclass Observer {\n  constructor(key, options) {\n    this.key = key\n    this.options = options\n    this.observer = isResizeSupported\n      ? new ResizeObserver(entries => this.handle(entries))\n      : null\n    this.handlersByNode = new WeakMap()\n    this.nodeCount = 0\n  }\n\n  observe(node, handler) {\n    let handlers = this.handlersByNode.get(node)\n    if (!handlers) {\n      handlers = new Set()\n      this.handlersByNode.set(node, handlers)\n      this.observer?.observe(node, this.options)\n      this.nodeCount++\n    }\n    handlers.add(handler)\n  }\n\n  unobserve(node, handler) {\n    const handlers = this.handlersByNode.get(node)\n    if (handlers?.delete(handler) && handlers.size === 0) {\n      this.handlersByNode.delete(node)\n      this.observer?.unobserve(node)\n      if (--this.nodeCount === 0) {\n        delete observers[this.key]\n      }\n    }\n  }\n\n  handle(entries) {\n    for (const entry of entries) {\n      const handlers = this.handlersByNode.get(entry.target)\n      if (handlers) {\n        const event = {\n          target: entry.target,\n          contentRect: entry.contentRect,\n          // Use `asArray` since Firefox before v92 returns these as objects:\n          borderBoxSize: asArray(entry.borderBoxSize),\n          contentBoxSize: asArray(entry.contentBoxSize),\n          devicePixelContentBoxSize: asArray(entry.devicePixelContentBoxSize)\n        }\n        for (const handler of handlers) {\n          handler(event)\n        }\n      }\n    }\n  }\n\n  static getObserver({ box = 'content-box' } = {}) {\n    const options = { box }\n    const key = JSON.stringify(options)\n    observers[key] ||= new Observer(key, options)\n    return observers[key]\n  }\n}\n","export default [\n  'create', 'created',\n  'save', 'saved',\n  'apply', 'applied',\n  'submit', 'submitted',\n  'delete', 'deleted',\n  'remove', 'removed',\n  'clear', 'cleared',\n  'edit', 'edited',\n  'close', 'closed',\n  'cancel', 'cancelled',\n  'drag', 'dragged',\n  'login', 'logged in'\n].reduce((verbs, verb) => {\n  verbs[verb] = verb\n  return verbs\n}, {})\n","import { createApp, h as createElement } from 'vue'\nimport { createRouter, createWebHistory } from 'vue-router'\nimport VueNotifications from '@kyvg/vue3-notification'\nimport {\n  isString,\n  isAbsoluteUrl,\n  assignDeeply,\n  hyphenate,\n  camelize,\n  defaultFormats\n} from '@ditojs/utils'\nimport * as components from './components/index.js'\nimport * as types from './types/index.js'\nimport DitoRoot from './components/DitoRoot.vue'\nimport DitoTypeComponent from './DitoTypeComponent.js'\nimport ResizeDirective from './directives/resize.js'\nimport { getResource } from './utils/resource.js'\nimport { formatQuery } from './utils/route.js'\nimport verbs from './verbs.js'\n\nexport default class DitoAdmin {\n  constructor(el, {\n    // `dito` contains the base and api settings passed from `AdminController`\n    dito = {},\n    api,\n    views = {},\n    ...options\n  } = {}) {\n    this.el = el\n    // Merge in `api` settings as passed from `config.admin` and through the\n    // `AdminController` with `api` values from from 'admin/index.js'\n    // NOTE: `AdminController` provides `dito.api.base`\n    this.api = api = assignDeeply({ base: '/' }, dito.api, api)\n    this.options = options\n\n    // Setup default api settings:\n    api.locale ||= 'en-US'\n    api.formats = assignDeeply({}, defaultFormats, api.formats)\n    api.request ||= options => request(api, options)\n    api.getApiUrl ||= options => getApiUrl(api, options)\n    api.isApiUrl ||= url => isApiUrl(api, url)\n    // Setting `api.normalizePaths = true (plural) sets both:\n    // `api.normalizePath = hyphenate` and `api.denormalizePath = camelize`\n    api.normalizePath ||= api.normalizePaths ? hyphenate : val => val\n    api.denormalizePath ||= api.normalizePaths ? camelize : val => val\n\n    // Allow definition of defaults for admin component types, nested per type:\n    // api.defaults = {\n    //   'multiselect': {\n    //     selectable: true\n    //   },\n    //   'fake-type': schema => {\n    //     // Return defaults, or directly modify the schema:\n    //     Object.assign(schema, {\n    //       type: 'real-type',\n    //       format: ({ value }) => `Formatted ${value}`,\n    //       process: ({ value }) => `Processed ${value}`\n    //     })\n    //   }\n    // }\n\n    api.defaults ||= {}\n\n    // Allow the configuration of all auth resources, like so:\n    // api.users = {\n    //   path: '/admins',\n    //   // These are the defaults:\n    //   login: {\n    //     path: 'login',\n    //     method: 'post'\n    //   },\n    //   logout: {\n    //     path: 'logout',\n    //     method: 'post'\n    //   },\n    //   session: {\n    //     path: 'session',\n    //     method: 'get'\n    //   }\n    // }\n    const users = getResource(api.users, {\n      type: 'collection'\n    }) || {}\n    users.login = getResource(users.login || 'login', {\n      method: 'post',\n      parent: users\n    })\n    users.logout = getResource(users.logout || 'logout', {\n      method: 'post',\n      parent: users\n    })\n    users.session = getResource(users.session || 'session', {\n      method: 'get',\n      parent: users\n    })\n    api.users = users\n\n    // Allow overriding of resource path handlers:\n    // api.resources = {\n    //   collection(resource) {\n    //     return resource.parent\n    //       ? `${resource.path}?${resource.parent.path}_id=${\n    //          resource.parent.id}`\n    //       : resource.path\n    //   }\n    // }\n\n    api.resources = {\n      any(resource) {\n        const handler = this[resource?.type] || this.default\n        return resource && handler.call(this, resource)\n      },\n\n      default(resource) {\n        const parentPath = this.any(resource.parent)\n        return parentPath\n          ? `${parentPath}/${resource.path}`\n          : resource.path\n      },\n\n      collection(resource) {\n        return this.default(resource)\n      },\n\n      member(resource) {\n        return `${this.default(resource)}/${resource.id}`\n      },\n\n      upload(resource) {\n        // Dito.js Server handles upload routes on the collection resource:\n        return `${this.collection(resource.parent)}/upload/${resource.path}`\n      },\n\n      ...api.resources\n    }\n\n    // Allow overriding / extending of headers:\n    // api.headers = {\n    //   'Content-Type': 'application/json'\n    // }\n    api.headers = {\n      'Content-Type': 'application/json',\n      ...api.headers\n    }\n\n    if (isString(el)) {\n      el = document.querySelector(el)\n    }\n\n    const app = (this.app = createApp({\n      components: {\n        DitoRoot,\n        VueNotifications,\n        // This may only be needed to avoid tree-shacking of these components,\n        // since they actually handle registry internally already.\n        // TODO: Remove this once we have a better solution.\n        ...components,\n        ...types\n      },\n\n      // Most injects are defined as functions, to preserve reactiveness across\n      // provide/inject, see:\n      // https://github.com/vuejs/vue/issues/7017#issuecomment-480906691\n      provide: {\n        api,\n        // A default list of verbs are provided by $verbs() and can be\n        // overridden at any point in the component hierarchy.\n        $verbs: () => verbs,\n        // Provide defaults so DitoMixin can inject them for all components:\n        //   inject: [  '$isPopulated', '$schemaComponent', '$routeComponent' ]\n        $views: () => {},\n        $isPopulated: () => true,\n        $parentComponent: () => null,\n        $schemaComponent: () => null,\n        $schemaParentComponent: () => null,\n        $routeComponent: () => null,\n        $dataComponent: () => null,\n        $sourceComponent: () => null,\n        $resourceComponent: () => null,\n        $dialogComponent: () => null,\n        $panelComponent: () => null,\n        $tabComponent: () => null\n      },\n\n      render: () =>\n        createElement(DitoRoot, {\n          ref: 'root',\n          class: dito.settings.rootClass,\n          unresolvedViews: views,\n          options\n        })\n    }))\n\n    // Prevent endless loops of error messages during render functions by\n    // setting a custom error handler.\n    app.config.errorHandler = console.error\n\n    app.use(VueNotifications, {\n      componentName: 'VueNotifications',\n      name: 'notify'\n    })\n\n    app.directive('resize', ResizeDirective)\n\n    app.use(\n      createRouter({\n        // Start with a catch-all route, to be replaced by the actual routes\n        // once the schemas are loaded, to prevent vue-router from complaining,\n        // see: `resolveViews()` in `DitoRoot` for the actual route setup.\n        routes: [\n          {\n            name: 'catch-all',\n            path: '/:_(.*)',\n            components: {}\n          }\n        ],\n        history: createWebHistory(dito.base),\n        linkActiveClass: '',\n        linkExactActiveClass: ''\n      })\n    )\n\n    el.classList.add('dito-app')\n    app.mount(el)\n  }\n\n  register(type, options) {\n    return DitoTypeComponent.register(type, options)\n  }\n}\n\nclass RequestError extends Error {\n  constructor(response) {\n    super(\n      `Request failed with status code: ${response.status} (${\n        response.statusText\n      })`\n    )\n    this.response = response\n  }\n}\n\nasync function request(api, {\n  url,\n  method = 'get',\n  query = null,\n  headers = null,\n  data = null,\n  signal = null\n}) {\n  const isApiUrl = api.isApiUrl(url)\n\n  const response = await fetch(api.getApiUrl({ url, query }), {\n    method: method.toUpperCase(),\n    ...(data && { body: JSON.stringify(data) }),\n    headers: {\n      ...(isApiUrl && api.headers),\n      ...headers\n    },\n    credentials:\n      isApiUrl && api.cors?.credentials\n        ? 'include'\n        : 'same-origin',\n    signal\n  })\n\n  if (response.headers.get('Content-Type')?.includes('application/json')) {\n    response.data = await response.json()\n  }\n\n  if (!response.ok) {\n    throw new RequestError(response)\n  }\n  return response\n}\n\nfunction isApiUrl(api, url) {\n  return !isAbsoluteUrl(url) || url.startsWith(api.url)\n}\n\nfunction getApiUrl(api, { url, query }) {\n  if (!url.startsWith(api.url) && !isAbsoluteUrl(url)) {\n    url = combineUrls(api.url, url)\n  }\n  // Support optional query parameters, to be are added to the URL.\n  const search = formatQuery(query)\n  return search ? `${url}${url.includes('?') ? '&' : '?'}${search}` : url\n}\n\nfunction combineUrls(baseUrl, relativeUrl) {\n  // Use same approach as axios `combineURLs()` to join baseUrl & relativeUrl:\n  return `${baseUrl.replace(/\\/+$/, '')}/${relativeUrl.replace(/^\\/+/, '')}`\n}\n"],"names":["parseUserAgent","userAgent","agent","ua","os","platform","match","browser","v1","v2","rv","version","appState","reactive","appendDataPath","dataPath","token","parseParentDataPath","path","parseDataPath","parseItemDataPath","nested","getItemDataPath","normalizeDataPath","parseParentItemDataPath","isInteger","getParentItemDataPath","getItem","rootItem","getValueAtDataPath","getParentItem","getLastDataPathToken","getLastDataPathName","getLastDataPathIndex","index","temporaryId","setTemporaryId","data","idKey","isTemporaryId","id","isReference","hasOwnProperty","contexts","toObject","context","rawStart","toRaw","raw","object","get","key","defaultValue","value","isFunction","set","DitoContext","component","item","options","location","resource","EmitterMixin","event","callback","isArray","ev","isPlainObject","listeners","callbacks","on","args","entry","cb","queue","resolve","next","result","errors","res","error","target","ValueMixin","computeValue","format","parse","ContextMixin","getProcessedParentData","schemaComponent","isCreditCard","decimals","isDomain","isEmail","isHostname","max","min","settings","password","isUrl","ValidationMixin","notify","isValid","rule","setting","validator","validators","validate","message","addLabel","focus","getSchemaAccessor","keyOrDataPath","type","def","isString","name","getStoreAccessor","TypeMixin","node","clearable","events","camelize","nativeField","textField","attributes","validations","add","onFocus","onBlur","onInput","onChange","element","asArray","uidMap","uid","getUid","getItemId","SchemaGraph","defaults","subGraph","part","schema","relatedDataPath","nanoid","flatten","graph","entries","$settings","subKey","sourceSchema","clipboard","internal","related","reference","source","relation","values","removeId","referenceId","refKey","revValue","typeCheckers","isBoolean","isNumber","isDate","isObject","isRegExp","typeConverters","isMatchingType","types","convertType","converter","typeComponents","unknownTypeReported","emptySchema","registerTypeComponent","getTypeComponent","allowNull","iterateSchemaComponents","schemas","isSingleComponentView","isSchema","iterateNestedSchemaComponents","getTabSchemas","findNestedSchemaComponent","someNestedSchemaComponent","hasNestedSchemaComponents","isForm","isView","isTab","isPanel","isMenu","getSchemaIdentifier","resolvedSchemas","resolveSchema","unwrapModule","isPromise","isModule","keys","resolveSchemas","unresolvedSchemas","resolveItem","mapConcurrently","resolveViews","unresolvedViews","flattenViews","views","resolveSchemaComponent","markRaw","DitoMixin","resolveSchemaComponents","processedSchemaDepths","processSchemaComponents","api","routes","level","maxDepth","depth","promises","process","relativeLevel","processSchemaComponent","getPanelSchemas","processSchemaDefaults","panel","getTypeOptions","processView","fullPath","processRouteSchema","children","processNestedSchemas","assignDeeply","processNestedSchemaDefaults","forms","getFormSchemas","form","processForms","components","processForm","processTab","processPanel","tabs","panels","tab","hasFormSchema","hasMultipleFormSchemas","getViewFormSchema","view","viewSchema","getViewSchema","hasViewSchema","getViewPath","getViewEditPath","modifyForm","compact","getItemFormSchemaFromForms","getItemFormSchema","isEmptySchema","isCompact","isInlined","isNested","hasLabel","generateLabels","label","omitSpacing","getSchemaValue","converted","shouldRenderSchema","getContext","getDefaultValue","clone","shouldExcludeValue","excludeValue","shouldIgnoreMissingValue","getMultipleValue","setDefaultValues","processSchemaData","rootData","compute","cloneItem","copy","orderKey","processData","schemaOnly","processedData","wrapPrimitives","processValue","processBefore","processAfter","processComponents","getDataPath","componentSchema","componentDataPath","processItem","itemDataPath","processedItem","getNamedSchemas","array","toSchema","getButtonSchemas","buttons","getType","schemaOrType","getSourceType","getPanelEntry","tabComponent","getPanelEntries","panelSchemas","panelEntries","getAllPanelEntries","panelSchema","isObjectSource","isListSource","getItemUid","hasResource","getResource","parent","defs","getMemberResource","pickBy","self","getParentComponent","nextUid","labelize","store","oldKey","verb","query","url","method","signal","checkUser","response","equals","cache","loadCache","cacheKey","locale","a","body","getComputedAccessor","getter","computed","accessor","watch","handlers","expr","addEvent","hyphenate","hasListeners","parentHasListeners","emitEvent","handleParentListeners","handleListeners","params","current","resolveMergedOptions","mixins","mergeOptions","to","from","mixin","ditoOptionKeys","DitoComponent","definition","hasVNodeContent","vnode","Comment","hasSlotContent","slot","props","useSlots","_","describeDate","date","alterDate","overrides","parseDate","string","time","timeDefault","day","sep1","month","sep2","year","hour","minute","second","millisecond","getDateParts","getMonthIndex","isValidTimePart","getDatePartAtPosition","position","parts","getPosition","length","pos","offset","isUS","start","end","shortFormat","longFormat","i","_sfc_main","weekdayNames","monthNames","getLocaleNames","mode","update","step","currentValue","enter","startYear","firstDayWeek","numDays","prevMonth","prevMonthNumDays","now","isDay","state","nextMonthNeed","nextMonth","localeNames","names","addEvents","targets","handler","combineEvents","getKey","getKeyNavigation","getTarget","classes","show","trigger","popup","el","bounds","triggerLeft","triggerTop","triggerWidth","triggerHeight","popupWidth","popupHeight","part1","part2","winWidth","winHeight","left","top","triggerBounds","input","size","getLength","prefix","setSelection","getSelection","DitoTrigger","DitoCalendar","DitoInput","DitoIcon","defaultFormats","getDatePart","calendar","toggle","selection","smooth","scroll","ref","lineHeight","distance","count","isDigit","char","DitoDatePicker","DitoTimePicker","transition","disabled","text","showPrev","showNext","currentPage","numPages","showLength","page","button","checked","unchecked","modelValue","TransitionHeight","enabled","slots","createElement","Transition","setStyle","style","nextTimeout","forceRepaint","width","height","DomMixin","remove","DitoUser","roles","role","SchemaParentMixin","schemaComponents","ValidatorMixin","it","first","RouteMixin","routeComponent","matched","record","breadcrumb","routeComponents","ok","recordPath","rootPath","getCommonPrefix","isLoading","tryOnScopeDispose","fn","failSilently","getCurrentScope","onScopeDispose","isClient","isDef","val","notNullish","toArray","getLifeCycleTarget","getCurrentInstance","tryOnMounted","sync","onMounted","nextTick","defaultDocument","unrefElement","elRef","_$el","plain","toValue","cloneFnJSON","useVModel","emit","_vm$$emit","_vm$proxy","passive","eventName","deep","shouldEmit","vm","_emit","cloneFn","getValue$1","triggerEmit","proxy","isUpdating","v","useFocusTrap","trap","immediate","focusTrapOptions","hasFocus","shallowRef","isPaused","activate","opts","deactivate","pause","unpause","_el","els","createFocusTrap","isActive","tryOnScopeDispose$1","UseFocusTrap","defineComponent","h","dialogData","DitoDialog","tippyDelegate","instance","err","dragCount","uploads","toggleDropTargetClass","upload","setDraggingFiles","hasUploads","canDrop","title","duration","reject","dialogId","additionalComponents","redirectAfterLogin","loginData","user","DitoView","addRoutes","router","removers","route","firstChild","log","stripHtml","notifications","durationFactor","PulldownMixin","startTime","open","DitoSpinner","DitoAffix","DitoAffixes","ItemMixin","itemId","extended","asObject","itemLabel","formLabel","getFormLabel","suffix","columns","hadLabel","defaultTab","routeTab","newTab","oldTab","content","dataPathOrName","scrollContainer","dispatch","componentsByDataPath","dataPaths","check","field","unmatched","wasFirst","errs","fullDataPath","dataPathParts","found","property","subComponents","localData","foreignData","pane","registry","entriesByDataPath","_withDirectives","_openBlock","_createElementBlock","_Fragment","_renderList","_ctx","_hoisted_1","_createBlock","_component_DitoContainer","nestedDataPath","_hoisted_2","positions","isLastInRow","findNextPosition","rows","row","verticalLabelsByIndices","hasLabelsInRow","container","padding","fontSize","parseFraction","dividend","divisor","accumulatedBasis","flexBasis","combinedBasis","capitalize","_createElementVNode","_withModifiers","$event","_toDisplayString","_hoisted_4","creatable","clipboardData","paste","$schema","report","json","deindent","LoadingMixin","updateRoot","updateView","ResourceMixin","amount","range","child","verbs","clear","loadingOptions","controller","request","setData","onSuccess","onError","notifySuccess","notifyError","parentMeta","resolvePath","isCreating","providesData","dataParts","pathParts","routeParts","lastDataPart","l","dataPart","param","mainSchemaComponent","present","closeForm","getVerb","buttonResource","success","_resource","_method","DitoForm","tip","tippy","scope","Pagination","SortableMixin","forceFallback","oldIndex","newIndex","list","paginationRange","_normalizeStyle","_cache","_normalizeClass","_hoisted_5","_hoisted_7","_mergeProps","_hoisted_8","_component_DitoLabel","_createVNode","_component_DitoTableCell","_component_DitoDraggable","_component_DitoTreeItem","childrenSchema","childrenList","editPath","childrenOpen","numChildren","editable","order","column","render","escapeHtml","TYPES","file","reader","useSortable","sortable","document","watchElement","resetOptions","defaultOptions","e","moveArrayElement","cleanup","initSortable","Sortable","option","stopWatch","newElement","stop","insertNodeAt","parentElement","refElement","removeNode","_valueIsRef","isRef","UseSortable","DitoVNode","DitoTypeComponent$1","DitoTypeComponent","DitoButton","onClick","DataMixin","asyncEntry","resolvedData","load","clearLoading","timer","OptionsMixin","convertValue","search","filter","debounce","debounceAsync","grouped","results","group","findOption","groupBy","optionValue","optionLabel","processRelate","flask","CodeFlask","changed","ignoreWatch","ignoreUpdate","setCode","code","setValue","language","getPoint","x","y","prevY","mousemove","hex","SketchPicker","convertColor","color","tinycolor","convertedValue","canUpdateValue","toVue3ColorFormat","toTinyColorFormat","formats","DitoDateTimePicker","formatQuery","replaceRoute","hash","SourceMixin","defaultSort","direction","draggable","collapsible","collapsed","removed","listData","onComplete","opened","callOnComplete","inlined","meta","formMeta","childRoutes","sourcePath","formRoute","getPathWithParam","flatRoutes","subRoutes","childRoute","filterComponents","datetime","createFiltersPanel","filters","sticky","filterSchemas","parseFiltersData","createFiltersComponents","createFiltersButtons","formatFiltersData","small","getDataName","filterName","getFilterName","dataName","comps","getComponentsForFilter","filtersData","_component_DitoTableHead","_component_DitoSchemaInlined","_resolveDynamicComponent","_component_DitoEditButtons","_hoisted_9","obj","filtersDataPath","findDiffStart","b","childA","childB","j","inner","findDiffEnd","posA","posB","iA","iB","same","minSize","Fragment","f","nodeStart","blockSeparator","leafText","nodeText","other","last","p","otherPos","retIndex","curPos","cur","n","joined","nodes","Slice","openStart","openEnd","fragment","insertInto","removeRange","openIsolating","indexTo","offsetTo","dist","insert","EditorContent","editor","slice","paragraph","enableRules","updateValue","onUpdate","setValueDebounced","Editor","dialogComponent","getMarkAttributes","href","marks","tools","Document","Text","Paragraph","Bold","Italic","Underline","Strike","Small","Code","Superscript","Subscript","LinkWithTitle","Blockquote","CodeBlock","Heading","HorizontalRule","ListItem","BulletList","OrderedList","Footnotes","Footnote","FootnoteReference","History","HardBreak","setHardBreak","extension","settingsName","descriptions","commands","addButton","icon","command","description","settingName","attribute","Mark","Link","HTMLAttributes","VueMultiselect","placeholder","searchable","taggable","tag","searchTerm","NumberMixin","DitoSwitch","TextMixin","maskedPassword","hasEditableForms","formatFileSize","filesize","VueUpload","asFiles","accept","maxSize","parseFileSize","thumbnails","total","ready","newFile","oldFile","xhr","blob","files","ResizeDirective","binding","observeResize","unobserveResize","Observer","isResizeSupported","observers","box","DitoAdmin","dito","getApiUrl","isApiUrl","users","parentPath","app","createApp","DitoRoot","VueNotifications","createRouter","createWebHistory","RequestError","headers","isAbsoluteUrl","combineUrls","baseUrl","relativeUrl"],"mappings":"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","x_google_ignoreList":[52,53,54,55,97,98,117]}