GKD网页审查工具增强
// ==UserScript==
// @name GKD网页审查工具增强
// @name:en-US Make GKDInspect Better
// @namespace https://blog.adproqwq.xyz
// @version 2.9.2
// @author Adpro
// @description 让GKD网页审查工具再次强大!版本:Jupiter
// @description:en-US Let GKD Inspect Better Again! Version: Jupiter
// @license MIT
// @icon 
// @homepage https://github.com/adproqwq/MakeGKDInspectBetter
// @supportURL https://github.com/adproqwq/MakeGKDInspectBetter/issues
// @match https://i.gkd.li/*
// @exclude https://i.gkd.li
// @require https://cdn.jsdelivr.net/npm/vue@3.5.13/dist/vue.global.prod.js
// @grant none
// ==/UserScript==
(r=>{if(typeof GM_addStyle=="function"){GM_addStyle(r);return}const o=document.createElement("style");o.textContent=r,document.head.append(o)})(' :root{--mdui-breakpoint-xs:0px;--mdui-breakpoint-sm:600px;--mdui-breakpoint-md:840px;--mdui-breakpoint-lg:1080px;--mdui-breakpoint-xl:1440px;--mdui-breakpoint-xxl:1920px}:root{--mdui-color-primary-light:103,80,164;--mdui-color-primary-container-light:234,221,255;--mdui-color-on-primary-light:255,255,255;--mdui-color-on-primary-container-light:33,0,94;--mdui-color-inverse-primary-light:208,188,255;--mdui-color-secondary-light:98,91,113;--mdui-color-secondary-container-light:232,222,248;--mdui-color-on-secondary-light:255,255,255;--mdui-color-on-secondary-container-light:30,25,43;--mdui-color-tertiary-light:125,82,96;--mdui-color-tertiary-container-light:255,216,228;--mdui-color-on-tertiary-light:255,255,255;--mdui-color-on-tertiary-container-light:55,11,30;--mdui-color-surface-light:254,247,255;--mdui-color-surface-dim-light:222,216,225;--mdui-color-surface-bright-light:254,247,255;--mdui-color-surface-container-lowest-light:255,255,255;--mdui-color-surface-container-low-light:247,242,250;--mdui-color-surface-container-light:243,237,247;--mdui-color-surface-container-high-light:236,230,240;--mdui-color-surface-container-highest-light:230,224,233;--mdui-color-surface-variant-light:231,224,236;--mdui-color-on-surface-light:28,27,31;--mdui-color-on-surface-variant-light:73,69,78;--mdui-color-inverse-surface-light:49,48,51;--mdui-color-inverse-on-surface-light:244,239,244;--mdui-color-background-light:254,247,255;--mdui-color-on-background-light:28,27,31;--mdui-color-error-light:179,38,30;--mdui-color-error-container-light:249,222,220;--mdui-color-on-error-light:255,255,255;--mdui-color-on-error-container-light:65,14,11;--mdui-color-outline-light:121,116,126;--mdui-color-outline-variant-light:196,199,197;--mdui-color-shadow-light:0,0,0;--mdui-color-surface-tint-color-light:103,80,164;--mdui-color-scrim-light:0,0,0;--mdui-color-primary-dark:208,188,255;--mdui-color-primary-container-dark:79,55,139;--mdui-color-on-primary-dark:55,30,115;--mdui-color-on-primary-container-dark:234,221,255;--mdui-color-inverse-primary-dark:103,80,164;--mdui-color-secondary-dark:204,194,220;--mdui-color-secondary-container-dark:74,68,88;--mdui-color-on-secondary-dark:51,45,65;--mdui-color-on-secondary-container-dark:232,222,248;--mdui-color-tertiary-dark:239,184,200;--mdui-color-tertiary-container-dark:99,59,72;--mdui-color-on-tertiary-dark:73,37,50;--mdui-color-on-tertiary-container-dark:255,216,228;--mdui-color-surface-dark:20,18,24;--mdui-color-surface-dim-dark:20,18,24;--mdui-color-surface-bright-dark:59,56,62;--mdui-color-surface-container-lowest-dark:15,13,19;--mdui-color-surface-container-low-dark:29,27,32;--mdui-color-surface-container-dark:33,31,38;--mdui-color-surface-container-high-dark:43,41,48;--mdui-color-surface-container-highest-dark:54,52,59;--mdui-color-surface-variant-dark:73,69,79;--mdui-color-on-surface-dark:230,225,229;--mdui-color-on-surface-variant-dark:202,196,208;--mdui-color-inverse-surface-dark:230,225,229;--mdui-color-inverse-on-surface-dark:49,48,51;--mdui-color-background-dark:20,18,24;--mdui-color-on-background-dark:230,225,229;--mdui-color-error-dark:242,184,181;--mdui-color-error-container-dark:140,29,24;--mdui-color-on-error-dark:96,20,16;--mdui-color-on-error-container-dark:249,222,220;--mdui-color-outline-dark:147,143,153;--mdui-color-outline-variant-dark:68,71,70;--mdui-color-shadow-dark:0,0,0;--mdui-color-surface-tint-color-dark:208,188,255;--mdui-color-scrim-dark:0,0,0;font-size:16px}.mdui-theme-light,:root{color-scheme:light;--mdui-color-primary:var(--mdui-color-primary-light);--mdui-color-primary-container:var(--mdui-color-primary-container-light);--mdui-color-on-primary:var(--mdui-color-on-primary-light);--mdui-color-on-primary-container:var(--mdui-color-on-primary-container-light);--mdui-color-inverse-primary:var(--mdui-color-inverse-primary-light);--mdui-color-secondary:var(--mdui-color-secondary-light);--mdui-color-secondary-container:var(--mdui-color-secondary-container-light);--mdui-color-on-secondary:var(--mdui-color-on-secondary-light);--mdui-color-on-secondary-container:var(--mdui-color-on-secondary-container-light);--mdui-color-tertiary:var(--mdui-color-tertiary-light);--mdui-color-tertiary-container:var(--mdui-color-tertiary-container-light);--mdui-color-on-tertiary:var(--mdui-color-on-tertiary-light);--mdui-color-on-tertiary-container:var(--mdui-color-on-tertiary-container-light);--mdui-color-surface:var(--mdui-color-surface-light);--mdui-color-surface-dim:var(--mdui-color-surface-dim-light);--mdui-color-surface-bright:var(--mdui-color-surface-bright-light);--mdui-color-surface-container-lowest:var(--mdui-color-surface-container-lowest-light);--mdui-color-surface-container-low:var(--mdui-color-surface-container-low-light);--mdui-color-surface-container:var(--mdui-color-surface-container-light);--mdui-color-surface-container-high:var(--mdui-color-surface-container-high-light);--mdui-color-surface-container-highest:var(--mdui-color-surface-container-highest-light);--mdui-color-surface-variant:var(--mdui-color-surface-variant-light);--mdui-color-on-surface:var(--mdui-color-on-surface-light);--mdui-color-on-surface-variant:var(--mdui-color-on-surface-variant-light);--mdui-color-inverse-surface:var(--mdui-color-inverse-surface-light);--mdui-color-inverse-on-surface:var(--mdui-color-inverse-on-surface-light);--mdui-color-background:var(--mdui-color-background-light);--mdui-color-on-background:var(--mdui-color-on-background-light);--mdui-color-error:var(--mdui-color-error-light);--mdui-color-error-container:var(--mdui-color-error-container-light);--mdui-color-on-error:var(--mdui-color-on-error-light);--mdui-color-on-error-container:var(--mdui-color-on-error-container-light);--mdui-color-outline:var(--mdui-color-outline-light);--mdui-color-outline-variant:var(--mdui-color-outline-variant-light);--mdui-color-shadow:var(--mdui-color-shadow-light);--mdui-color-surface-tint-color:var(--mdui-color-surface-tint-color-light);--mdui-color-scrim:var(--mdui-color-scrim-light);color:rgb(var(--mdui-color-on-background));background-color:rgb(var(--mdui-color-background))}.mdui-theme-dark{color-scheme:dark;--mdui-color-primary:var(--mdui-color-primary-dark);--mdui-color-primary-container:var(--mdui-color-primary-container-dark);--mdui-color-on-primary:var(--mdui-color-on-primary-dark);--mdui-color-on-primary-container:var(--mdui-color-on-primary-container-dark);--mdui-color-inverse-primary:var(--mdui-color-inverse-primary-dark);--mdui-color-secondary:var(--mdui-color-secondary-dark);--mdui-color-secondary-container:var(--mdui-color-secondary-container-dark);--mdui-color-on-secondary:var(--mdui-color-on-secondary-dark);--mdui-color-on-secondary-container:var(--mdui-color-on-secondary-container-dark);--mdui-color-tertiary:var(--mdui-color-tertiary-dark);--mdui-color-tertiary-container:var(--mdui-color-tertiary-container-dark);--mdui-color-on-tertiary:var(--mdui-color-on-tertiary-dark);--mdui-color-on-tertiary-container:var(--mdui-color-on-tertiary-container-dark);--mdui-color-surface:var(--mdui-color-surface-dark);--mdui-color-surface-dim:var(--mdui-color-surface-dim-dark);--mdui-color-surface-bright:var(--mdui-color-surface-bright-dark);--mdui-color-surface-container-lowest:var(--mdui-color-surface-container-lowest-dark);--mdui-color-surface-container-low:var(--mdui-color-surface-container-low-dark);--mdui-color-surface-container:var(--mdui-color-surface-container-dark);--mdui-color-surface-container-high:var(--mdui-color-surface-container-high-dark);--mdui-color-surface-container-highest:var(--mdui-color-surface-container-highest-dark);--mdui-color-surface-variant:var(--mdui-color-surface-variant-dark);--mdui-color-on-surface:var(--mdui-color-on-surface-dark);--mdui-color-on-surface-variant:var(--mdui-color-on-surface-variant-dark);--mdui-color-inverse-surface:var(--mdui-color-inverse-surface-dark);--mdui-color-inverse-on-surface:var(--mdui-color-inverse-on-surface-dark);--mdui-color-background:var(--mdui-color-background-dark);--mdui-color-on-background:var(--mdui-color-on-background-dark);--mdui-color-error:var(--mdui-color-error-dark);--mdui-color-error-container:var(--mdui-color-error-container-dark);--mdui-color-on-error:var(--mdui-color-on-error-dark);--mdui-color-on-error-container:var(--mdui-color-on-error-container-dark);--mdui-color-outline:var(--mdui-color-outline-dark);--mdui-color-outline-variant:var(--mdui-color-outline-variant-dark);--mdui-color-shadow:var(--mdui-color-shadow-dark);--mdui-color-surface-tint-color:var(--mdui-color-surface-tint-color-dark);--mdui-color-scrim:var(--mdui-color-scrim-dark);color:rgb(var(--mdui-color-on-background));background-color:rgb(var(--mdui-color-background))}@media (prefers-color-scheme:dark){.mdui-theme-auto{color-scheme:dark;--mdui-color-primary:var(--mdui-color-primary-dark);--mdui-color-primary-container:var(--mdui-color-primary-container-dark);--mdui-color-on-primary:var(--mdui-color-on-primary-dark);--mdui-color-on-primary-container:var(--mdui-color-on-primary-container-dark);--mdui-color-inverse-primary:var(--mdui-color-inverse-primary-dark);--mdui-color-secondary:var(--mdui-color-secondary-dark);--mdui-color-secondary-container:var(--mdui-color-secondary-container-dark);--mdui-color-on-secondary:var(--mdui-color-on-secondary-dark);--mdui-color-on-secondary-container:var(--mdui-color-on-secondary-container-dark);--mdui-color-tertiary:var(--mdui-color-tertiary-dark);--mdui-color-tertiary-container:var(--mdui-color-tertiary-container-dark);--mdui-color-on-tertiary:var(--mdui-color-on-tertiary-dark);--mdui-color-on-tertiary-container:var(--mdui-color-on-tertiary-container-dark);--mdui-color-surface:var(--mdui-color-surface-dark);--mdui-color-surface-dim:var(--mdui-color-surface-dim-dark);--mdui-color-surface-bright:var(--mdui-color-surface-bright-dark);--mdui-color-surface-container-lowest:var(--mdui-color-surface-container-lowest-dark);--mdui-color-surface-container-low:var(--mdui-color-surface-container-low-dark);--mdui-color-surface-container:var(--mdui-color-surface-container-dark);--mdui-color-surface-container-high:var(--mdui-color-surface-container-high-dark);--mdui-color-surface-container-highest:var(--mdui-color-surface-container-highest-dark);--mdui-color-surface-variant:var(--mdui-color-surface-variant-dark);--mdui-color-on-surface:var(--mdui-color-on-surface-dark);--mdui-color-on-surface-variant:var(--mdui-color-on-surface-variant-dark);--mdui-color-inverse-surface:var(--mdui-color-inverse-surface-dark);--mdui-color-inverse-on-surface:var(--mdui-color-inverse-on-surface-dark);--mdui-color-background:var(--mdui-color-background-dark);--mdui-color-on-background:var(--mdui-color-on-background-dark);--mdui-color-error:var(--mdui-color-error-dark);--mdui-color-error-container:var(--mdui-color-error-container-dark);--mdui-color-on-error:var(--mdui-color-on-error-dark);--mdui-color-on-error-container:var(--mdui-color-on-error-container-dark);--mdui-color-outline:var(--mdui-color-outline-dark);--mdui-color-outline-variant:var(--mdui-color-outline-variant-dark);--mdui-color-shadow:var(--mdui-color-shadow-dark);--mdui-color-surface-tint-color:var(--mdui-color-surface-tint-color-dark);--mdui-color-scrim:var(--mdui-color-scrim-dark);color:rgb(var(--mdui-color-on-background));background-color:rgb(var(--mdui-color-background))}}:root{--mdui-elevation-level0:none;--mdui-elevation-level1:0 .5px 1.5px 0 rgba(var(--mdui-color-shadow), 19%),0 0 1px 0 rgba(var(--mdui-color-shadow), 3.9%);--mdui-elevation-level2:0 .85px 3px 0 rgba(var(--mdui-color-shadow), 19%),0 .25px 1px 0 rgba(var(--mdui-color-shadow), 3.9%);--mdui-elevation-level3:0 1.25px 5px 0 rgba(var(--mdui-color-shadow), 19%),0 .3333px 1.5px 0 rgba(var(--mdui-color-shadow), 3.9%);--mdui-elevation-level4:0 1.85px 6.25px 0 rgba(var(--mdui-color-shadow), 19%),0 .5px 1.75px 0 rgba(var(--mdui-color-shadow), 3.9%);--mdui-elevation-level5:0 2.75px 9px 0 rgba(var(--mdui-color-shadow), 19%),0 .25px 3px 0 rgba(var(--mdui-color-shadow), 3.9%)}:root{--mdui-motion-easing-linear:cubic-bezier(0, 0, 1, 1);--mdui-motion-easing-standard:cubic-bezier(.2, 0, 0, 1);--mdui-motion-easing-standard-accelerate:cubic-bezier(.3, 0, 1, 1);--mdui-motion-easing-standard-decelerate:cubic-bezier(0, 0, 0, 1);--mdui-motion-easing-emphasized:var(--mdui-motion-easing-standard);--mdui-motion-easing-emphasized-accelerate:cubic-bezier(.3, 0, .8, .15);--mdui-motion-easing-emphasized-decelerate:cubic-bezier(.05, .7, .1, 1);--mdui-motion-duration-short1:50ms;--mdui-motion-duration-short2:.1s;--mdui-motion-duration-short3:.15s;--mdui-motion-duration-short4:.2s;--mdui-motion-duration-medium1:.25s;--mdui-motion-duration-medium2:.3s;--mdui-motion-duration-medium3:.35s;--mdui-motion-duration-medium4:.4s;--mdui-motion-duration-long1:.45s;--mdui-motion-duration-long2:.5s;--mdui-motion-duration-long3:.55s;--mdui-motion-duration-long4:.6s;--mdui-motion-duration-extra-long1:.7s;--mdui-motion-duration-extra-long2:.8s;--mdui-motion-duration-extra-long3:.9s;--mdui-motion-duration-extra-long4:1s}.mdui-prose{line-height:1.75;word-wrap:break-word}.mdui-prose :first-child{margin-top:0}.mdui-prose :last-child{margin-bottom:0}.mdui-prose code,.mdui-prose kbd,.mdui-prose pre,.mdui-prose pre tt,.mdui-prose samp{font-family:Consolas,Courier,Courier New,monospace}.mdui-prose caption{text-align:left}.mdui-prose [draggable=true],.mdui-prose [draggable]{cursor:move}.mdui-prose [draggable=false]{cursor:inherit}.mdui-prose dl,.mdui-prose form,.mdui-prose ol,.mdui-prose p,.mdui-prose ul{margin-top:1.25em;margin-bottom:1.25em}.mdui-prose a{text-decoration:none;outline:0;color:rgb(var(--mdui-color-primary))}.mdui-prose a:focus,.mdui-prose a:hover{border-bottom:.0625rem solid rgb(var(--mdui-color-primary))}.mdui-prose small{font-size:.875em}.mdui-prose strong{font-weight:600}.mdui-prose blockquote{margin:1.6em 2em;padding-left:1em;border-left:.25rem solid rgb(var(--mdui-color-surface-variant))}@media only screen and (max-width:599.98px){.mdui-prose blockquote{margin:1.6em 0}}.mdui-prose blockquote footer{font-size:86%;color:rgb(var(--mdui-color-on-surface-variant))}.mdui-prose mark{color:inherit;background-color:rgb(var(--mdui-color-secondary-container));border-bottom:.0625rem solid rgb(var(--mdui-color-secondary));margin:0 .375rem;padding:.125rem}.mdui-prose h1,.mdui-prose h2,.mdui-prose h3,.mdui-prose h4,.mdui-prose h5,.mdui-prose h6{font-weight:400}.mdui-prose h1 small,.mdui-prose h2 small,.mdui-prose h3 small,.mdui-prose h4 small,.mdui-prose h5 small,.mdui-prose h6 small{font-weight:inherit;font-size:65%;color:rgb(var(--mdui-color-on-surface-variant))}.mdui-prose h1 strong,.mdui-prose h2 strong,.mdui-prose h3 strong,.mdui-prose h4 strong,.mdui-prose h5 strong,.mdui-prose h6 strong{font-weight:600}.mdui-prose h1{font-size:2.5em;margin-top:0;margin-bottom:1.25em;line-height:1.1111}.mdui-prose h2{font-size:1.875em;margin-top:2.25em;margin-bottom:1.125em;line-height:1.3333}.mdui-prose h3{font-size:1.5em;margin-top:2em;margin-bottom:1em;line-height:1.6}.mdui-prose h4{font-size:1.25em;margin-top:1.875em;margin-bottom:.875em;line-height:1.5}.mdui-prose h2+*,.mdui-prose h3+*,.mdui-prose h4+*,.mdui-prose hr+*{margin-top:0}.mdui-prose code,.mdui-prose kbd{font-size:.875em;color:rgb(var(--mdui-color-on-surface-container));background-color:rgba(var(--mdui-color-surface-variant),.28);padding:.125rem .375rem;border-radius:var(--mdui-shape-corner-extra-small)}.mdui-prose kbd{font-size:.9em}.mdui-prose abbr[title]{text-decoration:none;cursor:help;border-bottom:.0625rem dotted rgb(var(--mdui-color-on-surface-variant))}.mdui-prose ins,.mdui-prose u{text-decoration:none;border-bottom:.0625rem solid rgb(var(--mdui-color-on-surface-variant))}.mdui-prose del{text-decoration:line-through}.mdui-prose hr{margin-top:3em;margin-bottom:3em;border:none;border-bottom:.0625rem solid rgb(var(--mdui-color-surface-variant))}.mdui-prose pre{margin-top:1.7143em;margin-bottom:1.7143em}.mdui-prose pre code{padding:.8571em 1.1429em;overflow-x:auto;-webkit-overflow-scrolling:touch;background-color:rgb(var(--mdui-color-surface-container));color:rgb(var(--mdui-color-on-surface-container));border-radius:var(--mdui-shape-corner-extra-small)}.mdui-prose ol,.mdui-prose ul{padding-left:1.625em}.mdui-prose ul{list-style-type:disc}.mdui-prose ol{list-style-type:decimal}.mdui-prose ol[type=A]{list-style-type:upper-alpha}.mdui-prose ol[type=a]{list-style-type:lower-alpha}.mdui-prose ol[type=I]{list-style-type:upper-roman}.mdui-prose ol[type=i]{list-style-type:lower-roman}.mdui-prose ol[type="1"]{list-style-type:decimal}.mdui-prose li{margin-top:.5em;margin-bottom:.5em}.mdui-prose ol>li,.mdui-prose ul>li{padding-left:.375em}.mdui-prose ol>li>p,.mdui-prose ul>li>p{margin-top:.75em;margin-bottom:.75em}.mdui-prose ol>li>:first-child,.mdui-prose ul>li>:first-child{margin-top:1.25em}.mdui-prose ol>li>:last-child,.mdui-prose ul>li>:last-child{margin-bottom:1.25em}.mdui-prose ol>li::marker{font-weight:400;color:rgb(var(--mdui-color-on-surface-variant))}.mdui-prose ul>li::marker{color:rgb(var(--mdui-color-on-surface-variant))}.mdui-prose ol ol,.mdui-prose ol ul,.mdui-prose ul ol,.mdui-prose ul ul{margin-top:.75em;margin-bottom:.75em}.mdui-prose fieldset,.mdui-prose img{border:none}.mdui-prose figure,.mdui-prose img,.mdui-prose video{margin-top:2em;margin-bottom:2em;max-width:100%}.mdui-prose figure>*{margin-top:0;margin-bottom:0}.mdui-prose figcaption{font-size:.875em;line-height:1.4286;margin-top:.8571em;color:rgb(var(--mdui-color-on-surface-variant))}.mdui-prose figcaption:empty:before{z-index:-1;cursor:text;content:attr(placeholder);color:rgb(var(--mdui-color-on-surface-variant))}.mdui-prose table{margin-top:2em;margin-bottom:2em;border:.0625rem solid rgb(var(--mdui-color-surface-variant));border-radius:var(--mdui-shape-corner-large)}.mdui-table{width:100%;overflow-x:auto;margin-top:2em;margin-bottom:2em;border:.0625rem solid rgb(var(--mdui-color-surface-variant));border-radius:var(--mdui-shape-corner-large)}.mdui-table table{margin-top:0;margin-bottom:0;border:none;border-radius:0}.mdui-prose table,.mdui-table table{width:100%;text-align:left;border-collapse:collapse;border-spacing:0}.mdui-prose td,.mdui-prose th,.mdui-table td,.mdui-table th{border-top:.0625rem solid rgb(var(--mdui-color-surface-variant))}.mdui-prose td:not(:first-child),.mdui-prose th:not(:first-child),.mdui-table td:not(:first-child),.mdui-table th:not(:first-child){border-left:.0625rem solid rgb(var(--mdui-color-surface-variant))}.mdui-prose td:not(:last-child),.mdui-prose th:not(:last-child),.mdui-table td:not(:last-child),.mdui-table th:not(:last-child){border-right:.0625rem solid rgb(var(--mdui-color-surface-variant))}.mdui-prose tbody:first-child tr:first-child td,.mdui-prose thead:first-child tr:first-child th,.mdui-table tbody:first-child tr:first-child td,.mdui-table thead:first-child tr:first-child th{border-top:0}.mdui-prose tfoot td,.mdui-prose tfoot th,.mdui-prose thead td,.mdui-prose thead th,.mdui-table tfoot td,.mdui-table tfoot th,.mdui-table thead td,.mdui-table thead th{position:relative;vertical-align:middle;padding:1.125rem 1rem;font-weight:var(--mdui-typescale-title-medium-weight);letter-spacing:var(--mdui-typescale-title-medium-tracking);line-height:var(--mdui-typescale-title-medium-line-height);color:rgb(var(--mdui-color-on-surface-variant));box-shadow:var(--mdui-elevation-level1)}.mdui-prose tbody td,.mdui-prose tbody th,.mdui-table tbody td,.mdui-table tbody th{padding:.875rem 1rem}.mdui-prose tbody th,.mdui-table tbody th{vertical-align:middle;font-weight:inherit}.mdui-prose tbody td,.mdui-table tbody td{vertical-align:baseline}:root{--mdui-shape-corner-none:0;--mdui-shape-corner-extra-small:.25rem;--mdui-shape-corner-small:.5rem;--mdui-shape-corner-medium:.75rem;--mdui-shape-corner-large:1rem;--mdui-shape-corner-extra-large:1.75rem;--mdui-shape-corner-full:1000rem}:root{--mdui-state-layer-hover:.08;--mdui-state-layer-focus:.12;--mdui-state-layer-pressed:.12;--mdui-state-layer-dragged:.16}:root{--mdui-typescale-display-large-weight:400;--mdui-typescale-display-medium-weight:400;--mdui-typescale-display-small-weight:400;--mdui-typescale-display-large-line-height:4rem;--mdui-typescale-display-medium-line-height:3.25rem;--mdui-typescale-display-small-line-height:2.75rem;--mdui-typescale-display-large-size:3.5625rem;--mdui-typescale-display-medium-size:2.8125rem;--mdui-typescale-display-small-size:2.25rem;--mdui-typescale-display-large-tracking:0rem;--mdui-typescale-display-medium-tracking:0rem;--mdui-typescale-display-small-tracking:0rem;--mdui-typescale-headline-large-weight:400;--mdui-typescale-headline-medium-weight:400;--mdui-typescale-headline-small-weight:400;--mdui-typescale-headline-large-line-height:2.5rem;--mdui-typescale-headline-medium-line-height:2.25rem;--mdui-typescale-headline-small-line-height:2rem;--mdui-typescale-headline-large-size:2rem;--mdui-typescale-headline-medium-size:1.75rem;--mdui-typescale-headline-small-size:1.5rem;--mdui-typescale-headline-large-tracking:0rem;--mdui-typescale-headline-medium-tracking:0rem;--mdui-typescale-headline-small-tracking:0rem;--mdui-typescale-title-large-weight:400;--mdui-typescale-title-medium-weight:500;--mdui-typescale-title-small-weight:500;--mdui-typescale-title-large-line-height:1.75rem;--mdui-typescale-title-medium-line-height:1.5rem;--mdui-typescale-title-small-line-height:1.25rem;--mdui-typescale-title-large-size:1.375rem;--mdui-typescale-title-medium-size:1rem;--mdui-typescale-title-small-size:.875rem;--mdui-typescale-title-large-tracking:0rem;--mdui-typescale-title-medium-tracking:.009375rem;--mdui-typescale-title-small-tracking:.00625rem;--mdui-typescale-label-large-weight:500;--mdui-typescale-label-medium-weight:500;--mdui-typescale-label-small-weight:500;--mdui-typescale-label-large-line-height:1.25rem;--mdui-typescale-label-medium-line-height:1rem;--mdui-typescale-label-small-line-height:.375rem;--mdui-typescale-label-large-size:.875rem;--mdui-typescale-label-medium-size:.75rem;--mdui-typescale-label-small-size:.6875rem;--mdui-typescale-label-large-tracking:.00625rem;--mdui-typescale-label-medium-tracking:.03125rem;--mdui-typescale-label-small-tracking:.03125rem;--mdui-typescale-body-large-weight:400;--mdui-typescale-body-medium-weight:400;--mdui-typescale-body-small-weight:400;--mdui-typescale-body-large-line-height:1.5rem;--mdui-typescale-body-medium-line-height:1.25rem;--mdui-typescale-body-small-line-height:1rem;--mdui-typescale-body-large-size:1rem;--mdui-typescale-body-medium-size:.875rem;--mdui-typescale-body-small-size:.75rem;--mdui-typescale-body-large-tracking:.009375rem;--mdui-typescale-body-medium-tracking:.015625rem;--mdui-typescale-body-small-tracking:.025rem}.mdui-lock-screen{overflow:hidden!important}.position{width:15%;height:var(--mdui-typescale-title-large-line-height)}#categories{width:500px}mdui-dialog>*>span{display:flex;font-size:var(--mdui-typescale-body-large-size)}.introduction{color:rgb(var(--mdui-color-on-surface-variant));display:block;opacity:1;word-break:normal;white-space:pre-warp;word-wrap:break-word;transition:opacity var(--mdui-motion-duration-short4) var(--mdui-motion-easing-linear);font-size:var(--mdui-typescale-body-small-size);font-weight:var(--mdui-typescale-body-small-weight);letter-spacing:var(--mdui-typescale-body-small-tracking);line-height:var(--mdui-typescale-body-small-line-height)} ');
(async function (vue) {
'use strict';
var _a;
function isObject(obj) {
return obj !== null && typeof obj === "object" && "constructor" in obj && obj.constructor === Object;
}
function extend$1(target = {}, src = {}) {
Object.keys(src).forEach((key2) => {
if (typeof target[key2] === "undefined")
target[key2] = src[key2];
else if (isObject(src[key2]) && isObject(target[key2]) && Object.keys(src[key2]).length > 0) {
extend$1(target[key2], src[key2]);
}
});
}
const ssrDocument = {
body: {},
addEventListener() {
},
removeEventListener() {
},
activeElement: {
blur() {
},
nodeName: ""
},
querySelector() {
return null;
},
querySelectorAll() {
return [];
},
getElementById() {
return null;
},
createEvent() {
return {
initEvent() {
}
};
},
createElement() {
return {
children: [],
childNodes: [],
style: {},
setAttribute() {
},
getElementsByTagName() {
return [];
}
};
},
createElementNS() {
return {};
},
importNode() {
return null;
},
location: {
hash: "",
host: "",
hostname: "",
href: "",
origin: "",
pathname: "",
protocol: "",
search: ""
}
};
function getDocument() {
const doc = typeof document !== "undefined" ? document : {};
extend$1(doc, ssrDocument);
return doc;
}
const ssrWindow = {
document: ssrDocument,
navigator: {
userAgent: ""
},
location: {
hash: "",
host: "",
hostname: "",
href: "",
origin: "",
pathname: "",
protocol: "",
search: ""
},
history: {
replaceState() {
},
pushState() {
},
go() {
},
back() {
}
},
CustomEvent: function CustomEvent2() {
return this;
},
addEventListener() {
},
removeEventListener() {
},
getComputedStyle() {
return {
getPropertyValue() {
return "";
}
};
},
Image() {
},
Date() {
},
screen: {},
setTimeout() {
},
clearTimeout() {
},
matchMedia() {
return {};
},
requestAnimationFrame(callback) {
if (typeof setTimeout === "undefined") {
callback();
return null;
}
return setTimeout(callback, 0);
},
cancelAnimationFrame(id2) {
if (typeof setTimeout === "undefined") {
return;
}
clearTimeout(id2);
}
};
function getWindow$1() {
const win = typeof window !== "undefined" ? window : {};
extend$1(win, ssrWindow);
return win;
}
const getNodeName$1 = (element) => {
return (element == null ? void 0 : element.nodeName.toLowerCase()) ?? "";
};
const isNodeName = (element, name) => {
return (element == null ? void 0 : element.nodeName.toLowerCase()) === name.toLowerCase();
};
const isFunction = (target) => {
return typeof target === "function";
};
const isString = (target) => {
return typeof target === "string";
};
const isNumber = (target) => {
return typeof target === "number";
};
const isBoolean = (target) => {
return typeof target === "boolean";
};
const isUndefined = (target) => {
return typeof target === "undefined";
};
const isNull = (target) => {
return target === null;
};
const isWindow = (target) => {
return typeof Window !== "undefined" && target instanceof Window;
};
const isDocument = (target) => {
return typeof Document !== "undefined" && target instanceof Document;
};
const isElement = (target) => {
return typeof Element !== "undefined" && target instanceof Element;
};
const isNode$1 = (target) => {
return typeof Node !== "undefined" && target instanceof Node;
};
const isArrayLike = (target) => {
return !isFunction(target) && !isWindow(target) && isNumber(target.length);
};
const isObjectLike = (target) => {
return typeof target === "object" && target !== null;
};
const toElement = (target) => {
return isDocument(target) ? target.documentElement : target;
};
const toCamelCase = (string) => {
return string.replace(/-([a-z])/g, (_2, letter) => {
return letter.toUpperCase();
});
};
const toKebabCase = (string) => {
if (!string) {
return string;
}
return string.replace(/^./, string[0].toLowerCase()).replace(/[A-Z]/g, (replacer) => {
return "-" + replacer.toLowerCase();
});
};
const returnFalse = () => {
return false;
};
const returnTrue = () => {
return true;
};
const eachArray = (target, callback) => {
for (let i3 = 0; i3 < target.length; i3 += 1) {
if (callback.call(target[i3], target[i3], i3) === false) {
return target;
}
}
return target;
};
const eachObject = (target, callback) => {
const keys = Object.keys(target);
for (let i3 = 0; i3 < keys.length; i3 += 1) {
const key2 = keys[i3];
if (callback.call(target[key2], key2, target[key2]) === false) {
return target;
}
}
return target;
};
class JQ {
constructor(arr) {
this.length = 0;
if (!arr) {
return this;
}
eachArray(arr, (item, i3) => {
this[i3] = item;
});
this.length = arr.length;
return this;
}
}
const isDomReady = (document2 = getDocument()) => {
return /complete|interactive/.test(document2.readyState);
};
const createElement = (tagName) => {
const document2 = getDocument();
return document2.createElement(tagName);
};
const appendChild = (element, child) => {
return element.appendChild(child);
};
const removeChild = (element) => {
return element.parentNode ? element.parentNode.removeChild(element) : element;
};
const getChildNodesArray = (target, parent) => {
const tempParent = createElement(parent);
tempParent.innerHTML = target;
return [].slice.call(tempParent.childNodes);
};
const get$ = () => {
const $2 = function(selector) {
if (!selector) {
return new JQ();
}
if (selector instanceof JQ) {
return selector;
}
if (isFunction(selector)) {
const document2 = getDocument();
if (isDomReady(document2)) {
selector.call(document2, $2);
} else {
document2.addEventListener("DOMContentLoaded", () => selector.call(document2, $2), { once: true });
}
return new JQ([document2]);
}
if (isString(selector)) {
const html = selector.trim();
if (html.startsWith("<") && html.endsWith(">")) {
let toCreate = "div";
const tags = {
li: "ul",
tr: "tbody",
td: "tr",
th: "tr",
tbody: "table",
option: "select"
};
eachObject(tags, (childTag, parentTag) => {
if (html.startsWith(`<${childTag}`)) {
toCreate = parentTag;
return false;
}
return;
});
return new JQ(getChildNodesArray(html, toCreate));
}
const document2 = getDocument();
return new JQ(document2.querySelectorAll(selector));
}
if (isArrayLike(selector) && !isNode$1(selector)) {
return new JQ(selector);
}
return new JQ([selector]);
};
$2.fn = JQ.prototype;
return $2;
};
const $$1 = get$();
const merge = (first, second) => {
eachArray(second, (value) => {
first.push(value);
});
return first;
};
const unique = (arr) => {
return [...new Set(arr)];
};
$$1.fn.get = function(index) {
return index === void 0 ? [].slice.call(this) : this[index >= 0 ? index : index + this.length];
};
$$1.fn.add = function(selector) {
return new JQ(unique(merge(this.get(), $$1(selector).get())));
};
const getAttribute = (element, key2, defaultValue2) => {
const value = element.getAttribute(key2);
return isNull(value) ? defaultValue2 : value;
};
const removeAttribute = (element, key2) => {
element.removeAttribute(key2);
};
const setAttribute = (element, key2, value) => {
isNull(value) ? removeAttribute(element, key2) : element.setAttribute(key2, value);
};
$$1.fn.each = function(callback) {
return eachArray(this, (value, index) => {
return callback.call(value, index, value);
});
};
eachArray(["add", "remove", "toggle"], (name) => {
$$1.fn[`${name}Class`] = function(className2) {
if (name === "remove" && !arguments.length) {
return this.each((_2, element) => {
setAttribute(element, "class", "");
});
}
return this.each((i3, element) => {
if (!isElement(element)) {
return;
}
const classes = (isFunction(className2) ? className2.call(element, i3, getAttribute(element, "class", "")) : className2).split(" ").filter((name2) => name2);
eachArray(classes, (cls) => {
element.classList[name](cls);
});
});
};
});
eachArray(["insertBefore", "insertAfter"], (name, nameIndex) => {
$$1.fn[name] = function(target) {
const $element = nameIndex ? $$1(this.get().reverse()) : this;
const $target = $$1(target);
const result = [];
$target.each((index, target2) => {
if (!target2.parentNode) {
return;
}
$element.each((_2, element) => {
const newItem = index ? element.cloneNode(true) : element;
const existingItem = nameIndex ? target2.nextSibling : target2;
result.push(newItem);
target2.parentNode.insertBefore(newItem, existingItem);
});
});
return $$1(nameIndex ? result.reverse() : result);
};
});
const isPlainText = (target) => {
return isString(target) && !(target.startsWith("<") && target.endsWith(">"));
};
eachArray(["before", "after"], (name, nameIndex) => {
$$1.fn[name] = function(...args) {
if (nameIndex === 1) {
args = args.reverse();
}
return this.each((index, element) => {
const targets = isFunction(args[0]) ? [args[0].call(element, index, element.innerHTML)] : args;
eachArray(targets, (target) => {
let $target;
if (isPlainText(target)) {
$target = $$1(getChildNodesArray(target, "div"));
} else if (index && isElement(target)) {
$target = $$1(target.cloneNode(true));
} else {
$target = $$1(target);
}
$target[nameIndex ? "insertAfter" : "insertBefore"](element);
});
});
};
});
function each(target, callback) {
return isArrayLike(target) ? eachArray(target, (value, index) => {
return callback.call(value, index, value);
}) : eachObject(target, callback);
}
function map(elements, callback) {
const window2 = getWindow$1();
let value;
const ret = [];
each(elements, (i3, element) => {
value = callback.call(window2, element, i3);
if (value != null) {
ret.push(value);
}
});
return [].concat(...ret);
}
$$1.fn.map = function(callback) {
return new JQ(map(this, (element, i3) => {
return callback.call(element, i3, element);
}));
};
$$1.fn.clone = function() {
return this.map(function() {
return this.cloneNode(true);
});
};
$$1.fn.is = function(selector) {
let isMatched = false;
if (isFunction(selector)) {
this.each((index, element) => {
if (selector.call(element, index, element)) {
isMatched = true;
}
});
return isMatched;
}
if (isString(selector)) {
this.each((_2, element) => {
if (isDocument(element) || isWindow(element)) {
return;
}
if (element.matches.call(element, selector)) {
isMatched = true;
}
});
return isMatched;
}
const $compareWith = $$1(selector);
this.each((_2, element) => {
$compareWith.each((_3, compare) => {
if (element === compare) {
isMatched = true;
}
});
});
return isMatched;
};
$$1.fn.remove = function(selector) {
return this.each((_2, element) => {
if (!selector || $$1(element).is(selector)) {
removeChild(element);
}
});
};
eachArray(["prepend", "append"], (name, nameIndex) => {
$$1.fn[name] = function(...args) {
return this.each((index, element) => {
const childNodes = element.childNodes;
const childLength = childNodes.length;
const child = childLength ? childNodes[nameIndex ? childLength - 1 : 0] : createElement("div");
if (!childLength) {
appendChild(element, child);
}
let contents = isFunction(args[0]) ? [args[0].call(element, index, element.innerHTML)] : args;
if (index) {
contents = contents.map((content) => {
return isString(content) ? content : $$1(content).clone();
});
}
$$1(child)[nameIndex ? "after" : "before"](...contents);
if (!childLength) {
removeChild(child);
}
});
};
});
eachArray(["appendTo", "prependTo"], (name, nameIndex) => {
$$1.fn[name] = function(target) {
const extraChilds = [];
const $target = $$1(target).map((_2, element) => {
const childNodes = element.childNodes;
const childLength = childNodes.length;
if (childLength) {
return childNodes[nameIndex ? 0 : childLength - 1];
}
const child = createElement("div");
appendChild(element, child);
extraChilds.push(child);
return child;
});
const $result = this[nameIndex ? "insertBefore" : "insertAfter"]($target);
$$1(extraChilds).remove();
return $result;
};
});
const getComputedStyleValue = (element, name) => {
const window2 = getWindow$1();
return window2.getComputedStyle(element).getPropertyValue(toKebabCase(name));
};
const isBorderBox = (element) => {
return getComputedStyleValue(element, "box-sizing") === "border-box";
};
const getExtraWidth = (element, direction, extra) => {
const position = direction === "width" ? ["Left", "Right"] : ["Top", "Bottom"];
return [0, 1].reduce((prev, _2, index) => {
let prop = extra + position[index];
if (extra === "border") {
prop += "Width";
}
return prev + parseFloat(getComputedStyleValue(element, prop) || "0");
}, 0);
};
const getStyle = (element, name) => {
if (name === "width" || name === "height") {
const valueNumber = element.getBoundingClientRect()[name];
if (isBorderBox(element)) {
return `${valueNumber}px`;
}
return `${valueNumber - getExtraWidth(element, name, "border") - getExtraWidth(element, name, "padding")}px`;
}
return getComputedStyleValue(element, name);
};
const cssNumber = [
"animation-iteration-count",
"column-count",
"fill-opacity",
"flex-grow",
"flex-shrink",
"font-weight",
"grid-area",
"grid-column",
"grid-column-end",
"grid-column-start",
"grid-row",
"grid-row-end",
"grid-row-start",
"line-height",
"opacity",
"order",
"orphans",
"widows",
"z-index",
"zoom"
];
eachArray(["attr", "prop", "css"], (name, nameIndex) => {
const set2 = (element, key2, value) => {
if (isUndefined(value)) {
return;
}
if (nameIndex === 0) {
return setAttribute(element, key2, value);
}
if (nameIndex === 1) {
element[key2] = value;
return;
}
key2 = toKebabCase(key2);
const getSuffix = () => key2.startsWith("--") || cssNumber.includes(key2) ? "" : "px";
element.style.setProperty(key2, isNumber(value) ? `${value}${getSuffix()}` : value);
};
const get2 = (element, key2) => {
if (nameIndex === 0) {
return getAttribute(element, key2);
}
if (nameIndex === 1) {
return element[key2];
}
return getStyle(element, key2);
};
$$1.fn[name] = function(key2, value) {
if (isObjectLike(key2)) {
eachObject(key2, (k3, v2) => {
this[name](k3, v2);
});
return this;
}
if (arguments.length === 1) {
const element = this[0];
return isElement(element) ? get2(element, key2) : void 0;
}
return this.each((i3, element) => {
set2(element, key2, isFunction(value) ? value.call(element, i3, get2(element, key2)) : value);
});
};
});
$$1.fn.children = function(selector) {
const children = [];
this.each((_2, element) => {
eachArray(element.childNodes, (childNode) => {
if (!isElement(childNode)) {
return;
}
if (!selector || $$1(childNode).is(selector)) {
children.push(childNode);
}
});
});
return new JQ(unique(children));
};
$$1.fn.slice = function(...args) {
return new JQ([].slice.apply(this, args));
};
$$1.fn.eq = function(index) {
const ret = index === -1 ? this.slice(index) : this.slice(index, +index + 1);
return new JQ(ret);
};
const dir = ($elements, nameIndex, node, selector, filter) => {
const ret = [];
let target;
$elements.each((_2, element) => {
target = element[node];
while (target && isElement(target)) {
if (nameIndex === 2) {
if (selector && $$1(target).is(selector)) {
break;
}
if (!filter || $$1(target).is(filter)) {
ret.push(target);
}
} else if (nameIndex === 0) {
if (!selector || $$1(target).is(selector)) {
ret.push(target);
}
break;
} else {
if (!selector || $$1(target).is(selector)) {
ret.push(target);
}
}
target = target[node];
}
});
return new JQ(unique(ret));
};
eachArray(["", "s", "sUntil"], (name, nameIndex) => {
$$1.fn[`parent${name}`] = function(selector, filter) {
const $nodes = !nameIndex ? this : $$1(this.get().reverse());
return dir($nodes, nameIndex, "parentNode", selector, filter);
};
});
$$1.fn.closest = function(selector) {
if (this.is(selector)) {
return this;
}
const matched = [];
this.parents().each((_2, element) => {
if ($$1(element).is(selector)) {
matched.push(element);
return false;
}
});
return new JQ(matched);
};
const weakMap$2 = /* @__PURE__ */ new WeakMap();
const getAll = (element) => {
return weakMap$2.get(element) ?? {};
};
const get$2 = (element, keyOriginal) => {
const data2 = getAll(element);
const key2 = toCamelCase(keyOriginal);
return key2 in data2 ? data2[key2] : void 0;
};
const setAll = (element, object) => {
const data2 = getAll(element);
eachObject(object, (keyOriginal, value) => {
data2[toCamelCase(keyOriginal)] = value;
});
weakMap$2.set(element, data2);
};
const set$2 = (element, keyOriginal, value) => {
setAll(element, { [keyOriginal]: value });
};
const removeAll = (element) => {
weakMap$2.delete(element);
};
const removeMultiple = (element, keysOriginal) => {
const data2 = getAll(element);
eachArray(keysOriginal, (keyOriginal) => {
const key2 = toCamelCase(keyOriginal);
delete data2[key2];
});
weakMap$2.set(element, data2);
};
const rbrace = /^(?:{[\w\W]*\}|\[[\w\W]*\])$/;
const stringTransform = (value) => {
if (value === "true") {
return true;
}
if (value === "false") {
return false;
}
if (value === "null") {
return null;
}
if (value === +value + "") {
return +value;
}
if (rbrace.test(value)) {
return JSON.parse(value);
}
return value;
};
const dataAttr = (element, key2, value) => {
if (isUndefined(value) && element.nodeType === 1) {
value = element.dataset[key2];
if (isString(value)) {
try {
value = stringTransform(value);
} catch (e3) {
}
}
}
return value;
};
$$1.fn.data = function(key2, value) {
if (isUndefined(key2)) {
if (!this.length) {
return void 0;
}
const element = this[0];
const resultData = getAll(element);
if (element.nodeType !== 1) {
return resultData;
}
eachObject(element.dataset, (key3) => {
resultData[key3] = dataAttr(element, key3, resultData[key3]);
});
return resultData;
}
if (isObjectLike(key2)) {
return this.each(function() {
setAll(this, key2);
});
}
if (arguments.length === 2 && isUndefined(value)) {
return this;
}
if (!isUndefined(value)) {
return this.each(function() {
set$2(this, key2, value);
});
}
if (!this.length) {
return void 0;
}
return dataAttr(this[0], toCamelCase(key2), get$2(this[0], key2));
};
$$1.fn.empty = function() {
return this.each((_2, element) => {
element.innerHTML = "";
});
};
$$1.fn.extend = function(obj) {
eachObject(obj, (prop, value) => {
$$1.fn[prop] = value;
});
return this;
};
$$1.fn.filter = function(selector) {
if (isFunction(selector)) {
return this.map((index, element) => {
return selector.call(element, index, element) ? element : void 0;
});
}
if (isString(selector)) {
return this.map((_2, element) => {
return $$1(element).is(selector) ? element : void 0;
});
}
const $selector = $$1(selector);
return this.map((_2, element) => {
return $selector.get().includes(element) ? element : void 0;
});
};
$$1.fn.find = function(selector) {
const foundElements = [];
this.each((_2, element) => {
merge(foundElements, $$1(element.querySelectorAll(selector)).get());
});
return new JQ(foundElements);
};
$$1.fn.first = function() {
return this.eq(0);
};
const contains = (container2, contains2) => {
return container2 !== contains2 && toElement(container2).contains(contains2);
};
$$1.fn.has = function(selector) {
const $targets = isString(selector) ? this.find(selector) : $$1(selector);
const { length } = $targets;
return this.map(function() {
for (let i3 = 0; i3 < length; i3 += 1) {
if (contains(this, $targets[i3])) {
return this;
}
}
return;
});
};
$$1.fn.hasClass = function(className2) {
return this[0].classList.contains(className2);
};
const handleExtraWidth = (element, name, value, funcIndex, includeMargin, multiply) => {
const getExtraWidthValue = (extra) => {
return getExtraWidth(element, name.toLowerCase(), extra) * multiply;
};
if (funcIndex === 2 && includeMargin) {
value += getExtraWidthValue("margin");
}
if (isBorderBox(element)) {
if (funcIndex === 0) {
value -= getExtraWidthValue("border");
}
if (funcIndex === 1) {
value -= getExtraWidthValue("border");
value -= getExtraWidthValue("padding");
}
} else {
if (funcIndex === 0) {
value += getExtraWidthValue("padding");
}
if (funcIndex === 2) {
value += getExtraWidthValue("border");
value += getExtraWidthValue("padding");
}
}
return value;
};
const get$1 = (element, name, funcIndex, includeMargin) => {
const document2 = getDocument();
const clientProp = `client${name}`;
const scrollProp = `scroll${name}`;
const offsetProp = `offset${name}`;
const innerProp = `inner${name}`;
if (isWindow(element)) {
return funcIndex === 2 ? element[innerProp] : toElement(document2)[clientProp];
}
if (isDocument(element)) {
const doc = toElement(element);
return Math.max(
// @ts-ignore
element.body[scrollProp],
doc[scrollProp],
// @ts-ignore
element.body[offsetProp],
doc[offsetProp],
doc[clientProp]
);
}
const value = parseFloat(getComputedStyleValue(element, name.toLowerCase()) || "0");
return handleExtraWidth(element, name, value, funcIndex, includeMargin, 1);
};
const set$1 = (element, elementIndex, name, funcIndex, includeMargin, value) => {
let computedValue = isFunction(value) ? value.call(element, elementIndex, get$1(element, name, funcIndex, includeMargin)) : value;
if (computedValue == null) {
return;
}
const $element = $$1(element);
const dimension = name.toLowerCase();
if (isString(computedValue) && ["auto", "inherit", ""].includes(computedValue)) {
$element.css(dimension, computedValue);
return;
}
const suffix = computedValue.toString().replace(/\b[0-9.]*/, "");
const numerical = parseFloat(computedValue);
computedValue = handleExtraWidth(element, name, numerical, funcIndex, includeMargin, -1) + (suffix || "px");
$element.css(dimension, computedValue);
};
eachArray(["Width", "Height"], (name) => {
eachArray([`inner${name}`, name.toLowerCase(), `outer${name}`], (funcName, funcIndex) => {
$$1.fn[funcName] = function(margin, value) {
const isSet = arguments.length && (funcIndex < 2 || !isBoolean(margin));
const includeMargin = margin === true || value === true;
if (!isSet) {
return this.length ? get$1(this[0], name, funcIndex, includeMargin) : void 0;
}
return this.each((index, element) => {
return set$1(element, index, name, funcIndex, includeMargin, margin);
});
};
});
});
$$1.fn.hide = function() {
return this.each((_2, element) => {
element.style.display = "none";
});
};
eachArray(["val", "html", "text"], (name, nameIndex) => {
const props = ["value", "innerHTML", "textContent"];
const propName = props[nameIndex];
const get2 = ($elements) => {
if (nameIndex === 2) {
return map($elements, (element) => {
return toElement(element)[propName];
}).join("");
}
if (!$elements.length) {
return void 0;
}
const firstElement = $elements[0];
const $firstElement = $$1(firstElement);
if (nameIndex === 0 && $firstElement.is("select[multiple]")) {
return map($firstElement.find("option:checked"), (element) => element.value);
}
return firstElement[propName];
};
const set2 = (element, value) => {
if (isUndefined(value)) {
if (nameIndex !== 0) {
return;
}
value = "";
}
if (nameIndex === 1 && isElement(value)) {
value = value.outerHTML;
}
element[propName] = value;
};
$$1.fn[name] = function(value) {
if (!arguments.length) {
return get2(this);
}
return this.each((i3, element) => {
const $element = $$1(element);
const computedValue = isFunction(value) ? value.call(element, i3, get2($element)) : value;
if (nameIndex === 0 && Array.isArray(computedValue)) {
if ($element.is("select[multiple]")) {
map($element.find("option"), (option) => {
return option.selected = computedValue.includes(option.value);
});
} else {
element.checked = computedValue.includes(element.value);
}
} else {
set2(element, computedValue);
}
});
};
});
$$1.fn.index = function(selector) {
if (!arguments.length) {
return this.eq(0).parent().children().get().indexOf(this[0]);
}
if (isString(selector)) {
return $$1(selector).get().indexOf(this[0]);
}
return this.get().indexOf($$1(selector)[0]);
};
$$1.fn.last = function() {
return this.eq(-1);
};
eachArray(["", "All", "Until"], (name, nameIndex) => {
$$1.fn[`next${name}`] = function(selector, filter) {
return dir(this, nameIndex, "nextElementSibling", selector, filter);
};
});
$$1.fn.not = function(selector) {
const $excludes = this.filter(selector);
return this.map((_2, element) => {
return $excludes.index(element) > -1 ? void 0 : element;
});
};
const CustomEvent$1 = getWindow$1().CustomEvent;
class MduiCustomEvent extends CustomEvent$1 {
constructor(type, options) {
super(type, options);
this.data = options.data;
this.namespace = options.namespace;
}
}
const elementIdMap = /* @__PURE__ */ new WeakMap();
let elementId = 1;
const getElementId = (element) => {
if (!elementIdMap.has(element)) {
elementIdMap.set(element, ++elementId);
}
return elementIdMap.get(element);
};
const handlersMap = /* @__PURE__ */ new Map();
const getHandlers = (element) => {
const id2 = getElementId(element);
return handlersMap.get(id2) || handlersMap.set(id2, []).get(id2);
};
const parse$1 = (type) => {
const parts = type.split(".");
return {
type: parts[0],
namespace: parts.slice(1).sort().join(" ")
};
};
const matcherFor = (namespace) => {
return new RegExp("(?:^| )" + namespace.replace(" ", " .* ?") + "(?: |$)");
};
const getMatchedHandlers = (element, type, func, selector) => {
const event = parse$1(type);
return getHandlers(element).filter((handler) => {
return handler && (!event.type || handler.type === event.type) && (!event.namespace || matcherFor(event.namespace).test(handler.namespace)) && (!func || getElementId(handler.func) === getElementId(func)) && (!selector || handler.selector === selector);
});
};
const add = (element, types, func, data2, selector) => {
let useCapture = false;
if (isObjectLike(data2) && data2.useCapture) {
useCapture = true;
}
types.split(" ").forEach((type) => {
if (!type) {
return;
}
const event = parse$1(type);
const callFn = (e3, elem) => {
const result = func.apply(
elem,
// @ts-ignore
e3.detail === null ? [e3] : [e3].concat(e3.detail)
);
if (result === false) {
e3.preventDefault();
e3.stopPropagation();
}
};
const proxyFn = (e3) => {
if (e3.namespace && !matcherFor(e3.namespace).test(event.namespace)) {
return;
}
e3.data = data2;
if (selector) {
$$1(element).find(selector).get().reverse().forEach((elem) => {
if (elem === e3.target || contains(elem, e3.target)) {
callFn(e3, elem);
}
});
} else {
callFn(e3, element);
}
};
const handler = {
type: event.type,
namespace: event.namespace,
func,
selector,
id: getHandlers(element).length,
proxy: proxyFn
};
getHandlers(element).push(handler);
element.addEventListener(handler.type, proxyFn, useCapture);
});
};
const remove$1 = (element, types, func, selector) => {
const handlersInElement = getHandlers(element);
const removeEvent = (handler) => {
delete handlersInElement[handler.id];
element.removeEventListener(handler.type, handler.proxy, false);
};
if (!types) {
handlersInElement.forEach((handler) => {
removeEvent(handler);
});
} else {
types.split(" ").forEach((type) => {
if (type) {
getMatchedHandlers(element, type, func, selector).forEach((handler) => {
removeEvent(handler);
});
}
});
}
};
$$1.fn.off = function(types, selector, callback) {
if (isObjectLike(types)) {
eachObject(types, (type, fn) => {
this.off(type, selector, fn);
});
return this;
}
if (selector === false || isFunction(selector)) {
callback = selector;
selector = void 0;
}
if (callback === false) {
callback = returnFalse;
}
return this.each(function() {
remove$1(this, types, callback, selector);
});
};
function extend(target, ...objectN) {
eachArray(objectN, (object) => {
eachObject(object, (prop, value) => {
if (!isUndefined(value)) {
target[prop] = value;
}
});
});
return target;
}
$$1.fn.offsetParent = function() {
const document2 = getDocument();
return this.map(function() {
let offsetParent = this.offsetParent;
while (offsetParent && $$1(offsetParent).css("position") === "static") {
offsetParent = offsetParent.offsetParent;
}
return offsetParent || document2.documentElement;
});
};
const floatStyle = ($element, name) => {
return parseFloat($element.css(name));
};
$$1.fn.position = function() {
if (!this.length) {
return void 0;
}
const $element = this.eq(0);
let currentOffset;
let parentOffset = {
left: 0,
top: 0
};
if ($element.css("position") === "fixed") {
currentOffset = $element[0].getBoundingClientRect();
} else {
currentOffset = $element.offset();
const $offsetParent = $element.offsetParent();
parentOffset = $offsetParent.offset();
parentOffset.top += floatStyle($offsetParent, "border-top-width");
parentOffset.left += floatStyle($offsetParent, "border-left-width");
}
return {
top: currentOffset.top - parentOffset.top - floatStyle($element, "margin-top"),
left: currentOffset.left - parentOffset.left - floatStyle($element, "margin-left")
};
};
const get = (element) => {
if (!element.getClientRects().length) {
return { top: 0, left: 0 };
}
const { top: top2, left } = element.getBoundingClientRect();
const { pageYOffset, pageXOffset } = element.ownerDocument.defaultView;
return {
top: top2 + pageYOffset,
left: left + pageXOffset
};
};
const set = (element, value, index) => {
const $element = $$1(element);
const position = $element.css("position");
if (position === "static") {
$element.css("position", "relative");
}
const currentOffset = get(element);
const currentTopString = $element.css("top");
const currentLeftString = $element.css("left");
let currentTop;
let currentLeft;
const calculatePosition = (position === "absolute" || position === "fixed") && (currentTopString + currentLeftString).includes("auto");
if (calculatePosition) {
const currentPosition = $element.position();
currentTop = currentPosition.top;
currentLeft = currentPosition.left;
} else {
currentTop = parseFloat(currentTopString);
currentLeft = parseFloat(currentLeftString);
}
const computedValue = isFunction(value) ? value.call(element, index, extend({}, currentOffset)) : value;
$element.css({
top: computedValue.top != null ? computedValue.top - currentOffset.top + currentTop : void 0,
left: computedValue.left != null ? computedValue.left - currentOffset.left + currentLeft : void 0
});
};
$$1.fn.offset = function(value) {
if (!arguments.length) {
if (!this.length) {
return void 0;
}
return get(this[0]);
}
return this.each(function(index) {
set(this, value, index);
});
};
$$1.fn.on = function(types, selector, data2, callback, one) {
if (isObjectLike(types)) {
if (!isString(selector)) {
data2 = data2 || selector;
selector = void 0;
}
eachObject(types, (type, fn) => {
this.on(type, selector, data2, fn, one);
});
return this;
}
if (data2 == null && callback == null) {
callback = selector;
data2 = selector = void 0;
} else if (callback == null) {
if (isString(selector)) {
callback = data2;
data2 = void 0;
} else {
callback = data2;
data2 = selector;
selector = void 0;
}
}
if (callback === false) {
callback = returnFalse;
} else if (!callback) {
return this;
}
if (one) {
const _this = this;
const origCallback = callback;
callback = function(event, ...dataN) {
_this.off(event.type, selector, callback);
return origCallback.call(this, event, ...dataN);
};
}
return this.each(function() {
add(this, types, callback, data2, selector);
});
};
$$1.fn.one = function(types, selector, data2, callback) {
return this.on(types, selector, data2, callback, true);
};
eachArray(["", "All", "Until"], (name, nameIndex) => {
$$1.fn[`prev${name}`] = function(selector, filter) {
const $nodes = !nameIndex ? this : $$1(this.get().reverse());
return dir($nodes, nameIndex, "previousElementSibling", selector, filter);
};
});
$$1.fn.removeAttr = function(attributeName) {
const names = attributeName.split(" ").filter((name) => name);
return this.each(function() {
eachArray(names, (name) => {
removeAttribute(this, name);
});
});
};
const removeData = (element, name) => {
if (isUndefined(name)) {
return removeAll(element);
}
const keys = isString(name) ? name.split(" ").filter((nameItem) => nameItem) : name;
removeMultiple(element, keys);
};
$$1.fn.removeData = function(name) {
return this.each((_2, element) => {
removeData(element, name);
});
};
$$1.fn.removeProp = function(name) {
return this.each((_2, element) => {
try {
delete element[name];
} catch (e3) {
}
});
};
$$1.fn.replaceWith = function(newContent) {
this.each((index, element) => {
let content = newContent;
if (isFunction(content)) {
content = content.call(element, index, element.innerHTML);
} else if (index && !isString(content)) {
content = $$1(content).clone();
}
$$1(element).before(content);
});
return this.remove();
};
$$1.fn.replaceAll = function(target) {
return $$1(target).map((index, element) => {
$$1(element).replaceWith(index ? this.clone() : this);
return this.get();
});
};
const param = (obj) => {
if (!isObjectLike(obj) && !Array.isArray(obj)) {
return "";
}
const args = [];
const destructure = (key2, value) => {
let keyTmp;
if (isObjectLike(value)) {
eachObject(value, (i3, v2) => {
keyTmp = Array.isArray(value) && !isObjectLike(v2) ? "" : i3;
destructure(`${key2}[${keyTmp}]`, v2);
});
} else {
keyTmp = value == null || value === "" ? "=" : `=${encodeURIComponent(value)}`;
args.push(encodeURIComponent(key2) + keyTmp);
}
};
if (Array.isArray(obj)) {
eachArray(obj, ({ name, value }) => {
return destructure(name, value);
});
} else {
eachObject(obj, destructure);
}
return args.join("&");
};
const formCollections = /* @__PURE__ */ new WeakMap();
const getFormControls = (form) => {
const nativeFormControls = [...form.elements];
const formControls = formCollections.get(form) || [];
const comparePosition = (a2, b3) => {
const position = a2.compareDocumentPosition(b3);
return position & Node.DOCUMENT_POSITION_FOLLOWING ? -1 : 1;
};
return [...nativeFormControls, ...formControls].sort(comparePosition);
};
const getFormControlsValue = ($elements) => {
const result = [];
$elements.each((_2, element) => {
const elements = element instanceof HTMLFormElement ? getFormControls(element) : [element];
$$1(elements).each((_3, element2) => {
const $element = $$1(element2);
const type = element2.type;
const nodeName = element2.nodeName.toLowerCase();
if (nodeName !== "fieldset" && element2.name && !element2.disabled && [
"input",
"select",
"textarea",
"keygen",
"mdui-checkbox",
"mdui-radio-group",
"mdui-switch",
"mdui-text-field",
"mdui-select",
"mdui-slider",
"mdui-range-slider",
"mdui-segmented-button-group"
].includes(nodeName) && !["submit", "button", "image", "reset", "file"].includes(type) && (!["radio", "checkbox"].includes(type) || element2.checked) && (!["mdui-checkbox", "mdui-switch"].includes(nodeName) || element2.checked)) {
result.push({
name: element2.name,
value: $element.val()
});
}
});
});
return result;
};
$$1.fn.serializeArray = function() {
return getFormControlsValue(this).map((element) => {
if (!Array.isArray(element.value)) {
return element;
}
return element.value.map((value) => ({
name: element.name,
value
}));
}).flat();
};
$$1.fn.serialize = function() {
return param(this.serializeArray());
};
$$1.fn.serializeObject = function() {
const result = {};
getFormControlsValue(this).forEach((element) => {
const { name, value } = element;
if (!result.hasOwnProperty(name)) {
result[name] = value;
} else {
const originalValue = result[name];
if (!Array.isArray(originalValue)) {
result[name] = [originalValue];
}
if (Array.isArray(value)) {
result[name].push(...value);
} else {
result[name].push(value);
}
}
});
return result;
};
const elementDisplay = {};
const defaultDisplay = (nodeName) => {
const document2 = getDocument();
let element;
let display;
if (!elementDisplay[nodeName]) {
element = createElement(nodeName);
appendChild(document2.body, element);
display = getStyle(element, "display");
removeChild(element);
if (display === "none") {
display = "block";
}
elementDisplay[nodeName] = display;
}
return elementDisplay[nodeName];
};
$$1.fn.show = function() {
return this.each((_2, element) => {
if (element.style.display === "none") {
element.style.display = "";
}
if (getStyle(element, "display") === "none") {
element.style.display = defaultDisplay(element.nodeName);
}
});
};
$$1.fn.siblings = function(selector) {
return this.prevAll(selector).add(this.nextAll(selector));
};
$$1.fn.toggle = function() {
return this.each((_2, element) => {
getStyle(element, "display") === "none" ? $$1(element).show() : $$1(element).hide();
});
};
$$1.fn.trigger = function(name, detail = null, options) {
const { type, namespace } = parse$1(name);
const event = new MduiCustomEvent(type, {
detail,
data: null,
namespace,
bubbles: true,
cancelable: false,
composed: true,
...options
});
return this.each((_2, element) => {
element.dispatchEvent(event);
});
};
const ajaxStart = "ajaxStart";
const ajaxSuccess = "ajaxSuccess";
const ajaxError = "ajaxError";
const ajaxComplete = "ajaxComplete";
const globalOptions = {};
const isQueryStringData = (method) => {
return ["GET", "HEAD"].includes(method);
};
const appendQuery = (url, query) => {
return `${url}&${query}`.replace(/[&?]{1,2}/, "?");
};
const isCrossDomain = (url) => {
const window2 = getWindow$1();
return /^([\w-]+:)?\/\/([^/]+)/.test(url) && RegExp.$2 !== window2.location.host;
};
const isHttpStatusSuccess = (status) => {
return status >= 200 && status < 300 || [0, 304].includes(status);
};
const mergeOptions = (options) => {
const defaults = {
url: "",
method: "GET",
data: "",
processData: true,
async: true,
cache: true,
username: "",
password: "",
headers: {},
xhrFields: {},
statusCode: {},
dataType: "",
contentType: "application/x-www-form-urlencoded",
timeout: 0,
global: true
};
eachObject(globalOptions, (key2, value) => {
const callbacks = [
"beforeSend",
"success",
"error",
"complete",
"statusCode"
];
if (!callbacks.includes(key2) && !isUndefined(value)) {
defaults[key2] = value;
}
});
return extend({}, defaults, options);
};
const ajax = (options) => {
const document2 = getDocument();
const window2 = getWindow$1();
let isCanceled = false;
const eventParams = {};
const successEventParams = {};
const mergedOptions = mergeOptions(options);
const method = mergedOptions.method.toUpperCase();
let { data: data2, url } = mergedOptions;
url = url || window2.location.toString();
const { processData, async, cache, username, password, headers, xhrFields, statusCode, dataType, contentType, timeout, global: global2 } = mergedOptions;
const isMethodQueryString = isQueryStringData(method);
if (data2 && (isMethodQueryString || processData) && !isString(data2) && !(data2 instanceof ArrayBuffer) && !(data2 instanceof Blob) && !(data2 instanceof Document) && !(data2 instanceof FormData)) {
data2 = param(data2);
}
if (data2 && isMethodQueryString) {
url = appendQuery(url, data2);
data2 = null;
}
const trigger = (event, callback, ...args) => {
if (global2) {
$$1(document2).trigger(event, callback === "success" ? successEventParams : eventParams);
}
let resultGlobal;
let resultCustom;
if (callback in globalOptions) {
resultGlobal = globalOptions[callback](...args);
}
if (mergedOptions[callback]) {
resultCustom = mergedOptions[callback](...args);
}
if (callback === "beforeSend" && [resultGlobal, resultCustom].includes(false)) {
isCanceled = true;
}
};
const XHR = () => {
let textStatus;
return new Promise((resolve, reject) => {
const doReject = (reason) => {
return reject(new Error(reason));
};
if (isMethodQueryString && !cache) {
url = appendQuery(url, `_=${Date.now()}`);
}
const xhr = new XMLHttpRequest();
xhr.open(method, url, async, username, password);
if (contentType || data2 && !isMethodQueryString && contentType !== false) {
xhr.setRequestHeader("Content-Type", contentType);
}
if (dataType === "json") {
xhr.setRequestHeader("Accept", "application/json, text/javascript");
}
eachObject(headers, (key2, value) => {
if (!isUndefined(value)) {
xhr.setRequestHeader(key2, value + "");
}
});
if (!isCrossDomain(url)) {
xhr.setRequestHeader("X-Requested-With", "XMLHttpRequest");
}
eachObject(xhrFields, (key2, value) => {
xhr[key2] = value;
});
eventParams.xhr = successEventParams.xhr = xhr;
eventParams.options = successEventParams.options = mergedOptions;
let xhrTimeout;
xhr.onload = () => {
if (xhrTimeout) {
clearTimeout(xhrTimeout);
}
const isSuccess = isHttpStatusSuccess(xhr.status);
let responseData = void 0;
if (isSuccess) {
textStatus = xhr.status === 204 || method === "HEAD" ? "nocontent" : xhr.status === 304 ? "notmodified" : "success";
if (dataType === "json" || !dataType && (xhr.getResponseHeader("content-type") || "").includes("json")) {
try {
responseData = method === "HEAD" ? void 0 : JSON.parse(xhr.responseText);
successEventParams.response = responseData;
} catch (err) {
textStatus = "parsererror";
trigger(ajaxError, "error", xhr, textStatus);
doReject(textStatus);
}
if (textStatus !== "parsererror") {
trigger(ajaxSuccess, "success", responseData, textStatus, xhr);
resolve(responseData);
}
} else {
responseData = method === "HEAD" ? void 0 : xhr.responseType === "text" || xhr.responseType === "" ? xhr.responseText : xhr.response;
successEventParams.response = responseData;
trigger(ajaxSuccess, "success", responseData, textStatus, xhr);
resolve(responseData);
}
} else {
textStatus = "error";
trigger(ajaxError, "error", xhr, textStatus);
doReject(textStatus);
}
eachArray([globalOptions.statusCode ?? {}, statusCode], (func) => {
if (func[xhr.status]) {
if (isSuccess) {
func[xhr.status](responseData, textStatus, xhr);
} else {
func[xhr.status](xhr, textStatus);
}
}
});
trigger(ajaxComplete, "complete", xhr, textStatus);
};
xhr.onerror = () => {
if (xhrTimeout) {
clearTimeout(xhrTimeout);
}
trigger(ajaxError, "error", xhr, xhr.statusText);
trigger(ajaxComplete, "complete", xhr, "error");
doReject(xhr.statusText);
};
xhr.onabort = () => {
let statusText = "abort";
if (xhrTimeout) {
statusText = "timeout";
clearTimeout(xhrTimeout);
}
trigger(ajaxError, "error", xhr, statusText);
trigger(ajaxComplete, "complete", xhr, statusText);
doReject(statusText);
};
trigger(ajaxStart, "beforeSend", xhr, mergedOptions);
if (isCanceled) {
return doReject("cancel");
}
if (timeout > 0) {
xhrTimeout = window2.setTimeout(() => xhr.abort(), timeout);
}
xhr.send(data2);
});
};
return XHR();
};
$$1.ajax = ajax;
const ajaxSetup = (options) => {
return extend(globalOptions, options);
};
$$1.ajaxSetup = ajaxSetup;
$$1.contains = contains;
function data(element, key2, value) {
if (isObjectLike(key2)) {
setAll(element, key2);
return key2;
}
if (!isUndefined(value)) {
set$2(element, key2, value);
return value;
}
if (isUndefined(key2)) {
return getAll(element);
}
return get$2(element, key2);
}
$$1.data = data;
$$1.each = each;
$$1.extend = function(target, ...objectN) {
if (!objectN.length) {
eachObject(target, (prop, value) => {
this[prop] = value;
});
return this;
}
return extend(target, ...objectN);
};
$$1.map = map;
$$1.merge = merge;
$$1.param = param;
$$1.removeData = removeData;
$$1.unique = unique;
function __decorate(decorators, target, key2, desc) {
var c3 = arguments.length, r3 = c3 < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key2) : desc, d2;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r3 = Reflect.decorate(decorators, target, key2, desc);
else for (var i3 = decorators.length - 1; i3 >= 0; i3--) if (d2 = decorators[i3]) r3 = (c3 < 3 ? d2(r3) : c3 > 3 ? d2(target, key2, r3) : d2(target, key2)) || r3;
return c3 > 3 && r3 && Object.defineProperty(target, key2, r3), r3;
}
typeof SuppressedError === "function" ? SuppressedError : function(error, suppressed, message) {
var e3 = new Error(message);
return e3.name = "SuppressedError", e3.error = error, e3.suppressed = suppressed, e3;
};
/**
* @license
* Copyright 2019 Google LLC
* SPDX-License-Identifier: BSD-3-Clause
*/
const t$5 = globalThis, e$8 = t$5.ShadowRoot && (void 0 === t$5.ShadyCSS || t$5.ShadyCSS.nativeShadow) && "adoptedStyleSheets" in Document.prototype && "replace" in CSSStyleSheet.prototype, s$4 = Symbol(), o$a = /* @__PURE__ */ new WeakMap();
let n$9 = class n {
constructor(t3, e3, o2) {
if (this._$cssResult$ = true, o2 !== s$4) throw Error("CSSResult is not constructable. Use `unsafeCSS` or `css` instead.");
this.cssText = t3, this.t = e3;
}
get styleSheet() {
let t3 = this.o;
const s3 = this.t;
if (e$8 && void 0 === t3) {
const e3 = void 0 !== s3 && 1 === s3.length;
e3 && (t3 = o$a.get(s3)), void 0 === t3 && ((this.o = t3 = new CSSStyleSheet()).replaceSync(this.cssText), e3 && o$a.set(s3, t3));
}
return t3;
}
toString() {
return this.cssText;
}
};
const r$6 = (t3) => new n$9("string" == typeof t3 ? t3 : t3 + "", void 0, s$4), i$7 = (t3, ...e3) => {
const o2 = 1 === t3.length ? t3[0] : e3.reduce((e4, s3, o3) => e4 + ((t4) => {
if (true === t4._$cssResult$) return t4.cssText;
if ("number" == typeof t4) return t4;
throw Error("Value passed to 'css' function must be a 'css' function result: " + t4 + ". Use 'unsafeCSS' to pass non-literal values, but take care to ensure page security.");
})(s3) + t3[o3 + 1], t3[0]);
return new n$9(o2, t3, s$4);
}, S$1 = (s3, o2) => {
if (e$8) s3.adoptedStyleSheets = o2.map((t3) => t3 instanceof CSSStyleSheet ? t3 : t3.styleSheet);
else for (const e3 of o2) {
const o3 = document.createElement("style"), n3 = t$5.litNonce;
void 0 !== n3 && o3.setAttribute("nonce", n3), o3.textContent = e3.cssText, s3.appendChild(o3);
}
}, c$6 = e$8 ? (t3) => t3 : (t3) => t3 instanceof CSSStyleSheet ? ((t4) => {
let e3 = "";
for (const s3 of t4.cssRules) e3 += s3.cssText;
return r$6(e3);
})(t3) : t3;
/**
* @license
* Copyright 2017 Google LLC
* SPDX-License-Identifier: BSD-3-Clause
*/
const { is: i$6, defineProperty: e$7, getOwnPropertyDescriptor: r$5, getOwnPropertyNames: h$5, getOwnPropertySymbols: o$9, getPrototypeOf: n$8 } = Object, a$1 = globalThis, c$5 = a$1.trustedTypes, l$3 = c$5 ? c$5.emptyScript : "", p$2 = a$1.reactiveElementPolyfillSupport, d$2 = (t3, s3) => t3, u$3 = { toAttribute(t3, s3) {
switch (s3) {
case Boolean:
t3 = t3 ? l$3 : null;
break;
case Object:
case Array:
t3 = null == t3 ? t3 : JSON.stringify(t3);
}
return t3;
}, fromAttribute(t3, s3) {
let i3 = t3;
switch (s3) {
case Boolean:
i3 = null !== t3;
break;
case Number:
i3 = null === t3 ? null : Number(t3);
break;
case Object:
case Array:
try {
i3 = JSON.parse(t3);
} catch (t4) {
i3 = null;
}
}
return i3;
} }, f$4 = (t3, s3) => !i$6(t3, s3), y$2 = { attribute: true, type: String, converter: u$3, reflect: false, hasChanged: f$4 };
Symbol.metadata ?? (Symbol.metadata = Symbol("metadata")), a$1.litPropertyMetadata ?? (a$1.litPropertyMetadata = /* @__PURE__ */ new WeakMap());
let b$1 = class b extends HTMLElement {
static addInitializer(t3) {
this._$Ei(), (this.l ?? (this.l = [])).push(t3);
}
static get observedAttributes() {
return this.finalize(), this._$Eh && [...this._$Eh.keys()];
}
static createProperty(t3, s3 = y$2) {
if (s3.state && (s3.attribute = false), this._$Ei(), this.elementProperties.set(t3, s3), !s3.noAccessor) {
const i3 = Symbol(), r3 = this.getPropertyDescriptor(t3, i3, s3);
void 0 !== r3 && e$7(this.prototype, t3, r3);
}
}
static getPropertyDescriptor(t3, s3, i3) {
const { get: e3, set: h3 } = r$5(this.prototype, t3) ?? { get() {
return this[s3];
}, set(t4) {
this[s3] = t4;
} };
return { get() {
return e3 == null ? void 0 : e3.call(this);
}, set(s4) {
const r3 = e3 == null ? void 0 : e3.call(this);
h3.call(this, s4), this.requestUpdate(t3, r3, i3);
}, configurable: true, enumerable: true };
}
static getPropertyOptions(t3) {
return this.elementProperties.get(t3) ?? y$2;
}
static _$Ei() {
if (this.hasOwnProperty(d$2("elementProperties"))) return;
const t3 = n$8(this);
t3.finalize(), void 0 !== t3.l && (this.l = [...t3.l]), this.elementProperties = new Map(t3.elementProperties);
}
static finalize() {
if (this.hasOwnProperty(d$2("finalized"))) return;
if (this.finalized = true, this._$Ei(), this.hasOwnProperty(d$2("properties"))) {
const t4 = this.properties, s3 = [...h$5(t4), ...o$9(t4)];
for (const i3 of s3) this.createProperty(i3, t4[i3]);
}
const t3 = this[Symbol.metadata];
if (null !== t3) {
const s3 = litPropertyMetadata.get(t3);
if (void 0 !== s3) for (const [t4, i3] of s3) this.elementProperties.set(t4, i3);
}
this._$Eh = /* @__PURE__ */ new Map();
for (const [t4, s3] of this.elementProperties) {
const i3 = this._$Eu(t4, s3);
void 0 !== i3 && this._$Eh.set(i3, t4);
}
this.elementStyles = this.finalizeStyles(this.styles);
}
static finalizeStyles(s3) {
const i3 = [];
if (Array.isArray(s3)) {
const e3 = new Set(s3.flat(1 / 0).reverse());
for (const s4 of e3) i3.unshift(c$6(s4));
} else void 0 !== s3 && i3.push(c$6(s3));
return i3;
}
static _$Eu(t3, s3) {
const i3 = s3.attribute;
return false === i3 ? void 0 : "string" == typeof i3 ? i3 : "string" == typeof t3 ? t3.toLowerCase() : void 0;
}
constructor() {
super(), this._$Ep = void 0, this.isUpdatePending = false, this.hasUpdated = false, this._$Em = null, this._$Ev();
}
_$Ev() {
var _a2;
this._$ES = new Promise((t3) => this.enableUpdating = t3), this._$AL = /* @__PURE__ */ new Map(), this._$E_(), this.requestUpdate(), (_a2 = this.constructor.l) == null ? void 0 : _a2.forEach((t3) => t3(this));
}
addController(t3) {
var _a2;
(this._$EO ?? (this._$EO = /* @__PURE__ */ new Set())).add(t3), void 0 !== this.renderRoot && this.isConnected && ((_a2 = t3.hostConnected) == null ? void 0 : _a2.call(t3));
}
removeController(t3) {
var _a2;
(_a2 = this._$EO) == null ? void 0 : _a2.delete(t3);
}
_$E_() {
const t3 = /* @__PURE__ */ new Map(), s3 = this.constructor.elementProperties;
for (const i3 of s3.keys()) this.hasOwnProperty(i3) && (t3.set(i3, this[i3]), delete this[i3]);
t3.size > 0 && (this._$Ep = t3);
}
createRenderRoot() {
const t3 = this.shadowRoot ?? this.attachShadow(this.constructor.shadowRootOptions);
return S$1(t3, this.constructor.elementStyles), t3;
}
connectedCallback() {
var _a2;
this.renderRoot ?? (this.renderRoot = this.createRenderRoot()), this.enableUpdating(true), (_a2 = this._$EO) == null ? void 0 : _a2.forEach((t3) => {
var _a3;
return (_a3 = t3.hostConnected) == null ? void 0 : _a3.call(t3);
});
}
enableUpdating(t3) {
}
disconnectedCallback() {
var _a2;
(_a2 = this._$EO) == null ? void 0 : _a2.forEach((t3) => {
var _a3;
return (_a3 = t3.hostDisconnected) == null ? void 0 : _a3.call(t3);
});
}
attributeChangedCallback(t3, s3, i3) {
this._$AK(t3, i3);
}
_$EC(t3, s3) {
var _a2;
const i3 = this.constructor.elementProperties.get(t3), e3 = this.constructor._$Eu(t3, i3);
if (void 0 !== e3 && true === i3.reflect) {
const r3 = (void 0 !== ((_a2 = i3.converter) == null ? void 0 : _a2.toAttribute) ? i3.converter : u$3).toAttribute(s3, i3.type);
this._$Em = t3, null == r3 ? this.removeAttribute(e3) : this.setAttribute(e3, r3), this._$Em = null;
}
}
_$AK(t3, s3) {
var _a2;
const i3 = this.constructor, e3 = i3._$Eh.get(t3);
if (void 0 !== e3 && this._$Em !== e3) {
const t4 = i3.getPropertyOptions(e3), r3 = "function" == typeof t4.converter ? { fromAttribute: t4.converter } : void 0 !== ((_a2 = t4.converter) == null ? void 0 : _a2.fromAttribute) ? t4.converter : u$3;
this._$Em = e3, this[e3] = r3.fromAttribute(s3, t4.type), this._$Em = null;
}
}
requestUpdate(t3, s3, i3) {
if (void 0 !== t3) {
if (i3 ?? (i3 = this.constructor.getPropertyOptions(t3)), !(i3.hasChanged ?? f$4)(this[t3], s3)) return;
this.P(t3, s3, i3);
}
false === this.isUpdatePending && (this._$ES = this._$ET());
}
P(t3, s3, i3) {
this._$AL.has(t3) || this._$AL.set(t3, s3), true === i3.reflect && this._$Em !== t3 && (this._$Ej ?? (this._$Ej = /* @__PURE__ */ new Set())).add(t3);
}
async _$ET() {
this.isUpdatePending = true;
try {
await this._$ES;
} catch (t4) {
Promise.reject(t4);
}
const t3 = this.scheduleUpdate();
return null != t3 && await t3, !this.isUpdatePending;
}
scheduleUpdate() {
return this.performUpdate();
}
performUpdate() {
var _a2;
if (!this.isUpdatePending) return;
if (!this.hasUpdated) {
if (this.renderRoot ?? (this.renderRoot = this.createRenderRoot()), this._$Ep) {
for (const [t5, s4] of this._$Ep) this[t5] = s4;
this._$Ep = void 0;
}
const t4 = this.constructor.elementProperties;
if (t4.size > 0) for (const [s4, i3] of t4) true !== i3.wrapped || this._$AL.has(s4) || void 0 === this[s4] || this.P(s4, this[s4], i3);
}
let t3 = false;
const s3 = this._$AL;
try {
t3 = this.shouldUpdate(s3), t3 ? (this.willUpdate(s3), (_a2 = this._$EO) == null ? void 0 : _a2.forEach((t4) => {
var _a3;
return (_a3 = t4.hostUpdate) == null ? void 0 : _a3.call(t4);
}), this.update(s3)) : this._$EU();
} catch (s4) {
throw t3 = false, this._$EU(), s4;
}
t3 && this._$AE(s3);
}
willUpdate(t3) {
}
_$AE(t3) {
var _a2;
(_a2 = this._$EO) == null ? void 0 : _a2.forEach((t4) => {
var _a3;
return (_a3 = t4.hostUpdated) == null ? void 0 : _a3.call(t4);
}), this.hasUpdated || (this.hasUpdated = true, this.firstUpdated(t3)), this.updated(t3);
}
_$EU() {
this._$AL = /* @__PURE__ */ new Map(), this.isUpdatePending = false;
}
get updateComplete() {
return this.getUpdateComplete();
}
getUpdateComplete() {
return this._$ES;
}
shouldUpdate(t3) {
return true;
}
update(t3) {
this._$Ej && (this._$Ej = this._$Ej.forEach((t4) => this._$EC(t4, this[t4]))), this._$EU();
}
updated(t3) {
}
firstUpdated(t3) {
}
};
b$1.elementStyles = [], b$1.shadowRootOptions = { mode: "open" }, b$1[d$2("elementProperties")] = /* @__PURE__ */ new Map(), b$1[d$2("finalized")] = /* @__PURE__ */ new Map(), p$2 == null ? void 0 : p$2({ ReactiveElement: b$1 }), (a$1.reactiveElementVersions ?? (a$1.reactiveElementVersions = [])).push("2.0.4");
/**
* @license
* Copyright 2017 Google LLC
* SPDX-License-Identifier: BSD-3-Clause
*/
const t$4 = globalThis, i$5 = t$4.trustedTypes, s$3 = i$5 ? i$5.createPolicy("lit-html", { createHTML: (t3) => t3 }) : void 0, e$6 = "$lit$", h$4 = `lit$${Math.random().toFixed(9).slice(2)}$`, o$8 = "?" + h$4, n$7 = `<${o$8}>`, r$4 = document, l$2 = () => r$4.createComment(""), c$4 = (t3) => null === t3 || "object" != typeof t3 && "function" != typeof t3, a = Array.isArray, u$2 = (t3) => a(t3) || "function" == typeof (t3 == null ? void 0 : t3[Symbol.iterator]), d$1 = "[ \n\f\r]", f$3 = /<(?:(!--|\/[^a-zA-Z])|(\/?[a-zA-Z][^>\s]*)|(\/?$))/g, v$1 = /-->/g, _ = />/g, m$3 = RegExp(`>|${d$1}(?:([^\\s"'>=/]+)(${d$1}*=${d$1}*(?:[^
\f\r"'\`<>=]|("|')|))|$)`, "g"), p$1 = /'/g, g = /"/g, $ = /^(?:script|style|textarea|title)$/i, y$1 = (t3) => (i3, ...s3) => ({ _$litType$: t3, strings: i3, values: s3 }), x = y$1(1), T = Symbol.for("lit-noChange"), E = Symbol.for("lit-nothing"), A = /* @__PURE__ */ new WeakMap(), C = r$4.createTreeWalker(r$4, 129);
function P$1(t3, i3) {
if (!a(t3) || !t3.hasOwnProperty("raw")) throw Error("invalid template strings array");
return void 0 !== s$3 ? s$3.createHTML(i3) : i3;
}
const V = (t3, i3) => {
const s3 = t3.length - 1, o2 = [];
let r3, l2 = 2 === i3 ? "<svg>" : 3 === i3 ? "<math>" : "", c3 = f$3;
for (let i4 = 0; i4 < s3; i4++) {
const s4 = t3[i4];
let a2, u2, d2 = -1, y2 = 0;
for (; y2 < s4.length && (c3.lastIndex = y2, u2 = c3.exec(s4), null !== u2); ) y2 = c3.lastIndex, c3 === f$3 ? "!--" === u2[1] ? c3 = v$1 : void 0 !== u2[1] ? c3 = _ : void 0 !== u2[2] ? ($.test(u2[2]) && (r3 = RegExp("</" + u2[2], "g")), c3 = m$3) : void 0 !== u2[3] && (c3 = m$3) : c3 === m$3 ? ">" === u2[0] ? (c3 = r3 ?? f$3, d2 = -1) : void 0 === u2[1] ? d2 = -2 : (d2 = c3.lastIndex - u2[2].length, a2 = u2[1], c3 = void 0 === u2[3] ? m$3 : '"' === u2[3] ? g : p$1) : c3 === g || c3 === p$1 ? c3 = m$3 : c3 === v$1 || c3 === _ ? c3 = f$3 : (c3 = m$3, r3 = void 0);
const x2 = c3 === m$3 && t3[i4 + 1].startsWith("/>") ? " " : "";
l2 += c3 === f$3 ? s4 + n$7 : d2 >= 0 ? (o2.push(a2), s4.slice(0, d2) + e$6 + s4.slice(d2) + h$4 + x2) : s4 + h$4 + (-2 === d2 ? i4 : x2);
}
return [P$1(t3, l2 + (t3[s3] || "<?>") + (2 === i3 ? "</svg>" : 3 === i3 ? "</math>" : "")), o2];
};
class N {
constructor({ strings: t3, _$litType$: s3 }, n3) {
let r3;
this.parts = [];
let c3 = 0, a2 = 0;
const u2 = t3.length - 1, d2 = this.parts, [f3, v2] = V(t3, s3);
if (this.el = N.createElement(f3, n3), C.currentNode = this.el.content, 2 === s3 || 3 === s3) {
const t4 = this.el.content.firstChild;
t4.replaceWith(...t4.childNodes);
}
for (; null !== (r3 = C.nextNode()) && d2.length < u2; ) {
if (1 === r3.nodeType) {
if (r3.hasAttributes()) for (const t4 of r3.getAttributeNames()) if (t4.endsWith(e$6)) {
const i3 = v2[a2++], s4 = r3.getAttribute(t4).split(h$4), e3 = /([.?@])?(.*)/.exec(i3);
d2.push({ type: 1, index: c3, name: e3[2], strings: s4, ctor: "." === e3[1] ? H : "?" === e3[1] ? I : "@" === e3[1] ? L : k$1 }), r3.removeAttribute(t4);
} else t4.startsWith(h$4) && (d2.push({ type: 6, index: c3 }), r3.removeAttribute(t4));
if ($.test(r3.tagName)) {
const t4 = r3.textContent.split(h$4), s4 = t4.length - 1;
if (s4 > 0) {
r3.textContent = i$5 ? i$5.emptyScript : "";
for (let i3 = 0; i3 < s4; i3++) r3.append(t4[i3], l$2()), C.nextNode(), d2.push({ type: 2, index: ++c3 });
r3.append(t4[s4], l$2());
}
}
} else if (8 === r3.nodeType) if (r3.data === o$8) d2.push({ type: 2, index: c3 });
else {
let t4 = -1;
for (; -1 !== (t4 = r3.data.indexOf(h$4, t4 + 1)); ) d2.push({ type: 7, index: c3 }), t4 += h$4.length - 1;
}
c3++;
}
}
static createElement(t3, i3) {
const s3 = r$4.createElement("template");
return s3.innerHTML = t3, s3;
}
}
function S(t3, i3, s3 = t3, e3) {
var _a2, _b;
if (i3 === T) return i3;
let h3 = void 0 !== e3 ? (_a2 = s3._$Co) == null ? void 0 : _a2[e3] : s3._$Cl;
const o2 = c$4(i3) ? void 0 : i3._$litDirective$;
return (h3 == null ? void 0 : h3.constructor) !== o2 && ((_b = h3 == null ? void 0 : h3._$AO) == null ? void 0 : _b.call(h3, false), void 0 === o2 ? h3 = void 0 : (h3 = new o2(t3), h3._$AT(t3, s3, e3)), void 0 !== e3 ? (s3._$Co ?? (s3._$Co = []))[e3] = h3 : s3._$Cl = h3), void 0 !== h3 && (i3 = S(t3, h3._$AS(t3, i3.values), h3, e3)), i3;
}
class M {
constructor(t3, i3) {
this._$AV = [], this._$AN = void 0, this._$AD = t3, this._$AM = i3;
}
get parentNode() {
return this._$AM.parentNode;
}
get _$AU() {
return this._$AM._$AU;
}
u(t3) {
const { el: { content: i3 }, parts: s3 } = this._$AD, e3 = ((t3 == null ? void 0 : t3.creationScope) ?? r$4).importNode(i3, true);
C.currentNode = e3;
let h3 = C.nextNode(), o2 = 0, n3 = 0, l2 = s3[0];
for (; void 0 !== l2; ) {
if (o2 === l2.index) {
let i4;
2 === l2.type ? i4 = new R(h3, h3.nextSibling, this, t3) : 1 === l2.type ? i4 = new l2.ctor(h3, l2.name, l2.strings, this, t3) : 6 === l2.type && (i4 = new z(h3, this, t3)), this._$AV.push(i4), l2 = s3[++n3];
}
o2 !== (l2 == null ? void 0 : l2.index) && (h3 = C.nextNode(), o2++);
}
return C.currentNode = r$4, e3;
}
p(t3) {
let i3 = 0;
for (const s3 of this._$AV) void 0 !== s3 && (void 0 !== s3.strings ? (s3._$AI(t3, s3, i3), i3 += s3.strings.length - 2) : s3._$AI(t3[i3])), i3++;
}
}
class R {
get _$AU() {
var _a2;
return ((_a2 = this._$AM) == null ? void 0 : _a2._$AU) ?? this._$Cv;
}
constructor(t3, i3, s3, e3) {
this.type = 2, this._$AH = E, this._$AN = void 0, this._$AA = t3, this._$AB = i3, this._$AM = s3, this.options = e3, this._$Cv = (e3 == null ? void 0 : e3.isConnected) ?? true;
}
get parentNode() {
let t3 = this._$AA.parentNode;
const i3 = this._$AM;
return void 0 !== i3 && 11 === (t3 == null ? void 0 : t3.nodeType) && (t3 = i3.parentNode), t3;
}
get startNode() {
return this._$AA;
}
get endNode() {
return this._$AB;
}
_$AI(t3, i3 = this) {
t3 = S(this, t3, i3), c$4(t3) ? t3 === E || null == t3 || "" === t3 ? (this._$AH !== E && this._$AR(), this._$AH = E) : t3 !== this._$AH && t3 !== T && this._(t3) : void 0 !== t3._$litType$ ? this.$(t3) : void 0 !== t3.nodeType ? this.T(t3) : u$2(t3) ? this.k(t3) : this._(t3);
}
O(t3) {
return this._$AA.parentNode.insertBefore(t3, this._$AB);
}
T(t3) {
this._$AH !== t3 && (this._$AR(), this._$AH = this.O(t3));
}
_(t3) {
this._$AH !== E && c$4(this._$AH) ? this._$AA.nextSibling.data = t3 : this.T(r$4.createTextNode(t3)), this._$AH = t3;
}
$(t3) {
var _a2;
const { values: i3, _$litType$: s3 } = t3, e3 = "number" == typeof s3 ? this._$AC(t3) : (void 0 === s3.el && (s3.el = N.createElement(P$1(s3.h, s3.h[0]), this.options)), s3);
if (((_a2 = this._$AH) == null ? void 0 : _a2._$AD) === e3) this._$AH.p(i3);
else {
const t4 = new M(e3, this), s4 = t4.u(this.options);
t4.p(i3), this.T(s4), this._$AH = t4;
}
}
_$AC(t3) {
let i3 = A.get(t3.strings);
return void 0 === i3 && A.set(t3.strings, i3 = new N(t3)), i3;
}
k(t3) {
a(this._$AH) || (this._$AH = [], this._$AR());
const i3 = this._$AH;
let s3, e3 = 0;
for (const h3 of t3) e3 === i3.length ? i3.push(s3 = new R(this.O(l$2()), this.O(l$2()), this, this.options)) : s3 = i3[e3], s3._$AI(h3), e3++;
e3 < i3.length && (this._$AR(s3 && s3._$AB.nextSibling, e3), i3.length = e3);
}
_$AR(t3 = this._$AA.nextSibling, i3) {
var _a2;
for ((_a2 = this._$AP) == null ? void 0 : _a2.call(this, false, true, i3); t3 && t3 !== this._$AB; ) {
const i4 = t3.nextSibling;
t3.remove(), t3 = i4;
}
}
setConnected(t3) {
var _a2;
void 0 === this._$AM && (this._$Cv = t3, (_a2 = this._$AP) == null ? void 0 : _a2.call(this, t3));
}
}
let k$1 = class k {
get tagName() {
return this.element.tagName;
}
get _$AU() {
return this._$AM._$AU;
}
constructor(t3, i3, s3, e3, h3) {
this.type = 1, this._$AH = E, this._$AN = void 0, this.element = t3, this.name = i3, this._$AM = e3, this.options = h3, s3.length > 2 || "" !== s3[0] || "" !== s3[1] ? (this._$AH = Array(s3.length - 1).fill(new String()), this.strings = s3) : this._$AH = E;
}
_$AI(t3, i3 = this, s3, e3) {
const h3 = this.strings;
let o2 = false;
if (void 0 === h3) t3 = S(this, t3, i3, 0), o2 = !c$4(t3) || t3 !== this._$AH && t3 !== T, o2 && (this._$AH = t3);
else {
const e4 = t3;
let n3, r3;
for (t3 = h3[0], n3 = 0; n3 < h3.length - 1; n3++) r3 = S(this, e4[s3 + n3], i3, n3), r3 === T && (r3 = this._$AH[n3]), o2 || (o2 = !c$4(r3) || r3 !== this._$AH[n3]), r3 === E ? t3 = E : t3 !== E && (t3 += (r3 ?? "") + h3[n3 + 1]), this._$AH[n3] = r3;
}
o2 && !e3 && this.j(t3);
}
j(t3) {
t3 === E ? this.element.removeAttribute(this.name) : this.element.setAttribute(this.name, t3 ?? "");
}
};
class H extends k$1 {
constructor() {
super(...arguments), this.type = 3;
}
j(t3) {
this.element[this.name] = t3 === E ? void 0 : t3;
}
}
class I extends k$1 {
constructor() {
super(...arguments), this.type = 4;
}
j(t3) {
this.element.toggleAttribute(this.name, !!t3 && t3 !== E);
}
}
class L extends k$1 {
constructor(t3, i3, s3, e3, h3) {
super(t3, i3, s3, e3, h3), this.type = 5;
}
_$AI(t3, i3 = this) {
if ((t3 = S(this, t3, i3, 0) ?? E) === T) return;
const s3 = this._$AH, e3 = t3 === E && s3 !== E || t3.capture !== s3.capture || t3.once !== s3.once || t3.passive !== s3.passive, h3 = t3 !== E && (s3 === E || e3);
e3 && this.element.removeEventListener(this.name, this, s3), h3 && this.element.addEventListener(this.name, this, t3), this._$AH = t3;
}
handleEvent(t3) {
var _a2;
"function" == typeof this._$AH ? this._$AH.call(((_a2 = this.options) == null ? void 0 : _a2.host) ?? this.element, t3) : this._$AH.handleEvent(t3);
}
}
class z {
constructor(t3, i3, s3) {
this.element = t3, this.type = 6, this._$AN = void 0, this._$AM = i3, this.options = s3;
}
get _$AU() {
return this._$AM._$AU;
}
_$AI(t3) {
S(this, t3);
}
}
const j = t$4.litHtmlPolyfillSupport;
j == null ? void 0 : j(N, R), (t$4.litHtmlVersions ?? (t$4.litHtmlVersions = [])).push("3.2.1");
const B = (t3, i3, s3) => {
const e3 = (s3 == null ? void 0 : s3.renderBefore) ?? i3;
let h3 = e3._$litPart$;
if (void 0 === h3) {
const t4 = (s3 == null ? void 0 : s3.renderBefore) ?? null;
e3._$litPart$ = h3 = new R(i3.insertBefore(l$2(), t4), t4, void 0, s3 ?? {});
}
return h3._$AI(t3), h3;
};
/**
* @license
* Copyright 2017 Google LLC
* SPDX-License-Identifier: BSD-3-Clause
*/
let r$3 = class r extends b$1 {
constructor() {
super(...arguments), this.renderOptions = { host: this }, this._$Do = void 0;
}
createRenderRoot() {
var _a2;
const t3 = super.createRenderRoot();
return (_a2 = this.renderOptions).renderBefore ?? (_a2.renderBefore = t3.firstChild), t3;
}
update(t3) {
const s3 = this.render();
this.hasUpdated || (this.renderOptions.isConnected = this.isConnected), super.update(t3), this._$Do = B(s3, this.renderRoot, this.renderOptions);
}
connectedCallback() {
var _a2;
super.connectedCallback(), (_a2 = this._$Do) == null ? void 0 : _a2.setConnected(true);
}
disconnectedCallback() {
var _a2;
super.disconnectedCallback(), (_a2 = this._$Do) == null ? void 0 : _a2.setConnected(false);
}
render() {
return T;
}
};
r$3._$litElement$ = true, r$3["finalized"] = true, (_a = globalThis.litElementHydrateSupport) == null ? void 0 : _a.call(globalThis, { LitElement: r$3 });
const i$4 = globalThis.litElementPolyfillSupport;
i$4 == null ? void 0 : i$4({ LitElement: r$3 });
(globalThis.litElementVersions ?? (globalThis.litElementVersions = [])).push("4.1.1");
/**
* @license
* Copyright 2017 Google LLC
* SPDX-License-Identifier: BSD-3-Clause
*/
const t$3 = (t3) => (e3, o2) => {
void 0 !== o2 ? o2.addInitializer(() => {
customElements.define(t3, e3);
}) : customElements.define(t3, e3);
};
/**
* @license
* Copyright 2017 Google LLC
* SPDX-License-Identifier: BSD-3-Clause
*/
const o$7 = { attribute: true, type: String, converter: u$3, reflect: false, hasChanged: f$4 }, r$2 = (t3 = o$7, e3, r3) => {
const { kind: n3, metadata: i3 } = r3;
let s3 = globalThis.litPropertyMetadata.get(i3);
if (void 0 === s3 && globalThis.litPropertyMetadata.set(i3, s3 = /* @__PURE__ */ new Map()), s3.set(r3.name, t3), "accessor" === n3) {
const { name: o2 } = r3;
return { set(r4) {
const n4 = e3.get.call(this);
e3.set.call(this, r4), this.requestUpdate(o2, n4, t3);
}, init(e4) {
return void 0 !== e4 && this.P(o2, void 0, t3), e4;
} };
}
if ("setter" === n3) {
const { name: o2 } = r3;
return function(r4) {
const n4 = this[o2];
e3.call(this, r4), this.requestUpdate(o2, n4, t3);
};
}
throw Error("Unsupported decorator location: " + n3);
};
function n$6(t3) {
return (e3, o2) => "object" == typeof o2 ? r$2(t3, e3, o2) : ((t4, e4, o3) => {
const r3 = e4.hasOwnProperty(o3);
return e4.constructor.createProperty(o3, r3 ? { ...t4, wrapped: true } : t4), r3 ? Object.getOwnPropertyDescriptor(e4, o3) : void 0;
})(t3, e3, o2);
}
/**
* @license
* Copyright 2017 Google LLC
* SPDX-License-Identifier: BSD-3-Clause
*/
function r$1(r3) {
return n$6({ ...r3, state: true, attribute: false });
}
/**
* @license
* Copyright 2017 Google LLC
* SPDX-License-Identifier: BSD-3-Clause
*/
const e$5 = (e3, t3, c3) => (c3.configurable = true, c3.enumerable = true, Reflect.decorate && "object" != typeof t3 && Object.defineProperty(e3, t3, c3), c3);
/**
* @license
* Copyright 2021 Google LLC
* SPDX-License-Identifier: BSD-3-Clause
*/
function o$6(o2) {
return (e3, n3) => {
const { slot: r3, selector: s3 } = o2 ?? {}, c3 = "slot" + (r3 ? `[name=${r3}]` : ":not([name])");
return e$5(e3, n3, { get() {
var _a2;
const t3 = (_a2 = this.renderRoot) == null ? void 0 : _a2.querySelector(c3), e4 = (t3 == null ? void 0 : t3.assignedElements(o2)) ?? [];
return void 0 === s3 ? e4 : e4.filter((t4) => t4.matches(s3));
} });
};
}
/**
* @license
* Copyright 2018 Google LLC
* SPDX-License-Identifier: BSD-3-Clause
*/
const o$5 = (o2) => o2 ?? E;
/**
* @license
* Copyright 2017 Google LLC
* SPDX-License-Identifier: BSD-3-Clause
*/
const t$2 = { ATTRIBUTE: 1, CHILD: 2, PROPERTY: 3, BOOLEAN_ATTRIBUTE: 4 }, e$4 = (t3) => (...e3) => ({ _$litDirective$: t3, values: e3 });
let i$3 = class i {
constructor(t3) {
}
get _$AU() {
return this._$AM._$AU;
}
_$AT(t3, e3, i3) {
this._$Ct = t3, this._$AM = e3, this._$Ci = i3;
}
_$AS(t3, e3) {
return this.update(t3, e3);
}
update(t3, e3) {
return this.render(...e3);
}
};
/**
* @license
* Copyright 2018 Google LLC
* SPDX-License-Identifier: BSD-3-Clause
*/
const n$5 = "important", i$2 = " !" + n$5, o$4 = e$4(class extends i$3 {
constructor(t3) {
var _a2;
if (super(t3), t3.type !== t$2.ATTRIBUTE || "style" !== t3.name || ((_a2 = t3.strings) == null ? void 0 : _a2.length) > 2) throw Error("The `styleMap` directive must be used in the `style` attribute and must be the only part in the attribute.");
}
render(t3) {
return Object.keys(t3).reduce((e3, r3) => {
const s3 = t3[r3];
return null == s3 ? e3 : e3 + `${r3 = r3.includes("-") ? r3 : r3.replace(/(?:^(webkit|moz|ms|o)|)(?=[A-Z])/g, "-$&").toLowerCase()}:${s3};`;
}, "");
}
update(e3, [r3]) {
const { style: s3 } = e3.element;
if (void 0 === this.ft) return this.ft = new Set(Object.keys(r3)), this.render(r3);
for (const t3 of this.ft) null == r3[t3] && (this.ft.delete(t3), t3.includes("-") ? s3.removeProperty(t3) : s3[t3] = null);
for (const t3 in r3) {
const e4 = r3[t3];
if (null != e4) {
this.ft.add(t3);
const r4 = "string" == typeof e4 && e4.endsWith(i$2);
t3.includes("-") || r4 ? s3.setProperty(t3, r4 ? e4.slice(0, -11) : e4, r4 ? n$5 : "") : s3[t3] = e4;
}
}
return T;
}
});
class MduiElement extends r$3 {
/**
* 触发自定义事件。若返回 false,表示事件被取消
* @param type
* @param options 通常只用到 cancelable 和 detail;bubbles、composed 统一不用
*/
emit(type, options) {
const event = new CustomEvent(type, Object.assign({
bubbles: true,
cancelable: false,
composed: true,
detail: {}
}, options));
return this.dispatchEvent(event);
}
}
class HasSlotController {
constructor(host, ...slotNames) {
this.slotNames = [];
(this.host = host).addController(this);
this.slotNames = slotNames;
this.onSlotChange = this.onSlotChange.bind(this);
}
hostConnected() {
this.host.shadowRoot.addEventListener("slotchange", this.onSlotChange);
if (!isDomReady()) {
$$1(() => {
this.host.requestUpdate();
});
}
}
hostDisconnected() {
this.host.shadowRoot.removeEventListener("slotchange", this.onSlotChange);
}
test(slotName) {
return slotName === "[default]" ? this.hasDefaultSlot() : this.hasNamedSlot(slotName);
}
hasDefaultSlot() {
return [...this.host.childNodes].some((node) => {
if (node.nodeType === node.TEXT_NODE && node.textContent.trim() !== "") {
return true;
}
if (node.nodeType === node.ELEMENT_NODE) {
const el = node;
if (!el.hasAttribute("slot")) {
return true;
}
}
return false;
});
}
hasNamedSlot(name) {
return this.host.querySelector(`:scope > [slot="${name}"]`) !== null;
}
onSlotChange(event) {
const slot = event.target;
if (this.slotNames.includes("[default]") && !slot.name || slot.name && this.slotNames.includes(slot.name)) {
this.host.requestUpdate();
}
}
}
const nothingTemplate = x`${E}`;
const componentStyle = i$7`:host{box-sizing:border-box}:host *,:host ::after,:host ::before{box-sizing:inherit}:host :focus,:host :focus-visible,:host(:focus),:host(:focus-visible){outline:0}[hidden]{display:none!important}`;
/**
* @license
* Copyright 2017 Google LLC
* SPDX-License-Identifier: BSD-3-Clause
*/
let e$3 = class e extends i$3 {
constructor(i3) {
if (super(i3), this.it = E, i3.type !== t$2.CHILD) throw Error(this.constructor.directiveName + "() can only be used in child bindings");
}
render(r3) {
if (r3 === E || null == r3) return this._t = void 0, this.it = r3;
if (r3 === T) return r3;
if ("string" != typeof r3) throw Error(this.constructor.directiveName + "() called with a non-string value");
if (r3 === this.it) return this._t;
this.it = r3;
const s3 = [r3];
return s3.raw = s3, this._t = { _$litType$: this.constructor.resultType, strings: s3, values: [] };
}
};
e$3.directiveName = "unsafeHTML", e$3.resultType = 1;
/**
* @license
* Copyright 2017 Google LLC
* SPDX-License-Identifier: BSD-3-Clause
*/
let t$1 = class t extends e$3 {
};
t$1.directiveName = "unsafeSVG", t$1.resultType = 2;
const o$3 = e$4(t$1);
/**
* @license
* Copyright 2020 Google LLC
* SPDX-License-Identifier: BSD-3-Clause
*/
const i$1 = (o2) => null === o2 || "object" != typeof o2 && "function" != typeof o2, f$2 = (o2) => void 0 === o2.strings, u$1 = {}, m$2 = (o2, t3 = u$1) => o2._$AH = t3;
/**
* @license
* Copyright 2017 Google LLC
* SPDX-License-Identifier: BSD-3-Clause
*/
const s$2 = (i3, t3) => {
var _a2;
const e3 = i3._$AN;
if (void 0 === e3) return false;
for (const i4 of e3) (_a2 = i4._$AO) == null ? void 0 : _a2.call(i4, t3, false), s$2(i4, t3);
return true;
}, o$2 = (i3) => {
let t3, e3;
do {
if (void 0 === (t3 = i3._$AM)) break;
e3 = t3._$AN, e3.delete(i3), i3 = t3;
} while (0 === (e3 == null ? void 0 : e3.size));
}, r2 = (i3) => {
for (let t3; t3 = i3._$AM; i3 = t3) {
let e3 = t3._$AN;
if (void 0 === e3) t3._$AN = e3 = /* @__PURE__ */ new Set();
else if (e3.has(i3)) break;
e3.add(i3), c$3(t3);
}
};
function h$3(i3) {
void 0 !== this._$AN ? (o$2(this), this._$AM = i3, r2(this)) : this._$AM = i3;
}
function n$4(i3, t3 = false, e3 = 0) {
const r3 = this._$AH, h3 = this._$AN;
if (void 0 !== h3 && 0 !== h3.size) if (t3) if (Array.isArray(r3)) for (let i4 = e3; i4 < r3.length; i4++) s$2(r3[i4], false), o$2(r3[i4]);
else null != r3 && (s$2(r3, false), o$2(r3));
else s$2(this, i3);
}
const c$3 = (i3) => {
i3.type == t$2.CHILD && (i3._$AP ?? (i3._$AP = n$4), i3._$AQ ?? (i3._$AQ = h$3));
};
let f$1 = class f extends i$3 {
constructor() {
super(...arguments), this._$AN = void 0;
}
_$AT(i3, t3, e3) {
super._$AT(i3, t3, e3), r2(this), this.isConnected = i3._$AU;
}
_$AO(i3, t3 = true) {
var _a2, _b;
i3 !== this.isConnected && (this.isConnected = i3, i3 ? (_a2 = this.reconnected) == null ? void 0 : _a2.call(this) : (_b = this.disconnected) == null ? void 0 : _b.call(this)), t3 && (s$2(this, i3), o$2(this));
}
setValue(t3) {
if (f$2(this._$Ct)) this._$Ct._$AI(t3, this);
else {
const i3 = [...this._$Ct._$AH];
i3[this._$Ci] = t3, this._$Ct._$AI(i3, this, 0);
}
}
disconnected() {
}
reconnected() {
}
};
/**
* @license
* Copyright 2021 Google LLC
* SPDX-License-Identifier: BSD-3-Clause
*/
let s$1 = class s {
constructor(t3) {
this.Y = t3;
}
disconnect() {
this.Y = void 0;
}
reconnect(t3) {
this.Y = t3;
}
deref() {
return this.Y;
}
};
class i2 {
constructor() {
this.Z = void 0, this.q = void 0;
}
get() {
return this.Z;
}
pause() {
this.Z ?? (this.Z = new Promise((t3) => this.q = t3));
}
resume() {
var _a2;
(_a2 = this.q) == null ? void 0 : _a2.call(this), this.Z = this.q = void 0;
}
}
/**
* @license
* Copyright 2017 Google LLC
* SPDX-License-Identifier: BSD-3-Clause
*/
const n$3 = (t3) => !i$1(t3) && "function" == typeof t3.then, h$2 = 1073741823;
let c$2 = class c extends f$1 {
constructor() {
super(...arguments), this._$Cwt = h$2, this._$Cbt = [], this._$CK = new s$1(this), this._$CX = new i2();
}
render(...s3) {
return s3.find((t3) => !n$3(t3)) ?? T;
}
update(s3, i3) {
const e3 = this._$Cbt;
let r3 = e3.length;
this._$Cbt = i3;
const o2 = this._$CK, c3 = this._$CX;
this.isConnected || this.disconnected();
for (let t3 = 0; t3 < i3.length && !(t3 > this._$Cwt); t3++) {
const s4 = i3[t3];
if (!n$3(s4)) return this._$Cwt = t3, s4;
t3 < r3 && s4 === e3[t3] || (this._$Cwt = h$2, r3 = 0, Promise.resolve(s4).then(async (t4) => {
for (; c3.get(); ) await c3.get();
const i4 = o2.deref();
if (void 0 !== i4) {
const e4 = i4._$Cbt.indexOf(s4);
e4 > -1 && e4 < i4._$Cwt && (i4._$Cwt = e4, i4.setValue(t4));
}
}));
}
return T;
}
disconnected() {
this._$CK.disconnect(), this._$CX.pause();
}
reconnected() {
this._$CK.reconnect(this), this._$CX.resume();
}
};
const m$1 = e$4(c$2);
const style$n = i$7`:host{display:inline-block;width:1em;height:1em;font-weight:400;font-family:'Material Icons';font-display:block;font-style:normal;line-height:1;direction:ltr;letter-spacing:normal;white-space:nowrap;text-transform:none;word-wrap:normal;-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;-moz-osx-font-smoothing:grayscale;font-size:1.5rem}::slotted(svg),svg{width:100%;height:100%;fill:currentcolor}`;
let Icon = class Icon2 extends MduiElement {
constructor() {
super(...arguments);
this.hasSlotController = new HasSlotController(this, "[default]");
}
render() {
const renderDefault = () => {
if (this.name) {
const [name, variant] = this.name.split("--");
const familyMap = /* @__PURE__ */ new Map([
["outlined", "Material Icons Outlined"],
["filled", "Material Icons"],
["rounded", "Material Icons Round"],
["sharp", "Material Icons Sharp"],
["two-tone", "Material Icons Two Tone"]
]);
return x`<span style="${o$4({ fontFamily: familyMap.get(variant) })}">${name}</span>`;
}
if (this.src) {
return x`${m$1(ajax({ url: this.src }).then(o$3))}`;
}
return x``;
};
return this.hasSlotController.test("[default]") ? x`<slot></slot>` : renderDefault();
}
};
Icon.styles = [componentStyle, style$n];
__decorate([
n$6({ reflect: true })
], Icon.prototype, "name", void 0);
__decorate([
n$6({ reflect: true })
], Icon.prototype, "src", void 0);
Icon = __decorate([
t$3("mdui-icon")
], Icon);
const style$m = i$7`:host{--shape-corner:var(--mdui-shape-corner-full);position:relative;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;white-space:nowrap;vertical-align:middle;border-radius:var(--shape-corner);-webkit-user-select:none;user-select:none;width:2.5rem;height:2.5rem;background-color:rgb(var(--mdui-color-primary-container));color:rgb(var(--mdui-color-on-primary-container));font-size:var(--mdui-typescale-title-medium-size);font-weight:var(--mdui-typescale-title-medium-weight);letter-spacing:var(--mdui-typescale-title-medium-tracking);line-height:var(--mdui-typescale-title-medium-line-height)}img{width:100%;height:100%}::slotted(mdui-icon),mdui-icon{font-size:1.5em}`;
let Avatar = class Avatar2 extends MduiElement {
constructor() {
super(...arguments);
this.hasSlotController = new HasSlotController(this, "[default]");
}
render() {
return this.hasSlotController.test("[default]") ? x`<slot></slot>` : this.src ? x`<img part="image" alt="${o$5(this.label)}" src="${this.src}" style="${o$4({ objectFit: this.fit })}">` : this.icon ? x`<mdui-icon part="icon" name="${this.icon}"></mdui-icon>` : nothingTemplate;
}
};
Avatar.styles = [componentStyle, style$m];
__decorate([
n$6({ reflect: true })
], Avatar.prototype, "src", void 0);
__decorate([
n$6({ reflect: true })
], Avatar.prototype, "fit", void 0);
__decorate([
n$6({ reflect: true })
], Avatar.prototype, "icon", void 0);
__decorate([
n$6({ reflect: true })
], Avatar.prototype, "label", void 0);
Avatar = __decorate([
t$3("mdui-avatar")
], Avatar);
const style$l = i$7`:host{--shape-corner:var(--mdui-shape-corner-full);display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:var(--shape-corner);padding-left:.25rem;padding-right:.25rem;color:rgb(var(--mdui-color-on-error));background-color:rgb(var(--mdui-color-error));height:1rem;min-width:1rem;font-size:var(--mdui-typescale-label-small-size);font-weight:var(--mdui-typescale-label-small-weight);letter-spacing:var(--mdui-typescale-label-small-tracking);line-height:var(--mdui-typescale-label-small-line-height)}:host([variant=small]){min-width:0;padding:0;width:.375rem;height:.375rem}`;
let Badge = class Badge2 extends MduiElement {
constructor() {
super(...arguments);
this.variant = "large";
}
render() {
if (this.variant === "small") {
return nothingTemplate;
}
return x`<slot></slot>`;
}
};
Badge.styles = [componentStyle, style$l];
__decorate([
n$6({ reflect: true })
], Badge.prototype, "variant", void 0);
Badge = __decorate([
t$3("mdui-badge")
], Badge);
const booleanConverter = (value) => {
return value !== null && value.toLowerCase() !== "false";
};
class DefinedController {
constructor(host, options) {
this.defined = false;
(this.host = host).addController(this);
this.relatedElements = options.relatedElements;
this.needDomReady = options.needDomReady || !!options.relatedElements;
this.onSlotChange = this.onSlotChange.bind(this);
}
hostConnected() {
this.host.shadowRoot.addEventListener("slotchange", this.onSlotChange);
}
hostDisconnected() {
this.host.shadowRoot.removeEventListener("slotchange", this.onSlotChange);
}
/**
* 判断组件是否定义完成
*/
isDefined() {
if (this.defined) {
return true;
}
this.defined = (!this.needDomReady || isDomReady()) && !this.getUndefinedLocalNames().length;
return this.defined;
}
/**
* 在组件定义完成后,promise 被 resolve
*/
async whenDefined() {
if (this.defined) {
return Promise.resolve();
}
const document2 = getDocument();
if (this.needDomReady && !isDomReady(document2)) {
await new Promise((resolve) => {
document2.addEventListener("DOMContentLoaded", () => resolve(), {
once: true
});
});
}
const undefinedLocalNames = this.getUndefinedLocalNames();
if (undefinedLocalNames.length) {
const promises = [];
undefinedLocalNames.forEach((localName) => {
promises.push(customElements.whenDefined(localName));
});
await Promise.all(promises);
}
this.defined = true;
return;
}
/**
* slot 中的未完成定义的相关 Web components 组件的 CSS 选择器
*/
getScopeLocalNameSelector() {
const localNames = this.relatedElements;
if (!localNames) {
return null;
}
if (Array.isArray(localNames)) {
return localNames.map((localName) => `${localName}:not(:defined)`).join(",");
}
return Object.keys(localNames).filter((localName) => !localNames[localName]).map((localName) => `${localName}:not(:defined)`).join(",");
}
/**
* 整个页面中的未完成定义的相关 Web components 组件的 CSS 选择器
*/
getGlobalLocalNameSelector() {
const localNames = this.relatedElements;
if (!localNames || Array.isArray(localNames)) {
return null;
}
return Object.keys(localNames).filter((localName) => localNames[localName]).map((localName) => `${localName}:not(:defined)`).join(",");
}
/**
* 获取未完成定义的相关 Web components 组件名
*/
getUndefinedLocalNames() {
const scopeSelector = this.getScopeLocalNameSelector();
const globalSelector = this.getGlobalLocalNameSelector();
const undefinedScopeElements = scopeSelector ? [...this.host.querySelectorAll(scopeSelector)] : [];
const undefinedGlobalElements = globalSelector ? [...getDocument().querySelectorAll(globalSelector)] : [];
const localNames = [
...undefinedScopeElements,
...undefinedGlobalElements
].map((element) => element.localName);
return unique(localNames);
}
/**
* slot 变更时,若 slot 中包含未完成定义的相关 Web components 组件,则组件未定义完成
*/
onSlotChange() {
const selector = this.getScopeLocalNameSelector();
if (selector) {
const undefinedElements = this.host.querySelectorAll(selector);
if (undefinedElements.length) {
this.defined = false;
}
}
}
}
function watch(propName, waitUntilFirstUpdate = false) {
return (proto, functionName) => {
const { update } = proto;
if (propName in proto) {
proto.update = function(changedProperties) {
if (changedProperties.has(propName)) {
const oldValue = changedProperties.get(propName);
const newValue = this[propName];
if (oldValue !== newValue) {
if (!waitUntilFirstUpdate || this.hasUpdated) {
this[functionName](oldValue, newValue);
}
}
}
update.call(this, changedProperties);
};
}
};
}
const weakMap$1 = /* @__PURE__ */ new WeakMap();
const ScrollBehaviorMixin = (superclass) => {
class ScrollBehaviorMixinClass extends superclass {
// eslint-disable-next-line @typescript-eslint/no-explicit-any
constructor(...args) {
super(...args);
this.scrollBehaviorDefinedController = new DefinedController(this, {
needDomReady: true
});
this.lastScrollTopThreshold = 0;
this.lastScrollTopNoThreshold = 0;
this.isParentLayout = false;
this.onListeningScroll = this.onListeningScroll.bind(this);
}
/**
* 滚动时,如果需要给 container 添加 padding,添加在顶部还是底部
*/
get scrollPaddingPosition() {
throw new Error("Must implement scrollPaddingPosition getter");
}
async onScrollTargetChange(oldValue, newValue) {
const hasUpdated = this.hasUpdated;
await this.scrollBehaviorDefinedController.whenDefined();
if (hasUpdated) {
this.setContainerPadding("remove", oldValue);
this.setContainerPadding("add", newValue);
}
if (!this.scrollBehavior) {
return;
}
const oldListening = this.getListening(oldValue);
if (oldListening) {
oldListening.removeEventListener("scroll", this.onListeningScroll);
}
const newListening = this.getListening(newValue);
if (newListening) {
this.updateScrollTop(newListening);
newListening.addEventListener("scroll", this.onListeningScroll);
}
}
async onScrollBehaviorChange() {
await this.scrollBehaviorDefinedController.whenDefined();
const listening = this.getListening(this.scrollTarget);
if (!listening) {
return;
}
if (this.scrollBehavior) {
this.updateScrollTop(listening);
listening.addEventListener("scroll", this.onListeningScroll);
} else {
listening.removeEventListener("scroll", this.onListeningScroll);
}
}
connectedCallback() {
super.connectedCallback();
this.scrollBehaviorDefinedController.whenDefined().then(() => {
this.isParentLayout = isNodeName(this.parentElement, "mdui-layout");
this.setContainerPadding("add", this.scrollTarget);
});
}
disconnectedCallback() {
super.disconnectedCallback();
this.scrollBehaviorDefinedController.whenDefined().then(() => {
this.setContainerPadding("remove", this.scrollTarget);
});
}
/**
* scrollBehavior 包含多个滚动行为,用空格分割
* 用该方法判断指定滚动行为是否在 scrollBehavior 中
* @param behavior 为数组时,只要其中一个行为在 scrollBehavior 中,即返回 `true`
*/
hasScrollBehavior(behavior) {
var _a2;
const behaviors = ((_a2 = this.scrollBehavior) == null ? void 0 : _a2.split(" ")) ?? [];
if (Array.isArray(behavior)) {
return !!behaviors.filter((v2) => behavior.includes(v2)).length;
} else {
return behaviors.includes(behavior);
}
}
/**
* 执行滚动事件,在滚动距离超过 scrollThreshold 时才会执行
* Note: 父类可以按需实现该方法
* @param isScrollingUp 是否向上滚动
* @param scrollTop 距离 scrollTarget 顶部的距离
*/
// eslint-disable-next-line @typescript-eslint/no-unused-vars
runScrollThreshold(isScrollingUp, scrollTop) {
return;
}
/**
* 执行滚动事件,会无视 scrollThreshold,始终会执行
* @param isScrollingUp 是否向上滚动
* @param scrollTop 距离 scrollTarget 顶部的距离
*/
// eslint-disable-next-line @typescript-eslint/no-unused-vars
runScrollNoThreshold(isScrollingUp, scrollTop) {
return;
}
/**
* 更新滚动容器的 padding,避免内容被 navigation-bar 覆盖
* @param action 新增、更新、移除 padding
* @param scrollTarget 在该元素上添加、更新或移除 padding
*/
setContainerPadding(action, scrollTarget) {
const container2 = this.getContainer(scrollTarget);
if (!container2 || this.isParentLayout) {
return;
}
const position = this.scrollPaddingPosition;
const propName = position === "top" ? "paddingTop" : "paddingBottom";
if (action === "add" || action === "update") {
const propValue = ["fixed", "absolute"].includes($$1(this).css("position")) ? this.offsetHeight : null;
$$1(container2).css({ [propName]: propValue });
if (action === "add" && propValue !== null) {
const options = weakMap$1.get(container2) ?? { top: [], bottom: [] };
options[position].push(this);
weakMap$1.set(container2, options);
}
}
if (action === "remove") {
const options = weakMap$1.get(container2);
if (!options) {
return;
}
const index = options[position].indexOf(this);
if (index > -1) {
options[position].splice(index, 1);
weakMap$1.set(container2, options);
}
if (!options[position].length) {
$$1(container2).css({ [propName]: null });
}
}
}
onListeningScroll() {
const listening = this.getListening(this.scrollTarget);
window.requestAnimationFrame(() => this.onScroll(listening));
}
/**
* 滚动事件,这里过滤掉不符合条件的滚动
*/
onScroll(listening) {
const scrollTop = listening.scrollY ?? listening.scrollTop;
if (this.lastScrollTopNoThreshold !== scrollTop) {
this.runScrollNoThreshold(scrollTop < this.lastScrollTopNoThreshold, scrollTop);
this.lastScrollTopNoThreshold = scrollTop;
}
if (Math.abs(scrollTop - this.lastScrollTopThreshold) > (this.scrollThreshold || 0)) {
this.runScrollThreshold(scrollTop < this.lastScrollTopThreshold, scrollTop);
this.lastScrollTopThreshold = scrollTop;
}
}
/**
* 重新更新 lastScrollTopThreshold、lastScrollTopNoThreshold 的值
* 用于在 scrollTarget、scrollBehavior 变更时,重新设置 lastScrollTopThreshold、lastScrollTopNoThreshold 的初始值
*/
updateScrollTop(listening) {
this.lastScrollTopThreshold = this.lastScrollTopNoThreshold = listening.scrollY ?? listening.scrollTop;
}
/**
* 获取组件需要监听哪个元素的滚动状态
*/
getListening(target) {
return target ? $$1(target)[0] : window;
}
/**
* 获取组件在哪个容器内滚动
*/
getContainer(target) {
return target ? $$1(target)[0] : document.body;
}
}
__decorate([
n$6({ attribute: "scroll-target" })
], ScrollBehaviorMixinClass.prototype, "scrollTarget", void 0);
__decorate([
n$6({ reflect: true, attribute: "scroll-behavior" })
], ScrollBehaviorMixinClass.prototype, "scrollBehavior", void 0);
__decorate([
n$6({ type: Number, reflect: true, attribute: "scroll-threshold" })
], ScrollBehaviorMixinClass.prototype, "scrollThreshold", void 0);
__decorate([
watch("scrollTarget")
], ScrollBehaviorMixinClass.prototype, "onScrollTargetChange", null);
__decorate([
watch("scrollBehavior")
], ScrollBehaviorMixinClass.prototype, "onScrollBehaviorChange", null);
return ScrollBehaviorMixinClass;
};
let id = 0;
const uniqueId = () => {
return ++id;
};
let weakMap;
let observer;
const observeResize = (target, callback) => {
const $target = $$1(target);
const key2 = uniqueId();
const result = {
unobserve: () => {
$target.each((_2, target2) => {
const options = weakMap.get(target2);
const index = options.coArr.findIndex((co) => co.key === key2);
if (index !== -1) {
options.coArr.splice(index, 1);
}
if (!options.coArr.length) {
observer.unobserve(target2);
weakMap.delete(target2);
} else {
weakMap.set(target2, options);
}
});
}
};
if (!weakMap) {
weakMap = /* @__PURE__ */ new WeakMap();
observer = new ResizeObserver((entries) => {
entries.forEach((entry) => {
const target2 = entry.target;
const options = weakMap.get(target2);
options.entry = entry;
options.coArr.forEach((co) => {
co.callback.call(result, entry, result);
});
});
});
}
$target.each((_2, target2) => {
const options = weakMap.get(target2) ?? { coArr: [] };
if (options.coArr.length && options.entry) {
callback.call(result, options.entry, result);
}
options.coArr.push({ callback, key: key2 });
weakMap.set(target2, options);
observer.observe(target2);
});
return result;
};
class LayoutManager {
constructor() {
this.states = [];
}
/**
* 注册 `<mdui-layout-main>`
*/
registerMain(element) {
this.$main = $$1(element);
}
/**
* 取消注册 `<mdui-layout-main>`
*/
unregisterMain() {
this.$main = void 0;
}
/**
* 注册新的 `<mdui-layout-item>`
*/
registerItem(element) {
const state = { element };
this.states.push(state);
state.observeResize = observeResize(state.element, () => {
this.updateLayout(state.element, {
width: this.isNoWidth(state) ? 0 : void 0
});
});
this.items = void 0;
this.resort();
this.updateLayout();
}
/**
* 取消注册 `<mdui-layout-item>`
*/
unregisterItem(element) {
var _a2;
const index = this.states.findIndex((item2) => item2.element === element);
if (index < 0) {
return;
}
const item = this.states[index];
(_a2 = item.observeResize) == null ? void 0 : _a2.unobserve();
this.items = void 0;
this.states.splice(index, 1);
if (this.states[index]) {
this.updateLayout(this.states[index].element);
}
}
/**
* 获取所有 `<mdui-layout-item>` 元素(按在 DOM 中的顺序)
*/
getItems() {
if (!this.items) {
const items = this.states.map((state) => state.element);
this.items = items.sort((a2, b3) => {
const position = a2.compareDocumentPosition(b3);
if (position & Node.DOCUMENT_POSITION_FOLLOWING) {
return -1;
} else if (position & Node.DOCUMENT_POSITION_PRECEDING) {
return 1;
} else {
return 0;
}
});
}
return this.items;
}
/**
* 获取 `<mdui-layout-main>` 元素
*/
getMain() {
return this.$main ? this.$main[0] : void 0;
}
/**
* 获取 `<mdui-layout-item>` 及 `<mdui-layout-main>` 元素
*/
getItemsAndMain() {
return [...this.getItems(), this.getMain()].filter((i3) => i3);
}
/**
* 更新 `order` 值,更新完后重新计算布局
*/
updateOrder() {
this.resort();
this.updateLayout();
}
/**
* 重新计算布局
* @param element 从哪一个元素开始更新;若未传入参数,则将更新所有元素
* @param size 此次更新中,元素的宽高(仅在此次更新中使用)。若不传则自动计算
*/
updateLayout(element, size) {
const state = element ? {
element,
width: size == null ? void 0 : size.width,
height: size == null ? void 0 : size.height
} : void 0;
const index = state ? this.states.findIndex((v2) => v2.element === state.element) : 0;
if (index < 0) {
return;
}
Object.assign(this.states[index], state);
this.states.forEach((currState, currIndex) => {
if (currIndex < index) {
return;
}
const placement = currState.element.layoutPlacement;
const prevState = currIndex > 0 ? this.states[currIndex - 1] : void 0;
const top2 = (prevState == null ? void 0 : prevState.top) ?? 0;
const right = (prevState == null ? void 0 : prevState.right) ?? 0;
const bottom = (prevState == null ? void 0 : prevState.bottom) ?? 0;
const left = (prevState == null ? void 0 : prevState.left) ?? 0;
Object.assign(currState, { top: top2, right, bottom, left });
switch (placement) {
case "top":
case "bottom":
currState[placement] += currState.height ?? currState.element.offsetHeight;
break;
case "right":
case "left":
currState[placement] += (this.isNoWidth(currState) ? 0 : currState.width) ?? currState.element.offsetWidth;
break;
}
currState.height = currState.width = void 0;
$$1(currState.element).css({
position: "absolute",
top: placement === "bottom" ? null : top2,
right: placement === "left" ? null : right,
bottom: placement === "top" ? null : bottom,
left: placement === "right" ? null : left
});
});
const lastState = this.states[this.states.length - 1];
if (this.$main) {
this.$main.css({
paddingTop: lastState.top,
paddingRight: lastState.right,
paddingBottom: lastState.bottom,
paddingLeft: lastState.left
});
}
}
/**
* 按 order 排序,order 相同时,按在 DOM 中的顺序排序
*/
resort() {
const items = this.getItems();
this.states.sort((a2, b3) => {
const aOrder = a2.element.order ?? 0;
const bOrder = b3.element.order ?? 0;
if (aOrder > bOrder) {
return 1;
}
if (aOrder < bOrder) {
return -1;
}
if (items.indexOf(a2.element) > items.indexOf(b3.element)) {
return 1;
}
if (items.indexOf(a2.element) < items.indexOf(b3.element)) {
return -1;
}
return 0;
});
}
/**
* 组件宽度是否为 0
* mdui-navigation-drawer 较为特殊,在为模态化时,占据的宽度为 0
*/
isNoWidth(state) {
return isNodeName(state.element, "mdui-navigation-drawer") && // @ts-ignore
state.element.isModal;
}
}
const layoutManagerMap = /* @__PURE__ */ new WeakMap();
const getLayout = (element) => {
if (!layoutManagerMap.has(element)) {
layoutManagerMap.set(element, new LayoutManager());
}
return layoutManagerMap.get(element);
};
class LayoutItemBase extends MduiElement {
constructor() {
super(...arguments);
this.isParentLayout = false;
}
/**
* 当前布局组件所处的位置,父类必须实现该 getter
*/
get layoutPlacement() {
throw new Error("Must implement placement getter!");
}
// order 变更时,需要重新调整布局
onOrderChange() {
var _a2;
(_a2 = this.layoutManager) == null ? void 0 : _a2.updateOrder();
}
connectedCallback() {
super.connectedCallback();
const parentElement = this.parentElement;
this.isParentLayout = isNodeName(parentElement, "mdui-layout");
if (this.isParentLayout) {
this.layoutManager = getLayout(parentElement);
this.layoutManager.registerItem(this);
}
}
disconnectedCallback() {
super.disconnectedCallback();
if (this.layoutManager) {
this.layoutManager.unregisterItem(this);
}
}
}
__decorate([
n$6({ type: Number, reflect: true })
], LayoutItemBase.prototype, "order", void 0);
__decorate([
watch("order", true)
], LayoutItemBase.prototype, "onOrderChange", null);
const style$k = i$7`:host{--shape-corner:var(--mdui-shape-corner-none);--z-index:2000;position:fixed;right:0;bottom:0;left:0;display:flex;flex:0 0 auto;align-items:center;justify-content:flex-start;border-radius:var(--shape-corner) var(--shape-corner) 0 0;z-index:var(--z-index);transition:bottom var(--mdui-motion-duration-long2) var(--mdui-motion-easing-emphasized);padding:0 1rem;height:5rem;background-color:rgb(var(--mdui-color-surface-container));box-shadow:var(--mdui-elevation-level2)}:host([scroll-target]:not([scroll-target=''])){position:absolute}:host([hide]:not([hide=false i])){transition-duration:var(--mdui-motion-duration-short4);bottom:-5.625rem}::slotted(:not(:first-child)){margin-left:.5rem}::slotted(mdui-fab){box-shadow:var(--mdui-elevation-level0)}:host([fab-detach]:not([fab-detach=false i])) ::slotted(mdui-fab){position:absolute;transition:bottom var(--mdui-motion-duration-long2) var(--mdui-motion-easing-standard);right:1rem;bottom:.75rem}:host([fab-detach][hide][scroll-behavior~=hide]:not([hide=false i],[fab-detach=false i])) ::slotted(mdui-fab){transition-duration:var(--mdui-motion-duration-short4);bottom:1rem;box-shadow:var(--mdui-elevation-level2)}:host([fab-detach][hide][scroll-behavior~=hide][scroll-target]:not([fab-detach=false i],[hide=false i],[scroll-target=''])) ::slotted(mdui-fab){bottom:6.625rem}:host([hide]:not([hide=false i])) ::slotted(:not(mdui-fab)),:host([hide]:not([hide=false i],[fab-detach])) ::slotted(mdui-fab),:host([hide][fab-detach=false i]:not([hide=false i])) ::slotted(mdui-fab){transform:translateY(8.75rem);transition:transform var(--mdui-motion-duration-0) var(--mdui-motion-easing-emphasized-accelerate) var(--mdui-motion-duration-short4)}::slotted(:first-child){transition:transform var(--mdui-motion-duration-short3) var(--mdui-motion-easing-emphasized-decelerate) var(--mdui-motion-duration-short1)}::slotted(:nth-child(2)){transition:transform var(--mdui-motion-duration-short3) var(--mdui-motion-easing-emphasized-decelerate) var(--mdui-motion-duration-short3)}::slotted(:nth-child(3)){transition:transform var(--mdui-motion-duration-short3) var(--mdui-motion-easing-emphasized-decelerate) var(--mdui-motion-duration-short4)}::slotted(:nth-child(4)){transition:transform var(--mdui-motion-duration-short3) var(--mdui-motion-easing-emphasized-decelerate) var(--mdui-motion-duration-medium1)}::slotted(:nth-child(5)){transition:transform var(--mdui-motion-duration-short3) var(--mdui-motion-easing-emphasized-decelerate) var(--mdui-motion-duration-medium2)}::slotted(:nth-child(6)){transition:transform var(--mdui-motion-duration-short3) var(--mdui-motion-easing-emphasized-decelerate) var(--mdui-motion-duration-medium3)}`;
let BottomAppBar = class BottomAppBar2 extends ScrollBehaviorMixin(LayoutItemBase) {
constructor() {
super(...arguments);
this.hide = false;
this.fabDetach = false;
}
get scrollPaddingPosition() {
return "bottom";
}
get layoutPlacement() {
return "bottom";
}
firstUpdated(_changedProperties) {
super.firstUpdated(_changedProperties);
this.addEventListener("transitionend", (event) => {
if (event.target === this) {
this.emit(this.hide ? "hidden" : "shown");
}
});
}
render() {
return x`<slot></slot>`;
}
/**
* 滚动行为
* 当前仅支持 hide 这一个行为,所以不做行为类型判断
*/
runScrollThreshold(isScrollingUp) {
if (!isScrollingUp && !this.hide) {
const eventProceeded = this.emit("hide", { cancelable: true });
if (eventProceeded) {
this.hide = true;
}
}
if (isScrollingUp && this.hide) {
const eventProceeded = this.emit("show", { cancelable: true });
if (eventProceeded) {
this.hide = false;
}
}
}
};
BottomAppBar.styles = [componentStyle, style$k];
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], BottomAppBar.prototype, "hide", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter,
attribute: "fab-detach"
})
], BottomAppBar.prototype, "fabDetach", void 0);
__decorate([
n$6({ reflect: true, attribute: "scroll-behavior" })
], BottomAppBar.prototype, "scrollBehavior", void 0);
BottomAppBar = __decorate([
t$3("mdui-bottom-app-bar")
], BottomAppBar);
/**
* @license
* Copyright 2020 Google LLC
* SPDX-License-Identifier: BSD-3-Clause
*/
const e$2 = () => new h$1();
let h$1 = class h {
};
const o$1 = /* @__PURE__ */ new WeakMap(), n$2 = e$4(class extends f$1 {
render(i3) {
return E;
}
update(i3, [s3]) {
var _a2;
const e3 = s3 !== this.Y;
return e3 && void 0 !== this.Y && this.rt(void 0), (e3 || this.lt !== this.ct) && (this.Y = s3, this.ht = (_a2 = i3.options) == null ? void 0 : _a2.host, this.rt(this.ct = i3.element)), E;
}
rt(t3) {
if (this.isConnected || (t3 = void 0), "function" == typeof this.Y) {
const i3 = this.ht ?? globalThis;
let s3 = o$1.get(i3);
void 0 === s3 && (s3 = /* @__PURE__ */ new WeakMap(), o$1.set(i3, s3)), void 0 !== s3.get(this.Y) && this.Y.call(this.ht, void 0), s3.set(this.Y, t3), void 0 !== t3 && this.Y.call(this.ht, t3);
} else this.Y.value = t3;
}
get lt() {
var _a2, _b;
return "function" == typeof this.Y ? (_a2 = o$1.get(this.ht ?? globalThis)) == null ? void 0 : _a2.get(this.Y) : (_b = this.Y) == null ? void 0 : _b.value;
}
disconnected() {
this.lt === this.ct && this.rt(void 0);
}
reconnected() {
this.rt(this.ct);
}
});
function cc(names) {
if (typeof names === "string" || typeof names === "number") return "" + names;
let out = "";
if (Array.isArray(names)) {
for (let i3 = 0, tmp; i3 < names.length; i3++) {
if ((tmp = cc(names[i3])) !== "") {
out += (out && " ") + tmp;
}
}
} else {
for (let k3 in names) {
if (names[k3]) out += (out && " ") + k3;
}
}
return out;
}
const reportValidityOverloads = /* @__PURE__ */ new WeakMap();
const formResets = /* @__PURE__ */ new WeakMap();
class FormController {
constructor(host, options) {
(this.host = host).addController(this);
this.definedController = new DefinedController(host, {
needDomReady: true
});
this.options = {
form: (control) => {
const formId = $$1(control).attr("form");
if (formId) {
const root2 = control.getRootNode();
return root2.getElementById(formId);
}
return control.closest("form");
},
name: (control) => control.name,
value: (control) => control.value,
defaultValue: (control) => control.defaultValue,
setValue: (control, value) => control.value = value,
disabled: (control) => control.disabled,
reportValidity: (control) => isFunction(control.reportValidity) ? control.reportValidity() : true,
...options
};
this.onFormData = this.onFormData.bind(this);
this.onFormSubmit = this.onFormSubmit.bind(this);
this.onFormReset = this.onFormReset.bind(this);
this.reportFormValidity = this.reportFormValidity.bind(this);
}
hostConnected() {
this.definedController.whenDefined().then(() => {
this.form = this.options.form(this.host);
if (this.form) {
this.attachForm(this.form);
}
});
}
hostDisconnected() {
this.detachForm();
}
hostUpdated() {
this.definedController.whenDefined().then(() => {
const form = this.options.form(this.host);
if (!form) {
this.detachForm();
}
if (form && this.form !== form) {
this.detachForm();
this.attachForm(form);
}
});
}
/**
* 获取当前表单控件关联的 `<form>` 元素
*/
getForm() {
return this.form ?? null;
}
/**
* 重置整个表单,所有表单控件恢复成默认值
*/
reset(invoker) {
this.doAction("reset", invoker);
}
/**
* 提交整个表单
*/
submit(invoker) {
this.doAction("submit", invoker);
}
attachForm(form) {
if (!form) {
this.form = void 0;
return;
}
this.form = form;
if (formCollections.has(this.form)) {
formCollections.get(this.form).add(this.host);
} else {
formCollections.set(this.form, /* @__PURE__ */ new Set([this.host]));
}
this.form.addEventListener("formdata", this.onFormData);
this.form.addEventListener("submit", this.onFormSubmit);
this.form.addEventListener("reset", this.onFormReset);
if (!reportValidityOverloads.has(this.form)) {
reportValidityOverloads.set(this.form, this.form.reportValidity);
this.form.reportValidity = () => this.reportFormValidity();
}
}
detachForm() {
if (this.form) {
formCollections.get(this.form).delete(this.host);
this.form.removeEventListener("formdata", this.onFormData);
this.form.removeEventListener("submit", this.onFormSubmit);
this.form.removeEventListener("reset", this.onFormReset);
if (reportValidityOverloads.has(this.form) && !formCollections.get(this.form).size) {
this.form.reportValidity = reportValidityOverloads.get(this.form);
reportValidityOverloads.delete(this.form);
}
}
}
doAction(type, invoker) {
if (!this.form) {
return;
}
const $button = $$1(`<button type="${type}">`).css({
position: "absolute",
width: 0,
height: 0,
clipPath: "inset(50%)",
overflow: "hidden",
whiteSpace: "nowrap"
});
const button = $button[0];
if (invoker) {
button.name = invoker.name;
button.value = invoker.value;
[
"formaction",
"formenctype",
"formmethod",
"formnovalidate",
"formtarget"
].forEach((attr) => {
$button.attr(attr, $$1(invoker).attr(attr));
});
}
this.form.append(button);
button.click();
button.remove();
}
onFormData(event) {
const disabled = this.options.disabled(this.host);
const name = this.options.name(this.host);
const value = this.options.value(this.host);
const isButton = [
"mdui-button",
"mdui-button-icon",
"mdui-chip",
"mdui-fab",
"mdui-segmented-button"
].includes(this.host.tagName.toLowerCase());
if (!disabled && !isButton && isString(name) && name && !isUndefined(value)) {
if (Array.isArray(value)) {
value.forEach((val) => {
event.formData.append(name, val.toString());
});
} else {
event.formData.append(name, value.toString());
}
}
}
// todo: 当前组件进行验证的顺序,取决于组件的注册顺序,而不会按在 DOM 中的顺序从上到下验证。如何按 DOM 顺序验证?
onFormSubmit(event) {
const disabled = this.options.disabled(this.host);
const reportValidity = this.options.reportValidity;
if (this.form && !this.form.noValidate && !disabled && !reportValidity(this.host)) {
event.preventDefault();
event.stopImmediatePropagation();
}
}
onFormReset() {
if (this.form) {
this.options.setValue(this.host, this.options.defaultValue(this.host));
this.host.invalid = false;
if (formResets.has(this.form)) {
formResets.get(this.form).add(this.host);
} else {
formResets.set(this.form, /* @__PURE__ */ new Set([this.host]));
}
}
}
reportFormValidity() {
if (this.form && !this.form.noValidate) {
const elements = getFormControls(this.form);
for (const element of elements) {
if (isFunction(element.reportValidity) && !element.reportValidity()) {
return false;
}
}
}
return true;
}
}
const AnchorMixin = (superclass) => {
class AnchorMixinClass extends superclass {
renderAnchor({ id: id2, className: className2, part, content = x`<slot></slot>`, refDirective, tabIndex }) {
return x`<a ${refDirective} id="${o$5(id2)}" class="_a ${className2 ? className2 : ""}" part="${o$5(part)}" href="${o$5(this.href)}" download="${o$5(this.download)}" target="${o$5(this.target)}" rel="${o$5(this.rel)}" tabindex="${o$5(tabIndex)}">${content}</a>`;
}
}
__decorate([
n$6({ reflect: true })
], AnchorMixinClass.prototype, "href", void 0);
__decorate([
n$6({ reflect: true })
], AnchorMixinClass.prototype, "download", void 0);
__decorate([
n$6({ reflect: true })
], AnchorMixinClass.prototype, "target", void 0);
__decorate([
n$6({ reflect: true })
], AnchorMixinClass.prototype, "rel", void 0);
return AnchorMixinClass;
};
let isClick = true;
const document$1 = getDocument();
document$1.addEventListener("pointerdown", () => {
isClick = true;
});
document$1.addEventListener("keydown", () => {
isClick = false;
});
const FocusableMixin = (superclass) => {
class FocusableMixinClass extends superclass {
constructor() {
super(...arguments);
this.autofocus = false;
this.focused = false;
this.focusVisible = false;
this.focusableDefinedController = new DefinedController(this, { relatedElements: [""] });
this._manipulatingTabindex = false;
this._tabIndex = 0;
}
/**
* 元素在使用 Tab 键切换焦点时的顺序
*/
get tabIndex() {
const $this = $$1(this);
if (this.focusElement === this) {
return Number($this.attr("tabindex") || -1);
}
const tabIndexAttribute = Number($this.attr("tabindex") || 0);
if (this.focusDisabled || tabIndexAttribute < 0) {
return -1;
}
if (!this.focusElement) {
return tabIndexAttribute;
}
return this.focusElement.tabIndex;
}
set tabIndex(tabIndex) {
if (this._manipulatingTabindex) {
this._manipulatingTabindex = false;
return;
}
const $this = $$1(this);
if (this.focusElement === this) {
if (tabIndex !== null) {
this._tabIndex = tabIndex;
}
$this.attr("tabindex", this.focusDisabled ? null : tabIndex);
return;
}
const onPointerDown = () => {
if (this.tabIndex === -1) {
this.tabIndex = 0;
this.focus({ preventScroll: true });
}
};
if (tabIndex === -1) {
this.addEventListener("pointerdown", onPointerDown);
} else {
this._manipulatingTabindex = true;
this.removeEventListener("pointerdown", onPointerDown);
}
if (tabIndex === -1 || this.focusDisabled) {
$this.attr("tabindex", -1);
if (tabIndex !== -1) {
this.manageFocusElementTabindex(tabIndex);
}
return;
}
if (!this.hasAttribute("tabindex")) {
this._manipulatingTabindex = false;
}
this.manageFocusElementTabindex(tabIndex);
}
/**
* 父类要实现该属性,表示是否禁用 focus 状态
*/
get focusDisabled() {
throw new Error("Must implement focusDisabled getter!");
}
/**
* 最终获得焦点的元素
*/
get focusElement() {
throw new Error("Must implement focusElement getter!");
}
connectedCallback() {
super.connectedCallback();
this.updateComplete.then(() => {
requestAnimationFrame(() => {
this.manageAutoFocus();
});
});
}
/**
* 模拟鼠标点击元素
*/
click() {
if (this.focusDisabled) {
return;
}
if (this.focusElement !== this) {
this.focusElement.click();
} else {
HTMLElement.prototype.click.apply(this);
}
}
/**
* 将焦点设置到当前元素。
*
* 可以传入一个对象作为参数,该对象的属性包括:
*
* * `preventScroll`:默认情况下,元素获取焦点后,页面会滚动以将该元素滚动到视图中。如果不希望页面滚动,可以将此属性设置为 `true`。
*/
focus(options) {
if (this.focusDisabled || !this.focusElement) {
return;
}
if (this.focusElement !== this) {
this.focusElement.focus(options);
} else {
HTMLElement.prototype.focus.apply(this, [options]);
}
}
/**
* 移除当前元素的焦点
*/
blur() {
if (this.focusElement !== this) {
this.focusElement.blur();
} else {
HTMLElement.prototype.blur.apply(this);
}
}
firstUpdated(changedProperties) {
super.firstUpdated(changedProperties);
this.focusElement.addEventListener("focus", () => {
this.focused = true;
this.focusVisible = !isClick;
});
this.focusElement.addEventListener("blur", () => {
this.focused = false;
this.focusVisible = false;
});
}
update(changedProperties) {
if (this._lastFocusDisabled === void 0 || this._lastFocusDisabled !== this.focusDisabled) {
this._lastFocusDisabled = this.focusDisabled;
const $this = $$1(this);
if (this.focusDisabled) {
$this.removeAttr("tabindex");
} else {
if (this.focusElement === this) {
this._manipulatingTabindex = true;
$this.attr("tabindex", this._tabIndex);
} else if (this.tabIndex > -1) {
$this.removeAttr("tabindex");
}
}
}
super.update(changedProperties);
}
updated(changedProperties) {
super.updated(changedProperties);
if (this.focused && this.focusDisabled) {
this.blur();
}
}
async manageFocusElementTabindex(tabIndex) {
if (!this.focusElement) {
await this.updateComplete;
}
if (tabIndex === null) {
this.focusElement.removeAttribute("tabindex");
} else {
this.focusElement.tabIndex = tabIndex;
}
}
manageAutoFocus() {
if (this.autofocus) {
this.dispatchEvent(new KeyboardEvent("keydown", {
code: "Tab"
}));
this.focusElement.focus();
}
}
}
__decorate([
n$6({
type: Boolean,
/**
* 哪些属性需要 reflect: true?
* 一般所有属性都需要 reflect,但以下情况除外:
* 1. 会频繁变更的属性
* 2. 属性同步会造成较大性能开销的属性
* 3. 复杂类型属性(数组、对象等,仅提供 property,不提供 attribute)
*/
reflect: true,
converter: booleanConverter
})
], FocusableMixinClass.prototype, "autofocus", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], FocusableMixinClass.prototype, "focused", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter,
attribute: "focus-visible"
})
], FocusableMixinClass.prototype, "focusVisible", void 0);
__decorate([
n$6({ type: Number, attribute: "tabindex" })
], FocusableMixinClass.prototype, "tabIndex", null);
return FocusableMixinClass;
};
/**
* @license
* Copyright 2018 Google LLC
* SPDX-License-Identifier: BSD-3-Clause
*/
const e$1 = e$4(class extends i$3 {
constructor(t3) {
var _a2;
if (super(t3), t3.type !== t$2.ATTRIBUTE || "class" !== t3.name || ((_a2 = t3.strings) == null ? void 0 : _a2.length) > 2) throw Error("`classMap()` can only be used in the `class` attribute and must be the only part in the attribute.");
}
render(t3) {
return " " + Object.keys(t3).filter((s3) => t3[s3]).join(" ") + " ";
}
update(s3, [i3]) {
var _a2, _b;
if (void 0 === this.st) {
this.st = /* @__PURE__ */ new Set(), void 0 !== s3.strings && (this.nt = new Set(s3.strings.join(" ").split(/\s/).filter((t3) => "" !== t3)));
for (const t3 in i3) i3[t3] && !((_a2 = this.nt) == null ? void 0 : _a2.has(t3)) && this.st.add(t3);
return this.render(i3);
}
const r3 = s3.element.classList;
for (const t3 of this.st) t3 in i3 || (r3.remove(t3), this.st.delete(t3));
for (const t3 in i3) {
const s4 = !!i3[t3];
s4 === this.st.has(t3) || ((_b = this.nt) == null ? void 0 : _b.has(t3)) || (s4 ? (r3.add(t3), this.st.add(t3)) : (r3.remove(t3), this.st.delete(t3)));
}
return T;
}
});
const style$j = i$7`:host{position:relative;display:inline-block;flex-shrink:0;width:2.5rem;height:2.5rem;stroke:rgb(var(--mdui-color-primary))}.progress{position:relative;display:inline-block;width:100%;height:100%;text-align:left;transition:opacity var(--mdui-motion-duration-medium1) var(--mdui-motion-easing-linear)}.determinate svg{transform:rotate(-90deg);fill:transparent}.determinate .track{stroke:transparent}.determinate .circle{stroke:inherit;transition:stroke-dashoffset var(--mdui-motion-duration-long2) var(--mdui-motion-easing-standard)}.indeterminate{font-size:0;letter-spacing:0;white-space:nowrap;animation:mdui-comp-circular-progress-rotate 1568ms var(--mdui-motion-easing-linear) infinite}.indeterminate .circle,.indeterminate .layer{position:absolute;width:100%;height:100%}.indeterminate .layer{animation:mdui-comp-circular-progress-layer-rotate 5332ms var(--mdui-motion-easing-standard) infinite both}.indeterminate .circle{fill:transparent;stroke:inherit}.indeterminate .gap-patch{position:absolute;top:0;left:47.5%;width:5%;height:100%;overflow:hidden}.indeterminate .gap-patch .circle{left:-900%;width:2000%;transform:rotate(180deg)}.indeterminate .clipper{position:relative;display:inline-block;width:50%;height:100%;overflow:hidden}.indeterminate .clipper .circle{width:200%}.indeterminate .clipper.left .circle{animation:mdui-comp-circular-progress-left-spin 1333ms var(--mdui-motion-easing-standard) infinite both}.indeterminate .clipper.right .circle{left:-100%;animation:mdui-comp-circular-progress-right-spin 1333ms var(--mdui-motion-easing-standard) infinite both}@keyframes mdui-comp-circular-progress-rotate{to{transform:rotate(360deg)}}@keyframes mdui-comp-circular-progress-layer-rotate{12.5%{transform:rotate(135deg)}25%{transform:rotate(270deg)}37.5%{transform:rotate(405deg)}50%{transform:rotate(540deg)}62.5%{transform:rotate(675deg)}75%{transform:rotate(810deg)}87.5%{transform:rotate(945deg)}100%{transform:rotate(1080deg)}}@keyframes mdui-comp-circular-progress-left-spin{0%{transform:rotate(265deg)}50%{transform:rotate(130deg)}100%{transform:rotate(265deg)}}@keyframes mdui-comp-circular-progress-right-spin{0%{transform:rotate(-265deg)}50%{transform:rotate(-130deg)}100%{transform:rotate(-265deg)}}`;
let CircularProgress = class CircularProgress2 extends MduiElement {
constructor() {
super(...arguments);
this.max = 1;
}
render() {
const isDeterminate = !isUndefined(this.value);
return x`<div class="progress ${e$1({
determinate: isDeterminate,
indeterminate: !isDeterminate
})}">${isDeterminate ? this.renderDeterminate() : this.renderInDeterminate()}</div>`;
}
renderDeterminate() {
const value = this.value;
const strokeWidth = 4;
const circleRadius = 18;
const π = 3.1415926;
const center = circleRadius + strokeWidth / 2;
const circumference = 2 * π * circleRadius;
const determinateStrokeDashOffset = (1 - value / Math.max(this.max ?? value, value)) * circumference;
return x`<svg viewBox="0 0 ${center * 2} ${center * 2}"><circle class="track" cx="${center}" cy="${center}" r="${circleRadius}" stroke-width="${strokeWidth}"></circle><circle class="circle" cx="${center}" cy="${center}" r="${circleRadius}" stroke-dasharray="${2 * π * circleRadius}" stroke-dashoffset="${determinateStrokeDashOffset}" stroke-width="${strokeWidth}"></circle></svg>`;
}
renderInDeterminate() {
const strokeWidth = 4;
const circleRadius = 18;
const π = 3.1415926;
const center = circleRadius + strokeWidth / 2;
const circumference = 2 * π * circleRadius;
const halfCircumference = 0.5 * circumference;
const circle = (thisStrokeWidth) => x`<svg class="circle" viewBox="0 0 ${center * 2} ${center * 2}"><circle cx="${center}" cy="${center}" r="${circleRadius}" stroke-dasharray="${circumference}" stroke-dashoffset="${halfCircumference}" stroke-width="${thisStrokeWidth}"></circle></svg>`;
return x`<div class="layer"><div class="clipper left">${circle(strokeWidth)}</div><div class="gap-patch">${circle(strokeWidth * 0.8)}</div><div class="clipper right">${circle(strokeWidth)}</div></div>`;
}
};
CircularProgress.styles = [componentStyle, style$j];
__decorate([
n$6({ type: Number, reflect: true })
], CircularProgress.prototype, "max", void 0);
__decorate([
n$6({ type: Number })
], CircularProgress.prototype, "value", void 0);
CircularProgress = __decorate([
t$3("mdui-circular-progress")
], CircularProgress);
const style$i = i$7`:host{position:absolute;top:0;left:0;display:block;width:100%;height:100%;overflow:hidden;pointer-events:none}.surface{position:absolute;top:0;left:0;width:100%;height:100%;transition-duration:280ms;transition-property:background-color;pointer-events:none;transition-timing-function:var(--mdui-motion-easing-standard)}.hover{background-color:rgba(var(--mdui-comp-ripple-state-layer-color,var(--mdui-color-on-surface)),var(--mdui-state-layer-hover))}:host-context([focus-visible]) .focused{background-color:rgba(var(--mdui-comp-ripple-state-layer-color,var(--mdui-color-on-surface)),var(--mdui-state-layer-focus))}.dragged{background-color:rgba(var(--mdui-comp-ripple-state-layer-color,var(--mdui-color-on-surface)),var(--mdui-state-layer-dragged))}.wave{position:absolute;z-index:1;background-color:rgb(var(--mdui-comp-ripple-state-layer-color,var(--mdui-color-on-surface)));border-radius:50%;transform:translate3d(0,0,0) scale(.4);opacity:0;animation:225ms ease 0s 1 normal forwards running mdui-comp-ripple-radius-in,75ms ease 0s 1 normal forwards running mdui-comp-ripple-opacity-in;pointer-events:none}.out{transform:translate3d(var(--mdui-comp-ripple-transition-x,0),var(--mdui-comp-ripple-transition-y,0),0) scale(1);animation:150ms ease 0s 1 normal none running mdui-comp-ripple-opacity-out}@keyframes mdui-comp-ripple-radius-in{from{transform:translate3d(0,0,0) scale(.4);animation-timing-function:var(--mdui-motion-easing-standard)}to{transform:translate3d(var(--mdui-comp-ripple-transition-x,0),var(--mdui-comp-ripple-transition-y,0),0) scale(1)}}@keyframes mdui-comp-ripple-opacity-in{from{opacity:0;animation-timing-function:linear}to{opacity:var(--mdui-state-layer-pressed)}}@keyframes mdui-comp-ripple-opacity-out{from{animation-timing-function:linear;opacity:var(--mdui-state-layer-pressed)}to{opacity:0}}`;
let Ripple = class Ripple2 extends MduiElement {
constructor() {
super(...arguments);
this.noRipple = false;
this.hover = false;
this.focused = false;
this.dragged = false;
this.surfaceRef = e$2();
}
startPress(event) {
if (this.noRipple) {
return;
}
const $surface = $$1(this.surfaceRef.value);
const surfaceHeight = $surface.innerHeight();
const surfaceWidth = $surface.innerWidth();
let touchStartX;
let touchStartY;
if (!event) {
touchStartX = surfaceWidth / 2;
touchStartY = surfaceHeight / 2;
} else {
const touchPosition = typeof TouchEvent !== "undefined" && event instanceof TouchEvent && event.touches.length ? event.touches[0] : event;
const offset = $surface.offset();
if (touchPosition.pageX < offset.left || touchPosition.pageX > offset.left + surfaceWidth || touchPosition.pageY < offset.top || touchPosition.pageY > offset.top + surfaceHeight) {
return;
}
touchStartX = touchPosition.pageX - offset.left;
touchStartY = touchPosition.pageY - offset.top;
}
const diameter = Math.max(Math.pow(Math.pow(surfaceHeight, 2) + Math.pow(surfaceWidth, 2), 0.5), 48);
const translateX = `${-touchStartX + surfaceWidth / 2}px`;
const translateY = `${-touchStartY + surfaceHeight / 2}px`;
const translate = `translate3d(${translateX}, ${translateY}, 0) scale(1)`;
$$1('<div class="wave"></div>').css({
width: diameter,
height: diameter,
marginTop: -diameter / 2,
marginLeft: -diameter / 2,
left: touchStartX,
top: touchStartY
}).each((_2, wave) => {
wave.style.setProperty("--mdui-comp-ripple-transition-x", translateX);
wave.style.setProperty("--mdui-comp-ripple-transition-y", translateY);
}).prependTo(this.surfaceRef.value).each((_2, wave) => wave.clientLeft).css("transform", translate).on("animationend", function(e3) {
const event2 = e3;
if (event2.animationName === "mdui-comp-ripple-radius-in") {
$$1(this).data("filled", true);
}
});
}
endPress() {
const $waves = $$1(this.surfaceRef.value).children().filter((_2, wave) => !$$1(wave).data("removing")).data("removing", true);
const hideAndRemove = ($waves2) => {
$waves2.addClass("out").each((_2, wave) => wave.clientLeft).on("animationend", function() {
$$1(this).remove();
});
};
$waves.filter((_2, wave) => !$$1(wave).data("filled")).on("animationend", function(e3) {
const event = e3;
if (event.animationName === "mdui-comp-ripple-radius-in") {
hideAndRemove($$1(this));
}
});
hideAndRemove($waves.filter((_2, wave) => !!$$1(wave).data("filled")));
}
startHover() {
this.hover = true;
}
endHover() {
this.hover = false;
}
startFocus() {
this.focused = true;
}
endFocus() {
this.focused = false;
}
startDrag() {
this.dragged = true;
}
endDrag() {
this.dragged = false;
}
render() {
return x`<div ${n$2(this.surfaceRef)} class="surface ${e$1({
hover: this.hover,
focused: this.focused,
dragged: this.dragged
})}"></div>`;
}
};
Ripple.styles = [componentStyle, style$i];
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter,
attribute: "no-ripple"
})
], Ripple.prototype, "noRipple", void 0);
__decorate([
r$1()
], Ripple.prototype, "hover", void 0);
__decorate([
r$1()
], Ripple.prototype, "focused", void 0);
__decorate([
r$1()
], Ripple.prototype, "dragged", void 0);
Ripple = __decorate([
t$3("mdui-ripple")
], Ripple);
const RippleMixin = (superclass) => {
class Mixin extends superclass {
constructor() {
super(...arguments);
this.noRipple = false;
this.rippleIndex = void 0;
this.getRippleIndex = () => this.rippleIndex;
}
/**
* 子类要添加该属性,指向 <mdui-ripple> 元素
* 如果一个组件中包含多个 <mdui-ripple> 元素,则这里可以是一个数组或 NodeList
*/
get rippleElement() {
throw new Error("Must implement rippleElement getter!");
}
/**
* 子类要实现该属性,表示是否禁用 ripple
* 如果一个组件中包含多个 <mdui-ripple> 元素,则这里可以是一个数组;也可以是单个值,同时控制多个 <mdui-ripple> 元素
*/
get rippleDisabled() {
throw new Error("Must implement rippleDisabled getter!");
}
/**
* 当前 <mdui-ripple> 元素相对于哪个元素存在,即 hover、pressed、dragged 属性要添加到哪个元素上,默认为 :host
* 如果需要修改该属性,则子类可以实现该属性
* 如果一个组件中包含多个 <mdui-ripple> 元素,则这里可以是一个数组;也可以是单个值,同时控制多个 <mdui-ripple> 元素
*/
get rippleTarget() {
return this;
}
firstUpdated(changedProperties) {
super.firstUpdated(changedProperties);
const $rippleTarget = $$1(this.rippleTarget);
const setRippleIndex = (event) => {
if (isArrayLike(this.rippleTarget)) {
this.rippleIndex = $rippleTarget.index(event.target);
}
};
const rippleTargetArr = isArrayLike(this.rippleTarget) ? this.rippleTarget : [this.rippleTarget];
rippleTargetArr.forEach((rippleTarget) => {
rippleTarget.addEventListener("pointerdown", (event) => {
setRippleIndex(event);
this.startPress(event);
});
rippleTarget.addEventListener("pointerenter", (event) => {
setRippleIndex(event);
this.startHover(event);
});
rippleTarget.addEventListener("pointerleave", (event) => {
setRippleIndex(event);
this.endHover(event);
});
rippleTarget.addEventListener("focus", (event) => {
setRippleIndex(event);
this.startFocus();
});
rippleTarget.addEventListener("blur", (event) => {
setRippleIndex(event);
this.endFocus();
});
});
}
/**
* 若存在多个 <mdui-ripple>,但 rippleTarget 为同一个,则 hover 状态无法在多个 <mdui-ripple> 之间切换
* 所以把 startHover 和 endHover 设置为 protected,供子类调用
* 子类中,在 getRippleIndex() 的返回值变更前调用 endHover(event),变更后调用 startHover(event)
*/
startHover(event) {
if (event.pointerType !== "mouse" || this.isRippleDisabled()) {
return;
}
this.getRippleTarget().setAttribute("hover", "");
this.getRippleElement().startHover();
}
endHover(event) {
if (event.pointerType !== "mouse" || this.isRippleDisabled()) {
return;
}
this.getRippleTarget().removeAttribute("hover");
this.getRippleElement().endHover();
}
/**
* 当前激活的 <mdui-ripple> 元素是否被禁用
*/
isRippleDisabled() {
const disabled = this.rippleDisabled;
if (!Array.isArray(disabled)) {
return disabled;
}
const rippleIndex = this.getRippleIndex();
if (rippleIndex !== void 0) {
return disabled[rippleIndex];
}
return disabled.length ? disabled[0] : false;
}
/**
* 获取当前激活的 <mdui-ripple> 元素实例
*/
getRippleElement() {
const ripple = this.rippleElement;
if (!isArrayLike(ripple)) {
return ripple;
}
const rippleIndex = this.getRippleIndex();
if (rippleIndex !== void 0) {
return ripple[rippleIndex];
}
return ripple[0];
}
/**
* 获取当前激活的 <mdui-ripple> 元素相对于哪个元素存在
*/
getRippleTarget() {
const target = this.rippleTarget;
if (!isArrayLike(target)) {
return target;
}
const rippleIndex = this.getRippleIndex();
if (rippleIndex !== void 0) {
return target[rippleIndex];
}
return target[0];
}
startFocus() {
if (this.isRippleDisabled()) {
return;
}
this.getRippleElement().startFocus();
}
endFocus() {
if (this.isRippleDisabled()) {
return;
}
this.getRippleElement().endFocus();
}
startPress(event) {
if (this.isRippleDisabled() || event.button) {
return;
}
const target = this.getRippleTarget();
target.setAttribute("pressed", "");
if (["touch", "pen"].includes(event.pointerType)) {
let hidden = false;
let timer = setTimeout(() => {
timer = 0;
this.getRippleElement().startPress(event);
}, 70);
const hideRipple = () => {
if (timer) {
clearTimeout(timer);
timer = 0;
this.getRippleElement().startPress(event);
}
if (!hidden) {
hidden = true;
this.endPress();
}
target.removeEventListener("pointerup", hideRipple);
target.removeEventListener("pointercancel", hideRipple);
};
const touchMove = () => {
if (timer) {
clearTimeout(timer);
timer = 0;
}
target.removeEventListener("touchmove", touchMove);
};
target.addEventListener("touchmove", touchMove);
target.addEventListener("pointerup", hideRipple);
target.addEventListener("pointercancel", hideRipple);
}
if (event.pointerType === "mouse" && event.button === 0) {
const hideRipple = () => {
this.endPress();
target.removeEventListener("pointerup", hideRipple);
target.removeEventListener("pointercancel", hideRipple);
target.removeEventListener("pointerleave", hideRipple);
};
this.getRippleElement().startPress(event);
target.addEventListener("pointerup", hideRipple);
target.addEventListener("pointercancel", hideRipple);
target.addEventListener("pointerleave", hideRipple);
}
}
endPress() {
if (this.isRippleDisabled()) {
return;
}
this.getRippleTarget().removeAttribute("pressed");
this.getRippleElement().endPress();
}
startDrag() {
if (this.isRippleDisabled()) {
return;
}
this.getRippleElement().startDrag();
}
endDrag() {
if (this.isRippleDisabled()) {
return;
}
this.getRippleElement().endDrag();
}
}
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter,
attribute: "no-ripple"
})
], Mixin.prototype, "noRipple", void 0);
return Mixin;
};
const buttonBaseStyle = i$7`.button{position:relative;display:inline-flex;align-items:center;justify-content:center;height:100%;padding:0;overflow:hidden;color:inherit;font-size:inherit;font-family:inherit;font-weight:inherit;letter-spacing:inherit;white-space:nowrap;text-align:center;text-decoration:none;vertical-align:middle;background:0 0;border:none;outline:0;cursor:inherit;-webkit-user-select:none;user-select:none;touch-action:manipulation;zoom:1;-webkit-user-drag:none}`;
class ButtonBase extends AnchorMixin(RippleMixin(FocusableMixin(MduiElement))) {
constructor() {
super(...arguments);
this.disabled = false;
this.loading = false;
this.name = "";
this.value = "";
this.type = "button";
this.formNoValidate = false;
this.formController = new FormController(this);
}
/**
* 表单验证状态对象,具体参见 [`ValidityState`](https://developer.mozilla.org/zh-CN/docs/Web/API/ValidityState)
*/
get validity() {
if (this.isButton()) {
return this.focusElement.validity;
}
}
/**
* 如果表单验证未通过,此属性将包含提示信息。如果验证通过,此属性将为空字符串
*/
get validationMessage() {
if (this.isButton()) {
return this.focusElement.validationMessage;
}
}
get rippleDisabled() {
return this.disabled || this.loading;
}
get focusElement() {
var _a2, _b;
return this.isButton() ? (_a2 = this.renderRoot) == null ? void 0 : _a2.querySelector("._button") : !this.focusDisabled ? (_b = this.renderRoot) == null ? void 0 : _b.querySelector("._a") : this;
}
get focusDisabled() {
return this.disabled || this.loading;
}
/**
* 检查表单字段是否通过验证。如果未通过,返回 `false` 并触发 `invalid` 事件;如果通过,返回 `true`
*/
checkValidity() {
if (this.isButton()) {
const valid = this.focusElement.checkValidity();
if (!valid) {
this.emit("invalid", {
bubbles: false,
cancelable: true,
composed: false
});
}
return valid;
}
return true;
}
/**
* 检查表单字段是否通过验证。如果未通过,返回 `false` 并触发 `invalid` 事件;如果通过,返回 `true`。
*
* 如果验证未通过,还会在组件上显示验证失败的提示。
*/
reportValidity() {
if (this.isButton()) {
const invalid = !this.focusElement.reportValidity();
if (invalid) {
this.emit("invalid", {
bubbles: false,
cancelable: true,
composed: false
});
}
return !invalid;
}
return true;
}
/**
* 设置自定义的错误提示文本。只要这个文本不为空,就表示字段未通过验证
*
* @param message 自定义的错误提示文本
*/
setCustomValidity(message) {
if (this.isButton()) {
this.focusElement.setCustomValidity(message);
}
}
firstUpdated(_changedProperties) {
super.firstUpdated(_changedProperties);
this.addEventListener("click", () => {
if (this.type === "submit") {
this.formController.submit(this);
}
if (this.type === "reset") {
this.formController.reset(this);
}
});
}
renderLoading() {
return this.loading ? x`<mdui-circular-progress part="loading"></mdui-circular-progress>` : nothingTemplate;
}
renderButton({ id: id2, className: className2, part, content = x`<slot></slot>` }) {
return x`<button id="${o$5(id2)}" class="${cc(["_button", className2])}" part="${o$5(part)}" ?disabled="${this.rippleDisabled || this.focusDisabled}">${content}</button>`;
}
isButton() {
return !this.href;
}
}
ButtonBase.styles = [
componentStyle,
buttonBaseStyle
];
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], ButtonBase.prototype, "disabled", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], ButtonBase.prototype, "loading", void 0);
__decorate([
n$6({ reflect: true })
], ButtonBase.prototype, "name", void 0);
__decorate([
n$6({ reflect: true })
], ButtonBase.prototype, "value", void 0);
__decorate([
n$6({ reflect: true })
], ButtonBase.prototype, "type", void 0);
__decorate([
n$6({ reflect: true })
], ButtonBase.prototype, "form", void 0);
__decorate([
n$6({ reflect: true, attribute: "formaction" })
], ButtonBase.prototype, "formAction", void 0);
__decorate([
n$6({ reflect: true, attribute: "formenctype" })
], ButtonBase.prototype, "formEnctype", void 0);
__decorate([
n$6({ reflect: true, attribute: "formmethod" })
], ButtonBase.prototype, "formMethod", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter,
attribute: "formnovalidate"
})
], ButtonBase.prototype, "formNoValidate", void 0);
__decorate([
n$6({ reflect: true, attribute: "formtarget" })
], ButtonBase.prototype, "formTarget", void 0);
const style$h = i$7`:host{--shape-corner:var(--mdui-shape-corner-full);position:relative;display:inline-block;flex-shrink:0;overflow:hidden;text-align:center;border-radius:var(--shape-corner);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:box-shadow var(--mdui-motion-duration-short4) var(--mdui-motion-easing-linear);min-width:3rem;height:2.5rem;color:rgb(var(--mdui-color-primary));font-size:var(--mdui-typescale-label-large-size);font-weight:var(--mdui-typescale-label-large-weight);letter-spacing:var(--mdui-typescale-label-large-tracking);line-height:var(--mdui-typescale-label-large-line-height)}.button{width:100%;padding:0 1rem}:host([full-width]:not([full-width=false i])){display:block}:host([variant=elevated]){box-shadow:var(--mdui-elevation-level1);background-color:rgb(var(--mdui-color-surface-container-low));--mdui-comp-ripple-state-layer-color:var(--mdui-color-primary)}:host([variant=filled]){color:rgb(var(--mdui-color-on-primary));background-color:rgb(var(--mdui-color-primary));--mdui-comp-ripple-state-layer-color:var(--mdui-color-on-primary)}:host([variant=tonal]){color:rgb(var(--mdui-color-on-secondary-container));background-color:rgb(var(--mdui-color-secondary-container));--mdui-comp-ripple-state-layer-color:var(
--mdui-color-on-secondary-container
)}:host([variant=outlined]){border:.0625rem solid rgb(var(--mdui-color-outline));--mdui-comp-ripple-state-layer-color:var(--mdui-color-primary)}:host([variant=text]){--mdui-comp-ripple-state-layer-color:var(--mdui-color-primary)}:host([variant=outlined][focus-visible]){border-color:rgb(var(--mdui-color-primary))}:host([variant=elevated][hover]){box-shadow:var(--mdui-elevation-level2)}:host([variant=filled][hover]),:host([variant=tonal][hover]){box-shadow:var(--mdui-elevation-level1)}:host([disabled]:not([disabled=false i])),:host([loading]:not([loading=false i])){cursor:default;pointer-events:none}:host([disabled]:not([disabled=false i])){color:rgba(var(--mdui-color-on-surface),38%);box-shadow:var(--mdui-elevation-level0)}:host([variant=elevated][disabled]:not([disabled=false i])),:host([variant=filled][disabled]:not([disabled=false i])),:host([variant=tonal][disabled]:not([disabled=false i])){background-color:rgba(var(--mdui-color-on-surface),12%)}:host([variant=outlined][disabled]:not([disabled=false i])){border-color:rgba(var(--mdui-color-on-surface),12%)}.label{display:inline-flex;padding-right:.5rem;padding-left:.5rem}.end-icon,.icon{display:inline-flex;font-size:1.28571429em}.end-icon mdui-icon,.icon mdui-icon,::slotted([slot=end-icon]),::slotted([slot=icon]){font-size:inherit}mdui-circular-progress{display:inline-flex;width:1.125rem;height:1.125rem}:host([variant=filled]) mdui-circular-progress{stroke:rgb(var(--mdui-color-on-primary))}:host([variant=tonal]) mdui-circular-progress{stroke:rgb(var(--mdui-color-on-secondary-container))}:host([disabled]:not([disabled=false i])) mdui-circular-progress{stroke:rgba(var(--mdui-color-on-surface),38%)}`;
let Button = class Button2 extends ButtonBase {
constructor() {
super(...arguments);
this.variant = "filled";
this.fullWidth = false;
this.rippleRef = e$2();
}
get rippleElement() {
return this.rippleRef.value;
}
render() {
return x`<mdui-ripple ${n$2(this.rippleRef)} .noRipple="${this.noRipple}"></mdui-ripple>${this.isButton() ? this.renderButton({
className: "button",
part: "button",
content: this.renderInner()
}) : this.disabled || this.loading ? x`<span part="button" class="button _a">${this.renderInner()}</span>` : this.renderAnchor({
className: "button",
part: "button",
content: this.renderInner()
})}`;
}
renderIcon() {
if (this.loading) {
return this.renderLoading();
}
return x`<slot name="icon" part="icon" class="icon">${this.icon ? x`<mdui-icon name="${this.icon}"></mdui-icon>` : nothingTemplate}</slot>`;
}
renderLabel() {
return x`<slot part="label" class="label"></slot>`;
}
renderEndIcon() {
return x`<slot name="end-icon" part="end-icon" class="end-icon">${this.endIcon ? x`<mdui-icon name="${this.endIcon}"></mdui-icon>` : nothingTemplate}</slot>`;
}
renderInner() {
return [this.renderIcon(), this.renderLabel(), this.renderEndIcon()];
}
};
Button.styles = [ButtonBase.styles, style$h];
__decorate([
n$6({ reflect: true })
], Button.prototype, "variant", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter,
attribute: "full-width"
})
], Button.prototype, "fullWidth", void 0);
__decorate([
n$6({ reflect: true })
], Button.prototype, "icon", void 0);
__decorate([
n$6({ reflect: true, attribute: "end-icon" })
], Button.prototype, "endIcon", void 0);
Button = __decorate([
t$3("mdui-button")
], Button);
const style$g = i$7`:host{--shape-corner:var(--mdui-shape-corner-full);position:relative;display:inline-block;flex-shrink:0;overflow:hidden;text-align:center;border-radius:var(--shape-corner);cursor:pointer;-webkit-tap-highlight-color:transparent;font-size:1.5rem;width:2.5rem;height:2.5rem}:host([variant=standard]){color:rgb(var(--mdui-color-on-surface-variant));--mdui-comp-ripple-state-layer-color:var(--mdui-color-on-surface-variant)}:host([variant=filled]){color:rgb(var(--mdui-color-primary));background-color:rgb(var(--mdui-color-surface-container-highest));--mdui-comp-ripple-state-layer-color:var(--mdui-color-primary)}:host([variant=tonal]){color:rgb(var(--mdui-color-on-surface-variant));background-color:rgb(var(--mdui-color-surface-container-highest));--mdui-comp-ripple-state-layer-color:var(--mdui-color-on-surface-variant)}:host([variant=outlined]){border:.0625rem solid rgb(var(--mdui-color-outline));color:rgb(var(--mdui-color-on-surface-variant));--mdui-comp-ripple-state-layer-color:var(--mdui-color-on-surface-variant)}:host([variant=outlined][pressed]){color:rgb(var(--mdui-color-on-surface));--mdui-comp-ripple-state-layer-color:var(--mdui-color-on-surface)}:host([variant=standard][selected]:not([selected=false i])){color:rgb(var(--mdui-color-primary));--mdui-comp-ripple-state-layer-color:var(--mdui-color-primary)}:host([variant=filled]:not([selectable])),:host([variant=filled][selectable=false i]),:host([variant=filled][selected]:not([selected=false i])){color:rgb(var(--mdui-color-on-primary));background-color:rgb(var(--mdui-color-primary));--mdui-comp-ripple-state-layer-color:var(--mdui-color-on-primary)}:host([variant=tonal]:not([selectable])),:host([variant=tonal][selectable=false i]),:host([variant=tonal][selected]:not([selected=false i])){color:rgb(var(--mdui-color-on-secondary-container));background-color:rgb(var(--mdui-color-secondary-container));--mdui-comp-ripple-state-layer-color:var(
--mdui-color-on-secondary-container
)}:host([variant=outlined][selected]:not([selected=false i])){border:none;color:rgb(var(--mdui-color-inverse-on-surface));background-color:rgb(var(--mdui-color-inverse-surface));--mdui-comp-ripple-state-layer-color:var(--mdui-color-inverse-on-surface)}:host([variant=filled][disabled]:not([disabled=false i])),:host([variant=outlined][disabled]:not([disabled=false i])),:host([variant=tonal][disabled]:not([disabled=false i])){background-color:rgba(var(--mdui-color-on-surface),.12);border-color:rgba(var(--mdui-color-on-surface),.12)}:host([disabled]:not([disabled=false i])),:host([loading]:not([loading=false i])){cursor:default;pointer-events:none}:host([disabled]:not([disabled=false i])){color:rgba(var(--mdui-color-on-surface),.38)!important}:host([loading]:not([loading=false i])) .button,:host([loading]:not([loading=false i])) mdui-ripple{opacity:0}.button{float:left;width:100%}.icon,.selected-icon mdui-icon,::slotted(*){font-size:inherit}mdui-circular-progress{display:flex;position:absolute;top:calc(50% - 1.5rem / 2);left:calc(50% - 1.5rem / 2);width:1.5rem;height:1.5rem}:host([variant=filled]:not([disabled])) mdui-circular-progress,:host([variant=filled][disabled=false i]) mdui-circular-progress{stroke:rgb(var(--mdui-color-on-primary))}:host([disabled]:not([disabled=false i])) mdui-circular-progress{stroke:rgba(var(--mdui-color-on-surface),38%)}`;
let ButtonIcon = class ButtonIcon2 extends ButtonBase {
constructor() {
super(...arguments);
this.variant = "standard";
this.selectable = false;
this.selected = false;
this.rippleRef = e$2();
this.hasSlotController = new HasSlotController(this, "[default]", "selected-icon");
}
get rippleElement() {
return this.rippleRef.value;
}
onSelectedChange() {
this.emit("change");
}
firstUpdated(changedProperties) {
super.firstUpdated(changedProperties);
this.addEventListener("click", () => {
if (!this.selectable || this.disabled) {
return;
}
this.selected = !this.selected;
});
}
render() {
return x`<mdui-ripple ${n$2(this.rippleRef)} .noRipple="${this.noRipple}"></mdui-ripple>${this.isButton() ? this.renderButton({
className: "button",
part: "button",
content: this.renderIcon()
}) : this.disabled || this.loading ? x`<span part="button" class="button _a">${this.renderIcon()}</span>` : this.renderAnchor({
className: "button",
part: "button",
content: this.renderIcon()
})} ${this.renderLoading()}`;
}
renderIcon() {
const icon = () => this.hasSlotController.test("[default]") ? x`<slot></slot>` : this.icon ? x`<mdui-icon part="icon" class="icon" name="${this.icon}"></mdui-icon>` : nothingTemplate;
const selectedIcon = () => this.hasSlotController.test("selected-icon") || this.selectedIcon ? x`<slot name="selected-icon" part="selected-icon" class="selected-icon"><mdui-icon name="${this.selectedIcon}"></mdui-icon></slot>` : icon();
return this.selected ? selectedIcon() : icon();
}
};
ButtonIcon.styles = [ButtonBase.styles, style$g];
__decorate([
n$6({ reflect: true })
], ButtonIcon.prototype, "variant", void 0);
__decorate([
n$6({ reflect: true })
], ButtonIcon.prototype, "icon", void 0);
__decorate([
n$6({ reflect: true, attribute: "selected-icon" })
], ButtonIcon.prototype, "selectedIcon", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], ButtonIcon.prototype, "selectable", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], ButtonIcon.prototype, "selected", void 0);
__decorate([
watch("selected", true)
], ButtonIcon.prototype, "onSelectedChange", null);
ButtonIcon = __decorate([
t$3("mdui-button-icon")
], ButtonIcon);
const style$f = i$7`:host{--shape-corner:var(--mdui-shape-corner-medium);position:relative;display:inline-block;overflow:hidden;border-radius:var(--shape-corner);-webkit-tap-highlight-color:transparent;transition:box-shadow var(--mdui-motion-duration-short4) var(--mdui-motion-easing-linear);--mdui-comp-ripple-state-layer-color:var(--mdui-color-on-surface)}:host([clickable]:not([clickable=false i])){cursor:pointer}:host([variant=elevated]){background-color:rgb(var(--mdui-color-surface-container-low));box-shadow:var(--mdui-elevation-level1)}:host([variant=filled]){background-color:rgb(var(--mdui-color-surface-container-highest))}:host([variant=outlined]){background-color:rgb(var(--mdui-color-surface));border:.0625rem solid rgb(var(--mdui-color-outline))}:host([variant=elevated][hover]){box-shadow:var(--mdui-elevation-level2)}:host([variant=filled][hover]),:host([variant=outlined][hover]){box-shadow:var(--mdui-elevation-level1)}:host([variant=elevated][dragged]),:host([variant=filled][dragged]),:host([variant=outlined][dragged]){box-shadow:var(--mdui-elevation-level3)}:host([disabled]:not([disabled=false i])){opacity:.38;cursor:default;-webkit-user-select:none;user-select:none}:host([variant=elevated][disabled]:not([disabled=false i])){background-color:rgb(var(--mdui-color-surface-variant));box-shadow:var(--mdui-elevation-level0)}:host([variant=filled][disabled]:not([disabled=false i])){background-color:rgb(var(--mdui-color-surface));box-shadow:var(--mdui-elevation-level1)}:host([variant=outlined][disabled]:not([disabled=false i])){box-shadow:var(--mdui-elevation-level0);border-color:rgba(var(--mdui-color-outline),.32)}.link{position:relative;display:inline-block;width:100%;height:100%;color:inherit;font-size:inherit;letter-spacing:inherit;text-decoration:none;touch-action:manipulation;-webkit-user-drag:none}`;
let Card = class Card2 extends AnchorMixin(RippleMixin(FocusableMixin(MduiElement))) {
constructor() {
super(...arguments);
this.variant = "elevated";
this.clickable = false;
this.disabled = false;
this.rippleRef = e$2();
}
get rippleElement() {
return this.rippleRef.value;
}
get rippleDisabled() {
return this.disabled || !this.href && !this.clickable;
}
get focusElement() {
return this.href && !this.disabled ? this.renderRoot.querySelector("._a") : this;
}
get focusDisabled() {
return this.rippleDisabled;
}
render() {
return x`<mdui-ripple ${n$2(this.rippleRef)} .noRipple="${this.noRipple}"></mdui-ripple>${this.href && !this.disabled ? this.renderAnchor({
className: "link",
content: x`<slot></slot>`
}) : x`<slot></slot>`}`;
}
};
Card.styles = [componentStyle, style$f];
__decorate([
n$6({ reflect: true })
], Card.prototype, "variant", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Card.prototype, "clickable", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Card.prototype, "disabled", void 0);
Card = __decorate([
t$3("mdui-card")
], Card);
/**
* @license
* Copyright 2020 Google LLC
* SPDX-License-Identifier: BSD-3-Clause
*/
const l$1 = e$4(class extends i$3 {
constructor(r3) {
if (super(r3), r3.type !== t$2.PROPERTY && r3.type !== t$2.ATTRIBUTE && r3.type !== t$2.BOOLEAN_ATTRIBUTE) throw Error("The `live` directive is not allowed on child or event bindings");
if (!f$2(r3)) throw Error("`live` bindings can only contain a single expression");
}
render(r3) {
return r3;
}
update(i3, [t3]) {
if (t3 === T || t3 === E) return t3;
const o2 = i3.element, l2 = i3.name;
if (i3.type === t$2.PROPERTY) {
if (t3 === o2[l2]) return T;
} else if (i3.type === t$2.BOOLEAN_ATTRIBUTE) {
if (!!t3 === o2.hasAttribute(l2)) return T;
} else if (i3.type === t$2.ATTRIBUTE && o2.getAttribute(l2) === t3 + "") return T;
return m$2(i3), t3;
}
});
function defaultValue(propertyName = "value") {
return (proto, key2) => {
const constructor = proto.constructor;
const attributeChangedCallback = constructor.prototype.attributeChangedCallback;
constructor.prototype.attributeChangedCallback = function(name, old, value) {
const options = constructor.getPropertyOptions(propertyName);
const attributeName = isString(options.attribute) ? options.attribute : propertyName;
if (name === attributeName) {
const converter = options.converter || u$3;
const fromAttribute = isFunction(converter) ? converter : (converter == null ? void 0 : converter.fromAttribute) ?? u$3.fromAttribute;
const newValue = fromAttribute(value, options.type);
if (this[propertyName] !== newValue) {
this[key2] = newValue;
}
}
attributeChangedCallback.call(this, name, old, value);
};
};
}
const style$e = i$7`:host{display:inline-block;width:1em;height:1em;line-height:1;font-size:1.5rem}`;
const svgTag = (svgPaths) => x`<svg xmlns="http://www.w3.org/2000/svg" width="100%" height="100%" viewBox="0 0 24 24" fill="currentColor">${o$3(svgPaths)}</svg>`;
let IconCheckBoxOutlineBlank = class IconCheckBoxOutlineBlank2 extends r$3 {
render() {
return svgTag('<path d="M19 5v14H5V5h14m0-2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2z"/>');
}
};
IconCheckBoxOutlineBlank.styles = style$e;
IconCheckBoxOutlineBlank = __decorate([
t$3("mdui-icon-check-box-outline-blank")
], IconCheckBoxOutlineBlank);
let IconCheckBox = class IconCheckBox2 extends r$3 {
render() {
return svgTag('<path d="M19 3H5a2 2 0 0 0-2 2v14a2 2 0 0 0 2 2h14a2 2 0 0 0 2-2V5a2 2 0 0 0-2-2zm-9 14-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8l-9 9z"/>');
}
};
IconCheckBox.styles = style$e;
IconCheckBox = __decorate([
t$3("mdui-icon-check-box")
], IconCheckBox);
let IconIndeterminateCheckBox = class IconIndeterminateCheckBox2 extends r$3 {
render() {
return svgTag('<path d="M19 3H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2V5c0-1.1-.9-2-2-2zm-2 10H7v-2h10v2z"/>');
}
};
IconIndeterminateCheckBox.styles = style$e;
IconIndeterminateCheckBox = __decorate([
t$3("mdui-icon-indeterminate-check-box")
], IconIndeterminateCheckBox);
const style$d = i$7`:host{position:relative;display:inline-flex;cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:.125rem;font-size:var(--mdui-typescale-label-large-size);font-weight:var(--mdui-typescale-label-large-weight);letter-spacing:var(--mdui-typescale-label-large-tracking);line-height:var(--mdui-typescale-label-large-line-height)}label{display:inline-flex;align-items:center;width:100%;cursor:inherit;-webkit-user-select:none;user-select:none;touch-action:manipulation;zoom:1;-webkit-user-drag:none}input{position:absolute;padding:0;opacity:0;pointer-events:none;width:1.125rem;height:1.125rem;margin:0 0 0 .6875rem}.icon{display:flex;position:absolute;opacity:1;transform:scale(1);color:rgb(var(--mdui-color-on-surface));font-size:1.5rem;transition:color var(--mdui-motion-duration-short4) var(--mdui-motion-easing-standard)}.checked-icon,.indeterminate-icon{opacity:0;transform:scale(.5);transition-property:color,opacity,transform;transition-duration:var(--mdui-motion-duration-short4);transition-timing-function:var(--mdui-motion-easing-standard)}.icon .i,::slotted([slot=checked-icon]),::slotted([slot=indeterminate-icon]),::slotted([slot=unchecked-icon]){color:inherit;font-size:inherit}i{position:relative;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;border-radius:50%;width:2.5rem;height:2.5rem;--mdui-comp-ripple-state-layer-color:var(--mdui-color-on-surface)}.label{display:flex;width:100%;padding-top:.625rem;padding-bottom:.625rem;color:rgb(var(--mdui-color-on-surface));transition:color var(--mdui-motion-duration-short4) var(--mdui-motion-easing-standard)}:host([checked]:not([checked=false i])) i{--mdui-comp-ripple-state-layer-color:var(--mdui-color-primary)}:host([checked]:not([checked=false i])) .icon{color:rgb(var(--mdui-color-primary))}:host([checked]:not([checked=false i])) .indeterminate-icon{opacity:0;transform:scale(.5)}:host([checked]:not([checked=false i])) .checked-icon{opacity:1;transform:scale(1)}:host([indeterminate]:not([indeterminate=false i])) i{--mdui-comp-ripple-state-layer-color:var(--mdui-color-primary)}:host([indeterminate]:not([indeterminate=false i])) .icon{color:rgb(var(--mdui-color-primary))}:host([indeterminate]:not([indeterminate=false i])) .checked-icon{opacity:0;transform:scale(.5)}:host([indeterminate]:not([indeterminate=false i])) .indeterminate-icon{opacity:1;transform:scale(1)}.invalid i{--mdui-comp-ripple-state-layer-color:var(--mdui-color-error)}.invalid .icon{color:rgb(var(--mdui-color-error))}.invalid .label{color:rgb(var(--mdui-color-error))}:host([disabled]:not([disabled=false i])){cursor:default;pointer-events:none}:host([disabled]:not([disabled=false i])) .icon{color:rgba(var(--mdui-color-on-surface),38%)}:host([disabled]:not([disabled=false i])) .label{color:rgba(var(--mdui-color-on-surface),38%)}:host([disabled][checked]:not([disabled=false i],[checked=false i])) .unchecked-icon,:host([disabled][indeterminate]:not([disabled=false i],[indeterminate=false i])) .unchecked-icon{opacity:0}`;
let Checkbox = class Checkbox2 extends RippleMixin(FocusableMixin(MduiElement)) {
constructor() {
super(...arguments);
this.disabled = false;
this.checked = false;
this.defaultChecked = false;
this.indeterminate = false;
this.required = false;
this.name = "";
this.value = "on";
this.invalid = false;
this.inputRef = e$2();
this.rippleRef = e$2();
this.formController = new FormController(this, {
value: (control) => control.checked ? control.value : void 0,
defaultValue: (control) => control.defaultChecked,
setValue: (control, checked) => control.checked = checked
});
}
/**
* 表单验证状态对象,具体参见 [`ValidityState`](https://developer.mozilla.org/zh-CN/docs/Web/API/ValidityState)
*/
get validity() {
return this.inputRef.value.validity;
}
/**
* 如果表单验证未通过,此属性将包含提示信息。如果验证通过,此属性将为空字符串
*/
get validationMessage() {
return this.inputRef.value.validationMessage;
}
get rippleElement() {
return this.rippleRef.value;
}
get rippleDisabled() {
return this.disabled;
}
get focusElement() {
return this.inputRef.value;
}
get focusDisabled() {
return this.disabled;
}
async onDisabledChange() {
await this.updateComplete;
this.invalid = !this.inputRef.value.checkValidity();
}
async onCheckedChange() {
var _a2;
await this.updateComplete;
const form = this.formController.getForm();
if (form && ((_a2 = formResets.get(form)) == null ? void 0 : _a2.has(this))) {
this.invalid = false;
formResets.get(form).delete(this);
} else {
this.invalid = !this.inputRef.value.checkValidity();
}
}
/**
* 检查表单字段是否通过验证。如果未通过,返回 `false` 并触发 `invalid` 事件;如果通过,返回 `true`
*/
checkValidity() {
const valid = this.inputRef.value.checkValidity();
if (!valid) {
this.emit("invalid", {
bubbles: false,
cancelable: true,
composed: false
});
}
return valid;
}
/**
* 检查表单字段是否通过验证。如果未通过,返回 `false` 并触发 `invalid` 事件;如果通过,返回 `true`。
*
* 如果验证未通过,还会在组件上显示验证失败的提示。
*/
reportValidity() {
this.invalid = !this.inputRef.value.reportValidity();
if (this.invalid) {
const eventProceeded = this.emit("invalid", {
bubbles: false,
cancelable: true,
composed: false
});
if (!eventProceeded) {
this.blur();
this.focus();
}
}
return !this.invalid;
}
/**
* 设置自定义的错误提示文本。只要这个文本不为空,就表示字段未通过验证
*
* @param message 自定义的错误提示文本
*/
setCustomValidity(message) {
this.inputRef.value.setCustomValidity(message);
this.invalid = !this.inputRef.value.checkValidity();
}
render() {
return x`<label class="${e$1({ invalid: this.invalid })}"><input ${n$2(this.inputRef)} type="checkbox" name="${o$5(this.name)}" value="${o$5(this.value)}" .indeterminate="${l$1(this.indeterminate)}" .disabled="${this.disabled}" .checked="${l$1(this.checked)}" .required="${this.required}" @change="${this.onChange}"> <i part="control"><mdui-ripple ${n$2(this.rippleRef)} .noRipple="${this.noRipple}"></mdui-ripple><slot name="unchecked-icon" part="unchecked-icon" class="icon unchecked-icon">${this.uncheckedIcon ? x`<mdui-icon name="${this.uncheckedIcon}" class="i"></mdui-icon>` : x`<mdui-icon-check-box-outline-blank class="i"></mdui-icon-check-box-outline-blank>`}</slot><slot name="checked-icon" part="checked-icon" class="icon checked-icon">${this.checkedIcon ? x`<mdui-icon name="${this.checkedIcon}" class="i"></mdui-icon>` : x`<mdui-icon-check-box class="i"></mdui-icon-check-box>`}</slot><slot name="indeterminate-icon" part="indeterminate-icon" class="icon indeterminate-icon">${this.indeterminateIcon ? x`<mdui-icon name="${this.indeterminateIcon}" class="i"></mdui-icon>` : x`<mdui-icon-indeterminate-check-box class="i"></mdui-icon-indeterminate-check-box>`}</slot></i><slot part="label" class="label"></slot></label>`;
}
/**
* input[type="checkbox"] 的 change 事件无法冒泡越过 shadow dom
*/
onChange() {
this.checked = this.inputRef.value.checked;
this.indeterminate = false;
this.emit("change");
}
};
Checkbox.styles = [componentStyle, style$d];
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Checkbox.prototype, "disabled", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Checkbox.prototype, "checked", void 0);
__decorate([
defaultValue("checked")
], Checkbox.prototype, "defaultChecked", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Checkbox.prototype, "indeterminate", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Checkbox.prototype, "required", void 0);
__decorate([
n$6({ reflect: true })
], Checkbox.prototype, "form", void 0);
__decorate([
n$6({ reflect: true })
], Checkbox.prototype, "name", void 0);
__decorate([
n$6({ reflect: true })
], Checkbox.prototype, "value", void 0);
__decorate([
n$6({ reflect: true, attribute: "unchecked-icon" })
], Checkbox.prototype, "uncheckedIcon", void 0);
__decorate([
n$6({ reflect: true, attribute: "checked-icon" })
], Checkbox.prototype, "checkedIcon", void 0);
__decorate([
n$6({ reflect: true, attribute: "indeterminate-icon" })
], Checkbox.prototype, "indeterminateIcon", void 0);
__decorate([
r$1()
], Checkbox.prototype, "invalid", void 0);
__decorate([
watch("disabled", true),
watch("indeterminate", true),
watch("required", true)
], Checkbox.prototype, "onDisabledChange", null);
__decorate([
watch("checked", true)
], Checkbox.prototype, "onCheckedChange", null);
Checkbox = __decorate([
t$3("mdui-checkbox")
], Checkbox);
let IconCheck = class IconCheck2 extends r$3 {
render() {
return svgTag('<path d="M9 16.17 4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z"/>');
}
};
IconCheck.styles = style$e;
IconCheck = __decorate([
t$3("mdui-icon-check")
], IconCheck);
let IconClear = class IconClear2 extends r$3 {
render() {
return svgTag('<path d="M19 6.41 17.59 5 12 10.59 6.41 5 5 6.41 10.59 12 5 17.59 6.41 19 12 13.41 17.59 19 19 17.59 13.41 12z"/>');
}
};
IconClear.styles = style$e;
IconClear = __decorate([
t$3("mdui-icon-clear")
], IconClear);
const style$c = i$7`:host{--shape-corner:var(--mdui-shape-corner-small);position:relative;display:inline-block;flex-shrink:0;overflow:hidden;border-radius:var(--shape-corner);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:box-shadow var(--mdui-motion-duration-short4) var(--mdui-motion-easing-linear);height:2rem;background-color:rgb(var(--mdui-color-surface));border:.0625rem solid rgb(var(--mdui-color-outline));color:rgb(var(--mdui-color-on-surface-variant));font-size:var(--mdui-typescale-label-large-size);font-weight:var(--mdui-typescale-label-large-weight);letter-spacing:var(--mdui-typescale-label-large-tracking);line-height:var(--mdui-typescale-label-large-line-height);--mdui-comp-ripple-state-layer-color:var(--mdui-color-on-surface-variant)}.button{padding-right:.4375rem;padding-left:.4375rem}:host([variant=input]) .button{padding-right:.1875rem;padding-left:.1875rem}:host([selected]:not([selected=false i])) .button{padding-right:.5rem;padding-left:.5rem}:host([selected][variant=input]:not([selected=false i])) .button{padding-right:.25rem;padding-left:.25rem}:host([elevated]:not([elevated=false i])) .button{padding-right:.5rem;padding-left:.5rem}:host([variant=assist]){color:rgb(var(--mdui-color-on-surface));--mdui-comp-ripple-state-layer-color:var(--mdui-color-on-surface)}:host([elevated]:not([elevated=false i])){border-width:0;background-color:rgb(var(--mdui-color-surface-container-low));box-shadow:var(--mdui-elevation-level1)}:host([selected]:not([selected=false i])){color:rgb(var(--mdui-color-on-secondary-container));background-color:rgb(var(--mdui-color-secondary-container));border-width:0;--mdui-comp-ripple-state-layer-color:var(
--mdui-color-on-secondary-container
)}:host([disabled]:not([disabled=false i])),:host([loading]:not([loading=false i])){cursor:default;pointer-events:none}:host([disabled]:not([disabled=false i])){border-color:rgba(var(--mdui-color-on-surface),12%);color:rgba(var(--mdui-color-on-surface),38%);box-shadow:var(--mdui-elevation-level0)}:host([disabled][elevated]:not([disabled=false i],[elevated=false i])),:host([disabled][selected]:not([disabled=false i],[selected=false i])){background-color:rgba(var(--mdui-color-on-surface),12%)}:host([selected][hover]:not([selected=false i])){box-shadow:var(--mdui-elevation-level1)}:host([elevated][hover]:not([elevated=false i])){color:rgb(var(--mdui-color-on-secondary-container));box-shadow:var(--mdui-elevation-level2)}:host([variant=filter][hover]),:host([variant=input][hover]),:host([variant=suggestion][hover]){color:rgb(var(--mdui-color-on-surface-variant))}:host([variant=filter][focus-visible]),:host([variant=input][focus-visible]),:host([variant=suggestion][focus-visible]){border-color:rgb(var(--mdui-color-on-surface-variant))}:host([dragged]),:host([dragged][hover]){box-shadow:var(--mdui-elevation-level4)}.button{overflow:visible}.label{display:inline-flex;padding-right:.5rem;padding-left:.5rem}.end-icon,.icon,.selected-icon{display:inline-flex;font-size:1.28571429em;color:rgb(var(--mdui-color-on-surface-variant))}:host([variant=assist]) .end-icon,:host([variant=assist]) .icon,:host([variant=assist]) .selected-icon{color:rgb(var(--mdui-color-primary))}:host([selected]:not([selected=false i])) .end-icon,:host([selected]:not([selected=false i])) .icon,:host([selected]:not([selected=false i])) .selected-icon{color:rgb(var(--mdui-color-on-secondary-container))}:host([disabled]:not([disabled=false i])) .end-icon,:host([disabled]:not([disabled=false i])) .icon,:host([disabled]:not([disabled=false i])) .selected-icon{opacity:.38;color:rgb(var(--mdui-color-on-surface))}.end-icon .i,.icon .i,.selected-icon .i,::slotted([slot=end-icon]),::slotted([slot=icon]),::slotted([slot=selected-icon]){font-size:inherit}:host([variant=input]) .has-icon .icon,:host([variant=input]) .has-icon .selected-icon,:host([variant=input]) .has-icon mdui-circular-progress{margin-left:.25rem}:host([variant=input]) .has-end-icon .end-icon{margin-right:.25rem}mdui-circular-progress{display:inline-flex;width:1.125rem;height:1.125rem}:host([disabled]:not([disabled=false i])) mdui-circular-progress{stroke:rgba(var(--mdui-color-on-surface),38%)}::slotted(mdui-avatar[slot=end-icon]),::slotted(mdui-avatar[slot=icon]),::slotted(mdui-avatar[slot=selected-icon]){width:1.5rem;height:1.5rem}:host([disabled]:not([disabled=false i])) ::slotted(mdui-avatar[slot=end-icon]),:host([disabled]:not([disabled=false i])) ::slotted(mdui-avatar[slot=icon]),:host([disabled]:not([disabled=false i])) ::slotted(mdui-avatar[slot=selected-icon]){opacity:.38}::slotted(mdui-avatar[slot=icon]),::slotted(mdui-avatar[slot=selected-icon]){margin-left:-.25rem;margin-right:-.125rem}::slotted(mdui-avatar[slot=end-icon]){margin-right:-.25rem;margin-left:-.125rem}.delete-icon{display:inline-flex;font-size:1.28571429em;transition:background-color var(--mdui-motion-duration-short4) var(--mdui-motion-easing-linear);border-radius:var(--mdui-shape-corner-full);margin-right:-.25rem;margin-left:-.25rem;padding:.25rem;color:rgb(var(--mdui-color-on-surface-variant))}.delete-icon:hover{background-color:rgba(var(--mdui-color-on-surface-variant),12%)}.has-end-icon .delete-icon{margin-left:.25rem}:host([variant=assiat]) .delete-icon{color:rgb(var(--mdui-color-primary))}:host([variant=input]) .delete-icon{margin-right:.0625rem}:host([disabled]:not([disabled=false i])) .delete-icon{color:rgba(var(--mdui-color-on-surface),38%)}.delete-icon .i,::slotted([slot=delete-icon]){font-size:inherit}::slotted(mdui-avatar[slot=delete-icon]){width:1.125rem;height:1.125rem}`;
let Chip = class Chip2 extends ButtonBase {
constructor() {
super();
this.variant = "assist";
this.elevated = false;
this.selectable = false;
this.selected = false;
this.deletable = false;
this.rippleRef = e$2();
this.hasSlotController = new HasSlotController(this, "icon", "selected-icon", "end-icon");
this.onClick = this.onClick.bind(this);
this.onKeyDown = this.onKeyDown.bind(this);
}
get rippleElement() {
return this.rippleRef.value;
}
onSelectedChange() {
this.emit("change");
}
firstUpdated(changedProperties) {
super.firstUpdated(changedProperties);
this.addEventListener("click", this.onClick);
this.addEventListener("keydown", this.onKeyDown);
}
render() {
const hasIcon = this.icon || this.hasSlotController.test("icon");
const hasEndIcon = this.endIcon || this.hasSlotController.test("end-icon");
const hasSelectedIcon = this.selectedIcon || ["assist", "filter"].includes(this.variant) || hasIcon || this.hasSlotController.test("selected-icon");
const className2 = cc({
button: true,
"has-icon": this.loading || !this.selected && hasIcon || this.selected && hasSelectedIcon,
"has-end-icon": hasEndIcon
});
return x`<mdui-ripple ${n$2(this.rippleRef)} .noRipple="${this.noRipple}"></mdui-ripple>${this.isButton() ? this.renderButton({
className: className2,
part: "button",
content: this.renderInner()
}) : this.disabled || this.loading ? x`<span part="button" class="${className2} _a">${this.renderInner()}</span>` : this.renderAnchor({
className: className2,
part: "button",
content: this.renderInner()
})}`;
}
onClick() {
if (this.disabled || this.loading) {
return;
}
if (this.selectable) {
this.selected = !this.selected;
}
}
onKeyDown(event) {
if (this.disabled || this.loading) {
return;
}
if (this.selectable && event.key === " ") {
event.preventDefault();
this.selected = !this.selected;
}
if (this.deletable && ["Delete", "Backspace"].includes(event.key)) {
this.emit("delete");
}
}
/**
* 点击删除按钮
*/
onDelete(event) {
event.stopPropagation();
this.emit("delete");
}
renderIcon() {
if (this.loading) {
return this.renderLoading();
}
const icon = () => {
return this.icon ? x`<mdui-icon name="${this.icon}" class="i"></mdui-icon>` : nothingTemplate;
};
const selectedIcon = () => {
if (this.selectedIcon) {
return x`<mdui-icon name="${this.selectedIcon}" class="i"></mdui-icon>`;
}
if (this.variant === "assist" || this.variant === "filter") {
return x`<mdui-icon-check class="i"></mdui-icon-check>`;
}
return icon();
};
return !this.selected ? x`<slot name="icon" part="icon" class="icon">${icon()}</slot>` : x`<slot name="selected-icon" part="selected-icon" class="selected-icon">${selectedIcon()}</slot>`;
}
renderLabel() {
return x`<slot part="label" class="label"></slot>`;
}
renderEndIcon() {
return x`<slot name="end-icon" part="end-icon" class="end-icon">${this.endIcon ? x`<mdui-icon name="${this.endIcon}" class="i"></mdui-icon>` : nothingTemplate}</slot>`;
}
renderDeleteIcon() {
if (!this.deletable) {
return nothingTemplate;
}
return x`<slot name="delete-icon" part="delete-icon" class="delete-icon" @click="${this.onDelete}">${this.deleteIcon ? x`<mdui-icon name="${this.deleteIcon}" class="i"></mdui-icon>` : x`<mdui-icon-clear class="i"></mdui-icon-clear>`}</slot>`;
}
renderInner() {
return [
this.renderIcon(),
this.renderLabel(),
this.renderEndIcon(),
this.renderDeleteIcon()
];
}
};
Chip.styles = [ButtonBase.styles, style$c];
__decorate([
n$6({ reflect: true })
], Chip.prototype, "variant", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Chip.prototype, "elevated", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Chip.prototype, "selectable", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Chip.prototype, "selected", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Chip.prototype, "deletable", void 0);
__decorate([
n$6({ reflect: true })
], Chip.prototype, "icon", void 0);
__decorate([
n$6({ reflect: true, attribute: "selected-icon" })
], Chip.prototype, "selectedIcon", void 0);
__decorate([
n$6({ reflect: true, attribute: "end-icon" })
], Chip.prototype, "endIcon", void 0);
__decorate([
n$6({ reflect: true, attribute: "delete-icon" })
], Chip.prototype, "deleteIcon", void 0);
__decorate([
watch("selected", true)
], Chip.prototype, "onSelectedChange", null);
Chip = __decorate([
t$3("mdui-chip")
], Chip);
const arraysEqualIgnoreOrder = (a2, b3) => {
if (a2.length !== b3.length) {
return false;
}
const sortedA = [...a2].sort();
const sortedB = [...b3].sort();
return sortedA.every((value, index) => value === sortedB[index]);
};
const collapseStyle = i$7`:host{display:block}`;
let Collapse = class Collapse2 extends MduiElement {
constructor() {
super(...arguments);
this.accordion = false;
this.disabled = false;
this.activeKeys = [];
this.isInitial = true;
this.definedController = new DefinedController(this, {
relatedElements: ["mdui-collapse-item"]
});
}
async onActiveKeysChange() {
var _a2;
await this.definedController.whenDefined();
const value = this.accordion ? (_a2 = this.items.find((item) => this.activeKeys.includes(item.key))) == null ? void 0 : _a2.value : this.items.filter((item) => this.activeKeys.includes(item.key)).map((item) => item.value);
this.setValue(value);
if (!this.isInitial) {
this.emit("change");
}
}
async onValueChange() {
this.isInitial = !this.hasUpdated;
await this.definedController.whenDefined();
if (this.accordion) {
const value = this.value;
if (!value) {
this.setActiveKeys([]);
} else {
const item = this.items.find((item2) => item2.value === value);
this.setActiveKeys(item ? [item.key] : []);
}
} else {
const value = this.value;
if (!value.length) {
this.setActiveKeys([]);
} else {
const activeKeys = this.items.filter((item) => value.includes(item.value)).map((item) => item.key);
this.setActiveKeys(activeKeys);
}
}
this.updateItems();
}
render() {
return x`<slot @slotchange="${this.onSlotChange}" @click="${this.onClick}"></slot>`;
}
setActiveKeys(activeKeys) {
if (!arraysEqualIgnoreOrder(this.activeKeys, activeKeys)) {
this.activeKeys = activeKeys;
}
}
setValue(value) {
if (this.accordion || isUndefined(this.value) || isUndefined(value)) {
this.value = value;
} else if (!arraysEqualIgnoreOrder(this.value, value)) {
this.value = value;
}
}
onClick(event) {
if (this.disabled) {
return;
}
if (event.button) {
return;
}
const target = event.target;
const item = target.closest("mdui-collapse-item");
if (!item || item.disabled) {
return;
}
const path = event.composedPath();
if (item.trigger && !path.find((element) => isElement(element) && $$1(element).is(item.trigger))) {
return;
}
if (!path.find((element) => isElement(element) && element.part.contains("header"))) {
return;
}
if (this.accordion) {
if (this.activeKeys.includes(item.key)) {
this.setActiveKeys([]);
} else {
this.setActiveKeys([item.key]);
}
} else {
const activeKeys = [...this.activeKeys];
if (activeKeys.includes(item.key)) {
activeKeys.splice(activeKeys.indexOf(item.key), 1);
} else {
activeKeys.push(item.key);
}
this.setActiveKeys(activeKeys);
}
this.isInitial = false;
this.updateItems();
}
async onSlotChange() {
await this.definedController.whenDefined();
this.updateItems();
}
// 更新 <mdui-collapse-item> 的状态
updateItems() {
this.items.forEach((item) => {
item.active = this.activeKeys.includes(item.key);
item.isInitial = this.isInitial;
});
}
};
Collapse.styles = [
componentStyle,
collapseStyle
];
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Collapse.prototype, "accordion", void 0);
__decorate([
n$6()
], Collapse.prototype, "value", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Collapse.prototype, "disabled", void 0);
__decorate([
r$1()
], Collapse.prototype, "activeKeys", void 0);
__decorate([
o$6({ selector: "mdui-collapse-item", flatten: true })
], Collapse.prototype, "items", void 0);
__decorate([
watch("activeKeys", true)
], Collapse.prototype, "onActiveKeysChange", null);
__decorate([
watch("value")
], Collapse.prototype, "onValueChange", null);
Collapse = __decorate([
t$3("mdui-collapse")
], Collapse);
const collapseItemStyle = i$7`:host{display:flex;flex-direction:column}.header{display:block}.body{display:block;overflow:hidden;transition:height var(--mdui-motion-duration-short4) var(--mdui-motion-easing-emphasized)}.body.opened{overflow:visible}.body.active{transition-duration:var(--mdui-motion-duration-medium4)}`;
let CollapseItem = class CollapseItem2 extends MduiElement {
constructor() {
super(...arguments);
this.disabled = false;
this.active = false;
this.state = "closed";
this.isInitial = true;
this.key = uniqueId();
this.bodyRef = e$2();
}
onActiveChange() {
if (this.isInitial) {
this.state = this.active ? "opened" : "closed";
if (this.hasUpdated) {
this.updateBodyHeight();
}
} else {
this.state = this.active ? "open" : "close";
this.emit(this.state);
this.updateBodyHeight();
}
}
firstUpdated(changedProperties) {
super.firstUpdated(changedProperties);
this.updateBodyHeight();
}
render() {
return x`<slot name="header" part="header" class="header">${this.header}</slot><slot part="body" class="body ${e$1({
opened: this.state === "opened",
active: this.active
})}" ${n$2(this.bodyRef)} @transitionend="${this.onTransitionEnd}"></slot>`;
}
onTransitionEnd(event) {
if (event.target === this.bodyRef.value) {
this.state = this.active ? "opened" : "closed";
this.emit(this.state);
this.updateBodyHeight();
}
}
updateBodyHeight() {
const scrollHeight = this.bodyRef.value.scrollHeight;
if (this.state === "close") {
$$1(this.bodyRef.value).height(scrollHeight);
this.bodyRef.value.clientLeft;
}
$$1(this.bodyRef.value).height(this.state === "opened" ? "auto" : this.state === "open" ? scrollHeight : 0);
}
};
CollapseItem.styles = [
componentStyle,
collapseItemStyle
];
__decorate([
n$6({ reflect: true })
], CollapseItem.prototype, "value", void 0);
__decorate([
n$6({ reflect: true })
], CollapseItem.prototype, "header", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], CollapseItem.prototype, "disabled", void 0);
__decorate([
n$6()
], CollapseItem.prototype, "trigger", void 0);
__decorate([
r$1()
], CollapseItem.prototype, "active", void 0);
__decorate([
r$1()
], CollapseItem.prototype, "state", void 0);
__decorate([
watch("active")
], CollapseItem.prototype, "onActiveChange", null);
CollapseItem = __decorate([
t$3("mdui-collapse-item")
], CollapseItem);
/**
* @license
* Copyright 2021 Google LLC
* SPDX-License-Identifier: BSD-3-Clause
*/
function n$1(n3, r3, t3) {
return n3 ? r3(n3) : t3 == null ? void 0 : t3(n3);
}
function animateTo(el, keyframes, options) {
if (!el) {
return Promise.resolve();
}
return new Promise((resolve) => {
if (options.duration === Infinity) {
throw new Error("Promise-based animations must be finite.");
}
if (isNumber(options.duration) && isNaN(options.duration)) {
options.duration = 0;
}
if (options.easing === "") {
options.easing = "linear";
}
const animation = el.animate(keyframes, options);
animation.addEventListener("cancel", resolve, { once: true });
animation.addEventListener("finish", resolve, { once: true });
});
}
function stopAnimations(el) {
if (!el) {
return Promise.resolve();
}
return Promise.all(el.getAnimations().map((animation) => {
return new Promise((resolve) => {
const handleAnimationEvent = requestAnimationFrame(resolve);
animation.addEventListener("cancel", () => handleAnimationEvent, {
once: true
});
animation.addEventListener("finish", () => handleAnimationEvent, {
once: true
});
animation.cancel();
});
}));
}
function isTabbable(el) {
const window2 = getWindow$1();
const localName = el.localName;
if (el.getAttribute("tabindex") === "-1") {
return false;
}
if (el.hasAttribute("disabled")) {
return false;
}
if (el.hasAttribute("aria-disabled") && el.getAttribute("aria-disabled") !== "false") {
return false;
}
if (localName === "input" && el.getAttribute("type") === "radio" && !el.hasAttribute("checked")) {
return false;
}
if (el.offsetParent === null) {
return false;
}
if (window2.getComputedStyle(el).visibility === "hidden") {
return false;
}
if ((localName === "audio" || localName === "video") && el.hasAttribute("controls")) {
return true;
}
if (el.hasAttribute("tabindex")) {
return true;
}
if (el.hasAttribute("contenteditable") && el.getAttribute("contenteditable") !== "false") {
return true;
}
return [
"button",
"input",
"select",
"textarea",
"a",
"audio",
"video",
"summary"
].includes(localName);
}
function getTabbableBoundary(root2) {
const allElements = [];
function walk(el) {
if (el instanceof HTMLElement) {
allElements.push(el);
if (el.shadowRoot !== null && el.shadowRoot.mode === "open") {
walk(el.shadowRoot);
}
}
const children = el.children;
[...children].forEach((e3) => walk(e3));
}
walk(root2);
const start = allElements.find((el) => isTabbable(el)) ?? null;
const end = allElements.reverse().find((el) => isTabbable(el)) ?? null;
return { start, end };
}
let activeModals = [];
class Modal {
constructor(element) {
this.tabDirection = "forward";
this.element = element;
this.handleFocusIn = this.handleFocusIn.bind(this);
this.handleKeyDown = this.handleKeyDown.bind(this);
this.handleKeyUp = this.handleKeyUp.bind(this);
}
activate() {
activeModals.push(this.element);
document.addEventListener("focusin", this.handleFocusIn);
document.addEventListener("keydown", this.handleKeyDown);
document.addEventListener("keyup", this.handleKeyUp);
}
deactivate() {
activeModals = activeModals.filter((modal) => modal !== this.element);
document.removeEventListener("focusin", this.handleFocusIn);
document.removeEventListener("keydown", this.handleKeyDown);
document.removeEventListener("keyup", this.handleKeyUp);
}
isActive() {
return activeModals[activeModals.length - 1] === this.element;
}
checkFocus() {
if (this.isActive()) {
if (!this.element.matches(":focus-within")) {
const { start, end } = getTabbableBoundary(this.element);
const target = this.tabDirection === "forward" ? start : end;
if (typeof (target == null ? void 0 : target.focus) === "function") {
target.focus({ preventScroll: true });
}
}
}
}
handleFocusIn() {
this.checkFocus();
}
handleKeyDown(event) {
if (event.key === "Tab" && event.shiftKey) {
this.tabDirection = "backward";
}
requestAnimationFrame(() => this.checkFocus());
}
handleKeyUp() {
this.tabDirection = "forward";
}
}
const getEasing = (element, name) => {
const cssVariableName = `--mdui-motion-easing-${name}`;
return $$1(element).css(cssVariableName).trim();
};
const getDuration = (element, name) => {
const cssVariableName = `--mdui-motion-duration-${name}`;
const cssValue = $$1(element).css(cssVariableName).trim().toLowerCase();
if (cssValue.endsWith("ms")) {
return parseFloat(cssValue);
} else {
return parseFloat(cssValue) * 1e3;
}
};
let scrollBarSizeCached;
const getScrollBarSize = (fresh) => {
if (isUndefined(document)) {
return 0;
}
if (scrollBarSizeCached === void 0) {
const $inner = $$1("<div>").css({
width: "100%",
height: "200px"
});
const $outer = $$1("<div>").css({
position: "absolute",
top: "0",
left: "0",
pointerEvents: "none",
visibility: "hidden",
width: "200px",
height: "150px",
overflow: "hidden"
}).append($inner).appendTo(document.body);
const widthContained = $inner[0].offsetWidth;
$outer.css("overflow", "scroll");
let widthScroll = $inner[0].offsetWidth;
if (widthContained === widthScroll) {
widthScroll = $outer[0].clientWidth;
}
$outer.remove();
scrollBarSizeCached = widthContained - widthScroll;
}
return scrollBarSizeCached;
};
const hasScrollbar = (target) => {
return target.scrollHeight > target.clientHeight;
};
const lockMap = /* @__PURE__ */ new WeakMap();
const className = "mdui-lock-screen";
const lockScreen = (source2, target) => {
const document2 = getDocument();
target ?? (target = document2.documentElement);
if (!lockMap.has(target)) {
lockMap.set(target, /* @__PURE__ */ new Set());
}
const lock = lockMap.get(target);
lock.add(source2);
const $target = $$1(target);
if (hasScrollbar(target)) {
$target.css("width", `calc(100% - ${getScrollBarSize()}px)`);
}
$target.addClass(className);
};
const unlockScreen = (source2, target) => {
const document2 = getDocument();
target ?? (target = document2.documentElement);
const lock = lockMap.get(target);
if (!lock) {
return;
}
lock.delete(source2);
if (lock.size === 0) {
lockMap.delete(target);
$$1(target).removeClass(className).width("");
}
};
/**
* @license
* Copyright 2021 Google LLC
* SPDX-License-Identifier: BSD-3-Clause
*/
const LOCALE_STATUS_EVENT = "lit-localize-status";
/**
* @license
* Copyright 2021 Google LLC
* SPDX-License-Identifier: BSD-3-Clause
*/
const isStrTagged = (val) => typeof val !== "string" && "strTag" in val;
const joinStringsAndValues = (strings, values, valueOrder) => {
let concat = strings[0];
for (let i3 = 1; i3 < strings.length; i3++) {
concat += values[i3 - 1];
concat += strings[i3];
}
return concat;
};
/**
* @license
* Copyright 2021 Google LLC
* SPDX-License-Identifier: BSD-3-Clause
*/
const defaultMsg = (template) => isStrTagged(template) ? joinStringsAndValues(template.strings, template.values) : template;
let msg = defaultMsg;
/**
* @license
* Copyright 2020 Google LLC
* SPDX-License-Identifier: BSD-3-Clause
*/
class Deferred {
constructor() {
this.settled = false;
this.promise = new Promise((resolve, reject) => {
this._resolve = resolve;
this._reject = reject;
});
}
resolve(value) {
this.settled = true;
this._resolve(value);
}
reject(error) {
this.settled = true;
this._reject(error);
}
}
/**
* @license
* Copyright 2014 Travis Webb
* SPDX-License-Identifier: MIT
*/
for (let i3 = 0; i3 < 256; i3++) {
(i3 >> 4 & 15).toString(16) + (i3 & 15).toString(16);
}
/**
* @license
* Copyright 2021 Google LLC
* SPDX-License-Identifier: BSD-3-Clause
*/
let loading = new Deferred();
loading.resolve();
let listeningLitLocalizeStatus = false;
const localeReadyCallbacksMap = /* @__PURE__ */ new Map();
const onLocaleReady = (target, callback) => {
if (!listeningLitLocalizeStatus) {
listeningLitLocalizeStatus = true;
const window2 = getWindow$1();
window2.addEventListener(LOCALE_STATUS_EVENT, (event) => {
if (event.detail.status === "ready") {
localeReadyCallbacksMap.forEach((callbacks2) => {
callbacks2.forEach((cb) => cb());
});
}
});
}
const callbacks = localeReadyCallbacksMap.get(target) || [];
callbacks.push(callback);
localeReadyCallbacksMap.set(target, callbacks);
};
const offLocaleReady = (target) => {
localeReadyCallbacksMap.delete(target);
};
const style$b = i$7`:host{--shape-corner:var(--mdui-shape-corner-extra-large);--z-index:2300;position:fixed;z-index:var(--z-index);display:none;align-items:center;justify-content:center;inset:0;padding:3rem}::slotted(mdui-top-app-bar[slot=header]){position:absolute;border-top-left-radius:var(--mdui-shape-corner-extra-large);border-top-right-radius:var(--mdui-shape-corner-extra-large);background-color:rgb(var(--mdui-color-surface-container-high))}:host([fullscreen]:not([fullscreen=false i])){--shape-corner:var(--mdui-shape-corner-none);padding:0}:host([fullscreen]:not([fullscreen=false i])) ::slotted(mdui-top-app-bar[slot=header]){border-top-left-radius:var(--mdui-shape-corner-none);border-top-right-radius:var(--mdui-shape-corner-none)}.overlay{position:fixed;inset:0;background-color:rgba(var(--mdui-color-scrim),.4)}.panel{--mdui-color-background:var(--mdui-color-surface-container-high);position:relative;display:flex;flex-direction:column;max-height:100%;border-radius:var(--shape-corner);outline:0;transform-origin:top;min-width:17.5rem;max-width:35rem;padding:1.5rem;background-color:rgb(var(--mdui-color-surface-container-high));box-shadow:var(--mdui-elevation-level3)}:host([fullscreen]:not([fullscreen=false i])) .panel{width:100%;max-width:100%;height:100%;max-height:100%;box-shadow:var(--mdui-elevation-level0)}.header{display:flex;flex-direction:column}.has-icon .header{align-items:center}.icon{display:flex;color:rgb(var(--mdui-color-secondary));font-size:1.5rem}.icon mdui-icon,::slotted([slot=icon]){font-size:inherit}.headline{display:flex;color:rgb(var(--mdui-color-on-surface));font-size:var(--mdui-typescale-headline-small-size);font-weight:var(--mdui-typescale-headline-small-weight);letter-spacing:var(--mdui-typescale-headline-small-tracking);line-height:var(--mdui-typescale-headline-small-line-height)}.icon+.headline{padding-top:1rem}.body{overflow:auto}.header+.body{margin-top:1rem}.description{display:flex;color:rgb(var(--mdui-color-on-surface-variant));font-size:var(--mdui-typescale-body-medium-size);font-weight:var(--mdui-typescale-body-medium-weight);letter-spacing:var(--mdui-typescale-body-medium-tracking);line-height:var(--mdui-typescale-body-medium-line-height)}:host([fullscreen]:not([fullscreen=false i])) .description{color:rgb(var(--mdui-color-on-surface))}.has-description.has-default .description{margin-bottom:1rem}.action{display:flex;justify-content:flex-end;padding-top:1.5rem}.action::slotted(:not(:first-child)){margin-left:.5rem}:host([stacked-actions]:not([stacked-actions=false i])) .action{flex-direction:column;align-items:end}:host([stacked-actions]:not([stacked-actions=false i])) .action::slotted(:not(:first-child)){margin-left:0;margin-top:.5rem}`;
let Dialog = class Dialog2 extends MduiElement {
constructor() {
super(...arguments);
this.open = false;
this.fullscreen = false;
this.closeOnEsc = false;
this.closeOnOverlayClick = false;
this.stackedActions = false;
this.overlayRef = e$2();
this.panelRef = e$2();
this.bodyRef = e$2();
this.hasSlotController = new HasSlotController(this, "header", "icon", "headline", "description", "action", "[default]");
this.definedController = new DefinedController(this, {
relatedElements: ["mdui-top-app-bar"]
});
}
async onOpenChange() {
const hasUpdated = this.hasUpdated;
if (!this.open && !hasUpdated) {
return;
}
await this.definedController.whenDefined();
if (!hasUpdated) {
await this.updateComplete;
}
const children = Array.from(this.panelRef.value.querySelectorAll(".header, .body, .actions"));
const easingLinear = getEasing(this, "linear");
const easingEmphasizedDecelerate = getEasing(this, "emphasized-decelerate");
const easingEmphasizedAccelerate = getEasing(this, "emphasized-accelerate");
const stopAnimation = () => Promise.all([
stopAnimations(this.overlayRef.value),
stopAnimations(this.panelRef.value),
...children.map((child) => stopAnimations(child))
]);
if (this.open) {
if (hasUpdated) {
const eventProceeded = this.emit("open", { cancelable: true });
if (!eventProceeded) {
return;
}
}
this.style.display = "flex";
const topAppBarElements = this.topAppBarElements ?? [];
if (topAppBarElements.length) {
const topAppBarElement = topAppBarElements[0];
if (!topAppBarElement.scrollTarget) {
topAppBarElement.scrollTarget = this.bodyRef.value;
}
this.bodyRef.value.style.marginTop = "0";
}
this.originalTrigger = document.activeElement;
this.modalHelper.activate();
lockScreen(this);
await stopAnimation();
requestAnimationFrame(() => {
const autoFocusTarget = this.querySelector("[autofocus]");
if (autoFocusTarget) {
autoFocusTarget.focus({ preventScroll: true });
} else {
this.panelRef.value.focus({ preventScroll: true });
}
});
const duration = getDuration(this, "medium4");
await Promise.all([
animateTo(this.overlayRef.value, [{ opacity: 0 }, { opacity: 1, offset: 0.3 }, { opacity: 1 }], {
duration: hasUpdated ? duration : 0,
easing: easingLinear
}),
animateTo(this.panelRef.value, [
{ transform: "translateY(-1.875rem) scaleY(0)" },
{ transform: "translateY(0) scaleY(1)" }
], {
duration: hasUpdated ? duration : 0,
easing: easingEmphasizedDecelerate
}),
animateTo(this.panelRef.value, [{ opacity: 0 }, { opacity: 1, offset: 0.1 }, { opacity: 1 }], {
duration: hasUpdated ? duration : 0,
easing: easingLinear
}),
...children.map((child) => animateTo(child, [
{ opacity: 0 },
{ opacity: 0, offset: 0.2 },
{ opacity: 1, offset: 0.8 },
{ opacity: 1 }
], {
duration: hasUpdated ? duration : 0,
easing: easingLinear
}))
]);
if (hasUpdated) {
this.emit("opened");
}
} else {
const eventProceeded = this.emit("close", { cancelable: true });
if (!eventProceeded) {
return;
}
this.modalHelper.deactivate();
await stopAnimation();
const duration = getDuration(this, "short4");
await Promise.all([
animateTo(this.overlayRef.value, [{ opacity: 1 }, { opacity: 0 }], {
duration,
easing: easingLinear
}),
animateTo(this.panelRef.value, [
{ transform: "translateY(0) scaleY(1)" },
{ transform: "translateY(-1.875rem) scaleY(0.6)" }
], { duration, easing: easingEmphasizedAccelerate }),
animateTo(this.panelRef.value, [{ opacity: 1 }, { opacity: 1, offset: 0.75 }, { opacity: 0 }], { duration, easing: easingLinear }),
...children.map((child) => animateTo(child, [{ opacity: 1 }, { opacity: 0, offset: 0.75 }, { opacity: 0 }], { duration, easing: easingLinear }))
]);
this.style.display = "none";
unlockScreen(this);
const trigger = this.originalTrigger;
if (typeof (trigger == null ? void 0 : trigger.focus) === "function") {
setTimeout(() => trigger.focus());
}
this.emit("closed");
}
}
disconnectedCallback() {
super.disconnectedCallback();
unlockScreen(this);
offLocaleReady(this);
}
firstUpdated(_changedProperties) {
super.firstUpdated(_changedProperties);
this.modalHelper = new Modal(this);
this.addEventListener("keydown", (event) => {
if (this.open && this.closeOnEsc && event.key === "Escape") {
event.stopPropagation();
this.open = false;
}
});
}
render() {
const hasActionSlot = this.hasSlotController.test("action");
const hasDefaultSlot = this.hasSlotController.test("[default]");
const hasIcon = !!this.icon || this.hasSlotController.test("icon");
const hasHeadline = !!this.headline || this.hasSlotController.test("headline");
const hasDescription = !!this.description || this.hasSlotController.test("description");
const hasHeader = hasIcon || hasHeadline || this.hasSlotController.test("header");
const hasBody = hasDescription || hasDefaultSlot;
return x`<div ${n$2(this.overlayRef)} part="overlay" class="overlay" @click="${this.onOverlayClick}" tabindex="-1"></div><div ${n$2(this.panelRef)} part="panel" class="panel ${e$1({
"has-icon": hasIcon,
"has-description": hasDescription,
"has-default": hasDefaultSlot
})}" tabindex="0">${n$1(hasHeader, () => x`<slot name="header" part="header" class="header">${n$1(hasIcon, () => this.renderIcon())} ${n$1(hasHeadline, () => this.renderHeadline())}</slot>`)} ${n$1(hasBody, () => x`<div ${n$2(this.bodyRef)} part="body" class="body">${n$1(hasDescription, () => this.renderDescription())}<slot></slot></div>`)} ${n$1(hasActionSlot, () => x`<slot name="action" part="action" class="action"></slot>`)}</div>`;
}
onOverlayClick() {
this.emit("overlay-click");
if (!this.closeOnOverlayClick) {
return;
}
this.open = false;
}
renderIcon() {
return x`<slot name="icon" part="icon" class="icon">${this.icon ? x`<mdui-icon name="${this.icon}"></mdui-icon>` : nothingTemplate}</slot>`;
}
renderHeadline() {
return x`<slot name="headline" part="headline" class="headline">${this.headline}</slot>`;
}
renderDescription() {
return x`<slot name="description" part="description" class="description">${this.description}</slot>`;
}
};
Dialog.styles = [componentStyle, style$b];
__decorate([
n$6({ reflect: true })
], Dialog.prototype, "icon", void 0);
__decorate([
n$6({ reflect: true })
], Dialog.prototype, "headline", void 0);
__decorate([
n$6({ reflect: true })
], Dialog.prototype, "description", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Dialog.prototype, "open", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Dialog.prototype, "fullscreen", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter,
attribute: "close-on-esc"
})
], Dialog.prototype, "closeOnEsc", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter,
attribute: "close-on-overlay-click"
})
], Dialog.prototype, "closeOnOverlayClick", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter,
attribute: "stacked-actions"
})
], Dialog.prototype, "stackedActions", void 0);
__decorate([
o$6({
slot: "header",
selector: "mdui-top-app-bar",
flatten: true
})
], Dialog.prototype, "topAppBarElements", void 0);
__decorate([
watch("open")
], Dialog.prototype, "onOpenChange", null);
Dialog = __decorate([
t$3("mdui-dialog")
], Dialog);
const style$a = i$7`:host{display:block;height:.0625rem;background-color:rgb(var(--mdui-color-surface-variant))}:host([inset]:not([inset=false i])){margin-left:1rem}:host([middle]:not([middle=false i])){margin-left:1rem;margin-right:1rem}:host([vertical]:not([vertical=false i])){height:100%;width:.0625rem}`;
let Divider = class Divider2 extends MduiElement {
constructor() {
super(...arguments);
this.vertical = false;
this.inset = false;
this.middle = false;
}
render() {
return x``;
}
};
Divider.styles = [componentStyle, style$a];
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Divider.prototype, "vertical", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Divider.prototype, "inset", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Divider.prototype, "middle", void 0);
Divider = __decorate([
t$3("mdui-divider")
], Divider);
function hasWindow() {
return typeof window !== "undefined";
}
function getNodeName(node) {
if (isNode(node)) {
return (node.nodeName || "").toLowerCase();
}
return "#document";
}
function getWindow(node) {
var _node$ownerDocument;
return (node == null || (_node$ownerDocument = node.ownerDocument) == null ? void 0 : _node$ownerDocument.defaultView) || window;
}
function getDocumentElement(node) {
var _ref;
return (_ref = (isNode(node) ? node.ownerDocument : node.document) || window.document) == null ? void 0 : _ref.documentElement;
}
function isNode(value) {
if (!hasWindow()) {
return false;
}
return value instanceof Node || value instanceof getWindow(value).Node;
}
function isHTMLElement(value) {
if (!hasWindow()) {
return false;
}
return value instanceof HTMLElement || value instanceof getWindow(value).HTMLElement;
}
function isShadowRoot(value) {
if (!hasWindow() || typeof ShadowRoot === "undefined") {
return false;
}
return value instanceof ShadowRoot || value instanceof getWindow(value).ShadowRoot;
}
function isOverflowElement(element) {
const {
overflow,
overflowX,
overflowY,
display
} = getComputedStyle(element);
return /auto|scroll|overlay|hidden|clip/.test(overflow + overflowY + overflowX) && !["inline", "contents"].includes(display);
}
function isLastTraversableNode(node) {
return ["html", "body", "#document"].includes(getNodeName(node));
}
function getComputedStyle(element) {
return getWindow(element).getComputedStyle(element);
}
function getParentNode(node) {
if (getNodeName(node) === "html") {
return node;
}
const result = (
// Step into the shadow DOM of the parent of a slotted node.
node.assignedSlot || // DOM Element detected.
node.parentNode || // ShadowRoot detected.
isShadowRoot(node) && node.host || // Fallback.
getDocumentElement(node)
);
return isShadowRoot(result) ? result.host : result;
}
function getNearestOverflowAncestor(node) {
const parentNode = getParentNode(node);
if (isLastTraversableNode(parentNode)) {
return node.ownerDocument ? node.ownerDocument.body : node.body;
}
if (isHTMLElement(parentNode) && isOverflowElement(parentNode)) {
return parentNode;
}
return getNearestOverflowAncestor(parentNode);
}
function getOverflowAncestors(node, list, traverseIframes) {
var _node$ownerDocument2;
if (list === void 0) {
list = [];
}
if (traverseIframes === void 0) {
traverseIframes = true;
}
const scrollableAncestor = getNearestOverflowAncestor(node);
const isBody = scrollableAncestor === ((_node$ownerDocument2 = node.ownerDocument) == null ? void 0 : _node$ownerDocument2.body);
const win = getWindow(scrollableAncestor);
if (isBody) {
const frameElement = getFrameElement(win);
return list.concat(win, win.visualViewport || [], isOverflowElement(scrollableAncestor) ? scrollableAncestor : [], frameElement && traverseIframes ? getOverflowAncestors(frameElement) : []);
}
return list.concat(scrollableAncestor, getOverflowAncestors(scrollableAncestor, [], traverseIframes));
}
function getFrameElement(win) {
return win.parent && Object.getPrototypeOf(win.parent) ? win.frameElement : null;
}
const style$9 = i$7`:host{--z-index:2100;display:contents}.panel{display:block;position:fixed;z-index:var(--z-index)}`;
let Dropdown = class Dropdown2 extends MduiElement {
constructor() {
super();
this.open = false;
this.disabled = false;
this.trigger = "click";
this.placement = "auto";
this.stayOpenOnClick = false;
this.openDelay = 150;
this.closeDelay = 150;
this.openOnPointer = false;
this.panelRef = e$2();
this.definedController = new DefinedController(this, {
relatedElements: [""]
});
this.onDocumentClick = this.onDocumentClick.bind(this);
this.onDocumentKeydown = this.onDocumentKeydown.bind(this);
this.onWindowScroll = this.onWindowScroll.bind(this);
this.onMouseLeave = this.onMouseLeave.bind(this);
this.onFocus = this.onFocus.bind(this);
this.onClick = this.onClick.bind(this);
this.onContextMenu = this.onContextMenu.bind(this);
this.onMouseEnter = this.onMouseEnter.bind(this);
this.onPanelClick = this.onPanelClick.bind(this);
}
get triggerElement() {
return this.triggerElements[0];
}
// 这些属性变更时,需要更新样式
async onPositionChange() {
if (this.open) {
await this.definedController.whenDefined();
this.updatePositioner();
}
}
async onOpenChange() {
var _a2, _b;
const hasUpdated = this.hasUpdated;
if (!this.open && !hasUpdated) {
return;
}
await this.definedController.whenDefined();
if (!hasUpdated) {
await this.updateComplete;
}
const easingLinear = getEasing(this, "linear");
const easingEmphasizedDecelerate = getEasing(this, "emphasized-decelerate");
const easingEmphasizedAccelerate = getEasing(this, "emphasized-accelerate");
if (this.open) {
if (hasUpdated) {
const eventProceeded = this.emit("open", { cancelable: true });
if (!eventProceeded) {
return;
}
}
const focusablePanel = this.panelElements.find((panel) => isFunction(panel.focus));
setTimeout(() => {
focusablePanel == null ? void 0 : focusablePanel.focus();
});
const duration = getDuration(this, "medium4");
await stopAnimations(this.panelRef.value);
this.panelRef.value.hidden = false;
this.updatePositioner();
await Promise.all([
animateTo(this.panelRef.value, [
{ transform: `${this.getCssScaleName()}(0.45)` },
{ transform: `${this.getCssScaleName()}(1)` }
], {
duration: hasUpdated ? duration : 0,
easing: easingEmphasizedDecelerate
}),
animateTo(this.panelRef.value, [{ opacity: 0 }, { opacity: 1, offset: 0.125 }, { opacity: 1 }], {
duration: hasUpdated ? duration : 0,
easing: easingLinear
})
]);
if (hasUpdated) {
this.emit("opened");
}
} else {
const eventProceeded = this.emit("close", { cancelable: true });
if (!eventProceeded) {
return;
}
if (!this.hasTrigger("focus") && isFunction((_a2 = this.triggerElement) == null ? void 0 : _a2.focus) && (this.contains(document.activeElement) || this.contains(((_b = document.activeElement) == null ? void 0 : _b.assignedSlot) ?? null))) {
this.triggerElement.focus();
}
const duration = getDuration(this, "short4");
await stopAnimations(this.panelRef.value);
await Promise.all([
animateTo(this.panelRef.value, [
{ transform: `${this.getCssScaleName()}(1)` },
{ transform: `${this.getCssScaleName()}(0.45)` }
], { duration, easing: easingEmphasizedAccelerate }),
animateTo(this.panelRef.value, [{ opacity: 1 }, { opacity: 1, offset: 0.875 }, { opacity: 0 }], { duration, easing: easingLinear })
]);
if (this.panelRef.value) {
this.panelRef.value.hidden = true;
}
this.emit("closed");
}
}
connectedCallback() {
super.connectedCallback();
this.definedController.whenDefined().then(() => {
document.addEventListener("pointerdown", this.onDocumentClick);
document.addEventListener("keydown", this.onDocumentKeydown);
this.overflowAncestors = getOverflowAncestors(this.triggerElement);
this.overflowAncestors.forEach((ancestor) => {
ancestor.addEventListener("scroll", this.onWindowScroll);
});
this.observeResize = observeResize(this.triggerElement, () => {
this.updatePositioner();
});
});
}
disconnectedCallback() {
var _a2, _b;
if (!this.open && this.panelRef.value) {
this.panelRef.value.hidden = true;
}
super.disconnectedCallback();
document.removeEventListener("pointerdown", this.onDocumentClick);
document.removeEventListener("keydown", this.onDocumentKeydown);
(_a2 = this.overflowAncestors) == null ? void 0 : _a2.forEach((ancestor) => {
ancestor.removeEventListener("scroll", this.onWindowScroll);
});
(_b = this.observeResize) == null ? void 0 : _b.unobserve();
}
firstUpdated(changedProperties) {
super.firstUpdated(changedProperties);
this.addEventListener("mouseleave", this.onMouseLeave);
this.definedController.whenDefined().then(() => {
this.triggerElement.addEventListener("focus", this.onFocus);
this.triggerElement.addEventListener("click", this.onClick);
this.triggerElement.addEventListener("contextmenu", this.onContextMenu);
this.triggerElement.addEventListener("mouseenter", this.onMouseEnter);
});
}
render() {
return x`<slot name="trigger" part="trigger" class="trigger"></slot><slot ${n$2(this.panelRef)} part="panel" class="panel" hidden @click="${this.onPanelClick}"></slot>`;
}
/**
* 获取 dropdown 打开、关闭动画的 CSS scaleX 或 scaleY
*/
getCssScaleName() {
return this.animateDirection === "horizontal" ? "scaleX" : "scaleY";
}
/**
* 在 document 上点击时,根据条件判断是否要关闭 dropdown
*/
onDocumentClick(e3) {
if (this.disabled || !this.open) {
return;
}
const path = e3.composedPath();
if (!path.includes(this)) {
this.open = false;
}
if (this.hasTrigger("contextmenu") && !this.hasTrigger("click") && path.includes(this.triggerElement)) {
this.open = false;
}
}
/**
* 在 document 上按下按键时,根据条件判断是否要关闭 dropdown
*/
onDocumentKeydown(event) {
var _a2;
if (this.disabled || !this.open) {
return;
}
if (event.key === "Escape") {
this.open = false;
return;
}
if (event.key === "Tab") {
if (!this.hasTrigger("focus") && isFunction((_a2 = this.triggerElement) == null ? void 0 : _a2.focus)) {
event.preventDefault();
}
this.open = false;
}
}
onWindowScroll() {
window.requestAnimationFrame(() => this.onPositionChange());
}
hasTrigger(trigger) {
const triggers = this.trigger.split(" ");
return triggers.includes(trigger);
}
onFocus() {
if (this.disabled || this.open || !this.hasTrigger("focus")) {
return;
}
this.open = true;
}
onClick(e3) {
if (this.disabled || e3.button || !this.hasTrigger("click")) {
return;
}
if (this.open && (this.hasTrigger("hover") || this.hasTrigger("focus"))) {
return;
}
this.pointerOffsetX = e3.offsetX;
this.pointerOffsetY = e3.offsetY;
this.open = !this.open;
}
onPanelClick(e3) {
if (!this.disabled && !this.stayOpenOnClick && $$1(e3.target).is("mdui-menu-item")) {
this.open = false;
}
}
onContextMenu(e3) {
if (this.disabled || !this.hasTrigger("contextmenu")) {
return;
}
e3.preventDefault();
this.pointerOffsetX = e3.offsetX;
this.pointerOffsetY = e3.offsetY;
this.open = true;
}
onMouseEnter() {
if (this.disabled || !this.hasTrigger("hover")) {
return;
}
window.clearTimeout(this.closeTimeout);
if (this.openDelay) {
this.openTimeout = window.setTimeout(() => {
this.open = true;
}, this.openDelay);
} else {
this.open = true;
}
}
onMouseLeave() {
if (this.disabled || !this.hasTrigger("hover")) {
return;
}
window.clearTimeout(this.openTimeout);
this.closeTimeout = window.setTimeout(() => {
this.open = false;
}, this.closeDelay || 50);
}
// 更新 panel 的位置
updatePositioner() {
const $panel = $$1(this.panelRef.value);
const $window = $$1(window);
const panelElements = this.panelElements;
const panelRect = {
width: Math.max(...(panelElements == null ? void 0 : panelElements.map((panel) => panel.offsetWidth)) ?? []),
height: panelElements == null ? void 0 : panelElements.map((panel) => panel.offsetHeight).reduce((total, height) => total + height, 0)
};
const triggerClientRect = this.triggerElement.getBoundingClientRect();
const triggerRect = this.openOnPointer ? {
top: this.pointerOffsetY + triggerClientRect.top,
left: this.pointerOffsetX + triggerClientRect.left,
width: 0,
height: 0
} : triggerClientRect;
const screenMargin = 8;
let transformOriginX;
let transformOriginY;
let top2;
let left;
let placement = this.placement;
if (placement === "auto") {
const windowWidth = $window.width();
const windowHeight = $window.height();
let position2;
let alignment2;
if (windowHeight - triggerRect.top - triggerRect.height > panelRect.height + screenMargin) {
position2 = "bottom";
} else if (triggerRect.top > panelRect.height + screenMargin) {
position2 = "top";
} else if (windowWidth - triggerRect.left - triggerRect.width > panelRect.width + screenMargin) {
position2 = "right";
} else if (triggerRect.left > panelRect.width + screenMargin) {
position2 = "left";
} else {
position2 = "bottom";
}
if (["top", "bottom"].includes(position2)) {
if (windowWidth - triggerRect.left > panelRect.width + screenMargin) {
alignment2 = "start";
} else if (triggerRect.left + triggerRect.width / 2 > panelRect.width / 2 + screenMargin && windowWidth - triggerRect.left - triggerRect.width / 2 > panelRect.width / 2 + screenMargin) {
alignment2 = void 0;
} else if (triggerRect.left + triggerRect.width > panelRect.width + screenMargin) {
alignment2 = "end";
} else {
alignment2 = "start";
}
} else {
if (windowHeight - triggerRect.top > panelRect.height + screenMargin) {
alignment2 = "start";
} else if (triggerRect.top + triggerRect.height / 2 > panelRect.height / 2 + screenMargin && windowHeight - triggerRect.top - triggerRect.height / 2 > panelRect.height / 2 + screenMargin) {
alignment2 = void 0;
} else if (triggerRect.top + triggerRect.height > panelRect.height + screenMargin) {
alignment2 = "end";
} else {
alignment2 = "start";
}
}
placement = alignment2 ? [position2, alignment2].join("-") : position2;
}
const [position, alignment] = placement.split("-");
this.animateDirection = ["top", "bottom"].includes(position) ? "vertical" : "horizontal";
switch (position) {
case "top":
transformOriginY = "bottom";
top2 = triggerRect.top - panelRect.height;
break;
case "bottom":
transformOriginY = "top";
top2 = triggerRect.top + triggerRect.height;
break;
default:
transformOriginY = "center";
switch (alignment) {
case "start":
top2 = triggerRect.top;
break;
case "end":
top2 = triggerRect.top + triggerRect.height - panelRect.height;
break;
default:
top2 = triggerRect.top + triggerRect.height / 2 - panelRect.height / 2;
break;
}
break;
}
switch (position) {
case "left":
transformOriginX = "right";
left = triggerRect.left - panelRect.width;
break;
case "right":
transformOriginX = "left";
left = triggerRect.left + triggerRect.width;
break;
default:
transformOriginX = "center";
switch (alignment) {
case "start":
left = triggerRect.left;
break;
case "end":
left = triggerRect.left + triggerRect.width - panelRect.width;
break;
default:
left = triggerRect.left + triggerRect.width / 2 - panelRect.width / 2;
break;
}
break;
}
$panel.css({
top: top2,
left,
transformOrigin: [transformOriginX, transformOriginY].join(" ")
});
}
};
Dropdown.styles = [componentStyle, style$9];
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Dropdown.prototype, "open", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Dropdown.prototype, "disabled", void 0);
__decorate([
n$6({ reflect: true })
], Dropdown.prototype, "trigger", void 0);
__decorate([
n$6({ reflect: true })
], Dropdown.prototype, "placement", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter,
attribute: "stay-open-on-click"
})
], Dropdown.prototype, "stayOpenOnClick", void 0);
__decorate([
n$6({ type: Number, reflect: true, attribute: "open-delay" })
], Dropdown.prototype, "openDelay", void 0);
__decorate([
n$6({ type: Number, reflect: true, attribute: "close-delay" })
], Dropdown.prototype, "closeDelay", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter,
attribute: "open-on-pointer"
})
], Dropdown.prototype, "openOnPointer", void 0);
__decorate([
o$6({ slot: "trigger", flatten: true })
], Dropdown.prototype, "triggerElements", void 0);
__decorate([
o$6({ flatten: true })
], Dropdown.prototype, "panelElements", void 0);
__decorate([
watch("placement", true),
watch("openOnPointer", true)
], Dropdown.prototype, "onPositionChange", null);
__decorate([
watch("open")
], Dropdown.prototype, "onOpenChange", null);
Dropdown = __decorate([
t$3("mdui-dropdown")
], Dropdown);
const delay = (duration = 0) => {
return new Promise((resolve) => setTimeout(resolve, duration));
};
const style$8 = i$7`:host{--shape-corner-small:var(--mdui-shape-corner-small);--shape-corner-normal:var(--mdui-shape-corner-large);--shape-corner-large:var(--mdui-shape-corner-extra-large);position:relative;display:inline-block;flex-shrink:0;overflow:hidden;text-align:center;border-radius:var(--shape-corner-normal);cursor:pointer;-webkit-tap-highlight-color:transparent;transition-property:box-shadow;transition-timing-function:var(--mdui-motion-easing-emphasized);transition-duration:var(--mdui-motion-duration-medium4);width:3.5rem;height:3.5rem;box-shadow:var(--mdui-elevation-level3);font-size:var(--mdui-typescale-label-large-size);font-weight:var(--mdui-typescale-label-large-weight);letter-spacing:var(--mdui-typescale-label-large-tracking);line-height:var(--mdui-typescale-label-large-line-height)}.button{padding:0 1rem}:host([size=small]) .button{padding:0 .5rem}:host([size=large]) .button{padding:0 1.875rem}:host([lowered]){box-shadow:var(--mdui-elevation-level1)}:host([focus-visible]){box-shadow:var(--mdui-elevation-level3)}:host([lowered][focus-visible]){box-shadow:var(--mdui-elevation-level1)}:host([pressed]){box-shadow:var(--mdui-elevation-level3)}:host([lowered][pressed]){box-shadow:var(--mdui-elevation-level1)}:host([hover]){box-shadow:var(--mdui-elevation-level4)}:host([lowered][hover]){box-shadow:var(--mdui-elevation-level2)}:host([variant=primary]){color:rgb(var(--mdui-color-on-primary-container));background-color:rgb(var(--mdui-color-primary-container));--mdui-comp-ripple-state-layer-color:var(
--mdui-color-on-primary-container
)}:host([variant=surface]){color:rgb(var(--mdui-color-primary));background-color:rgb(var(--mdui-color-surface-container-high));--mdui-comp-ripple-state-layer-color:var(--mdui-color-primary)}:host([variant=surface][lowered]){background-color:rgb(var(--mdui-color-surface-container-low))}:host([variant=secondary]){color:rgb(var(--mdui-color-on-secondary-container));background-color:rgb(var(--mdui-color-secondary-container));--mdui-comp-ripple-state-layer-color:var(
--mdui-color-on-secondary-container
)}:host([variant=tertiary]){color:rgb(var(--mdui-color-on-tertiary-container));background-color:rgb(var(--mdui-color-tertiary-container));--mdui-comp-ripple-state-layer-color:var(
--mdui-color-on-tertiary-container
)}:host([size=small]){border-radius:var(--shape-corner-small);width:2.5rem;height:2.5rem}:host([size=large]){border-radius:var(--shape-corner-large);width:6rem;height:6rem}:host([disabled]:not([disabled=false i])),:host([loading]:not([loading=false i])){cursor:default;pointer-events:none}:host([disabled]:not([disabled=false i])){color:rgba(var(--mdui-color-on-surface),38%);background-color:rgba(var(--mdui-color-on-surface),12%);box-shadow:var(--mdui-elevation-level0)}:host([extended]:not([extended=false i])){width:auto}.label{display:inline-flex;transition:opacity var(--mdui-motion-duration-short2) var(--mdui-motion-easing-linear) var(--mdui-motion-duration-short2);padding-left:.25rem;padding-right:.25rem}.has-icon .label{margin-left:.5rem}:host([size=small]) .has-icon .label{margin-left:.25rem}:host([size=large]) .has-icon .label{margin-left:1rem}:host(:not([extended])) .label,:host([extended=false i]) .label{opacity:0;transition-delay:0s;transition-duration:var(--mdui-motion-duration-short1)}:host([size=large]) .label{font-size:1.5em}.icon{display:inline-flex;font-size:1.71428571em}:host([size=large]) .icon{font-size:2.57142857em}.icon mdui-icon,::slotted([slot=icon]){font-size:inherit}mdui-circular-progress{display:inline-flex;width:1.5rem;height:1.5rem}:host([size=large]) mdui-circular-progress{width:2.25rem;height:2.25rem}:host([disabled]:not([disabled=false i])) mdui-circular-progress{stroke:rgba(var(--mdui-color-on-surface),38%)}`;
let Fab = class Fab2 extends ButtonBase {
constructor() {
super(...arguments);
this.variant = "primary";
this.size = "normal";
this.extended = false;
this.rippleRef = e$2();
this.hasSlotController = new HasSlotController(this, "icon");
this.definedController = new DefinedController(this, {
relatedElements: [""]
});
}
get rippleElement() {
return this.rippleRef.value;
}
/**
* extended 变更时,设置动画
*/
async onExtendedChange() {
const hasUpdated = this.hasUpdated;
if (this.extended) {
this.style.width = `${this.scrollWidth}px`;
} else {
this.style.width = "";
}
await this.definedController.whenDefined();
await this.updateComplete;
if (this.extended && !hasUpdated) {
this.style.width = `${this.scrollWidth}px`;
}
if (!hasUpdated) {
await delay();
this.style.transitionProperty = "box-shadow, width, bottom, transform";
}
}
render() {
const className2 = cc({
button: true,
"has-icon": this.icon || this.hasSlotController.test("icon")
});
return x`<mdui-ripple ${n$2(this.rippleRef)} .noRipple="${this.noRipple}"></mdui-ripple>${this.isButton() ? this.renderButton({
className: className2,
part: "button",
content: this.renderInner()
}) : this.disabled || this.loading ? x`<span part="button" class="_a ${className2}">${this.renderInner()}</span>` : this.renderAnchor({
className: className2,
part: "button",
content: this.renderInner()
})}`;
}
renderLabel() {
return x`<slot part="label" class="label"></slot>`;
}
renderIcon() {
if (this.loading) {
return this.renderLoading();
}
return x`<slot name="icon" part="icon" class="icon">${this.icon ? x`<mdui-icon name="${this.icon}"></mdui-icon>` : nothingTemplate}</slot>`;
}
renderInner() {
return [this.renderIcon(), this.renderLabel()];
}
};
Fab.styles = [ButtonBase.styles, style$8];
__decorate([
n$6({ reflect: true })
], Fab.prototype, "variant", void 0);
__decorate([
n$6({ reflect: true })
], Fab.prototype, "size", void 0);
__decorate([
n$6({ reflect: true })
], Fab.prototype, "icon", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Fab.prototype, "extended", void 0);
__decorate([
watch("extended")
], Fab.prototype, "onExtendedChange", null);
Fab = __decorate([
t$3("mdui-fab")
], Fab);
const layoutStyle = i$7`:host{position:relative;display:flex;flex:1 1 auto;overflow:hidden}:host([full-height]:not([full-height=false i])){height:100%}`;
let Layout = class Layout2 extends MduiElement {
constructor() {
super(...arguments);
this.fullHeight = false;
}
render() {
return x`<slot></slot>`;
}
};
Layout.styles = [componentStyle, layoutStyle];
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter,
attribute: "full-height"
})
], Layout.prototype, "fullHeight", void 0);
Layout = __decorate([
t$3("mdui-layout")
], Layout);
const layoutItemStyle = i$7`:host{display:flex;z-index:1}`;
let LayoutItem = class LayoutItem2 extends LayoutItemBase {
constructor() {
super(...arguments);
this.placement = "top";
}
get layoutPlacement() {
return this.placement;
}
// placement 变更时,需要重新调整布局
onPlacementChange() {
var _a2;
(_a2 = this.layoutManager) == null ? void 0 : _a2.updateLayout(this);
}
render() {
return x`<slot></slot>`;
}
};
LayoutItem.styles = [
componentStyle,
layoutItemStyle
];
__decorate([
n$6({ reflect: true })
], LayoutItem.prototype, "placement", void 0);
__decorate([
watch("placement", true)
], LayoutItem.prototype, "onPlacementChange", null);
LayoutItem = __decorate([
t$3("mdui-layout-item")
], LayoutItem);
const layoutMainStyle = i$7`:host{flex:1 0 auto;max-width:100%;overflow:auto}`;
let LayoutMain = class LayoutMain2 extends MduiElement {
connectedCallback() {
super.connectedCallback();
const parentElement = this.parentElement;
if (isNodeName(parentElement, "mdui-layout")) {
this.layoutManager = getLayout(parentElement);
this.layoutManager.registerMain(this);
}
}
disconnectedCallback() {
super.disconnectedCallback();
if (this.layoutManager) {
this.layoutManager.unregisterMain();
}
}
render() {
return x`<slot></slot>`;
}
};
LayoutMain.styles = [
componentStyle,
layoutMainStyle
];
LayoutMain = __decorate([
t$3("mdui-layout-main")
], LayoutMain);
const style$7 = i$7`:host{--shape-corner:var(--mdui-shape-corner-none);position:relative;display:inline-block;width:100%;overflow:hidden;border-radius:var(--shape-corner);background-color:rgb(var(--mdui-color-surface-container-highest));height:.25rem}.determinate,.indeterminate{background-color:rgb(var(--mdui-color-primary))}.determinate{height:100%;transition:width var(--mdui-motion-duration-long2) var(--mdui-motion-easing-standard)}.indeterminate::before{position:absolute;top:0;bottom:0;left:0;background-color:inherit;animation:mdui-comp-progress-indeterminate 2s var(--mdui-motion-easing-linear) infinite;content:' '}.indeterminate::after{position:absolute;top:0;bottom:0;left:0;background-color:inherit;animation:mdui-comp-progress-indeterminate-short 2s var(--mdui-motion-easing-linear) infinite;content:' '}@keyframes mdui-comp-progress-indeterminate{0%{left:0;width:0}50%{left:30%;width:70%}75%{left:100%;width:0}}@keyframes mdui-comp-progress-indeterminate-short{0%{left:0;width:0}50%{left:0;width:0}75%{left:0;width:25%}100%{left:100%;width:0}}`;
let LinearProgress = class LinearProgress2 extends MduiElement {
constructor() {
super(...arguments);
this.max = 1;
}
render() {
const isDeterminate = !isUndefined(this.value);
if (isDeterminate) {
const value = this.value;
return x`<div part="indicator" class="determinate" style="${o$4({
width: `${value / Math.max(this.max ?? value, value) * 100}%`
})}"></div>`;
}
return x`<div part="indicator" class="indeterminate"></div>`;
}
};
LinearProgress.styles = [componentStyle, style$7];
__decorate([
n$6({ type: Number, reflect: true })
], LinearProgress.prototype, "max", void 0);
__decorate([
n$6({ type: Number })
], LinearProgress.prototype, "value", void 0);
LinearProgress = __decorate([
t$3("mdui-linear-progress")
], LinearProgress);
const listItemStyle = i$7`:host{--shape-corner:var(--mdui-shape-corner-none);--shape-corner-rounded:var(--mdui-shape-corner-extra-large);position:relative;display:block;border-radius:var(--shape-corner);--mdui-comp-ripple-state-layer-color:var(--mdui-color-on-surface)}:host([rounded]:not([rounded=false i])),:host([rounded]:not([rounded=false i])) mdui-ripple{border-radius:var(--shape-corner-rounded)}:host([active]:not([active=false i])){background-color:rgb(var(--mdui-color-secondary-container));--mdui-comp-ripple-state-layer-color:var(
--mdui-color-on-secondary-container
)}:host([disabled]:not([disabled=false i])){pointer-events:none}.container{cursor:pointer;-webkit-user-select:none;user-select:none;text-decoration:none;color:inherit;-webkit-tap-highlight-color:transparent}:host([disabled]:not([disabled=false i])) .container{cursor:default;opacity:.38}:host([nonclickable]:not([href],[nonclickable=false i])) .container{cursor:auto;-webkit-user-select:auto;user-select:auto}.preset{display:flex;align-items:center;padding:.5rem 1.5rem .5rem 1rem;min-height:3.5rem}:host([alignment=start]) .preset{align-items:flex-start}:host([alignment=end]) .preset{align-items:flex-end}.body{display:flex;flex:1 1 100%;flex-direction:column;justify-content:center;min-width:0}.headline{display:block;color:rgb(var(--mdui-color-on-surface));font-size:var(--mdui-typescale-body-large-size);font-weight:var(--mdui-typescale-body-large-weight);letter-spacing:var(--mdui-typescale-body-large-tracking);line-height:var(--mdui-typescale-body-large-line-height)}:host([active]:not([active=false i])) .headline{color:rgb(var(--mdui-color-on-secondary-container))}.description{display:none;color:rgb(var(--mdui-color-on-surface-variant));font-size:var(--mdui-typescale-body-medium-size);font-weight:var(--mdui-typescale-body-medium-weight);letter-spacing:var(--mdui-typescale-body-medium-tracking);line-height:var(--mdui-typescale-body-medium-line-height)}:host([disabled]:not([disabled=false i])) .description,:host([focused]) .description,:host([hover]) .description,:host([pressed]) .description{color:rgb(var(--mdui-color-on-surface))}.has-description .description{display:block}:host([description-line='1']) .description,:host([headline-line='1']) .headline{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host([description-line='2']) .description,:host([description-line='3']) .description,:host([headline-line='2']) .headline,:host([headline-line='3']) .headline{display:-webkit-box;overflow:hidden;text-overflow:ellipsis;-webkit-box-orient:vertical}:host([description-line='2']) .description,:host([headline-line='2']) .headline{-webkit-line-clamp:2}:host([description-line='3']) .description,:host([headline-line='3']) .headline{-webkit-line-clamp:3}.end-icon,.icon{display:flex;flex:0 0 auto;font-size:var(--mdui-typescale-label-small-size);font-weight:var(--mdui-typescale-label-small-weight);letter-spacing:var(--mdui-typescale-label-small-tracking);line-height:var(--mdui-typescale-label-small-line-height);color:rgb(var(--mdui-color-on-surface-variant))}:host([disabled]:not([disabled=false i])) .end-icon,:host([disabled]:not([disabled=false i])) .icon,:host([focused]) .end-icon,:host([focused]) .icon,:host([hover]) .end-icon,:host([hover]) .icon,:host([pressed]) .end-icon,:host([pressed]) .icon{color:rgb(var(--mdui-color-on-surface))}:host([active]:not([active=false i])) .end-icon,:host([active]:not([active=false i])) .icon{color:rgb(var(--mdui-color-on-secondary-container))}.end-icon mdui-icon,.icon mdui-icon,.is-end-icon ::slotted([slot=end-icon]),.is-icon ::slotted([slot=icon]){font-size:1.5rem}.has-icon .icon{margin-right:1rem}.has-icon ::slotted(mdui-checkbox[slot=icon]),.has-icon ::slotted(mdui-radio[slot=icon]){margin-left:-.5rem}.has-end-icon .end-icon{margin-left:1rem}.has-end-icon ::slotted(mdui-checkbox[slot=end-icon]),.has-end-icon ::slotted(mdui-radio[slot=end-icon]){margin-right:-.5rem}`;
let ListItem = class ListItem2 extends AnchorMixin(RippleMixin(FocusableMixin(MduiElement))) {
constructor() {
super(...arguments);
this.disabled = false;
this.active = false;
this.nonclickable = false;
this.rounded = false;
this.alignment = "center";
this.rippleRef = e$2();
this.itemRef = e$2();
this.hasSlotController = new HasSlotController(this, "[default]", "description", "icon", "end-icon", "custom");
}
get rippleElement() {
return this.rippleRef.value;
}
get rippleDisabled() {
return this.focusDisabled;
}
get focusElement() {
return this.href && !this.disabled ? this.itemRef.value : this;
}
get focusDisabled() {
return this.href ? this.disabled : this.disabled || this.nonclickable;
}
render() {
const preset = !this.hasSlotController.test("custom");
const hasIcon = this.icon || this.hasSlotController.test("icon");
const hasEndIcon = this.endIcon || this.hasSlotController.test("end-icon");
const hasDescription = this.description || this.hasSlotController.test("description");
const className2 = cc({
container: true,
preset,
"has-icon": hasIcon,
"has-end-icon": hasEndIcon,
"has-description": hasDescription,
// icon slot 中的元素是否为 mdui-icon 或 mdui-icon-* 组件
"is-icon": isNodeName(this.iconElements[0], "mdui-icon"),
// end-icon slot 中的元素是否为 mdui-icon 或 mdui-icon-* 组件
"is-end-icon": getNodeName$1(this.endIconElements[0]).startsWith("mdui-icon-")
});
return x`<mdui-ripple ${n$2(this.rippleRef)} .noRipple="${this.noRipple}"></mdui-ripple>${this.href && !this.disabled ? this.renderAnchor({
className: className2,
content: this.renderInner(),
part: "container",
refDirective: n$2(this.itemRef)
}) : x`<div part="container" class="${className2}" ${n$2(this.itemRef)}>${this.renderInner()}</div>`}`;
}
renderInner() {
const hasDefaultSlot = this.hasSlotController.test("[default]");
return x`<slot name="custom"><slot name="icon" part="icon" class="icon">${this.icon ? x`<mdui-icon name="${this.icon}"></mdui-icon>` : nothingTemplate}</slot><div part="body" class="body">${hasDefaultSlot ? x`<slot part="headline" class="headline"></slot>` : x`<div part="headline" class="headline">${this.headline}</div>`}<slot name="description" part="description" class="description">${this.description}</slot></div><slot name="end-icon" part="end-icon" class="end-icon">${this.endIcon ? x`<mdui-icon name="${this.endIcon}"></mdui-icon>` : nothingTemplate}</slot></slot>`;
}
};
ListItem.styles = [
componentStyle,
listItemStyle
];
__decorate([
n$6({ reflect: true })
], ListItem.prototype, "headline", void 0);
__decorate([
n$6({ type: Number, reflect: true, attribute: "headline-line" })
], ListItem.prototype, "headlineLine", void 0);
__decorate([
n$6({ reflect: true })
], ListItem.prototype, "description", void 0);
__decorate([
n$6({ type: Number, reflect: true, attribute: "description-line" })
], ListItem.prototype, "descriptionLine", void 0);
__decorate([
n$6({ reflect: true })
], ListItem.prototype, "icon", void 0);
__decorate([
n$6({ reflect: true, attribute: "end-icon" })
], ListItem.prototype, "endIcon", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], ListItem.prototype, "disabled", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], ListItem.prototype, "active", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], ListItem.prototype, "nonclickable", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], ListItem.prototype, "rounded", void 0);
__decorate([
n$6({ reflect: true })
], ListItem.prototype, "alignment", void 0);
__decorate([
o$6({ slot: "icon", flatten: true })
], ListItem.prototype, "iconElements", void 0);
__decorate([
o$6({ slot: "end-icon", flatten: true })
], ListItem.prototype, "endIconElements", void 0);
ListItem = __decorate([
t$3("mdui-list-item")
], ListItem);
const listSubheaderStyle = i$7`:host{display:block;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;cursor:default;color:rgb(var(--mdui-color-on-surface-variant));font-size:var(--mdui-typescale-label-small-size);font-weight:var(--mdui-typescale-label-small-weight);letter-spacing:var(--mdui-typescale-label-small-tracking);line-height:var(--mdui-typescale-label-small-line-height);padding-left:1rem;padding-right:1.5rem;height:3.5rem;line-height:3.5rem}`;
let ListSubheader = class ListSubheader2 extends MduiElement {
render() {
return x`<slot></slot>`;
}
};
ListSubheader.styles = [
componentStyle,
listSubheaderStyle
];
ListSubheader = __decorate([
t$3("mdui-list-subheader")
], ListSubheader);
const listStyle = i$7`:host{display:block;padding:.5rem 0}::slotted(mdui-divider[middle]){margin-left:1rem;margin-right:1.5rem}`;
let List = class List2 extends MduiElement {
render() {
return x`<slot></slot>`;
}
};
List.styles = [componentStyle, listStyle];
List = __decorate([
t$3("mdui-list")
], List);
let IconArrowRight = class IconArrowRight2 extends r$3 {
render() {
return svgTag('<path d="m10 17 5-5-5-5v10z"/>');
}
};
IconArrowRight.styles = style$e;
IconArrowRight = __decorate([
t$3("mdui-icon-arrow-right")
], IconArrowRight);
const menuItemStyle = i$7`:host{position:relative;display:block}:host([selected]){background-color:rgba(var(--mdui-color-primary),12%)}:host([disabled]:not([disabled=false i])){pointer-events:none}.container{cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}:host([disabled]:not([disabled=false i])) .container{cursor:default;opacity:.38}.preset{display:flex;align-items:center;text-decoration:none;height:3rem;padding:0 .75rem}.preset.dense{height:2rem}.label-container{flex:1 1 100%;min-width:0}.label{display:block;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;color:rgb(var(--mdui-color-on-surface));font-size:var(--mdui-typescale-label-large-size);font-weight:var(--mdui-typescale-label-large-weight);letter-spacing:var(--mdui-typescale-label-large-tracking)}.end-icon,.end-text,.icon,.selected-icon{display:none;flex:0 0 auto;color:rgb(var(--mdui-color-on-surface-variant))}.has-end-icon .end-icon,.has-end-text .end-text,.has-icon .icon,.has-icon .selected-icon{display:flex}.end-icon,.icon,.selected-icon{font-size:1.5rem}.end-icon::slotted(mdui-avatar),.icon::slotted(mdui-avatar),.selected-icon::slotted(mdui-avatar){width:1.5rem;height:1.5rem}.dense .end-icon,.dense .icon,.dense .selected-icon{font-size:1.125rem}.dense .end-icon::slotted(mdui-avatar),.dense .icon::slotted(mdui-avatar),.dense .selected-icon::slotted(mdui-avatar){width:1.125rem;height:1.125rem}.end-icon .i,.icon .i,.selected-icon .i,::slotted([slot=end-icon]),::slotted([slot=icon]),::slotted([slot=selected-icon]){font-size:inherit}.end-text{font-size:var(--mdui-typescale-label-large-size);font-weight:var(--mdui-typescale-label-large-weight);letter-spacing:var(--mdui-typescale-label-large-tracking);line-height:var(--mdui-typescale-label-large-line-height)}.icon,.selected-icon{margin-right:.75rem}.end-icon,.end-text{margin-left:.75rem}.arrow-right{color:rgb(var(--mdui-color-on-surface))}.submenu{--shape-corner:var(--mdui-shape-corner-extra-small);display:block;position:absolute;z-index:1;border-radius:var(--shape-corner);background-color:rgb(var(--mdui-color-surface-container));box-shadow:var(--mdui-elevation-level2);min-width:7rem;max-width:17.5rem;padding-top:.5rem;padding-bottom:.5rem;--mdui-comp-ripple-state-layer-color:var(--mdui-color-on-surface)}.submenu::slotted(mdui-divider){margin-top:.5rem;margin-bottom:.5rem}`;
let MenuItem = class MenuItem2 extends AnchorMixin(RippleMixin(FocusableMixin(MduiElement))) {
constructor() {
super();
this.disabled = false;
this.submenuOpen = false;
this.selected = false;
this.dense = false;
this.focusable = false;
this.key = uniqueId();
this.rippleRef = e$2();
this.containerRef = e$2();
this.submenuRef = e$2();
this.hasSlotController = new HasSlotController(this, "[default]", "icon", "end-icon", "end-text", "submenu", "custom");
this.definedController = new DefinedController(this, {
relatedElements: [""]
});
this.onOuterClick = this.onOuterClick.bind(this);
this.onFocus = this.onFocus.bind(this);
this.onBlur = this.onBlur.bind(this);
this.onClick = this.onClick.bind(this);
this.onKeydown = this.onKeydown.bind(this);
this.onMouseEnter = this.onMouseEnter.bind(this);
this.onMouseLeave = this.onMouseLeave.bind(this);
}
get focusDisabled() {
return this.disabled || !this.focusable;
}
get focusElement() {
return this.href && !this.disabled ? this.containerRef.value : this;
}
get rippleDisabled() {
return this.disabled;
}
get rippleElement() {
return this.rippleRef.value;
}
get hasSubmenu() {
return this.hasSlotController.test("submenu");
}
async onOpenChange() {
const hasUpdated = this.hasUpdated;
if (!this.submenuOpen && !hasUpdated) {
return;
}
await this.definedController.whenDefined();
if (!hasUpdated) {
await this.updateComplete;
}
const easingLinear = getEasing(this, "linear");
const easingEmphasizedDecelerate = getEasing(this, "emphasized-decelerate");
const easingEmphasizedAccelerate = getEasing(this, "emphasized-accelerate");
if (this.submenuOpen) {
if (hasUpdated) {
const eventProceeded = this.emit("submenu-open", { cancelable: true });
if (!eventProceeded) {
return;
}
}
const duration = getDuration(this, "medium4");
await stopAnimations(this.submenuRef.value);
this.submenuRef.value.hidden = false;
this.updateSubmenuPositioner();
await Promise.all([
animateTo(this.submenuRef.value, [{ transform: "scaleY(0.45)" }, { transform: "scaleY(1)" }], {
duration: hasUpdated ? duration : 0,
easing: easingEmphasizedDecelerate
}),
animateTo(this.submenuRef.value, [{ opacity: 0 }, { opacity: 1, offset: 0.125 }, { opacity: 1 }], {
duration: hasUpdated ? duration : 0,
easing: easingLinear
})
]);
if (hasUpdated) {
this.emit("submenu-opened");
}
} else {
const eventProceeded = this.emit("submenu-close", { cancelable: true });
if (!eventProceeded) {
return;
}
const duration = getDuration(this, "short4");
await stopAnimations(this.submenuRef.value);
await Promise.all([
animateTo(this.submenuRef.value, [{ transform: "scaleY(1)" }, { transform: "scaleY(0.45)" }], { duration, easing: easingEmphasizedAccelerate }),
animateTo(this.submenuRef.value, [{ opacity: 1 }, { opacity: 1, offset: 0.875 }, { opacity: 0 }], { duration, easing: easingLinear })
]);
if (this.submenuRef.value) {
this.submenuRef.value.hidden = true;
}
this.emit("submenu-closed");
}
}
connectedCallback() {
super.connectedCallback();
this.definedController.whenDefined().then(() => {
document.addEventListener("pointerdown", this.onOuterClick);
});
}
disconnectedCallback() {
super.disconnectedCallback();
document.removeEventListener("pointerdown", this.onOuterClick);
}
firstUpdated(changedProperties) {
super.firstUpdated(changedProperties);
this.definedController.whenDefined().then(() => {
this.addEventListener("focus", this.onFocus);
this.addEventListener("blur", this.onBlur);
this.addEventListener("click", this.onClick);
this.addEventListener("keydown", this.onKeydown);
this.addEventListener("mouseenter", this.onMouseEnter);
this.addEventListener("mouseleave", this.onMouseLeave);
});
}
render() {
const hasSubmenu = this.hasSubmenu;
const hasCustomSlot = this.hasSlotController.test("custom");
const hasEndIconSlot = this.hasSlotController.test("end-icon");
const useDefaultEndIcon = !this.endIcon && hasSubmenu && !hasEndIconSlot;
const hasEndIcon = this.endIcon || hasSubmenu || hasEndIconSlot;
const hasIcon = !isUndefined(this.icon) || this.selects === "single" || this.selects === "multiple" || this.hasSlotController.test("icon");
const hasEndText = !!this.endText || this.hasSlotController.test("end-text");
const className2 = cc({
container: true,
dense: this.dense,
preset: !hasCustomSlot,
"has-icon": hasIcon,
"has-end-text": hasEndText,
"has-end-icon": hasEndIcon
});
return x`<mdui-ripple ${n$2(this.rippleRef)} .noRipple="${this.noRipple}"></mdui-ripple>${this.href && !this.disabled ? this.renderAnchor({
part: "container",
className: className2,
content: this.renderInner(useDefaultEndIcon, hasIcon),
refDirective: n$2(this.containerRef),
tabIndex: this.focusable ? 0 : -1
}) : x`<div part="container" ${n$2(this.containerRef)} class="${className2}">${this.renderInner(useDefaultEndIcon, hasIcon)}</div>`} ${n$1(hasSubmenu, () => x`<slot name="submenu" ${n$2(this.submenuRef)} part="submenu" class="submenu" hidden></slot>`)}`;
}
/**
* 点击子菜单外面的区域,关闭子菜单
*/
onOuterClick(event) {
if (!this.disabled && this.submenuOpen && this !== event.target && !$$1.contains(this, event.target)) {
this.submenuOpen = false;
}
}
hasTrigger(trigger) {
return this.submenuTrigger ? this.submenuTrigger.split(" ").includes(trigger) : false;
}
onFocus() {
if (this.disabled || this.submenuOpen || !this.hasTrigger("focus") || !this.hasSubmenu) {
return;
}
this.submenuOpen = true;
}
onBlur() {
if (this.disabled || !this.submenuOpen || !this.hasTrigger("focus") || !this.hasSubmenu) {
return;
}
this.submenuOpen = false;
}
onClick(event) {
if (this.disabled || event.button) {
return;
}
if (!this.hasTrigger("click") || event.target !== this || !this.hasSubmenu) {
return;
}
if (this.submenuOpen && (this.hasTrigger("hover") || this.hasTrigger("focus"))) {
return;
}
this.submenuOpen = !this.submenuOpen;
}
onKeydown(event) {
if (this.disabled || !this.hasSubmenu) {
return;
}
if (!this.submenuOpen && event.key === "Enter") {
event.stopPropagation();
this.submenuOpen = true;
}
if (this.submenuOpen && event.key === "Escape") {
event.stopPropagation();
this.submenuOpen = false;
}
}
onMouseEnter() {
if (this.disabled || !this.hasTrigger("hover") || !this.hasSubmenu) {
return;
}
window.clearTimeout(this.submenuCloseTimeout);
if (this.submenuOpenDelay) {
this.submenuOpenTimeout = window.setTimeout(() => {
this.submenuOpen = true;
}, this.submenuOpenDelay);
} else {
this.submenuOpen = true;
}
}
onMouseLeave() {
if (this.disabled || !this.hasTrigger("hover") || !this.hasSubmenu) {
return;
}
window.clearTimeout(this.submenuOpenTimeout);
this.submenuCloseTimeout = window.setTimeout(() => {
this.submenuOpen = false;
}, this.submenuCloseDelay || 50);
}
// 更新子菜单的位置
updateSubmenuPositioner() {
const $window = $$1(window);
const $submenu = $$1(this.submenuRef.value);
const itemRect = this.getBoundingClientRect();
const submenuWidth = $submenu.innerWidth();
const submenuHeight = $submenu.innerHeight();
const screenMargin = 8;
let placementX = "bottom";
let placementY = "right";
if ($window.height() - itemRect.top > submenuHeight + screenMargin) {
placementX = "bottom";
} else if (itemRect.top + itemRect.height > submenuHeight + screenMargin) {
placementX = "top";
}
if ($window.width() - itemRect.left - itemRect.width > submenuWidth + screenMargin) {
placementY = "right";
} else if (itemRect.left > submenuWidth + screenMargin) {
placementY = "left";
}
$$1(this.submenuRef.value).css({
top: placementX === "bottom" ? 0 : itemRect.height - submenuHeight,
left: placementY === "right" ? itemRect.width : -submenuWidth,
transformOrigin: [
placementY === "right" ? 0 : "100%",
placementX === "bottom" ? 0 : "100%"
].join(" ")
});
}
renderInner(useDefaultEndIcon, hasIcon) {
return x`<slot name="custom">${this.selected ? x`<slot name="selected-icon" part="selected-icon" class="selected-icon">${this.selectedIcon ? x`<mdui-icon name="${this.selectedIcon}" class="i"></mdui-icon>` : x`<mdui-icon-check class="i"></mdui-icon-check>`}</slot>` : x`<slot name="icon" part="icon" class="icon">${hasIcon ? x`<mdui-icon name="${this.icon}" class="i"></mdui-icon>` : nothingTemplate}</slot>`}<div class="label-container"><slot part="label" class="label"></slot></div><slot name="end-text" part="end-text" class="end-text">${this.endText}</slot>${useDefaultEndIcon ? x`<mdui-icon-arrow-right part="end-icon" class="end-icon arrow-right"></mdui-icon-arrow-right>` : x`<slot name="end-icon" part="end-icon" class="end-icon">${this.endIcon ? x`<mdui-icon name="${this.endIcon}"></mdui-icon>` : nothingTemplate}</slot>`}</slot>`;
}
};
MenuItem.styles = [
componentStyle,
menuItemStyle
];
__decorate([
n$6({ reflect: true })
], MenuItem.prototype, "value", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], MenuItem.prototype, "disabled", void 0);
__decorate([
n$6({ reflect: true })
], MenuItem.prototype, "icon", void 0);
__decorate([
n$6({ reflect: true, attribute: "end-icon" })
], MenuItem.prototype, "endIcon", void 0);
__decorate([
n$6({ reflect: true, attribute: "end-text" })
], MenuItem.prototype, "endText", void 0);
__decorate([
n$6({ reflect: true, attribute: "selected-icon" })
], MenuItem.prototype, "selectedIcon", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter,
attribute: "submenu-open"
})
], MenuItem.prototype, "submenuOpen", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], MenuItem.prototype, "selected", void 0);
__decorate([
r$1()
], MenuItem.prototype, "dense", void 0);
__decorate([
r$1()
], MenuItem.prototype, "selects", void 0);
__decorate([
r$1()
], MenuItem.prototype, "submenuTrigger", void 0);
__decorate([
r$1()
], MenuItem.prototype, "submenuOpenDelay", void 0);
__decorate([
r$1()
], MenuItem.prototype, "submenuCloseDelay", void 0);
__decorate([
r$1()
], MenuItem.prototype, "focusable", void 0);
__decorate([
watch("submenuOpen")
], MenuItem.prototype, "onOpenChange", null);
MenuItem = __decorate([
t$3("mdui-menu-item")
], MenuItem);
const menuStyle = i$7`:host{--shape-corner:var(--mdui-shape-corner-extra-small);position:relative;display:block;border-radius:var(--shape-corner);background-color:rgb(var(--mdui-color-surface-container));box-shadow:var(--mdui-elevation-level2);min-width:7rem;max-width:17.5rem;padding-top:.5rem;padding-bottom:.5rem;--mdui-comp-ripple-state-layer-color:var(--mdui-color-on-surface)}::slotted(mdui-divider){margin-top:.5rem;margin-bottom:.5rem}`;
let Menu = class Menu2 extends MduiElement {
constructor() {
super(...arguments);
this.dense = false;
this.submenuTrigger = "click hover";
this.submenuOpenDelay = 200;
this.submenuCloseDelay = 200;
this.selectedKeys = [];
this.isInitial = true;
this.lastActiveItems = [];
this.definedController = new DefinedController(this, {
relatedElements: ["mdui-menu-item"]
});
}
// 菜单项元素(包含子菜单中的菜单项)
get items() {
return $$1(this.childrenItems).find("mdui-menu-item").add(this.childrenItems).get();
}
// 菜单项元素(不包含已禁用的,包含子菜单中的菜单项)
get itemsEnabled() {
return this.items.filter((item) => !item.disabled);
}
// 当前菜单是否为单选
get isSingle() {
return this.selects === "single";
}
// 当前菜单是否为多选
get isMultiple() {
return this.selects === "multiple";
}
// 当前菜单是否可选择
get isSelectable() {
return this.isSingle || this.isMultiple;
}
// 当前菜单是否为子菜单
get isSubmenu() {
return !$$1(this).parent().length;
}
// 最深层级的子菜单中,最后交互过的 menu-item
get lastActiveItem() {
const index = this.lastActiveItems.length ? this.lastActiveItems.length - 1 : 0;
return this.lastActiveItems[index];
}
set lastActiveItem(item) {
const index = this.lastActiveItems.length ? this.lastActiveItems.length - 1 : 0;
this.lastActiveItems[index] = item;
}
async onSlotChange() {
await this.definedController.whenDefined();
this.items.forEach((item) => {
item.dense = this.dense;
item.selects = this.selects;
item.submenuTrigger = this.submenuTrigger;
item.submenuOpenDelay = this.submenuOpenDelay;
item.submenuCloseDelay = this.submenuCloseDelay;
});
}
async onSelectsChange() {
if (!this.isSelectable) {
this.setSelectedKeys([]);
} else if (this.isSingle) {
this.setSelectedKeys(this.selectedKeys.slice(0, 1));
}
await this.onSelectedKeysChange();
}
async onSelectedKeysChange() {
await this.definedController.whenDefined();
const values = this.itemsEnabled.filter((item) => this.selectedKeys.includes(item.key)).map((item) => item.value);
const value = this.isMultiple ? values : values[0] || void 0;
this.setValue(value);
if (!this.isInitial) {
this.emit("change");
}
}
async onValueChange() {
this.isInitial = !this.hasUpdated;
await this.definedController.whenDefined();
if (!this.isSelectable) {
this.updateSelected();
return;
}
const values = (this.isSingle ? [this.value] : (
// 多选时,传入的值可能是字符串(通过 attribute 属性设置);或字符串数组(通过 property 属性设置)
isString(this.value) ? [this.value] : this.value
)).filter((i3) => i3);
if (!values.length) {
this.setSelectedKeys([]);
} else if (this.isSingle) {
const firstItem = this.itemsEnabled.find((item) => item.value === values[0]);
this.setSelectedKeys(firstItem ? [firstItem.key] : []);
} else if (this.isMultiple) {
this.setSelectedKeys(this.itemsEnabled.filter((item) => values.includes(item.value)).map((item) => item.key));
}
this.updateSelected();
this.updateFocusable();
}
/**
* 将焦点设置在当前元素上
*/
focus(options) {
if (this.lastActiveItem) {
this.focusOne(this.lastActiveItem, options);
}
}
/**
* 从当前元素中移除焦点
*/
blur() {
if (this.lastActiveItem) {
this.lastActiveItem.blur();
}
}
firstUpdated(changedProperties) {
super.firstUpdated(changedProperties);
this.definedController.whenDefined().then(() => {
this.updateFocusable();
this.lastActiveItem = this.items.find((item) => item.focusable);
});
this.addEventListener("submenu-open", (e3) => {
const $parentItem = $$1(e3.target);
const submenuItemsEnabled = $parentItem.children("mdui-menu-item:not([disabled])").get();
const submenuLevel = $parentItem.parents("mdui-menu-item").length + 1;
if (submenuItemsEnabled.length) {
this.lastActiveItems[submenuLevel] = submenuItemsEnabled[0];
this.updateFocusable();
this.focusOne(this.lastActiveItems[submenuLevel]);
}
});
this.addEventListener("submenu-close", (e3) => {
const $parentItem = $$1(e3.target);
const submenuLevel = $parentItem.parents("mdui-menu-item").length + 1;
if (this.lastActiveItems.length - 1 === submenuLevel) {
this.lastActiveItems.pop();
this.updateFocusable();
if (this.lastActiveItems[submenuLevel - 1]) {
this.focusOne(this.lastActiveItems[submenuLevel - 1]);
}
}
});
}
render() {
return x`<slot @slotchange="${this.onSlotChange}" @click="${this.onClick}" @keydown="${this.onKeyDown}"></slot>`;
}
setSelectedKeys(selectedKeys) {
if (!arraysEqualIgnoreOrder(this.selectedKeys, selectedKeys)) {
this.selectedKeys = selectedKeys;
}
}
setValue(value) {
if (this.isSingle || isUndefined(this.value) || isUndefined(value)) {
this.value = value;
} else if (!arraysEqualIgnoreOrder(this.value, value)) {
this.value = value;
}
}
// 获取和指定菜单项同级的所有菜单项
getSiblingsItems(item, onlyEnabled = false) {
return $$1(item).parent().children(`mdui-menu-item${onlyEnabled ? ":not([disabled])" : ""}`).get();
}
// 更新 menu-item 的可聚焦状态
updateFocusable() {
if (this.lastActiveItem) {
this.items.forEach((item) => {
item.focusable = item.key === this.lastActiveItem.key;
});
return;
}
if (!this.selectedKeys.length) {
this.itemsEnabled.forEach((item, index) => {
item.focusable = !index;
});
return;
}
if (this.isSingle) {
this.items.forEach((item) => {
item.focusable = this.selectedKeys.includes(item.key);
});
return;
}
if (this.isMultiple) {
const focusableItem = this.items.find((item) => item.focusable);
if (!(focusableItem == null ? void 0 : focusableItem.key) || !this.selectedKeys.includes(focusableItem.key)) {
this.itemsEnabled.filter((item) => this.selectedKeys.includes(item.key)).forEach((item, index) => item.focusable = !index);
}
}
}
updateSelected() {
this.items.forEach((item) => {
item.selected = this.selectedKeys.includes(item.key);
});
}
// 切换一个菜单项的选中状态
selectOne(item) {
if (this.isMultiple) {
const selectedKeys = [...this.selectedKeys];
if (selectedKeys.includes(item.key)) {
selectedKeys.splice(selectedKeys.indexOf(item.key), 1);
} else {
selectedKeys.push(item.key);
}
this.setSelectedKeys(selectedKeys);
}
if (this.isSingle) {
if (this.selectedKeys.includes(item.key)) {
this.setSelectedKeys([]);
} else {
this.setSelectedKeys([item.key]);
}
}
this.isInitial = false;
this.updateSelected();
}
// 使一个 menu-item 可聚焦
async focusableOne(item) {
this.items.forEach((_item) => _item.focusable = _item.key === item.key);
await delay();
}
// 聚焦一个 menu-item
focusOne(item, options) {
item.focus(options);
}
async onClick(event) {
if (!this.definedController.isDefined()) {
return;
}
if (this.isSubmenu) {
return;
}
if (event.button) {
return;
}
const target = event.target;
const item = target.closest("mdui-menu-item");
if (!item || item.disabled) {
return;
}
this.lastActiveItem = item;
if (this.isSelectable && item.value) {
this.selectOne(item);
}
await this.focusableOne(item);
this.focusOne(item);
}
async onKeyDown(event) {
if (!this.definedController.isDefined()) {
return;
}
if (this.isSubmenu) {
return;
}
const item = event.target;
if (event.key === "Enter") {
event.preventDefault();
item.click();
}
if (event.key === " ") {
event.preventDefault();
if (this.isSelectable && item.value) {
this.selectOne(item);
await this.focusableOne(item);
this.focusOne(item);
}
}
if (["ArrowUp", "ArrowDown", "Home", "End"].includes(event.key)) {
const items = this.getSiblingsItems(item, true);
const activeItem = items.find((item2) => item2.focusable);
let index = activeItem ? items.indexOf(activeItem) : 0;
if (items.length > 0) {
event.preventDefault();
if (event.key === "ArrowDown") {
index++;
} else if (event.key === "ArrowUp") {
index--;
} else if (event.key === "Home") {
index = 0;
} else if (event.key === "End") {
index = items.length - 1;
}
if (index < 0) {
index = items.length - 1;
}
if (index > items.length - 1) {
index = 0;
}
this.lastActiveItem = items[index];
await this.focusableOne(items[index]);
this.focusOne(items[index]);
return;
}
}
}
};
Menu.styles = [componentStyle, menuStyle];
__decorate([
n$6({ reflect: true })
// eslint-disable-next-line prettier/prettier
], Menu.prototype, "selects", void 0);
__decorate([
n$6()
], Menu.prototype, "value", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Menu.prototype, "dense", void 0);
__decorate([
n$6({ reflect: true, attribute: "submenu-trigger" })
], Menu.prototype, "submenuTrigger", void 0);
__decorate([
n$6({ type: Number, reflect: true, attribute: "submenu-open-delay" })
], Menu.prototype, "submenuOpenDelay", void 0);
__decorate([
n$6({ type: Number, reflect: true, attribute: "submenu-close-delay" })
], Menu.prototype, "submenuCloseDelay", void 0);
__decorate([
r$1()
], Menu.prototype, "selectedKeys", void 0);
__decorate([
o$6({ flatten: true, selector: "mdui-menu-item" })
], Menu.prototype, "childrenItems", void 0);
__decorate([
watch("dense"),
watch("selects"),
watch("submenuTrigger"),
watch("submenuOpenDelay"),
watch("submenuCloseDelay")
], Menu.prototype, "onSlotChange", null);
__decorate([
watch("selects", true)
], Menu.prototype, "onSelectsChange", null);
__decorate([
watch("selectedKeys", true)
], Menu.prototype, "onSelectedKeysChange", null);
__decorate([
watch("value")
], Menu.prototype, "onValueChange", null);
Menu = __decorate([
t$3("mdui-menu")
], Menu);
const navigationBarItemStyle = i$7`:host{--shape-corner-indicator:var(--mdui-shape-corner-full);position:relative;z-index:0;flex:1;overflow:hidden;min-width:3rem;--mdui-comp-ripple-state-layer-color:var(--mdui-color-on-surface-variant)}.container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-decoration:none;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;padding-top:.75rem;padding-bottom:.75rem}.container:not(.initial){transition:padding var(--mdui-motion-duration-short4) var(--mdui-motion-easing-standard)}mdui-ripple{z-index:1;left:50%;transform:translateX(-50%);width:4rem;height:2rem;margin-top:.75rem;border-radius:var(--mdui-shape-corner-full)}mdui-ripple:not(.initial){transition:margin-top var(--mdui-motion-duration-short4) var(--mdui-motion-easing-standard)}.indicator{position:relative;display:flex;align-items:center;justify-content:center;background-color:transparent;border-radius:var(--shape-corner-indicator);height:2rem;width:2rem}:not(.initial) .indicator{transition:background-color var(--mdui-motion-duration-short1) var(--mdui-motion-easing-standard),width var(--mdui-motion-duration-short4) var(--mdui-motion-easing-standard)}::slotted([slot=badge]){position:absolute;transform:translate(50%,-50%)}::slotted([slot=badge][variant=small]){transform:translate(.5625rem,-.5625rem)}.active-icon,.icon{color:rgb(var(--mdui-color-on-surface-variant));font-size:1.5rem}.active-icon mdui-icon,.icon mdui-icon,::slotted([slot=active]),::slotted([slot=icon]){font-size:inherit}.icon{display:flex}.active-icon{display:none}.label{display:flex;align-items:center;height:1rem;color:rgb(var(--mdui-color-on-surface-variant));margin-top:.25rem;margin-bottom:.25rem;font-size:var(--mdui-typescale-label-medium-size);font-weight:var(--mdui-typescale-label-medium-weight);letter-spacing:var(--mdui-typescale-label-medium-tracking);line-height:var(--mdui-typescale-label-medium-line-height)}:not(.initial) .label{transition:opacity var(--mdui-motion-duration-short4) var(--mdui-motion-easing-linear)}:host(:not([active])) mdui-ripple.label-visibility-selected,mdui-ripple.label-visibility-unlabeled{margin-top:1.5rem}.container.label-visibility-unlabeled,:host(:not([active])) .container.label-visibility-selected{padding-top:1.5rem;padding-bottom:0}.container.label-visibility-unlabeled .label,:host(:not([active])) .container.label-visibility-selected .label{opacity:0}:host([active]){--mdui-comp-ripple-state-layer-color:var(--mdui-color-on-surface)}:host([active]) .indicator{width:4rem;background-color:rgb(var(--mdui-color-secondary-container))}:host([active]) .active-icon,:host([active]) .icon{color:rgb(var(--mdui-color-on-secondary-container))}:host([active]) .has-active-icon .active-icon{display:flex}:host([active]) .has-active-icon .icon{display:none}:host([active]) .label{color:rgb(var(--mdui-color-on-surface))}`;
let NavigationBarItem = class NavigationBarItem2 extends AnchorMixin(RippleMixin(FocusableMixin(MduiElement))) {
constructor() {
super(...arguments);
this.isInitial = true;
this.active = false;
this.disabled = false;
this.key = uniqueId();
this.rippleRef = e$2();
this.hasSlotController = new HasSlotController(this, "active-icon");
}
get rippleElement() {
return this.rippleRef.value;
}
get rippleDisabled() {
return this.disabled;
}
get focusElement() {
var _a2;
return this.href ? (_a2 = this.renderRoot) == null ? void 0 : _a2.querySelector("._a") : this;
}
get focusDisabled() {
return this.disabled;
}
render() {
const labelVisibilityClassName = cc({
"label-visibility-selected": this.labelVisibility === "selected",
"label-visibility-labeled": this.labelVisibility === "labeled",
"label-visibility-unlabeled": this.labelVisibility === "unlabeled",
initial: this.isInitial
});
const className2 = cc([
{
container: true,
"has-active-icon": this.activeIcon || this.hasSlotController.test("active-icon")
},
labelVisibilityClassName
]);
return x`<mdui-ripple .noRipple="${!this.active || this.noRipple}" class="${labelVisibilityClassName}" ${n$2(this.rippleRef)}></mdui-ripple>${this.href ? this.renderAnchor({
part: "container",
className: className2,
content: this.renderInner()
}) : x`<div part="container" class="${className2}">${this.renderInner()}</div>`}`;
}
renderInner() {
return x`<div part="indicator" class="indicator"><slot name="badge" part="badge" class="badge"></slot><slot name="active-icon" part="active-icon" class="active-icon">${this.activeIcon ? x`<mdui-icon name="${this.activeIcon}"></mdui-icon>` : nothingTemplate}</slot><slot name="icon" part="icon" class="icon">${this.icon ? x`<mdui-icon name="${this.icon}"></mdui-icon>` : nothingTemplate}</slot></div><slot part="label" class="label"></slot>`;
}
};
NavigationBarItem.styles = [
componentStyle,
navigationBarItemStyle
];
__decorate([
n$6({ reflect: true })
], NavigationBarItem.prototype, "icon", void 0);
__decorate([
n$6({ reflect: true, attribute: "active-icon" })
], NavigationBarItem.prototype, "activeIcon", void 0);
__decorate([
n$6({ reflect: true })
], NavigationBarItem.prototype, "value", void 0);
__decorate([
r$1()
], NavigationBarItem.prototype, "labelVisibility", void 0);
__decorate([
r$1()
], NavigationBarItem.prototype, "isInitial", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], NavigationBarItem.prototype, "active", void 0);
__decorate([
r$1()
], NavigationBarItem.prototype, "disabled", void 0);
NavigationBarItem = __decorate([
t$3("mdui-navigation-bar-item")
], NavigationBarItem);
const navigationBarStyle = i$7`:host{--shape-corner:var(--mdui-shape-corner-none);--z-index:2000;position:fixed;right:0;bottom:0;left:0;display:flex;flex:0 0 auto;overflow:hidden;border-radius:var(--shape-corner) var(--shape-corner) 0 0;z-index:var(--z-index);transition-property:transform;transition-duration:var(--mdui-motion-duration-long2);transition-timing-function:var(--mdui-motion-easing-emphasized);height:5rem;background-color:rgb(var(--mdui-color-surface));box-shadow:var(--mdui-elevation-level2)}:host([scroll-target]:not([scroll-target=''])){position:absolute}:host([hide]:not([hide=false i])){transform:translateY(5.625rem);transition-duration:var(--mdui-motion-duration-short4)}`;
let NavigationBar = class NavigationBar2 extends ScrollBehaviorMixin(LayoutItemBase) {
constructor() {
super(...arguments);
this.hide = false;
this.labelVisibility = "auto";
this.activeKey = 0;
this.isInitial = true;
this.definedController = new DefinedController(this, {
relatedElements: ["mdui-navigation-bar-item"]
});
}
get scrollPaddingPosition() {
return "bottom";
}
get layoutPlacement() {
return "bottom";
}
async onActiveKeyChange() {
await this.definedController.whenDefined();
const item = this.items.find((item2) => item2.key === this.activeKey);
this.value = item == null ? void 0 : item.value;
if (!this.isInitial) {
this.emit("change");
}
}
async onValueChange() {
this.isInitial = !this.hasUpdated;
await this.definedController.whenDefined();
const item = this.items.find((item2) => item2.value === this.value);
this.activeKey = (item == null ? void 0 : item.key) ?? 0;
this.updateItems();
}
async onLabelVisibilityChange() {
await this.definedController.whenDefined();
this.updateItems();
}
firstUpdated(_changedProperties) {
super.firstUpdated(_changedProperties);
this.addEventListener("transitionend", (event) => {
if (event.target === this) {
this.emit(this.hide ? "hidden" : "shown");
}
});
}
render() {
return x`<slot @slotchange="${this.onSlotChange}" @click="${this.onClick}"></slot>`;
}
/**
* 滚动行为
* 当前仅支持 hide 这一个行为,所以不做行为类型判断
*/
runScrollThreshold(isScrollingUp) {
if (!isScrollingUp && !this.hide) {
const eventProceeded = this.emit("hide", { cancelable: true });
if (eventProceeded) {
this.hide = true;
}
}
if (isScrollingUp && this.hide) {
const eventProceeded = this.emit("show", { cancelable: true });
if (eventProceeded) {
this.hide = false;
}
}
}
onClick(event) {
if (event.button) {
return;
}
const target = event.target;
const item = target.closest("mdui-navigation-bar-item");
if (!item) {
return;
}
this.activeKey = item.key;
this.isInitial = false;
this.updateItems();
}
// 更新 <mdui-navigation-bar-item> 的状态
updateItems() {
const items = this.items;
const labelVisibility = this.labelVisibility === "auto" ? items.length <= 3 ? "labeled" : "selected" : this.labelVisibility;
items.forEach((item) => {
item.active = this.activeKey === item.key;
item.labelVisibility = labelVisibility;
item.isInitial = this.isInitial;
});
}
async onSlotChange() {
await this.definedController.whenDefined();
this.updateItems();
}
};
NavigationBar.styles = [
componentStyle,
navigationBarStyle
];
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], NavigationBar.prototype, "hide", void 0);
__decorate([
n$6({ reflect: true, attribute: "label-visibility" })
], NavigationBar.prototype, "labelVisibility", void 0);
__decorate([
n$6({ reflect: true })
], NavigationBar.prototype, "value", void 0);
__decorate([
n$6({ reflect: true, attribute: "scroll-behavior" })
], NavigationBar.prototype, "scrollBehavior", void 0);
__decorate([
r$1()
], NavigationBar.prototype, "activeKey", void 0);
__decorate([
o$6({
selector: "mdui-navigation-bar-item",
flatten: true
})
], NavigationBar.prototype, "items", void 0);
__decorate([
watch("activeKey", true)
], NavigationBar.prototype, "onActiveKeyChange", null);
__decorate([
watch("value")
], NavigationBar.prototype, "onValueChange", null);
__decorate([
watch("labelVisibility", true)
], NavigationBar.prototype, "onLabelVisibilityChange", null);
NavigationBar = __decorate([
t$3("mdui-navigation-bar")
], NavigationBar);
const breakpoint = (width) => {
const window2 = getWindow$1();
const document2 = getDocument();
const computedStyle = window2.getComputedStyle(document2.documentElement);
const containerWidth = isElement(width) ? $$1(width).innerWidth() : isNumber(width) ? width : $$1(window2).innerWidth();
const getBreakpointValue = (breakpoint2) => {
const width2 = computedStyle.getPropertyValue(`--mdui-breakpoint-${breakpoint2}`).toLowerCase();
return parseFloat(width2);
};
const getNextBreakpoint = (breakpoint2) => {
switch (breakpoint2) {
case "xs":
return "sm";
case "sm":
return "md";
case "md":
return "lg";
case "lg":
return "xl";
case "xl":
return "xxl";
}
};
return {
/**
* 当前宽度是否大于指定断点值
* @param breakpoint
*/
up(breakpoint2) {
return containerWidth >= getBreakpointValue(breakpoint2);
},
/**
* 当前宽度是否小于指定断点值
* @param breakpoint
*/
down(breakpoint2) {
return containerWidth < getBreakpointValue(breakpoint2);
},
/**
* 当前宽度是否在指定断点值内
* @param breakpoint
*/
only(breakpoint2) {
if (breakpoint2 === "xxl") {
return this.up(breakpoint2);
} else {
return this.up(breakpoint2) && this.down(getNextBreakpoint(breakpoint2));
}
},
/**
* 当前宽度是否不在指定断点值内
* @param breakpoint
*/
not(breakpoint2) {
return !this.only(breakpoint2);
},
/**
* 当前宽度是否在指定断点值之间
* @param startBreakpoint
* @param endBreakpoint
* @returns
*/
between(startBreakpoint, endBreakpoint) {
return this.up(startBreakpoint) && this.down(endBreakpoint);
}
};
};
const style$6 = i$7`:host{--shape-corner:var(--mdui-shape-corner-large);--z-index:2200;display:none;position:fixed;top:0;bottom:0;left:0;z-index:1;width:22.5rem}:host([placement=right]){left:initial;right:0}:host([mobile]),:host([modal]:not([modal=false i])){top:0!important;right:0;bottom:0!important;width:initial;z-index:var(--z-index)}:host([placement=right][mobile]),:host([placement=right][modal]:not([modal=false i])){left:0}:host([contained]:not([contained=false i])){position:absolute}.overlay{position:absolute;inset:0;z-index:inherit;background-color:rgba(var(--mdui-color-scrim),.4)}.panel{display:block;position:absolute;top:0;bottom:0;left:0;width:100%;overflow:auto;z-index:inherit;background-color:rgb(var(--mdui-color-surface));box-shadow:var(--mdui-elevation-level0)}:host([mobile]) .panel,:host([modal]:not([modal=false i])) .panel{border-radius:0 var(--shape-corner) var(--shape-corner) 0;max-width:80%;width:22.5rem;background-color:rgb(var(--mdui-color-surface-container-low));box-shadow:var(--mdui-elevation-level1)}:host([placement=right]) .panel{left:initial;right:0}:host([placement=right][mobile]) .panel,:host([placement=right][modal]:not([modal=false i])) .panel{border-radius:var(--shape-corner) 0 0 var(--shape-corner)}`;
let NavigationDrawer = class NavigationDrawer2 extends LayoutItemBase {
constructor() {
super(...arguments);
this.open = false;
this.modal = false;
this.closeOnEsc = false;
this.closeOnOverlayClick = false;
this.placement = "left";
this.contained = false;
this.mobile = false;
this.overlayRef = e$2();
this.panelRef = e$2();
this.definedController = new DefinedController(this, {
needDomReady: true
});
}
get layoutPlacement() {
return this.placement;
}
get lockTarget() {
return this.contained || this.isParentLayout ? this.parentElement : document.documentElement;
}
get isModal() {
return this.mobile || this.modal;
}
// contained 变更后,修改监听尺寸变化的元素。为 true 时,监听父元素;为 false 时,监听 body
async onContainedChange() {
var _a2;
await this.definedController.whenDefined();
(_a2 = this.observeResize) == null ? void 0 : _a2.unobserve();
this.setObserveResize();
}
onPlacementChange() {
if (this.isParentLayout) {
this.layoutManager.updateLayout(this);
}
}
async onMobileChange() {
if (!this.open || this.isParentLayout || this.contained) {
return;
}
await this.definedController.whenDefined();
if (this.isModal) {
lockScreen(this, this.lockTarget);
await this.getLockTargetAnimate(false, 0);
} else {
unlockScreen(this, this.lockTarget);
await this.getLockTargetAnimate(true, 0);
}
}
async onOpenChange() {
let panel = this.panelRef.value;
let overlay = this.overlayRef.value;
const isRight = this.placement === "right";
const easingLinear = getEasing(this, "linear");
const easingEmphasized = getEasing(this, "emphasized");
const setLayoutTransition = (duration, easing) => {
$$1(this.layoutManager.getItemsAndMain()).css("transition", isNull(duration) ? null : `all ${duration}ms ${easing}`);
};
const stopOldAnimations = async () => {
const elements = [];
if (this.isModal) {
elements.push(overlay, panel);
} else if (!this.isParentLayout) {
elements.push(this.lockTarget);
}
if (this.isParentLayout) {
const layoutItems = this.layoutManager.getItemsAndMain();
const layoutIndex = layoutItems.indexOf(this);
elements.push(...layoutItems.slice(layoutIndex));
}
if (!this.isModal && !elements.includes(this)) {
elements.push(this);
}
await Promise.all(elements.map((element) => stopAnimations(element)));
};
if (this.open) {
const hasUpdated = this.hasUpdated;
if (!hasUpdated) {
await this.updateComplete;
panel = this.panelRef.value;
overlay = this.overlayRef.value;
}
if (hasUpdated) {
const eventProceeded = this.emit("open", { cancelable: true });
if (!eventProceeded) {
return;
}
}
await this.definedController.whenDefined();
this.style.display = "block";
this.originalTrigger = document.activeElement;
if (this.isModal) {
this.modalHelper.activate();
if (!this.contained) {
lockScreen(this, this.lockTarget);
}
}
await stopOldAnimations();
requestAnimationFrame(() => {
const autoFocusTarget = this.querySelector("[autofocus]");
if (autoFocusTarget) {
autoFocusTarget.focus({ preventScroll: true });
} else {
panel.focus({ preventScroll: true });
}
});
const duration = getDuration(this, "long2");
const animations = [];
if (this.isModal) {
animations.push(animateTo(overlay, [{ opacity: 0 }, { opacity: 1, offset: 0.3 }, { opacity: 1 }], {
duration: hasUpdated ? duration : 0,
easing: easingLinear
}));
} else if (!this.isParentLayout) {
animations.push(this.getLockTargetAnimate(true, hasUpdated ? duration : 0));
}
if (this.isParentLayout && hasUpdated) {
setLayoutTransition(duration, easingEmphasized);
this.layoutManager.updateLayout(this);
}
animations.push(animateTo(this.isModal ? panel : this, [
{ transform: `translateX(${isRight ? "" : "-"}100%)` },
{ transform: "translateX(0)" }
], {
duration: hasUpdated ? duration : 0,
easing: easingEmphasized
}));
await Promise.all(animations);
if (!this.open) {
return;
}
if (this.isParentLayout && hasUpdated) {
setLayoutTransition(null);
}
if (hasUpdated) {
this.emit("opened");
}
} else if (this.hasUpdated) {
const eventProceeded = this.emit("close", { cancelable: true });
if (!eventProceeded) {
return;
}
await this.definedController.whenDefined();
if (this.isModal) {
this.modalHelper.deactivate();
}
await stopOldAnimations();
const duration = getDuration(this, "short4");
const animations = [];
if (this.isModal) {
animations.push(animateTo(overlay, [{ opacity: 1 }, { opacity: 0 }], {
duration,
easing: easingLinear
}));
} else if (!this.isParentLayout) {
animations.push(this.getLockTargetAnimate(false, duration));
}
if (this.isParentLayout) {
setLayoutTransition(duration, easingEmphasized);
this.layoutManager.updateLayout(this, { width: 0 });
}
animations.push(animateTo(this.isModal ? panel : this, [
{ transform: "translateX(0)" },
{ transform: `translateX(${isRight ? "" : "-"}100%)` }
], { duration, easing: easingEmphasized }));
await Promise.all(animations);
if (this.open) {
return;
}
if (this.isParentLayout) {
setLayoutTransition(null);
}
this.style.display = "none";
if (this.isModal && !this.contained) {
unlockScreen(this, this.lockTarget);
}
const trigger = this.originalTrigger;
if (isFunction(trigger == null ? void 0 : trigger.focus)) {
setTimeout(() => trigger.focus());
}
this.emit("closed");
}
}
connectedCallback() {
super.connectedCallback();
this.modalHelper = new Modal(this);
this.definedController.whenDefined().then(() => {
this.setObserveResize();
});
}
disconnectedCallback() {
var _a2;
super.disconnectedCallback();
unlockScreen(this, this.lockTarget);
(_a2 = this.observeResize) == null ? void 0 : _a2.unobserve();
}
firstUpdated(_changedProperties) {
super.firstUpdated(_changedProperties);
this.addEventListener("keydown", (event) => {
if (this.open && this.closeOnEsc && event.key === "Escape" && this.isModal) {
event.stopPropagation();
this.open = false;
}
});
}
render() {
return x`${n$1(this.isModal, () => x`<div ${n$2(this.overlayRef)} part="overlay" class="overlay" @click="${this.onOverlayClick}"></div>`)}<slot ${n$2(this.panelRef)} part="panel" class="panel" tabindex="0"></slot>`;
}
setObserveResize() {
this.observeResize = observeResize(this.contained ? this.parentElement : document.documentElement, () => {
const target = this.contained ? this.parentElement : void 0;
this.mobile = breakpoint(target).down("md");
if (this.isParentLayout) {
this.layoutManager.updateLayout(this, {
width: this.isModal ? 0 : void 0
});
}
});
}
onOverlayClick() {
this.emit("overlay-click");
if (this.closeOnOverlayClick) {
this.open = false;
}
}
getLockTargetAnimate(open2, duration) {
const paddingName = this.placement === "right" ? "paddingRight" : "paddingLeft";
const panelWidth = $$1(this.panelRef.value).innerWidth() + "px";
return animateTo(this.lockTarget, [
{ [paddingName]: open2 ? 0 : panelWidth },
{ [paddingName]: open2 ? panelWidth : 0 }
], {
duration,
easing: getEasing(this, "emphasized"),
fill: "forwards"
});
}
};
NavigationDrawer.styles = [componentStyle, style$6];
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], NavigationDrawer.prototype, "open", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], NavigationDrawer.prototype, "modal", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter,
attribute: "close-on-esc"
})
], NavigationDrawer.prototype, "closeOnEsc", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter,
attribute: "close-on-overlay-click"
})
], NavigationDrawer.prototype, "closeOnOverlayClick", void 0);
__decorate([
n$6({ reflect: true })
// eslint-disable-next-line prettier/prettier
], NavigationDrawer.prototype, "placement", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], NavigationDrawer.prototype, "contained", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], NavigationDrawer.prototype, "mobile", void 0);
__decorate([
watch("contained", true)
], NavigationDrawer.prototype, "onContainedChange", null);
__decorate([
watch("placement", true)
], NavigationDrawer.prototype, "onPlacementChange", null);
__decorate([
watch("mobile", true),
watch("modal", true)
], NavigationDrawer.prototype, "onMobileChange", null);
__decorate([
watch("open")
], NavigationDrawer.prototype, "onOpenChange", null);
NavigationDrawer = __decorate([
t$3("mdui-navigation-drawer")
], NavigationDrawer);
const navigationRailStyle = i$7`:host{--shape-corner:var(--mdui-shape-corner-none);--z-index:2000;position:fixed;top:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;border-radius:0 var(--shape-corner) var(--shape-corner) 0;z-index:var(--z-index);width:5rem;background-color:rgb(var(--mdui-color-surface));padding:.375rem .75rem}:host([contained]:not([contained=false i])){position:absolute}:host([divider]:not([divider=false i])){border-right:.0625rem solid rgb(var(--mdui-color-surface-variant));width:5.0625rem}:host([placement=right]){left:initial;right:0;border-radius:var(--shape-corner) 0 0 var(--shape-corner)}:host([placement=right][divider]:not([divider=false i])){border-right:none;border-left:.0625rem solid rgb(var(--mdui-color-surface-variant))}.bottom,.items,.top{display:flex;flex-direction:column;align-items:center;width:100%}.top{margin-bottom:1.75rem}.bottom{margin-top:1.75rem}::slotted([slot=bottom]),::slotted([slot=top]),::slotted(mdui-navigation-rail-item){margin-top:.375rem;margin-bottom:.375rem}:host([alignment=start]) .top-spacer{flex-grow:0}:host([alignment=start]) .bottom-spacer{flex-grow:1}:host([alignment=end]) .top-spacer{flex-grow:1}:host([alignment=end]) .bottom-spacer{flex-grow:0}:host([alignment=center]){justify-content:center}:host([alignment=center]) .bottom,:host([alignment=center]) .top{position:absolute}:host([alignment=center]) .top{top:.375rem}:host([alignment=center]) .bottom{bottom:.375rem}`;
let NavigationRail = class NavigationRail2 extends LayoutItemBase {
constructor() {
super(...arguments);
this.placement = "left";
this.alignment = "start";
this.contained = false;
this.divider = false;
this.activeKey = 0;
this.hasSlotController = new HasSlotController(this, "top", "bottom");
this.definedController = new DefinedController(this, {
relatedElements: ["mdui-navigation-rail-item"]
});
this.isInitial = true;
}
get layoutPlacement() {
return this.placement;
}
get parentTarget() {
return this.contained || this.isParentLayout ? this.parentElement : document.body;
}
get isRight() {
return this.placement === "right";
}
get paddingValue() {
return ["fixed", "absolute"].includes($$1(this).css("position")) ? this.offsetWidth : void 0;
}
async onActiveKeyChange() {
await this.definedController.whenDefined();
const item = this.items.find((item2) => item2.key === this.activeKey);
this.value = item == null ? void 0 : item.value;
if (!this.isInitial) {
this.emit("change");
}
}
async onValueChange() {
this.isInitial = !this.hasUpdated;
await this.definedController.whenDefined();
const item = this.items.find((item2) => item2.value === this.value);
this.activeKey = (item == null ? void 0 : item.key) ?? 0;
this.updateItems();
}
async onContainedChange() {
if (this.isParentLayout) {
return;
}
await this.definedController.whenDefined();
$$1(document.body).css({
paddingLeft: this.contained || this.isRight ? null : this.paddingValue,
paddingRight: this.contained || !this.isRight ? null : this.paddingValue
});
$$1(this.parentElement).css({
paddingLeft: this.contained && !this.isRight ? this.paddingValue : null,
paddingRight: this.contained && this.isRight ? this.paddingValue : null
});
}
async onPlacementChange() {
var _a2;
await this.definedController.whenDefined();
(_a2 = this.layoutManager) == null ? void 0 : _a2.updateLayout(this);
this.items.forEach((item) => {
item.placement = this.placement;
});
if (!this.isParentLayout) {
$$1(this.parentTarget).css({
paddingLeft: this.isRight ? null : this.paddingValue,
paddingRight: this.isRight ? this.paddingValue : null
});
}
}
connectedCallback() {
super.connectedCallback();
if (!this.isParentLayout) {
this.definedController.whenDefined().then(() => {
$$1(this.parentTarget).css({
paddingLeft: this.isRight ? null : this.paddingValue,
paddingRight: this.isRight ? this.paddingValue : null
});
});
}
}
disconnectedCallback() {
super.disconnectedCallback();
if (!this.isParentLayout && this.definedController.isDefined()) {
$$1(this.parentTarget).css({
paddingLeft: this.isRight ? void 0 : null,
paddingRight: this.isRight ? null : void 0
});
}
}
render() {
const hasTopSlot = this.hasSlotController.test("top");
const hasBottomSlot = this.hasSlotController.test("bottom");
return x`${n$1(hasTopSlot, () => x`<slot name="top" part="top" class="top"></slot>`)} <span class="top-spacer"></span><slot part="items" class="items" @slotchange="${this.onSlotChange}" @click="${this.onClick}"></slot><span class="bottom-spacer"></span> ${n$1(hasBottomSlot, () => x`<slot name="bottom" part="bottom" class="bottom"></slot>`)}`;
}
onClick(event) {
if (event.button) {
return;
}
const target = event.target;
const item = target.closest("mdui-navigation-rail-item");
if (!item) {
return;
}
this.activeKey = item.key;
this.isInitial = false;
this.updateItems();
}
updateItems() {
this.items.forEach((item) => {
item.active = this.activeKey === item.key;
item.placement = this.placement;
item.isInitial = this.isInitial;
});
}
async onSlotChange() {
await this.definedController.whenDefined();
this.updateItems();
}
};
NavigationRail.styles = [
componentStyle,
navigationRailStyle
];
__decorate([
n$6({ reflect: true })
], NavigationRail.prototype, "value", void 0);
__decorate([
n$6({ reflect: true })
// eslint-disable-next-line prettier/prettier
], NavigationRail.prototype, "placement", void 0);
__decorate([
n$6({ reflect: true })
], NavigationRail.prototype, "alignment", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], NavigationRail.prototype, "contained", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], NavigationRail.prototype, "divider", void 0);
__decorate([
r$1()
], NavigationRail.prototype, "activeKey", void 0);
__decorate([
o$6({
selector: "mdui-navigation-rail-item",
flatten: true
})
], NavigationRail.prototype, "items", void 0);
__decorate([
watch("activeKey", true)
], NavigationRail.prototype, "onActiveKeyChange", null);
__decorate([
watch("value")
], NavigationRail.prototype, "onValueChange", null);
__decorate([
watch("contained", true)
], NavigationRail.prototype, "onContainedChange", null);
__decorate([
watch("placement", true)
], NavigationRail.prototype, "onPlacementChange", null);
NavigationRail = __decorate([
t$3("mdui-navigation-rail")
], NavigationRail);
const navigationRailItemStyle = i$7`:host{--shape-corner-indicator:var(--mdui-shape-corner-full);position:relative;z-index:0;width:100%;--mdui-comp-ripple-state-layer-color:var(--mdui-color-on-surface-variant)}.container{display:flex;flex-direction:column;align-items:center;justify-content:center;text-decoration:none;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;height:3.5rem}.container:not(.initial){transition:padding var(--mdui-motion-duration-short4) var(--mdui-motion-easing-standard)}mdui-ripple{z-index:1;width:3.5rem;height:2rem;border-radius:var(--mdui-shape-corner-full)}.container:not(.has-label)+mdui-ripple{height:3.5rem}.indicator{position:relative;display:flex;align-items:center;justify-content:center;background-color:transparent;border-radius:var(--shape-corner-indicator);height:2rem;width:2rem}:not(.initial) .indicator{transition:background-color var(--mdui-motion-duration-short1) var(--mdui-motion-easing-standard),width var(--mdui-motion-duration-short4) var(--mdui-motion-easing-standard),height var(--mdui-motion-duration-short4) var(--mdui-motion-easing-standard)}::slotted([slot=badge]){position:absolute;transform:translate(50%,-50%)}.placement-right::slotted([slot=badge]){transform:translate(-50%,-50%)}::slotted([slot=badge][variant=small]){transform:translate(.5625rem,-.5625rem)}.placement-right::slotted([slot=badge][variant=small]){transform:translate(-.5625rem,-.5625rem)}.active-icon,.icon{color:rgb(var(--mdui-color-on-surface-variant));font-size:1.5rem}.active-icon mdui-icon,.icon mdui-icon,::slotted([slot=active-icon]),::slotted([slot=icon]){font-size:inherit}.icon{display:flex}.active-icon{display:none}.label{display:flex;align-items:center;height:1rem;color:rgb(var(--mdui-color-on-surface-variant));margin-top:.25rem;margin-bottom:.25rem;font-size:var(--mdui-typescale-label-medium-size);font-weight:var(--mdui-typescale-label-medium-weight);letter-spacing:var(--mdui-typescale-label-medium-tracking);line-height:var(--mdui-typescale-label-medium-line-height)}:not(.initial) .label{transition:opacity var(--mdui-motion-duration-short4) var(--mdui-motion-easing-linear)}:host([active]){--mdui-comp-ripple-state-layer-color:var(--mdui-color-on-surface)}:host([active]) .indicator{width:3.5rem;background-color:rgb(var(--mdui-color-secondary-container))}:host([active]) :not(.has-label) .indicator{height:3.5rem}:host([active]) .active-icon,:host([active]) .icon{color:rgb(var(--mdui-color-on-secondary-container))}:host([active]) .has-active-icon .active-icon{display:flex}:host([active]) .has-active-icon .icon{display:none}:host([active]) .label{color:rgb(var(--mdui-color-on-surface))}`;
let NavigationRailItem = class NavigationRailItem2 extends AnchorMixin(RippleMixin(FocusableMixin(MduiElement))) {
constructor() {
super(...arguments);
this.active = false;
this.isInitial = true;
this.placement = "left";
this.disabled = false;
this.key = uniqueId();
this.rippleRef = e$2();
this.hasSlotController = new HasSlotController(this, "[default]", "active-icon");
}
get rippleElement() {
return this.rippleRef.value;
}
get rippleDisabled() {
return this.disabled;
}
get focusElement() {
var _a2;
return this.href ? (_a2 = this.renderRoot) == null ? void 0 : _a2.querySelector("._a") : this;
}
get focusDisabled() {
return this.disabled;
}
render() {
const hasDefaultSlot = this.hasSlotController.test("[default]");
const className2 = cc({
container: true,
"has-label": hasDefaultSlot,
"has-active-icon": this.activeIcon || this.hasSlotController.test("active-icon"),
initial: this.isInitial
});
return x`${this.href ? this.renderAnchor({
part: "container",
className: className2,
content: this.renderInner(hasDefaultSlot)
}) : x`<div part="container" class="${className2}">${this.renderInner(hasDefaultSlot)}</div>`}<mdui-ripple .noRipple="${!this.active || this.noRipple}" ${n$2(this.rippleRef)}></mdui-ripple>`;
}
renderInner(hasDefaultSlot) {
return x`<div part="indicator" class="indicator"><slot name="badge" part="badge" class="${e$1({
badge: true,
"placement-right": this.placement === "right"
})}"></slot><slot name="active-icon" part="active-icon" class="active-icon">${this.activeIcon ? x`<mdui-icon name="${this.activeIcon}"></mdui-icon>` : nothingTemplate}</slot><slot name="icon" part="icon" class="icon">${this.icon ? x`<mdui-icon name="${this.icon}"></mdui-icon>` : nothingTemplate}</slot></div>${hasDefaultSlot ? x`<slot part="label" class="label"></slot>` : E}`;
}
};
NavigationRailItem.styles = [
componentStyle,
navigationRailItemStyle
];
__decorate([
n$6({ reflect: true })
], NavigationRailItem.prototype, "icon", void 0);
__decorate([
n$6({ reflect: true, attribute: "active-icon" })
], NavigationRailItem.prototype, "activeIcon", void 0);
__decorate([
n$6({ reflect: true })
], NavigationRailItem.prototype, "value", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], NavigationRailItem.prototype, "active", void 0);
__decorate([
r$1()
], NavigationRailItem.prototype, "isInitial", void 0);
__decorate([
r$1()
], NavigationRailItem.prototype, "placement", void 0);
__decorate([
r$1()
], NavigationRailItem.prototype, "disabled", void 0);
NavigationRailItem = __decorate([
t$3("mdui-navigation-rail-item")
], NavigationRailItem);
let IconCircle = class IconCircle2 extends r$3 {
render() {
return svgTag('<path d="M12 2C6.47 2 2 6.47 2 12s4.47 10 10 10 10-4.47 10-10S17.53 2 12 2z"/>');
}
};
IconCircle.styles = style$e;
IconCircle = __decorate([
t$3("mdui-icon-circle")
], IconCircle);
let IconRadioButtonUnchecked = class IconRadioButtonUnchecked2 extends r$3 {
render() {
return svgTag('<path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.42 0-8-3.58-8-8s3.58-8 8-8 8 3.58 8 8-3.58 8-8 8z"/>');
}
};
IconRadioButtonUnchecked.styles = style$e;
IconRadioButtonUnchecked = __decorate([
t$3("mdui-icon-radio-button-unchecked")
], IconRadioButtonUnchecked);
const radioStyle = i$7`:host{position:relative;display:inline-flex;align-items:center;cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;touch-action:manipulation;zoom:1;-webkit-user-drag:none;border-radius:.125rem;font-size:var(--mdui-typescale-label-large-size);font-weight:var(--mdui-typescale-label-large-weight);letter-spacing:var(--mdui-typescale-label-large-tracking);line-height:var(--mdui-typescale-label-large-line-height)}.icon{display:flex;position:absolute;font-size:1.5rem}:not(.initial) .icon{transition-duration:var(--mdui-motion-duration-short4);transition-timing-function:var(--mdui-motion-easing-standard)}.unchecked-icon{transition-property:color;color:rgb(var(--mdui-color-on-surface-variant))}:host([focused]) .unchecked-icon,:host([hover]) .unchecked-icon,:host([pressed]) .unchecked-icon{color:rgb(var(--mdui-color-on-surface))}.checked-icon{opacity:0;transform:scale(.2);transition-property:color,opacity,transform;color:rgb(var(--mdui-color-primary))}.icon .i,::slotted([slot=checked-icon]),::slotted([slot=unchecked-icon]){color:inherit;font-size:inherit}i{position:relative;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;border-radius:50%;width:2.5rem;height:2.5rem;--mdui-comp-ripple-state-layer-color:var(--mdui-color-on-surface)}.label{display:flex;width:100%;padding-top:.625rem;padding-bottom:.625rem;color:rgb(var(--mdui-color-on-surface))}.label:not(.initial){transition:color var(--mdui-motion-duration-short4) var(--mdui-motion-easing-standard)}:host([checked]:not([checked=false i])) i{--mdui-comp-ripple-state-layer-color:var(--mdui-color-primary)}:host([checked]:not([checked=false i])) .icon{color:rgb(var(--mdui-color-primary))}:host([checked]:not([checked=false i])) .checked-icon{opacity:1;transform:scale(.5)}i.invalid{--mdui-comp-ripple-state-layer-color:var(--mdui-color-error)}i.invalid .icon{color:rgb(var(--mdui-color-error))}.label.invalid{color:rgb(var(--mdui-color-error))}:host([disabled]:not([disabled=false i])),:host([group-disabled]){cursor:default;pointer-events:none}:host([disabled]:not([disabled=false i])) .icon,:host([group-disabled]) .icon{color:rgba(var(--mdui-color-on-surface),38%)}:host([disabled]:not([disabled=false i])) .label,:host([group-disabled]) .label{color:rgba(var(--mdui-color-on-surface),38%)}`;
let Radio = class Radio2 extends RippleMixin(FocusableMixin(MduiElement)) {
constructor() {
super(...arguments);
this.value = "";
this.disabled = false;
this.checked = false;
this.invalid = false;
this.groupDisabled = false;
this.focusable = true;
this.isInitial = true;
this.rippleRef = e$2();
}
get rippleElement() {
return this.rippleRef.value;
}
get rippleDisabled() {
return this.isDisabled();
}
get focusElement() {
return this;
}
get focusDisabled() {
return this.isDisabled() || !this.focusable;
}
onCheckedChange() {
this.emit("change");
}
firstUpdated(_changedProperties) {
super.firstUpdated(_changedProperties);
this.addEventListener("click", () => {
if (!this.isDisabled()) {
this.checked = true;
}
});
}
render() {
const className2 = e$1({
invalid: this.invalid,
initial: this.isInitial
});
return x`<i part="control" class="${className2}"><mdui-ripple ${n$2(this.rippleRef)} .noRipple="${this.noRipple}"></mdui-ripple><slot name="unchecked-icon" part="unchecked-icon" class="icon unchecked-icon">${this.uncheckedIcon ? x`<mdui-icon name="${this.uncheckedIcon}" class="i"></mdui-icon>` : x`<mdui-icon-radio-button-unchecked class="i"></mdui-icon-radio-button-unchecked>`}</slot><slot name="checked-icon" part="checked-icon" class="icon checked-icon">${this.checkedIcon ? x`<mdui-icon name="${this.checkedIcon}" class="i"></mdui-icon>` : x`<mdui-icon-circle class="i"></mdui-icon-circle>`}</slot></i><slot part="label" class="label ${className2}"></slot>`;
}
isDisabled() {
return this.disabled || this.groupDisabled;
}
};
Radio.styles = [componentStyle, radioStyle];
__decorate([
n$6({ reflect: true })
], Radio.prototype, "value", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Radio.prototype, "disabled", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Radio.prototype, "checked", void 0);
__decorate([
n$6({ reflect: true, attribute: "unchecked-icon" })
], Radio.prototype, "uncheckedIcon", void 0);
__decorate([
n$6({ reflect: true, attribute: "checked-icon" })
], Radio.prototype, "checkedIcon", void 0);
__decorate([
r$1()
], Radio.prototype, "invalid", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter,
attribute: "group-disabled"
})
], Radio.prototype, "groupDisabled", void 0);
__decorate([
r$1()
], Radio.prototype, "focusable", void 0);
__decorate([
r$1()
], Radio.prototype, "isInitial", void 0);
__decorate([
watch("checked", true)
], Radio.prototype, "onCheckedChange", null);
Radio = __decorate([
t$3("mdui-radio")
], Radio);
const radioGroupStyle = i$7`:host{display:inline-block}fieldset{border:none;padding:0;margin:0;min-width:0}input{position:absolute;padding:0;opacity:0;pointer-events:none;width:1.25rem;height:1.25rem;margin:0 0 0 .625rem}`;
let RadioGroup = class RadioGroup2 extends MduiElement {
constructor() {
super(...arguments);
this.disabled = false;
this.name = "";
this.value = "";
this.defaultValue = "";
this.required = false;
this.invalid = false;
this.isInitial = true;
this.inputRef = e$2();
this.formController = new FormController(this);
this.definedController = new DefinedController(this, {
relatedElements: ["mdui-radio"]
});
}
/**
* 表单验证状态对象,具体参见 [`ValidityState`](https://developer.mozilla.org/zh-CN/docs/Web/API/ValidityState)
*/
get validity() {
return this.inputRef.value.validity;
}
/**
* 如果表单验证未通过,此属性将包含提示信息。如果验证通过,此属性将为空字符串
*/
get validationMessage() {
return this.inputRef.value.validationMessage;
}
// 为了使 <mdui-radio> 可以不是该组件的直接子元素,这里不用 @queryAssignedElements()
get items() {
return $$1(this).find("mdui-radio").get();
}
get itemsEnabled() {
return $$1(this).find("mdui-radio:not([disabled])").get();
}
async onValueChange() {
var _a2;
this.isInitial = false;
await this.definedController.whenDefined();
this.emit("input");
this.emit("change");
this.updateItems();
this.updateRadioFocusable();
await this.updateComplete;
const form = this.formController.getForm();
if (form && ((_a2 = formResets.get(form)) == null ? void 0 : _a2.has(this))) {
this.invalid = false;
formResets.get(form).delete(this);
} else {
this.invalid = !this.inputRef.value.checkValidity();
}
}
async onInvalidChange() {
await this.definedController.whenDefined();
this.updateItems();
}
/**
* 检查表单字段是否通过验证。如果未通过,返回 `false` 并触发 `invalid` 事件;如果通过,返回 `true`
*/
checkValidity() {
const valid = this.inputRef.value.checkValidity();
if (!valid) {
this.emit("invalid", {
bubbles: false,
cancelable: true,
composed: false
});
}
return valid;
}
/**
* 检查表单字段是否通过验证。如果未通过,返回 `false` 并触发 `invalid` 事件;如果通过,返回 `true`。
*
* 如果验证未通过,还会在组件上显示验证失败的提示。
*/
reportValidity() {
this.invalid = !this.inputRef.value.reportValidity();
if (this.invalid) {
const eventProceeded = this.emit("invalid", {
bubbles: false,
cancelable: true,
composed: false
});
if (!eventProceeded) {
this.inputRef.value.blur();
this.inputRef.value.focus();
}
}
return !this.invalid;
}
/**
* 设置自定义的错误提示文本。只要这个文本不为空,就表示字段未通过验证
*
* @param message 自定义的错误提示文本
*/
setCustomValidity(message) {
this.inputRef.value.setCustomValidity(message);
this.invalid = !this.inputRef.value.checkValidity();
}
render() {
return x`<fieldset><input ${n$2(this.inputRef)} type="radio" class="input" name="${o$5(this.name)}" value="${o$5(this.value)}" .checked="${!!this.value}" .required="${this.required}" tabindex="-1" @keydown="${this.onKeyDown}"><slot @click="${this.onClick}" @keydown="${this.onKeyDown}" @slotchange="${this.onSlotChange}" @change="${this.onCheckedChange}"></slot></fieldset>`;
}
// 更新 mdui-radio 的 checked 后,需要更新可聚焦状态
// 同一个 mdui-radio-group 中的多个 mdui-radio,仅有一个可聚焦
// 若有已选中的,则已选中的可聚焦;若没有已选中的,则第一个可聚焦
updateRadioFocusable() {
const items = this.items;
const itemChecked = items.find((item) => item.checked);
if (itemChecked) {
items.forEach((item) => {
item.focusable = item === itemChecked;
});
} else {
this.itemsEnabled.forEach((item, index) => {
item.focusable = !index;
});
}
}
async onClick(event) {
await this.definedController.whenDefined();
const target = event.target;
const item = target.closest("mdui-radio");
if (!item || item.disabled) {
return;
}
this.value = item.value;
await this.updateComplete;
item.focus();
}
/**
* 在内部的 `<mdui-radio>` 上按下按键时,在 `<mdui-radio>` 之间切换焦点
*/
async onKeyDown(event) {
if (!["ArrowUp", "ArrowDown", "ArrowLeft", "ArrowRight", " "].includes(event.key)) {
return;
}
event.preventDefault();
await this.definedController.whenDefined();
const items = this.itemsEnabled;
const itemChecked = items.find((item) => item.checked) ?? items[0];
const incr = event.key === " " ? 0 : ["ArrowUp", "ArrowLeft"].includes(event.key) ? -1 : 1;
let index = items.indexOf(itemChecked) + incr;
if (index < 0) {
index = items.length - 1;
}
if (index > items.length - 1) {
index = 0;
}
this.value = items[index].value;
await this.updateComplete;
items[index].focus();
}
async onSlotChange() {
await this.definedController.whenDefined();
this.updateItems();
this.updateRadioFocusable();
}
/**
* slot 中的 mdui-radio 的 checked 变更时触发的事件
*/
onCheckedChange(event) {
event.stopPropagation();
}
// 更新 <mdui-radio> 的状态
updateItems() {
this.items.forEach((item) => {
item.checked = item.value === this.value;
item.invalid = this.invalid;
item.groupDisabled = this.disabled;
item.isInitial = this.isInitial;
});
}
};
RadioGroup.styles = [
componentStyle,
radioGroupStyle
];
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], RadioGroup.prototype, "disabled", void 0);
__decorate([
n$6({ reflect: true })
], RadioGroup.prototype, "form", void 0);
__decorate([
n$6({ reflect: true })
], RadioGroup.prototype, "name", void 0);
__decorate([
n$6({ reflect: true })
], RadioGroup.prototype, "value", void 0);
__decorate([
defaultValue()
], RadioGroup.prototype, "defaultValue", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], RadioGroup.prototype, "required", void 0);
__decorate([
r$1()
], RadioGroup.prototype, "invalid", void 0);
__decorate([
watch("value", true)
], RadioGroup.prototype, "onValueChange", null);
__decorate([
watch("invalid", true),
watch("disabled")
], RadioGroup.prototype, "onInvalidChange", null);
RadioGroup = __decorate([
t$3("mdui-radio-group")
], RadioGroup);
/**
* @license
* Copyright 2021 Google LLC
* SPDX-License-Identifier: BSD-3-Clause
*/
function* o(o2, f3) {
if (void 0 !== o2) {
let i3 = 0;
for (const t3 of o2) yield f3(t3, i3++);
}
}
const sliderBaseStyle = i$7`:host{position:relative;display:block;width:100%;-webkit-tap-highlight-color:transparent;height:2.5rem;padding:0 1.25rem}label{position:relative;display:block;width:100%;height:100%}input[type=range]{position:absolute;inset:0;z-index:4;height:100%;cursor:pointer;opacity:0;appearance:none;width:calc(100% + 20rem * 2 / 16);margin:0 -1.25rem;padding:0 .75rem}:host([disabled]:not([disabled=false i])) input[type=range]{cursor:not-allowed}.track-active,.track-inactive{position:absolute;top:50%;height:.25rem;margin-top:-.125rem}.track-inactive{left:-.125rem;right:-.125rem;border-radius:var(--mdui-shape-corner-full);background-color:rgb(var(--mdui-color-surface-container-highest))}.invalid .track-inactive{background-color:rgba(var(--mdui-color-error),.12)}:host([disabled]:not([disabled=false i])) .track-inactive{background-color:rgba(var(--mdui-color-on-surface),.12)}.track-active{background-color:rgb(var(--mdui-color-primary))}.invalid .track-active{background-color:rgb(var(--mdui-color-error))}:host([disabled]:not([disabled=false i])) .track-active{background-color:rgba(var(--mdui-color-on-surface),.38)}.handle{position:absolute;top:50%;transform:translate(-50%);cursor:pointer;z-index:2;width:2.5rem;height:2.5rem;margin-top:-1.25rem;--mdui-comp-ripple-state-layer-color:var(--mdui-color-primary)}.invalid .handle{--mdui-comp-ripple-state-layer-color:var(--mdui-color-error)}.handle .elevation,.handle::before{position:absolute;display:block;content:' ';left:.625rem;top:.625rem;width:1.25rem;height:1.25rem;border-radius:var(--mdui-shape-corner-full)}.handle .elevation{background-color:rgb(var(--mdui-color-primary));box-shadow:var(--mdui-elevation-level1)}.invalid .handle .elevation{background-color:rgb(var(--mdui-color-error))}:host([disabled]:not([disabled=false i])) .handle .elevation{background-color:rgba(var(--mdui-color-on-surface),.38);box-shadow:var(--mdui-elevation-level0)}.handle::before{background-color:rgb(var(--mdui-color-background))}.handle mdui-ripple{border-radius:var(--mdui-shape-corner-full)}.label{position:absolute;left:50%;transform:translateX(-50%) scale(0);transform-origin:center bottom;display:flex;align-items:center;justify-content:center;cursor:default;white-space:nowrap;-webkit-user-select:none;user-select:none;pointer-events:none;transition:transform var(--mdui-motion-duration-short2) var(--mdui-motion-easing-standard);bottom:2.5rem;min-width:1.75rem;height:1.75rem;padding:.375rem .5rem;border-radius:var(--mdui-shape-corner-full);color:rgb(var(--mdui-color-on-primary));font-size:var(--mdui-typescale-label-medium-size);font-weight:var(--mdui-typescale-label-medium-weight);letter-spacing:var(--mdui-typescale-label-medium-tracking);line-height:var(--mdui-typescale-label-medium-line-height);background-color:rgb(var(--mdui-color-primary))}.invalid .label{color:rgb(var(--mdui-color-on-error));background-color:rgb(var(--mdui-color-error))}.label::after{content:' ';position:absolute;z-index:-1;transform:rotate(45deg);width:.875rem;height:.875rem;bottom:-.125rem;background-color:rgb(var(--mdui-color-primary))}.invalid .label::after{background-color:rgb(var(--mdui-color-error))}.label-visible{transform:translateX(-50%) scale(1);transition:transform var(--mdui-motion-duration-short4) var(--mdui-motion-easing-standard)}.tickmark{position:absolute;top:50%;transform:translate(-50%);width:.125rem;height:.125rem;margin-top:-.0625rem;border-radius:var(--mdui-shape-corner-full);background-color:rgba(var(--mdui-color-on-surface-variant),.38)}.invalid .tickmark{background-color:rgba(var(--mdui-color-error),.38)}.tickmark.active{background-color:rgba(var(--mdui-color-on-primary),.38)}.invalid .tickmark.active{background-color:rgba(var(--mdui-color-on-error),.38)}:host([disabled]:not([disabled=false i])) .tickmark{background-color:rgba(var(--mdui-color-on-surface),.38)}`;
class SliderBase extends RippleMixin(FocusableMixin(MduiElement)) {
constructor() {
super(...arguments);
this.min = 0;
this.max = 100;
this.step = 1;
this.tickmarks = false;
this.nolabel = false;
this.disabled = false;
this.name = "";
this.invalid = false;
this.labelVisible = false;
this.inputRef = e$2();
this.trackActiveRef = e$2();
this.labelFormatter = (value) => value.toString();
}
/**
* 表单验证状态对象,具体参见 [`ValidityState`](https://developer.mozilla.org/zh-CN/docs/Web/API/ValidityState)
*/
get validity() {
return this.inputRef.value.validity;
}
/**
* 如果表单验证未通过,此属性将包含提示信息。如果验证通过,此属性将为空字符串
*/
get validationMessage() {
return this.inputRef.value.validationMessage;
}
get rippleDisabled() {
return this.disabled;
}
get focusElement() {
return this.inputRef.value;
}
get focusDisabled() {
return this.disabled;
}
onDisabledChange() {
this.invalid = !this.inputRef.value.checkValidity();
}
/**
* 检查表单字段是否通过验证。如果未通过,返回 `false` 并触发 `invalid` 事件;如果通过,返回 `true`
*/
checkValidity() {
const valid = this.inputRef.value.checkValidity();
if (!valid) {
this.emit("invalid", {
bubbles: false,
cancelable: true,
composed: false
});
}
return valid;
}
/**
* 检查表单字段是否通过验证。如果未通过,返回 `false` 并触发 `invalid` 事件;如果通过,返回 `true`。
*
* 如果验证未通过,还会在组件上显示验证失败的提示。
*/
reportValidity() {
this.invalid = !this.inputRef.value.reportValidity();
if (this.invalid) {
const eventProceeded = this.emit("invalid", {
bubbles: false,
cancelable: true,
composed: false
});
if (!eventProceeded) {
this.blur();
this.focus();
}
}
return !this.invalid;
}
/**
* 设置自定义的错误提示文本。只要这个文本不为空,就表示字段未通过验证
*
* @param message 自定义的错误提示文本
*/
setCustomValidity(message) {
this.inputRef.value.setCustomValidity(message);
this.invalid = !this.inputRef.value.checkValidity();
}
/**
* value 不在 min、max 或 step 的限制范围内时,修正 value 的值
*/
fixValue(value) {
const { min, max, step } = this;
value = Math.min(Math.max(value, min), max);
const steps = Math.round((value - min) / step);
let fixedValue = min + steps * step;
if (fixedValue > max) {
fixedValue -= step;
}
return fixedValue;
}
/**
* 获取候选值组成的数组
*/
getCandidateValues() {
return Array.from({ length: this.max - this.min + 1 }, (_2, index) => index + this.min).filter((value) => !((value - this.min) % this.step));
}
/**
* 渲染浮动标签
*/
renderLabel(value) {
return n$1(!this.nolabel, () => x`<div part="label" class="label ${e$1({ "label-visible": this.labelVisible })}">${this.labelFormatter(value)}</div>`);
}
onChange() {
this.emit("change");
}
}
SliderBase.styles = [
componentStyle,
sliderBaseStyle
];
__decorate([
n$6({ type: Number, reflect: true })
], SliderBase.prototype, "min", void 0);
__decorate([
n$6({ type: Number, reflect: true })
], SliderBase.prototype, "max", void 0);
__decorate([
n$6({ type: Number, reflect: true })
], SliderBase.prototype, "step", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], SliderBase.prototype, "tickmarks", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], SliderBase.prototype, "nolabel", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], SliderBase.prototype, "disabled", void 0);
__decorate([
n$6({ reflect: true })
], SliderBase.prototype, "form", void 0);
__decorate([
n$6({ reflect: true })
], SliderBase.prototype, "name", void 0);
__decorate([
r$1()
], SliderBase.prototype, "invalid", void 0);
__decorate([
r$1()
], SliderBase.prototype, "labelVisible", void 0);
__decorate([
n$6({ attribute: false })
], SliderBase.prototype, "labelFormatter", void 0);
__decorate([
watch("disabled", true)
], SliderBase.prototype, "onDisabledChange", null);
let RangeSlider = class RangeSlider2 extends SliderBase {
constructor() {
super(...arguments);
this.defaultValue = [];
this.currentHandle = "start";
this.rippleStartRef = e$2();
this.rippleEndRef = e$2();
this.handleStartRef = e$2();
this.handleEndRef = e$2();
this.formController = new FormController(this);
this._value = [];
this.getRippleIndex = () => {
if (this.hoverHandle) {
return this.hoverHandle === "start" ? 0 : 1;
}
return this.currentHandle === "start" ? 0 : 1;
};
}
/**
* 滑块的值,为数组格式,将于表单数据一起提交。
*
* **NOTE**:该属性无法通过 HTML 属性设置初始值,如果要修改该值,只能通过修改 JavaScript 属性值实现。
*/
get value() {
return this._value;
}
set value(_value) {
const oldValue = [...this._value];
this._value = [this.fixValue(_value[0]), this.fixValue(_value[1])];
this.requestUpdate("value", oldValue);
this.updateComplete.then(() => {
var _a2;
this.updateStyle();
const form = this.formController.getForm();
if (form && ((_a2 = formResets.get(form)) == null ? void 0 : _a2.has(this))) {
this.invalid = false;
formResets.get(form).delete(this);
} else {
this.invalid = !this.inputRef.value.checkValidity();
}
});
}
get rippleElement() {
return [this.rippleStartRef.value, this.rippleEndRef.value];
}
connectedCallback() {
super.connectedCallback();
if (!this.value.length) {
this.value = [this.min, this.max];
}
this.value[0] = this.fixValue(this.value[0]);
this.value[1] = this.fixValue(this.value[1]);
if (!this.defaultValue.length) {
this.defaultValue = [...this.value];
}
}
firstUpdated(changedProperties) {
super.firstUpdated(changedProperties);
const getCurrentHandle = (event) => {
const $this = $$1(this);
const paddingLeft = parseFloat($this.css("padding-left"));
const paddingRight = parseFloat($this.css("padding-right"));
const percent = (event.offsetX - paddingLeft) / (this.clientWidth - paddingLeft - paddingRight);
const pointerValue = (this.max - this.min) * percent + this.min;
const middleValue = (this.value[1] - this.value[0]) / 2 + this.value[0];
return pointerValue > middleValue ? "end" : "start";
};
const onTouchStart = () => {
if (!this.disabled) {
this.labelVisible = true;
}
};
const onTouchEnd = () => {
if (!this.disabled) {
this.labelVisible = false;
}
};
this.addEventListener("touchstart", onTouchStart);
this.addEventListener("mousedown", onTouchStart);
this.addEventListener("touchend", onTouchEnd);
this.addEventListener("mouseup", onTouchEnd);
this.addEventListener("pointerdown", (event) => {
this.currentHandle = getCurrentHandle(event);
});
this.addEventListener("pointermove", (event) => {
const currentHandle = getCurrentHandle(event);
if (this.hoverHandle !== currentHandle) {
this.endHover(event);
this.hoverHandle = currentHandle;
this.startHover(event);
}
});
this.updateStyle();
}
/**
* <input /> 用于提供拖拽操作
* <input class="invalid" /> 用于提供 html5 自带的表单错误提示
*/
render() {
return x`<label class="${e$1({ invalid: this.invalid })}"><input ${n$2(this.inputRef)} type="range" step="${this.step}" min="${this.min}" max="${this.max}" ?disabled="${this.disabled}" @input="${this.onInput}" @change="${this.onChange}"><div part="track-inactive" class="track-inactive"></div><div ${n$2(this.trackActiveRef)} part="track-active" class="track-active"></div><div ${n$2(this.handleStartRef)} part="handle" class="handle start" style="${o$4({
"z-index": this.currentHandle === "start" ? "2" : "1"
})}"><div class="elevation"></div><mdui-ripple ${n$2(this.rippleStartRef)} .noRipple="${this.noRipple}"></mdui-ripple>${this.renderLabel(this.value[0])}</div><div ${n$2(this.handleEndRef)} part="handle" class="handle end" style="${o$4({
"z-index": this.currentHandle === "end" ? "2" : "1"
})}"><div class="elevation"></div><mdui-ripple ${n$2(this.rippleEndRef)} .noRipple="${this.noRipple}"></mdui-ripple>${this.renderLabel(this.value[1])}</div>${n$1(this.tickmarks, () => o(this.getCandidateValues(), (value) => x`<div part="tickmark" class="tickmark ${e$1({
active: value > this.value[0] && value < this.value[1]
})}" style="${o$4({
left: `${(value - this.min) / this.max * 100}%`,
display: value === this.value[0] || value === this.value[1] ? "none" : "block"
})}"></div>`))}</label>`;
}
updateStyle() {
const getPercent = (value) => (value - this.min) / (this.max - this.min) * 100;
const startPercent = getPercent(this.value[0]);
const endPercent = getPercent(this.value[1]);
this.trackActiveRef.value.style.width = `${endPercent - startPercent}%`;
this.trackActiveRef.value.style.left = `${startPercent}%`;
this.handleStartRef.value.style.left = `${startPercent}%`;
this.handleEndRef.value.style.left = `${endPercent}%`;
}
onInput() {
const isStart = this.currentHandle === "start";
const value = parseFloat(this.inputRef.value.value);
const startValue = this.value[0];
const endValue = this.value[1];
const doInput = () => {
this.updateStyle();
};
if (isStart) {
if (value <= endValue) {
this.value = [value, endValue];
doInput();
} else if (startValue !== endValue) {
this.value = [endValue, endValue];
doInput();
}
} else {
if (value >= startValue) {
this.value = [startValue, value];
doInput();
} else if (startValue !== endValue) {
this.value = [startValue, startValue];
doInput();
}
}
}
};
RangeSlider.styles = [SliderBase.styles];
__decorate([
defaultValue()
], RangeSlider.prototype, "defaultValue", void 0);
__decorate([
r$1()
], RangeSlider.prototype, "currentHandle", void 0);
__decorate([
n$6({ type: Array, attribute: false })
], RangeSlider.prototype, "value", null);
RangeSlider = __decorate([
t$3("mdui-range-slider")
], RangeSlider);
const segmentedButtonStyle = i$7`:host{position:relative;display:inline-flex;flex-grow:1;flex-shrink:0;float:left;height:100%;overflow:hidden;cursor:pointer;-webkit-tap-highlight-color:transparent;border:.0625rem solid rgb(var(--mdui-color-outline))}.button{width:100%;padding:0 .75rem}:host([invalid]){color:rgb(var(--mdui-color-error));border-color:rgb(var(--mdui-color-error))}:host([invalid]) .button{background-color:rgb(var(--mdui-color-error-container))}:host([selected]){color:rgb(var(--mdui-color-on-secondary-container));background-color:rgb(var(--mdui-color-secondary-container));--mdui-comp-ripple-state-layer-color:var(
--mdui-color-on-secondary-container
)}:host([disabled]:not([disabled=false i])),:host([group-disabled]){cursor:default;pointer-events:none;color:rgba(var(--mdui-color-on-surface),38%);border-color:rgba(var(--mdui-color-on-surface),12%)}:host([loading]:not([loading=false i])){cursor:default;pointer-events:none}:host(:not(.mdui-segmented-button-first)){margin-left:-.0625rem}:host(.mdui-segmented-button-first){border-radius:var(--shape-corner) 0 0 var(--shape-corner)}:host(.mdui-segmented-button-last){border-radius:0 var(--shape-corner) var(--shape-corner) 0}.end-icon,.icon,.selected-icon{display:inline-flex;font-size:1.28571429em}.end-icon .i,.icon .i,.selected-icon .i,::slotted([slot=end-icon]),::slotted([slot=icon]),::slotted([slot=selected-icon]){font-size:inherit}mdui-circular-progress{width:1.125rem;height:1.125rem}:host([disabled]:not([disabled=false i])) mdui-circular-progress{opacity:.38}.label{display:inline-flex}.has-icon .label{padding-left:.5rem}.has-end-icon .label{padding-right:.5rem}`;
let SegmentedButton = class SegmentedButton2 extends ButtonBase {
constructor() {
super(...arguments);
this.selected = false;
this.invalid = false;
this.groupDisabled = false;
this.key = uniqueId();
this.rippleRef = e$2();
this.hasSlotController = new HasSlotController(this, "[default]", "icon", "end-icon");
}
get rippleElement() {
return this.rippleRef.value;
}
get rippleDisabled() {
return this.isDisabled() || this.loading;
}
get focusDisabled() {
return this.isDisabled() || this.loading;
}
render() {
const className2 = cc({
button: true,
"has-icon": this.icon || this.selected || this.loading || this.hasSlotController.test("icon"),
"has-end-icon": this.endIcon || this.hasSlotController.test("end-icon")
});
return x`<mdui-ripple ${n$2(this.rippleRef)} .noRipple="${this.noRipple}"></mdui-ripple>${this.isButton() ? this.renderButton({
className: className2,
part: "button",
content: this.renderInner()
}) : this.isDisabled() || this.loading ? x`<span part="button" class="_a ${className2}">${this.renderInner()}</span>` : this.renderAnchor({
className: className2,
part: "button",
content: this.renderInner()
})}`;
}
isDisabled() {
return this.disabled || this.groupDisabled;
}
renderIcon() {
if (this.loading) {
return this.renderLoading();
}
if (this.selected) {
return x`<slot name="selected-icon" part="selected-icon" class="selected-icon">${this.selectedIcon ? x`<mdui-icon name="${this.selectedIcon}" class="i"></mdui-icon>` : x`<mdui-icon-check class="i"></mdui-icon-check>`}</slot>`;
}
return x`<slot name="icon" part="icon" class="icon">${this.icon ? x`<mdui-icon name="${this.icon}" class="i"></mdui-icon>` : nothingTemplate}</slot>`;
}
renderLabel() {
const hasLabel = this.hasSlotController.test("[default]");
if (!hasLabel) {
return nothingTemplate;
}
return x`<slot part="label" class="label"></slot>`;
}
renderEndIcon() {
return x`<slot name="end-icon" part="end-icon" class="end-icon">${this.endIcon ? x`<mdui-icon name="${this.endIcon}" class="i"></mdui-icon>` : nothingTemplate}</slot>`;
}
renderInner() {
return [this.renderIcon(), this.renderLabel(), this.renderEndIcon()];
}
};
SegmentedButton.styles = [
ButtonBase.styles,
segmentedButtonStyle
];
__decorate([
n$6({ reflect: true })
], SegmentedButton.prototype, "icon", void 0);
__decorate([
n$6({ reflect: true, attribute: "end-icon" })
], SegmentedButton.prototype, "endIcon", void 0);
__decorate([
n$6({ reflect: true, attribute: "selected-icon" })
], SegmentedButton.prototype, "selectedIcon", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], SegmentedButton.prototype, "selected", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], SegmentedButton.prototype, "invalid", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter,
attribute: "group-disabled"
})
], SegmentedButton.prototype, "groupDisabled", void 0);
SegmentedButton = __decorate([
t$3("mdui-segmented-button")
], SegmentedButton);
const segmentedButtonGroupStyle = i$7`:host{--shape-corner:var(--mdui-shape-corner-full);position:relative;display:inline-flex;vertical-align:middle;height:2.5rem;font-size:var(--mdui-typescale-label-large-size);font-weight:var(--mdui-typescale-label-large-weight);letter-spacing:var(--mdui-typescale-label-large-tracking);line-height:var(--mdui-typescale-label-large-line-height);color:rgb(var(--mdui-color-on-surface));--mdui-comp-ripple-state-layer-color:var(--mdui-color-on-surface)}:host([full-width]:not([full-width=false i])){display:flex;flex-wrap:nowrap}input,select{position:absolute;width:100%;height:100%;padding:0;opacity:0;pointer-events:none}`;
let SegmentedButtonGroup = class SegmentedButtonGroup2 extends MduiElement {
constructor() {
super(...arguments);
this.fullWidth = false;
this.disabled = false;
this.required = false;
this.name = "";
this.value = "";
this.defaultValue = "";
this.selectedKeys = [];
this.invalid = false;
this.isInitial = true;
this.inputRef = e$2();
this.formController = new FormController(this);
this.definedController = new DefinedController(this, {
relatedElements: ["mdui-segmented-button"]
});
}
/**
* 表单验证状态对象,具体参见 [`ValidityState`](https://developer.mozilla.org/zh-CN/docs/Web/API/ValidityState)
*/
get validity() {
return this.inputRef.value.validity;
}
/**
* 如果表单验证未通过,此属性将包含提示信息。如果验证通过,此属性将为空字符串
*/
get validationMessage() {
return this.inputRef.value.validationMessage;
}
// 为了使 <mdui-segmented-button> 可以不是该组件的直接子元素,这里不用 @queryAssignedElements()
get items() {
return $$1(this).find("mdui-segmented-button").get();
}
// 所有的子项元素(不包含已禁用的)
get itemsEnabled() {
return $$1(this).find("mdui-segmented-button:not([disabled])").get();
}
// 是否为单选
get isSingle() {
return this.selects === "single";
}
// 是否为多选
get isMultiple() {
return this.selects === "multiple";
}
// 是否可选择
get isSelectable() {
return this.isSingle || this.isMultiple;
}
async onSelectsChange() {
if (!this.isSelectable) {
this.setSelectedKeys([]);
} else if (this.isSingle) {
this.setSelectedKeys(this.selectedKeys.slice(0, 1));
}
await this.onSelectedKeysChange();
}
async onSelectedKeysChange() {
await this.definedController.whenDefined();
const values = this.itemsEnabled.filter((item) => this.selectedKeys.includes(item.key)).map((item) => item.value);
const value = this.isMultiple ? values : values[0] || "";
this.setValue(value);
if (!this.isInitial) {
this.emit("change");
}
}
async onValueChange() {
var _a2;
this.isInitial = !this.hasUpdated;
await this.definedController.whenDefined();
if (!this.isSelectable) {
this.updateItems();
return;
}
const values = (this.isSingle ? [this.value] : (
// 多选时,传入的值可能是字符串(通过 attribute 属性设置);或字符串数组(通过 property 属性设置)
isString(this.value) ? [this.value] : this.value
)).filter((i3) => i3);
if (!values.length) {
this.setSelectedKeys([]);
} else if (this.isSingle) {
const firstItem = this.itemsEnabled.find((item) => item.value === values[0]);
this.setSelectedKeys(firstItem ? [firstItem.key] : []);
} else if (this.isMultiple) {
this.setSelectedKeys(this.itemsEnabled.filter((item) => values.includes(item.value)).map((item) => item.key));
}
this.updateItems();
if (!this.isInitial) {
const form = this.formController.getForm();
if (form && ((_a2 = formResets.get(form)) == null ? void 0 : _a2.has(this))) {
this.invalid = false;
formResets.get(form).delete(this);
} else {
this.invalid = !this.inputRef.value.checkValidity();
}
}
}
async onInvalidChange() {
await this.definedController.whenDefined();
this.updateItems();
}
connectedCallback() {
super.connectedCallback();
this.value = this.isMultiple && isString(this.value) ? this.value ? [this.value] : [] : this.value;
this.defaultValue = this.selects === "multiple" ? [] : "";
}
/**
* 检查表单字段是否通过验证。如果未通过,返回 `false` 并触发 `invalid` 事件;如果通过,返回 `true`
*/
checkValidity() {
const valid = this.inputRef.value.checkValidity();
if (!valid) {
this.emit("invalid", {
bubbles: false,
cancelable: true,
composed: false
});
}
return valid;
}
/**
* 检查表单字段是否通过验证。如果未通过,返回 `false` 并触发 `invalid` 事件;如果通过,返回 `true`。
*
* 如果验证未通过,还会在组件上显示验证失败的提示。
*/
reportValidity() {
this.invalid = !this.inputRef.value.reportValidity();
if (this.invalid) {
const eventProceeded = this.emit("invalid", {
bubbles: false,
cancelable: true,
composed: false
});
if (!eventProceeded) {
this.inputRef.value.blur();
this.inputRef.value.focus();
}
}
return !this.invalid;
}
/**
* 设置自定义的错误提示文本。只要这个文本不为空,就表示字段未通过验证
*
* @param message 自定义的错误提示文本
*/
setCustomValidity(message) {
this.inputRef.value.setCustomValidity(message);
this.invalid = !this.inputRef.value.checkValidity();
}
render() {
return x`${n$1(this.isSelectable && this.isSingle, () => x`<input ${n$2(this.inputRef)} type="radio" name="${o$5(this.name)}" value="1" .disabled="${this.disabled}" .required="${this.required}" .checked="${!!this.value}" tabindex="-1" @keydown="${this.onInputKeyDown}">`)}${n$1(this.isSelectable && this.isMultiple, () => x`<select ${n$2(this.inputRef)} name="${o$5(this.name)}" .disabled="${this.disabled}" .required="${this.required}" multiple="multiple" tabindex="-1" @keydown="${this.onInputKeyDown}">${o(this.value, (value) => x`<option selected="selected" value="${value}"></option>`)}</select>`)}<slot @slotchange="${this.onSlotChange}" @click="${this.onClick}"></slot>`;
}
// 切换一个元素的选中状态
selectOne(item) {
if (this.isMultiple) {
const selectedKeys = [...this.selectedKeys];
if (selectedKeys.includes(item.key)) {
selectedKeys.splice(selectedKeys.indexOf(item.key), 1);
} else {
selectedKeys.push(item.key);
}
this.setSelectedKeys(selectedKeys);
}
if (this.isSingle) {
if (this.selectedKeys.includes(item.key)) {
this.setSelectedKeys([]);
} else {
this.setSelectedKeys([item.key]);
}
}
this.isInitial = false;
this.updateItems();
}
async onClick(event) {
if (event.button) {
return;
}
await this.definedController.whenDefined();
const target = event.target;
const item = target.closest("mdui-segmented-button");
if (!item || item.disabled) {
return;
}
if (this.isSelectable && item.value) {
this.selectOne(item);
}
}
/**
* 在隐藏的 `<input>` 或 `<select>` 上按下按键时,切换选中状态
* 通常为验证不通过时,默认聚焦到 `<input>` 或 `<select>` 上,此时按下按键,切换第一个元素的选中状态
*/
async onInputKeyDown(event) {
if (!["Enter", " "].includes(event.key)) {
return;
}
event.preventDefault();
await this.definedController.whenDefined();
if (this.isSingle) {
const input = event.target;
input.checked = !input.checked;
this.selectOne(this.itemsEnabled[0]);
this.itemsEnabled[0].focus();
}
if (this.isMultiple) {
this.selectOne(this.itemsEnabled[0]);
this.itemsEnabled[0].focus();
}
}
async onSlotChange() {
await this.definedController.whenDefined();
this.updateItems(true);
}
setSelectedKeys(selectedKeys) {
if (!arraysEqualIgnoreOrder(this.selectedKeys, selectedKeys)) {
this.selectedKeys = selectedKeys;
}
}
setValue(value) {
if (this.isSingle) {
this.value = value;
} else if (!arraysEqualIgnoreOrder(this.value, value)) {
this.value = value;
}
}
updateItems(slotChange = false) {
const items = this.items;
items.forEach((item, index) => {
item.invalid = this.invalid;
item.groupDisabled = this.disabled;
item.selected = this.selectedKeys.includes(item.key);
if (slotChange) {
item.classList.toggle("mdui-segmented-button-first", index === 0);
item.classList.toggle("mdui-segmented-button-last", index === items.length - 1);
}
});
}
};
SegmentedButtonGroup.styles = [
componentStyle,
segmentedButtonGroupStyle
];
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter,
attribute: "full-width"
})
], SegmentedButtonGroup.prototype, "fullWidth", void 0);
__decorate([
n$6({ reflect: true })
// eslint-disable-next-line prettier/prettier
], SegmentedButtonGroup.prototype, "selects", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], SegmentedButtonGroup.prototype, "disabled", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], SegmentedButtonGroup.prototype, "required", void 0);
__decorate([
n$6({ reflect: true })
], SegmentedButtonGroup.prototype, "form", void 0);
__decorate([
n$6({ reflect: true })
], SegmentedButtonGroup.prototype, "name", void 0);
__decorate([
n$6()
], SegmentedButtonGroup.prototype, "value", void 0);
__decorate([
defaultValue()
], SegmentedButtonGroup.prototype, "defaultValue", void 0);
__decorate([
r$1()
], SegmentedButtonGroup.prototype, "selectedKeys", void 0);
__decorate([
r$1()
], SegmentedButtonGroup.prototype, "invalid", void 0);
__decorate([
watch("selects", true)
], SegmentedButtonGroup.prototype, "onSelectsChange", null);
__decorate([
watch("selectedKeys", true)
], SegmentedButtonGroup.prototype, "onSelectedKeysChange", null);
__decorate([
watch("value")
], SegmentedButtonGroup.prototype, "onValueChange", null);
__decorate([
watch("invalid", true),
watch("disabled")
], SegmentedButtonGroup.prototype, "onInvalidChange", null);
SegmentedButtonGroup = __decorate([
t$3("mdui-segmented-button-group")
], SegmentedButtonGroup);
let IconCancel_Outlined = class IconCancel_Outlined2 extends r$3 {
render() {
return svgTag('<path d="M12 2C6.47 2 2 6.47 2 12s4.47 10 10 10 10-4.47 10-10S17.53 2 12 2zm0 18c-4.41 0-8-3.59-8-8s3.59-8 8-8 8 3.59 8 8-3.59 8-8 8zm3.59-13L12 10.59 8.41 7 7 8.41 10.59 12 7 15.59 8.41 17 12 13.41 15.59 17 17 15.59 13.41 12 17 8.41z"/>');
}
};
IconCancel_Outlined.styles = style$e;
IconCancel_Outlined = __decorate([
t$3("mdui-icon-cancel--outlined")
], IconCancel_Outlined);
let IconError = class IconError2 extends r$3 {
render() {
return svgTag('<path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-2h2v2zm0-4h-2V7h2v6z"/>');
}
};
IconError.styles = style$e;
IconError = __decorate([
t$3("mdui-icon-error")
], IconError);
let IconVisibilityOff = class IconVisibilityOff2 extends r$3 {
render() {
return svgTag('<path d="M12 7c2.76 0 5 2.24 5 5 0 .65-.13 1.26-.36 1.83l2.92 2.92c1.51-1.26 2.7-2.89 3.43-4.75-1.73-4.39-6-7.5-11-7.5-1.4 0-2.74.25-3.98.7l2.16 2.16C10.74 7.13 11.35 7 12 7zM2 4.27l2.28 2.28.46.46A11.804 11.804 0 0 0 1 12c1.73 4.39 6 7.5 11 7.5 1.55 0 3.03-.3 4.38-.84l.42.42L19.73 22 21 20.73 3.27 3 2 4.27zM7.53 9.8l1.55 1.55c-.05.21-.08.43-.08.65 0 1.66 1.34 3 3 3 .22 0 .44-.03.65-.08l1.55 1.55c-.67.33-1.41.53-2.2.53-2.76 0-5-2.24-5-5 0-.79.2-1.53.53-2.2zm4.31-.78 3.15 3.15.02-.16c0-1.66-1.34-3-3-3l-.17.01z"/>');
}
};
IconVisibilityOff.styles = style$e;
IconVisibilityOff = __decorate([
t$3("mdui-icon-visibility-off")
], IconVisibilityOff);
let IconVisibility = class IconVisibility2 extends r$3 {
render() {
return svgTag('<path d="M12 4.5C7 4.5 2.73 7.61 1 12c1.73 4.39 6 7.5 11 7.5s9.27-3.11 11-7.5c-1.73-4.39-6-7.5-11-7.5zM12 17c-2.76 0-5-2.24-5-5s2.24-5 5-5 5 2.24 5 5-2.24 5-5 5zm0-8c-1.66 0-3 1.34-3 3s1.34 3 3 3 3-1.34 3-3-1.34-3-3-3z"/>');
}
};
IconVisibility.styles = style$e;
IconVisibility = __decorate([
t$3("mdui-icon-visibility")
], IconVisibility);
const style$5 = i$7`:host{display:inline-block;width:100%}:host([disabled]:not([disabled=false i])){pointer-events:none}:host([type=hidden]){display:none}.container{position:relative;display:flex;align-items:center;height:100%;padding:.125rem .125rem .125rem 1rem;transition:box-shadow var(--mdui-motion-duration-short4) var(--mdui-motion-easing-standard)}.container.has-icon{padding-left:.75rem}.container.has-action,.container.has-right-icon,.container.has-suffix{padding-right:.75rem}:host([variant=filled]) .container{box-shadow:inset 0 -.0625rem 0 0 rgb(var(--mdui-color-on-surface-variant));background-color:rgb(var(--mdui-color-surface-container-highest));border-radius:var(--mdui-shape-corner-extra-small) var(--mdui-shape-corner-extra-small) 0 0}:host([variant=filled]) .container.invalid,:host([variant=filled]) .container.invalid-style{box-shadow:inset 0 -.0625rem 0 0 rgb(var(--mdui-color-error))}:host([variant=filled]:hover) .container{box-shadow:inset 0 -.0625rem 0 0 rgb(var(--mdui-color-on-surface))}:host([variant=filled]:hover) .container.invalid,:host([variant=filled]:hover) .container.invalid-style{box-shadow:inset 0 -.0625rem 0 0 rgb(var(--mdui-color-on-error-container))}:host([variant=filled][focused-style]) .container,:host([variant=filled][focused]) .container{box-shadow:inset 0 -.125rem 0 0 rgb(var(--mdui-color-primary))}:host([variant=filled][focused-style]) .container.invalid,:host([variant=filled][focused-style]) .container.invalid-style,:host([variant=filled][focused]) .container.invalid,:host([variant=filled][focused]) .container.invalid-style{box-shadow:inset 0 -.125rem 0 0 rgb(var(--mdui-color-error))}:host([variant=filled][disabled]:not([disabled=false i])) .container{box-shadow:inset 0 -.0625rem 0 0 rgba(var(--mdui-color-on-surface),38%);background-color:rgba(var(--mdui-color-on-surface),4%)}:host([variant=outlined]) .container{box-shadow:inset 0 0 0 .0625rem rgb(var(--mdui-color-outline));border-radius:var(--mdui-shape-corner-extra-small)}:host([variant=outlined]) .container.invalid,:host([variant=outlined]) .container.invalid-style{box-shadow:inset 0 0 0 .0625rem rgb(var(--mdui-color-error))}:host([variant=outlined]:hover) .container{box-shadow:inset 0 0 0 .0625rem rgb(var(--mdui-color-on-surface))}:host([variant=outlined]:hover) .container.invalid,:host([variant=outlined]:hover) .container.invalid-style{box-shadow:inset 0 0 0 .0625rem rgb(var(--mdui-color-on-error-container))}:host([variant=outlined][focused-style]) .container,:host([variant=outlined][focused]) .container{box-shadow:inset 0 0 0 .125rem rgb(var(--mdui-color-primary))}:host([variant=outlined][focused-style]) .container.invalid,:host([variant=outlined][focused-style]) .container.invalid-style,:host([variant=outlined][focused]) .container.invalid,:host([variant=outlined][focused]) .container.invalid-style{box-shadow:inset 0 0 0 .125rem rgb(var(--mdui-color-error))}:host([variant=outlined][disabled]:not([disabled=false i])) .container{box-shadow:inset 0 0 0 .125rem rgba(var(--mdui-color-on-surface),12%)}.action,.icon,.prefix,.right-icon,.suffix{display:flex;-webkit-user-select:none;user-select:none;color:rgb(var(--mdui-color-on-surface-variant))}:host([disabled]:not([disabled=false i])) .action,:host([disabled]:not([disabled=false i])) .icon,:host([disabled]:not([disabled=false i])) .prefix,:host([disabled]:not([disabled=false i])) .right-icon,:host([disabled]:not([disabled=false i])) .suffix{color:rgba(var(--mdui-color-on-surface),38%)}.invalid .right-icon,.invalid-style .right-icon{color:rgb(var(--mdui-color-error))}:host(:hover) .invalid .right-icon,:host(:hover) .invalid-style .right-icon{color:rgb(var(--mdui-color-on-error-container))}:host([focused-style]) .invalid .right-icon,:host([focused-style]) .invalid-style .right-icon,:host([focused]) .invalid .right-icon,:host([focused]) .invalid-style .right-icon{color:rgb(var(--mdui-color-error))}.action,.icon,.right-icon{font-size:1.5rem}.action mdui-button-icon,.icon mdui-button-icon,.right-icon mdui-button-icon,::slotted(mdui-button-icon[slot]){margin-left:-.5rem;margin-right:-.5rem}.action .i,.icon .i,.right-icon .i,::slotted([slot$=icon]){font-size:inherit}.has-icon .icon{margin-right:1rem}.has-prefix .prefix{padding-right:.125rem}.has-action .action{margin-left:.75rem}.has-suffix .suffix{padding-right:.25rem;padding-left:.125rem}.has-right-icon .right-icon{margin-left:.75rem}.prefix,.suffix{display:none;font-size:var(--mdui-typescale-body-large-size);font-weight:var(--mdui-typescale-body-large-weight);letter-spacing:var(--mdui-typescale-body-large-tracking);line-height:var(--mdui-typescale-body-large-line-height)}:host([variant=filled][label]) .prefix,:host([variant=filled][label]) .suffix{padding-top:1rem}.has-value .prefix,.has-value .suffix,:host([focused-style]) .prefix,:host([focused-style]) .suffix,:host([focused]) .prefix,:host([focused]) .suffix{display:flex}.input-container{display:flex;width:100%;height:100%}.label{position:absolute;pointer-events:none;max-width:calc(100% - 1rem);display:-webkit-box;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:1;transition:all var(--mdui-motion-duration-short4) var(--mdui-motion-easing-standard);top:1rem;color:rgb(var(--mdui-color-on-surface-variant));font-size:var(--mdui-typescale-body-large-size);font-weight:var(--mdui-typescale-body-large-weight);letter-spacing:var(--mdui-typescale-body-large-tracking);line-height:var(--mdui-typescale-body-large-line-height)}.invalid .label,.invalid-style .label{color:rgb(var(--mdui-color-error))}:host([variant=outlined]) .label{padding:0 .25rem;margin:0 -.25rem}:host([variant=outlined]:hover) .label{color:rgb(var(--mdui-color-on-surface))}:host([variant=filled]:hover) .invalid .label,:host([variant=filled]:hover) .invalid-style .label,:host([variant=outlined]:hover) .invalid .label,:host([variant=outlined]:hover) .invalid-style .label{color:rgb(var(--mdui-color-on-error-container))}:host([variant=filled][focused-style]) .label,:host([variant=filled][focused]) .label,:host([variant=outlined][focused-style]) .label,:host([variant=outlined][focused]) .label{color:rgb(var(--mdui-color-primary))}:host([variant=filled]) .has-value .label,:host([variant=filled][focused-style]) .label,:host([variant=filled][focused]) .label,:host([variant=filled][type=date]) .label,:host([variant=filled][type=datetime-local]) .label,:host([variant=filled][type=month]) .label,:host([variant=filled][type=time]) .label,:host([variant=filled][type=week]) .label{font-size:var(--mdui-typescale-body-small-size);font-weight:var(--mdui-typescale-body-small-weight);letter-spacing:var(--mdui-typescale-body-small-tracking);line-height:var(--mdui-typescale-body-small-line-height);top:.25rem}:host([variant=outlined]) .has-value .label,:host([variant=outlined][focused-style]) .label,:host([variant=outlined][focused]) .label,:host([variant=outlined][type=date]) .label,:host([variant=outlined][type=datetime-local]) .label,:host([variant=outlined][type=month]) .label,:host([variant=outlined][type=time]) .label,:host([variant=outlined][type=week]) .label{font-size:var(--mdui-typescale-body-small-size);font-weight:var(--mdui-typescale-body-small-weight);letter-spacing:var(--mdui-typescale-body-small-tracking);line-height:var(--mdui-typescale-body-small-line-height);top:-.5rem;left:.75rem;background-color:rgb(var(--mdui-color-background))}:host([variant=filled][focused-style]) .invalid .label,:host([variant=filled][focused-style]) .invalid-style .label,:host([variant=filled][focused]) .invalid .label,:host([variant=filled][focused]) .invalid-style .label,:host([variant=outlined][focused-style]) .invalid .label,:host([variant=outlined][focused-style]) .invalid-style .label,:host([variant=outlined][focused]) .invalid .label,:host([variant=outlined][focused]) .invalid-style .label{color:rgb(var(--mdui-color-error))}:host([variant=filled][disabled]:not([disabled=false i])) .label,:host([variant=outlined][disabled]:not([disabled=false i])) .label{color:rgba(var(--mdui-color-on-surface),38%)}.input{display:block;width:100%;border:none;outline:0;background:0 0;appearance:none;resize:none;cursor:inherit;font-family:inherit;padding:.875rem .875rem .875rem 0;font-size:var(--mdui-typescale-body-large-size);font-weight:var(--mdui-typescale-body-large-weight);letter-spacing:var(--mdui-typescale-body-large-tracking);line-height:var(--mdui-typescale-body-large-line-height);color:rgb(var(--mdui-color-on-surface));caret-color:rgb(var(--mdui-color-primary))}.has-action .input,.has-right-icon .input{padding-right:.25rem}.has-suffix .input{padding-right:0}.input.hide-input{opacity:0;height:0;min-height:0;width:0;padding:0!important;overflow:hidden}.input::placeholder{color:rgb(var(--mdui-color-on-surface-variant))}.invalid .input,.invalid-style .input{caret-color:rgb(var(--mdui-color-error))}:host([disabled]:not([disabled=false i])) .input{color:rgba(var(--mdui-color-on-surface),38%)}:host([end-aligned]:not([end-aligned=false i])) .input{text-align:right}textarea.input{padding-top:0;margin-top:.875rem}:host([variant=filled]) .label+.input{padding-top:1.375rem;padding-bottom:.375rem}:host([variant=filled]) .label+textarea.input{padding-top:0;margin-top:1.375rem}.supporting{display:flex;justify-content:space-between;padding:.25rem 1rem;color:rgb(var(--mdui-color-on-surface-variant))}.supporting.invalid,.supporting.invalid-style{color:rgb(var(--mdui-color-error))}.helper{display:block;opacity:1;transition:opacity var(--mdui-motion-duration-short4) var(--mdui-motion-easing-linear);font-size:var(--mdui-typescale-body-small-size);font-weight:var(--mdui-typescale-body-small-weight);letter-spacing:var(--mdui-typescale-body-small-tracking);line-height:var(--mdui-typescale-body-small-line-height)}:host([disabled]:not([disabled=false i])) .helper{color:rgba(var(--mdui-color-on-surface),38%)}:host([helper-on-focus]:not([helper-on-focus=false i])) .helper{opacity:0}:host([helper-on-focus][focused-style]:not([helper-on-focus=false i])) .helper,:host([helper-on-focus][focused]:not([helper-on-focus=false i])) .helper{opacity:1}.error{font-size:var(--mdui-typescale-body-small-size);font-weight:var(--mdui-typescale-body-small-weight);letter-spacing:var(--mdui-typescale-body-small-tracking);line-height:var(--mdui-typescale-body-small-line-height)}.counter{flex-wrap:nowrap;padding-left:1rem;font-size:var(--mdui-typescale-body-small-size);font-weight:var(--mdui-typescale-body-small-weight);letter-spacing:var(--mdui-typescale-body-small-tracking);line-height:var(--mdui-typescale-body-small-line-height)}::-ms-reveal{display:none}.input[type=number]::-webkit-inner-spin-button,.input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;display:none}.input[type=number]{-moz-appearance:textfield}.input[type=search]::-webkit-search-cancel-button{-webkit-appearance:none}`;
let TextField = class TextField2 extends FocusableMixin(MduiElement) {
constructor() {
super(...arguments);
this.variant = "filled";
this.type = "text";
this.name = "";
this.value = "";
this.defaultValue = "";
this.helperOnFocus = false;
this.clearable = false;
this.endAligned = false;
this.readonly = false;
this.disabled = false;
this.required = false;
this.autosize = false;
this.counter = false;
this.togglePassword = false;
this.spellcheck = false;
this.invalid = false;
this.invalidStyle = false;
this.focusedStyle = false;
this.isPasswordVisible = false;
this.hasValue = false;
this.error = "";
this.inputRef = e$2();
this.formController = new FormController(this);
this.hasSlotController = new HasSlotController(this, "icon", "end-icon", "helper", "input");
this.readonlyButClearable = false;
}
/**
* 表单验证状态对象,具体参见 [`ValidityState`](https://developer.mozilla.org/zh-CN/docs/Web/API/ValidityState)
*/
get validity() {
return this.inputRef.value.validity;
}
/**
* 如果表单验证未通过,此属性将包含提示信息。如果验证通过,此属性将为空字符串
*/
get validationMessage() {
return this.inputRef.value.validationMessage;
}
/**
* 获取当前值,并转换为 `number` 类型;或设置一个 `number` 类型的值。
* 如果值无法被转换为 `number` 类型,则会返回 `NaN`。
*/
get valueAsNumber() {
var _a2;
return ((_a2 = this.inputRef.value) == null ? void 0 : _a2.valueAsNumber) ?? parseFloat(this.value);
}
set valueAsNumber(newValue) {
const input = document.createElement("input");
input.type = "number";
input.valueAsNumber = newValue;
this.value = input.value;
}
get focusElement() {
return this.inputRef.value;
}
get focusDisabled() {
return this.disabled;
}
/**
* 是否显示聚焦状态样式
*/
get isFocusedStyle() {
return this.focused || this.focusedStyle;
}
/**
* 是否渲染为 textarea。为 false 时渲染为 input
*/
get isTextarea() {
return this.rows && this.rows > 1 || this.autosize;
}
onDisabledChange() {
this.inputRef.value.disabled = this.disabled;
this.invalid = !this.inputRef.value.checkValidity();
}
async onValueChange() {
var _a2;
this.hasValue = !["", null].includes(this.value);
if (this.hasUpdated) {
await this.updateComplete;
this.setTextareaHeight();
const form = this.formController.getForm();
if (form && ((_a2 = formResets.get(form)) == null ? void 0 : _a2.has(this))) {
this.invalid = false;
formResets.get(form).delete(this);
} else {
this.invalid = !this.inputRef.value.checkValidity();
}
}
}
onRowsChange() {
this.setTextareaHeight();
}
async onMaxRowsChange() {
if (!this.autosize) {
return;
}
if (!this.hasUpdated) {
await this.updateComplete;
}
const $input = $$1(this.inputRef.value);
$input.css("max-height", parseFloat($input.css("line-height")) * (this.maxRows ?? 1) + parseFloat($input.css("padding-top")) + parseFloat($input.css("padding-bottom")));
}
async onMinRowsChange() {
if (!this.autosize) {
return;
}
if (!this.hasUpdated) {
await this.updateComplete;
}
const $input = $$1(this.inputRef.value);
$input.css("min-height", parseFloat($input.css("line-height")) * (this.minRows ?? 1) + parseFloat($input.css("padding-top")) + parseFloat($input.css("padding-bottom")));
}
connectedCallback() {
super.connectedCallback();
this.updateComplete.then(() => {
this.setTextareaHeight();
this.observeResize = observeResize(this.inputRef.value, () => this.setTextareaHeight());
});
}
disconnectedCallback() {
var _a2;
super.disconnectedCallback();
(_a2 = this.observeResize) == null ? void 0 : _a2.unobserve();
offLocaleReady(this);
}
/**
* 选中文本框中的文本
*/
select() {
this.inputRef.value.select();
}
/**
* 选中文本框中特定范围的内容
*
* @param start 被选中的第一个字符的位置索引,从 `0` 开始。如果这个值比元素的 `value` 长度还大,则会被看作 `value` 最后一个位置的索引
* @param end 被选中的最后一个字符的*下一个*位置索引。如果这个值比元素的 `value` 长度还大,则会被看作 `value` 最后一个位置的索引
* @param direction 一个表示选择方向的字符串,可能的值有:`forward`、`backward`、`none`
*/
setSelectionRange(start, end, direction = "none") {
this.inputRef.value.setSelectionRange(start, end, direction);
}
/**
* 将文本框中特定范围的文本替换为新的文本
* @param replacement 要插入的字符串
* @param start 要替换的字符的起止位置的索引。默认为当前用户选中的字符的起始位置的索引
* @param end 要替换的字符的结束位置的索引。默认为当前用户选中的字符的结束位置的索引
* @param selectMode 文本被替换后,选取的状态。可选值为:
* * `select`:选择新插入的文本
* * `start`:将光标移动到新插入的文本的起始位置
* * `end`:将光标移动到新插入的文本的结束位置
* * `preserve`:默认值。尝试保留选取
*/
setRangeText(replacement, start, end, selectMode = "preserve") {
this.inputRef.value.setRangeText(replacement, start, end, selectMode);
if (this.value !== this.inputRef.value.value) {
this.value = this.inputRef.value.value;
this.setTextareaHeight();
this.emit("input");
this.emit("change");
}
}
/**
* 检查表单字段是否通过验证。如果未通过,返回 `false` 并触发 `invalid` 事件;如果通过,返回 `true`
*/
checkValidity() {
const valid = this.inputRef.value.checkValidity();
if (!valid) {
this.emit("invalid", {
bubbles: false,
cancelable: true,
composed: false
});
}
return valid;
}
/**
* 检查表单字段是否通过验证。如果未通过,返回 `false` 并触发 `invalid` 事件;如果通过,返回 `true`。
*
* 如果验证未通过,还会在组件上显示验证失败的提示。
*/
reportValidity() {
this.invalid = !this.inputRef.value.reportValidity();
if (this.invalid) {
this.emit("invalid", {
bubbles: false,
cancelable: true,
composed: false
});
this.focus();
}
return !this.invalid;
}
/**
* 设置自定义的错误提示文本。只要这个文本不为空,就表示字段未通过验证
*
* @param message 自定义的错误提示文本
*/
setCustomValidity(message) {
this.setCustomValidityInternal(message);
offLocaleReady(this);
}
render() {
const hasIcon = !!this.icon || this.hasSlotController.test("icon");
const hasEndIcon = !!this.endIcon || this.hasSlotController.test("end-icon");
const hasErrorIcon = this.invalid || this.invalidStyle;
const hasTogglePasswordButton = this.type === "password" && this.togglePassword && !this.disabled;
const hasClearButton = this.clearable && !this.disabled && (!this.readonly || this.readonlyButClearable) && (typeof this.value === "number" || this.value.length > 0);
const hasPrefix = !!this.prefix || this.hasSlotController.test("prefix");
const hasSuffix = !!this.suffix || this.hasSlotController.test("suffix");
const hasHelper = !!this.helper || this.hasSlotController.test("helper");
const hasError = hasErrorIcon && !!(this.error || this.inputRef.value.validationMessage);
const hasCounter = this.counter && !!this.maxlength;
const hasInputSlot = this.hasSlotController.test("input");
const invalidClassNameObj = {
invalid: this.invalid,
"invalid-style": this.invalidStyle
};
const className2 = e$1({
container: true,
"has-value": this.hasValue,
"has-icon": hasIcon,
"has-right-icon": hasEndIcon || hasErrorIcon,
"has-action": hasClearButton || hasTogglePasswordButton,
"has-prefix": hasPrefix,
"has-suffix": hasSuffix,
"is-firefox": navigator.userAgent.includes("Firefox"),
...invalidClassNameObj
});
return x`<div part="container" class="${className2}">${this.renderPrefix()}<div class="input-container">${this.renderLabel()} ${this.isTextarea ? this.renderTextArea(hasInputSlot) : this.renderInput(hasInputSlot)} ${n$1(hasInputSlot, () => x`<slot name="input" class="input"></slot>`)}</div>${this.renderSuffix()}${this.renderClearButton(hasClearButton)} ${this.renderTogglePasswordButton(hasTogglePasswordButton)} ${this.renderRightIcon(hasErrorIcon)}</div>${n$1(hasError || hasHelper || hasCounter, () => x`<div part="supporting" class="${e$1({ supporting: true, ...invalidClassNameObj })}">${this.renderHelper(hasError, hasHelper)} ${this.renderCounter(hasCounter)}</div>`)}`;
}
setCustomValidityInternal(message) {
this.inputRef.value.setCustomValidity(message);
this.invalid = !this.inputRef.value.checkValidity();
this.requestUpdate();
}
onChange() {
this.value = this.inputRef.value.value;
if (this.isTextarea) {
this.setTextareaHeight();
}
this.emit("change");
}
onClear(event) {
this.value = "";
this.emit("clear");
this.emit("input");
this.emit("change");
this.focus();
event.stopPropagation();
}
onInput(event) {
event.stopPropagation();
this.value = this.inputRef.value.value;
if (this.isTextarea) {
this.setTextareaHeight();
}
this.emit("input");
}
onInvalid(event) {
event.preventDefault();
}
onKeyDown(event) {
const hasModifier = event.metaKey || event.ctrlKey || event.shiftKey || event.altKey;
if (event.key === "Enter" && !hasModifier) {
setTimeout(() => {
if (!event.defaultPrevented) {
this.formController.submit();
}
});
}
}
/**
* textarea 不支持 pattern 属性,所以在 keyup 时执行验证
*/
onTextAreaKeyUp() {
if (this.pattern) {
const patternRegex = new RegExp(this.pattern);
const hasError = this.value && !this.value.match(patternRegex);
if (hasError) {
this.setCustomValidityInternal(this.getPatternErrorMsg());
onLocaleReady(this, () => {
this.setCustomValidityInternal(this.getPatternErrorMsg());
});
} else {
this.setCustomValidityInternal("");
offLocaleReady(this);
}
}
}
onTogglePassword() {
this.isPasswordVisible = !this.isPasswordVisible;
}
getPatternErrorMsg() {
return msg("Please match the requested format.");
}
setTextareaHeight() {
if (this.autosize) {
this.inputRef.value.style.height = "auto";
this.inputRef.value.style.height = `${this.inputRef.value.scrollHeight}px`;
} else {
this.inputRef.value.style.height = void 0;
}
}
renderLabel() {
return this.label ? x`<label part="label" class="label">${this.label}</label>` : nothingTemplate;
}
renderPrefix() {
return x`<slot name="icon" part="icon" class="icon">${this.icon ? x`<mdui-icon name="${this.icon}" class="i"></mdui-icon>` : nothingTemplate}</slot><slot name="prefix" part="prefix" class="prefix">${this.prefix}</slot>`;
}
renderSuffix() {
return x`<slot name="suffix" part="suffix" class="suffix">${this.suffix}</slot>`;
}
renderRightIcon(hasErrorIcon) {
return hasErrorIcon ? x`<slot name="error-icon" part="error-icon" class="right-icon">${this.errorIcon ? x`<mdui-icon name="${this.errorIcon}" class="i"></mdui-icon>` : x`<mdui-icon-error class="i"></mdui-icon-error>`}</slot>` : x`<slot name="end-icon" part="end-icon" class="end-icon right-icon">${this.endIcon ? x`<mdui-icon name="${this.endIcon}" class="i"></mdui-icon>` : nothingTemplate}</slot>`;
}
renderClearButton(hasClearButton) {
return n$1(hasClearButton, () => x`<slot name="clear-button" part="clear-button" class="action" @click="${this.onClear}"><mdui-button-icon tabindex="-1"><slot name="clear-icon" part="clear-icon">${this.clearIcon ? x`<mdui-icon name="${this.clearIcon}" class="i"></mdui-icon>` : x`<mdui-icon-cancel--outlined class="i"></mdui-icon-cancel--outlined>`}</slot></mdui-button-icon></slot>`);
}
renderTogglePasswordButton(hasTogglePasswordButton) {
return n$1(hasTogglePasswordButton, () => x`<slot name="toggle-password-button" part="toggle-password-button" class="action" @click="${this.onTogglePassword}"><mdui-button-icon tabindex="-1">${this.isPasswordVisible ? x`<slot name="show-password-icon" part="show-password-icon">${this.showPasswordIcon ? x`<mdui-icon name="${this.showPasswordIcon}" class="i"></mdui-icon>` : x`<mdui-icon-visibility-off class="i"></mdui-icon-visibility-off>`}</slot>` : x`<slot name="hide-password-icon" part="hide-password-icon">${this.hidePasswordIcon ? x`<mdui-icon name="${this.hidePasswordIcon}" class="i"></mdui-icon>` : x`<mdui-icon-visibility class="i"></mdui-icon-visibility>`}</slot>`}</mdui-button-icon></slot>`);
}
renderInput(hasInputSlot) {
return x`<input ${n$2(this.inputRef)} part="input" class="input ${e$1({ "hide-input": hasInputSlot })}" type="${this.type === "password" && this.isPasswordVisible ? "text" : this.type}" name="${o$5(this.name)}" .value="${l$1(this.value)}" placeholder="${o$5(
// @ts-ignore
!this.label || this.isFocusedStyle || this.hasValue ? this.placeholder : void 0
)}" ?readonly="${this.readonly}" ?disabled="${this.disabled}" ?required="${this.required}" minlength="${o$5(this.minlength)}" maxlength="${o$5(this.maxlength)}" min="${o$5(this.min)}" max="${o$5(this.max)}" step="${o$5(this.step)}" autocapitalize="${o$5(this.type === "password" ? "off" : this.autocapitalize)}" autocomplete="${this.autocomplete}" autocorrect="${o$5(this.type === "password" ? "off" : this.autocorrect)}" spellcheck="${o$5(this.spellcheck)}" pattern="${o$5(this.pattern)}" enterkeyhint="${o$5(this.enterkeyhint)}" inputmode="${o$5(this.inputmode)}" @change="${this.onChange}" @input="${this.onInput}" @invalid="${this.onInvalid}" @keydown="${this.onKeyDown}">`;
}
renderTextArea(hasInputSlot) {
return x`<textarea ${n$2(this.inputRef)} part="input" class="input ${e$1({ "hide-input": hasInputSlot })}" name="${o$5(this.name)}" .value="${l$1(this.value)}" placeholder="${o$5(
// @ts-ignore
!this.label || this.isFocusedStyle || this.hasValue ? this.placeholder : void 0
)}" ?readonly="${this.readonly}" ?disabled="${this.disabled}" ?required="${this.required}" minlength="${o$5(this.minlength)}" maxlength="${o$5(this.maxlength)}" rows="${this.rows ?? 1}" autocapitalize="${o$5(this.autocapitalize)}" autocorrect="${o$5(this.autocorrect)}" spellcheck="${o$5(this.spellcheck)}" enterkeyhint="${o$5(this.enterkeyhint)}" inputmode="${o$5(this.inputmode)}" @change="${this.onChange}" @input="${this.onInput}" @invalid="${this.onInvalid}" @keydown="${this.onKeyDown}" @keyup="${this.onTextAreaKeyUp}"></textarea>`;
}
/**
* @param hasError 是否包含错误提示
* @param hasHelper 是否含 helper 属性或 helper slot
*/
renderHelper(hasError, hasHelper) {
return hasError ? x`<div part="error" class="error">${this.error || this.inputRef.value.validationMessage}</div>` : hasHelper ? x`<slot name="helper" part="helper" class="helper">${this.helper}</slot>` : (
// 右边有 counter,需要占位
x`<span></span>`
);
}
renderCounter(hasCounter) {
return hasCounter ? x`<div part="counter" class="counter">${this.value.length}/${this.maxlength}</div>` : nothingTemplate;
}
};
TextField.styles = [componentStyle, style$5];
__decorate([
n$6({ reflect: true })
], TextField.prototype, "variant", void 0);
__decorate([
n$6({ reflect: true })
], TextField.prototype, "type", void 0);
__decorate([
n$6({ reflect: true })
], TextField.prototype, "name", void 0);
__decorate([
n$6()
], TextField.prototype, "value", void 0);
__decorate([
defaultValue()
], TextField.prototype, "defaultValue", void 0);
__decorate([
n$6({ reflect: true })
], TextField.prototype, "label", void 0);
__decorate([
n$6({ reflect: true })
], TextField.prototype, "placeholder", void 0);
__decorate([
n$6({ reflect: true })
], TextField.prototype, "helper", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter,
attribute: "helper-on-focus"
})
], TextField.prototype, "helperOnFocus", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], TextField.prototype, "clearable", void 0);
__decorate([
n$6({ reflect: true, attribute: "clear-icon" })
], TextField.prototype, "clearIcon", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter,
attribute: "end-aligned"
})
], TextField.prototype, "endAligned", void 0);
__decorate([
n$6({ reflect: true })
], TextField.prototype, "prefix", void 0);
__decorate([
n$6({ reflect: true })
], TextField.prototype, "suffix", void 0);
__decorate([
n$6({ reflect: true })
], TextField.prototype, "icon", void 0);
__decorate([
n$6({ reflect: true, attribute: "end-icon" })
], TextField.prototype, "endIcon", void 0);
__decorate([
n$6({ reflect: true, attribute: "error-icon" })
], TextField.prototype, "errorIcon", void 0);
__decorate([
n$6({ reflect: true })
], TextField.prototype, "form", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], TextField.prototype, "readonly", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], TextField.prototype, "disabled", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], TextField.prototype, "required", void 0);
__decorate([
n$6({ type: Number, reflect: true })
], TextField.prototype, "rows", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], TextField.prototype, "autosize", void 0);
__decorate([
n$6({ type: Number, reflect: true, attribute: "min-rows" })
], TextField.prototype, "minRows", void 0);
__decorate([
n$6({ type: Number, reflect: true, attribute: "max-rows" })
], TextField.prototype, "maxRows", void 0);
__decorate([
n$6({ type: Number, reflect: true })
], TextField.prototype, "minlength", void 0);
__decorate([
n$6({ type: Number, reflect: true })
], TextField.prototype, "maxlength", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], TextField.prototype, "counter", void 0);
__decorate([
n$6({ type: Number, reflect: true })
], TextField.prototype, "min", void 0);
__decorate([
n$6({ type: Number, reflect: true })
], TextField.prototype, "max", void 0);
__decorate([
n$6({ type: Number, reflect: true })
], TextField.prototype, "step", void 0);
__decorate([
n$6({ reflect: true })
], TextField.prototype, "pattern", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter,
attribute: "toggle-password"
})
], TextField.prototype, "togglePassword", void 0);
__decorate([
n$6({ reflect: true, attribute: "show-password-icon" })
], TextField.prototype, "showPasswordIcon", void 0);
__decorate([
n$6({ reflect: true, attribute: "hide-password-icon" })
], TextField.prototype, "hidePasswordIcon", void 0);
__decorate([
n$6({ reflect: true })
], TextField.prototype, "autocapitalize", void 0);
__decorate([
n$6({ reflect: true })
], TextField.prototype, "autocorrect", void 0);
__decorate([
n$6({ reflect: true })
], TextField.prototype, "autocomplete", void 0);
__decorate([
n$6({ reflect: true })
], TextField.prototype, "enterkeyhint", void 0);
__decorate([
n$6({ type: Boolean, reflect: true, converter: booleanConverter })
], TextField.prototype, "spellcheck", void 0);
__decorate([
n$6({ reflect: true })
], TextField.prototype, "inputmode", void 0);
__decorate([
r$1()
], TextField.prototype, "invalid", void 0);
__decorate([
r$1()
], TextField.prototype, "invalidStyle", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter,
attribute: "focused-style"
})
], TextField.prototype, "focusedStyle", void 0);
__decorate([
r$1()
], TextField.prototype, "isPasswordVisible", void 0);
__decorate([
r$1()
], TextField.prototype, "hasValue", void 0);
__decorate([
r$1()
], TextField.prototype, "error", void 0);
__decorate([
watch("disabled", true)
], TextField.prototype, "onDisabledChange", null);
__decorate([
watch("value")
], TextField.prototype, "onValueChange", null);
__decorate([
watch("rows", true)
], TextField.prototype, "onRowsChange", null);
__decorate([
watch("maxRows")
], TextField.prototype, "onMaxRowsChange", null);
__decorate([
watch("minRows")
], TextField.prototype, "onMinRowsChange", null);
TextField = __decorate([
t$3("mdui-text-field")
], TextField);
const style$4 = i$7`:host{display:inline-block;width:100%}.hidden-input{display:none}.text-field{cursor:pointer}.chips{display:flex;flex-wrap:wrap;margin:-.5rem -.25rem;min-height:2.5rem}:host([variant=filled][label]) .chips{margin:0 -.25rem -1rem -.25rem}.chip{margin:.25rem}mdui-menu{max-width:none}`;
let Select = class Select2 extends FocusableMixin(MduiElement) {
constructor() {
super(...arguments);
this.variant = "filled";
this.multiple = false;
this.name = "";
this.value = "";
this.defaultValue = "";
this.clearable = false;
this.placement = "auto";
this.endAligned = false;
this.readonly = false;
this.disabled = false;
this.required = false;
this.invalid = false;
this.menuRef = e$2();
this.textFieldRef = e$2();
this.hiddenInputRef = e$2();
this.formController = new FormController(this);
this.hasSlotController = new HasSlotController(this, "icon", "end-icon", "error-icon", "prefix", "suffix", "clear-button", "clear-icon", "helper");
this.definedController = new DefinedController(this, {
relatedElements: ["mdui-menu-item"]
});
}
/**
* 表单验证状态对象,具体参见 [`ValidityState`](https://developer.mozilla.org/zh-CN/docs/Web/API/ValidityState)
*/
get validity() {
return this.hiddenInputRef.value.validity;
}
/**
* 如果表单验证未通过,此属性将包含提示信息。如果验证通过,此属性将为空字符串
*/
get validationMessage() {
return this.hiddenInputRef.value.validationMessage;
}
get focusElement() {
return this.textFieldRef.value;
}
get focusDisabled() {
return this.disabled;
}
connectedCallback() {
super.connectedCallback();
this.value = this.multiple && isString(this.value) ? this.value ? [this.value] : [] : this.value;
this.defaultValue = this.multiple ? [] : "";
this.definedController.whenDefined().then(() => {
this.requestUpdate();
});
this.updateComplete.then(() => {
this.observeResize = observeResize(this.textFieldRef.value, () => this.resizeMenu());
});
}
disconnectedCallback() {
var _a2;
super.disconnectedCallback();
(_a2 = this.observeResize) == null ? void 0 : _a2.unobserve();
}
/**
* 检查表单字段是否通过验证。如果未通过,返回 `false` 并触发 `invalid` 事件;如果通过,返回 `true`
*/
checkValidity() {
const valid = this.hiddenInputRef.value.checkValidity();
if (!valid) {
this.emit("invalid", {
bubbles: false,
cancelable: true,
composed: false
});
}
return valid;
}
/**
* 检查表单字段是否通过验证。如果未通过,返回 `false` 并触发 `invalid` 事件;如果通过,返回 `true`。
*
* 如果验证未通过,还会在组件上显示验证失败的提示。
*/
reportValidity() {
this.invalid = !this.hiddenInputRef.value.reportValidity();
if (this.invalid) {
this.emit("invalid", {
bubbles: false,
cancelable: true,
composed: false
});
this.focus();
}
return !this.invalid;
}
/**
* 设置自定义的错误提示文本。只要这个文本不为空,就表示字段未通过验证
*
* @param message 自定义的错误提示文本
*/
setCustomValidity(message) {
this.hiddenInputRef.value.setCustomValidity(message);
this.invalid = !this.hiddenInputRef.value.checkValidity();
}
render() {
var _a2;
const hasSelection = this.multiple ? !!this.value.length : !!this.value;
return x`${this.multiple ? x`<select ${n$2(this.hiddenInputRef)} class="hidden-input" name="${o$5(this.name)}" value="${o$5(this.value)}" .required="${this.required}" .disabled="${this.disabled}" multiple="multiple" tabindex="-1">${o(this.value, (value) => x`<option selected="selected" value="${value}"></option>`)}</select>` : x`<input ${n$2(this.hiddenInputRef)} type="radio" class="hidden-input" name="${o$5(this.name)}" value="${o$5(this.value)}" .required="${this.required}" .disabled="${this.disabled}" .checked="${hasSelection}" tabindex="-1">`}<mdui-dropdown .stayOpenOnClick="${this.multiple}" .disabled="${this.readonly || this.disabled}" .placement="${this.placement === "top" ? "top-start" : this.placement === "bottom" ? "bottom-start" : "auto"}" @open="${this.onDropdownOpen}" @close="${this.onDropdownClose}"><mdui-text-field ${n$2(this.textFieldRef)} slot="trigger" part="text-field" class="text-field" exportparts="${[
"container",
"icon",
"end-icon",
"error-icon",
"prefix",
"suffix",
"label",
"input",
"clear-button",
"clear-icon",
"supporting",
"helper",
"error"
].map((v2) => `${v2}:text-field__${v2}`).join(",")}" readonly="readonly" .readonlyButClearable="${true}" .variant="${this.variant}" .name="${this.name}" .value="${this.multiple ? this.value.length ? " " : "" : this.getMenuItemLabelByValue(this.value)}" .label="${this.label}" .placeholder="${this.placeholder}" .helper="${this.helper}" .error="${(_a2 = this.hiddenInputRef.value) == null ? void 0 : _a2.validationMessage}" .clearable="${this.clearable}" .clearIcon="${this.clearIcon}" .endAligned="${this.endAligned}" .prefix="${this.prefix}" .suffix="${this.suffix}" .icon="${this.icon}" .endIcon="${this.endIcon}" .errorIcon="${this.errorIcon}" .form="${this.form}" .disabled="${this.disabled}" .required="${this.required}" .invalidStyle="${this.invalid}" @clear="${this.onClear}" @change="${(e3) => e3.stopPropagation()}" @keydown="${this.onTextFieldKeyDown}">${o([
"icon",
"end-icon",
"error-icon",
"prefix",
"suffix",
"clear-button",
"clear-icon",
"helper"
], (slotName) => this.hasSlotController.test(slotName) ? x`<slot name="${slotName}" slot="${slotName}"></slot>` : E)} ${n$1(this.multiple && this.value.length, () => x`<div slot="input" class="chips" part="chips">${o(this.value, (valueItem) => x`<mdui-chip class="chip" part="chip" exportparts="${["button", "label", "delete-icon"].map((v2) => `${v2}:chip__${v2}`).join(",")}" variant="input" deletable tabindex="-1" @delete="${() => this.onDeleteOneValue(valueItem)}">${this.getMenuItemLabelByValue(valueItem)}</mdui-chip>`)}</div>`)}</mdui-text-field><mdui-menu ${n$2(this.menuRef)} part="menu" .selects="${this.multiple ? "multiple" : "single"}" .value="${this.value}" @change="${this.onValueChange}"><slot></slot></mdui-menu></mdui-dropdown>`;
}
getMenuItemLabelByValue(valueItem) {
var _a2, _b;
if (!this.menuItems.length) {
return valueItem;
}
return ((_b = (_a2 = this.menuItems.find((item) => item.value === valueItem)) == null ? void 0 : _a2.textContent) == null ? void 0 : _b.trim()) || valueItem;
}
resizeMenu() {
this.menuRef.value.style.width = `${this.textFieldRef.value.clientWidth}px`;
}
async onDropdownOpen() {
this.textFieldRef.value.focusedStyle = true;
}
onDropdownClose() {
var _a2;
this.textFieldRef.value.focusedStyle = false;
if (this.contains(document.activeElement) || this.contains(((_a2 = document.activeElement) == null ? void 0 : _a2.assignedSlot) ?? null)) {
setTimeout(() => {
this.focus();
});
}
}
async onValueChange(e3) {
var _a2;
const menu = e3.target;
this.value = this.multiple ? menu.value.map((v2) => v2 ?? "") : menu.value ?? "";
await this.updateComplete;
const form = this.formController.getForm();
if (form && ((_a2 = formResets.get(form)) == null ? void 0 : _a2.has(this))) {
this.invalid = false;
formResets.get(form).delete(this);
} else {
this.invalid = !this.hiddenInputRef.value.checkValidity();
}
}
/**
* multiple 为 true 时,点 chip 的删除按钮,删除其中一个值
*/
onDeleteOneValue(valueItem) {
const value = [...this.value];
if (value.includes(valueItem)) {
value.splice(value.indexOf(valueItem), 1);
}
this.value = value;
}
onClear() {
this.value = this.multiple ? [] : "";
}
/**
* 焦点在 text-field 上时,按下回车键,打开下拉选项
*/
onTextFieldKeyDown(event) {
if (event.key === "Enter") {
event.preventDefault();
this.textFieldRef.value.click();
}
}
};
Select.styles = [componentStyle, style$4];
__decorate([
n$6({ reflect: true })
], Select.prototype, "variant", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Select.prototype, "multiple", void 0);
__decorate([
n$6({ reflect: true })
], Select.prototype, "name", void 0);
__decorate([
n$6()
], Select.prototype, "value", void 0);
__decorate([
defaultValue()
], Select.prototype, "defaultValue", void 0);
__decorate([
n$6({ reflect: true })
], Select.prototype, "label", void 0);
__decorate([
n$6({ reflect: true })
], Select.prototype, "placeholder", void 0);
__decorate([
n$6({ reflect: true })
], Select.prototype, "helper", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Select.prototype, "clearable", void 0);
__decorate([
n$6({ reflect: true, attribute: "clear-icon" })
], Select.prototype, "clearIcon", void 0);
__decorate([
n$6({ reflect: true })
], Select.prototype, "placement", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter,
attribute: "end-aligned"
})
], Select.prototype, "endAligned", void 0);
__decorate([
n$6({ reflect: true })
], Select.prototype, "prefix", void 0);
__decorate([
n$6({ reflect: true })
], Select.prototype, "suffix", void 0);
__decorate([
n$6({ reflect: true })
], Select.prototype, "icon", void 0);
__decorate([
n$6({ reflect: true, attribute: "end-icon" })
], Select.prototype, "endIcon", void 0);
__decorate([
n$6({ reflect: true, attribute: "error-icon" })
], Select.prototype, "errorIcon", void 0);
__decorate([
n$6({ reflect: true })
], Select.prototype, "form", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Select.prototype, "readonly", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Select.prototype, "disabled", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Select.prototype, "required", void 0);
__decorate([
r$1()
], Select.prototype, "invalid", void 0);
__decorate([
o$6({ flatten: true, selector: "mdui-menu-item" })
], Select.prototype, "menuItems", void 0);
Select = __decorate([
t$3("mdui-select")
], Select);
const style$3 = i$7`.track-active{left:-.125rem;border-radius:var(--mdui-shape-corner-full) 0 0 var(--mdui-shape-corner-full)}`;
let Slider = class Slider2 extends SliderBase {
constructor() {
super(...arguments);
this.value = 0;
this.defaultValue = 0;
this.rippleRef = e$2();
this.handleRef = e$2();
this.formController = new FormController(this);
}
get rippleElement() {
return this.rippleRef.value;
}
async onValueChange() {
var _a2;
this.value = this.fixValue(this.value);
const form = this.formController.getForm();
if (form && ((_a2 = formResets.get(form)) == null ? void 0 : _a2.has(this))) {
this.invalid = false;
formResets.get(form).delete(this);
} else {
await this.updateComplete;
this.invalid = !this.inputRef.value.checkValidity();
}
this.updateStyle();
}
connectedCallback() {
super.connectedCallback();
this.value = this.fixValue(this.value);
}
firstUpdated(changedProperties) {
super.firstUpdated(changedProperties);
const onTouchStart = () => {
if (!this.disabled) {
this.labelVisible = true;
}
};
const onTouchEnd = () => {
if (!this.disabled) {
this.labelVisible = false;
}
};
this.addEventListener("touchstart", onTouchStart);
this.addEventListener("mousedown", onTouchStart);
this.addEventListener("touchend", onTouchEnd);
this.addEventListener("mouseup", onTouchEnd);
this.updateStyle();
}
/**
* <input /> 用于提供拖拽操作
* <input class="invalid" /> 用于提供 html5 自带的表单错误提示
*/
render() {
return x`<label class="${e$1({ invalid: this.invalid })}"><input ${n$2(this.inputRef)} type="range" step="${this.step}" min="${this.min}" max="${this.max}" ?disabled="${this.disabled}" .value="${l$1(this.value.toString())}" @input="${this.onInput}" @change="${this.onChange}"><div part="track-inactive" class="track-inactive"></div><div ${n$2(this.trackActiveRef)} part="track-active" class="track-active"></div><div ${n$2(this.handleRef)} part="handle" class="handle"><div class="elevation"></div><mdui-ripple ${n$2(this.rippleRef)} .noRipple="${this.noRipple}"></mdui-ripple>${this.renderLabel(this.value)}</div>${n$1(this.tickmarks, () => o(this.getCandidateValues(), (value) => x`<div part="tickmark" class="tickmark ${e$1({ active: value < this.value })}" style="${o$4({
left: `${(value - this.min) / this.max * 100}%`,
display: value === this.value ? "none" : "block"
})}"></div>`))}</label>`;
}
updateStyle() {
const percent = (this.value - this.min) / (this.max - this.min) * 100;
this.trackActiveRef.value.style.width = `${percent}%`;
this.handleRef.value.style.left = `${percent}%`;
}
onInput() {
this.value = parseFloat(this.inputRef.value.value);
this.updateStyle();
}
};
Slider.styles = [SliderBase.styles, style$3];
__decorate([
n$6({ type: Number })
], Slider.prototype, "value", void 0);
__decorate([
defaultValue()
], Slider.prototype, "defaultValue", void 0);
__decorate([
watch("value", true)
], Slider.prototype, "onValueChange", null);
Slider = __decorate([
t$3("mdui-slider")
], Slider);
const style$2 = i$7`:host{--shape-corner:var(--mdui-shape-corner-extra-small);--z-index:2400;position:fixed;z-index:var(--z-index);display:none;align-items:center;flex-wrap:wrap;border-radius:var(--shape-corner);transform:scaleY(0);transition:transform 0s var(--mdui-motion-easing-linear) var(--mdui-motion-duration-short4);min-width:20rem;max-width:36rem;padding:.25rem 0;box-shadow:var(--mdui-elevation-level3);background-color:rgb(var(--mdui-color-inverse-surface));color:rgb(var(--mdui-color-inverse-on-surface));font-size:var(--mdui-typescale-body-medium-size);font-weight:var(--mdui-typescale-body-medium-weight);letter-spacing:var(--mdui-typescale-body-medium-tracking);line-height:var(--mdui-typescale-body-medium-line-height)}:host([placement^=top]){transform-origin:top}:host([placement^=bottom]){transform-origin:bottom}:host([placement=bottom-start]:not([mobile])),:host([placement=top-start]:not([mobile])){left:1rem}:host([placement=bottom-end]:not([mobile])),:host([placement=top-end]:not([mobile])){right:1rem}:host([placement=bottom]:not([mobile])),:host([placement=top]:not([mobile])){left:50%;transform:scaleY(0) translateX(-50%)}:host([mobile]){min-width:0;left:1rem;right:1rem}:host([open]){transform:scaleY(1);transition:top var(--mdui-motion-duration-short4) var(--mdui-motion-easing-standard),bottom var(--mdui-motion-duration-short4) var(--mdui-motion-easing-standard),transform var(--mdui-motion-duration-medium4) var(--mdui-motion-easing-emphasized-decelerate)}:host([placement=bottom][open]:not([mobile])),:host([placement=top][open]:not([mobile])){transform:scaleY(1) translateX(-50%)}.message{display:block;margin:.625rem 1rem}:host([message-line='1']) .message{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host([message-line='2']) .message{display:-webkit-box;overflow:hidden;text-overflow:ellipsis;-webkit-box-orient:vertical;-webkit-line-clamp:2}.action-group{display:flex;align-items:center;margin-left:auto;padding-right:.5rem}.action,.close-button{display:inline-flex;align-items:center;justify-content:center}.action{color:rgb(var(--mdui-color-inverse-primary));font-size:var(--mdui-typescale-label-large-size);font-weight:var(--mdui-typescale-label-large-weight);letter-spacing:var(--mdui-typescale-label-large-tracking)}.action mdui-button,::slotted(mdui-button[slot=action][variant=outlined]),::slotted(mdui-button[slot=action][variant=text]){color:inherit;font-size:inherit;font-weight:inherit;letter-spacing:inherit;--mdui-comp-ripple-state-layer-color:var(--mdui-color-inverse-primary)}.action mdui-button::part(button){padding:0 .5rem}.close-button{margin:0 -.25rem 0 .25rem;font-size:1.5rem;color:rgb(var(--mdui-color-inverse-on-surface))}.close-button mdui-button-icon,::slotted(mdui-button-icon[slot=close-button][variant=outlined]),::slotted(mdui-button-icon[slot=close-button][variant=standard]){font-size:inherit;color:inherit;--mdui-comp-ripple-state-layer-color:var(--mdui-color-inverse-on-surface)}.close-button .i,::slotted([slot=close-icon]){font-size:inherit}`;
const stacks = [];
let reordering = false;
let Snackbar = class Snackbar2 extends MduiElement {
constructor() {
super();
this.open = false;
this.placement = "bottom";
this.actionLoading = false;
this.closeable = false;
this.autoCloseDelay = 5e3;
this.closeOnOutsideClick = false;
this.mobile = false;
this.onDocumentClick = this.onDocumentClick.bind(this);
}
async onOpenChange() {
const easingLinear = getEasing(this, "linear");
const children = Array.from(this.renderRoot.querySelectorAll(".message, .action-group"));
if (this.open) {
const hasUpdated = this.hasUpdated;
if (!hasUpdated) {
await this.updateComplete;
}
if (hasUpdated) {
const eventProceeded = this.emit("open", { cancelable: true });
if (!eventProceeded) {
return;
}
}
window.clearTimeout(this.closeTimeout);
if (this.autoCloseDelay) {
this.closeTimeout = window.setTimeout(() => {
this.open = false;
}, this.autoCloseDelay);
}
this.style.display = "flex";
await Promise.all([
stopAnimations(this),
...children.map((child) => stopAnimations(child))
]);
stacks.push({
height: this.clientHeight,
snackbar: this
});
await this.reorderStack(this);
const duration = getDuration(this, "medium4");
await Promise.all([
animateTo(this, [{ opacity: 0 }, { opacity: 1, offset: 0.5 }, { opacity: 1 }], {
duration: hasUpdated ? duration : 0,
easing: easingLinear,
fill: "forwards"
}),
...children.map((child) => animateTo(child, [
{ opacity: 0 },
{ opacity: 0, offset: 0.2 },
{ opacity: 1, offset: 0.8 },
{ opacity: 1 }
], {
duration: hasUpdated ? duration : 0,
easing: easingLinear
}))
]);
if (hasUpdated) {
this.emit("opened");
}
return;
}
if (!this.open && this.hasUpdated) {
const eventProceeded = this.emit("close", { cancelable: true });
if (!eventProceeded) {
return;
}
window.clearTimeout(this.closeTimeout);
await Promise.all([
stopAnimations(this),
...children.map((child) => stopAnimations(child))
]);
const duration = getDuration(this, "short4");
await Promise.all([
animateTo(this, [{ opacity: 1 }, { opacity: 0 }], {
duration,
easing: easingLinear,
fill: "forwards"
}),
...children.map((child) => animateTo(child, [{ opacity: 1 }, { opacity: 0, offset: 0.75 }, { opacity: 0 }], {
duration,
easing: easingLinear
}))
]);
this.style.display = "none";
this.emit("closed");
const stackIndex = stacks.findIndex((stack2) => stack2.snackbar === this);
stacks.splice(stackIndex, 1);
if (stacks[stackIndex]) {
await this.reorderStack(stacks[stackIndex].snackbar);
}
return;
}
}
/**
* 这两个属性变更时,需要重新排序该组件后面的 snackbar
*/
async onStackChange() {
await this.reorderStack(this);
}
connectedCallback() {
super.connectedCallback();
document.addEventListener("pointerdown", this.onDocumentClick);
this.mobile = breakpoint().down("sm");
this.observeResize = observeResize(document.documentElement, async () => {
const mobile = breakpoint().down("sm");
if (this.mobile !== mobile) {
this.mobile = mobile;
if (!reordering) {
reordering = true;
await this.reorderStack();
reordering = false;
}
}
});
}
disconnectedCallback() {
var _a2;
super.disconnectedCallback();
document.removeEventListener("pointerdown", this.onDocumentClick);
window.clearTimeout(this.closeTimeout);
if (this.open) {
this.open = false;
}
(_a2 = this.observeResize) == null ? void 0 : _a2.unobserve();
}
render() {
return x`<slot part="message" class="message"></slot><div class="action-group"><slot name="action" part="action" class="action" @click="${this.onActionClick}">${this.action ? x`<mdui-button variant="text" loading="${this.actionLoading}">${this.action}</mdui-button>` : nothingTemplate}</slot>${n$1(this.closeable, () => x`<slot name="close-button" part="close-button" class="close-button" @click="${this.onCloseClick}"><mdui-button-icon><slot name="close-icon" part="close-icon">${this.closeIcon ? x`<mdui-icon name="${this.closeIcon}" class="i"></mdui-icon>` : x`<mdui-icon-clear class="i"></mdui-icon-clear>`}</slot></mdui-button-icon></slot>`)}</div>`;
}
/**
* 重新排序 snackbar 堆叠
* @param startSnackbar 从哪个 snackbar 开始重新排列,默认从第一个开始
* @private
*/
async reorderStack(startSnackbar) {
const stackIndex = startSnackbar ? stacks.findIndex((stack2) => stack2.snackbar === startSnackbar) : 0;
for (let i3 = stackIndex; i3 < stacks.length; i3++) {
const stack2 = stacks[i3];
const snackbar2 = stack2.snackbar;
if (this.mobile) {
["top", "bottom"].forEach((placement) => {
if (snackbar2.placement.startsWith(placement)) {
const prevStacks = stacks.filter((stack3, index) => {
return index < i3 && stack3.snackbar.placement.startsWith(placement);
});
const prevHeight = prevStacks.reduce((prev, current) => prev + current.height, 0);
snackbar2.style[placement] = `calc(${prevHeight}px + ${prevStacks.length + 1}rem)`;
snackbar2.style[placement === "top" ? "bottom" : "top"] = "auto";
}
});
} else {
[
"top",
"top-start",
"top-end",
"bottom",
"bottom-start",
"bottom-end"
].forEach((placement) => {
if (snackbar2.placement === placement) {
const prevStacks = stacks.filter((stack3, index) => {
return index < i3 && stack3.snackbar.placement === placement;
});
const prevHeight = prevStacks.reduce((prev, current) => prev + current.height, 0);
snackbar2.style[placement.startsWith("top") ? "top" : "bottom"] = `calc(${prevHeight}px + ${prevStacks.length + 1}rem)`;
snackbar2.style[placement.startsWith("top") ? "bottom" : "top"] = "auto";
}
});
}
}
}
/**
* 在 document 上点击时,根据条件判断是否要关闭 snackbar
*/
onDocumentClick(e3) {
if (!this.open || !this.closeOnOutsideClick) {
return;
}
const target = e3.target;
if (!this.contains(target) && this !== target) {
this.open = false;
}
}
onActionClick(event) {
event.stopPropagation();
this.emit("action-click");
}
onCloseClick() {
this.open = false;
}
};
Snackbar.styles = [componentStyle, style$2];
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Snackbar.prototype, "open", void 0);
__decorate([
n$6({ reflect: true })
], Snackbar.prototype, "placement", void 0);
__decorate([
n$6({ reflect: true, attribute: "action" })
], Snackbar.prototype, "action", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter,
attribute: "action-loading"
})
], Snackbar.prototype, "actionLoading", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Snackbar.prototype, "closeable", void 0);
__decorate([
n$6({ reflect: true, attribute: "close-icon" })
], Snackbar.prototype, "closeIcon", void 0);
__decorate([
n$6({ type: Number, reflect: true, attribute: "message-line" })
// eslint-disable-next-line prettier/prettier
], Snackbar.prototype, "messageLine", void 0);
__decorate([
n$6({ type: Number, reflect: true, attribute: "auto-close-delay" })
], Snackbar.prototype, "autoCloseDelay", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
attribute: "close-on-outside-click",
converter: booleanConverter
})
], Snackbar.prototype, "closeOnOutsideClick", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Snackbar.prototype, "mobile", void 0);
__decorate([
watch("open")
], Snackbar.prototype, "onOpenChange", null);
__decorate([
watch("placement", true),
watch("messageLine", true)
], Snackbar.prototype, "onStackChange", null);
Snackbar = __decorate([
t$3("mdui-snackbar")
], Snackbar);
const style$1 = i$7`:host{--shape-corner:var(--mdui-shape-corner-full);--shape-corner-thumb:var(--mdui-shape-corner-full);position:relative;display:inline-block;cursor:pointer;-webkit-tap-highlight-color:transparent;height:2.5rem}:host([disabled]:not([disabled=false i])){cursor:default;pointer-events:none}label{display:inline-flex;align-items:center;width:100%;height:100%;white-space:nowrap;cursor:inherit;-webkit-user-select:none;user-select:none;touch-action:manipulation;zoom:1;-webkit-user-drag:none}.track{position:relative;display:flex;align-items:center;border-radius:var(--shape-corner);transition-property:background-color,border-width;transition-duration:var(--mdui-motion-duration-short4);transition-timing-function:var(--mdui-motion-easing-standard);height:2rem;width:3.25rem;border:.125rem solid rgb(var(--mdui-color-outline));background-color:rgb(var(--mdui-color-surface-container-highest))}:host([checked]:not([checked=false i])) .track{background-color:rgb(var(--mdui-color-primary));border-width:0}.invalid .track{background-color:rgb(var(--mdui-color-error-container));border-color:rgb(var(--mdui-color-error))}:host([disabled]:not([disabled=false i])) .track{background-color:rgba(var(--mdui-color-surface-container-highest),.12);border-color:rgba(var(--mdui-color-on-surface),.12)}:host([disabled][checked]:not([disabled=false i],[checked=false i])) .track{background-color:rgba(var(--mdui-color-on-surface),.12)}input{position:absolute;padding:0;opacity:0;pointer-events:none;width:1.25rem;height:1.25rem;margin:0 0 0 .625rem}mdui-ripple{border-radius:50%;transition-property:left,top;transition-duration:var(--mdui-motion-duration-short4);transition-timing-function:var(--mdui-motion-easing-standard);width:2.5rem;height:2.5rem}.thumb{position:absolute;display:flex;align-items:center;justify-content:center;border-radius:var(--shape-corner-thumb);transition-property:width,height,left,background-color;transition-duration:var(--mdui-motion-duration-short4);transition-timing-function:var(--mdui-motion-easing-standard);height:1rem;width:1rem;left:.375rem;background-color:rgb(var(--mdui-color-outline));--mdui-comp-ripple-state-layer-color:var(--mdui-color-on-surface)}.thumb mdui-ripple{left:-.75rem;top:-.75rem}.has-unchecked-icon .thumb{height:1.5rem;width:1.5rem;left:.125rem}.has-unchecked-icon .thumb mdui-ripple{left:-.5rem;top:-.5rem}:host([focus-visible]) .thumb,:host([hover]) .thumb,:host([pressed]) .thumb{background-color:rgb(var(--mdui-color-on-surface-variant))}:host([checked]:not([checked=false i])) .thumb{height:1.5rem;width:1.5rem;left:1.5rem;background-color:rgb(var(--mdui-color-on-primary));--mdui-comp-ripple-state-layer-color:var(--mdui-color-primary)}:host([checked]:not([checked=false i])) .thumb mdui-ripple{left:-.5rem;top:-.5rem}:host([pressed]) .thumb{height:1.75rem;width:1.75rem;left:0}:host([pressed]) .thumb mdui-ripple{left:-.375rem;top:-.375rem}:host([pressed][checked]:not([checked=false i])) .thumb{left:1.375rem}:host([focus-visible][checked]:not([checked=false i])) .thumb,:host([hover][checked]:not([checked=false i])) .thumb,:host([pressed][checked]:not([checked=false i])) .thumb{background-color:rgb(var(--mdui-color-primary-container))}.invalid .thumb{background-color:rgb(var(--mdui-color-error));--mdui-comp-ripple-state-layer-color:var(--mdui-color-error)}:host([focus-visible]) .invalid .thumb,:host([hover]) .invalid .thumb,:host([pressed]) .invalid .thumb{background-color:rgb(var(--mdui-color-error))}:host([disabled]:not([disabled=false i])) .thumb{background-color:rgba(var(--mdui-color-on-surface),.38)}:host([disabled][checked]:not([disabled=false i],[checked=false i])) .thumb{background-color:rgb(var(--mdui-color-surface))}.checked-icon,.unchecked-icon{display:flex;position:absolute;transition-property:opacity,transform;font-size:1rem}.unchecked-icon{opacity:1;transform:scale(1);transition-delay:var(--mdui-motion-duration-short1);transition-duration:var(--mdui-motion-duration-short3);transition-timing-function:var(--mdui-motion-easing-linear);color:rgb(var(--mdui-color-surface-container-highest))}:host([checked]:not([checked=false i])) .unchecked-icon{opacity:0;transform:scale(.92);transition-delay:0s;transition-duration:var(--mdui-motion-duration-short1)}:host([disabled]:not([disabled=false i])) .unchecked-icon{color:rgba(var(--mdui-color-surface-container-highest),.38)}.checked-icon{opacity:0;transform:scale(.92);transition-delay:0s;transition-duration:var(--mdui-motion-duration-short1);transition-timing-function:var(--mdui-motion-easing-linear);color:rgb(var(--mdui-color-on-primary-container))}:host([checked]:not([checked=false i])) .checked-icon{opacity:1;transform:scale(1);transition-delay:var(--mdui-motion-duration-short1);transition-duration:var(--mdui-motion-duration-short3)}.invalid .checked-icon{color:rgb(var(--mdui-color-error-container))}:host([disabled]:not([disabled=false i])) .checked-icon{color:rgba(var(--mdui-color-on-surface),.38)}.checked-icon .i,.unchecked-icon .i,::slotted([slot=checked-icon]),::slotted([slot=unchecked-icon]){font-size:inherit;color:inherit}`;
let Switch = class Switch2 extends RippleMixin(FocusableMixin(MduiElement)) {
constructor() {
super(...arguments);
this.disabled = false;
this.checked = false;
this.defaultChecked = false;
this.required = false;
this.name = "";
this.value = "on";
this.invalid = false;
this.rippleRef = e$2();
this.inputRef = e$2();
this.formController = new FormController(this, {
value: (control) => control.checked ? control.value : void 0,
defaultValue: (control) => control.defaultChecked,
setValue: (control, checked) => control.checked = checked
});
this.hasSlotController = new HasSlotController(this, "unchecked-icon");
}
/**
* 表单验证状态对象,具体参见 [`ValidityState`](https://developer.mozilla.org/zh-CN/docs/Web/API/ValidityState)
*/
get validity() {
return this.inputRef.value.validity;
}
/**
* 如果表单验证未通过,此属性将包含提示信息。如果验证通过,此属性将为空字符串
*/
get validationMessage() {
return this.inputRef.value.validationMessage;
}
get rippleElement() {
return this.rippleRef.value;
}
get rippleDisabled() {
return this.disabled;
}
get focusElement() {
return this.inputRef.value;
}
get focusDisabled() {
return this.disabled;
}
async onDisabledChange() {
await this.updateComplete;
this.invalid = !this.inputRef.value.checkValidity();
}
async onCheckedChange() {
var _a2;
await this.updateComplete;
const form = this.formController.getForm();
if (form && ((_a2 = formResets.get(form)) == null ? void 0 : _a2.has(this))) {
this.invalid = false;
formResets.get(form).delete(this);
} else {
this.invalid = !this.inputRef.value.checkValidity();
}
}
/**
* 检查表单字段是否通过验证。如果未通过,返回 `false` 并触发 `invalid` 事件;如果通过,返回 `true`
*/
checkValidity() {
const valid = this.inputRef.value.checkValidity();
if (!valid) {
this.emit("invalid", {
bubbles: false,
cancelable: true,
composed: false
});
}
return valid;
}
/**
* 检查表单字段是否通过验证。如果未通过,返回 `false` 并触发 `invalid` 事件;如果通过,返回 `true`。
*
* 如果验证未通过,还会在组件上显示验证失败的提示。
*/
reportValidity() {
this.invalid = !this.inputRef.value.reportValidity();
if (this.invalid) {
const eventProceeded = this.emit("invalid", {
bubbles: false,
cancelable: true,
composed: false
});
if (!eventProceeded) {
this.blur();
this.focus();
}
}
return !this.invalid;
}
/**
* 设置自定义的错误提示文本。只要这个文本不为空,就表示字段未通过验证
*
* @param message 自定义的错误提示文本
*/
setCustomValidity(message) {
this.inputRef.value.setCustomValidity(message);
this.invalid = !this.inputRef.value.checkValidity();
}
render() {
return x`<label class="${e$1({
invalid: this.invalid,
"has-unchecked-icon": this.uncheckedIcon || this.hasSlotController.test("unchecked-icon")
})}"><input ${n$2(this.inputRef)} type="checkbox" name="${o$5(this.name)}" value="${o$5(this.value)}" .disabled="${this.disabled}" .checked="${l$1(this.checked)}" .required="${this.required}" @change="${this.onChange}"><div part="track" class="track"><div part="thumb" class="thumb"><mdui-ripple ${n$2(this.rippleRef)} .noRipple="${this.noRipple}"></mdui-ripple><slot name="checked-icon" part="checked-icon" class="checked-icon">${this.checkedIcon ? x`<mdui-icon name="${this.checkedIcon}" class="i"></mdui-icon>` : this.checkedIcon === "" ? nothingTemplate : x`<mdui-icon-check class="i"></mdui-icon-check>`}</slot><slot name="unchecked-icon" part="unchecked-icon" class="unchecked-icon">${this.uncheckedIcon ? x`<mdui-icon name="${this.uncheckedIcon}" class="i"></mdui-icon>` : nothingTemplate}</slot></div></div></label>`;
}
/**
* input[type="checkbox"] 的 change 事件无法冒泡越过 shadow dom
*/
onChange() {
this.checked = this.inputRef.value.checked;
this.emit("change");
}
};
Switch.styles = [componentStyle, style$1];
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Switch.prototype, "disabled", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Switch.prototype, "checked", void 0);
__decorate([
defaultValue("checked")
], Switch.prototype, "defaultChecked", void 0);
__decorate([
n$6({ reflect: true, attribute: "unchecked-icon" })
], Switch.prototype, "uncheckedIcon", void 0);
__decorate([
n$6({ reflect: true, attribute: "checked-icon" })
], Switch.prototype, "checkedIcon", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Switch.prototype, "required", void 0);
__decorate([
n$6({ reflect: true })
], Switch.prototype, "form", void 0);
__decorate([
n$6({ reflect: true })
], Switch.prototype, "name", void 0);
__decorate([
n$6({ reflect: true })
], Switch.prototype, "value", void 0);
__decorate([
r$1()
], Switch.prototype, "invalid", void 0);
__decorate([
watch("disabled", true),
watch("required", true)
], Switch.prototype, "onDisabledChange", null);
__decorate([
watch("checked", true)
], Switch.prototype, "onCheckedChange", null);
Switch = __decorate([
t$3("mdui-switch")
], Switch);
const tabStyle = i$7`:host{position:relative;--mdui-comp-ripple-state-layer-color:var(--mdui-color-on-surface)}:host([active]){--mdui-comp-ripple-state-layer-color:var(--mdui-color-primary)}.container{display:flex;justify-content:center;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;height:100%}.preset{flex-direction:column;min-height:3rem;padding:.625rem 1rem}:host([inline]:not([inline=false i])) .preset{flex-direction:row}.icon-container,.label-container{position:relative;display:flex;align-items:center;justify-content:center}.icon-container ::slotted([slot=badge]){position:absolute;transform:translate(50%,-50%)}.icon-container ::slotted([slot=badge][variant=small]){transform:translate(.5625rem,-.5625rem)}.label-container ::slotted([slot=badge]){position:absolute;left:100%;bottom:100%;transform:translate(-.75rem,.625rem)}.label-container ::slotted([slot=badge][variant=small]){transform:translate(-.375rem,.375rem)}.icon,.label{display:flex;color:rgb(var(--mdui-color-on-surface-variant))}:host([focused]) .icon,:host([focused]) .label,:host([hover]) .icon,:host([hover]) .label,:host([pressed]) .icon,:host([pressed]) .label{color:rgb(var(--mdui-color-on-surface))}:host([active]) .icon,:host([active]) .label{color:rgb(var(--mdui-color-primary))}:host([active]) .variant-secondary .icon,:host([active]) .variant-secondary .label{color:rgb(var(--mdui-color-on-surface))}.icon{font-size:1.5rem}.label{font-size:var(--mdui-typescale-title-small-size);font-weight:var(--mdui-typescale-title-small-weight);letter-spacing:var(--mdui-typescale-title-small-tracking);line-height:var(--mdui-typescale-title-small-line-height)}.icon mdui-icon,::slotted([slot=icon]){font-size:inherit;color:inherit}`;
let Tab = class Tab2 extends RippleMixin(FocusableMixin(MduiElement)) {
constructor() {
super(...arguments);
this.inline = false;
this.active = false;
this.variant = "primary";
this.key = uniqueId();
this.rippleRef = e$2();
this.hasSlotController = new HasSlotController(this, "icon", "custom");
}
get rippleElement() {
return this.rippleRef.value;
}
get rippleDisabled() {
return false;
}
get focusElement() {
return this;
}
get focusDisabled() {
return false;
}
render() {
const hasIcon = this.icon || this.hasSlotController.test("icon");
const hasCustomSlot = this.hasSlotController.test("custom");
const renderBadge = () => x`<slot name="badge"></slot>`;
return x`<mdui-ripple ${n$2(this.rippleRef)} .noRipple="${this.noRipple}"></mdui-ripple><div part="container" class="${e$1({
container: true,
preset: !hasCustomSlot,
"variant-secondary": this.variant === "secondary"
})}"><slot name="custom"><div class="icon-container">${n$1(hasIcon || this.icon, renderBadge)}<slot name="icon" part="icon" class="icon">${this.icon ? x`<mdui-icon name="${this.icon}"></mdui-icon>` : nothingTemplate}</slot></div><div class="label-container">${n$1(!hasIcon, renderBadge)}<slot part="label" class="label"></slot></div></slot></div>`;
}
};
Tab.styles = [componentStyle, tabStyle];
__decorate([
n$6({ reflect: true })
], Tab.prototype, "value", void 0);
__decorate([
n$6({ reflect: true })
], Tab.prototype, "icon", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Tab.prototype, "inline", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Tab.prototype, "active", void 0);
__decorate([
r$1()
], Tab.prototype, "variant", void 0);
Tab = __decorate([
t$3("mdui-tab")
], Tab);
const tabPanelStyle = i$7`:host{display:block;overflow-y:auto;flex:1 1 auto}:host(:not([active])){display:none}`;
let TabPanel = class TabPanel2 extends MduiElement {
constructor() {
super(...arguments);
this.active = false;
}
render() {
return x`<slot></slot>`;
}
};
TabPanel.styles = [
componentStyle,
tabPanelStyle
];
__decorate([
n$6({ reflect: true })
], TabPanel.prototype, "value", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], TabPanel.prototype, "active", void 0);
TabPanel = __decorate([
t$3("mdui-tab-panel")
], TabPanel);
const tabsStyle = i$7`:host{position:relative;display:flex}:host([placement^=top]){flex-direction:column}:host([placement^=bottom]){flex-direction:column-reverse}:host([placement^=left]){flex-direction:row}:host([placement^=right]){flex-direction:row-reverse}.container{position:relative;display:flex;flex:0 0 auto;overflow-x:auto;background-color:rgb(var(--mdui-color-surface))}:host([placement^=bottom]) .container,:host([placement^=top]) .container{flex-direction:row}:host([placement^=left]) .container,:host([placement^=right]) .container{flex-direction:column}:host([placement$='-start']) .container{justify-content:flex-start}:host([placement=bottom]) .container,:host([placement=left]) .container,:host([placement=right]) .container,:host([placement=top]) .container{justify-content:center}:host([placement$='-end']) .container{justify-content:flex-end}.container::after{content:' ';position:absolute;background-color:rgb(var(--mdui-color-surface-variant))}:host([placement^=bottom]) .container::after,:host([placement^=top]) .container::after{left:0;width:100%;height:.0625rem}:host([placement^=top]) .container::after{bottom:0}:host([placement^=bottom]) .container::after{top:0}:host([placement^=left]) .container::after,:host([placement^=right]) .container::after{top:0;height:100%;width:.0625rem}:host([placement^=left]) .container::after{right:0}:host([placement^=right]) .container::after{left:0}.indicator{position:absolute;z-index:1;background-color:rgb(var(--mdui-color-primary))}.container:not(.initial) .indicator{transition-duration:var(--mdui-motion-duration-medium2);transition-timing-function:var(--mdui-motion-easing-standard-decelerate)}:host([placement^=bottom]) .indicator,:host([placement^=top]) .indicator{transition-property:transform,left,width}:host([placement^=left]) .indicator,:host([placement^=right]) .indicator{transition-property:transform,top,height}:host([placement^=top]) .indicator{bottom:0}:host([placement^=bottom]) .indicator{top:0}:host([placement^=left]) .indicator{right:0}:host([placement^=right]) .indicator{left:0}:host([placement^=bottom][variant=primary]) .indicator,:host([placement^=top][variant=primary]) .indicator{height:.1875rem}:host([placement^=bottom][variant=secondary]) .indicator,:host([placement^=top][variant=secondary]) .indicator{height:.125rem}:host([placement^=left][variant=primary]) .indicator,:host([placement^=right][variant=primary]) .indicator{width:.1875rem}:host([placement^=left][variant=secondary]) .indicator,:host([placement^=right][variant=secondary]) .indicator{width:.125rem}:host([placement^=top][variant=primary]) .indicator{border-top-left-radius:.1875rem;border-top-right-radius:.1875rem}:host([placement^=bottom][variant=primary]) .indicator{border-bottom-right-radius:.1875rem;border-bottom-left-radius:.1875rem}:host([placement^=left][variant=primary]) .indicator{border-top-left-radius:.1875rem;border-bottom-left-radius:.1875rem}:host([placement^=right][variant=primary]) .indicator{border-top-right-radius:.1875rem;border-bottom-right-radius:.1875rem}:host([full-width]:not([full-width=false i])) ::slotted(mdui-tab){flex:1}`;
let Tabs = class Tabs2 extends MduiElement {
constructor() {
super(...arguments);
this.variant = "primary";
this.placement = "top-start";
this.fullWidth = false;
this.activeKey = 0;
this.isInitial = true;
this.containerRef = e$2();
this.indicatorRef = e$2();
this.definedController = new DefinedController(this, {
relatedElements: ["mdui-tab", "mdui-tab-panel"]
});
}
async onActiveKeyChange() {
var _a2;
await this.definedController.whenDefined();
this.value = (_a2 = this.tabs.find((tab) => tab.key === this.activeKey)) == null ? void 0 : _a2.value;
this.updateActive();
if (!this.isInitial) {
this.emit("change");
}
}
async onValueChange() {
this.isInitial = !this.hasUpdated;
await this.definedController.whenDefined();
const tab = this.tabs.find((tab2) => tab2.value === this.value);
this.activeKey = (tab == null ? void 0 : tab.key) ?? 0;
}
async onIndicatorChange() {
await this.updateComplete;
this.updateIndicator();
}
connectedCallback() {
super.connectedCallback();
this.updateComplete.then(() => {
this.observeResize = observeResize(this.containerRef.value, () => this.updateIndicator());
});
}
disconnectedCallback() {
var _a2;
super.disconnectedCallback();
(_a2 = this.observeResize) == null ? void 0 : _a2.unobserve();
}
render() {
return x`<div ${n$2(this.containerRef)} part="container" class="container ${e$1({ initial: this.isInitial })}"><slot @slotchange="${this.onSlotChange}" @click="${this.onClick}"></slot><div ${n$2(this.indicatorRef)} part="indicator" class="indicator"></div></div><slot name="panel" @slotchange="${this.onSlotChange}"></slot>`;
}
async onSlotChange() {
await this.definedController.whenDefined();
this.updateActive();
}
async onClick(event) {
if (event.button) {
return;
}
await this.definedController.whenDefined();
const target = event.target;
const tab = target.closest("mdui-tab");
if (!tab) {
return;
}
this.activeKey = tab.key;
this.isInitial = false;
this.updateActive();
}
updateActive() {
this.activeTab = this.tabs.map((tab) => {
tab.active = this.activeKey === tab.key;
return tab;
}).find((tab) => tab.active);
this.panels.forEach((panel) => {
var _a2;
return panel.active = panel.value === ((_a2 = this.activeTab) == null ? void 0 : _a2.value);
});
this.updateIndicator();
}
updateIndicator() {
const activeTab = this.activeTab;
const $indicator = $$1(this.indicatorRef.value);
const isVertical = this.placement.startsWith("left") || this.placement.startsWith("right");
if (!activeTab) {
$indicator.css({
transform: isVertical ? "scaleY(0)" : "scaleX(0)"
});
return;
}
const $activeTab = $$1(activeTab);
const offsetTop = activeTab.offsetTop;
const offsetLeft = activeTab.offsetLeft;
const commonStyle = isVertical ? { transform: "scaleY(1)", width: "", left: "" } : { transform: "scaleX(1)", height: "", top: "" };
let shownStyle = {};
if (this.variant === "primary") {
const $customSlots = $activeTab.find(':scope > [slot="custom"]');
const children = $customSlots.length ? $customSlots.get() : $$1(activeTab.renderRoot).find('slot[name="custom"]').children().get();
if (isVertical) {
const top2 = Math.min(...children.map((child) => child.offsetTop)) + offsetTop;
const bottom = Math.max(...children.map((child) => child.offsetTop + child.offsetHeight)) + offsetTop;
shownStyle = { top: top2, height: bottom - top2 };
} else {
const left = Math.min(...children.map((child) => child.offsetLeft)) + offsetLeft;
const right = Math.max(...children.map((child) => child.offsetLeft + child.offsetWidth)) + offsetLeft;
shownStyle = { left, width: right - left };
}
}
if (this.variant === "secondary") {
shownStyle = isVertical ? { top: offsetTop, height: activeTab.offsetHeight } : { left: offsetLeft, width: activeTab.offsetWidth };
}
$indicator.css({ ...commonStyle, ...shownStyle });
}
};
Tabs.styles = [componentStyle, tabsStyle];
__decorate([
n$6({ reflect: true })
], Tabs.prototype, "variant", void 0);
__decorate([
n$6({ reflect: true })
], Tabs.prototype, "value", void 0);
__decorate([
n$6({ reflect: true })
], Tabs.prototype, "placement", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter,
attribute: "full-width"
})
], Tabs.prototype, "fullWidth", void 0);
__decorate([
r$1()
], Tabs.prototype, "activeKey", void 0);
__decorate([
r$1()
], Tabs.prototype, "isInitial", void 0);
__decorate([
o$6({ selector: "mdui-tab", flatten: true })
], Tabs.prototype, "tabs", void 0);
__decorate([
o$6({
selector: "mdui-tab-panel",
slot: "panel",
flatten: true
})
], Tabs.prototype, "panels", void 0);
__decorate([
watch("activeKey", true)
], Tabs.prototype, "onActiveKeyChange", null);
__decorate([
watch("value")
], Tabs.prototype, "onValueChange", null);
__decorate([
watch("variant", true),
watch("placement", true),
watch("fullWidth", true)
], Tabs.prototype, "onIndicatorChange", null);
Tabs = __decorate([
t$3("mdui-tabs")
], Tabs);
class HoverController {
/**
* @param host
* @param elementRef 检查鼠标是否放在该元素上
*/
constructor(host, elementRef) {
this.isHover = false;
this.uniqueID = uniqueId();
this.enterEventName = `mouseenter.${this.uniqueID}.hoverController`;
this.leaveEventName = `mouseleave.${this.uniqueID}.hoverController`;
this.mouseEnterItems = [];
this.mouseLeaveItems = [];
(this.host = host).addController(this);
this.elementRef = elementRef;
}
hostConnected() {
this.host.updateComplete.then(() => {
$$1(this.elementRef.value).on(this.enterEventName, () => {
this.isHover = true;
for (let i3 = this.mouseEnterItems.length - 1; i3 >= 0; i3--) {
const item = this.mouseEnterItems[i3];
item.callback();
if (item.one) {
this.mouseEnterItems.splice(i3, 1);
}
}
}).on(this.leaveEventName, () => {
this.isHover = false;
for (let i3 = this.mouseLeaveItems.length - 1; i3 >= 0; i3--) {
const item = this.mouseLeaveItems[i3];
item.callback();
if (item.one) {
this.mouseLeaveItems.splice(i3, 1);
}
}
});
});
}
hostDisconnected() {
$$1(this.elementRef.value).off(this.enterEventName).off(this.leaveEventName);
}
/**
* 指定鼠标移入时的回调函数
* @param callback 要执行的回调函数
* @param one 是否仅执行一次
*/
onMouseEnter(callback, one = false) {
this.mouseEnterItems.push({ callback, one });
}
/**
* 指定鼠标移出时的回调函数
* @param callback 要执行的回调函数
* @param one 是否仅执行一次
*/
onMouseLeave(callback, one = false) {
this.mouseLeaveItems.push({ callback, one });
}
}
const style = i$7`:host{--shape-corner-plain:var(--mdui-shape-corner-extra-small);--shape-corner-rich:var(--mdui-shape-corner-medium);--z-index:2500;display:contents}.popup{position:fixed;display:flex;flex-direction:column;z-index:var(--z-index);border-radius:var(--shape-corner-plain);background-color:rgb(var(--mdui-color-inverse-surface));padding:0 .5rem;min-width:1.75rem;max-width:20rem}:host([variant=rich]) .popup{border-radius:var(--shape-corner-rich);background-color:rgb(var(--mdui-color-surface-container));box-shadow:var(--mdui-elevation-level2);padding:.75rem 1rem .5rem 1rem}.headline{display:flex;color:rgb(var(--mdui-color-on-surface-variant));font-size:var(--mdui-typescale-title-small-size);font-weight:var(--mdui-typescale-title-small-weight);letter-spacing:var(--mdui-typescale-title-small-tracking);line-height:var(--mdui-typescale-title-small-line-height)}.content{display:flex;padding:.25rem 0;color:rgb(var(--mdui-color-inverse-on-surface));font-size:var(--mdui-typescale-body-small-size);font-weight:var(--mdui-typescale-body-small-weight);letter-spacing:var(--mdui-typescale-body-small-tracking);line-height:var(--mdui-typescale-body-small-line-height)}:host([variant=rich]) .content{color:rgb(var(--mdui-color-on-surface-variant));font-size:var(--mdui-typescale-body-medium-size);font-weight:var(--mdui-typescale-body-medium-weight);letter-spacing:var(--mdui-typescale-body-medium-tracking);line-height:var(--mdui-typescale-body-medium-line-height)}.action{display:flex;justify-content:flex-start;padding-top:.5rem}.action ::slotted(:not(:last-child)){margin-right:.5rem}`;
let Tooltip = class Tooltip2 extends MduiElement {
constructor() {
super();
this.variant = "plain";
this.placement = "auto";
this.openDelay = 150;
this.closeDelay = 150;
this.trigger = "hover focus";
this.disabled = false;
this.open = false;
this.popupRef = e$2();
this.hasSlotController = new HasSlotController(this, "headline", "action");
this.hoverController = new HoverController(this, this.popupRef);
this.definedController = new DefinedController(this, {
needDomReady: true
});
this.onDocumentClick = this.onDocumentClick.bind(this);
this.onWindowScroll = this.onWindowScroll.bind(this);
this.onFocus = this.onFocus.bind(this);
this.onBlur = this.onBlur.bind(this);
this.onClick = this.onClick.bind(this);
this.onKeydown = this.onKeydown.bind(this);
this.onMouseEnter = this.onMouseEnter.bind(this);
this.onMouseLeave = this.onMouseLeave.bind(this);
}
/**
* 获取第一个非 <style> 和 content slot 的子元素,作为 tooltip 的目标元素
*/
get target() {
return [...this.children].find((el) => el.tagName.toLowerCase() !== "style" && el.getAttribute("slot") !== "content");
}
async onPositionChange() {
if (this.open) {
await this.definedController.whenDefined();
this.updatePositioner();
}
}
async onOpenChange() {
const hasUpdated = this.hasUpdated;
const duration = getDuration(this, "short4");
const easing = getEasing(this, "standard");
if (this.open) {
await this.definedController.whenDefined();
$$1(`mdui-tooltip[variant="${this.variant}"]`).filter((_2, element) => element !== this).prop("open", false);
if (!hasUpdated) {
await this.updateComplete;
}
if (hasUpdated) {
const eventProceeded = this.emit("open", { cancelable: true });
if (!eventProceeded) {
return;
}
}
await stopAnimations(this.popupRef.value);
this.popupRef.value.hidden = false;
this.updatePositioner();
await animateTo(this.popupRef.value, [{ transform: "scale(0)" }, { transform: "scale(1)" }], {
duration: hasUpdated ? duration : 0,
easing
});
if (hasUpdated) {
this.emit("opened");
}
return;
}
if (!this.open && hasUpdated) {
const eventProceeded = this.emit("close", { cancelable: true });
if (!eventProceeded) {
return;
}
await stopAnimations(this.popupRef.value);
await animateTo(this.popupRef.value, [{ transform: "scale(1)" }, { transform: "scale(0)" }], { duration, easing });
this.popupRef.value.hidden = true;
this.emit("closed");
}
}
connectedCallback() {
super.connectedCallback();
document.addEventListener("pointerdown", this.onDocumentClick);
this.overflowAncestors = getOverflowAncestors(this.target);
this.overflowAncestors.forEach((ancestor) => {
ancestor.addEventListener("scroll", this.onWindowScroll);
});
this.definedController.whenDefined().then(() => {
this.observeResize = observeResize(this.target, () => {
this.updatePositioner();
});
});
}
disconnectedCallback() {
var _a2, _b;
super.disconnectedCallback();
document.removeEventListener("pointerdown", this.onDocumentClick);
(_a2 = this.overflowAncestors) == null ? void 0 : _a2.forEach((ancestor) => {
ancestor.removeEventListener("scroll", this.onWindowScroll);
});
(_b = this.observeResize) == null ? void 0 : _b.unobserve();
}
firstUpdated(changedProperties) {
super.firstUpdated(changedProperties);
this.definedController.whenDefined().then(() => {
const target = this.target;
target.addEventListener("focus", this.onFocus);
target.addEventListener("blur", this.onBlur);
target.addEventListener("pointerdown", this.onClick);
target.addEventListener("keydown", this.onKeydown);
target.addEventListener("mouseenter", this.onMouseEnter);
target.addEventListener("mouseleave", this.onMouseLeave);
});
}
render() {
const hasHeadline = this.isRich() && (this.headline || this.hasSlotController.test("headline"));
const hasAction = this.isRich() && this.hasSlotController.test("action");
return x`<slot></slot><div ${n$2(this.popupRef)} part="popup" class="popup" hidden>${n$1(hasHeadline, () => x`<slot name="headline" part="headline" class="headline">${this.headline}</slot>`)}<slot name="content" part="content" class="content">${this.content}</slot>${n$1(hasAction, () => x`<slot name="action" part="action" class="action"></slot>`)}</div>`;
}
isRich() {
return this.variant === "rich";
}
/**
* 请求关闭 tooltip。鼠标未悬浮在 tooltip 上时,直接关闭;否则等鼠标移走再关闭
*/
requestClose() {
if (!this.hoverController.isHover) {
this.open = false;
return;
}
this.hoverController.onMouseLeave(() => {
if (this.hasTrigger("hover")) {
this.hoverTimeout = window.setTimeout(() => {
this.open = false;
}, this.closeDelay || 50);
} else {
this.open = false;
}
}, true);
}
hasTrigger(trigger) {
const triggers = this.trigger.split(" ");
return triggers.includes(trigger);
}
onFocus() {
if (this.disabled || this.open || !this.hasTrigger("focus")) {
return;
}
this.open = true;
}
onBlur() {
if (this.disabled || !this.open || !this.hasTrigger("focus")) {
return;
}
this.requestClose();
}
onClick(e3) {
if (this.disabled || e3.button || !this.hasTrigger("click")) {
return;
}
if (this.open && (this.hasTrigger("hover") || this.hasTrigger("focus"))) {
return;
}
this.open = !this.open;
}
onKeydown(e3) {
if (this.disabled || !this.open || e3.key !== "Escape") {
return;
}
e3.stopPropagation();
this.requestClose();
}
onMouseEnter() {
if (this.disabled || this.open || !this.hasTrigger("hover")) {
return;
}
if (this.openDelay) {
window.clearTimeout(this.hoverTimeout);
this.hoverTimeout = window.setTimeout(() => {
this.open = true;
}, this.openDelay);
} else {
this.open = true;
}
}
onMouseLeave() {
window.clearTimeout(this.hoverTimeout);
if (this.disabled || !this.open || !this.hasTrigger("hover")) {
return;
}
this.hoverTimeout = window.setTimeout(() => {
this.requestClose();
}, this.closeDelay || 50);
}
/**
* 在 document 上点击时,根据条件判断是否关闭 tooltip
*/
onDocumentClick(e3) {
if (this.disabled || !this.open) {
return;
}
const path = e3.composedPath();
if (!path.includes(this)) {
this.requestClose();
}
}
onWindowScroll() {
window.requestAnimationFrame(() => this.updatePositioner());
}
updatePositioner() {
const $popup = $$1(this.popupRef.value);
const targetMargin = this.isRich() ? 0 : 4;
const popupMargin = 4;
const targetRect = this.target.getBoundingClientRect();
const targetTop = targetRect.top;
const targetLeft = targetRect.left;
const targetHeight = targetRect.height;
const targetWidth = targetRect.width;
const popupHeight = this.popupRef.value.offsetHeight;
const popupWidth = this.popupRef.value.offsetWidth;
const popupXSpace = popupWidth + targetMargin + popupMargin;
const popupYSpace = popupHeight + targetMargin + popupMargin;
let transformOriginX;
let transformOriginY;
let top2;
let left;
let placement = this.placement;
if (placement === "auto") {
const $window = $$1(window);
const hasTopSpace = targetTop > popupYSpace;
const hasBottomSpace = $window.height() - targetTop - targetHeight > popupYSpace;
const hasLeftSpace = targetLeft > popupXSpace;
const hasRightSpace = $window.width() - targetLeft - targetWidth > popupXSpace;
if (this.isRich()) {
placement = "bottom-right";
if (hasBottomSpace && hasRightSpace) {
placement = "bottom-right";
} else if (hasBottomSpace && hasLeftSpace) {
placement = "bottom-left";
} else if (hasTopSpace && hasRightSpace) {
placement = "top-right";
} else if (hasTopSpace && hasLeftSpace) {
placement = "top-left";
} else if (hasBottomSpace) {
placement = "bottom";
} else if (hasTopSpace) {
placement = "top";
} else if (hasRightSpace) {
placement = "right";
} else if (hasLeftSpace) {
placement = "left";
}
} else {
placement = "top";
if (hasTopSpace) {
placement = "top";
} else if (hasBottomSpace) {
placement = "bottom";
} else if (hasLeftSpace) {
placement = "left";
} else if (hasRightSpace) {
placement = "right";
}
}
}
const [position, alignment] = placement.split("-");
switch (position) {
case "top":
transformOriginY = "bottom";
top2 = targetTop - popupHeight - targetMargin;
break;
case "bottom":
transformOriginY = "top";
top2 = targetTop + targetHeight + targetMargin;
break;
default:
transformOriginY = "center";
switch (alignment) {
case "start":
top2 = targetTop;
break;
case "end":
top2 = targetTop + targetHeight - popupHeight;
break;
default:
top2 = targetTop + targetHeight / 2 - popupHeight / 2;
break;
}
break;
}
switch (position) {
case "left":
transformOriginX = "right";
left = targetLeft - popupWidth - targetMargin;
break;
case "right":
transformOriginX = "left";
left = targetLeft + targetWidth + targetMargin;
break;
default:
transformOriginX = "center";
switch (alignment) {
case "start":
left = targetLeft;
break;
case "end":
left = targetLeft + targetWidth - popupWidth;
break;
case "left":
transformOriginX = "right";
left = targetLeft - popupWidth - targetMargin;
break;
case "right":
transformOriginX = "left";
left = targetLeft + targetWidth + targetMargin;
break;
default:
left = targetLeft + targetWidth / 2 - popupWidth / 2;
break;
}
break;
}
$popup.css({
top: top2,
left,
transformOrigin: [transformOriginX, transformOriginY].join(" ")
});
}
};
Tooltip.styles = [componentStyle, style];
__decorate([
n$6({ reflect: true })
], Tooltip.prototype, "variant", void 0);
__decorate([
n$6({ reflect: true })
], Tooltip.prototype, "placement", void 0);
__decorate([
n$6({ type: Number, reflect: true, attribute: "open-delay" })
], Tooltip.prototype, "openDelay", void 0);
__decorate([
n$6({ type: Number, reflect: true, attribute: "close-delay" })
], Tooltip.prototype, "closeDelay", void 0);
__decorate([
n$6({ reflect: true })
], Tooltip.prototype, "headline", void 0);
__decorate([
n$6({ reflect: true })
], Tooltip.prototype, "content", void 0);
__decorate([
n$6({ reflect: true })
], Tooltip.prototype, "trigger", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Tooltip.prototype, "disabled", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], Tooltip.prototype, "open", void 0);
__decorate([
watch("placement", true),
watch("content", true)
], Tooltip.prototype, "onPositionChange", null);
__decorate([
watch("open")
], Tooltip.prototype, "onOpenChange", null);
Tooltip = __decorate([
t$3("mdui-tooltip")
], Tooltip);
const getInnerHtmlFromSlot = (slot) => {
const nodes = slot.assignedNodes({ flatten: true });
let html = "";
[...nodes].forEach((node) => {
if (node.nodeType === Node.ELEMENT_NODE) {
html += node.outerHTML;
}
if (node.nodeType === Node.TEXT_NODE) {
html += node.textContent;
}
});
return html;
};
const topAppBarTitleStyle = i$7`:host{display:block;width:100%;flex-shrink:initial!important;overflow:hidden;color:rgb(var(--mdui-color-on-surface));font-size:var(--mdui-typescale-title-large-size);font-weight:var(--mdui-typescale-title-large-weight);letter-spacing:var(--mdui-typescale-title-large-tracking);line-height:var(--mdui-typescale-title-large-line-height);line-height:2.5rem}.label{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;opacity:1;transition:opacity var(--mdui-motion-duration-short2) var(--mdui-motion-easing-linear)}.label.variant-center-aligned{text-align:center}.label.variant-large:not(.shrink),.label.variant-medium:not(.shrink){opacity:0}.label.variant-large.shrink,.label.variant-medium.shrink{transition-delay:var(--mdui-motion-duration-short2)}.label-large{display:none;position:absolute;width:100%;left:0;margin-right:0;padding:0 1rem;transition:opacity var(--mdui-motion-duration-short2) var(--mdui-motion-easing-linear)}.label-large.variant-large,.label-large.variant-medium{display:block}.label-large.variant-medium{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;bottom:.75rem;font-size:var(--mdui-typescale-headline-small-size);font-weight:var(--mdui-typescale-headline-small-weight);letter-spacing:var(--mdui-typescale-headline-small-tracking);line-height:var(--mdui-typescale-headline-small-line-height)}.label-large.variant-large{display:-webkit-box;overflow:hidden;white-space:normal;-webkit-box-orient:vertical;-webkit-line-clamp:2;bottom:1.25rem;font-size:var(--mdui-typescale-headline-medium-size);font-weight:var(--mdui-typescale-headline-medium-weight);letter-spacing:var(--mdui-typescale-headline-medium-tracking);line-height:var(--mdui-typescale-headline-medium-line-height)}.label-large.variant-large:not(.shrink),.label-large.variant-medium:not(.shrink){opacity:1;transition-delay:var(--mdui-motion-duration-short2)}.label-large.variant-large.shrink,.label-large.variant-medium.shrink{opacity:0;z-index:-1}`;
let TopAppBarTitle = class TopAppBarTitle2 extends MduiElement {
constructor() {
super(...arguments);
this.variant = "small";
this.shrink = false;
this.hasSlotController = new HasSlotController(this, "label-large");
this.labelLargeRef = e$2();
this.defaultSlotRef = e$2();
}
render() {
const hasLabelLargeSlot = this.hasSlotController.test("label-large");
const className2 = e$1({
shrink: this.shrink,
"variant-center-aligned": this.variant === "center-aligned",
"variant-small": this.variant === "small",
"variant-medium": this.variant === "medium",
"variant-large": this.variant === "large"
});
return x`<slot part="label" class="label ${className2}" ${n$2(this.defaultSlotRef)} @slotchange="${() => this.onSlotChange(hasLabelLargeSlot)}"></slot>${hasLabelLargeSlot ? x`<slot name="label-large" part="label-large" class="label-large ${className2}"></slot>` : x`<div ${n$2(this.labelLargeRef)} part="label-large" class="label-large ${className2}"></div>`}`;
}
/**
* default slot 变化时,同步到 label-large 中
* @param hasLabelLargeSlot
* @private
*/
onSlotChange(hasLabelLargeSlot) {
if (!hasLabelLargeSlot) {
this.labelLargeRef.value.innerHTML = getInnerHtmlFromSlot(this.defaultSlotRef.value);
}
}
};
TopAppBarTitle.styles = [
componentStyle,
topAppBarTitleStyle
];
__decorate([
r$1()
], TopAppBarTitle.prototype, "variant", void 0);
__decorate([
r$1()
], TopAppBarTitle.prototype, "shrink", void 0);
TopAppBarTitle = __decorate([
t$3("mdui-top-app-bar-title")
], TopAppBarTitle);
const topAppBarStyle = i$7`:host{--shape-corner:var(--mdui-shape-corner-none);--z-index:2000;position:fixed;top:0;right:0;left:0;display:flex;flex:0 0 auto;align-items:flex-start;justify-content:flex-start;border-bottom-left-radius:var(--shape-corner);border-bottom-right-radius:var(--shape-corner);z-index:var(--z-index);transition:top var(--mdui-motion-duration-long2) var(--mdui-motion-easing-standard),height var(--mdui-motion-duration-long2) var(--mdui-motion-easing-standard),box-shadow var(--mdui-motion-duration-short4) var(--mdui-motion-easing-linear),background-color var(--mdui-motion-duration-short4) var(--mdui-motion-easing-linear);padding:.75rem .5rem;height:4rem;background-color:rgb(var(--mdui-color-surface))}:host([scroll-target]:not([scroll-target=''])){position:absolute}:host([scroll-behavior~=shrink]){transition-duration:var(--mdui-motion-duration-short4)}:host([scrolling]){background-color:rgb(var(--mdui-color-surface-container));box-shadow:var(--mdui-elevation-level2)}::slotted(mdui-button-icon){color:rgb(var(--mdui-color-on-surface-variant));font-size:1.5rem}::slotted(mdui-button-icon:first-child){color:rgb(var(--mdui-color-on-surface))}::slotted(mdui-avatar){width:1.875rem;height:1.875rem;margin-top:.3125rem;margin-bottom:.3125rem}::slotted(*){flex-shrink:0}::slotted(:not(:last-child)){margin-right:.5rem}:host([variant=medium]){height:7rem}:host([variant=large]){height:9.5rem}:host([hide]:not([hide=false i])){transition-duration:var(--mdui-motion-duration-short4);top:-4.625rem}:host([hide][variant=medium]:not([hide=false i])){top:-7.625rem}:host([hide][variant=large]:not([hide=false i])){top:-10.125rem}:host([shrink][variant=large]:not([shrink=false i])),:host([shrink][variant=medium]:not([shrink=false i])){transition-duration:var(--mdui-motion-duration-short4);height:4rem}`;
let TopAppBar = class TopAppBar2 extends ScrollBehaviorMixin(LayoutItemBase) {
constructor() {
super(...arguments);
this.variant = "small";
this.hide = false;
this.shrink = false;
this.scrolling = false;
}
get scrollPaddingPosition() {
return "top";
}
get layoutPlacement() {
return "top";
}
async onVariantChange() {
if (this.hasUpdated) {
this.addEventListener("transitionend", async () => {
await this.scrollBehaviorDefinedController.whenDefined();
this.setContainerPadding("update", this.scrollTarget);
}, { once: true });
} else {
await this.updateComplete;
}
this.titleElements.forEach((titleElement) => {
titleElement.variant = this.variant;
});
}
async onShrinkChange() {
if (!this.hasUpdated) {
await this.updateComplete;
}
this.titleElements.forEach((titleElement) => {
titleElement.shrink = this.shrink;
});
}
firstUpdated(_changedProperties) {
super.firstUpdated(_changedProperties);
this.addEventListener("transitionend", (e3) => {
if (e3.target === this) {
this.emit(this.hide ? "hidden" : "shown");
}
});
}
render() {
return x`<slot></slot>`;
}
runScrollNoThreshold(isScrollingUp, scrollTop) {
if (this.hasScrollBehavior("shrink")) {
if (isScrollingUp && scrollTop < 8) {
this.shrink = false;
}
}
}
runScrollThreshold(isScrollingUp, scrollTop) {
if (this.hasScrollBehavior("elevate")) {
this.scrolling = !!scrollTop;
}
if (this.hasScrollBehavior("shrink")) {
if (!isScrollingUp) {
this.shrink = true;
}
}
if (this.hasScrollBehavior("hide")) {
if (!isScrollingUp && !this.hide) {
const eventProceeded = this.emit("hide", { cancelable: true });
if (eventProceeded) {
this.hide = true;
}
}
if (isScrollingUp && this.hide) {
const eventProceeded = this.emit("show", { cancelable: true });
if (eventProceeded) {
this.hide = false;
}
}
}
}
};
TopAppBar.styles = [
componentStyle,
topAppBarStyle
];
__decorate([
n$6({ reflect: true })
], TopAppBar.prototype, "variant", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], TopAppBar.prototype, "hide", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], TopAppBar.prototype, "shrink", void 0);
__decorate([
n$6({ reflect: true, attribute: "scroll-behavior" })
], TopAppBar.prototype, "scrollBehavior", void 0);
__decorate([
n$6({
type: Boolean,
reflect: true,
converter: booleanConverter
})
], TopAppBar.prototype, "scrolling", void 0);
__decorate([
o$6({ selector: "mdui-top-app-bar-title", flatten: true })
], TopAppBar.prototype, "titleElements", void 0);
__decorate([
watch("variant")
], TopAppBar.prototype, "onVariantChange", null);
__decorate([
watch("shrink")
], TopAppBar.prototype, "onShrinkChange", null);
TopAppBar = __decorate([
t$3("mdui-top-app-bar")
], TopAppBar);
function isPromise(obj) {
return !!obj && (typeof obj === "object" || typeof obj === "function") && typeof obj.then === "function";
}
const container = {};
function queue(name, func) {
if (isUndefined(container[name])) {
container[name] = [];
}
if (isUndefined(func)) {
return container[name];
}
container[name].push(func);
}
function dequeue(name) {
if (isUndefined(container[name])) {
return;
}
if (!container[name].length) {
return;
}
const func = container[name].shift();
func();
}
const defaultAction = {
onClick: returnTrue
};
const queueName$1 = "mdui.functions.dialog.";
let currentDialog = void 0;
const dialog = (options) => {
const dialog2 = new Dialog();
const $dialog = $$1(dialog2);
const properties = [
"headline",
"description",
"icon",
"closeOnEsc",
"closeOnOverlayClick",
"stackedActions"
];
const callbacks = ["onOpen", "onOpened", "onClose", "onClosed", "onOverlayClick"];
Object.entries(options).forEach(([key2, value]) => {
if (properties.includes(key2)) {
dialog2[key2] = value;
} else if (callbacks.includes(key2)) {
const eventName = toKebabCase(key2.slice(2));
$dialog.on(eventName, (e3) => {
if (e3.target === dialog2) {
value.call(dialog2, dialog2);
}
});
}
});
if (options.body) {
$dialog.append(options.body);
}
if (options.actions) {
options.actions.forEach((action) => {
const mergedAction = Object.assign({}, defaultAction, action);
$$1(`<mdui-button
slot="action"
variant="text"
>${mergedAction.text}</mdui-button>`).appendTo($dialog).on("click", function() {
const clickResult = mergedAction.onClick.call(dialog2, dialog2);
if (isPromise(clickResult)) {
this.loading = true;
clickResult.then(() => {
dialog2.open = false;
}).finally(() => {
this.loading = false;
});
} else if (clickResult !== false) {
dialog2.open = false;
}
});
});
}
$dialog.appendTo("body").on("closed", (e3) => {
if (e3.target !== dialog2) {
return;
}
$dialog.remove();
if (options.queue) {
currentDialog = void 0;
dequeue(queueName$1 + options.queue);
}
});
if (!options.queue) {
setTimeout(() => {
dialog2.open = true;
});
} else if (currentDialog) {
queue(queueName$1 + options.queue, () => {
dialog2.open = true;
currentDialog = dialog2;
});
} else {
setTimeout(() => {
dialog2.open = true;
});
currentDialog = dialog2;
}
return dialog2;
};
const getConfirmText$1 = () => {
return msg("OK");
};
const getCancelText$1 = () => {
return msg("Cancel");
};
const confirm = (options) => {
const mergedOptions = Object.assign({}, {
confirmText: getConfirmText$1(),
cancelText: getCancelText$1(),
onConfirm: returnTrue,
onCancel: returnTrue
}, options);
const properties = [
"headline",
"description",
"icon",
"closeOnEsc",
"closeOnOverlayClick",
"stackedActions",
"queue",
"onOpen",
"onOpened",
"onClose",
"onClosed",
"onOverlayClick"
];
return new Promise((resolve, reject) => {
let isResolve = false;
const dialog$1 = dialog({
...Object.fromEntries(properties.filter((key2) => !isUndefined(mergedOptions[key2])).map((key2) => [key2, mergedOptions[key2]])),
actions: [
{
text: mergedOptions.cancelText,
onClick: (dialog2) => {
return mergedOptions.onCancel.call(dialog2, dialog2);
}
},
{
text: mergedOptions.confirmText,
onClick: (dialog2) => {
const clickResult = mergedOptions.onConfirm.call(dialog2, dialog2);
if (isPromise(clickResult)) {
clickResult.then(() => {
isResolve = true;
});
} else if (clickResult !== false) {
isResolve = true;
}
return clickResult;
}
}
]
});
if (!options.confirmText) {
onLocaleReady(dialog$1, () => {
$$1(dialog$1).find('[slot="action"]').last().text(getConfirmText$1());
});
}
if (!options.cancelText) {
onLocaleReady(dialog$1, () => {
$$1(dialog$1).find('[slot="action"]').first().text(getCancelText$1());
});
}
$$1(dialog$1).on("close", (e3) => {
if (e3.target === dialog$1) {
isResolve ? resolve() : reject();
offLocaleReady(dialog$1);
}
});
});
};
/**
* @license
* Copyright 2021 Google LLC
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
function signum(num) {
if (num < 0) {
return -1;
} else if (num === 0) {
return 0;
} else {
return 1;
}
}
function lerp(start, stop, amount) {
return (1 - amount) * start + amount * stop;
}
function clampInt(min, max, input) {
if (input < min) {
return min;
} else if (input > max) {
return max;
}
return input;
}
function clampDouble(min, max, input) {
if (input < min) {
return min;
} else if (input > max) {
return max;
}
return input;
}
function sanitizeDegreesDouble(degrees) {
degrees = degrees % 360;
if (degrees < 0) {
degrees = degrees + 360;
}
return degrees;
}
function rotationDirection(from, to) {
const increasingDifference = sanitizeDegreesDouble(to - from);
return increasingDifference <= 180 ? 1 : -1;
}
function differenceDegrees(a2, b3) {
return 180 - Math.abs(Math.abs(a2 - b3) - 180);
}
function matrixMultiply(row, matrix) {
const a2 = row[0] * matrix[0][0] + row[1] * matrix[0][1] + row[2] * matrix[0][2];
const b3 = row[0] * matrix[1][0] + row[1] * matrix[1][1] + row[2] * matrix[1][2];
const c3 = row[0] * matrix[2][0] + row[1] * matrix[2][1] + row[2] * matrix[2][2];
return [a2, b3, c3];
}
/**
* @license
* Copyright 2021 Google LLC
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
const SRGB_TO_XYZ = [
[0.41233895, 0.35762064, 0.18051042],
[0.2126, 0.7152, 0.0722],
[0.01932141, 0.11916382, 0.95034478]
];
const XYZ_TO_SRGB = [
[
3.2413774792388685,
-1.5376652402851851,
-0.49885366846268053
],
[
-0.9691452513005321,
1.8758853451067872,
0.04156585616912061
],
[
0.05562093689691305,
-0.20395524564742123,
1.0571799111220335
]
];
const WHITE_POINT_D65 = [95.047, 100, 108.883];
function argbFromRgb(red, green, blue) {
return (255 << 24 | (red & 255) << 16 | (green & 255) << 8 | blue & 255) >>> 0;
}
function argbFromLinrgb(linrgb) {
const r3 = delinearized(linrgb[0]);
const g2 = delinearized(linrgb[1]);
const b3 = delinearized(linrgb[2]);
return argbFromRgb(r3, g2, b3);
}
function redFromArgb(argb) {
return argb >> 16 & 255;
}
function greenFromArgb(argb) {
return argb >> 8 & 255;
}
function blueFromArgb(argb) {
return argb & 255;
}
function argbFromXyz(x2, y2, z2) {
const matrix = XYZ_TO_SRGB;
const linearR = matrix[0][0] * x2 + matrix[0][1] * y2 + matrix[0][2] * z2;
const linearG = matrix[1][0] * x2 + matrix[1][1] * y2 + matrix[1][2] * z2;
const linearB = matrix[2][0] * x2 + matrix[2][1] * y2 + matrix[2][2] * z2;
const r3 = delinearized(linearR);
const g2 = delinearized(linearG);
const b3 = delinearized(linearB);
return argbFromRgb(r3, g2, b3);
}
function xyzFromArgb(argb) {
const r3 = linearized(redFromArgb(argb));
const g2 = linearized(greenFromArgb(argb));
const b3 = linearized(blueFromArgb(argb));
return matrixMultiply([r3, g2, b3], SRGB_TO_XYZ);
}
function argbFromLstar(lstar) {
const y2 = yFromLstar(lstar);
const component = delinearized(y2);
return argbFromRgb(component, component, component);
}
function lstarFromArgb(argb) {
const y2 = xyzFromArgb(argb)[1];
return 116 * labF(y2 / 100) - 16;
}
function yFromLstar(lstar) {
return 100 * labInvf((lstar + 16) / 116);
}
function lstarFromY(y2) {
return labF(y2 / 100) * 116 - 16;
}
function linearized(rgbComponent) {
const normalized = rgbComponent / 255;
if (normalized <= 0.040449936) {
return normalized / 12.92 * 100;
} else {
return Math.pow((normalized + 0.055) / 1.055, 2.4) * 100;
}
}
function delinearized(rgbComponent) {
const normalized = rgbComponent / 100;
let delinearized2 = 0;
if (normalized <= 31308e-7) {
delinearized2 = normalized * 12.92;
} else {
delinearized2 = 1.055 * Math.pow(normalized, 1 / 2.4) - 0.055;
}
return clampInt(0, 255, Math.round(delinearized2 * 255));
}
function whitePointD65() {
return WHITE_POINT_D65;
}
function labF(t3) {
const e3 = 216 / 24389;
const kappa = 24389 / 27;
if (t3 > e3) {
return Math.pow(t3, 1 / 3);
} else {
return (kappa * t3 + 16) / 116;
}
}
function labInvf(ft) {
const e3 = 216 / 24389;
const kappa = 24389 / 27;
const ft3 = ft * ft * ft;
if (ft3 > e3) {
return ft3;
} else {
return (116 * ft - 16) / kappa;
}
}
/**
* @license
* Copyright 2021 Google LLC
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
class ViewingConditions {
/**
* Create ViewingConditions from a simple, physically relevant, set of
* parameters.
*
* @param whitePoint White point, measured in the XYZ color space.
* default = D65, or sunny day afternoon
* @param adaptingLuminance The luminance of the adapting field. Informally,
* how bright it is in the room where the color is viewed. Can be
* calculated from lux by multiplying lux by 0.0586. default = 11.72,
* or 200 lux.
* @param backgroundLstar The lightness of the area surrounding the color.
* measured by L* in L*a*b*. default = 50.0
* @param surround A general description of the lighting surrounding the
* color. 0 is pitch dark, like watching a movie in a theater. 1.0 is a
* dimly light room, like watching TV at home at night. 2.0 means there
* is no difference between the lighting on the color and around it.
* default = 2.0
* @param discountingIlluminant Whether the eye accounts for the tint of the
* ambient lighting, such as knowing an apple is still red in green light.
* default = false, the eye does not perform this process on
* self-luminous objects like displays.
*/
static make(whitePoint = whitePointD65(), adaptingLuminance = 200 / Math.PI * yFromLstar(50) / 100, backgroundLstar = 50, surround = 2, discountingIlluminant = false) {
const xyz = whitePoint;
const rW = xyz[0] * 0.401288 + xyz[1] * 0.650173 + xyz[2] * -0.051461;
const gW = xyz[0] * -0.250268 + xyz[1] * 1.204414 + xyz[2] * 0.045854;
const bW = xyz[0] * -2079e-6 + xyz[1] * 0.048952 + xyz[2] * 0.953127;
const f3 = 0.8 + surround / 10;
const c3 = f3 >= 0.9 ? lerp(0.59, 0.69, (f3 - 0.9) * 10) : lerp(0.525, 0.59, (f3 - 0.8) * 10);
let d2 = discountingIlluminant ? 1 : f3 * (1 - 1 / 3.6 * Math.exp((-adaptingLuminance - 42) / 92));
d2 = d2 > 1 ? 1 : d2 < 0 ? 0 : d2;
const nc = f3;
const rgbD = [
d2 * (100 / rW) + 1 - d2,
d2 * (100 / gW) + 1 - d2,
d2 * (100 / bW) + 1 - d2
];
const k3 = 1 / (5 * adaptingLuminance + 1);
const k4 = k3 * k3 * k3 * k3;
const k4F = 1 - k4;
const fl = k4 * adaptingLuminance + 0.1 * k4F * k4F * Math.cbrt(5 * adaptingLuminance);
const n3 = yFromLstar(backgroundLstar) / whitePoint[1];
const z2 = 1.48 + Math.sqrt(n3);
const nbb = 0.725 / Math.pow(n3, 0.2);
const ncb = nbb;
const rgbAFactors = [
Math.pow(fl * rgbD[0] * rW / 100, 0.42),
Math.pow(fl * rgbD[1] * gW / 100, 0.42),
Math.pow(fl * rgbD[2] * bW / 100, 0.42)
];
const rgbA = [
400 * rgbAFactors[0] / (rgbAFactors[0] + 27.13),
400 * rgbAFactors[1] / (rgbAFactors[1] + 27.13),
400 * rgbAFactors[2] / (rgbAFactors[2] + 27.13)
];
const aw = (2 * rgbA[0] + rgbA[1] + 0.05 * rgbA[2]) * nbb;
return new ViewingConditions(n3, aw, nbb, ncb, c3, nc, rgbD, fl, Math.pow(fl, 0.25), z2);
}
/**
* Parameters are intermediate values of the CAM16 conversion process. Their
* names are shorthand for technical color science terminology, this class
* would not benefit from documenting them individually. A brief overview
* is available in the CAM16 specification, and a complete overview requires
* a color science textbook, such as Fairchild's Color Appearance Models.
*/
constructor(n3, aw, nbb, ncb, c3, nc, rgbD, fl, fLRoot, z2) {
this.n = n3;
this.aw = aw;
this.nbb = nbb;
this.ncb = ncb;
this.c = c3;
this.nc = nc;
this.rgbD = rgbD;
this.fl = fl;
this.fLRoot = fLRoot;
this.z = z2;
}
}
ViewingConditions.DEFAULT = ViewingConditions.make();
/**
* @license
* Copyright 2021 Google LLC
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
class Cam16 {
/**
* All of the CAM16 dimensions can be calculated from 3 of the dimensions, in
* the following combinations:
* - {j or q} and {c, m, or s} and hue
* - jstar, astar, bstar
* Prefer using a static method that constructs from 3 of those dimensions.
* This constructor is intended for those methods to use to return all
* possible dimensions.
*
* @param hue
* @param chroma informally, colorfulness / color intensity. like saturation
* in HSL, except perceptually accurate.
* @param j lightness
* @param q brightness; ratio of lightness to white point's lightness
* @param m colorfulness
* @param s saturation; ratio of chroma to white point's chroma
* @param jstar CAM16-UCS J coordinate
* @param astar CAM16-UCS a coordinate
* @param bstar CAM16-UCS b coordinate
*/
constructor(hue, chroma, j2, q, m2, s3, jstar, astar, bstar) {
this.hue = hue;
this.chroma = chroma;
this.j = j2;
this.q = q;
this.m = m2;
this.s = s3;
this.jstar = jstar;
this.astar = astar;
this.bstar = bstar;
}
/**
* CAM16 instances also have coordinates in the CAM16-UCS space, called J*,
* a*, b*, or jstar, astar, bstar in code. CAM16-UCS is included in the CAM16
* specification, and is used to measure distances between colors.
*/
distance(other) {
const dJ = this.jstar - other.jstar;
const dA = this.astar - other.astar;
const dB = this.bstar - other.bstar;
const dEPrime = Math.sqrt(dJ * dJ + dA * dA + dB * dB);
const dE = 1.41 * Math.pow(dEPrime, 0.63);
return dE;
}
/**
* @param argb ARGB representation of a color.
* @return CAM16 color, assuming the color was viewed in default viewing
* conditions.
*/
static fromInt(argb) {
return Cam16.fromIntInViewingConditions(argb, ViewingConditions.DEFAULT);
}
/**
* @param argb ARGB representation of a color.
* @param viewingConditions Information about the environment where the color
* was observed.
* @return CAM16 color.
*/
static fromIntInViewingConditions(argb, viewingConditions) {
const red = (argb & 16711680) >> 16;
const green = (argb & 65280) >> 8;
const blue = argb & 255;
const redL = linearized(red);
const greenL = linearized(green);
const blueL = linearized(blue);
const x2 = 0.41233895 * redL + 0.35762064 * greenL + 0.18051042 * blueL;
const y2 = 0.2126 * redL + 0.7152 * greenL + 0.0722 * blueL;
const z2 = 0.01932141 * redL + 0.11916382 * greenL + 0.95034478 * blueL;
const rC = 0.401288 * x2 + 0.650173 * y2 - 0.051461 * z2;
const gC = -0.250268 * x2 + 1.204414 * y2 + 0.045854 * z2;
const bC = -2079e-6 * x2 + 0.048952 * y2 + 0.953127 * z2;
const rD = viewingConditions.rgbD[0] * rC;
const gD = viewingConditions.rgbD[1] * gC;
const bD = viewingConditions.rgbD[2] * bC;
const rAF = Math.pow(viewingConditions.fl * Math.abs(rD) / 100, 0.42);
const gAF = Math.pow(viewingConditions.fl * Math.abs(gD) / 100, 0.42);
const bAF = Math.pow(viewingConditions.fl * Math.abs(bD) / 100, 0.42);
const rA = signum(rD) * 400 * rAF / (rAF + 27.13);
const gA = signum(gD) * 400 * gAF / (gAF + 27.13);
const bA = signum(bD) * 400 * bAF / (bAF + 27.13);
const a2 = (11 * rA + -12 * gA + bA) / 11;
const b3 = (rA + gA - 2 * bA) / 9;
const u2 = (20 * rA + 20 * gA + 21 * bA) / 20;
const p2 = (40 * rA + 20 * gA + bA) / 20;
const atan2 = Math.atan2(b3, a2);
const atanDegrees = atan2 * 180 / Math.PI;
const hue = atanDegrees < 0 ? atanDegrees + 360 : atanDegrees >= 360 ? atanDegrees - 360 : atanDegrees;
const hueRadians = hue * Math.PI / 180;
const ac = p2 * viewingConditions.nbb;
const j2 = 100 * Math.pow(ac / viewingConditions.aw, viewingConditions.c * viewingConditions.z);
const q = 4 / viewingConditions.c * Math.sqrt(j2 / 100) * (viewingConditions.aw + 4) * viewingConditions.fLRoot;
const huePrime = hue < 20.14 ? hue + 360 : hue;
const eHue = 0.25 * (Math.cos(huePrime * Math.PI / 180 + 2) + 3.8);
const p1 = 5e4 / 13 * eHue * viewingConditions.nc * viewingConditions.ncb;
const t3 = p1 * Math.sqrt(a2 * a2 + b3 * b3) / (u2 + 0.305);
const alpha = Math.pow(t3, 0.9) * Math.pow(1.64 - Math.pow(0.29, viewingConditions.n), 0.73);
const c3 = alpha * Math.sqrt(j2 / 100);
const m2 = c3 * viewingConditions.fLRoot;
const s3 = 50 * Math.sqrt(alpha * viewingConditions.c / (viewingConditions.aw + 4));
const jstar = (1 + 100 * 7e-3) * j2 / (1 + 7e-3 * j2);
const mstar = 1 / 0.0228 * Math.log(1 + 0.0228 * m2);
const astar = mstar * Math.cos(hueRadians);
const bstar = mstar * Math.sin(hueRadians);
return new Cam16(hue, c3, j2, q, m2, s3, jstar, astar, bstar);
}
/**
* @param j CAM16 lightness
* @param c CAM16 chroma
* @param h CAM16 hue
*/
static fromJch(j2, c3, h3) {
return Cam16.fromJchInViewingConditions(j2, c3, h3, ViewingConditions.DEFAULT);
}
/**
* @param j CAM16 lightness
* @param c CAM16 chroma
* @param h CAM16 hue
* @param viewingConditions Information about the environment where the color
* was observed.
*/
static fromJchInViewingConditions(j2, c3, h3, viewingConditions) {
const q = 4 / viewingConditions.c * Math.sqrt(j2 / 100) * (viewingConditions.aw + 4) * viewingConditions.fLRoot;
const m2 = c3 * viewingConditions.fLRoot;
const alpha = c3 / Math.sqrt(j2 / 100);
const s3 = 50 * Math.sqrt(alpha * viewingConditions.c / (viewingConditions.aw + 4));
const hueRadians = h3 * Math.PI / 180;
const jstar = (1 + 100 * 7e-3) * j2 / (1 + 7e-3 * j2);
const mstar = 1 / 0.0228 * Math.log(1 + 0.0228 * m2);
const astar = mstar * Math.cos(hueRadians);
const bstar = mstar * Math.sin(hueRadians);
return new Cam16(h3, c3, j2, q, m2, s3, jstar, astar, bstar);
}
/**
* @param jstar CAM16-UCS lightness.
* @param astar CAM16-UCS a dimension. Like a* in L*a*b*, it is a Cartesian
* coordinate on the Y axis.
* @param bstar CAM16-UCS b dimension. Like a* in L*a*b*, it is a Cartesian
* coordinate on the X axis.
*/
static fromUcs(jstar, astar, bstar) {
return Cam16.fromUcsInViewingConditions(jstar, astar, bstar, ViewingConditions.DEFAULT);
}
/**
* @param jstar CAM16-UCS lightness.
* @param astar CAM16-UCS a dimension. Like a* in L*a*b*, it is a Cartesian
* coordinate on the Y axis.
* @param bstar CAM16-UCS b dimension. Like a* in L*a*b*, it is a Cartesian
* coordinate on the X axis.
* @param viewingConditions Information about the environment where the color
* was observed.
*/
static fromUcsInViewingConditions(jstar, astar, bstar, viewingConditions) {
const a2 = astar;
const b3 = bstar;
const m2 = Math.sqrt(a2 * a2 + b3 * b3);
const M2 = (Math.exp(m2 * 0.0228) - 1) / 0.0228;
const c3 = M2 / viewingConditions.fLRoot;
let h3 = Math.atan2(b3, a2) * (180 / Math.PI);
if (h3 < 0) {
h3 += 360;
}
const j2 = jstar / (1 - (jstar - 100) * 7e-3);
return Cam16.fromJchInViewingConditions(j2, c3, h3, viewingConditions);
}
/**
* @return ARGB representation of color, assuming the color was viewed in
* default viewing conditions, which are near-identical to the default
* viewing conditions for sRGB.
*/
toInt() {
return this.viewed(ViewingConditions.DEFAULT);
}
/**
* @param viewingConditions Information about the environment where the color
* will be viewed.
* @return ARGB representation of color
*/
viewed(viewingConditions) {
const alpha = this.chroma === 0 || this.j === 0 ? 0 : this.chroma / Math.sqrt(this.j / 100);
const t3 = Math.pow(alpha / Math.pow(1.64 - Math.pow(0.29, viewingConditions.n), 0.73), 1 / 0.9);
const hRad = this.hue * Math.PI / 180;
const eHue = 0.25 * (Math.cos(hRad + 2) + 3.8);
const ac = viewingConditions.aw * Math.pow(this.j / 100, 1 / viewingConditions.c / viewingConditions.z);
const p1 = eHue * (5e4 / 13) * viewingConditions.nc * viewingConditions.ncb;
const p2 = ac / viewingConditions.nbb;
const hSin = Math.sin(hRad);
const hCos = Math.cos(hRad);
const gamma = 23 * (p2 + 0.305) * t3 / (23 * p1 + 11 * t3 * hCos + 108 * t3 * hSin);
const a2 = gamma * hCos;
const b3 = gamma * hSin;
const rA = (460 * p2 + 451 * a2 + 288 * b3) / 1403;
const gA = (460 * p2 - 891 * a2 - 261 * b3) / 1403;
const bA = (460 * p2 - 220 * a2 - 6300 * b3) / 1403;
const rCBase = Math.max(0, 27.13 * Math.abs(rA) / (400 - Math.abs(rA)));
const rC = signum(rA) * (100 / viewingConditions.fl) * Math.pow(rCBase, 1 / 0.42);
const gCBase = Math.max(0, 27.13 * Math.abs(gA) / (400 - Math.abs(gA)));
const gC = signum(gA) * (100 / viewingConditions.fl) * Math.pow(gCBase, 1 / 0.42);
const bCBase = Math.max(0, 27.13 * Math.abs(bA) / (400 - Math.abs(bA)));
const bC = signum(bA) * (100 / viewingConditions.fl) * Math.pow(bCBase, 1 / 0.42);
const rF = rC / viewingConditions.rgbD[0];
const gF = gC / viewingConditions.rgbD[1];
const bF = bC / viewingConditions.rgbD[2];
const x2 = 1.86206786 * rF - 1.01125463 * gF + 0.14918677 * bF;
const y2 = 0.38752654 * rF + 0.62144744 * gF - 897398e-8 * bF;
const z2 = -0.0158415 * rF - 0.03412294 * gF + 1.04996444 * bF;
const argb = argbFromXyz(x2, y2, z2);
return argb;
}
/// Given color expressed in XYZ and viewed in [viewingConditions], convert to
/// CAM16.
static fromXyzInViewingConditions(x2, y2, z2, viewingConditions) {
const rC = 0.401288 * x2 + 0.650173 * y2 - 0.051461 * z2;
const gC = -0.250268 * x2 + 1.204414 * y2 + 0.045854 * z2;
const bC = -2079e-6 * x2 + 0.048952 * y2 + 0.953127 * z2;
const rD = viewingConditions.rgbD[0] * rC;
const gD = viewingConditions.rgbD[1] * gC;
const bD = viewingConditions.rgbD[2] * bC;
const rAF = Math.pow(viewingConditions.fl * Math.abs(rD) / 100, 0.42);
const gAF = Math.pow(viewingConditions.fl * Math.abs(gD) / 100, 0.42);
const bAF = Math.pow(viewingConditions.fl * Math.abs(bD) / 100, 0.42);
const rA = signum(rD) * 400 * rAF / (rAF + 27.13);
const gA = signum(gD) * 400 * gAF / (gAF + 27.13);
const bA = signum(bD) * 400 * bAF / (bAF + 27.13);
const a2 = (11 * rA + -12 * gA + bA) / 11;
const b3 = (rA + gA - 2 * bA) / 9;
const u2 = (20 * rA + 20 * gA + 21 * bA) / 20;
const p2 = (40 * rA + 20 * gA + bA) / 20;
const atan2 = Math.atan2(b3, a2);
const atanDegrees = atan2 * 180 / Math.PI;
const hue = atanDegrees < 0 ? atanDegrees + 360 : atanDegrees >= 360 ? atanDegrees - 360 : atanDegrees;
const hueRadians = hue * Math.PI / 180;
const ac = p2 * viewingConditions.nbb;
const J = 100 * Math.pow(ac / viewingConditions.aw, viewingConditions.c * viewingConditions.z);
const Q = 4 / viewingConditions.c * Math.sqrt(J / 100) * (viewingConditions.aw + 4) * viewingConditions.fLRoot;
const huePrime = hue < 20.14 ? hue + 360 : hue;
const eHue = 1 / 4 * (Math.cos(huePrime * Math.PI / 180 + 2) + 3.8);
const p1 = 5e4 / 13 * eHue * viewingConditions.nc * viewingConditions.ncb;
const t3 = p1 * Math.sqrt(a2 * a2 + b3 * b3) / (u2 + 0.305);
const alpha = Math.pow(t3, 0.9) * Math.pow(1.64 - Math.pow(0.29, viewingConditions.n), 0.73);
const C2 = alpha * Math.sqrt(J / 100);
const M2 = C2 * viewingConditions.fLRoot;
const s3 = 50 * Math.sqrt(alpha * viewingConditions.c / (viewingConditions.aw + 4));
const jstar = (1 + 100 * 7e-3) * J / (1 + 7e-3 * J);
const mstar = Math.log(1 + 0.0228 * M2) / 0.0228;
const astar = mstar * Math.cos(hueRadians);
const bstar = mstar * Math.sin(hueRadians);
return new Cam16(hue, C2, J, Q, M2, s3, jstar, astar, bstar);
}
/// XYZ representation of CAM16 seen in [viewingConditions].
xyzInViewingConditions(viewingConditions) {
const alpha = this.chroma === 0 || this.j === 0 ? 0 : this.chroma / Math.sqrt(this.j / 100);
const t3 = Math.pow(alpha / Math.pow(1.64 - Math.pow(0.29, viewingConditions.n), 0.73), 1 / 0.9);
const hRad = this.hue * Math.PI / 180;
const eHue = 0.25 * (Math.cos(hRad + 2) + 3.8);
const ac = viewingConditions.aw * Math.pow(this.j / 100, 1 / viewingConditions.c / viewingConditions.z);
const p1 = eHue * (5e4 / 13) * viewingConditions.nc * viewingConditions.ncb;
const p2 = ac / viewingConditions.nbb;
const hSin = Math.sin(hRad);
const hCos = Math.cos(hRad);
const gamma = 23 * (p2 + 0.305) * t3 / (23 * p1 + 11 * t3 * hCos + 108 * t3 * hSin);
const a2 = gamma * hCos;
const b3 = gamma * hSin;
const rA = (460 * p2 + 451 * a2 + 288 * b3) / 1403;
const gA = (460 * p2 - 891 * a2 - 261 * b3) / 1403;
const bA = (460 * p2 - 220 * a2 - 6300 * b3) / 1403;
const rCBase = Math.max(0, 27.13 * Math.abs(rA) / (400 - Math.abs(rA)));
const rC = signum(rA) * (100 / viewingConditions.fl) * Math.pow(rCBase, 1 / 0.42);
const gCBase = Math.max(0, 27.13 * Math.abs(gA) / (400 - Math.abs(gA)));
const gC = signum(gA) * (100 / viewingConditions.fl) * Math.pow(gCBase, 1 / 0.42);
const bCBase = Math.max(0, 27.13 * Math.abs(bA) / (400 - Math.abs(bA)));
const bC = signum(bA) * (100 / viewingConditions.fl) * Math.pow(bCBase, 1 / 0.42);
const rF = rC / viewingConditions.rgbD[0];
const gF = gC / viewingConditions.rgbD[1];
const bF = bC / viewingConditions.rgbD[2];
const x2 = 1.86206786 * rF - 1.01125463 * gF + 0.14918677 * bF;
const y2 = 0.38752654 * rF + 0.62144744 * gF - 897398e-8 * bF;
const z2 = -0.0158415 * rF - 0.03412294 * gF + 1.04996444 * bF;
return [x2, y2, z2];
}
}
/**
* @license
* Copyright 2021 Google LLC
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
class HctSolver {
/**
* Sanitizes a small enough angle in radians.
*
* @param angle An angle in radians; must not deviate too much
* from 0.
* @return A coterminal angle between 0 and 2pi.
*/
static sanitizeRadians(angle) {
return (angle + Math.PI * 8) % (Math.PI * 2);
}
/**
* Delinearizes an RGB component, returning a floating-point
* number.
*
* @param rgbComponent 0.0 <= rgb_component <= 100.0, represents
* linear R/G/B channel
* @return 0.0 <= output <= 255.0, color channel converted to
* regular RGB space
*/
static trueDelinearized(rgbComponent) {
const normalized = rgbComponent / 100;
let delinearized2 = 0;
if (normalized <= 31308e-7) {
delinearized2 = normalized * 12.92;
} else {
delinearized2 = 1.055 * Math.pow(normalized, 1 / 2.4) - 0.055;
}
return delinearized2 * 255;
}
static chromaticAdaptation(component) {
const af = Math.pow(Math.abs(component), 0.42);
return signum(component) * 400 * af / (af + 27.13);
}
/**
* Returns the hue of a linear RGB color in CAM16.
*
* @param linrgb The linear RGB coordinates of a color.
* @return The hue of the color in CAM16, in radians.
*/
static hueOf(linrgb) {
const scaledDiscount = matrixMultiply(linrgb, HctSolver.SCALED_DISCOUNT_FROM_LINRGB);
const rA = HctSolver.chromaticAdaptation(scaledDiscount[0]);
const gA = HctSolver.chromaticAdaptation(scaledDiscount[1]);
const bA = HctSolver.chromaticAdaptation(scaledDiscount[2]);
const a2 = (11 * rA + -12 * gA + bA) / 11;
const b3 = (rA + gA - 2 * bA) / 9;
return Math.atan2(b3, a2);
}
static areInCyclicOrder(a2, b3, c3) {
const deltaAB = HctSolver.sanitizeRadians(b3 - a2);
const deltaAC = HctSolver.sanitizeRadians(c3 - a2);
return deltaAB < deltaAC;
}
/**
* Solves the lerp equation.
*
* @param source The starting number.
* @param mid The number in the middle.
* @param target The ending number.
* @return A number t such that lerp(source, target, t) = mid.
*/
static intercept(source2, mid, target) {
return (mid - source2) / (target - source2);
}
static lerpPoint(source2, t3, target) {
return [
source2[0] + (target[0] - source2[0]) * t3,
source2[1] + (target[1] - source2[1]) * t3,
source2[2] + (target[2] - source2[2]) * t3
];
}
/**
* Intersects a segment with a plane.
*
* @param source The coordinates of point A.
* @param coordinate The R-, G-, or B-coordinate of the plane.
* @param target The coordinates of point B.
* @param axis The axis the plane is perpendicular with. (0: R, 1:
* G, 2: B)
* @return The intersection point of the segment AB with the plane
* R=coordinate, G=coordinate, or B=coordinate
*/
static setCoordinate(source2, coordinate, target, axis) {
const t3 = HctSolver.intercept(source2[axis], coordinate, target[axis]);
return HctSolver.lerpPoint(source2, t3, target);
}
static isBounded(x2) {
return 0 <= x2 && x2 <= 100;
}
/**
* Returns the nth possible vertex of the polygonal intersection.
*
* @param y The Y value of the plane.
* @param n The zero-based index of the point. 0 <= n <= 11.
* @return The nth possible vertex of the polygonal intersection
* of the y plane and the RGB cube, in linear RGB coordinates, if
* it exists. If this possible vertex lies outside of the cube,
* [-1.0, -1.0, -1.0] is returned.
*/
static nthVertex(y2, n3) {
const kR = HctSolver.Y_FROM_LINRGB[0];
const kG = HctSolver.Y_FROM_LINRGB[1];
const kB = HctSolver.Y_FROM_LINRGB[2];
const coordA = n3 % 4 <= 1 ? 0 : 100;
const coordB = n3 % 2 === 0 ? 0 : 100;
if (n3 < 4) {
const g2 = coordA;
const b3 = coordB;
const r3 = (y2 - g2 * kG - b3 * kB) / kR;
if (HctSolver.isBounded(r3)) {
return [r3, g2, b3];
} else {
return [-1, -1, -1];
}
} else if (n3 < 8) {
const b3 = coordA;
const r3 = coordB;
const g2 = (y2 - r3 * kR - b3 * kB) / kG;
if (HctSolver.isBounded(g2)) {
return [r3, g2, b3];
} else {
return [-1, -1, -1];
}
} else {
const r3 = coordA;
const g2 = coordB;
const b3 = (y2 - r3 * kR - g2 * kG) / kB;
if (HctSolver.isBounded(b3)) {
return [r3, g2, b3];
} else {
return [-1, -1, -1];
}
}
}
/**
* Finds the segment containing the desired color.
*
* @param y The Y value of the color.
* @param targetHue The hue of the color.
* @return A list of two sets of linear RGB coordinates, each
* corresponding to an endpoint of the segment containing the
* desired color.
*/
static bisectToSegment(y2, targetHue) {
let left = [-1, -1, -1];
let right = left;
let leftHue = 0;
let rightHue = 0;
let initialized = false;
let uncut = true;
for (let n3 = 0; n3 < 12; n3++) {
const mid = HctSolver.nthVertex(y2, n3);
if (mid[0] < 0) {
continue;
}
const midHue = HctSolver.hueOf(mid);
if (!initialized) {
left = mid;
right = mid;
leftHue = midHue;
rightHue = midHue;
initialized = true;
continue;
}
if (uncut || HctSolver.areInCyclicOrder(leftHue, midHue, rightHue)) {
uncut = false;
if (HctSolver.areInCyclicOrder(leftHue, targetHue, midHue)) {
right = mid;
rightHue = midHue;
} else {
left = mid;
leftHue = midHue;
}
}
}
return [left, right];
}
static midpoint(a2, b3) {
return [
(a2[0] + b3[0]) / 2,
(a2[1] + b3[1]) / 2,
(a2[2] + b3[2]) / 2
];
}
static criticalPlaneBelow(x2) {
return Math.floor(x2 - 0.5);
}
static criticalPlaneAbove(x2) {
return Math.ceil(x2 - 0.5);
}
/**
* Finds a color with the given Y and hue on the boundary of the
* cube.
*
* @param y The Y value of the color.
* @param targetHue The hue of the color.
* @return The desired color, in linear RGB coordinates.
*/
static bisectToLimit(y2, targetHue) {
const segment = HctSolver.bisectToSegment(y2, targetHue);
let left = segment[0];
let leftHue = HctSolver.hueOf(left);
let right = segment[1];
for (let axis = 0; axis < 3; axis++) {
if (left[axis] !== right[axis]) {
let lPlane = -1;
let rPlane = 255;
if (left[axis] < right[axis]) {
lPlane = HctSolver.criticalPlaneBelow(HctSolver.trueDelinearized(left[axis]));
rPlane = HctSolver.criticalPlaneAbove(HctSolver.trueDelinearized(right[axis]));
} else {
lPlane = HctSolver.criticalPlaneAbove(HctSolver.trueDelinearized(left[axis]));
rPlane = HctSolver.criticalPlaneBelow(HctSolver.trueDelinearized(right[axis]));
}
for (let i3 = 0; i3 < 8; i3++) {
if (Math.abs(rPlane - lPlane) <= 1) {
break;
} else {
const mPlane = Math.floor((lPlane + rPlane) / 2);
const midPlaneCoordinate = HctSolver.CRITICAL_PLANES[mPlane];
const mid = HctSolver.setCoordinate(left, midPlaneCoordinate, right, axis);
const midHue = HctSolver.hueOf(mid);
if (HctSolver.areInCyclicOrder(leftHue, targetHue, midHue)) {
right = mid;
rPlane = mPlane;
} else {
left = mid;
leftHue = midHue;
lPlane = mPlane;
}
}
}
}
}
return HctSolver.midpoint(left, right);
}
static inverseChromaticAdaptation(adapted) {
const adaptedAbs = Math.abs(adapted);
const base = Math.max(0, 27.13 * adaptedAbs / (400 - adaptedAbs));
return signum(adapted) * Math.pow(base, 1 / 0.42);
}
/**
* Finds a color with the given hue, chroma, and Y.
*
* @param hueRadians The desired hue in radians.
* @param chroma The desired chroma.
* @param y The desired Y.
* @return The desired color as a hexadecimal integer, if found; 0
* otherwise.
*/
static findResultByJ(hueRadians, chroma, y2) {
let j2 = Math.sqrt(y2) * 11;
const viewingConditions = ViewingConditions.DEFAULT;
const tInnerCoeff = 1 / Math.pow(1.64 - Math.pow(0.29, viewingConditions.n), 0.73);
const eHue = 0.25 * (Math.cos(hueRadians + 2) + 3.8);
const p1 = eHue * (5e4 / 13) * viewingConditions.nc * viewingConditions.ncb;
const hSin = Math.sin(hueRadians);
const hCos = Math.cos(hueRadians);
for (let iterationRound = 0; iterationRound < 5; iterationRound++) {
const jNormalized = j2 / 100;
const alpha = chroma === 0 || j2 === 0 ? 0 : chroma / Math.sqrt(jNormalized);
const t3 = Math.pow(alpha * tInnerCoeff, 1 / 0.9);
const ac = viewingConditions.aw * Math.pow(jNormalized, 1 / viewingConditions.c / viewingConditions.z);
const p2 = ac / viewingConditions.nbb;
const gamma = 23 * (p2 + 0.305) * t3 / (23 * p1 + 11 * t3 * hCos + 108 * t3 * hSin);
const a2 = gamma * hCos;
const b3 = gamma * hSin;
const rA = (460 * p2 + 451 * a2 + 288 * b3) / 1403;
const gA = (460 * p2 - 891 * a2 - 261 * b3) / 1403;
const bA = (460 * p2 - 220 * a2 - 6300 * b3) / 1403;
const rCScaled = HctSolver.inverseChromaticAdaptation(rA);
const gCScaled = HctSolver.inverseChromaticAdaptation(gA);
const bCScaled = HctSolver.inverseChromaticAdaptation(bA);
const linrgb = matrixMultiply([rCScaled, gCScaled, bCScaled], HctSolver.LINRGB_FROM_SCALED_DISCOUNT);
if (linrgb[0] < 0 || linrgb[1] < 0 || linrgb[2] < 0) {
return 0;
}
const kR = HctSolver.Y_FROM_LINRGB[0];
const kG = HctSolver.Y_FROM_LINRGB[1];
const kB = HctSolver.Y_FROM_LINRGB[2];
const fnj = kR * linrgb[0] + kG * linrgb[1] + kB * linrgb[2];
if (fnj <= 0) {
return 0;
}
if (iterationRound === 4 || Math.abs(fnj - y2) < 2e-3) {
if (linrgb[0] > 100.01 || linrgb[1] > 100.01 || linrgb[2] > 100.01) {
return 0;
}
return argbFromLinrgb(linrgb);
}
j2 = j2 - (fnj - y2) * j2 / (2 * fnj);
}
return 0;
}
/**
* Finds an sRGB color with the given hue, chroma, and L*, if
* possible.
*
* @param hueDegrees The desired hue, in degrees.
* @param chroma The desired chroma.
* @param lstar The desired L*.
* @return A hexadecimal representing the sRGB color. The color
* has sufficiently close hue, chroma, and L* to the desired
* values, if possible; otherwise, the hue and L* will be
* sufficiently close, and chroma will be maximized.
*/
static solveToInt(hueDegrees, chroma, lstar) {
if (chroma < 1e-4 || lstar < 1e-4 || lstar > 99.9999) {
return argbFromLstar(lstar);
}
hueDegrees = sanitizeDegreesDouble(hueDegrees);
const hueRadians = hueDegrees / 180 * Math.PI;
const y2 = yFromLstar(lstar);
const exactAnswer = HctSolver.findResultByJ(hueRadians, chroma, y2);
if (exactAnswer !== 0) {
return exactAnswer;
}
const linrgb = HctSolver.bisectToLimit(y2, hueRadians);
return argbFromLinrgb(linrgb);
}
/**
* Finds an sRGB color with the given hue, chroma, and L*, if
* possible.
*
* @param hueDegrees The desired hue, in degrees.
* @param chroma The desired chroma.
* @param lstar The desired L*.
* @return An CAM16 object representing the sRGB color. The color
* has sufficiently close hue, chroma, and L* to the desired
* values, if possible; otherwise, the hue and L* will be
* sufficiently close, and chroma will be maximized.
*/
static solveToCam(hueDegrees, chroma, lstar) {
return Cam16.fromInt(HctSolver.solveToInt(hueDegrees, chroma, lstar));
}
}
HctSolver.SCALED_DISCOUNT_FROM_LINRGB = [
[
0.001200833568784504,
0.002389694492170889,
2795742885861124e-19
],
[
5891086651375999e-19,
0.0029785502573438758,
3270666104008398e-19
],
[
10146692491640572e-20,
5364214359186694e-19,
0.0032979401770712076
]
];
HctSolver.LINRGB_FROM_SCALED_DISCOUNT = [
[
1373.2198709594231,
-1100.4251190754821,
-7.278681089101213
],
[
-271.815969077903,
559.6580465940733,
-32.46047482791194
],
[
1.9622899599665666,
-57.173814538844006,
308.7233197812385
]
];
HctSolver.Y_FROM_LINRGB = [0.2126, 0.7152, 0.0722];
HctSolver.CRITICAL_PLANES = [
0.015176349177441876,
0.045529047532325624,
0.07588174588720938,
0.10623444424209313,
0.13658714259697685,
0.16693984095186062,
0.19729253930674434,
0.2276452376616281,
0.2579979360165119,
0.28835063437139563,
0.3188300904430532,
0.350925934958123,
0.3848314933096426,
0.42057480301049466,
0.458183274052838,
0.4976837250274023,
0.5391024159806381,
0.5824650784040898,
0.6277969426914107,
0.6751227633498623,
0.7244668422128921,
0.775853049866786,
0.829304845476233,
0.8848452951698498,
0.942497089126609,
1.0022825574869039,
1.0642236851973577,
1.1283421258858297,
1.1946592148522128,
1.2631959812511864,
1.3339731595349034,
1.407011200216447,
1.4823302800086415,
1.5599503113873272,
1.6398909516233677,
1.7221716113234105,
1.8068114625156377,
1.8938294463134073,
1.9832442801866852,
2.075074464868551,
2.1693382909216234,
2.2660538449872063,
2.36523901573795,
2.4669114995532007,
2.5710888059345764,
2.6777882626779785,
2.7870270208169257,
2.898822059350997,
3.0131901897720907,
3.1301480604002863,
3.2497121605402226,
3.3718988244681087,
3.4967242352587946,
3.624204428461639,
3.754355295633311,
3.887192587735158,
4.022731918402185,
4.160988767090289,
4.301978482107941,
4.445716283538092,
4.592217266055746,
4.741496401646282,
4.893568542229298,
5.048448422192488,
5.20615066083972,
5.3666897647573375,
5.5300801301023865,
5.696336044816294,
5.865471690767354,
6.037501145825082,
6.212438385869475,
6.390297286737924,
6.571091626112461,
6.7548350853498045,
6.941541251256611,
7.131223617812143,
7.323895587840543,
7.5195704746346665,
7.7182615035334345,
7.919981813454504,
8.124744458384042,
8.332562408825165,
8.543448553206703,
8.757415699253682,
8.974476575321063,
9.194643831691977,
9.417930041841839,
9.644347703669503,
9.873909240696694,
10.106627003236781,
10.342513269534024,
10.58158024687427,
10.8238400726681,
11.069304815507364,
11.317986476196008,
11.569896988756009,
11.825048221409341,
12.083451977536606,
12.345119996613247,
12.610063955123938,
12.878295467455942,
13.149826086772048,
13.42466730586372,
13.702830557985108,
13.984327217668513,
14.269168601521828,
14.55736596900856,
14.848930523210871,
15.143873411576273,
15.44220572664832,
15.743938506781891,
16.04908273684337,
16.35764934889634,
16.66964922287304,
16.985093187232053,
17.30399201960269,
17.62635644741625,
17.95219714852476,
18.281524751807332,
18.614349837764564,
18.95068293910138,
19.290534541298456,
19.633915083172692,
19.98083495742689,
20.331304511189067,
20.685334046541502,
21.042933821039977,
21.404114048223256,
21.76888489811322,
22.137256497705877,
22.50923893145328,
22.884842241736916,
23.264076429332462,
23.6469514538663,
24.033477234264016,
24.42366364919083,
24.817520537484558,
25.21505769858089,
25.61628489293138,
26.021211842414342,
26.429848230738664,
26.842203703840827,
27.258287870275353,
27.678110301598522,
28.10168053274597,
28.529008062403893,
28.96010235337422,
29.39497283293396,
29.83362889318845,
30.276079891419332,
30.722335150426627,
31.172403958865512,
31.62629557157785,
32.08401920991837,
32.54558406207592,
33.010999283389665,
33.4802739966603,
33.953417292456834,
34.430438229418264,
34.911345834551085,
35.39614910352207,
35.88485700094671,
36.37747846067349,
36.87402238606382,
37.37449765026789,
37.87891309649659,
38.38727753828926,
38.89959975977785,
39.41588851594697,
39.93615253289054,
40.460400508064545,
40.98864111053629,
41.520882981230194,
42.05713473317016,
42.597404951718396,
43.141702194811224,
43.6900349931913,
44.24241185063697,
44.798841244188324,
45.35933162437017,
45.92389141541209,
46.49252901546552,
47.065252796817916,
47.64207110610409,
48.22299226451468,
48.808024568002054,
49.3971762874833,
49.9904556690408,
50.587870934119984,
51.189430279724725,
51.79514187861014,
52.40501387947288,
53.0190544071392,
53.637271562750364,
54.259673423945976,
54.88626804504493,
55.517063457223934,
56.15206766869424,
56.79128866487574,
57.43473440856916,
58.08241284012621,
58.734331877617365,
59.39049941699807,
60.05092333227251,
60.715611475655585,
61.38457167773311,
62.057811747619894,
62.7353394731159,
63.417162620860914,
64.10328893648692,
64.79372614476921,
65.48848194977529,
66.18756403501224,
66.89098006357258,
67.59873767827808,
68.31084450182222,
69.02730813691093,
69.74813616640164,
70.47333615344107,
71.20291564160104,
71.93688215501312,
72.67524319850172,
73.41800625771542,
74.16517879925733,
74.9167682708136,
75.67278210128072,
76.43322770089146,
77.1981124613393,
77.96744375590167,
78.74122893956174,
79.51947534912904,
80.30219030335869,
81.08938110306934,
81.88105503125999,
82.67721935322541,
83.4778813166706,
84.28304815182372,
85.09272707154808,
85.90692527145302,
86.72564993000343,
87.54890820862819,
88.3767072518277,
89.2090541872801,
90.04595612594655,
90.88742016217518,
91.73345337380438,
92.58406282226491,
93.43925555268066,
94.29903859396902,
95.16341895893969,
96.03240364439274,
96.9059996312159,
97.78421388448044,
98.6670533535366,
99.55452497210776
];
/**
* @license
* Copyright 2021 Google LLC
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
class Hct {
static from(hue, chroma, tone) {
return new Hct(HctSolver.solveToInt(hue, chroma, tone));
}
/**
* @param argb ARGB representation of a color.
* @return HCT representation of a color in default viewing conditions
*/
static fromInt(argb) {
return new Hct(argb);
}
toInt() {
return this.argb;
}
/**
* A number, in degrees, representing ex. red, orange, yellow, etc.
* Ranges from 0 <= hue < 360.
*/
get hue() {
return this.internalHue;
}
/**
* @param newHue 0 <= newHue < 360; invalid values are corrected.
* Chroma may decrease because chroma has a different maximum for any given
* hue and tone.
*/
set hue(newHue) {
this.setInternalState(HctSolver.solveToInt(newHue, this.internalChroma, this.internalTone));
}
get chroma() {
return this.internalChroma;
}
/**
* @param newChroma 0 <= newChroma < ?
* Chroma may decrease because chroma has a different maximum for any given
* hue and tone.
*/
set chroma(newChroma) {
this.setInternalState(HctSolver.solveToInt(this.internalHue, newChroma, this.internalTone));
}
/** Lightness. Ranges from 0 to 100. */
get tone() {
return this.internalTone;
}
/**
* @param newTone 0 <= newTone <= 100; invalid valids are corrected.
* Chroma may decrease because chroma has a different maximum for any given
* hue and tone.
*/
set tone(newTone) {
this.setInternalState(HctSolver.solveToInt(this.internalHue, this.internalChroma, newTone));
}
constructor(argb) {
this.argb = argb;
const cam = Cam16.fromInt(argb);
this.internalHue = cam.hue;
this.internalChroma = cam.chroma;
this.internalTone = lstarFromArgb(argb);
this.argb = argb;
}
setInternalState(argb) {
const cam = Cam16.fromInt(argb);
this.internalHue = cam.hue;
this.internalChroma = cam.chroma;
this.internalTone = lstarFromArgb(argb);
this.argb = argb;
}
/**
* Translates a color into different [ViewingConditions].
*
* Colors change appearance. They look different with lights on versus off,
* the same color, as in hex code, on white looks different when on black.
* This is called color relativity, most famously explicated by Josef Albers
* in Interaction of Color.
*
* In color science, color appearance models can account for this and
* calculate the appearance of a color in different settings. HCT is based on
* CAM16, a color appearance model, and uses it to make these calculations.
*
* See [ViewingConditions.make] for parameters affecting color appearance.
*/
inViewingConditions(vc) {
const cam = Cam16.fromInt(this.toInt());
const viewedInVc = cam.xyzInViewingConditions(vc);
const recastInVc = Cam16.fromXyzInViewingConditions(viewedInVc[0], viewedInVc[1], viewedInVc[2], ViewingConditions.make());
const recastHct = Hct.from(recastInVc.hue, recastInVc.chroma, lstarFromY(viewedInVc[1]));
return recastHct;
}
}
/**
* @license
* Copyright 2021 Google LLC
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
class Blend {
/**
* Blend the design color's HCT hue towards the key color's HCT
* hue, in a way that leaves the original color recognizable and
* recognizably shifted towards the key color.
*
* @param designColor ARGB representation of an arbitrary color.
* @param sourceColor ARGB representation of the main theme color.
* @return The design color with a hue shifted towards the
* system's color, a slightly warmer/cooler variant of the design
* color's hue.
*/
static harmonize(designColor, sourceColor) {
const fromHct = Hct.fromInt(designColor);
const toHct = Hct.fromInt(sourceColor);
const differenceDegrees$1 = differenceDegrees(fromHct.hue, toHct.hue);
const rotationDegrees = Math.min(differenceDegrees$1 * 0.5, 15);
const outputHue = sanitizeDegreesDouble(fromHct.hue + rotationDegrees * rotationDirection(fromHct.hue, toHct.hue));
return Hct.from(outputHue, fromHct.chroma, fromHct.tone).toInt();
}
/**
* Blends hue from one color into another. The chroma and tone of
* the original color are maintained.
*
* @param from ARGB representation of color
* @param to ARGB representation of color
* @param amount how much blending to perform; 0.0 >= and <= 1.0
* @return from, with a hue blended towards to. Chroma and tone
* are constant.
*/
static hctHue(from, to, amount) {
const ucs = Blend.cam16Ucs(from, to, amount);
const ucsCam = Cam16.fromInt(ucs);
const fromCam = Cam16.fromInt(from);
const blended = Hct.from(ucsCam.hue, fromCam.chroma, lstarFromArgb(from));
return blended.toInt();
}
/**
* Blend in CAM16-UCS space.
*
* @param from ARGB representation of color
* @param to ARGB representation of color
* @param amount how much blending to perform; 0.0 >= and <= 1.0
* @return from, blended towards to. Hue, chroma, and tone will
* change.
*/
static cam16Ucs(from, to, amount) {
const fromCam = Cam16.fromInt(from);
const toCam = Cam16.fromInt(to);
const fromJ = fromCam.jstar;
const fromA = fromCam.astar;
const fromB = fromCam.bstar;
const toJ = toCam.jstar;
const toA = toCam.astar;
const toB = toCam.bstar;
const jstar = fromJ + (toJ - fromJ) * amount;
const astar = fromA + (toA - fromA) * amount;
const bstar = fromB + (toB - fromB) * amount;
return Cam16.fromUcs(jstar, astar, bstar).toInt();
}
}
/**
* @license
* Copyright 2022 Google LLC
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
class Contrast {
/**
* Returns a contrast ratio, which ranges from 1 to 21.
*
* @param toneA Tone between 0 and 100. Values outside will be clamped.
* @param toneB Tone between 0 and 100. Values outside will be clamped.
*/
static ratioOfTones(toneA, toneB) {
toneA = clampDouble(0, 100, toneA);
toneB = clampDouble(0, 100, toneB);
return Contrast.ratioOfYs(yFromLstar(toneA), yFromLstar(toneB));
}
static ratioOfYs(y1, y2) {
const lighter = y1 > y2 ? y1 : y2;
const darker = lighter === y2 ? y1 : y2;
return (lighter + 5) / (darker + 5);
}
/**
* Returns a tone >= tone parameter that ensures ratio parameter.
* Return value is between 0 and 100.
* Returns -1 if ratio cannot be achieved with tone parameter.
*
* @param tone Tone return value must contrast with.
* Range is 0 to 100. Invalid values will result in -1 being returned.
* @param ratio Contrast ratio of return value and tone.
* Range is 1 to 21, invalid values have undefined behavior.
*/
static lighter(tone, ratio) {
if (tone < 0 || tone > 100) {
return -1;
}
const darkY = yFromLstar(tone);
const lightY = ratio * (darkY + 5) - 5;
const realContrast = Contrast.ratioOfYs(lightY, darkY);
const delta = Math.abs(realContrast - ratio);
if (realContrast < ratio && delta > 0.04) {
return -1;
}
const returnValue = lstarFromY(lightY) + 0.4;
if (returnValue < 0 || returnValue > 100) {
return -1;
}
return returnValue;
}
/**
* Returns a tone <= tone parameter that ensures ratio parameter.
* Return value is between 0 and 100.
* Returns -1 if ratio cannot be achieved with tone parameter.
*
* @param tone Tone return value must contrast with.
* Range is 0 to 100. Invalid values will result in -1 being returned.
* @param ratio Contrast ratio of return value and tone.
* Range is 1 to 21, invalid values have undefined behavior.
*/
static darker(tone, ratio) {
if (tone < 0 || tone > 100) {
return -1;
}
const lightY = yFromLstar(tone);
const darkY = (lightY + 5) / ratio - 5;
const realContrast = Contrast.ratioOfYs(lightY, darkY);
const delta = Math.abs(realContrast - ratio);
if (realContrast < ratio && delta > 0.04) {
return -1;
}
const returnValue = lstarFromY(darkY) - 0.4;
if (returnValue < 0 || returnValue > 100) {
return -1;
}
return returnValue;
}
/**
* Returns a tone >= tone parameter that ensures ratio parameter.
* Return value is between 0 and 100.
* Returns 100 if ratio cannot be achieved with tone parameter.
*
* This method is unsafe because the returned value is guaranteed to be in
* bounds for tone, i.e. between 0 and 100. However, that value may not reach
* the ratio with tone. For example, there is no color lighter than T100.
*
* @param tone Tone return value must contrast with.
* Range is 0 to 100. Invalid values will result in 100 being returned.
* @param ratio Desired contrast ratio of return value and tone parameter.
* Range is 1 to 21, invalid values have undefined behavior.
*/
static lighterUnsafe(tone, ratio) {
const lighterSafe = Contrast.lighter(tone, ratio);
return lighterSafe < 0 ? 100 : lighterSafe;
}
/**
* Returns a tone >= tone parameter that ensures ratio parameter.
* Return value is between 0 and 100.
* Returns 100 if ratio cannot be achieved with tone parameter.
*
* This method is unsafe because the returned value is guaranteed to be in
* bounds for tone, i.e. between 0 and 100. However, that value may not reach
* the [ratio with [tone]. For example, there is no color darker than T0.
*
* @param tone Tone return value must contrast with.
* Range is 0 to 100. Invalid values will result in 0 being returned.
* @param ratio Desired contrast ratio of return value and tone parameter.
* Range is 1 to 21, invalid values have undefined behavior.
*/
static darkerUnsafe(tone, ratio) {
const darkerSafe = Contrast.darker(tone, ratio);
return darkerSafe < 0 ? 0 : darkerSafe;
}
}
/**
* @license
* Copyright 2023 Google LLC
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
class DislikeAnalyzer {
/**
* Returns true if a color is disliked.
*
* @param hct A color to be judged.
* @return Whether the color is disliked.
*
* Disliked is defined as a dark yellow-green that is not neutral.
*/
static isDisliked(hct) {
const huePasses = Math.round(hct.hue) >= 90 && Math.round(hct.hue) <= 111;
const chromaPasses = Math.round(hct.chroma) > 16;
const tonePasses = Math.round(hct.tone) < 65;
return huePasses && chromaPasses && tonePasses;
}
/**
* If a color is disliked, lighten it to make it likable.
*
* @param hct A color to be judged.
* @return A new color if the original color is disliked, or the original
* color if it is acceptable.
*/
static fixIfDisliked(hct) {
if (DislikeAnalyzer.isDisliked(hct)) {
return Hct.from(hct.hue, hct.chroma, 70);
}
return hct;
}
}
/**
* @license
* Copyright 2022 Google LLC
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
class DynamicColor {
/**
* Create a DynamicColor defined by a TonalPalette and HCT tone.
*
* @param args Functions with DynamicScheme as input. Must provide a palette
* and tone. May provide a background DynamicColor and ToneDeltaConstraint.
*/
static fromPalette(args) {
return new DynamicColor(args.name ?? "", args.palette, args.tone, args.isBackground ?? false, args.background, args.secondBackground, args.contrastCurve, args.toneDeltaPair);
}
/**
* The base constructor for DynamicColor.
*
* _Strongly_ prefer using one of the convenience constructors. This class is
* arguably too flexible to ensure it can support any scenario. Functional
* arguments allow overriding without risks that come with subclasses.
*
* For example, the default behavior of adjust tone at max contrast
* to be at a 7.0 ratio with its background is principled and
* matches accessibility guidance. That does not mean it's the desired
* approach for _every_ design system, and every color pairing,
* always, in every case.
*
* @param name The name of the dynamic color. Defaults to empty.
* @param palette Function that provides a TonalPalette given
* DynamicScheme. A TonalPalette is defined by a hue and chroma, so this
* replaces the need to specify hue/chroma. By providing a tonal palette, when
* contrast adjustments are made, intended chroma can be preserved.
* @param tone Function that provides a tone, given a DynamicScheme.
* @param isBackground Whether this dynamic color is a background, with
* some other color as the foreground. Defaults to false.
* @param background The background of the dynamic color (as a function of a
* `DynamicScheme`), if it exists.
* @param secondBackground A second background of the dynamic color (as a
* function of a `DynamicScheme`), if it
* exists.
* @param contrastCurve A `ContrastCurve` object specifying how its contrast
* against its background should behave in various contrast levels options.
* @param toneDeltaPair A `ToneDeltaPair` object specifying a tone delta
* constraint between two colors. One of them must be the color being
* constructed.
*/
constructor(name, palette, tone, isBackground, background, secondBackground, contrastCurve, toneDeltaPair) {
this.name = name;
this.palette = palette;
this.tone = tone;
this.isBackground = isBackground;
this.background = background;
this.secondBackground = secondBackground;
this.contrastCurve = contrastCurve;
this.toneDeltaPair = toneDeltaPair;
this.hctCache = /* @__PURE__ */ new Map();
if (!background && secondBackground) {
throw new Error(`Color ${name} has secondBackgrounddefined, but background is not defined.`);
}
if (!background && contrastCurve) {
throw new Error(`Color ${name} has contrastCurvedefined, but background is not defined.`);
}
if (background && !contrastCurve) {
throw new Error(`Color ${name} has backgrounddefined, but contrastCurve is not defined.`);
}
}
/**
* Return a ARGB integer (i.e. a hex code).
*
* @param scheme Defines the conditions of the user interface, for example,
* whether or not it is dark mode or light mode, and what the desired
* contrast level is.
*/
getArgb(scheme) {
return this.getHct(scheme).toInt();
}
/**
* Return a color, expressed in the HCT color space, that this
* DynamicColor is under the conditions in scheme.
*
* @param scheme Defines the conditions of the user interface, for example,
* whether or not it is dark mode or light mode, and what the desired
* contrast level is.
*/
getHct(scheme) {
const cachedAnswer = this.hctCache.get(scheme);
if (cachedAnswer != null) {
return cachedAnswer;
}
const tone = this.getTone(scheme);
const answer = this.palette(scheme).getHct(tone);
if (this.hctCache.size > 4) {
this.hctCache.clear();
}
this.hctCache.set(scheme, answer);
return answer;
}
/**
* Return a tone, T in the HCT color space, that this DynamicColor is under
* the conditions in scheme.
*
* @param scheme Defines the conditions of the user interface, for example,
* whether or not it is dark mode or light mode, and what the desired
* contrast level is.
*/
getTone(scheme) {
const decreasingContrast = scheme.contrastLevel < 0;
if (this.toneDeltaPair) {
const toneDeltaPair = this.toneDeltaPair(scheme);
const roleA = toneDeltaPair.roleA;
const roleB = toneDeltaPair.roleB;
const delta = toneDeltaPair.delta;
const polarity = toneDeltaPair.polarity;
const stayTogether = toneDeltaPair.stayTogether;
const bg = this.background(scheme);
const bgTone = bg.getTone(scheme);
const aIsNearer = polarity === "nearer" || polarity === "lighter" && !scheme.isDark || polarity === "darker" && scheme.isDark;
const nearer = aIsNearer ? roleA : roleB;
const farther = aIsNearer ? roleB : roleA;
const amNearer = this.name === nearer.name;
const expansionDir = scheme.isDark ? 1 : -1;
const nContrast = nearer.contrastCurve.get(scheme.contrastLevel);
const fContrast = farther.contrastCurve.get(scheme.contrastLevel);
const nInitialTone = nearer.tone(scheme);
let nTone = Contrast.ratioOfTones(bgTone, nInitialTone) >= nContrast ? nInitialTone : DynamicColor.foregroundTone(bgTone, nContrast);
const fInitialTone = farther.tone(scheme);
let fTone = Contrast.ratioOfTones(bgTone, fInitialTone) >= fContrast ? fInitialTone : DynamicColor.foregroundTone(bgTone, fContrast);
if (decreasingContrast) {
nTone = DynamicColor.foregroundTone(bgTone, nContrast);
fTone = DynamicColor.foregroundTone(bgTone, fContrast);
}
if ((fTone - nTone) * expansionDir >= delta) ;
else {
fTone = clampDouble(0, 100, nTone + delta * expansionDir);
if ((fTone - nTone) * expansionDir >= delta) ;
else {
nTone = clampDouble(0, 100, fTone - delta * expansionDir);
}
}
if (50 <= nTone && nTone < 60) {
if (expansionDir > 0) {
nTone = 60;
fTone = Math.max(fTone, nTone + delta * expansionDir);
} else {
nTone = 49;
fTone = Math.min(fTone, nTone + delta * expansionDir);
}
} else if (50 <= fTone && fTone < 60) {
if (stayTogether) {
if (expansionDir > 0) {
nTone = 60;
fTone = Math.max(fTone, nTone + delta * expansionDir);
} else {
nTone = 49;
fTone = Math.min(fTone, nTone + delta * expansionDir);
}
} else {
if (expansionDir > 0) {
fTone = 60;
} else {
fTone = 49;
}
}
}
return amNearer ? nTone : fTone;
} else {
let answer = this.tone(scheme);
if (this.background == null) {
return answer;
}
const bgTone = this.background(scheme).getTone(scheme);
const desiredRatio = this.contrastCurve.get(scheme.contrastLevel);
if (Contrast.ratioOfTones(bgTone, answer) >= desiredRatio) ;
else {
answer = DynamicColor.foregroundTone(bgTone, desiredRatio);
}
if (decreasingContrast) {
answer = DynamicColor.foregroundTone(bgTone, desiredRatio);
}
if (this.isBackground && 50 <= answer && answer < 60) {
if (Contrast.ratioOfTones(49, bgTone) >= desiredRatio) {
answer = 49;
} else {
answer = 60;
}
}
if (this.secondBackground) {
const [bg1, bg2] = [this.background, this.secondBackground];
const [bgTone1, bgTone2] = [bg1(scheme).getTone(scheme), bg2(scheme).getTone(scheme)];
const [upper, lower] = [Math.max(bgTone1, bgTone2), Math.min(bgTone1, bgTone2)];
if (Contrast.ratioOfTones(upper, answer) >= desiredRatio && Contrast.ratioOfTones(lower, answer) >= desiredRatio) {
return answer;
}
const lightOption = Contrast.lighter(upper, desiredRatio);
const darkOption = Contrast.darker(lower, desiredRatio);
const availables = [];
if (lightOption !== -1)
availables.push(lightOption);
if (darkOption !== -1)
availables.push(darkOption);
const prefersLight = DynamicColor.tonePrefersLightForeground(bgTone1) || DynamicColor.tonePrefersLightForeground(bgTone2);
if (prefersLight) {
return lightOption < 0 ? 100 : lightOption;
}
if (availables.length === 1) {
return availables[0];
}
return darkOption < 0 ? 0 : darkOption;
}
return answer;
}
}
/**
* Given a background tone, find a foreground tone, while ensuring they reach
* a contrast ratio that is as close to [ratio] as possible.
*
* @param bgTone Tone in HCT. Range is 0 to 100, undefined behavior when it
* falls outside that range.
* @param ratio The contrast ratio desired between bgTone and the return
* value.
*/
static foregroundTone(bgTone, ratio) {
const lighterTone = Contrast.lighterUnsafe(bgTone, ratio);
const darkerTone = Contrast.darkerUnsafe(bgTone, ratio);
const lighterRatio = Contrast.ratioOfTones(lighterTone, bgTone);
const darkerRatio = Contrast.ratioOfTones(darkerTone, bgTone);
const preferLighter = DynamicColor.tonePrefersLightForeground(bgTone);
if (preferLighter) {
const negligibleDifference = Math.abs(lighterRatio - darkerRatio) < 0.1 && lighterRatio < ratio && darkerRatio < ratio;
return lighterRatio >= ratio || lighterRatio >= darkerRatio || negligibleDifference ? lighterTone : darkerTone;
} else {
return darkerRatio >= ratio || darkerRatio >= lighterRatio ? darkerTone : lighterTone;
}
}
/**
* Returns whether [tone] prefers a light foreground.
*
* People prefer white foregrounds on ~T60-70. Observed over time, and also
* by Andrew Somers during research for APCA.
*
* T60 used as to create the smallest discontinuity possible when skipping
* down to T49 in order to ensure light foregrounds.
* Since `tertiaryContainer` in dark monochrome scheme requires a tone of
* 60, it should not be adjusted. Therefore, 60 is excluded here.
*/
static tonePrefersLightForeground(tone) {
return Math.round(tone) < 60;
}
/**
* Returns whether [tone] can reach a contrast ratio of 4.5 with a lighter
* color.
*/
static toneAllowsLightForeground(tone) {
return Math.round(tone) <= 49;
}
/**
* Adjust a tone such that white has 4.5 contrast, if the tone is
* reasonably close to supporting it.
*/
static enableLightForeground(tone) {
if (DynamicColor.tonePrefersLightForeground(tone) && !DynamicColor.toneAllowsLightForeground(tone)) {
return 49;
}
return tone;
}
}
/**
* @license
* Copyright 2021 Google LLC
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
class TonalPalette {
/**
* @param argb ARGB representation of a color
* @return Tones matching that color's hue and chroma.
*/
static fromInt(argb) {
const hct = Hct.fromInt(argb);
return TonalPalette.fromHct(hct);
}
/**
* @param hct Hct
* @return Tones matching that color's hue and chroma.
*/
static fromHct(hct) {
return new TonalPalette(hct.hue, hct.chroma, hct);
}
/**
* @param hue HCT hue
* @param chroma HCT chroma
* @return Tones matching hue and chroma.
*/
static fromHueAndChroma(hue, chroma) {
const keyColor = new KeyColor(hue, chroma).create();
return new TonalPalette(hue, chroma, keyColor);
}
constructor(hue, chroma, keyColor) {
this.hue = hue;
this.chroma = chroma;
this.keyColor = keyColor;
this.cache = /* @__PURE__ */ new Map();
}
/**
* @param tone HCT tone, measured from 0 to 100.
* @return ARGB representation of a color with that tone.
*/
tone(tone) {
let argb = this.cache.get(tone);
if (argb === void 0) {
argb = Hct.from(this.hue, this.chroma, tone).toInt();
this.cache.set(tone, argb);
}
return argb;
}
/**
* @param tone HCT tone.
* @return HCT representation of a color with that tone.
*/
getHct(tone) {
return Hct.fromInt(this.tone(tone));
}
}
class KeyColor {
constructor(hue, requestedChroma) {
this.hue = hue;
this.requestedChroma = requestedChroma;
this.chromaCache = /* @__PURE__ */ new Map();
this.maxChromaValue = 200;
}
/**
* Creates a key color from a [hue] and a [chroma].
* The key color is the first tone, starting from T50, matching the given hue
* and chroma.
*
* @return Key color [Hct]
*/
create() {
const pivotTone = 50;
const toneStepSize = 1;
const epsilon = 0.01;
let lowerTone = 0;
let upperTone = 100;
while (lowerTone < upperTone) {
const midTone = Math.floor((lowerTone + upperTone) / 2);
const isAscending = this.maxChroma(midTone) < this.maxChroma(midTone + toneStepSize);
const sufficientChroma = this.maxChroma(midTone) >= this.requestedChroma - epsilon;
if (sufficientChroma) {
if (Math.abs(lowerTone - pivotTone) < Math.abs(upperTone - pivotTone)) {
upperTone = midTone;
} else {
if (lowerTone === midTone) {
return Hct.from(this.hue, this.requestedChroma, lowerTone);
}
lowerTone = midTone;
}
} else {
if (isAscending) {
lowerTone = midTone + toneStepSize;
} else {
upperTone = midTone;
}
}
}
return Hct.from(this.hue, this.requestedChroma, lowerTone);
}
// Find the maximum chroma for a given tone
maxChroma(tone) {
if (this.chromaCache.has(tone)) {
return this.chromaCache.get(tone);
}
const chroma = Hct.from(this.hue, this.maxChromaValue, tone).chroma;
this.chromaCache.set(tone, chroma);
return chroma;
}
}
/**
* @license
* Copyright 2023 Google LLC
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
class ContrastCurve {
/**
* Creates a `ContrastCurve` object.
*
* @param low Value for contrast level -1.0
* @param normal Value for contrast level 0.0
* @param medium Value for contrast level 0.5
* @param high Value for contrast level 1.0
*/
constructor(low, normal, medium, high) {
this.low = low;
this.normal = normal;
this.medium = medium;
this.high = high;
}
/**
* Returns the value at a given contrast level.
*
* @param contrastLevel The contrast level. 0.0 is the default (normal); -1.0
* is the lowest; 1.0 is the highest.
* @return The value. For contrast ratios, a number between 1.0 and 21.0.
*/
get(contrastLevel) {
if (contrastLevel <= -1) {
return this.low;
} else if (contrastLevel < 0) {
return lerp(this.low, this.normal, (contrastLevel - -1) / 1);
} else if (contrastLevel < 0.5) {
return lerp(this.normal, this.medium, (contrastLevel - 0) / 0.5);
} else if (contrastLevel < 1) {
return lerp(this.medium, this.high, (contrastLevel - 0.5) / 0.5);
} else {
return this.high;
}
}
}
/**
* @license
* Copyright 2023 Google LLC
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
class ToneDeltaPair {
/**
* Documents a constraint in tone distance between two DynamicColors.
*
* The polarity is an adjective that describes "A", compared to "B".
*
* For instance, ToneDeltaPair(A, B, 15, 'darker', stayTogether) states that
* A's tone should be at least 15 darker than B's.
*
* 'nearer' and 'farther' describes closeness to the surface roles. For
* instance, ToneDeltaPair(A, B, 10, 'nearer', stayTogether) states that A
* should be 10 lighter than B in light mode, and 10 darker than B in dark
* mode.
*
* @param roleA The first role in a pair.
* @param roleB The second role in a pair.
* @param delta Required difference between tones. Absolute value, negative
* values have undefined behavior.
* @param polarity The relative relation between tones of roleA and roleB,
* as described above.
* @param stayTogether Whether these two roles should stay on the same side of
* the "awkward zone" (T50-59). This is necessary for certain cases where
* one role has two backgrounds.
*/
constructor(roleA, roleB, delta, polarity, stayTogether) {
this.roleA = roleA;
this.roleB = roleB;
this.delta = delta;
this.polarity = polarity;
this.stayTogether = stayTogether;
}
}
/**
* @license
* Copyright 2022 Google LLC
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
var Variant;
(function(Variant2) {
Variant2[Variant2["MONOCHROME"] = 0] = "MONOCHROME";
Variant2[Variant2["NEUTRAL"] = 1] = "NEUTRAL";
Variant2[Variant2["TONAL_SPOT"] = 2] = "TONAL_SPOT";
Variant2[Variant2["VIBRANT"] = 3] = "VIBRANT";
Variant2[Variant2["EXPRESSIVE"] = 4] = "EXPRESSIVE";
Variant2[Variant2["FIDELITY"] = 5] = "FIDELITY";
Variant2[Variant2["CONTENT"] = 6] = "CONTENT";
Variant2[Variant2["RAINBOW"] = 7] = "RAINBOW";
Variant2[Variant2["FRUIT_SALAD"] = 8] = "FRUIT_SALAD";
})(Variant || (Variant = {}));
/**
* @license
* Copyright 2022 Google LLC
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
function isFidelity(scheme) {
return scheme.variant === Variant.FIDELITY || scheme.variant === Variant.CONTENT;
}
function isMonochrome(scheme) {
return scheme.variant === Variant.MONOCHROME;
}
function findDesiredChromaByTone(hue, chroma, tone, byDecreasingTone) {
let answer = tone;
let closestToChroma = Hct.from(hue, chroma, tone);
if (closestToChroma.chroma < chroma) {
let chromaPeak = closestToChroma.chroma;
while (closestToChroma.chroma < chroma) {
answer += byDecreasingTone ? -1 : 1;
const potentialSolution = Hct.from(hue, chroma, answer);
if (chromaPeak > potentialSolution.chroma) {
break;
}
if (Math.abs(potentialSolution.chroma - chroma) < 0.4) {
break;
}
const potentialDelta = Math.abs(potentialSolution.chroma - chroma);
const currentDelta = Math.abs(closestToChroma.chroma - chroma);
if (potentialDelta < currentDelta) {
closestToChroma = potentialSolution;
}
chromaPeak = Math.max(chromaPeak, potentialSolution.chroma);
}
}
return answer;
}
class MaterialDynamicColors {
static highestSurface(s3) {
return s3.isDark ? MaterialDynamicColors.surfaceBright : MaterialDynamicColors.surfaceDim;
}
}
MaterialDynamicColors.contentAccentToneDelta = 15;
MaterialDynamicColors.primaryPaletteKeyColor = DynamicColor.fromPalette({
name: "primary_palette_key_color",
palette: (s3) => s3.primaryPalette,
tone: (s3) => s3.primaryPalette.keyColor.tone
});
MaterialDynamicColors.secondaryPaletteKeyColor = DynamicColor.fromPalette({
name: "secondary_palette_key_color",
palette: (s3) => s3.secondaryPalette,
tone: (s3) => s3.secondaryPalette.keyColor.tone
});
MaterialDynamicColors.tertiaryPaletteKeyColor = DynamicColor.fromPalette({
name: "tertiary_palette_key_color",
palette: (s3) => s3.tertiaryPalette,
tone: (s3) => s3.tertiaryPalette.keyColor.tone
});
MaterialDynamicColors.neutralPaletteKeyColor = DynamicColor.fromPalette({
name: "neutral_palette_key_color",
palette: (s3) => s3.neutralPalette,
tone: (s3) => s3.neutralPalette.keyColor.tone
});
MaterialDynamicColors.neutralVariantPaletteKeyColor = DynamicColor.fromPalette({
name: "neutral_variant_palette_key_color",
palette: (s3) => s3.neutralVariantPalette,
tone: (s3) => s3.neutralVariantPalette.keyColor.tone
});
MaterialDynamicColors.background = DynamicColor.fromPalette({
name: "background",
palette: (s3) => s3.neutralPalette,
tone: (s3) => s3.isDark ? 6 : 98,
isBackground: true
});
MaterialDynamicColors.onBackground = DynamicColor.fromPalette({
name: "on_background",
palette: (s3) => s3.neutralPalette,
tone: (s3) => s3.isDark ? 90 : 10,
background: (s3) => MaterialDynamicColors.background,
contrastCurve: new ContrastCurve(3, 3, 4.5, 7)
});
MaterialDynamicColors.surface = DynamicColor.fromPalette({
name: "surface",
palette: (s3) => s3.neutralPalette,
tone: (s3) => s3.isDark ? 6 : 98,
isBackground: true
});
MaterialDynamicColors.surfaceDim = DynamicColor.fromPalette({
name: "surface_dim",
palette: (s3) => s3.neutralPalette,
tone: (s3) => s3.isDark ? 6 : new ContrastCurve(87, 87, 80, 75).get(s3.contrastLevel),
isBackground: true
});
MaterialDynamicColors.surfaceBright = DynamicColor.fromPalette({
name: "surface_bright",
palette: (s3) => s3.neutralPalette,
tone: (s3) => s3.isDark ? new ContrastCurve(24, 24, 29, 34).get(s3.contrastLevel) : 98,
isBackground: true
});
MaterialDynamicColors.surfaceContainerLowest = DynamicColor.fromPalette({
name: "surface_container_lowest",
palette: (s3) => s3.neutralPalette,
tone: (s3) => s3.isDark ? new ContrastCurve(4, 4, 2, 0).get(s3.contrastLevel) : 100,
isBackground: true
});
MaterialDynamicColors.surfaceContainerLow = DynamicColor.fromPalette({
name: "surface_container_low",
palette: (s3) => s3.neutralPalette,
tone: (s3) => s3.isDark ? new ContrastCurve(10, 10, 11, 12).get(s3.contrastLevel) : new ContrastCurve(96, 96, 96, 95).get(s3.contrastLevel),
isBackground: true
});
MaterialDynamicColors.surfaceContainer = DynamicColor.fromPalette({
name: "surface_container",
palette: (s3) => s3.neutralPalette,
tone: (s3) => s3.isDark ? new ContrastCurve(12, 12, 16, 20).get(s3.contrastLevel) : new ContrastCurve(94, 94, 92, 90).get(s3.contrastLevel),
isBackground: true
});
MaterialDynamicColors.surfaceContainerHigh = DynamicColor.fromPalette({
name: "surface_container_high",
palette: (s3) => s3.neutralPalette,
tone: (s3) => s3.isDark ? new ContrastCurve(17, 17, 21, 25).get(s3.contrastLevel) : new ContrastCurve(92, 92, 88, 85).get(s3.contrastLevel),
isBackground: true
});
MaterialDynamicColors.surfaceContainerHighest = DynamicColor.fromPalette({
name: "surface_container_highest",
palette: (s3) => s3.neutralPalette,
tone: (s3) => s3.isDark ? new ContrastCurve(22, 22, 26, 30).get(s3.contrastLevel) : new ContrastCurve(90, 90, 84, 80).get(s3.contrastLevel),
isBackground: true
});
MaterialDynamicColors.onSurface = DynamicColor.fromPalette({
name: "on_surface",
palette: (s3) => s3.neutralPalette,
tone: (s3) => s3.isDark ? 90 : 10,
background: (s3) => MaterialDynamicColors.highestSurface(s3),
contrastCurve: new ContrastCurve(4.5, 7, 11, 21)
});
MaterialDynamicColors.surfaceVariant = DynamicColor.fromPalette({
name: "surface_variant",
palette: (s3) => s3.neutralVariantPalette,
tone: (s3) => s3.isDark ? 30 : 90,
isBackground: true
});
MaterialDynamicColors.onSurfaceVariant = DynamicColor.fromPalette({
name: "on_surface_variant",
palette: (s3) => s3.neutralVariantPalette,
tone: (s3) => s3.isDark ? 80 : 30,
background: (s3) => MaterialDynamicColors.highestSurface(s3),
contrastCurve: new ContrastCurve(3, 4.5, 7, 11)
});
MaterialDynamicColors.inverseSurface = DynamicColor.fromPalette({
name: "inverse_surface",
palette: (s3) => s3.neutralPalette,
tone: (s3) => s3.isDark ? 90 : 20
});
MaterialDynamicColors.inverseOnSurface = DynamicColor.fromPalette({
name: "inverse_on_surface",
palette: (s3) => s3.neutralPalette,
tone: (s3) => s3.isDark ? 20 : 95,
background: (s3) => MaterialDynamicColors.inverseSurface,
contrastCurve: new ContrastCurve(4.5, 7, 11, 21)
});
MaterialDynamicColors.outline = DynamicColor.fromPalette({
name: "outline",
palette: (s3) => s3.neutralVariantPalette,
tone: (s3) => s3.isDark ? 60 : 50,
background: (s3) => MaterialDynamicColors.highestSurface(s3),
contrastCurve: new ContrastCurve(1.5, 3, 4.5, 7)
});
MaterialDynamicColors.outlineVariant = DynamicColor.fromPalette({
name: "outline_variant",
palette: (s3) => s3.neutralVariantPalette,
tone: (s3) => s3.isDark ? 30 : 80,
background: (s3) => MaterialDynamicColors.highestSurface(s3),
contrastCurve: new ContrastCurve(1, 1, 3, 4.5)
});
MaterialDynamicColors.shadow = DynamicColor.fromPalette({
name: "shadow",
palette: (s3) => s3.neutralPalette,
tone: (s3) => 0
});
MaterialDynamicColors.scrim = DynamicColor.fromPalette({
name: "scrim",
palette: (s3) => s3.neutralPalette,
tone: (s3) => 0
});
MaterialDynamicColors.surfaceTint = DynamicColor.fromPalette({
name: "surface_tint",
palette: (s3) => s3.primaryPalette,
tone: (s3) => s3.isDark ? 80 : 40,
isBackground: true
});
MaterialDynamicColors.primary = DynamicColor.fromPalette({
name: "primary",
palette: (s3) => s3.primaryPalette,
tone: (s3) => {
if (isMonochrome(s3)) {
return s3.isDark ? 100 : 0;
}
return s3.isDark ? 80 : 40;
},
isBackground: true,
background: (s3) => MaterialDynamicColors.highestSurface(s3),
contrastCurve: new ContrastCurve(3, 4.5, 7, 7),
toneDeltaPair: (s3) => new ToneDeltaPair(MaterialDynamicColors.primaryContainer, MaterialDynamicColors.primary, 10, "nearer", false)
});
MaterialDynamicColors.onPrimary = DynamicColor.fromPalette({
name: "on_primary",
palette: (s3) => s3.primaryPalette,
tone: (s3) => {
if (isMonochrome(s3)) {
return s3.isDark ? 10 : 90;
}
return s3.isDark ? 20 : 100;
},
background: (s3) => MaterialDynamicColors.primary,
contrastCurve: new ContrastCurve(4.5, 7, 11, 21)
});
MaterialDynamicColors.primaryContainer = DynamicColor.fromPalette({
name: "primary_container",
palette: (s3) => s3.primaryPalette,
tone: (s3) => {
if (isFidelity(s3)) {
return s3.sourceColorHct.tone;
}
if (isMonochrome(s3)) {
return s3.isDark ? 85 : 25;
}
return s3.isDark ? 30 : 90;
},
isBackground: true,
background: (s3) => MaterialDynamicColors.highestSurface(s3),
contrastCurve: new ContrastCurve(1, 1, 3, 4.5),
toneDeltaPair: (s3) => new ToneDeltaPair(MaterialDynamicColors.primaryContainer, MaterialDynamicColors.primary, 10, "nearer", false)
});
MaterialDynamicColors.onPrimaryContainer = DynamicColor.fromPalette({
name: "on_primary_container",
palette: (s3) => s3.primaryPalette,
tone: (s3) => {
if (isFidelity(s3)) {
return DynamicColor.foregroundTone(MaterialDynamicColors.primaryContainer.tone(s3), 4.5);
}
if (isMonochrome(s3)) {
return s3.isDark ? 0 : 100;
}
return s3.isDark ? 90 : 30;
},
background: (s3) => MaterialDynamicColors.primaryContainer,
contrastCurve: new ContrastCurve(3, 4.5, 7, 11)
});
MaterialDynamicColors.inversePrimary = DynamicColor.fromPalette({
name: "inverse_primary",
palette: (s3) => s3.primaryPalette,
tone: (s3) => s3.isDark ? 40 : 80,
background: (s3) => MaterialDynamicColors.inverseSurface,
contrastCurve: new ContrastCurve(3, 4.5, 7, 7)
});
MaterialDynamicColors.secondary = DynamicColor.fromPalette({
name: "secondary",
palette: (s3) => s3.secondaryPalette,
tone: (s3) => s3.isDark ? 80 : 40,
isBackground: true,
background: (s3) => MaterialDynamicColors.highestSurface(s3),
contrastCurve: new ContrastCurve(3, 4.5, 7, 7),
toneDeltaPair: (s3) => new ToneDeltaPair(MaterialDynamicColors.secondaryContainer, MaterialDynamicColors.secondary, 10, "nearer", false)
});
MaterialDynamicColors.onSecondary = DynamicColor.fromPalette({
name: "on_secondary",
palette: (s3) => s3.secondaryPalette,
tone: (s3) => {
if (isMonochrome(s3)) {
return s3.isDark ? 10 : 100;
} else {
return s3.isDark ? 20 : 100;
}
},
background: (s3) => MaterialDynamicColors.secondary,
contrastCurve: new ContrastCurve(4.5, 7, 11, 21)
});
MaterialDynamicColors.secondaryContainer = DynamicColor.fromPalette({
name: "secondary_container",
palette: (s3) => s3.secondaryPalette,
tone: (s3) => {
const initialTone = s3.isDark ? 30 : 90;
if (isMonochrome(s3)) {
return s3.isDark ? 30 : 85;
}
if (!isFidelity(s3)) {
return initialTone;
}
return findDesiredChromaByTone(s3.secondaryPalette.hue, s3.secondaryPalette.chroma, initialTone, s3.isDark ? false : true);
},
isBackground: true,
background: (s3) => MaterialDynamicColors.highestSurface(s3),
contrastCurve: new ContrastCurve(1, 1, 3, 4.5),
toneDeltaPair: (s3) => new ToneDeltaPair(MaterialDynamicColors.secondaryContainer, MaterialDynamicColors.secondary, 10, "nearer", false)
});
MaterialDynamicColors.onSecondaryContainer = DynamicColor.fromPalette({
name: "on_secondary_container",
palette: (s3) => s3.secondaryPalette,
tone: (s3) => {
if (isMonochrome(s3)) {
return s3.isDark ? 90 : 10;
}
if (!isFidelity(s3)) {
return s3.isDark ? 90 : 30;
}
return DynamicColor.foregroundTone(MaterialDynamicColors.secondaryContainer.tone(s3), 4.5);
},
background: (s3) => MaterialDynamicColors.secondaryContainer,
contrastCurve: new ContrastCurve(3, 4.5, 7, 11)
});
MaterialDynamicColors.tertiary = DynamicColor.fromPalette({
name: "tertiary",
palette: (s3) => s3.tertiaryPalette,
tone: (s3) => {
if (isMonochrome(s3)) {
return s3.isDark ? 90 : 25;
}
return s3.isDark ? 80 : 40;
},
isBackground: true,
background: (s3) => MaterialDynamicColors.highestSurface(s3),
contrastCurve: new ContrastCurve(3, 4.5, 7, 7),
toneDeltaPair: (s3) => new ToneDeltaPair(MaterialDynamicColors.tertiaryContainer, MaterialDynamicColors.tertiary, 10, "nearer", false)
});
MaterialDynamicColors.onTertiary = DynamicColor.fromPalette({
name: "on_tertiary",
palette: (s3) => s3.tertiaryPalette,
tone: (s3) => {
if (isMonochrome(s3)) {
return s3.isDark ? 10 : 90;
}
return s3.isDark ? 20 : 100;
},
background: (s3) => MaterialDynamicColors.tertiary,
contrastCurve: new ContrastCurve(4.5, 7, 11, 21)
});
MaterialDynamicColors.tertiaryContainer = DynamicColor.fromPalette({
name: "tertiary_container",
palette: (s3) => s3.tertiaryPalette,
tone: (s3) => {
if (isMonochrome(s3)) {
return s3.isDark ? 60 : 49;
}
if (!isFidelity(s3)) {
return s3.isDark ? 30 : 90;
}
const proposedHct = s3.tertiaryPalette.getHct(s3.sourceColorHct.tone);
return DislikeAnalyzer.fixIfDisliked(proposedHct).tone;
},
isBackground: true,
background: (s3) => MaterialDynamicColors.highestSurface(s3),
contrastCurve: new ContrastCurve(1, 1, 3, 4.5),
toneDeltaPair: (s3) => new ToneDeltaPair(MaterialDynamicColors.tertiaryContainer, MaterialDynamicColors.tertiary, 10, "nearer", false)
});
MaterialDynamicColors.onTertiaryContainer = DynamicColor.fromPalette({
name: "on_tertiary_container",
palette: (s3) => s3.tertiaryPalette,
tone: (s3) => {
if (isMonochrome(s3)) {
return s3.isDark ? 0 : 100;
}
if (!isFidelity(s3)) {
return s3.isDark ? 90 : 30;
}
return DynamicColor.foregroundTone(MaterialDynamicColors.tertiaryContainer.tone(s3), 4.5);
},
background: (s3) => MaterialDynamicColors.tertiaryContainer,
contrastCurve: new ContrastCurve(3, 4.5, 7, 11)
});
MaterialDynamicColors.error = DynamicColor.fromPalette({
name: "error",
palette: (s3) => s3.errorPalette,
tone: (s3) => s3.isDark ? 80 : 40,
isBackground: true,
background: (s3) => MaterialDynamicColors.highestSurface(s3),
contrastCurve: new ContrastCurve(3, 4.5, 7, 7),
toneDeltaPair: (s3) => new ToneDeltaPair(MaterialDynamicColors.errorContainer, MaterialDynamicColors.error, 10, "nearer", false)
});
MaterialDynamicColors.onError = DynamicColor.fromPalette({
name: "on_error",
palette: (s3) => s3.errorPalette,
tone: (s3) => s3.isDark ? 20 : 100,
background: (s3) => MaterialDynamicColors.error,
contrastCurve: new ContrastCurve(4.5, 7, 11, 21)
});
MaterialDynamicColors.errorContainer = DynamicColor.fromPalette({
name: "error_container",
palette: (s3) => s3.errorPalette,
tone: (s3) => s3.isDark ? 30 : 90,
isBackground: true,
background: (s3) => MaterialDynamicColors.highestSurface(s3),
contrastCurve: new ContrastCurve(1, 1, 3, 4.5),
toneDeltaPair: (s3) => new ToneDeltaPair(MaterialDynamicColors.errorContainer, MaterialDynamicColors.error, 10, "nearer", false)
});
MaterialDynamicColors.onErrorContainer = DynamicColor.fromPalette({
name: "on_error_container",
palette: (s3) => s3.errorPalette,
tone: (s3) => {
if (isMonochrome(s3)) {
return s3.isDark ? 90 : 10;
}
return s3.isDark ? 90 : 30;
},
background: (s3) => MaterialDynamicColors.errorContainer,
contrastCurve: new ContrastCurve(3, 4.5, 7, 11)
});
MaterialDynamicColors.primaryFixed = DynamicColor.fromPalette({
name: "primary_fixed",
palette: (s3) => s3.primaryPalette,
tone: (s3) => isMonochrome(s3) ? 40 : 90,
isBackground: true,
background: (s3) => MaterialDynamicColors.highestSurface(s3),
contrastCurve: new ContrastCurve(1, 1, 3, 4.5),
toneDeltaPair: (s3) => new ToneDeltaPair(MaterialDynamicColors.primaryFixed, MaterialDynamicColors.primaryFixedDim, 10, "lighter", true)
});
MaterialDynamicColors.primaryFixedDim = DynamicColor.fromPalette({
name: "primary_fixed_dim",
palette: (s3) => s3.primaryPalette,
tone: (s3) => isMonochrome(s3) ? 30 : 80,
isBackground: true,
background: (s3) => MaterialDynamicColors.highestSurface(s3),
contrastCurve: new ContrastCurve(1, 1, 3, 4.5),
toneDeltaPair: (s3) => new ToneDeltaPair(MaterialDynamicColors.primaryFixed, MaterialDynamicColors.primaryFixedDim, 10, "lighter", true)
});
MaterialDynamicColors.onPrimaryFixed = DynamicColor.fromPalette({
name: "on_primary_fixed",
palette: (s3) => s3.primaryPalette,
tone: (s3) => isMonochrome(s3) ? 100 : 10,
background: (s3) => MaterialDynamicColors.primaryFixedDim,
secondBackground: (s3) => MaterialDynamicColors.primaryFixed,
contrastCurve: new ContrastCurve(4.5, 7, 11, 21)
});
MaterialDynamicColors.onPrimaryFixedVariant = DynamicColor.fromPalette({
name: "on_primary_fixed_variant",
palette: (s3) => s3.primaryPalette,
tone: (s3) => isMonochrome(s3) ? 90 : 30,
background: (s3) => MaterialDynamicColors.primaryFixedDim,
secondBackground: (s3) => MaterialDynamicColors.primaryFixed,
contrastCurve: new ContrastCurve(3, 4.5, 7, 11)
});
MaterialDynamicColors.secondaryFixed = DynamicColor.fromPalette({
name: "secondary_fixed",
palette: (s3) => s3.secondaryPalette,
tone: (s3) => isMonochrome(s3) ? 80 : 90,
isBackground: true,
background: (s3) => MaterialDynamicColors.highestSurface(s3),
contrastCurve: new ContrastCurve(1, 1, 3, 4.5),
toneDeltaPair: (s3) => new ToneDeltaPair(MaterialDynamicColors.secondaryFixed, MaterialDynamicColors.secondaryFixedDim, 10, "lighter", true)
});
MaterialDynamicColors.secondaryFixedDim = DynamicColor.fromPalette({
name: "secondary_fixed_dim",
palette: (s3) => s3.secondaryPalette,
tone: (s3) => isMonochrome(s3) ? 70 : 80,
isBackground: true,
background: (s3) => MaterialDynamicColors.highestSurface(s3),
contrastCurve: new ContrastCurve(1, 1, 3, 4.5),
toneDeltaPair: (s3) => new ToneDeltaPair(MaterialDynamicColors.secondaryFixed, MaterialDynamicColors.secondaryFixedDim, 10, "lighter", true)
});
MaterialDynamicColors.onSecondaryFixed = DynamicColor.fromPalette({
name: "on_secondary_fixed",
palette: (s3) => s3.secondaryPalette,
tone: (s3) => 10,
background: (s3) => MaterialDynamicColors.secondaryFixedDim,
secondBackground: (s3) => MaterialDynamicColors.secondaryFixed,
contrastCurve: new ContrastCurve(4.5, 7, 11, 21)
});
MaterialDynamicColors.onSecondaryFixedVariant = DynamicColor.fromPalette({
name: "on_secondary_fixed_variant",
palette: (s3) => s3.secondaryPalette,
tone: (s3) => isMonochrome(s3) ? 25 : 30,
background: (s3) => MaterialDynamicColors.secondaryFixedDim,
secondBackground: (s3) => MaterialDynamicColors.secondaryFixed,
contrastCurve: new ContrastCurve(3, 4.5, 7, 11)
});
MaterialDynamicColors.tertiaryFixed = DynamicColor.fromPalette({
name: "tertiary_fixed",
palette: (s3) => s3.tertiaryPalette,
tone: (s3) => isMonochrome(s3) ? 40 : 90,
isBackground: true,
background: (s3) => MaterialDynamicColors.highestSurface(s3),
contrastCurve: new ContrastCurve(1, 1, 3, 4.5),
toneDeltaPair: (s3) => new ToneDeltaPair(MaterialDynamicColors.tertiaryFixed, MaterialDynamicColors.tertiaryFixedDim, 10, "lighter", true)
});
MaterialDynamicColors.tertiaryFixedDim = DynamicColor.fromPalette({
name: "tertiary_fixed_dim",
palette: (s3) => s3.tertiaryPalette,
tone: (s3) => isMonochrome(s3) ? 30 : 80,
isBackground: true,
background: (s3) => MaterialDynamicColors.highestSurface(s3),
contrastCurve: new ContrastCurve(1, 1, 3, 4.5),
toneDeltaPair: (s3) => new ToneDeltaPair(MaterialDynamicColors.tertiaryFixed, MaterialDynamicColors.tertiaryFixedDim, 10, "lighter", true)
});
MaterialDynamicColors.onTertiaryFixed = DynamicColor.fromPalette({
name: "on_tertiary_fixed",
palette: (s3) => s3.tertiaryPalette,
tone: (s3) => isMonochrome(s3) ? 100 : 10,
background: (s3) => MaterialDynamicColors.tertiaryFixedDim,
secondBackground: (s3) => MaterialDynamicColors.tertiaryFixed,
contrastCurve: new ContrastCurve(4.5, 7, 11, 21)
});
MaterialDynamicColors.onTertiaryFixedVariant = DynamicColor.fromPalette({
name: "on_tertiary_fixed_variant",
palette: (s3) => s3.tertiaryPalette,
tone: (s3) => isMonochrome(s3) ? 90 : 30,
background: (s3) => MaterialDynamicColors.tertiaryFixedDim,
secondBackground: (s3) => MaterialDynamicColors.tertiaryFixed,
contrastCurve: new ContrastCurve(3, 4.5, 7, 11)
});
/**
* @license
* Copyright 2021 Google LLC
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
class CorePalette {
/**
* @param argb ARGB representation of a color
*/
static of(argb) {
return new CorePalette(argb, false);
}
/**
* @param argb ARGB representation of a color
*/
static contentOf(argb) {
return new CorePalette(argb, true);
}
/**
* Create a [CorePalette] from a set of colors
*/
static fromColors(colors) {
return CorePalette.createPaletteFromColors(false, colors);
}
/**
* Create a content [CorePalette] from a set of colors
*/
static contentFromColors(colors) {
return CorePalette.createPaletteFromColors(true, colors);
}
static createPaletteFromColors(content, colors) {
const palette = new CorePalette(colors.primary, content);
if (colors.secondary) {
const p2 = new CorePalette(colors.secondary, content);
palette.a2 = p2.a1;
}
if (colors.tertiary) {
const p2 = new CorePalette(colors.tertiary, content);
palette.a3 = p2.a1;
}
if (colors.error) {
const p2 = new CorePalette(colors.error, content);
palette.error = p2.a1;
}
if (colors.neutral) {
const p2 = new CorePalette(colors.neutral, content);
palette.n1 = p2.n1;
}
if (colors.neutralVariant) {
const p2 = new CorePalette(colors.neutralVariant, content);
palette.n2 = p2.n2;
}
return palette;
}
constructor(argb, isContent) {
const hct = Hct.fromInt(argb);
const hue = hct.hue;
const chroma = hct.chroma;
if (isContent) {
this.a1 = TonalPalette.fromHueAndChroma(hue, chroma);
this.a2 = TonalPalette.fromHueAndChroma(hue, chroma / 3);
this.a3 = TonalPalette.fromHueAndChroma(hue + 60, chroma / 2);
this.n1 = TonalPalette.fromHueAndChroma(hue, Math.min(chroma / 12, 4));
this.n2 = TonalPalette.fromHueAndChroma(hue, Math.min(chroma / 6, 8));
} else {
this.a1 = TonalPalette.fromHueAndChroma(hue, Math.max(48, chroma));
this.a2 = TonalPalette.fromHueAndChroma(hue, 16);
this.a3 = TonalPalette.fromHueAndChroma(hue + 60, 24);
this.n1 = TonalPalette.fromHueAndChroma(hue, 4);
this.n2 = TonalPalette.fromHueAndChroma(hue, 8);
}
this.error = TonalPalette.fromHueAndChroma(25, 84);
}
}
/**
* @license
* Copyright 2021 Google LLC
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
class Scheme {
get primary() {
return this.props.primary;
}
get onPrimary() {
return this.props.onPrimary;
}
get primaryContainer() {
return this.props.primaryContainer;
}
get onPrimaryContainer() {
return this.props.onPrimaryContainer;
}
get secondary() {
return this.props.secondary;
}
get onSecondary() {
return this.props.onSecondary;
}
get secondaryContainer() {
return this.props.secondaryContainer;
}
get onSecondaryContainer() {
return this.props.onSecondaryContainer;
}
get tertiary() {
return this.props.tertiary;
}
get onTertiary() {
return this.props.onTertiary;
}
get tertiaryContainer() {
return this.props.tertiaryContainer;
}
get onTertiaryContainer() {
return this.props.onTertiaryContainer;
}
get error() {
return this.props.error;
}
get onError() {
return this.props.onError;
}
get errorContainer() {
return this.props.errorContainer;
}
get onErrorContainer() {
return this.props.onErrorContainer;
}
get background() {
return this.props.background;
}
get onBackground() {
return this.props.onBackground;
}
get surface() {
return this.props.surface;
}
get onSurface() {
return this.props.onSurface;
}
get surfaceVariant() {
return this.props.surfaceVariant;
}
get onSurfaceVariant() {
return this.props.onSurfaceVariant;
}
get outline() {
return this.props.outline;
}
get outlineVariant() {
return this.props.outlineVariant;
}
get shadow() {
return this.props.shadow;
}
get scrim() {
return this.props.scrim;
}
get inverseSurface() {
return this.props.inverseSurface;
}
get inverseOnSurface() {
return this.props.inverseOnSurface;
}
get inversePrimary() {
return this.props.inversePrimary;
}
/**
* @param argb ARGB representation of a color.
* @return Light Material color scheme, based on the color's hue.
*/
static light(argb) {
return Scheme.lightFromCorePalette(CorePalette.of(argb));
}
/**
* @param argb ARGB representation of a color.
* @return Dark Material color scheme, based on the color's hue.
*/
static dark(argb) {
return Scheme.darkFromCorePalette(CorePalette.of(argb));
}
/**
* @param argb ARGB representation of a color.
* @return Light Material content color scheme, based on the color's hue.
*/
static lightContent(argb) {
return Scheme.lightFromCorePalette(CorePalette.contentOf(argb));
}
/**
* @param argb ARGB representation of a color.
* @return Dark Material content color scheme, based on the color's hue.
*/
static darkContent(argb) {
return Scheme.darkFromCorePalette(CorePalette.contentOf(argb));
}
/**
* Light scheme from core palette
*/
static lightFromCorePalette(core) {
return new Scheme({
primary: core.a1.tone(40),
onPrimary: core.a1.tone(100),
primaryContainer: core.a1.tone(90),
onPrimaryContainer: core.a1.tone(10),
secondary: core.a2.tone(40),
onSecondary: core.a2.tone(100),
secondaryContainer: core.a2.tone(90),
onSecondaryContainer: core.a2.tone(10),
tertiary: core.a3.tone(40),
onTertiary: core.a3.tone(100),
tertiaryContainer: core.a3.tone(90),
onTertiaryContainer: core.a3.tone(10),
error: core.error.tone(40),
onError: core.error.tone(100),
errorContainer: core.error.tone(90),
onErrorContainer: core.error.tone(10),
background: core.n1.tone(99),
onBackground: core.n1.tone(10),
surface: core.n1.tone(99),
onSurface: core.n1.tone(10),
surfaceVariant: core.n2.tone(90),
onSurfaceVariant: core.n2.tone(30),
outline: core.n2.tone(50),
outlineVariant: core.n2.tone(80),
shadow: core.n1.tone(0),
scrim: core.n1.tone(0),
inverseSurface: core.n1.tone(20),
inverseOnSurface: core.n1.tone(95),
inversePrimary: core.a1.tone(80)
});
}
/**
* Dark scheme from core palette
*/
static darkFromCorePalette(core) {
return new Scheme({
primary: core.a1.tone(80),
onPrimary: core.a1.tone(20),
primaryContainer: core.a1.tone(30),
onPrimaryContainer: core.a1.tone(90),
secondary: core.a2.tone(80),
onSecondary: core.a2.tone(20),
secondaryContainer: core.a2.tone(30),
onSecondaryContainer: core.a2.tone(90),
tertiary: core.a3.tone(80),
onTertiary: core.a3.tone(20),
tertiaryContainer: core.a3.tone(30),
onTertiaryContainer: core.a3.tone(90),
error: core.error.tone(80),
onError: core.error.tone(20),
errorContainer: core.error.tone(30),
onErrorContainer: core.error.tone(80),
background: core.n1.tone(10),
onBackground: core.n1.tone(90),
surface: core.n1.tone(10),
onSurface: core.n1.tone(90),
surfaceVariant: core.n2.tone(30),
onSurfaceVariant: core.n2.tone(80),
outline: core.n2.tone(60),
outlineVariant: core.n2.tone(30),
shadow: core.n1.tone(0),
scrim: core.n1.tone(0),
inverseSurface: core.n1.tone(90),
inverseOnSurface: core.n1.tone(20),
inversePrimary: core.a1.tone(40)
});
}
constructor(props) {
this.props = props;
}
toJSON() {
return {
...this.props
};
}
}
/**
* @license
* Copyright 2021 Google LLC
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
function argbFromHex(hex) {
hex = hex.replace("#", "");
const isThree = hex.length === 3;
const isSix = hex.length === 6;
const isEight = hex.length === 8;
if (!isThree && !isSix && !isEight) {
throw new Error("unexpected hex " + hex);
}
let r3 = 0;
let g2 = 0;
let b3 = 0;
if (isThree) {
r3 = parseIntHex(hex.slice(0, 1).repeat(2));
g2 = parseIntHex(hex.slice(1, 2).repeat(2));
b3 = parseIntHex(hex.slice(2, 3).repeat(2));
} else if (isSix) {
r3 = parseIntHex(hex.slice(0, 2));
g2 = parseIntHex(hex.slice(2, 4));
b3 = parseIntHex(hex.slice(4, 6));
} else if (isEight) {
r3 = parseIntHex(hex.slice(2, 4));
g2 = parseIntHex(hex.slice(4, 6));
b3 = parseIntHex(hex.slice(6, 8));
}
return (255 << 24 | (r3 & 255) << 16 | (g2 & 255) << 8 | b3 & 255) >>> 0;
}
function parseIntHex(value) {
return parseInt(value, 16);
}
/**
* @license
* Copyright 2021 Google LLC
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
function customColor(source2, color) {
let value = color.value;
const from = value;
const to = source2;
if (color.blend) {
value = Blend.harmonize(from, to);
}
const palette = CorePalette.of(value);
const tones = palette.a1;
return {
color,
value,
light: {
color: tones.tone(40),
onColor: tones.tone(100),
colorContainer: tones.tone(90),
onColorContainer: tones.tone(10)
},
dark: {
color: tones.tone(80),
onColor: tones.tone(20),
colorContainer: tones.tone(30),
onColorContainer: tones.tone(90)
}
};
}
const getConfirmText = () => {
return msg("OK");
};
const getCancelText = () => {
return msg("Cancel");
};
const prompt = (options) => {
const mergedOptions = Object.assign({}, {
confirmText: getConfirmText(),
cancelText: getCancelText(),
onConfirm: returnTrue,
onCancel: returnTrue,
validator: returnTrue,
textFieldOptions: {}
}, options);
const properties = [
"headline",
"description",
"icon",
"closeOnEsc",
"closeOnOverlayClick",
"stackedActions",
"queue",
"onOpen",
"onOpened",
"onClose",
"onClosed",
"onOverlayClick"
];
const textField = new TextField();
Object.entries(mergedOptions.textFieldOptions).forEach(([key2, value]) => {
textField[key2] = value;
});
return new Promise((resolve, reject) => {
let isResolve = false;
const dialog$1 = dialog({
...Object.fromEntries(properties.filter((key2) => !isUndefined(mergedOptions[key2])).map((key2) => [key2, mergedOptions[key2]])),
body: textField,
actions: [
{
text: mergedOptions.cancelText,
onClick: (dialog2) => {
return mergedOptions.onCancel.call(dialog2, textField.value, dialog2);
}
},
{
text: mergedOptions.confirmText,
onClick: (dialog2) => {
const onConfirm = () => {
const clickResult = mergedOptions.onConfirm.call(dialog2, textField.value, dialog2);
if (isPromise(clickResult)) {
clickResult.then(() => {
isResolve = true;
});
} else if (clickResult !== false) {
isResolve = true;
}
return clickResult;
};
textField.setCustomValidity("");
if (!textField.reportValidity()) {
return false;
}
const validateResult = mergedOptions.validator.call(textField, textField.value);
if (isBoolean(validateResult) && !validateResult) {
textField.setCustomValidity(" ");
return false;
}
if (isString(validateResult)) {
textField.setCustomValidity(validateResult);
return false;
}
if (isPromise(validateResult)) {
return new Promise((resolve2, reject2) => {
validateResult.then(resolve2).catch((reason) => {
textField.setCustomValidity(reason);
reject2(reason);
});
});
}
return onConfirm();
}
}
]
});
if (!options.confirmText) {
onLocaleReady(dialog$1, () => {
$$1(dialog$1).find('[slot="action"]').last().text(getConfirmText());
});
}
if (!options.cancelText) {
onLocaleReady(dialog$1, () => {
$$1(dialog$1).find('[slot="action"]').first().text(getCancelText());
});
}
$$1(dialog$1).on("close", (e3) => {
if (e3.target === dialog$1) {
isResolve ? resolve(textField.value) : reject();
offLocaleReady(dialog$1);
}
});
});
};
const themeArr = ["light", "dark"];
const prefix = "mdui-custom-color-scheme-";
let themeIndex = 0;
const rgbFromArgb = (source2) => {
const red = redFromArgb(source2);
const green = greenFromArgb(source2);
const blue = blueFromArgb(source2);
return [red, green, blue].join(", ");
};
const remove = (target) => {
const $target = $$1(target);
let classNames = $target.get().map((element) => Array.from(element.classList)).flat();
classNames = unique(classNames).filter((className2) => className2.startsWith(prefix));
$target.removeClass(classNames.join(" "));
const unusedClassNames = classNames.filter((className2) => $$1(`.${className2}`).length === 0);
$$1(unusedClassNames.map((i3) => `#${i3}`).join(",")).remove();
};
const setFromSource = (source2, options) => {
const document2 = getDocument();
const $target = $$1(document2.documentElement);
const schemes = {
light: Scheme.light(source2).toJSON(),
dark: Scheme.dark(source2).toJSON()
};
const palette = CorePalette.of(source2);
Object.assign(schemes.light, {
"surface-dim": palette.n1.tone(87),
"surface-bright": palette.n1.tone(98),
"surface-container-lowest": palette.n1.tone(100),
"surface-container-low": palette.n1.tone(96),
"surface-container": palette.n1.tone(94),
"surface-container-high": palette.n1.tone(92),
"surface-container-highest": palette.n1.tone(90),
"surface-tint-color": schemes.light.primary
});
Object.assign(schemes.dark, {
"surface-dim": palette.n1.tone(6),
"surface-bright": palette.n1.tone(24),
"surface-container-lowest": palette.n1.tone(4),
"surface-container-low": palette.n1.tone(10),
"surface-container": palette.n1.tone(12),
"surface-container-high": palette.n1.tone(17),
"surface-container-highest": palette.n1.tone(22),
"surface-tint-color": schemes.dark.primary
});
[].map((color) => {
const name = toKebabCase(color.name);
const custom = customColor(source2, {
name,
value: argbFromHex(color.value),
blend: true
});
themeArr.forEach((theme) => {
schemes[theme][name] = custom[theme].color;
schemes[theme][`on-${name}`] = custom[theme].onColor;
schemes[theme][`${name}-container`] = custom[theme].colorContainer;
schemes[theme][`on-${name}-container`] = custom[theme].onColorContainer;
});
});
const colorVar = (theme, callback) => {
return Object.entries(schemes[theme]).map(([key2, value]) => callback(toKebabCase(key2), rgbFromArgb(value))).join("");
};
const className2 = prefix + `${source2}-${themeIndex++}`;
const cssText = `.${className2} {
${colorVar("light", (token2, rgb) => `--mdui-color-${token2}-light: ${rgb};`)}
${colorVar("dark", (token2, rgb) => `--mdui-color-${token2}-dark: ${rgb};`)}
${colorVar("light", (token2) => `--mdui-color-${token2}: var(--mdui-color-${token2}-light);`)}
color: rgb(var(--mdui-color-on-background));
background-color: rgb(var(--mdui-color-background));
}
.mdui-theme-dark .${className2},
.mdui-theme-dark.${className2} {
${colorVar("dark", (token2) => `--mdui-color-${token2}: var(--mdui-color-${token2}-dark);`)}
}
@media (prefers-color-scheme: dark) {
.mdui-theme-auto .${className2},
.mdui-theme-auto.${className2} {
${colorVar("dark", (token2) => `--mdui-color-${token2}: var(--mdui-color-${token2}-dark);`)}
}
}`;
remove($target);
$$1(document2.head).append(`<style id="${className2}">${cssText}</style>`);
$target.addClass(className2);
};
const setColorScheme = (hex, options) => {
const source2 = argbFromHex(hex);
setFromSource(source2);
};
const queueName = "mdui.functions.snackbar.";
let currentSnackbar = void 0;
const snackbar = (options) => {
const snackbar2 = new Snackbar();
const $snackbar = $$1(snackbar2);
Object.entries(options).forEach(([key2, value]) => {
if (key2 === "message") {
snackbar2.innerHTML = value;
} else if ([
"onClick",
"onActionClick",
"onOpen",
"onOpened",
"onClose",
"onClosed"
].includes(key2)) {
const eventName = toKebabCase(key2.slice(2));
$snackbar.on(eventName, (e3) => {
if (e3.target !== snackbar2) {
return;
}
if (key2 === "onActionClick") {
const actionClick = (options.onActionClick ?? returnTrue).call(snackbar2, snackbar2);
if (isPromise(actionClick)) {
snackbar2.actionLoading = true;
actionClick.then(() => {
snackbar2.open = false;
}).finally(() => {
snackbar2.actionLoading = false;
});
} else if (actionClick !== false) {
snackbar2.open = false;
}
} else {
value.call(snackbar2, snackbar2);
}
});
} else {
snackbar2[key2] = value;
}
});
$snackbar.appendTo("body").on("closed", (e3) => {
if (e3.target !== snackbar2) {
return;
}
$snackbar.remove();
if (options.queue) {
currentSnackbar = void 0;
dequeue(queueName + options.queue);
}
});
if (!options.queue) {
setTimeout(() => {
snackbar2.open = true;
});
} else if (currentSnackbar) {
queue(queueName + options.queue, () => {
snackbar2.open = true;
currentSnackbar = snackbar2;
});
} else {
setTimeout(() => {
snackbar2.open = true;
});
currentSnackbar = snackbar2;
}
return snackbar2;
};
var commonjsGlobal = typeof globalThis !== "undefined" ? globalThis : typeof window !== "undefined" ? window : typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : {};
function getDefaultExportFromCjs(x2) {
return x2 && x2.__esModule && Object.prototype.hasOwnProperty.call(x2, "default") ? x2["default"] : x2;
}
function commonjsRequire(path) {
throw new Error('Could not dynamically require "' + path + '". Please configure the dynamicRequireTargets or/and ignoreDynamicRequires option of @rollup/plugin-commonjs appropriately for this require call to work.');
}
var localforage$1 = { exports: {} };
/*!
localForage -- Offline Storage, Improved
Version 1.10.0
https://localforage.github.io/localForage
(c) 2013-2017 Mozilla, Apache License 2.0
*/
(function(module, exports) {
(function(f3) {
{
module.exports = f3();
}
})(function() {
return function e3(t3, n3, r3) {
function s3(o3, u2) {
if (!n3[o3]) {
if (!t3[o3]) {
var a2 = typeof commonjsRequire == "function" && commonjsRequire;
if (!u2 && a2) return a2(o3, true);
if (i3) return i3(o3, true);
var f3 = new Error("Cannot find module '" + o3 + "'");
throw f3.code = "MODULE_NOT_FOUND", f3;
}
var l2 = n3[o3] = { exports: {} };
t3[o3][0].call(l2.exports, function(e4) {
var n4 = t3[o3][1][e4];
return s3(n4 ? n4 : e4);
}, l2, l2.exports, e3, t3, n3, r3);
}
return n3[o3].exports;
}
var i3 = typeof commonjsRequire == "function" && commonjsRequire;
for (var o2 = 0; o2 < r3.length; o2++) s3(r3[o2]);
return s3;
}({ 1: [function(_dereq_, module2, exports2) {
(function(global2) {
var Mutation = global2.MutationObserver || global2.WebKitMutationObserver;
var scheduleDrain;
{
if (Mutation) {
var called = 0;
var observer2 = new Mutation(nextTick);
var element = global2.document.createTextNode("");
observer2.observe(element, {
characterData: true
});
scheduleDrain = function() {
element.data = called = ++called % 2;
};
} else if (!global2.setImmediate && typeof global2.MessageChannel !== "undefined") {
var channel = new global2.MessageChannel();
channel.port1.onmessage = nextTick;
scheduleDrain = function() {
channel.port2.postMessage(0);
};
} else if ("document" in global2 && "onreadystatechange" in global2.document.createElement("script")) {
scheduleDrain = function() {
var scriptEl = global2.document.createElement("script");
scriptEl.onreadystatechange = function() {
nextTick();
scriptEl.onreadystatechange = null;
scriptEl.parentNode.removeChild(scriptEl);
scriptEl = null;
};
global2.document.documentElement.appendChild(scriptEl);
};
} else {
scheduleDrain = function() {
setTimeout(nextTick, 0);
};
}
}
var draining;
var queue2 = [];
function nextTick() {
draining = true;
var i3, oldQueue;
var len = queue2.length;
while (len) {
oldQueue = queue2;
queue2 = [];
i3 = -1;
while (++i3 < len) {
oldQueue[i3]();
}
len = queue2.length;
}
draining = false;
}
module2.exports = immediate;
function immediate(task) {
if (queue2.push(task) === 1 && !draining) {
scheduleDrain();
}
}
}).call(this, typeof commonjsGlobal !== "undefined" ? commonjsGlobal : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {});
}, {}], 2: [function(_dereq_, module2, exports2) {
var immediate = _dereq_(1);
function INTERNAL() {
}
var handlers = {};
var REJECTED = ["REJECTED"];
var FULFILLED = ["FULFILLED"];
var PENDING = ["PENDING"];
module2.exports = Promise2;
function Promise2(resolver) {
if (typeof resolver !== "function") {
throw new TypeError("resolver must be a function");
}
this.state = PENDING;
this.queue = [];
this.outcome = void 0;
if (resolver !== INTERNAL) {
safelyResolveThenable(this, resolver);
}
}
Promise2.prototype["catch"] = function(onRejected) {
return this.then(null, onRejected);
};
Promise2.prototype.then = function(onFulfilled, onRejected) {
if (typeof onFulfilled !== "function" && this.state === FULFILLED || typeof onRejected !== "function" && this.state === REJECTED) {
return this;
}
var promise = new this.constructor(INTERNAL);
if (this.state !== PENDING) {
var resolver = this.state === FULFILLED ? onFulfilled : onRejected;
unwrap(promise, resolver, this.outcome);
} else {
this.queue.push(new QueueItem(promise, onFulfilled, onRejected));
}
return promise;
};
function QueueItem(promise, onFulfilled, onRejected) {
this.promise = promise;
if (typeof onFulfilled === "function") {
this.onFulfilled = onFulfilled;
this.callFulfilled = this.otherCallFulfilled;
}
if (typeof onRejected === "function") {
this.onRejected = onRejected;
this.callRejected = this.otherCallRejected;
}
}
QueueItem.prototype.callFulfilled = function(value) {
handlers.resolve(this.promise, value);
};
QueueItem.prototype.otherCallFulfilled = function(value) {
unwrap(this.promise, this.onFulfilled, value);
};
QueueItem.prototype.callRejected = function(value) {
handlers.reject(this.promise, value);
};
QueueItem.prototype.otherCallRejected = function(value) {
unwrap(this.promise, this.onRejected, value);
};
function unwrap(promise, func, value) {
immediate(function() {
var returnValue;
try {
returnValue = func(value);
} catch (e3) {
return handlers.reject(promise, e3);
}
if (returnValue === promise) {
handlers.reject(promise, new TypeError("Cannot resolve promise with itself"));
} else {
handlers.resolve(promise, returnValue);
}
});
}
handlers.resolve = function(self2, value) {
var result = tryCatch(getThen, value);
if (result.status === "error") {
return handlers.reject(self2, result.value);
}
var thenable = result.value;
if (thenable) {
safelyResolveThenable(self2, thenable);
} else {
self2.state = FULFILLED;
self2.outcome = value;
var i3 = -1;
var len = self2.queue.length;
while (++i3 < len) {
self2.queue[i3].callFulfilled(value);
}
}
return self2;
};
handlers.reject = function(self2, error) {
self2.state = REJECTED;
self2.outcome = error;
var i3 = -1;
var len = self2.queue.length;
while (++i3 < len) {
self2.queue[i3].callRejected(error);
}
return self2;
};
function getThen(obj) {
var then = obj && obj.then;
if (obj && (typeof obj === "object" || typeof obj === "function") && typeof then === "function") {
return function appyThen() {
then.apply(obj, arguments);
};
}
}
function safelyResolveThenable(self2, thenable) {
var called = false;
function onError(value) {
if (called) {
return;
}
called = true;
handlers.reject(self2, value);
}
function onSuccess(value) {
if (called) {
return;
}
called = true;
handlers.resolve(self2, value);
}
function tryToUnwrap() {
thenable(onSuccess, onError);
}
var result = tryCatch(tryToUnwrap);
if (result.status === "error") {
onError(result.value);
}
}
function tryCatch(func, value) {
var out = {};
try {
out.value = func(value);
out.status = "success";
} catch (e3) {
out.status = "error";
out.value = e3;
}
return out;
}
Promise2.resolve = resolve;
function resolve(value) {
if (value instanceof this) {
return value;
}
return handlers.resolve(new this(INTERNAL), value);
}
Promise2.reject = reject;
function reject(reason) {
var promise = new this(INTERNAL);
return handlers.reject(promise, reason);
}
Promise2.all = all;
function all(iterable) {
var self2 = this;
if (Object.prototype.toString.call(iterable) !== "[object Array]") {
return this.reject(new TypeError("must be an array"));
}
var len = iterable.length;
var called = false;
if (!len) {
return this.resolve([]);
}
var values = new Array(len);
var resolved = 0;
var i3 = -1;
var promise = new this(INTERNAL);
while (++i3 < len) {
allResolver(iterable[i3], i3);
}
return promise;
function allResolver(value, i4) {
self2.resolve(value).then(resolveFromAll, function(error) {
if (!called) {
called = true;
handlers.reject(promise, error);
}
});
function resolveFromAll(outValue) {
values[i4] = outValue;
if (++resolved === len && !called) {
called = true;
handlers.resolve(promise, values);
}
}
}
}
Promise2.race = race;
function race(iterable) {
var self2 = this;
if (Object.prototype.toString.call(iterable) !== "[object Array]") {
return this.reject(new TypeError("must be an array"));
}
var len = iterable.length;
var called = false;
if (!len) {
return this.resolve([]);
}
var i3 = -1;
var promise = new this(INTERNAL);
while (++i3 < len) {
resolver(iterable[i3]);
}
return promise;
function resolver(value) {
self2.resolve(value).then(function(response) {
if (!called) {
called = true;
handlers.resolve(promise, response);
}
}, function(error) {
if (!called) {
called = true;
handlers.reject(promise, error);
}
});
}
}
}, { "1": 1 }], 3: [function(_dereq_, module2, exports2) {
(function(global2) {
if (typeof global2.Promise !== "function") {
global2.Promise = _dereq_(2);
}
}).call(this, typeof commonjsGlobal !== "undefined" ? commonjsGlobal : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {});
}, { "2": 2 }], 4: [function(_dereq_, module2, exports2) {
var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function(obj) {
return typeof obj;
} : function(obj) {
return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj;
};
function _classCallCheck(instance, Constructor) {
if (!(instance instanceof Constructor)) {
throw new TypeError("Cannot call a class as a function");
}
}
function getIDB() {
try {
if (typeof indexedDB !== "undefined") {
return indexedDB;
}
if (typeof webkitIndexedDB !== "undefined") {
return webkitIndexedDB;
}
if (typeof mozIndexedDB !== "undefined") {
return mozIndexedDB;
}
if (typeof OIndexedDB !== "undefined") {
return OIndexedDB;
}
if (typeof msIndexedDB !== "undefined") {
return msIndexedDB;
}
} catch (e3) {
return;
}
}
var idb = getIDB();
function isIndexedDBValid() {
try {
if (!idb || !idb.open) {
return false;
}
var isSafari = typeof openDatabase !== "undefined" && /(Safari|iPhone|iPad|iPod)/.test(navigator.userAgent) && !/Chrome/.test(navigator.userAgent) && !/BlackBerry/.test(navigator.platform);
var hasFetch = typeof fetch === "function" && fetch.toString().indexOf("[native code") !== -1;
return (!isSafari || hasFetch) && typeof indexedDB !== "undefined" && // some outdated implementations of IDB that appear on Samsung
// and HTC Android devices <4.4 are missing IDBKeyRange
// See: https://github.com/mozilla/localForage/issues/128
// See: https://github.com/mozilla/localForage/issues/272
typeof IDBKeyRange !== "undefined";
} catch (e3) {
return false;
}
}
function createBlob(parts, properties) {
parts = parts || [];
properties = properties || {};
try {
return new Blob(parts, properties);
} catch (e3) {
if (e3.name !== "TypeError") {
throw e3;
}
var Builder = typeof BlobBuilder !== "undefined" ? BlobBuilder : typeof MSBlobBuilder !== "undefined" ? MSBlobBuilder : typeof MozBlobBuilder !== "undefined" ? MozBlobBuilder : WebKitBlobBuilder;
var builder = new Builder();
for (var i3 = 0; i3 < parts.length; i3 += 1) {
builder.append(parts[i3]);
}
return builder.getBlob(properties.type);
}
}
if (typeof Promise === "undefined") {
_dereq_(3);
}
var Promise$1 = Promise;
function executeCallback(promise, callback) {
if (callback) {
promise.then(function(result) {
callback(null, result);
}, function(error) {
callback(error);
});
}
}
function executeTwoCallbacks(promise, callback, errorCallback) {
if (typeof callback === "function") {
promise.then(callback);
}
if (typeof errorCallback === "function") {
promise["catch"](errorCallback);
}
}
function normalizeKey(key3) {
if (typeof key3 !== "string") {
console.warn(key3 + " used as a key, but it is not a string.");
key3 = String(key3);
}
return key3;
}
function getCallback() {
if (arguments.length && typeof arguments[arguments.length - 1] === "function") {
return arguments[arguments.length - 1];
}
}
var DETECT_BLOB_SUPPORT_STORE = "local-forage-detect-blob-support";
var supportsBlobs = void 0;
var dbContexts = {};
var toString = Object.prototype.toString;
var READ_ONLY = "readonly";
var READ_WRITE = "readwrite";
function _binStringToArrayBuffer(bin) {
var length2 = bin.length;
var buf = new ArrayBuffer(length2);
var arr = new Uint8Array(buf);
for (var i3 = 0; i3 < length2; i3++) {
arr[i3] = bin.charCodeAt(i3);
}
return buf;
}
function _checkBlobSupportWithoutCaching(idb2) {
return new Promise$1(function(resolve) {
var txn = idb2.transaction(DETECT_BLOB_SUPPORT_STORE, READ_WRITE);
var blob = createBlob([""]);
txn.objectStore(DETECT_BLOB_SUPPORT_STORE).put(blob, "key");
txn.onabort = function(e3) {
e3.preventDefault();
e3.stopPropagation();
resolve(false);
};
txn.oncomplete = function() {
var matchedChrome = navigator.userAgent.match(/Chrome\/(\d+)/);
var matchedEdge = navigator.userAgent.match(/Edge\//);
resolve(matchedEdge || !matchedChrome || parseInt(matchedChrome[1], 10) >= 43);
};
})["catch"](function() {
return false;
});
}
function _checkBlobSupport(idb2) {
if (typeof supportsBlobs === "boolean") {
return Promise$1.resolve(supportsBlobs);
}
return _checkBlobSupportWithoutCaching(idb2).then(function(value) {
supportsBlobs = value;
return supportsBlobs;
});
}
function _deferReadiness(dbInfo) {
var dbContext = dbContexts[dbInfo.name];
var deferredOperation = {};
deferredOperation.promise = new Promise$1(function(resolve, reject) {
deferredOperation.resolve = resolve;
deferredOperation.reject = reject;
});
dbContext.deferredOperations.push(deferredOperation);
if (!dbContext.dbReady) {
dbContext.dbReady = deferredOperation.promise;
} else {
dbContext.dbReady = dbContext.dbReady.then(function() {
return deferredOperation.promise;
});
}
}
function _advanceReadiness(dbInfo) {
var dbContext = dbContexts[dbInfo.name];
var deferredOperation = dbContext.deferredOperations.pop();
if (deferredOperation) {
deferredOperation.resolve();
return deferredOperation.promise;
}
}
function _rejectReadiness(dbInfo, err) {
var dbContext = dbContexts[dbInfo.name];
var deferredOperation = dbContext.deferredOperations.pop();
if (deferredOperation) {
deferredOperation.reject(err);
return deferredOperation.promise;
}
}
function _getConnection(dbInfo, upgradeNeeded) {
return new Promise$1(function(resolve, reject) {
dbContexts[dbInfo.name] = dbContexts[dbInfo.name] || createDbContext();
if (dbInfo.db) {
if (upgradeNeeded) {
_deferReadiness(dbInfo);
dbInfo.db.close();
} else {
return resolve(dbInfo.db);
}
}
var dbArgs = [dbInfo.name];
if (upgradeNeeded) {
dbArgs.push(dbInfo.version);
}
var openreq = idb.open.apply(idb, dbArgs);
if (upgradeNeeded) {
openreq.onupgradeneeded = function(e3) {
var db = openreq.result;
try {
db.createObjectStore(dbInfo.storeName);
if (e3.oldVersion <= 1) {
db.createObjectStore(DETECT_BLOB_SUPPORT_STORE);
}
} catch (ex) {
if (ex.name === "ConstraintError") {
console.warn('The database "' + dbInfo.name + '" has been upgraded from version ' + e3.oldVersion + " to version " + e3.newVersion + ', but the storage "' + dbInfo.storeName + '" already exists.');
} else {
throw ex;
}
}
};
}
openreq.onerror = function(e3) {
e3.preventDefault();
reject(openreq.error);
};
openreq.onsuccess = function() {
var db = openreq.result;
db.onversionchange = function(e3) {
e3.target.close();
};
resolve(db);
_advanceReadiness(dbInfo);
};
});
}
function _getOriginalConnection(dbInfo) {
return _getConnection(dbInfo, false);
}
function _getUpgradedConnection(dbInfo) {
return _getConnection(dbInfo, true);
}
function _isUpgradeNeeded(dbInfo, defaultVersion) {
if (!dbInfo.db) {
return true;
}
var isNewStore = !dbInfo.db.objectStoreNames.contains(dbInfo.storeName);
var isDowngrade = dbInfo.version < dbInfo.db.version;
var isUpgrade = dbInfo.version > dbInfo.db.version;
if (isDowngrade) {
if (dbInfo.version !== defaultVersion) {
console.warn('The database "' + dbInfo.name + `" can't be downgraded from version ` + dbInfo.db.version + " to version " + dbInfo.version + ".");
}
dbInfo.version = dbInfo.db.version;
}
if (isUpgrade || isNewStore) {
if (isNewStore) {
var incVersion = dbInfo.db.version + 1;
if (incVersion > dbInfo.version) {
dbInfo.version = incVersion;
}
}
return true;
}
return false;
}
function _encodeBlob(blob) {
return new Promise$1(function(resolve, reject) {
var reader = new FileReader();
reader.onerror = reject;
reader.onloadend = function(e3) {
var base64 = btoa(e3.target.result || "");
resolve({
__local_forage_encoded_blob: true,
data: base64,
type: blob.type
});
};
reader.readAsBinaryString(blob);
});
}
function _decodeBlob(encodedBlob) {
var arrayBuff = _binStringToArrayBuffer(atob(encodedBlob.data));
return createBlob([arrayBuff], { type: encodedBlob.type });
}
function _isEncodedBlob(value) {
return value && value.__local_forage_encoded_blob;
}
function _fullyReady(callback) {
var self2 = this;
var promise = self2._initReady().then(function() {
var dbContext = dbContexts[self2._dbInfo.name];
if (dbContext && dbContext.dbReady) {
return dbContext.dbReady;
}
});
executeTwoCallbacks(promise, callback, callback);
return promise;
}
function _tryReconnect(dbInfo) {
_deferReadiness(dbInfo);
var dbContext = dbContexts[dbInfo.name];
var forages = dbContext.forages;
for (var i3 = 0; i3 < forages.length; i3++) {
var forage = forages[i3];
if (forage._dbInfo.db) {
forage._dbInfo.db.close();
forage._dbInfo.db = null;
}
}
dbInfo.db = null;
return _getOriginalConnection(dbInfo).then(function(db) {
dbInfo.db = db;
if (_isUpgradeNeeded(dbInfo)) {
return _getUpgradedConnection(dbInfo);
}
return db;
}).then(function(db) {
dbInfo.db = dbContext.db = db;
for (var i4 = 0; i4 < forages.length; i4++) {
forages[i4]._dbInfo.db = db;
}
})["catch"](function(err) {
_rejectReadiness(dbInfo, err);
throw err;
});
}
function createTransaction(dbInfo, mode, callback, retries) {
if (retries === void 0) {
retries = 1;
}
try {
var tx = dbInfo.db.transaction(dbInfo.storeName, mode);
callback(null, tx);
} catch (err) {
if (retries > 0 && (!dbInfo.db || err.name === "InvalidStateError" || err.name === "NotFoundError")) {
return Promise$1.resolve().then(function() {
if (!dbInfo.db || err.name === "NotFoundError" && !dbInfo.db.objectStoreNames.contains(dbInfo.storeName) && dbInfo.version <= dbInfo.db.version) {
if (dbInfo.db) {
dbInfo.version = dbInfo.db.version + 1;
}
return _getUpgradedConnection(dbInfo);
}
}).then(function() {
return _tryReconnect(dbInfo).then(function() {
createTransaction(dbInfo, mode, callback, retries - 1);
});
})["catch"](callback);
}
callback(err);
}
}
function createDbContext() {
return {
// Running localForages sharing a database.
forages: [],
// Shared database.
db: null,
// Database readiness (promise).
dbReady: null,
// Deferred operations on the database.
deferredOperations: []
};
}
function _initStorage(options) {
var self2 = this;
var dbInfo = {
db: null
};
if (options) {
for (var i3 in options) {
dbInfo[i3] = options[i3];
}
}
var dbContext = dbContexts[dbInfo.name];
if (!dbContext) {
dbContext = createDbContext();
dbContexts[dbInfo.name] = dbContext;
}
dbContext.forages.push(self2);
if (!self2._initReady) {
self2._initReady = self2.ready;
self2.ready = _fullyReady;
}
var initPromises = [];
function ignoreErrors() {
return Promise$1.resolve();
}
for (var j2 = 0; j2 < dbContext.forages.length; j2++) {
var forage = dbContext.forages[j2];
if (forage !== self2) {
initPromises.push(forage._initReady()["catch"](ignoreErrors));
}
}
var forages = dbContext.forages.slice(0);
return Promise$1.all(initPromises).then(function() {
dbInfo.db = dbContext.db;
return _getOriginalConnection(dbInfo);
}).then(function(db) {
dbInfo.db = db;
if (_isUpgradeNeeded(dbInfo, self2._defaultConfig.version)) {
return _getUpgradedConnection(dbInfo);
}
return db;
}).then(function(db) {
dbInfo.db = dbContext.db = db;
self2._dbInfo = dbInfo;
for (var k3 = 0; k3 < forages.length; k3++) {
var forage2 = forages[k3];
if (forage2 !== self2) {
forage2._dbInfo.db = dbInfo.db;
forage2._dbInfo.version = dbInfo.version;
}
}
});
}
function getItem(key3, callback) {
var self2 = this;
key3 = normalizeKey(key3);
var promise = new Promise$1(function(resolve, reject) {
self2.ready().then(function() {
createTransaction(self2._dbInfo, READ_ONLY, function(err, transaction) {
if (err) {
return reject(err);
}
try {
var store = transaction.objectStore(self2._dbInfo.storeName);
var req = store.get(key3);
req.onsuccess = function() {
var value = req.result;
if (value === void 0) {
value = null;
}
if (_isEncodedBlob(value)) {
value = _decodeBlob(value);
}
resolve(value);
};
req.onerror = function() {
reject(req.error);
};
} catch (e3) {
reject(e3);
}
});
})["catch"](reject);
});
executeCallback(promise, callback);
return promise;
}
function iterate(iterator, callback) {
var self2 = this;
var promise = new Promise$1(function(resolve, reject) {
self2.ready().then(function() {
createTransaction(self2._dbInfo, READ_ONLY, function(err, transaction) {
if (err) {
return reject(err);
}
try {
var store = transaction.objectStore(self2._dbInfo.storeName);
var req = store.openCursor();
var iterationNumber = 1;
req.onsuccess = function() {
var cursor = req.result;
if (cursor) {
var value = cursor.value;
if (_isEncodedBlob(value)) {
value = _decodeBlob(value);
}
var result = iterator(value, cursor.key, iterationNumber++);
if (result !== void 0) {
resolve(result);
} else {
cursor["continue"]();
}
} else {
resolve();
}
};
req.onerror = function() {
reject(req.error);
};
} catch (e3) {
reject(e3);
}
});
})["catch"](reject);
});
executeCallback(promise, callback);
return promise;
}
function setItem(key3, value, callback) {
var self2 = this;
key3 = normalizeKey(key3);
var promise = new Promise$1(function(resolve, reject) {
var dbInfo;
self2.ready().then(function() {
dbInfo = self2._dbInfo;
if (toString.call(value) === "[object Blob]") {
return _checkBlobSupport(dbInfo.db).then(function(blobSupport) {
if (blobSupport) {
return value;
}
return _encodeBlob(value);
});
}
return value;
}).then(function(value2) {
createTransaction(self2._dbInfo, READ_WRITE, function(err, transaction) {
if (err) {
return reject(err);
}
try {
var store = transaction.objectStore(self2._dbInfo.storeName);
if (value2 === null) {
value2 = void 0;
}
var req = store.put(value2, key3);
transaction.oncomplete = function() {
if (value2 === void 0) {
value2 = null;
}
resolve(value2);
};
transaction.onabort = transaction.onerror = function() {
var err2 = req.error ? req.error : req.transaction.error;
reject(err2);
};
} catch (e3) {
reject(e3);
}
});
})["catch"](reject);
});
executeCallback(promise, callback);
return promise;
}
function removeItem(key3, callback) {
var self2 = this;
key3 = normalizeKey(key3);
var promise = new Promise$1(function(resolve, reject) {
self2.ready().then(function() {
createTransaction(self2._dbInfo, READ_WRITE, function(err, transaction) {
if (err) {
return reject(err);
}
try {
var store = transaction.objectStore(self2._dbInfo.storeName);
var req = store["delete"](key3);
transaction.oncomplete = function() {
resolve();
};
transaction.onerror = function() {
reject(req.error);
};
transaction.onabort = function() {
var err2 = req.error ? req.error : req.transaction.error;
reject(err2);
};
} catch (e3) {
reject(e3);
}
});
})["catch"](reject);
});
executeCallback(promise, callback);
return promise;
}
function clear(callback) {
var self2 = this;
var promise = new Promise$1(function(resolve, reject) {
self2.ready().then(function() {
createTransaction(self2._dbInfo, READ_WRITE, function(err, transaction) {
if (err) {
return reject(err);
}
try {
var store = transaction.objectStore(self2._dbInfo.storeName);
var req = store.clear();
transaction.oncomplete = function() {
resolve();
};
transaction.onabort = transaction.onerror = function() {
var err2 = req.error ? req.error : req.transaction.error;
reject(err2);
};
} catch (e3) {
reject(e3);
}
});
})["catch"](reject);
});
executeCallback(promise, callback);
return promise;
}
function length(callback) {
var self2 = this;
var promise = new Promise$1(function(resolve, reject) {
self2.ready().then(function() {
createTransaction(self2._dbInfo, READ_ONLY, function(err, transaction) {
if (err) {
return reject(err);
}
try {
var store = transaction.objectStore(self2._dbInfo.storeName);
var req = store.count();
req.onsuccess = function() {
resolve(req.result);
};
req.onerror = function() {
reject(req.error);
};
} catch (e3) {
reject(e3);
}
});
})["catch"](reject);
});
executeCallback(promise, callback);
return promise;
}
function key2(n3, callback) {
var self2 = this;
var promise = new Promise$1(function(resolve, reject) {
if (n3 < 0) {
resolve(null);
return;
}
self2.ready().then(function() {
createTransaction(self2._dbInfo, READ_ONLY, function(err, transaction) {
if (err) {
return reject(err);
}
try {
var store = transaction.objectStore(self2._dbInfo.storeName);
var advanced = false;
var req = store.openKeyCursor();
req.onsuccess = function() {
var cursor = req.result;
if (!cursor) {
resolve(null);
return;
}
if (n3 === 0) {
resolve(cursor.key);
} else {
if (!advanced) {
advanced = true;
cursor.advance(n3);
} else {
resolve(cursor.key);
}
}
};
req.onerror = function() {
reject(req.error);
};
} catch (e3) {
reject(e3);
}
});
})["catch"](reject);
});
executeCallback(promise, callback);
return promise;
}
function keys(callback) {
var self2 = this;
var promise = new Promise$1(function(resolve, reject) {
self2.ready().then(function() {
createTransaction(self2._dbInfo, READ_ONLY, function(err, transaction) {
if (err) {
return reject(err);
}
try {
var store = transaction.objectStore(self2._dbInfo.storeName);
var req = store.openKeyCursor();
var keys2 = [];
req.onsuccess = function() {
var cursor = req.result;
if (!cursor) {
resolve(keys2);
return;
}
keys2.push(cursor.key);
cursor["continue"]();
};
req.onerror = function() {
reject(req.error);
};
} catch (e3) {
reject(e3);
}
});
})["catch"](reject);
});
executeCallback(promise, callback);
return promise;
}
function dropInstance(options, callback) {
callback = getCallback.apply(this, arguments);
var currentConfig = this.config();
options = typeof options !== "function" && options || {};
if (!options.name) {
options.name = options.name || currentConfig.name;
options.storeName = options.storeName || currentConfig.storeName;
}
var self2 = this;
var promise;
if (!options.name) {
promise = Promise$1.reject("Invalid arguments");
} else {
var isCurrentDb = options.name === currentConfig.name && self2._dbInfo.db;
var dbPromise = isCurrentDb ? Promise$1.resolve(self2._dbInfo.db) : _getOriginalConnection(options).then(function(db) {
var dbContext = dbContexts[options.name];
var forages = dbContext.forages;
dbContext.db = db;
for (var i3 = 0; i3 < forages.length; i3++) {
forages[i3]._dbInfo.db = db;
}
return db;
});
if (!options.storeName) {
promise = dbPromise.then(function(db) {
_deferReadiness(options);
var dbContext = dbContexts[options.name];
var forages = dbContext.forages;
db.close();
for (var i3 = 0; i3 < forages.length; i3++) {
var forage = forages[i3];
forage._dbInfo.db = null;
}
var dropDBPromise = new Promise$1(function(resolve, reject) {
var req = idb.deleteDatabase(options.name);
req.onerror = function() {
var db2 = req.result;
if (db2) {
db2.close();
}
reject(req.error);
};
req.onblocked = function() {
console.warn('dropInstance blocked for database "' + options.name + '" until all open connections are closed');
};
req.onsuccess = function() {
var db2 = req.result;
if (db2) {
db2.close();
}
resolve(db2);
};
});
return dropDBPromise.then(function(db2) {
dbContext.db = db2;
for (var i4 = 0; i4 < forages.length; i4++) {
var _forage = forages[i4];
_advanceReadiness(_forage._dbInfo);
}
})["catch"](function(err) {
(_rejectReadiness(options, err) || Promise$1.resolve())["catch"](function() {
});
throw err;
});
});
} else {
promise = dbPromise.then(function(db) {
if (!db.objectStoreNames.contains(options.storeName)) {
return;
}
var newVersion = db.version + 1;
_deferReadiness(options);
var dbContext = dbContexts[options.name];
var forages = dbContext.forages;
db.close();
for (var i3 = 0; i3 < forages.length; i3++) {
var forage = forages[i3];
forage._dbInfo.db = null;
forage._dbInfo.version = newVersion;
}
var dropObjectPromise = new Promise$1(function(resolve, reject) {
var req = idb.open(options.name, newVersion);
req.onerror = function(err) {
var db2 = req.result;
db2.close();
reject(err);
};
req.onupgradeneeded = function() {
var db2 = req.result;
db2.deleteObjectStore(options.storeName);
};
req.onsuccess = function() {
var db2 = req.result;
db2.close();
resolve(db2);
};
});
return dropObjectPromise.then(function(db2) {
dbContext.db = db2;
for (var j2 = 0; j2 < forages.length; j2++) {
var _forage2 = forages[j2];
_forage2._dbInfo.db = db2;
_advanceReadiness(_forage2._dbInfo);
}
})["catch"](function(err) {
(_rejectReadiness(options, err) || Promise$1.resolve())["catch"](function() {
});
throw err;
});
});
}
}
executeCallback(promise, callback);
return promise;
}
var asyncStorage = {
_driver: "asyncStorage",
_initStorage,
_support: isIndexedDBValid(),
iterate,
getItem,
setItem,
removeItem,
clear,
length,
key: key2,
keys,
dropInstance
};
function isWebSQLValid() {
return typeof openDatabase === "function";
}
var BASE_CHARS = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
var BLOB_TYPE_PREFIX = "~~local_forage_type~";
var BLOB_TYPE_PREFIX_REGEX = /^~~local_forage_type~([^~]+)~/;
var SERIALIZED_MARKER = "__lfsc__:";
var SERIALIZED_MARKER_LENGTH = SERIALIZED_MARKER.length;
var TYPE_ARRAYBUFFER = "arbf";
var TYPE_BLOB = "blob";
var TYPE_INT8ARRAY = "si08";
var TYPE_UINT8ARRAY = "ui08";
var TYPE_UINT8CLAMPEDARRAY = "uic8";
var TYPE_INT16ARRAY = "si16";
var TYPE_INT32ARRAY = "si32";
var TYPE_UINT16ARRAY = "ur16";
var TYPE_UINT32ARRAY = "ui32";
var TYPE_FLOAT32ARRAY = "fl32";
var TYPE_FLOAT64ARRAY = "fl64";
var TYPE_SERIALIZED_MARKER_LENGTH = SERIALIZED_MARKER_LENGTH + TYPE_ARRAYBUFFER.length;
var toString$1 = Object.prototype.toString;
function stringToBuffer(serializedString) {
var bufferLength = serializedString.length * 0.75;
var len = serializedString.length;
var i3;
var p2 = 0;
var encoded1, encoded2, encoded3, encoded4;
if (serializedString[serializedString.length - 1] === "=") {
bufferLength--;
if (serializedString[serializedString.length - 2] === "=") {
bufferLength--;
}
}
var buffer2 = new ArrayBuffer(bufferLength);
var bytes = new Uint8Array(buffer2);
for (i3 = 0; i3 < len; i3 += 4) {
encoded1 = BASE_CHARS.indexOf(serializedString[i3]);
encoded2 = BASE_CHARS.indexOf(serializedString[i3 + 1]);
encoded3 = BASE_CHARS.indexOf(serializedString[i3 + 2]);
encoded4 = BASE_CHARS.indexOf(serializedString[i3 + 3]);
bytes[p2++] = encoded1 << 2 | encoded2 >> 4;
bytes[p2++] = (encoded2 & 15) << 4 | encoded3 >> 2;
bytes[p2++] = (encoded3 & 3) << 6 | encoded4 & 63;
}
return buffer2;
}
function bufferToString(buffer2) {
var bytes = new Uint8Array(buffer2);
var base64String = "";
var i3;
for (i3 = 0; i3 < bytes.length; i3 += 3) {
base64String += BASE_CHARS[bytes[i3] >> 2];
base64String += BASE_CHARS[(bytes[i3] & 3) << 4 | bytes[i3 + 1] >> 4];
base64String += BASE_CHARS[(bytes[i3 + 1] & 15) << 2 | bytes[i3 + 2] >> 6];
base64String += BASE_CHARS[bytes[i3 + 2] & 63];
}
if (bytes.length % 3 === 2) {
base64String = base64String.substring(0, base64String.length - 1) + "=";
} else if (bytes.length % 3 === 1) {
base64String = base64String.substring(0, base64String.length - 2) + "==";
}
return base64String;
}
function serialize(value, callback) {
var valueType = "";
if (value) {
valueType = toString$1.call(value);
}
if (value && (valueType === "[object ArrayBuffer]" || value.buffer && toString$1.call(value.buffer) === "[object ArrayBuffer]")) {
var buffer2;
var marker = SERIALIZED_MARKER;
if (value instanceof ArrayBuffer) {
buffer2 = value;
marker += TYPE_ARRAYBUFFER;
} else {
buffer2 = value.buffer;
if (valueType === "[object Int8Array]") {
marker += TYPE_INT8ARRAY;
} else if (valueType === "[object Uint8Array]") {
marker += TYPE_UINT8ARRAY;
} else if (valueType === "[object Uint8ClampedArray]") {
marker += TYPE_UINT8CLAMPEDARRAY;
} else if (valueType === "[object Int16Array]") {
marker += TYPE_INT16ARRAY;
} else if (valueType === "[object Uint16Array]") {
marker += TYPE_UINT16ARRAY;
} else if (valueType === "[object Int32Array]") {
marker += TYPE_INT32ARRAY;
} else if (valueType === "[object Uint32Array]") {
marker += TYPE_UINT32ARRAY;
} else if (valueType === "[object Float32Array]") {
marker += TYPE_FLOAT32ARRAY;
} else if (valueType === "[object Float64Array]") {
marker += TYPE_FLOAT64ARRAY;
} else {
callback(new Error("Failed to get type for BinaryArray"));
}
}
callback(marker + bufferToString(buffer2));
} else if (valueType === "[object Blob]") {
var fileReader = new FileReader();
fileReader.onload = function() {
var str = BLOB_TYPE_PREFIX + value.type + "~" + bufferToString(this.result);
callback(SERIALIZED_MARKER + TYPE_BLOB + str);
};
fileReader.readAsArrayBuffer(value);
} else {
try {
callback(JSON.stringify(value));
} catch (e3) {
console.error("Couldn't convert value into a JSON string: ", value);
callback(null, e3);
}
}
}
function deserialize(value) {
if (value.substring(0, SERIALIZED_MARKER_LENGTH) !== SERIALIZED_MARKER) {
return JSON.parse(value);
}
var serializedString = value.substring(TYPE_SERIALIZED_MARKER_LENGTH);
var type = value.substring(SERIALIZED_MARKER_LENGTH, TYPE_SERIALIZED_MARKER_LENGTH);
var blobType;
if (type === TYPE_BLOB && BLOB_TYPE_PREFIX_REGEX.test(serializedString)) {
var matcher = serializedString.match(BLOB_TYPE_PREFIX_REGEX);
blobType = matcher[1];
serializedString = serializedString.substring(matcher[0].length);
}
var buffer2 = stringToBuffer(serializedString);
switch (type) {
case TYPE_ARRAYBUFFER:
return buffer2;
case TYPE_BLOB:
return createBlob([buffer2], { type: blobType });
case TYPE_INT8ARRAY:
return new Int8Array(buffer2);
case TYPE_UINT8ARRAY:
return new Uint8Array(buffer2);
case TYPE_UINT8CLAMPEDARRAY:
return new Uint8ClampedArray(buffer2);
case TYPE_INT16ARRAY:
return new Int16Array(buffer2);
case TYPE_UINT16ARRAY:
return new Uint16Array(buffer2);
case TYPE_INT32ARRAY:
return new Int32Array(buffer2);
case TYPE_UINT32ARRAY:
return new Uint32Array(buffer2);
case TYPE_FLOAT32ARRAY:
return new Float32Array(buffer2);
case TYPE_FLOAT64ARRAY:
return new Float64Array(buffer2);
default:
throw new Error("Unkown type: " + type);
}
}
var localforageSerializer = {
serialize,
deserialize,
stringToBuffer,
bufferToString
};
function createDbTable(t3, dbInfo, callback, errorCallback) {
t3.executeSql("CREATE TABLE IF NOT EXISTS " + dbInfo.storeName + " (id INTEGER PRIMARY KEY, key unique, value)", [], callback, errorCallback);
}
function _initStorage$1(options) {
var self2 = this;
var dbInfo = {
db: null
};
if (options) {
for (var i3 in options) {
dbInfo[i3] = typeof options[i3] !== "string" ? options[i3].toString() : options[i3];
}
}
var dbInfoPromise = new Promise$1(function(resolve, reject) {
try {
dbInfo.db = openDatabase(dbInfo.name, String(dbInfo.version), dbInfo.description, dbInfo.size);
} catch (e3) {
return reject(e3);
}
dbInfo.db.transaction(function(t3) {
createDbTable(t3, dbInfo, function() {
self2._dbInfo = dbInfo;
resolve();
}, function(t4, error) {
reject(error);
});
}, reject);
});
dbInfo.serializer = localforageSerializer;
return dbInfoPromise;
}
function tryExecuteSql(t3, dbInfo, sqlStatement, args, callback, errorCallback) {
t3.executeSql(sqlStatement, args, callback, function(t4, error) {
if (error.code === error.SYNTAX_ERR) {
t4.executeSql("SELECT name FROM sqlite_master WHERE type='table' AND name = ?", [dbInfo.storeName], function(t5, results) {
if (!results.rows.length) {
createDbTable(t5, dbInfo, function() {
t5.executeSql(sqlStatement, args, callback, errorCallback);
}, errorCallback);
} else {
errorCallback(t5, error);
}
}, errorCallback);
} else {
errorCallback(t4, error);
}
}, errorCallback);
}
function getItem$1(key3, callback) {
var self2 = this;
key3 = normalizeKey(key3);
var promise = new Promise$1(function(resolve, reject) {
self2.ready().then(function() {
var dbInfo = self2._dbInfo;
dbInfo.db.transaction(function(t3) {
tryExecuteSql(t3, dbInfo, "SELECT * FROM " + dbInfo.storeName + " WHERE key = ? LIMIT 1", [key3], function(t4, results) {
var result = results.rows.length ? results.rows.item(0).value : null;
if (result) {
result = dbInfo.serializer.deserialize(result);
}
resolve(result);
}, function(t4, error) {
reject(error);
});
});
})["catch"](reject);
});
executeCallback(promise, callback);
return promise;
}
function iterate$1(iterator, callback) {
var self2 = this;
var promise = new Promise$1(function(resolve, reject) {
self2.ready().then(function() {
var dbInfo = self2._dbInfo;
dbInfo.db.transaction(function(t3) {
tryExecuteSql(t3, dbInfo, "SELECT * FROM " + dbInfo.storeName, [], function(t4, results) {
var rows = results.rows;
var length2 = rows.length;
for (var i3 = 0; i3 < length2; i3++) {
var item = rows.item(i3);
var result = item.value;
if (result) {
result = dbInfo.serializer.deserialize(result);
}
result = iterator(result, item.key, i3 + 1);
if (result !== void 0) {
resolve(result);
return;
}
}
resolve();
}, function(t4, error) {
reject(error);
});
});
})["catch"](reject);
});
executeCallback(promise, callback);
return promise;
}
function _setItem(key3, value, callback, retriesLeft) {
var self2 = this;
key3 = normalizeKey(key3);
var promise = new Promise$1(function(resolve, reject) {
self2.ready().then(function() {
if (value === void 0) {
value = null;
}
var originalValue = value;
var dbInfo = self2._dbInfo;
dbInfo.serializer.serialize(value, function(value2, error) {
if (error) {
reject(error);
} else {
dbInfo.db.transaction(function(t3) {
tryExecuteSql(t3, dbInfo, "INSERT OR REPLACE INTO " + dbInfo.storeName + " (key, value) VALUES (?, ?)", [key3, value2], function() {
resolve(originalValue);
}, function(t4, error2) {
reject(error2);
});
}, function(sqlError) {
if (sqlError.code === sqlError.QUOTA_ERR) {
if (retriesLeft > 0) {
resolve(_setItem.apply(self2, [key3, originalValue, callback, retriesLeft - 1]));
return;
}
reject(sqlError);
}
});
}
});
})["catch"](reject);
});
executeCallback(promise, callback);
return promise;
}
function setItem$1(key3, value, callback) {
return _setItem.apply(this, [key3, value, callback, 1]);
}
function removeItem$1(key3, callback) {
var self2 = this;
key3 = normalizeKey(key3);
var promise = new Promise$1(function(resolve, reject) {
self2.ready().then(function() {
var dbInfo = self2._dbInfo;
dbInfo.db.transaction(function(t3) {
tryExecuteSql(t3, dbInfo, "DELETE FROM " + dbInfo.storeName + " WHERE key = ?", [key3], function() {
resolve();
}, function(t4, error) {
reject(error);
});
});
})["catch"](reject);
});
executeCallback(promise, callback);
return promise;
}
function clear$1(callback) {
var self2 = this;
var promise = new Promise$1(function(resolve, reject) {
self2.ready().then(function() {
var dbInfo = self2._dbInfo;
dbInfo.db.transaction(function(t3) {
tryExecuteSql(t3, dbInfo, "DELETE FROM " + dbInfo.storeName, [], function() {
resolve();
}, function(t4, error) {
reject(error);
});
});
})["catch"](reject);
});
executeCallback(promise, callback);
return promise;
}
function length$1(callback) {
var self2 = this;
var promise = new Promise$1(function(resolve, reject) {
self2.ready().then(function() {
var dbInfo = self2._dbInfo;
dbInfo.db.transaction(function(t3) {
tryExecuteSql(t3, dbInfo, "SELECT COUNT(key) as c FROM " + dbInfo.storeName, [], function(t4, results) {
var result = results.rows.item(0).c;
resolve(result);
}, function(t4, error) {
reject(error);
});
});
})["catch"](reject);
});
executeCallback(promise, callback);
return promise;
}
function key$12(n3, callback) {
var self2 = this;
var promise = new Promise$1(function(resolve, reject) {
self2.ready().then(function() {
var dbInfo = self2._dbInfo;
dbInfo.db.transaction(function(t3) {
tryExecuteSql(t3, dbInfo, "SELECT key FROM " + dbInfo.storeName + " WHERE id = ? LIMIT 1", [n3 + 1], function(t4, results) {
var result = results.rows.length ? results.rows.item(0).key : null;
resolve(result);
}, function(t4, error) {
reject(error);
});
});
})["catch"](reject);
});
executeCallback(promise, callback);
return promise;
}
function keys$1(callback) {
var self2 = this;
var promise = new Promise$1(function(resolve, reject) {
self2.ready().then(function() {
var dbInfo = self2._dbInfo;
dbInfo.db.transaction(function(t3) {
tryExecuteSql(t3, dbInfo, "SELECT key FROM " + dbInfo.storeName, [], function(t4, results) {
var keys2 = [];
for (var i3 = 0; i3 < results.rows.length; i3++) {
keys2.push(results.rows.item(i3).key);
}
resolve(keys2);
}, function(t4, error) {
reject(error);
});
});
})["catch"](reject);
});
executeCallback(promise, callback);
return promise;
}
function getAllStoreNames(db) {
return new Promise$1(function(resolve, reject) {
db.transaction(function(t3) {
t3.executeSql("SELECT name FROM sqlite_master WHERE type='table' AND name <> '__WebKitDatabaseInfoTable__'", [], function(t4, results) {
var storeNames = [];
for (var i3 = 0; i3 < results.rows.length; i3++) {
storeNames.push(results.rows.item(i3).name);
}
resolve({
db,
storeNames
});
}, function(t4, error) {
reject(error);
});
}, function(sqlError) {
reject(sqlError);
});
});
}
function dropInstance$1(options, callback) {
callback = getCallback.apply(this, arguments);
var currentConfig = this.config();
options = typeof options !== "function" && options || {};
if (!options.name) {
options.name = options.name || currentConfig.name;
options.storeName = options.storeName || currentConfig.storeName;
}
var self2 = this;
var promise;
if (!options.name) {
promise = Promise$1.reject("Invalid arguments");
} else {
promise = new Promise$1(function(resolve) {
var db;
if (options.name === currentConfig.name) {
db = self2._dbInfo.db;
} else {
db = openDatabase(options.name, "", "", 0);
}
if (!options.storeName) {
resolve(getAllStoreNames(db));
} else {
resolve({
db,
storeNames: [options.storeName]
});
}
}).then(function(operationInfo) {
return new Promise$1(function(resolve, reject) {
operationInfo.db.transaction(function(t3) {
function dropTable(storeName) {
return new Promise$1(function(resolve2, reject2) {
t3.executeSql("DROP TABLE IF EXISTS " + storeName, [], function() {
resolve2();
}, function(t4, error) {
reject2(error);
});
});
}
var operations = [];
for (var i3 = 0, len = operationInfo.storeNames.length; i3 < len; i3++) {
operations.push(dropTable(operationInfo.storeNames[i3]));
}
Promise$1.all(operations).then(function() {
resolve();
})["catch"](function(e3) {
reject(e3);
});
}, function(sqlError) {
reject(sqlError);
});
});
});
}
executeCallback(promise, callback);
return promise;
}
var webSQLStorage = {
_driver: "webSQLStorage",
_initStorage: _initStorage$1,
_support: isWebSQLValid(),
iterate: iterate$1,
getItem: getItem$1,
setItem: setItem$1,
removeItem: removeItem$1,
clear: clear$1,
length: length$1,
key: key$12,
keys: keys$1,
dropInstance: dropInstance$1
};
function isLocalStorageValid() {
try {
return typeof localStorage !== "undefined" && "setItem" in localStorage && // in IE8 typeof localStorage.setItem === 'object'
!!localStorage.setItem;
} catch (e3) {
return false;
}
}
function _getKeyPrefix(options, defaultConfig) {
var keyPrefix = options.name + "/";
if (options.storeName !== defaultConfig.storeName) {
keyPrefix += options.storeName + "/";
}
return keyPrefix;
}
function checkIfLocalStorageThrows() {
var localStorageTestKey = "_localforage_support_test";
try {
localStorage.setItem(localStorageTestKey, true);
localStorage.removeItem(localStorageTestKey);
return false;
} catch (e3) {
return true;
}
}
function _isLocalStorageUsable() {
return !checkIfLocalStorageThrows() || localStorage.length > 0;
}
function _initStorage$2(options) {
var self2 = this;
var dbInfo = {};
if (options) {
for (var i3 in options) {
dbInfo[i3] = options[i3];
}
}
dbInfo.keyPrefix = _getKeyPrefix(options, self2._defaultConfig);
if (!_isLocalStorageUsable()) {
return Promise$1.reject();
}
self2._dbInfo = dbInfo;
dbInfo.serializer = localforageSerializer;
return Promise$1.resolve();
}
function clear$2(callback) {
var self2 = this;
var promise = self2.ready().then(function() {
var keyPrefix = self2._dbInfo.keyPrefix;
for (var i3 = localStorage.length - 1; i3 >= 0; i3--) {
var key3 = localStorage.key(i3);
if (key3.indexOf(keyPrefix) === 0) {
localStorage.removeItem(key3);
}
}
});
executeCallback(promise, callback);
return promise;
}
function getItem$2(key3, callback) {
var self2 = this;
key3 = normalizeKey(key3);
var promise = self2.ready().then(function() {
var dbInfo = self2._dbInfo;
var result = localStorage.getItem(dbInfo.keyPrefix + key3);
if (result) {
result = dbInfo.serializer.deserialize(result);
}
return result;
});
executeCallback(promise, callback);
return promise;
}
function iterate$2(iterator, callback) {
var self2 = this;
var promise = self2.ready().then(function() {
var dbInfo = self2._dbInfo;
var keyPrefix = dbInfo.keyPrefix;
var keyPrefixLength = keyPrefix.length;
var length2 = localStorage.length;
var iterationNumber = 1;
for (var i3 = 0; i3 < length2; i3++) {
var key3 = localStorage.key(i3);
if (key3.indexOf(keyPrefix) !== 0) {
continue;
}
var value = localStorage.getItem(key3);
if (value) {
value = dbInfo.serializer.deserialize(value);
}
value = iterator(value, key3.substring(keyPrefixLength), iterationNumber++);
if (value !== void 0) {
return value;
}
}
});
executeCallback(promise, callback);
return promise;
}
function key$2(n3, callback) {
var self2 = this;
var promise = self2.ready().then(function() {
var dbInfo = self2._dbInfo;
var result;
try {
result = localStorage.key(n3);
} catch (error) {
result = null;
}
if (result) {
result = result.substring(dbInfo.keyPrefix.length);
}
return result;
});
executeCallback(promise, callback);
return promise;
}
function keys$2(callback) {
var self2 = this;
var promise = self2.ready().then(function() {
var dbInfo = self2._dbInfo;
var length2 = localStorage.length;
var keys2 = [];
for (var i3 = 0; i3 < length2; i3++) {
var itemKey = localStorage.key(i3);
if (itemKey.indexOf(dbInfo.keyPrefix) === 0) {
keys2.push(itemKey.substring(dbInfo.keyPrefix.length));
}
}
return keys2;
});
executeCallback(promise, callback);
return promise;
}
function length$2(callback) {
var self2 = this;
var promise = self2.keys().then(function(keys2) {
return keys2.length;
});
executeCallback(promise, callback);
return promise;
}
function removeItem$2(key3, callback) {
var self2 = this;
key3 = normalizeKey(key3);
var promise = self2.ready().then(function() {
var dbInfo = self2._dbInfo;
localStorage.removeItem(dbInfo.keyPrefix + key3);
});
executeCallback(promise, callback);
return promise;
}
function setItem$2(key3, value, callback) {
var self2 = this;
key3 = normalizeKey(key3);
var promise = self2.ready().then(function() {
if (value === void 0) {
value = null;
}
var originalValue = value;
return new Promise$1(function(resolve, reject) {
var dbInfo = self2._dbInfo;
dbInfo.serializer.serialize(value, function(value2, error) {
if (error) {
reject(error);
} else {
try {
localStorage.setItem(dbInfo.keyPrefix + key3, value2);
resolve(originalValue);
} catch (e3) {
if (e3.name === "QuotaExceededError" || e3.name === "NS_ERROR_DOM_QUOTA_REACHED") {
reject(e3);
}
reject(e3);
}
}
});
});
});
executeCallback(promise, callback);
return promise;
}
function dropInstance$2(options, callback) {
callback = getCallback.apply(this, arguments);
options = typeof options !== "function" && options || {};
if (!options.name) {
var currentConfig = this.config();
options.name = options.name || currentConfig.name;
options.storeName = options.storeName || currentConfig.storeName;
}
var self2 = this;
var promise;
if (!options.name) {
promise = Promise$1.reject("Invalid arguments");
} else {
promise = new Promise$1(function(resolve) {
if (!options.storeName) {
resolve(options.name + "/");
} else {
resolve(_getKeyPrefix(options, self2._defaultConfig));
}
}).then(function(keyPrefix) {
for (var i3 = localStorage.length - 1; i3 >= 0; i3--) {
var key3 = localStorage.key(i3);
if (key3.indexOf(keyPrefix) === 0) {
localStorage.removeItem(key3);
}
}
});
}
executeCallback(promise, callback);
return promise;
}
var localStorageWrapper = {
_driver: "localStorageWrapper",
_initStorage: _initStorage$2,
_support: isLocalStorageValid(),
iterate: iterate$2,
getItem: getItem$2,
setItem: setItem$2,
removeItem: removeItem$2,
clear: clear$2,
length: length$2,
key: key$2,
keys: keys$2,
dropInstance: dropInstance$2
};
var sameValue = function sameValue2(x2, y2) {
return x2 === y2 || typeof x2 === "number" && typeof y2 === "number" && isNaN(x2) && isNaN(y2);
};
var includes = function includes2(array, searchElement) {
var len = array.length;
var i3 = 0;
while (i3 < len) {
if (sameValue(array[i3], searchElement)) {
return true;
}
i3++;
}
return false;
};
var isArray = Array.isArray || function(arg) {
return Object.prototype.toString.call(arg) === "[object Array]";
};
var DefinedDrivers = {};
var DriverSupport = {};
var DefaultDrivers = {
INDEXEDDB: asyncStorage,
WEBSQL: webSQLStorage,
LOCALSTORAGE: localStorageWrapper
};
var DefaultDriverOrder = [DefaultDrivers.INDEXEDDB._driver, DefaultDrivers.WEBSQL._driver, DefaultDrivers.LOCALSTORAGE._driver];
var OptionalDriverMethods = ["dropInstance"];
var LibraryMethods = ["clear", "getItem", "iterate", "key", "keys", "length", "removeItem", "setItem"].concat(OptionalDriverMethods);
var DefaultConfig = {
description: "",
driver: DefaultDriverOrder.slice(),
name: "localforage",
// Default DB size is _JUST UNDER_ 5MB, as it's the highest size
// we can use without a prompt.
size: 4980736,
storeName: "keyvaluepairs",
version: 1
};
function callWhenReady(localForageInstance, libraryMethod) {
localForageInstance[libraryMethod] = function() {
var _args = arguments;
return localForageInstance.ready().then(function() {
return localForageInstance[libraryMethod].apply(localForageInstance, _args);
});
};
}
function extend2() {
for (var i3 = 1; i3 < arguments.length; i3++) {
var arg = arguments[i3];
if (arg) {
for (var _key in arg) {
if (arg.hasOwnProperty(_key)) {
if (isArray(arg[_key])) {
arguments[0][_key] = arg[_key].slice();
} else {
arguments[0][_key] = arg[_key];
}
}
}
}
}
return arguments[0];
}
var LocalForage = function() {
function LocalForage2(options) {
_classCallCheck(this, LocalForage2);
for (var driverTypeKey in DefaultDrivers) {
if (DefaultDrivers.hasOwnProperty(driverTypeKey)) {
var driver = DefaultDrivers[driverTypeKey];
var driverName = driver._driver;
this[driverTypeKey] = driverName;
if (!DefinedDrivers[driverName]) {
this.defineDriver(driver);
}
}
}
this._defaultConfig = extend2({}, DefaultConfig);
this._config = extend2({}, this._defaultConfig, options);
this._driverSet = null;
this._initDriver = null;
this._ready = false;
this._dbInfo = null;
this._wrapLibraryMethodsWithReady();
this.setDriver(this._config.driver)["catch"](function() {
});
}
LocalForage2.prototype.config = function config(options) {
if ((typeof options === "undefined" ? "undefined" : _typeof(options)) === "object") {
if (this._ready) {
return new Error("Can't call config() after localforage has been used.");
}
for (var i3 in options) {
if (i3 === "storeName") {
options[i3] = options[i3].replace(/\W/g, "_");
}
if (i3 === "version" && typeof options[i3] !== "number") {
return new Error("Database version must be a number.");
}
this._config[i3] = options[i3];
}
if ("driver" in options && options.driver) {
return this.setDriver(this._config.driver);
}
return true;
} else if (typeof options === "string") {
return this._config[options];
} else {
return this._config;
}
};
LocalForage2.prototype.defineDriver = function defineDriver(driverObject, callback, errorCallback) {
var promise = new Promise$1(function(resolve, reject) {
try {
var driverName = driverObject._driver;
var complianceError = new Error("Custom driver not compliant; see https://mozilla.github.io/localForage/#definedriver");
if (!driverObject._driver) {
reject(complianceError);
return;
}
var driverMethods = LibraryMethods.concat("_initStorage");
for (var i3 = 0, len = driverMethods.length; i3 < len; i3++) {
var driverMethodName = driverMethods[i3];
var isRequired = !includes(OptionalDriverMethods, driverMethodName);
if ((isRequired || driverObject[driverMethodName]) && typeof driverObject[driverMethodName] !== "function") {
reject(complianceError);
return;
}
}
var configureMissingMethods = function configureMissingMethods2() {
var methodNotImplementedFactory = function methodNotImplementedFactory2(methodName) {
return function() {
var error = new Error("Method " + methodName + " is not implemented by the current driver");
var promise2 = Promise$1.reject(error);
executeCallback(promise2, arguments[arguments.length - 1]);
return promise2;
};
};
for (var _i = 0, _len = OptionalDriverMethods.length; _i < _len; _i++) {
var optionalDriverMethod = OptionalDriverMethods[_i];
if (!driverObject[optionalDriverMethod]) {
driverObject[optionalDriverMethod] = methodNotImplementedFactory(optionalDriverMethod);
}
}
};
configureMissingMethods();
var setDriverSupport = function setDriverSupport2(support) {
if (DefinedDrivers[driverName]) {
console.info("Redefining LocalForage driver: " + driverName);
}
DefinedDrivers[driverName] = driverObject;
DriverSupport[driverName] = support;
resolve();
};
if ("_support" in driverObject) {
if (driverObject._support && typeof driverObject._support === "function") {
driverObject._support().then(setDriverSupport, reject);
} else {
setDriverSupport(!!driverObject._support);
}
} else {
setDriverSupport(true);
}
} catch (e3) {
reject(e3);
}
});
executeTwoCallbacks(promise, callback, errorCallback);
return promise;
};
LocalForage2.prototype.driver = function driver() {
return this._driver || null;
};
LocalForage2.prototype.getDriver = function getDriver(driverName, callback, errorCallback) {
var getDriverPromise = DefinedDrivers[driverName] ? Promise$1.resolve(DefinedDrivers[driverName]) : Promise$1.reject(new Error("Driver not found."));
executeTwoCallbacks(getDriverPromise, callback, errorCallback);
return getDriverPromise;
};
LocalForage2.prototype.getSerializer = function getSerializer(callback) {
var serializerPromise = Promise$1.resolve(localforageSerializer);
executeTwoCallbacks(serializerPromise, callback);
return serializerPromise;
};
LocalForage2.prototype.ready = function ready(callback) {
var self2 = this;
var promise = self2._driverSet.then(function() {
if (self2._ready === null) {
self2._ready = self2._initDriver();
}
return self2._ready;
});
executeTwoCallbacks(promise, callback, callback);
return promise;
};
LocalForage2.prototype.setDriver = function setDriver(drivers, callback, errorCallback) {
var self2 = this;
if (!isArray(drivers)) {
drivers = [drivers];
}
var supportedDrivers = this._getSupportedDrivers(drivers);
function setDriverToConfig() {
self2._config.driver = self2.driver();
}
function extendSelfWithDriver(driver) {
self2._extend(driver);
setDriverToConfig();
self2._ready = self2._initStorage(self2._config);
return self2._ready;
}
function initDriver(supportedDrivers2) {
return function() {
var currentDriverIndex = 0;
function driverPromiseLoop() {
while (currentDriverIndex < supportedDrivers2.length) {
var driverName = supportedDrivers2[currentDriverIndex];
currentDriverIndex++;
self2._dbInfo = null;
self2._ready = null;
return self2.getDriver(driverName).then(extendSelfWithDriver)["catch"](driverPromiseLoop);
}
setDriverToConfig();
var error = new Error("No available storage method found.");
self2._driverSet = Promise$1.reject(error);
return self2._driverSet;
}
return driverPromiseLoop();
};
}
var oldDriverSetDone = this._driverSet !== null ? this._driverSet["catch"](function() {
return Promise$1.resolve();
}) : Promise$1.resolve();
this._driverSet = oldDriverSetDone.then(function() {
var driverName = supportedDrivers[0];
self2._dbInfo = null;
self2._ready = null;
return self2.getDriver(driverName).then(function(driver) {
self2._driver = driver._driver;
setDriverToConfig();
self2._wrapLibraryMethodsWithReady();
self2._initDriver = initDriver(supportedDrivers);
});
})["catch"](function() {
setDriverToConfig();
var error = new Error("No available storage method found.");
self2._driverSet = Promise$1.reject(error);
return self2._driverSet;
});
executeTwoCallbacks(this._driverSet, callback, errorCallback);
return this._driverSet;
};
LocalForage2.prototype.supports = function supports(driverName) {
return !!DriverSupport[driverName];
};
LocalForage2.prototype._extend = function _extend(libraryMethodsAndProperties) {
extend2(this, libraryMethodsAndProperties);
};
LocalForage2.prototype._getSupportedDrivers = function _getSupportedDrivers(drivers) {
var supportedDrivers = [];
for (var i3 = 0, len = drivers.length; i3 < len; i3++) {
var driverName = drivers[i3];
if (this.supports(driverName)) {
supportedDrivers.push(driverName);
}
}
return supportedDrivers;
};
LocalForage2.prototype._wrapLibraryMethodsWithReady = function _wrapLibraryMethodsWithReady() {
for (var i3 = 0, len = LibraryMethods.length; i3 < len; i3++) {
callWhenReady(this, LibraryMethods[i3]);
}
};
LocalForage2.prototype.createInstance = function createInstance(options) {
return new LocalForage2(options);
};
return LocalForage2;
}();
var localforage_js = new LocalForage();
module2.exports = localforage_js;
}, { "3": 3 }] }, {}, [4])(4);
});
})(localforage$1);
var localforageExports = localforage$1.exports;
const localforage = /* @__PURE__ */ getDefaultExportFromCjs(localforageExports);
var jszip_min = { exports: {} };
/*!
JSZip v3.10.1 - A JavaScript class for generating and reading zip files
<http://stuartk.com/jszip>
(c) 2009-2016 Stuart Knightley <stuart [at] stuartk.com>
Dual licenced under the MIT license or GPLv3. See https://raw.github.com/Stuk/jszip/main/LICENSE.markdown.
JSZip uses the library pako released under the MIT license :
https://github.com/nodeca/pako/blob/main/LICENSE
*/
(function(module, exports) {
!function(e3) {
module.exports = e3();
}(function() {
return function s3(a2, o2, h3) {
function u2(r3, e4) {
if (!o2[r3]) {
if (!a2[r3]) {
var t3 = "function" == typeof commonjsRequire && commonjsRequire;
if (!e4 && t3) return t3(r3, true);
if (l2) return l2(r3, true);
var n3 = new Error("Cannot find module '" + r3 + "'");
throw n3.code = "MODULE_NOT_FOUND", n3;
}
var i3 = o2[r3] = { exports: {} };
a2[r3][0].call(i3.exports, function(e5) {
var t4 = a2[r3][1][e5];
return u2(t4 || e5);
}, i3, i3.exports, s3, a2, o2, h3);
}
return o2[r3].exports;
}
for (var l2 = "function" == typeof commonjsRequire && commonjsRequire, e3 = 0; e3 < h3.length; e3++) u2(h3[e3]);
return u2;
}({ 1: [function(e3, t3, r3) {
var d2 = e3("./utils"), c3 = e3("./support"), p2 = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";
r3.encode = function(e4) {
for (var t4, r4, n3, i3, s3, a2, o2, h3 = [], u2 = 0, l2 = e4.length, f3 = l2, c4 = "string" !== d2.getTypeOf(e4); u2 < e4.length; ) f3 = l2 - u2, n3 = c4 ? (t4 = e4[u2++], r4 = u2 < l2 ? e4[u2++] : 0, u2 < l2 ? e4[u2++] : 0) : (t4 = e4.charCodeAt(u2++), r4 = u2 < l2 ? e4.charCodeAt(u2++) : 0, u2 < l2 ? e4.charCodeAt(u2++) : 0), i3 = t4 >> 2, s3 = (3 & t4) << 4 | r4 >> 4, a2 = 1 < f3 ? (15 & r4) << 2 | n3 >> 6 : 64, o2 = 2 < f3 ? 63 & n3 : 64, h3.push(p2.charAt(i3) + p2.charAt(s3) + p2.charAt(a2) + p2.charAt(o2));
return h3.join("");
}, r3.decode = function(e4) {
var t4, r4, n3, i3, s3, a2, o2 = 0, h3 = 0, u2 = "data:";
if (e4.substr(0, u2.length) === u2) throw new Error("Invalid base64 input, it looks like a data url.");
var l2, f3 = 3 * (e4 = e4.replace(/[^A-Za-z0-9+/=]/g, "")).length / 4;
if (e4.charAt(e4.length - 1) === p2.charAt(64) && f3--, e4.charAt(e4.length - 2) === p2.charAt(64) && f3--, f3 % 1 != 0) throw new Error("Invalid base64 input, bad content length.");
for (l2 = c3.uint8array ? new Uint8Array(0 | f3) : new Array(0 | f3); o2 < e4.length; ) t4 = p2.indexOf(e4.charAt(o2++)) << 2 | (i3 = p2.indexOf(e4.charAt(o2++))) >> 4, r4 = (15 & i3) << 4 | (s3 = p2.indexOf(e4.charAt(o2++))) >> 2, n3 = (3 & s3) << 6 | (a2 = p2.indexOf(e4.charAt(o2++))), l2[h3++] = t4, 64 !== s3 && (l2[h3++] = r4), 64 !== a2 && (l2[h3++] = n3);
return l2;
};
}, { "./support": 30, "./utils": 32 }], 2: [function(e3, t3, r3) {
var n3 = e3("./external"), i3 = e3("./stream/DataWorker"), s3 = e3("./stream/Crc32Probe"), a2 = e3("./stream/DataLengthProbe");
function o2(e4, t4, r4, n4, i4) {
this.compressedSize = e4, this.uncompressedSize = t4, this.crc32 = r4, this.compression = n4, this.compressedContent = i4;
}
o2.prototype = { getContentWorker: function() {
var e4 = new i3(n3.Promise.resolve(this.compressedContent)).pipe(this.compression.uncompressWorker()).pipe(new a2("data_length")), t4 = this;
return e4.on("end", function() {
if (this.streamInfo.data_length !== t4.uncompressedSize) throw new Error("Bug : uncompressed data size mismatch");
}), e4;
}, getCompressedWorker: function() {
return new i3(n3.Promise.resolve(this.compressedContent)).withStreamInfo("compressedSize", this.compressedSize).withStreamInfo("uncompressedSize", this.uncompressedSize).withStreamInfo("crc32", this.crc32).withStreamInfo("compression", this.compression);
} }, o2.createWorkerFrom = function(e4, t4, r4) {
return e4.pipe(new s3()).pipe(new a2("uncompressedSize")).pipe(t4.compressWorker(r4)).pipe(new a2("compressedSize")).withStreamInfo("compression", t4);
}, t3.exports = o2;
}, { "./external": 6, "./stream/Crc32Probe": 25, "./stream/DataLengthProbe": 26, "./stream/DataWorker": 27 }], 3: [function(e3, t3, r3) {
var n3 = e3("./stream/GenericWorker");
r3.STORE = { magic: "\0\0", compressWorker: function() {
return new n3("STORE compression");
}, uncompressWorker: function() {
return new n3("STORE decompression");
} }, r3.DEFLATE = e3("./flate");
}, { "./flate": 7, "./stream/GenericWorker": 28 }], 4: [function(e3, t3, r3) {
var n3 = e3("./utils");
var o2 = function() {
for (var e4, t4 = [], r4 = 0; r4 < 256; r4++) {
e4 = r4;
for (var n4 = 0; n4 < 8; n4++) e4 = 1 & e4 ? 3988292384 ^ e4 >>> 1 : e4 >>> 1;
t4[r4] = e4;
}
return t4;
}();
t3.exports = function(e4, t4) {
return void 0 !== e4 && e4.length ? "string" !== n3.getTypeOf(e4) ? function(e5, t5, r4, n4) {
var i3 = o2, s3 = n4 + r4;
e5 ^= -1;
for (var a2 = n4; a2 < s3; a2++) e5 = e5 >>> 8 ^ i3[255 & (e5 ^ t5[a2])];
return -1 ^ e5;
}(0 | t4, e4, e4.length, 0) : function(e5, t5, r4, n4) {
var i3 = o2, s3 = n4 + r4;
e5 ^= -1;
for (var a2 = n4; a2 < s3; a2++) e5 = e5 >>> 8 ^ i3[255 & (e5 ^ t5.charCodeAt(a2))];
return -1 ^ e5;
}(0 | t4, e4, e4.length, 0) : 0;
};
}, { "./utils": 32 }], 5: [function(e3, t3, r3) {
r3.base64 = false, r3.binary = false, r3.dir = false, r3.createFolders = true, r3.date = null, r3.compression = null, r3.compressionOptions = null, r3.comment = null, r3.unixPermissions = null, r3.dosPermissions = null;
}, {}], 6: [function(e3, t3, r3) {
var n3 = null;
n3 = "undefined" != typeof Promise ? Promise : e3("lie"), t3.exports = { Promise: n3 };
}, { lie: 37 }], 7: [function(e3, t3, r3) {
var n3 = "undefined" != typeof Uint8Array && "undefined" != typeof Uint16Array && "undefined" != typeof Uint32Array, i3 = e3("pako"), s3 = e3("./utils"), a2 = e3("./stream/GenericWorker"), o2 = n3 ? "uint8array" : "array";
function h3(e4, t4) {
a2.call(this, "FlateWorker/" + e4), this._pako = null, this._pakoAction = e4, this._pakoOptions = t4, this.meta = {};
}
r3.magic = "\b\0", s3.inherits(h3, a2), h3.prototype.processChunk = function(e4) {
this.meta = e4.meta, null === this._pako && this._createPako(), this._pako.push(s3.transformTo(o2, e4.data), false);
}, h3.prototype.flush = function() {
a2.prototype.flush.call(this), null === this._pako && this._createPako(), this._pako.push([], true);
}, h3.prototype.cleanUp = function() {
a2.prototype.cleanUp.call(this), this._pako = null;
}, h3.prototype._createPako = function() {
this._pako = new i3[this._pakoAction]({ raw: true, level: this._pakoOptions.level || -1 });
var t4 = this;
this._pako.onData = function(e4) {
t4.push({ data: e4, meta: t4.meta });
};
}, r3.compressWorker = function(e4) {
return new h3("Deflate", e4);
}, r3.uncompressWorker = function() {
return new h3("Inflate", {});
};
}, { "./stream/GenericWorker": 28, "./utils": 32, pako: 38 }], 8: [function(e3, t3, r3) {
function A2(e4, t4) {
var r4, n4 = "";
for (r4 = 0; r4 < t4; r4++) n4 += String.fromCharCode(255 & e4), e4 >>>= 8;
return n4;
}
function n3(e4, t4, r4, n4, i4, s4) {
var a2, o2, h3 = e4.file, u2 = e4.compression, l2 = s4 !== O.utf8encode, f3 = I2.transformTo("string", s4(h3.name)), c3 = I2.transformTo("string", O.utf8encode(h3.name)), d2 = h3.comment, p2 = I2.transformTo("string", s4(d2)), m2 = I2.transformTo("string", O.utf8encode(d2)), _2 = c3.length !== h3.name.length, g2 = m2.length !== d2.length, b3 = "", v2 = "", y2 = "", w2 = h3.dir, k3 = h3.date, x2 = { crc32: 0, compressedSize: 0, uncompressedSize: 0 };
t4 && !r4 || (x2.crc32 = e4.crc32, x2.compressedSize = e4.compressedSize, x2.uncompressedSize = e4.uncompressedSize);
var S2 = 0;
t4 && (S2 |= 8), l2 || !_2 && !g2 || (S2 |= 2048);
var z2 = 0, C2 = 0;
w2 && (z2 |= 16), "UNIX" === i4 ? (C2 = 798, z2 |= function(e5, t5) {
var r5 = e5;
return e5 || (r5 = t5 ? 16893 : 33204), (65535 & r5) << 16;
}(h3.unixPermissions, w2)) : (C2 = 20, z2 |= function(e5) {
return 63 & (e5 || 0);
}(h3.dosPermissions)), a2 = k3.getUTCHours(), a2 <<= 6, a2 |= k3.getUTCMinutes(), a2 <<= 5, a2 |= k3.getUTCSeconds() / 2, o2 = k3.getUTCFullYear() - 1980, o2 <<= 4, o2 |= k3.getUTCMonth() + 1, o2 <<= 5, o2 |= k3.getUTCDate(), _2 && (v2 = A2(1, 1) + A2(B2(f3), 4) + c3, b3 += "up" + A2(v2.length, 2) + v2), g2 && (y2 = A2(1, 1) + A2(B2(p2), 4) + m2, b3 += "uc" + A2(y2.length, 2) + y2);
var E2 = "";
return E2 += "\n\0", E2 += A2(S2, 2), E2 += u2.magic, E2 += A2(a2, 2), E2 += A2(o2, 2), E2 += A2(x2.crc32, 4), E2 += A2(x2.compressedSize, 4), E2 += A2(x2.uncompressedSize, 4), E2 += A2(f3.length, 2), E2 += A2(b3.length, 2), { fileRecord: R2.LOCAL_FILE_HEADER + E2 + f3 + b3, dirRecord: R2.CENTRAL_FILE_HEADER + A2(C2, 2) + E2 + A2(p2.length, 2) + "\0\0\0\0" + A2(z2, 4) + A2(n4, 4) + f3 + b3 + p2 };
}
var I2 = e3("../utils"), i3 = e3("../stream/GenericWorker"), O = e3("../utf8"), B2 = e3("../crc32"), R2 = e3("../signature");
function s3(e4, t4, r4, n4) {
i3.call(this, "ZipFileWorker"), this.bytesWritten = 0, this.zipComment = t4, this.zipPlatform = r4, this.encodeFileName = n4, this.streamFiles = e4, this.accumulate = false, this.contentBuffer = [], this.dirRecords = [], this.currentSourceOffset = 0, this.entriesCount = 0, this.currentFile = null, this._sources = [];
}
I2.inherits(s3, i3), s3.prototype.push = function(e4) {
var t4 = e4.meta.percent || 0, r4 = this.entriesCount, n4 = this._sources.length;
this.accumulate ? this.contentBuffer.push(e4) : (this.bytesWritten += e4.data.length, i3.prototype.push.call(this, { data: e4.data, meta: { currentFile: this.currentFile, percent: r4 ? (t4 + 100 * (r4 - n4 - 1)) / r4 : 100 } }));
}, s3.prototype.openedSource = function(e4) {
this.currentSourceOffset = this.bytesWritten, this.currentFile = e4.file.name;
var t4 = this.streamFiles && !e4.file.dir;
if (t4) {
var r4 = n3(e4, t4, false, this.currentSourceOffset, this.zipPlatform, this.encodeFileName);
this.push({ data: r4.fileRecord, meta: { percent: 0 } });
} else this.accumulate = true;
}, s3.prototype.closedSource = function(e4) {
this.accumulate = false;
var t4 = this.streamFiles && !e4.file.dir, r4 = n3(e4, t4, true, this.currentSourceOffset, this.zipPlatform, this.encodeFileName);
if (this.dirRecords.push(r4.dirRecord), t4) this.push({ data: function(e5) {
return R2.DATA_DESCRIPTOR + A2(e5.crc32, 4) + A2(e5.compressedSize, 4) + A2(e5.uncompressedSize, 4);
}(e4), meta: { percent: 100 } });
else for (this.push({ data: r4.fileRecord, meta: { percent: 0 } }); this.contentBuffer.length; ) this.push(this.contentBuffer.shift());
this.currentFile = null;
}, s3.prototype.flush = function() {
for (var e4 = this.bytesWritten, t4 = 0; t4 < this.dirRecords.length; t4++) this.push({ data: this.dirRecords[t4], meta: { percent: 100 } });
var r4 = this.bytesWritten - e4, n4 = function(e5, t5, r5, n5, i4) {
var s4 = I2.transformTo("string", i4(n5));
return R2.CENTRAL_DIRECTORY_END + "\0\0\0\0" + A2(e5, 2) + A2(e5, 2) + A2(t5, 4) + A2(r5, 4) + A2(s4.length, 2) + s4;
}(this.dirRecords.length, r4, e4, this.zipComment, this.encodeFileName);
this.push({ data: n4, meta: { percent: 100 } });
}, s3.prototype.prepareNextSource = function() {
this.previous = this._sources.shift(), this.openedSource(this.previous.streamInfo), this.isPaused ? this.previous.pause() : this.previous.resume();
}, s3.prototype.registerPrevious = function(e4) {
this._sources.push(e4);
var t4 = this;
return e4.on("data", function(e5) {
t4.processChunk(e5);
}), e4.on("end", function() {
t4.closedSource(t4.previous.streamInfo), t4._sources.length ? t4.prepareNextSource() : t4.end();
}), e4.on("error", function(e5) {
t4.error(e5);
}), this;
}, s3.prototype.resume = function() {
return !!i3.prototype.resume.call(this) && (!this.previous && this._sources.length ? (this.prepareNextSource(), true) : this.previous || this._sources.length || this.generatedError ? void 0 : (this.end(), true));
}, s3.prototype.error = function(e4) {
var t4 = this._sources;
if (!i3.prototype.error.call(this, e4)) return false;
for (var r4 = 0; r4 < t4.length; r4++) try {
t4[r4].error(e4);
} catch (e5) {
}
return true;
}, s3.prototype.lock = function() {
i3.prototype.lock.call(this);
for (var e4 = this._sources, t4 = 0; t4 < e4.length; t4++) e4[t4].lock();
}, t3.exports = s3;
}, { "../crc32": 4, "../signature": 23, "../stream/GenericWorker": 28, "../utf8": 31, "../utils": 32 }], 9: [function(e3, t3, r3) {
var u2 = e3("../compressions"), n3 = e3("./ZipFileWorker");
r3.generateWorker = function(e4, a2, t4) {
var o2 = new n3(a2.streamFiles, t4, a2.platform, a2.encodeFileName), h3 = 0;
try {
e4.forEach(function(e5, t5) {
h3++;
var r4 = function(e6, t6) {
var r5 = e6 || t6, n5 = u2[r5];
if (!n5) throw new Error(r5 + " is not a valid compression method !");
return n5;
}(t5.options.compression, a2.compression), n4 = t5.options.compressionOptions || a2.compressionOptions || {}, i3 = t5.dir, s3 = t5.date;
t5._compressWorker(r4, n4).withStreamInfo("file", { name: e5, dir: i3, date: s3, comment: t5.comment || "", unixPermissions: t5.unixPermissions, dosPermissions: t5.dosPermissions }).pipe(o2);
}), o2.entriesCount = h3;
} catch (e5) {
o2.error(e5);
}
return o2;
};
}, { "../compressions": 3, "./ZipFileWorker": 8 }], 10: [function(e3, t3, r3) {
function n3() {
if (!(this instanceof n3)) return new n3();
if (arguments.length) throw new Error("The constructor with parameters has been removed in JSZip 3.0, please check the upgrade guide.");
this.files = /* @__PURE__ */ Object.create(null), this.comment = null, this.root = "", this.clone = function() {
var e4 = new n3();
for (var t4 in this) "function" != typeof this[t4] && (e4[t4] = this[t4]);
return e4;
};
}
(n3.prototype = e3("./object")).loadAsync = e3("./load"), n3.support = e3("./support"), n3.defaults = e3("./defaults"), n3.version = "3.10.1", n3.loadAsync = function(e4, t4) {
return new n3().loadAsync(e4, t4);
}, n3.external = e3("./external"), t3.exports = n3;
}, { "./defaults": 5, "./external": 6, "./load": 11, "./object": 15, "./support": 30 }], 11: [function(e3, t3, r3) {
var u2 = e3("./utils"), i3 = e3("./external"), n3 = e3("./utf8"), s3 = e3("./zipEntries"), a2 = e3("./stream/Crc32Probe"), l2 = e3("./nodejsUtils");
function f3(n4) {
return new i3.Promise(function(e4, t4) {
var r4 = n4.decompressed.getContentWorker().pipe(new a2());
r4.on("error", function(e5) {
t4(e5);
}).on("end", function() {
r4.streamInfo.crc32 !== n4.decompressed.crc32 ? t4(new Error("Corrupted zip : CRC32 mismatch")) : e4();
}).resume();
});
}
t3.exports = function(e4, o2) {
var h3 = this;
return o2 = u2.extend(o2 || {}, { base64: false, checkCRC32: false, optimizedBinaryString: false, createFolders: false, decodeFileName: n3.utf8decode }), l2.isNode && l2.isStream(e4) ? i3.Promise.reject(new Error("JSZip can't accept a stream when loading a zip file.")) : u2.prepareContent("the loaded zip file", e4, true, o2.optimizedBinaryString, o2.base64).then(function(e5) {
var t4 = new s3(o2);
return t4.load(e5), t4;
}).then(function(e5) {
var t4 = [i3.Promise.resolve(e5)], r4 = e5.files;
if (o2.checkCRC32) for (var n4 = 0; n4 < r4.length; n4++) t4.push(f3(r4[n4]));
return i3.Promise.all(t4);
}).then(function(e5) {
for (var t4 = e5.shift(), r4 = t4.files, n4 = 0; n4 < r4.length; n4++) {
var i4 = r4[n4], s4 = i4.fileNameStr, a3 = u2.resolve(i4.fileNameStr);
h3.file(a3, i4.decompressed, { binary: true, optimizedBinaryString: true, date: i4.date, dir: i4.dir, comment: i4.fileCommentStr.length ? i4.fileCommentStr : null, unixPermissions: i4.unixPermissions, dosPermissions: i4.dosPermissions, createFolders: o2.createFolders }), i4.dir || (h3.file(a3).unsafeOriginalName = s4);
}
return t4.zipComment.length && (h3.comment = t4.zipComment), h3;
});
};
}, { "./external": 6, "./nodejsUtils": 14, "./stream/Crc32Probe": 25, "./utf8": 31, "./utils": 32, "./zipEntries": 33 }], 12: [function(e3, t3, r3) {
var n3 = e3("../utils"), i3 = e3("../stream/GenericWorker");
function s3(e4, t4) {
i3.call(this, "Nodejs stream input adapter for " + e4), this._upstreamEnded = false, this._bindStream(t4);
}
n3.inherits(s3, i3), s3.prototype._bindStream = function(e4) {
var t4 = this;
(this._stream = e4).pause(), e4.on("data", function(e5) {
t4.push({ data: e5, meta: { percent: 0 } });
}).on("error", function(e5) {
t4.isPaused ? this.generatedError = e5 : t4.error(e5);
}).on("end", function() {
t4.isPaused ? t4._upstreamEnded = true : t4.end();
});
}, s3.prototype.pause = function() {
return !!i3.prototype.pause.call(this) && (this._stream.pause(), true);
}, s3.prototype.resume = function() {
return !!i3.prototype.resume.call(this) && (this._upstreamEnded ? this.end() : this._stream.resume(), true);
}, t3.exports = s3;
}, { "../stream/GenericWorker": 28, "../utils": 32 }], 13: [function(e3, t3, r3) {
var i3 = e3("readable-stream").Readable;
function n3(e4, t4, r4) {
i3.call(this, t4), this._helper = e4;
var n4 = this;
e4.on("data", function(e5, t5) {
n4.push(e5) || n4._helper.pause(), r4 && r4(t5);
}).on("error", function(e5) {
n4.emit("error", e5);
}).on("end", function() {
n4.push(null);
});
}
e3("../utils").inherits(n3, i3), n3.prototype._read = function() {
this._helper.resume();
}, t3.exports = n3;
}, { "../utils": 32, "readable-stream": 16 }], 14: [function(e3, t3, r3) {
t3.exports = { isNode: "undefined" != typeof Buffer, newBufferFrom: function(e4, t4) {
if (Buffer.from && Buffer.from !== Uint8Array.from) return Buffer.from(e4, t4);
if ("number" == typeof e4) throw new Error('The "data" argument must not be a number');
return new Buffer(e4, t4);
}, allocBuffer: function(e4) {
if (Buffer.alloc) return Buffer.alloc(e4);
var t4 = new Buffer(e4);
return t4.fill(0), t4;
}, isBuffer: function(e4) {
return Buffer.isBuffer(e4);
}, isStream: function(e4) {
return e4 && "function" == typeof e4.on && "function" == typeof e4.pause && "function" == typeof e4.resume;
} };
}, {}], 15: [function(e3, t3, r3) {
function s3(e4, t4, r4) {
var n4, i4 = u2.getTypeOf(t4), s4 = u2.extend(r4 || {}, f3);
s4.date = s4.date || /* @__PURE__ */ new Date(), null !== s4.compression && (s4.compression = s4.compression.toUpperCase()), "string" == typeof s4.unixPermissions && (s4.unixPermissions = parseInt(s4.unixPermissions, 8)), s4.unixPermissions && 16384 & s4.unixPermissions && (s4.dir = true), s4.dosPermissions && 16 & s4.dosPermissions && (s4.dir = true), s4.dir && (e4 = g2(e4)), s4.createFolders && (n4 = _2(e4)) && b3.call(this, n4, true);
var a3 = "string" === i4 && false === s4.binary && false === s4.base64;
r4 && void 0 !== r4.binary || (s4.binary = !a3), (t4 instanceof c3 && 0 === t4.uncompressedSize || s4.dir || !t4 || 0 === t4.length) && (s4.base64 = false, s4.binary = true, t4 = "", s4.compression = "STORE", i4 = "string");
var o3 = null;
o3 = t4 instanceof c3 || t4 instanceof l2 ? t4 : p2.isNode && p2.isStream(t4) ? new m2(e4, t4) : u2.prepareContent(e4, t4, s4.binary, s4.optimizedBinaryString, s4.base64);
var h4 = new d2(e4, o3, s4);
this.files[e4] = h4;
}
var i3 = e3("./utf8"), u2 = e3("./utils"), l2 = e3("./stream/GenericWorker"), a2 = e3("./stream/StreamHelper"), f3 = e3("./defaults"), c3 = e3("./compressedObject"), d2 = e3("./zipObject"), o2 = e3("./generate"), p2 = e3("./nodejsUtils"), m2 = e3("./nodejs/NodejsStreamInputAdapter"), _2 = function(e4) {
"/" === e4.slice(-1) && (e4 = e4.substring(0, e4.length - 1));
var t4 = e4.lastIndexOf("/");
return 0 < t4 ? e4.substring(0, t4) : "";
}, g2 = function(e4) {
return "/" !== e4.slice(-1) && (e4 += "/"), e4;
}, b3 = function(e4, t4) {
return t4 = void 0 !== t4 ? t4 : f3.createFolders, e4 = g2(e4), this.files[e4] || s3.call(this, e4, null, { dir: true, createFolders: t4 }), this.files[e4];
};
function h3(e4) {
return "[object RegExp]" === Object.prototype.toString.call(e4);
}
var n3 = { load: function() {
throw new Error("This method has been removed in JSZip 3.0, please check the upgrade guide.");
}, forEach: function(e4) {
var t4, r4, n4;
for (t4 in this.files) n4 = this.files[t4], (r4 = t4.slice(this.root.length, t4.length)) && t4.slice(0, this.root.length) === this.root && e4(r4, n4);
}, filter: function(r4) {
var n4 = [];
return this.forEach(function(e4, t4) {
r4(e4, t4) && n4.push(t4);
}), n4;
}, file: function(e4, t4, r4) {
if (1 !== arguments.length) return e4 = this.root + e4, s3.call(this, e4, t4, r4), this;
if (h3(e4)) {
var n4 = e4;
return this.filter(function(e5, t5) {
return !t5.dir && n4.test(e5);
});
}
var i4 = this.files[this.root + e4];
return i4 && !i4.dir ? i4 : null;
}, folder: function(r4) {
if (!r4) return this;
if (h3(r4)) return this.filter(function(e5, t5) {
return t5.dir && r4.test(e5);
});
var e4 = this.root + r4, t4 = b3.call(this, e4), n4 = this.clone();
return n4.root = t4.name, n4;
}, remove: function(r4) {
r4 = this.root + r4;
var e4 = this.files[r4];
if (e4 || ("/" !== r4.slice(-1) && (r4 += "/"), e4 = this.files[r4]), e4 && !e4.dir) delete this.files[r4];
else for (var t4 = this.filter(function(e5, t5) {
return t5.name.slice(0, r4.length) === r4;
}), n4 = 0; n4 < t4.length; n4++) delete this.files[t4[n4].name];
return this;
}, generate: function() {
throw new Error("This method has been removed in JSZip 3.0, please check the upgrade guide.");
}, generateInternalStream: function(e4) {
var t4, r4 = {};
try {
if ((r4 = u2.extend(e4 || {}, { streamFiles: false, compression: "STORE", compressionOptions: null, type: "", platform: "DOS", comment: null, mimeType: "application/zip", encodeFileName: i3.utf8encode })).type = r4.type.toLowerCase(), r4.compression = r4.compression.toUpperCase(), "binarystring" === r4.type && (r4.type = "string"), !r4.type) throw new Error("No output type specified.");
u2.checkSupport(r4.type), "darwin" !== r4.platform && "freebsd" !== r4.platform && "linux" !== r4.platform && "sunos" !== r4.platform || (r4.platform = "UNIX"), "win32" === r4.platform && (r4.platform = "DOS");
var n4 = r4.comment || this.comment || "";
t4 = o2.generateWorker(this, r4, n4);
} catch (e5) {
(t4 = new l2("error")).error(e5);
}
return new a2(t4, r4.type || "string", r4.mimeType);
}, generateAsync: function(e4, t4) {
return this.generateInternalStream(e4).accumulate(t4);
}, generateNodeStream: function(e4, t4) {
return (e4 = e4 || {}).type || (e4.type = "nodebuffer"), this.generateInternalStream(e4).toNodejsStream(t4);
} };
t3.exports = n3;
}, { "./compressedObject": 2, "./defaults": 5, "./generate": 9, "./nodejs/NodejsStreamInputAdapter": 12, "./nodejsUtils": 14, "./stream/GenericWorker": 28, "./stream/StreamHelper": 29, "./utf8": 31, "./utils": 32, "./zipObject": 35 }], 16: [function(e3, t3, r3) {
t3.exports = e3("stream");
}, { stream: void 0 }], 17: [function(e3, t3, r3) {
var n3 = e3("./DataReader");
function i3(e4) {
n3.call(this, e4);
for (var t4 = 0; t4 < this.data.length; t4++) e4[t4] = 255 & e4[t4];
}
e3("../utils").inherits(i3, n3), i3.prototype.byteAt = function(e4) {
return this.data[this.zero + e4];
}, i3.prototype.lastIndexOfSignature = function(e4) {
for (var t4 = e4.charCodeAt(0), r4 = e4.charCodeAt(1), n4 = e4.charCodeAt(2), i4 = e4.charCodeAt(3), s3 = this.length - 4; 0 <= s3; --s3) if (this.data[s3] === t4 && this.data[s3 + 1] === r4 && this.data[s3 + 2] === n4 && this.data[s3 + 3] === i4) return s3 - this.zero;
return -1;
}, i3.prototype.readAndCheckSignature = function(e4) {
var t4 = e4.charCodeAt(0), r4 = e4.charCodeAt(1), n4 = e4.charCodeAt(2), i4 = e4.charCodeAt(3), s3 = this.readData(4);
return t4 === s3[0] && r4 === s3[1] && n4 === s3[2] && i4 === s3[3];
}, i3.prototype.readData = function(e4) {
if (this.checkOffset(e4), 0 === e4) return [];
var t4 = this.data.slice(this.zero + this.index, this.zero + this.index + e4);
return this.index += e4, t4;
}, t3.exports = i3;
}, { "../utils": 32, "./DataReader": 18 }], 18: [function(e3, t3, r3) {
var n3 = e3("../utils");
function i3(e4) {
this.data = e4, this.length = e4.length, this.index = 0, this.zero = 0;
}
i3.prototype = { checkOffset: function(e4) {
this.checkIndex(this.index + e4);
}, checkIndex: function(e4) {
if (this.length < this.zero + e4 || e4 < 0) throw new Error("End of data reached (data length = " + this.length + ", asked index = " + e4 + "). Corrupted zip ?");
}, setIndex: function(e4) {
this.checkIndex(e4), this.index = e4;
}, skip: function(e4) {
this.setIndex(this.index + e4);
}, byteAt: function() {
}, readInt: function(e4) {
var t4, r4 = 0;
for (this.checkOffset(e4), t4 = this.index + e4 - 1; t4 >= this.index; t4--) r4 = (r4 << 8) + this.byteAt(t4);
return this.index += e4, r4;
}, readString: function(e4) {
return n3.transformTo("string", this.readData(e4));
}, readData: function() {
}, lastIndexOfSignature: function() {
}, readAndCheckSignature: function() {
}, readDate: function() {
var e4 = this.readInt(4);
return new Date(Date.UTC(1980 + (e4 >> 25 & 127), (e4 >> 21 & 15) - 1, e4 >> 16 & 31, e4 >> 11 & 31, e4 >> 5 & 63, (31 & e4) << 1));
} }, t3.exports = i3;
}, { "../utils": 32 }], 19: [function(e3, t3, r3) {
var n3 = e3("./Uint8ArrayReader");
function i3(e4) {
n3.call(this, e4);
}
e3("../utils").inherits(i3, n3), i3.prototype.readData = function(e4) {
this.checkOffset(e4);
var t4 = this.data.slice(this.zero + this.index, this.zero + this.index + e4);
return this.index += e4, t4;
}, t3.exports = i3;
}, { "../utils": 32, "./Uint8ArrayReader": 21 }], 20: [function(e3, t3, r3) {
var n3 = e3("./DataReader");
function i3(e4) {
n3.call(this, e4);
}
e3("../utils").inherits(i3, n3), i3.prototype.byteAt = function(e4) {
return this.data.charCodeAt(this.zero + e4);
}, i3.prototype.lastIndexOfSignature = function(e4) {
return this.data.lastIndexOf(e4) - this.zero;
}, i3.prototype.readAndCheckSignature = function(e4) {
return e4 === this.readData(4);
}, i3.prototype.readData = function(e4) {
this.checkOffset(e4);
var t4 = this.data.slice(this.zero + this.index, this.zero + this.index + e4);
return this.index += e4, t4;
}, t3.exports = i3;
}, { "../utils": 32, "./DataReader": 18 }], 21: [function(e3, t3, r3) {
var n3 = e3("./ArrayReader");
function i3(e4) {
n3.call(this, e4);
}
e3("../utils").inherits(i3, n3), i3.prototype.readData = function(e4) {
if (this.checkOffset(e4), 0 === e4) return new Uint8Array(0);
var t4 = this.data.subarray(this.zero + this.index, this.zero + this.index + e4);
return this.index += e4, t4;
}, t3.exports = i3;
}, { "../utils": 32, "./ArrayReader": 17 }], 22: [function(e3, t3, r3) {
var n3 = e3("../utils"), i3 = e3("../support"), s3 = e3("./ArrayReader"), a2 = e3("./StringReader"), o2 = e3("./NodeBufferReader"), h3 = e3("./Uint8ArrayReader");
t3.exports = function(e4) {
var t4 = n3.getTypeOf(e4);
return n3.checkSupport(t4), "string" !== t4 || i3.uint8array ? "nodebuffer" === t4 ? new o2(e4) : i3.uint8array ? new h3(n3.transformTo("uint8array", e4)) : new s3(n3.transformTo("array", e4)) : new a2(e4);
};
}, { "../support": 30, "../utils": 32, "./ArrayReader": 17, "./NodeBufferReader": 19, "./StringReader": 20, "./Uint8ArrayReader": 21 }], 23: [function(e3, t3, r3) {
r3.LOCAL_FILE_HEADER = "PK", r3.CENTRAL_FILE_HEADER = "PK", r3.CENTRAL_DIRECTORY_END = "PK", r3.ZIP64_CENTRAL_DIRECTORY_LOCATOR = "PK\x07", r3.ZIP64_CENTRAL_DIRECTORY_END = "PK", r3.DATA_DESCRIPTOR = "PK\x07\b";
}, {}], 24: [function(e3, t3, r3) {
var n3 = e3("./GenericWorker"), i3 = e3("../utils");
function s3(e4) {
n3.call(this, "ConvertWorker to " + e4), this.destType = e4;
}
i3.inherits(s3, n3), s3.prototype.processChunk = function(e4) {
this.push({ data: i3.transformTo(this.destType, e4.data), meta: e4.meta });
}, t3.exports = s3;
}, { "../utils": 32, "./GenericWorker": 28 }], 25: [function(e3, t3, r3) {
var n3 = e3("./GenericWorker"), i3 = e3("../crc32");
function s3() {
n3.call(this, "Crc32Probe"), this.withStreamInfo("crc32", 0);
}
e3("../utils").inherits(s3, n3), s3.prototype.processChunk = function(e4) {
this.streamInfo.crc32 = i3(e4.data, this.streamInfo.crc32 || 0), this.push(e4);
}, t3.exports = s3;
}, { "../crc32": 4, "../utils": 32, "./GenericWorker": 28 }], 26: [function(e3, t3, r3) {
var n3 = e3("../utils"), i3 = e3("./GenericWorker");
function s3(e4) {
i3.call(this, "DataLengthProbe for " + e4), this.propName = e4, this.withStreamInfo(e4, 0);
}
n3.inherits(s3, i3), s3.prototype.processChunk = function(e4) {
if (e4) {
var t4 = this.streamInfo[this.propName] || 0;
this.streamInfo[this.propName] = t4 + e4.data.length;
}
i3.prototype.processChunk.call(this, e4);
}, t3.exports = s3;
}, { "../utils": 32, "./GenericWorker": 28 }], 27: [function(e3, t3, r3) {
var n3 = e3("../utils"), i3 = e3("./GenericWorker");
function s3(e4) {
i3.call(this, "DataWorker");
var t4 = this;
this.dataIsReady = false, this.index = 0, this.max = 0, this.data = null, this.type = "", this._tickScheduled = false, e4.then(function(e5) {
t4.dataIsReady = true, t4.data = e5, t4.max = e5 && e5.length || 0, t4.type = n3.getTypeOf(e5), t4.isPaused || t4._tickAndRepeat();
}, function(e5) {
t4.error(e5);
});
}
n3.inherits(s3, i3), s3.prototype.cleanUp = function() {
i3.prototype.cleanUp.call(this), this.data = null;
}, s3.prototype.resume = function() {
return !!i3.prototype.resume.call(this) && (!this._tickScheduled && this.dataIsReady && (this._tickScheduled = true, n3.delay(this._tickAndRepeat, [], this)), true);
}, s3.prototype._tickAndRepeat = function() {
this._tickScheduled = false, this.isPaused || this.isFinished || (this._tick(), this.isFinished || (n3.delay(this._tickAndRepeat, [], this), this._tickScheduled = true));
}, s3.prototype._tick = function() {
if (this.isPaused || this.isFinished) return false;
var e4 = null, t4 = Math.min(this.max, this.index + 16384);
if (this.index >= this.max) return this.end();
switch (this.type) {
case "string":
e4 = this.data.substring(this.index, t4);
break;
case "uint8array":
e4 = this.data.subarray(this.index, t4);
break;
case "array":
case "nodebuffer":
e4 = this.data.slice(this.index, t4);
}
return this.index = t4, this.push({ data: e4, meta: { percent: this.max ? this.index / this.max * 100 : 0 } });
}, t3.exports = s3;
}, { "../utils": 32, "./GenericWorker": 28 }], 28: [function(e3, t3, r3) {
function n3(e4) {
this.name = e4 || "default", this.streamInfo = {}, this.generatedError = null, this.extraStreamInfo = {}, this.isPaused = true, this.isFinished = false, this.isLocked = false, this._listeners = { data: [], end: [], error: [] }, this.previous = null;
}
n3.prototype = { push: function(e4) {
this.emit("data", e4);
}, end: function() {
if (this.isFinished) return false;
this.flush();
try {
this.emit("end"), this.cleanUp(), this.isFinished = true;
} catch (e4) {
this.emit("error", e4);
}
return true;
}, error: function(e4) {
return !this.isFinished && (this.isPaused ? this.generatedError = e4 : (this.isFinished = true, this.emit("error", e4), this.previous && this.previous.error(e4), this.cleanUp()), true);
}, on: function(e4, t4) {
return this._listeners[e4].push(t4), this;
}, cleanUp: function() {
this.streamInfo = this.generatedError = this.extraStreamInfo = null, this._listeners = [];
}, emit: function(e4, t4) {
if (this._listeners[e4]) for (var r4 = 0; r4 < this._listeners[e4].length; r4++) this._listeners[e4][r4].call(this, t4);
}, pipe: function(e4) {
return e4.registerPrevious(this);
}, registerPrevious: function(e4) {
if (this.isLocked) throw new Error("The stream '" + this + "' has already been used.");
this.streamInfo = e4.streamInfo, this.mergeStreamInfo(), this.previous = e4;
var t4 = this;
return e4.on("data", function(e5) {
t4.processChunk(e5);
}), e4.on("end", function() {
t4.end();
}), e4.on("error", function(e5) {
t4.error(e5);
}), this;
}, pause: function() {
return !this.isPaused && !this.isFinished && (this.isPaused = true, this.previous && this.previous.pause(), true);
}, resume: function() {
if (!this.isPaused || this.isFinished) return false;
var e4 = this.isPaused = false;
return this.generatedError && (this.error(this.generatedError), e4 = true), this.previous && this.previous.resume(), !e4;
}, flush: function() {
}, processChunk: function(e4) {
this.push(e4);
}, withStreamInfo: function(e4, t4) {
return this.extraStreamInfo[e4] = t4, this.mergeStreamInfo(), this;
}, mergeStreamInfo: function() {
for (var e4 in this.extraStreamInfo) Object.prototype.hasOwnProperty.call(this.extraStreamInfo, e4) && (this.streamInfo[e4] = this.extraStreamInfo[e4]);
}, lock: function() {
if (this.isLocked) throw new Error("The stream '" + this + "' has already been used.");
this.isLocked = true, this.previous && this.previous.lock();
}, toString: function() {
var e4 = "Worker " + this.name;
return this.previous ? this.previous + " -> " + e4 : e4;
} }, t3.exports = n3;
}, {}], 29: [function(e3, t3, r3) {
var h3 = e3("../utils"), i3 = e3("./ConvertWorker"), s3 = e3("./GenericWorker"), u2 = e3("../base64"), n3 = e3("../support"), a2 = e3("../external"), o2 = null;
if (n3.nodestream) try {
o2 = e3("../nodejs/NodejsStreamOutputAdapter");
} catch (e4) {
}
function l2(e4, o3) {
return new a2.Promise(function(t4, r4) {
var n4 = [], i4 = e4._internalType, s4 = e4._outputType, a3 = e4._mimeType;
e4.on("data", function(e5, t5) {
n4.push(e5), o3 && o3(t5);
}).on("error", function(e5) {
n4 = [], r4(e5);
}).on("end", function() {
try {
var e5 = function(e6, t5, r5) {
switch (e6) {
case "blob":
return h3.newBlob(h3.transformTo("arraybuffer", t5), r5);
case "base64":
return u2.encode(t5);
default:
return h3.transformTo(e6, t5);
}
}(s4, function(e6, t5) {
var r5, n5 = 0, i5 = null, s5 = 0;
for (r5 = 0; r5 < t5.length; r5++) s5 += t5[r5].length;
switch (e6) {
case "string":
return t5.join("");
case "array":
return Array.prototype.concat.apply([], t5);
case "uint8array":
for (i5 = new Uint8Array(s5), r5 = 0; r5 < t5.length; r5++) i5.set(t5[r5], n5), n5 += t5[r5].length;
return i5;
case "nodebuffer":
return Buffer.concat(t5);
default:
throw new Error("concat : unsupported type '" + e6 + "'");
}
}(i4, n4), a3);
t4(e5);
} catch (e6) {
r4(e6);
}
n4 = [];
}).resume();
});
}
function f3(e4, t4, r4) {
var n4 = t4;
switch (t4) {
case "blob":
case "arraybuffer":
n4 = "uint8array";
break;
case "base64":
n4 = "string";
}
try {
this._internalType = n4, this._outputType = t4, this._mimeType = r4, h3.checkSupport(n4), this._worker = e4.pipe(new i3(n4)), e4.lock();
} catch (e5) {
this._worker = new s3("error"), this._worker.error(e5);
}
}
f3.prototype = { accumulate: function(e4) {
return l2(this, e4);
}, on: function(e4, t4) {
var r4 = this;
return "data" === e4 ? this._worker.on(e4, function(e5) {
t4.call(r4, e5.data, e5.meta);
}) : this._worker.on(e4, function() {
h3.delay(t4, arguments, r4);
}), this;
}, resume: function() {
return h3.delay(this._worker.resume, [], this._worker), this;
}, pause: function() {
return this._worker.pause(), this;
}, toNodejsStream: function(e4) {
if (h3.checkSupport("nodestream"), "nodebuffer" !== this._outputType) throw new Error(this._outputType + " is not supported by this method");
return new o2(this, { objectMode: "nodebuffer" !== this._outputType }, e4);
} }, t3.exports = f3;
}, { "../base64": 1, "../external": 6, "../nodejs/NodejsStreamOutputAdapter": 13, "../support": 30, "../utils": 32, "./ConvertWorker": 24, "./GenericWorker": 28 }], 30: [function(e3, t3, r3) {
if (r3.base64 = true, r3.array = true, r3.string = true, r3.arraybuffer = "undefined" != typeof ArrayBuffer && "undefined" != typeof Uint8Array, r3.nodebuffer = "undefined" != typeof Buffer, r3.uint8array = "undefined" != typeof Uint8Array, "undefined" == typeof ArrayBuffer) r3.blob = false;
else {
var n3 = new ArrayBuffer(0);
try {
r3.blob = 0 === new Blob([n3], { type: "application/zip" }).size;
} catch (e4) {
try {
var i3 = new (self.BlobBuilder || self.WebKitBlobBuilder || self.MozBlobBuilder || self.MSBlobBuilder)();
i3.append(n3), r3.blob = 0 === i3.getBlob("application/zip").size;
} catch (e5) {
r3.blob = false;
}
}
}
try {
r3.nodestream = !!e3("readable-stream").Readable;
} catch (e4) {
r3.nodestream = false;
}
}, { "readable-stream": 16 }], 31: [function(e3, t3, s3) {
for (var o2 = e3("./utils"), h3 = e3("./support"), r3 = e3("./nodejsUtils"), n3 = e3("./stream/GenericWorker"), u2 = new Array(256), i3 = 0; i3 < 256; i3++) u2[i3] = 252 <= i3 ? 6 : 248 <= i3 ? 5 : 240 <= i3 ? 4 : 224 <= i3 ? 3 : 192 <= i3 ? 2 : 1;
u2[254] = u2[254] = 1;
function a2() {
n3.call(this, "utf-8 decode"), this.leftOver = null;
}
function l2() {
n3.call(this, "utf-8 encode");
}
s3.utf8encode = function(e4) {
return h3.nodebuffer ? r3.newBufferFrom(e4, "utf-8") : function(e5) {
var t4, r4, n4, i4, s4, a3 = e5.length, o3 = 0;
for (i4 = 0; i4 < a3; i4++) 55296 == (64512 & (r4 = e5.charCodeAt(i4))) && i4 + 1 < a3 && 56320 == (64512 & (n4 = e5.charCodeAt(i4 + 1))) && (r4 = 65536 + (r4 - 55296 << 10) + (n4 - 56320), i4++), o3 += r4 < 128 ? 1 : r4 < 2048 ? 2 : r4 < 65536 ? 3 : 4;
for (t4 = h3.uint8array ? new Uint8Array(o3) : new Array(o3), i4 = s4 = 0; s4 < o3; i4++) 55296 == (64512 & (r4 = e5.charCodeAt(i4))) && i4 + 1 < a3 && 56320 == (64512 & (n4 = e5.charCodeAt(i4 + 1))) && (r4 = 65536 + (r4 - 55296 << 10) + (n4 - 56320), i4++), r4 < 128 ? t4[s4++] = r4 : (r4 < 2048 ? t4[s4++] = 192 | r4 >>> 6 : (r4 < 65536 ? t4[s4++] = 224 | r4 >>> 12 : (t4[s4++] = 240 | r4 >>> 18, t4[s4++] = 128 | r4 >>> 12 & 63), t4[s4++] = 128 | r4 >>> 6 & 63), t4[s4++] = 128 | 63 & r4);
return t4;
}(e4);
}, s3.utf8decode = function(e4) {
return h3.nodebuffer ? o2.transformTo("nodebuffer", e4).toString("utf-8") : function(e5) {
var t4, r4, n4, i4, s4 = e5.length, a3 = new Array(2 * s4);
for (t4 = r4 = 0; t4 < s4; ) if ((n4 = e5[t4++]) < 128) a3[r4++] = n4;
else if (4 < (i4 = u2[n4])) a3[r4++] = 65533, t4 += i4 - 1;
else {
for (n4 &= 2 === i4 ? 31 : 3 === i4 ? 15 : 7; 1 < i4 && t4 < s4; ) n4 = n4 << 6 | 63 & e5[t4++], i4--;
1 < i4 ? a3[r4++] = 65533 : n4 < 65536 ? a3[r4++] = n4 : (n4 -= 65536, a3[r4++] = 55296 | n4 >> 10 & 1023, a3[r4++] = 56320 | 1023 & n4);
}
return a3.length !== r4 && (a3.subarray ? a3 = a3.subarray(0, r4) : a3.length = r4), o2.applyFromCharCode(a3);
}(e4 = o2.transformTo(h3.uint8array ? "uint8array" : "array", e4));
}, o2.inherits(a2, n3), a2.prototype.processChunk = function(e4) {
var t4 = o2.transformTo(h3.uint8array ? "uint8array" : "array", e4.data);
if (this.leftOver && this.leftOver.length) {
if (h3.uint8array) {
var r4 = t4;
(t4 = new Uint8Array(r4.length + this.leftOver.length)).set(this.leftOver, 0), t4.set(r4, this.leftOver.length);
} else t4 = this.leftOver.concat(t4);
this.leftOver = null;
}
var n4 = function(e5, t5) {
var r5;
for ((t5 = t5 || e5.length) > e5.length && (t5 = e5.length), r5 = t5 - 1; 0 <= r5 && 128 == (192 & e5[r5]); ) r5--;
return r5 < 0 ? t5 : 0 === r5 ? t5 : r5 + u2[e5[r5]] > t5 ? r5 : t5;
}(t4), i4 = t4;
n4 !== t4.length && (h3.uint8array ? (i4 = t4.subarray(0, n4), this.leftOver = t4.subarray(n4, t4.length)) : (i4 = t4.slice(0, n4), this.leftOver = t4.slice(n4, t4.length))), this.push({ data: s3.utf8decode(i4), meta: e4.meta });
}, a2.prototype.flush = function() {
this.leftOver && this.leftOver.length && (this.push({ data: s3.utf8decode(this.leftOver), meta: {} }), this.leftOver = null);
}, s3.Utf8DecodeWorker = a2, o2.inherits(l2, n3), l2.prototype.processChunk = function(e4) {
this.push({ data: s3.utf8encode(e4.data), meta: e4.meta });
}, s3.Utf8EncodeWorker = l2;
}, { "./nodejsUtils": 14, "./stream/GenericWorker": 28, "./support": 30, "./utils": 32 }], 32: [function(e3, t3, a2) {
var o2 = e3("./support"), h3 = e3("./base64"), r3 = e3("./nodejsUtils"), u2 = e3("./external");
function n3(e4) {
return e4;
}
function l2(e4, t4) {
for (var r4 = 0; r4 < e4.length; ++r4) t4[r4] = 255 & e4.charCodeAt(r4);
return t4;
}
e3("setimmediate"), a2.newBlob = function(t4, r4) {
a2.checkSupport("blob");
try {
return new Blob([t4], { type: r4 });
} catch (e4) {
try {
var n4 = new (self.BlobBuilder || self.WebKitBlobBuilder || self.MozBlobBuilder || self.MSBlobBuilder)();
return n4.append(t4), n4.getBlob(r4);
} catch (e5) {
throw new Error("Bug : can't construct the Blob.");
}
}
};
var i3 = { stringifyByChunk: function(e4, t4, r4) {
var n4 = [], i4 = 0, s4 = e4.length;
if (s4 <= r4) return String.fromCharCode.apply(null, e4);
for (; i4 < s4; ) "array" === t4 || "nodebuffer" === t4 ? n4.push(String.fromCharCode.apply(null, e4.slice(i4, Math.min(i4 + r4, s4)))) : n4.push(String.fromCharCode.apply(null, e4.subarray(i4, Math.min(i4 + r4, s4)))), i4 += r4;
return n4.join("");
}, stringifyByChar: function(e4) {
for (var t4 = "", r4 = 0; r4 < e4.length; r4++) t4 += String.fromCharCode(e4[r4]);
return t4;
}, applyCanBeUsed: { uint8array: function() {
try {
return o2.uint8array && 1 === String.fromCharCode.apply(null, new Uint8Array(1)).length;
} catch (e4) {
return false;
}
}(), nodebuffer: function() {
try {
return o2.nodebuffer && 1 === String.fromCharCode.apply(null, r3.allocBuffer(1)).length;
} catch (e4) {
return false;
}
}() } };
function s3(e4) {
var t4 = 65536, r4 = a2.getTypeOf(e4), n4 = true;
if ("uint8array" === r4 ? n4 = i3.applyCanBeUsed.uint8array : "nodebuffer" === r4 && (n4 = i3.applyCanBeUsed.nodebuffer), n4) for (; 1 < t4; ) try {
return i3.stringifyByChunk(e4, r4, t4);
} catch (e5) {
t4 = Math.floor(t4 / 2);
}
return i3.stringifyByChar(e4);
}
function f3(e4, t4) {
for (var r4 = 0; r4 < e4.length; r4++) t4[r4] = e4[r4];
return t4;
}
a2.applyFromCharCode = s3;
var c3 = {};
c3.string = { string: n3, array: function(e4) {
return l2(e4, new Array(e4.length));
}, arraybuffer: function(e4) {
return c3.string.uint8array(e4).buffer;
}, uint8array: function(e4) {
return l2(e4, new Uint8Array(e4.length));
}, nodebuffer: function(e4) {
return l2(e4, r3.allocBuffer(e4.length));
} }, c3.array = { string: s3, array: n3, arraybuffer: function(e4) {
return new Uint8Array(e4).buffer;
}, uint8array: function(e4) {
return new Uint8Array(e4);
}, nodebuffer: function(e4) {
return r3.newBufferFrom(e4);
} }, c3.arraybuffer = { string: function(e4) {
return s3(new Uint8Array(e4));
}, array: function(e4) {
return f3(new Uint8Array(e4), new Array(e4.byteLength));
}, arraybuffer: n3, uint8array: function(e4) {
return new Uint8Array(e4);
}, nodebuffer: function(e4) {
return r3.newBufferFrom(new Uint8Array(e4));
} }, c3.uint8array = { string: s3, array: function(e4) {
return f3(e4, new Array(e4.length));
}, arraybuffer: function(e4) {
return e4.buffer;
}, uint8array: n3, nodebuffer: function(e4) {
return r3.newBufferFrom(e4);
} }, c3.nodebuffer = { string: s3, array: function(e4) {
return f3(e4, new Array(e4.length));
}, arraybuffer: function(e4) {
return c3.nodebuffer.uint8array(e4).buffer;
}, uint8array: function(e4) {
return f3(e4, new Uint8Array(e4.length));
}, nodebuffer: n3 }, a2.transformTo = function(e4, t4) {
if (t4 = t4 || "", !e4) return t4;
a2.checkSupport(e4);
var r4 = a2.getTypeOf(t4);
return c3[r4][e4](t4);
}, a2.resolve = function(e4) {
for (var t4 = e4.split("/"), r4 = [], n4 = 0; n4 < t4.length; n4++) {
var i4 = t4[n4];
"." === i4 || "" === i4 && 0 !== n4 && n4 !== t4.length - 1 || (".." === i4 ? r4.pop() : r4.push(i4));
}
return r4.join("/");
}, a2.getTypeOf = function(e4) {
return "string" == typeof e4 ? "string" : "[object Array]" === Object.prototype.toString.call(e4) ? "array" : o2.nodebuffer && r3.isBuffer(e4) ? "nodebuffer" : o2.uint8array && e4 instanceof Uint8Array ? "uint8array" : o2.arraybuffer && e4 instanceof ArrayBuffer ? "arraybuffer" : void 0;
}, a2.checkSupport = function(e4) {
if (!o2[e4.toLowerCase()]) throw new Error(e4 + " is not supported by this platform");
}, a2.MAX_VALUE_16BITS = 65535, a2.MAX_VALUE_32BITS = -1, a2.pretty = function(e4) {
var t4, r4, n4 = "";
for (r4 = 0; r4 < (e4 || "").length; r4++) n4 += "\\x" + ((t4 = e4.charCodeAt(r4)) < 16 ? "0" : "") + t4.toString(16).toUpperCase();
return n4;
}, a2.delay = function(e4, t4, r4) {
setImmediate(function() {
e4.apply(r4 || null, t4 || []);
});
}, a2.inherits = function(e4, t4) {
function r4() {
}
r4.prototype = t4.prototype, e4.prototype = new r4();
}, a2.extend = function() {
var e4, t4, r4 = {};
for (e4 = 0; e4 < arguments.length; e4++) for (t4 in arguments[e4]) Object.prototype.hasOwnProperty.call(arguments[e4], t4) && void 0 === r4[t4] && (r4[t4] = arguments[e4][t4]);
return r4;
}, a2.prepareContent = function(r4, e4, n4, i4, s4) {
return u2.Promise.resolve(e4).then(function(n5) {
return o2.blob && (n5 instanceof Blob || -1 !== ["[object File]", "[object Blob]"].indexOf(Object.prototype.toString.call(n5))) && "undefined" != typeof FileReader ? new u2.Promise(function(t4, r5) {
var e5 = new FileReader();
e5.onload = function(e6) {
t4(e6.target.result);
}, e5.onerror = function(e6) {
r5(e6.target.error);
}, e5.readAsArrayBuffer(n5);
}) : n5;
}).then(function(e5) {
var t4 = a2.getTypeOf(e5);
return t4 ? ("arraybuffer" === t4 ? e5 = a2.transformTo("uint8array", e5) : "string" === t4 && (s4 ? e5 = h3.decode(e5) : n4 && true !== i4 && (e5 = function(e6) {
return l2(e6, o2.uint8array ? new Uint8Array(e6.length) : new Array(e6.length));
}(e5))), e5) : u2.Promise.reject(new Error("Can't read the data of '" + r4 + "'. Is it in a supported JavaScript type (String, Blob, ArrayBuffer, etc) ?"));
});
};
}, { "./base64": 1, "./external": 6, "./nodejsUtils": 14, "./support": 30, setimmediate: 54 }], 33: [function(e3, t3, r3) {
var n3 = e3("./reader/readerFor"), i3 = e3("./utils"), s3 = e3("./signature"), a2 = e3("./zipEntry"), o2 = e3("./support");
function h3(e4) {
this.files = [], this.loadOptions = e4;
}
h3.prototype = { checkSignature: function(e4) {
if (!this.reader.readAndCheckSignature(e4)) {
this.reader.index -= 4;
var t4 = this.reader.readString(4);
throw new Error("Corrupted zip or bug: unexpected signature (" + i3.pretty(t4) + ", expected " + i3.pretty(e4) + ")");
}
}, isSignature: function(e4, t4) {
var r4 = this.reader.index;
this.reader.setIndex(e4);
var n4 = this.reader.readString(4) === t4;
return this.reader.setIndex(r4), n4;
}, readBlockEndOfCentral: function() {
this.diskNumber = this.reader.readInt(2), this.diskWithCentralDirStart = this.reader.readInt(2), this.centralDirRecordsOnThisDisk = this.reader.readInt(2), this.centralDirRecords = this.reader.readInt(2), this.centralDirSize = this.reader.readInt(4), this.centralDirOffset = this.reader.readInt(4), this.zipCommentLength = this.reader.readInt(2);
var e4 = this.reader.readData(this.zipCommentLength), t4 = o2.uint8array ? "uint8array" : "array", r4 = i3.transformTo(t4, e4);
this.zipComment = this.loadOptions.decodeFileName(r4);
}, readBlockZip64EndOfCentral: function() {
this.zip64EndOfCentralSize = this.reader.readInt(8), this.reader.skip(4), this.diskNumber = this.reader.readInt(4), this.diskWithCentralDirStart = this.reader.readInt(4), this.centralDirRecordsOnThisDisk = this.reader.readInt(8), this.centralDirRecords = this.reader.readInt(8), this.centralDirSize = this.reader.readInt(8), this.centralDirOffset = this.reader.readInt(8), this.zip64ExtensibleData = {};
for (var e4, t4, r4, n4 = this.zip64EndOfCentralSize - 44; 0 < n4; ) e4 = this.reader.readInt(2), t4 = this.reader.readInt(4), r4 = this.reader.readData(t4), this.zip64ExtensibleData[e4] = { id: e4, length: t4, value: r4 };
}, readBlockZip64EndOfCentralLocator: function() {
if (this.diskWithZip64CentralDirStart = this.reader.readInt(4), this.relativeOffsetEndOfZip64CentralDir = this.reader.readInt(8), this.disksCount = this.reader.readInt(4), 1 < this.disksCount) throw new Error("Multi-volumes zip are not supported");
}, readLocalFiles: function() {
var e4, t4;
for (e4 = 0; e4 < this.files.length; e4++) t4 = this.files[e4], this.reader.setIndex(t4.localHeaderOffset), this.checkSignature(s3.LOCAL_FILE_HEADER), t4.readLocalPart(this.reader), t4.handleUTF8(), t4.processAttributes();
}, readCentralDir: function() {
var e4;
for (this.reader.setIndex(this.centralDirOffset); this.reader.readAndCheckSignature(s3.CENTRAL_FILE_HEADER); ) (e4 = new a2({ zip64: this.zip64 }, this.loadOptions)).readCentralPart(this.reader), this.files.push(e4);
if (this.centralDirRecords !== this.files.length && 0 !== this.centralDirRecords && 0 === this.files.length) throw new Error("Corrupted zip or bug: expected " + this.centralDirRecords + " records in central dir, got " + this.files.length);
}, readEndOfCentral: function() {
var e4 = this.reader.lastIndexOfSignature(s3.CENTRAL_DIRECTORY_END);
if (e4 < 0) throw !this.isSignature(0, s3.LOCAL_FILE_HEADER) ? new Error("Can't find end of central directory : is this a zip file ? If it is, see https://stuk.github.io/jszip/documentation/howto/read_zip.html") : new Error("Corrupted zip: can't find end of central directory");
this.reader.setIndex(e4);
var t4 = e4;
if (this.checkSignature(s3.CENTRAL_DIRECTORY_END), this.readBlockEndOfCentral(), this.diskNumber === i3.MAX_VALUE_16BITS || this.diskWithCentralDirStart === i3.MAX_VALUE_16BITS || this.centralDirRecordsOnThisDisk === i3.MAX_VALUE_16BITS || this.centralDirRecords === i3.MAX_VALUE_16BITS || this.centralDirSize === i3.MAX_VALUE_32BITS || this.centralDirOffset === i3.MAX_VALUE_32BITS) {
if (this.zip64 = true, (e4 = this.reader.lastIndexOfSignature(s3.ZIP64_CENTRAL_DIRECTORY_LOCATOR)) < 0) throw new Error("Corrupted zip: can't find the ZIP64 end of central directory locator");
if (this.reader.setIndex(e4), this.checkSignature(s3.ZIP64_CENTRAL_DIRECTORY_LOCATOR), this.readBlockZip64EndOfCentralLocator(), !this.isSignature(this.relativeOffsetEndOfZip64CentralDir, s3.ZIP64_CENTRAL_DIRECTORY_END) && (this.relativeOffsetEndOfZip64CentralDir = this.reader.lastIndexOfSignature(s3.ZIP64_CENTRAL_DIRECTORY_END), this.relativeOffsetEndOfZip64CentralDir < 0)) throw new Error("Corrupted zip: can't find the ZIP64 end of central directory");
this.reader.setIndex(this.relativeOffsetEndOfZip64CentralDir), this.checkSignature(s3.ZIP64_CENTRAL_DIRECTORY_END), this.readBlockZip64EndOfCentral();
}
var r4 = this.centralDirOffset + this.centralDirSize;
this.zip64 && (r4 += 20, r4 += 12 + this.zip64EndOfCentralSize);
var n4 = t4 - r4;
if (0 < n4) this.isSignature(t4, s3.CENTRAL_FILE_HEADER) || (this.reader.zero = n4);
else if (n4 < 0) throw new Error("Corrupted zip: missing " + Math.abs(n4) + " bytes.");
}, prepareReader: function(e4) {
this.reader = n3(e4);
}, load: function(e4) {
this.prepareReader(e4), this.readEndOfCentral(), this.readCentralDir(), this.readLocalFiles();
} }, t3.exports = h3;
}, { "./reader/readerFor": 22, "./signature": 23, "./support": 30, "./utils": 32, "./zipEntry": 34 }], 34: [function(e3, t3, r3) {
var n3 = e3("./reader/readerFor"), s3 = e3("./utils"), i3 = e3("./compressedObject"), a2 = e3("./crc32"), o2 = e3("./utf8"), h3 = e3("./compressions"), u2 = e3("./support");
function l2(e4, t4) {
this.options = e4, this.loadOptions = t4;
}
l2.prototype = { isEncrypted: function() {
return 1 == (1 & this.bitFlag);
}, useUTF8: function() {
return 2048 == (2048 & this.bitFlag);
}, readLocalPart: function(e4) {
var t4, r4;
if (e4.skip(22), this.fileNameLength = e4.readInt(2), r4 = e4.readInt(2), this.fileName = e4.readData(this.fileNameLength), e4.skip(r4), -1 === this.compressedSize || -1 === this.uncompressedSize) throw new Error("Bug or corrupted zip : didn't get enough information from the central directory (compressedSize === -1 || uncompressedSize === -1)");
if (null === (t4 = function(e5) {
for (var t5 in h3) if (Object.prototype.hasOwnProperty.call(h3, t5) && h3[t5].magic === e5) return h3[t5];
return null;
}(this.compressionMethod))) throw new Error("Corrupted zip : compression " + s3.pretty(this.compressionMethod) + " unknown (inner file : " + s3.transformTo("string", this.fileName) + ")");
this.decompressed = new i3(this.compressedSize, this.uncompressedSize, this.crc32, t4, e4.readData(this.compressedSize));
}, readCentralPart: function(e4) {
this.versionMadeBy = e4.readInt(2), e4.skip(2), this.bitFlag = e4.readInt(2), this.compressionMethod = e4.readString(2), this.date = e4.readDate(), this.crc32 = e4.readInt(4), this.compressedSize = e4.readInt(4), this.uncompressedSize = e4.readInt(4);
var t4 = e4.readInt(2);
if (this.extraFieldsLength = e4.readInt(2), this.fileCommentLength = e4.readInt(2), this.diskNumberStart = e4.readInt(2), this.internalFileAttributes = e4.readInt(2), this.externalFileAttributes = e4.readInt(4), this.localHeaderOffset = e4.readInt(4), this.isEncrypted()) throw new Error("Encrypted zip are not supported");
e4.skip(t4), this.readExtraFields(e4), this.parseZIP64ExtraField(e4), this.fileComment = e4.readData(this.fileCommentLength);
}, processAttributes: function() {
this.unixPermissions = null, this.dosPermissions = null;
var e4 = this.versionMadeBy >> 8;
this.dir = !!(16 & this.externalFileAttributes), 0 == e4 && (this.dosPermissions = 63 & this.externalFileAttributes), 3 == e4 && (this.unixPermissions = this.externalFileAttributes >> 16 & 65535), this.dir || "/" !== this.fileNameStr.slice(-1) || (this.dir = true);
}, parseZIP64ExtraField: function() {
if (this.extraFields[1]) {
var e4 = n3(this.extraFields[1].value);
this.uncompressedSize === s3.MAX_VALUE_32BITS && (this.uncompressedSize = e4.readInt(8)), this.compressedSize === s3.MAX_VALUE_32BITS && (this.compressedSize = e4.readInt(8)), this.localHeaderOffset === s3.MAX_VALUE_32BITS && (this.localHeaderOffset = e4.readInt(8)), this.diskNumberStart === s3.MAX_VALUE_32BITS && (this.diskNumberStart = e4.readInt(4));
}
}, readExtraFields: function(e4) {
var t4, r4, n4, i4 = e4.index + this.extraFieldsLength;
for (this.extraFields || (this.extraFields = {}); e4.index + 4 < i4; ) t4 = e4.readInt(2), r4 = e4.readInt(2), n4 = e4.readData(r4), this.extraFields[t4] = { id: t4, length: r4, value: n4 };
e4.setIndex(i4);
}, handleUTF8: function() {
var e4 = u2.uint8array ? "uint8array" : "array";
if (this.useUTF8()) this.fileNameStr = o2.utf8decode(this.fileName), this.fileCommentStr = o2.utf8decode(this.fileComment);
else {
var t4 = this.findExtraFieldUnicodePath();
if (null !== t4) this.fileNameStr = t4;
else {
var r4 = s3.transformTo(e4, this.fileName);
this.fileNameStr = this.loadOptions.decodeFileName(r4);
}
var n4 = this.findExtraFieldUnicodeComment();
if (null !== n4) this.fileCommentStr = n4;
else {
var i4 = s3.transformTo(e4, this.fileComment);
this.fileCommentStr = this.loadOptions.decodeFileName(i4);
}
}
}, findExtraFieldUnicodePath: function() {
var e4 = this.extraFields[28789];
if (e4) {
var t4 = n3(e4.value);
return 1 !== t4.readInt(1) ? null : a2(this.fileName) !== t4.readInt(4) ? null : o2.utf8decode(t4.readData(e4.length - 5));
}
return null;
}, findExtraFieldUnicodeComment: function() {
var e4 = this.extraFields[25461];
if (e4) {
var t4 = n3(e4.value);
return 1 !== t4.readInt(1) ? null : a2(this.fileComment) !== t4.readInt(4) ? null : o2.utf8decode(t4.readData(e4.length - 5));
}
return null;
} }, t3.exports = l2;
}, { "./compressedObject": 2, "./compressions": 3, "./crc32": 4, "./reader/readerFor": 22, "./support": 30, "./utf8": 31, "./utils": 32 }], 35: [function(e3, t3, r3) {
function n3(e4, t4, r4) {
this.name = e4, this.dir = r4.dir, this.date = r4.date, this.comment = r4.comment, this.unixPermissions = r4.unixPermissions, this.dosPermissions = r4.dosPermissions, this._data = t4, this._dataBinary = r4.binary, this.options = { compression: r4.compression, compressionOptions: r4.compressionOptions };
}
var s3 = e3("./stream/StreamHelper"), i3 = e3("./stream/DataWorker"), a2 = e3("./utf8"), o2 = e3("./compressedObject"), h3 = e3("./stream/GenericWorker");
n3.prototype = { internalStream: function(e4) {
var t4 = null, r4 = "string";
try {
if (!e4) throw new Error("No output type specified.");
var n4 = "string" === (r4 = e4.toLowerCase()) || "text" === r4;
"binarystring" !== r4 && "text" !== r4 || (r4 = "string"), t4 = this._decompressWorker();
var i4 = !this._dataBinary;
i4 && !n4 && (t4 = t4.pipe(new a2.Utf8EncodeWorker())), !i4 && n4 && (t4 = t4.pipe(new a2.Utf8DecodeWorker()));
} catch (e5) {
(t4 = new h3("error")).error(e5);
}
return new s3(t4, r4, "");
}, async: function(e4, t4) {
return this.internalStream(e4).accumulate(t4);
}, nodeStream: function(e4, t4) {
return this.internalStream(e4 || "nodebuffer").toNodejsStream(t4);
}, _compressWorker: function(e4, t4) {
if (this._data instanceof o2 && this._data.compression.magic === e4.magic) return this._data.getCompressedWorker();
var r4 = this._decompressWorker();
return this._dataBinary || (r4 = r4.pipe(new a2.Utf8EncodeWorker())), o2.createWorkerFrom(r4, e4, t4);
}, _decompressWorker: function() {
return this._data instanceof o2 ? this._data.getContentWorker() : this._data instanceof h3 ? this._data : new i3(this._data);
} };
for (var u2 = ["asText", "asBinary", "asNodeBuffer", "asUint8Array", "asArrayBuffer"], l2 = function() {
throw new Error("This method has been removed in JSZip 3.0, please check the upgrade guide.");
}, f3 = 0; f3 < u2.length; f3++) n3.prototype[u2[f3]] = l2;
t3.exports = n3;
}, { "./compressedObject": 2, "./stream/DataWorker": 27, "./stream/GenericWorker": 28, "./stream/StreamHelper": 29, "./utf8": 31 }], 36: [function(e3, l2, t3) {
(function(t4) {
var r3, n3, e4 = t4.MutationObserver || t4.WebKitMutationObserver;
if (e4) {
var i3 = 0, s3 = new e4(u2), a2 = t4.document.createTextNode("");
s3.observe(a2, { characterData: true }), r3 = function() {
a2.data = i3 = ++i3 % 2;
};
} else if (t4.setImmediate || void 0 === t4.MessageChannel) r3 = "document" in t4 && "onreadystatechange" in t4.document.createElement("script") ? function() {
var e5 = t4.document.createElement("script");
e5.onreadystatechange = function() {
u2(), e5.onreadystatechange = null, e5.parentNode.removeChild(e5), e5 = null;
}, t4.document.documentElement.appendChild(e5);
} : function() {
setTimeout(u2, 0);
};
else {
var o2 = new t4.MessageChannel();
o2.port1.onmessage = u2, r3 = function() {
o2.port2.postMessage(0);
};
}
var h3 = [];
function u2() {
var e5, t5;
n3 = true;
for (var r4 = h3.length; r4; ) {
for (t5 = h3, h3 = [], e5 = -1; ++e5 < r4; ) t5[e5]();
r4 = h3.length;
}
n3 = false;
}
l2.exports = function(e5) {
1 !== h3.push(e5) || n3 || r3();
};
}).call(this, "undefined" != typeof commonjsGlobal ? commonjsGlobal : "undefined" != typeof self ? self : "undefined" != typeof window ? window : {});
}, {}], 37: [function(e3, t3, r3) {
var i3 = e3("immediate");
function u2() {
}
var l2 = {}, s3 = ["REJECTED"], a2 = ["FULFILLED"], n3 = ["PENDING"];
function o2(e4) {
if ("function" != typeof e4) throw new TypeError("resolver must be a function");
this.state = n3, this.queue = [], this.outcome = void 0, e4 !== u2 && d2(this, e4);
}
function h3(e4, t4, r4) {
this.promise = e4, "function" == typeof t4 && (this.onFulfilled = t4, this.callFulfilled = this.otherCallFulfilled), "function" == typeof r4 && (this.onRejected = r4, this.callRejected = this.otherCallRejected);
}
function f3(t4, r4, n4) {
i3(function() {
var e4;
try {
e4 = r4(n4);
} catch (e5) {
return l2.reject(t4, e5);
}
e4 === t4 ? l2.reject(t4, new TypeError("Cannot resolve promise with itself")) : l2.resolve(t4, e4);
});
}
function c3(e4) {
var t4 = e4 && e4.then;
if (e4 && ("object" == typeof e4 || "function" == typeof e4) && "function" == typeof t4) return function() {
t4.apply(e4, arguments);
};
}
function d2(t4, e4) {
var r4 = false;
function n4(e5) {
r4 || (r4 = true, l2.reject(t4, e5));
}
function i4(e5) {
r4 || (r4 = true, l2.resolve(t4, e5));
}
var s4 = p2(function() {
e4(i4, n4);
});
"error" === s4.status && n4(s4.value);
}
function p2(e4, t4) {
var r4 = {};
try {
r4.value = e4(t4), r4.status = "success";
} catch (e5) {
r4.status = "error", r4.value = e5;
}
return r4;
}
(t3.exports = o2).prototype.finally = function(t4) {
if ("function" != typeof t4) return this;
var r4 = this.constructor;
return this.then(function(e4) {
return r4.resolve(t4()).then(function() {
return e4;
});
}, function(e4) {
return r4.resolve(t4()).then(function() {
throw e4;
});
});
}, o2.prototype.catch = function(e4) {
return this.then(null, e4);
}, o2.prototype.then = function(e4, t4) {
if ("function" != typeof e4 && this.state === a2 || "function" != typeof t4 && this.state === s3) return this;
var r4 = new this.constructor(u2);
this.state !== n3 ? f3(r4, this.state === a2 ? e4 : t4, this.outcome) : this.queue.push(new h3(r4, e4, t4));
return r4;
}, h3.prototype.callFulfilled = function(e4) {
l2.resolve(this.promise, e4);
}, h3.prototype.otherCallFulfilled = function(e4) {
f3(this.promise, this.onFulfilled, e4);
}, h3.prototype.callRejected = function(e4) {
l2.reject(this.promise, e4);
}, h3.prototype.otherCallRejected = function(e4) {
f3(this.promise, this.onRejected, e4);
}, l2.resolve = function(e4, t4) {
var r4 = p2(c3, t4);
if ("error" === r4.status) return l2.reject(e4, r4.value);
var n4 = r4.value;
if (n4) d2(e4, n4);
else {
e4.state = a2, e4.outcome = t4;
for (var i4 = -1, s4 = e4.queue.length; ++i4 < s4; ) e4.queue[i4].callFulfilled(t4);
}
return e4;
}, l2.reject = function(e4, t4) {
e4.state = s3, e4.outcome = t4;
for (var r4 = -1, n4 = e4.queue.length; ++r4 < n4; ) e4.queue[r4].callRejected(t4);
return e4;
}, o2.resolve = function(e4) {
if (e4 instanceof this) return e4;
return l2.resolve(new this(u2), e4);
}, o2.reject = function(e4) {
var t4 = new this(u2);
return l2.reject(t4, e4);
}, o2.all = function(e4) {
var r4 = this;
if ("[object Array]" !== Object.prototype.toString.call(e4)) return this.reject(new TypeError("must be an array"));
var n4 = e4.length, i4 = false;
if (!n4) return this.resolve([]);
var s4 = new Array(n4), a3 = 0, t4 = -1, o3 = new this(u2);
for (; ++t4 < n4; ) h4(e4[t4], t4);
return o3;
function h4(e5, t5) {
r4.resolve(e5).then(function(e6) {
s4[t5] = e6, ++a3 !== n4 || i4 || (i4 = true, l2.resolve(o3, s4));
}, function(e6) {
i4 || (i4 = true, l2.reject(o3, e6));
});
}
}, o2.race = function(e4) {
var t4 = this;
if ("[object Array]" !== Object.prototype.toString.call(e4)) return this.reject(new TypeError("must be an array"));
var r4 = e4.length, n4 = false;
if (!r4) return this.resolve([]);
var i4 = -1, s4 = new this(u2);
for (; ++i4 < r4; ) a3 = e4[i4], t4.resolve(a3).then(function(e5) {
n4 || (n4 = true, l2.resolve(s4, e5));
}, function(e5) {
n4 || (n4 = true, l2.reject(s4, e5));
});
var a3;
return s4;
};
}, { immediate: 36 }], 38: [function(e3, t3, r3) {
var n3 = {};
(0, e3("./lib/utils/common").assign)(n3, e3("./lib/deflate"), e3("./lib/inflate"), e3("./lib/zlib/constants")), t3.exports = n3;
}, { "./lib/deflate": 39, "./lib/inflate": 40, "./lib/utils/common": 41, "./lib/zlib/constants": 44 }], 39: [function(e3, t3, r3) {
var a2 = e3("./zlib/deflate"), o2 = e3("./utils/common"), h3 = e3("./utils/strings"), i3 = e3("./zlib/messages"), s3 = e3("./zlib/zstream"), u2 = Object.prototype.toString, l2 = 0, f3 = -1, c3 = 0, d2 = 8;
function p2(e4) {
if (!(this instanceof p2)) return new p2(e4);
this.options = o2.assign({ level: f3, method: d2, chunkSize: 16384, windowBits: 15, memLevel: 8, strategy: c3, to: "" }, e4 || {});
var t4 = this.options;
t4.raw && 0 < t4.windowBits ? t4.windowBits = -t4.windowBits : t4.gzip && 0 < t4.windowBits && t4.windowBits < 16 && (t4.windowBits += 16), this.err = 0, this.msg = "", this.ended = false, this.chunks = [], this.strm = new s3(), this.strm.avail_out = 0;
var r4 = a2.deflateInit2(this.strm, t4.level, t4.method, t4.windowBits, t4.memLevel, t4.strategy);
if (r4 !== l2) throw new Error(i3[r4]);
if (t4.header && a2.deflateSetHeader(this.strm, t4.header), t4.dictionary) {
var n4;
if (n4 = "string" == typeof t4.dictionary ? h3.string2buf(t4.dictionary) : "[object ArrayBuffer]" === u2.call(t4.dictionary) ? new Uint8Array(t4.dictionary) : t4.dictionary, (r4 = a2.deflateSetDictionary(this.strm, n4)) !== l2) throw new Error(i3[r4]);
this._dict_set = true;
}
}
function n3(e4, t4) {
var r4 = new p2(t4);
if (r4.push(e4, true), r4.err) throw r4.msg || i3[r4.err];
return r4.result;
}
p2.prototype.push = function(e4, t4) {
var r4, n4, i4 = this.strm, s4 = this.options.chunkSize;
if (this.ended) return false;
n4 = t4 === ~~t4 ? t4 : true === t4 ? 4 : 0, "string" == typeof e4 ? i4.input = h3.string2buf(e4) : "[object ArrayBuffer]" === u2.call(e4) ? i4.input = new Uint8Array(e4) : i4.input = e4, i4.next_in = 0, i4.avail_in = i4.input.length;
do {
if (0 === i4.avail_out && (i4.output = new o2.Buf8(s4), i4.next_out = 0, i4.avail_out = s4), 1 !== (r4 = a2.deflate(i4, n4)) && r4 !== l2) return this.onEnd(r4), !(this.ended = true);
0 !== i4.avail_out && (0 !== i4.avail_in || 4 !== n4 && 2 !== n4) || ("string" === this.options.to ? this.onData(h3.buf2binstring(o2.shrinkBuf(i4.output, i4.next_out))) : this.onData(o2.shrinkBuf(i4.output, i4.next_out)));
} while ((0 < i4.avail_in || 0 === i4.avail_out) && 1 !== r4);
return 4 === n4 ? (r4 = a2.deflateEnd(this.strm), this.onEnd(r4), this.ended = true, r4 === l2) : 2 !== n4 || (this.onEnd(l2), !(i4.avail_out = 0));
}, p2.prototype.onData = function(e4) {
this.chunks.push(e4);
}, p2.prototype.onEnd = function(e4) {
e4 === l2 && ("string" === this.options.to ? this.result = this.chunks.join("") : this.result = o2.flattenChunks(this.chunks)), this.chunks = [], this.err = e4, this.msg = this.strm.msg;
}, r3.Deflate = p2, r3.deflate = n3, r3.deflateRaw = function(e4, t4) {
return (t4 = t4 || {}).raw = true, n3(e4, t4);
}, r3.gzip = function(e4, t4) {
return (t4 = t4 || {}).gzip = true, n3(e4, t4);
};
}, { "./utils/common": 41, "./utils/strings": 42, "./zlib/deflate": 46, "./zlib/messages": 51, "./zlib/zstream": 53 }], 40: [function(e3, t3, r3) {
var c3 = e3("./zlib/inflate"), d2 = e3("./utils/common"), p2 = e3("./utils/strings"), m2 = e3("./zlib/constants"), n3 = e3("./zlib/messages"), i3 = e3("./zlib/zstream"), s3 = e3("./zlib/gzheader"), _2 = Object.prototype.toString;
function a2(e4) {
if (!(this instanceof a2)) return new a2(e4);
this.options = d2.assign({ chunkSize: 16384, windowBits: 0, to: "" }, e4 || {});
var t4 = this.options;
t4.raw && 0 <= t4.windowBits && t4.windowBits < 16 && (t4.windowBits = -t4.windowBits, 0 === t4.windowBits && (t4.windowBits = -15)), !(0 <= t4.windowBits && t4.windowBits < 16) || e4 && e4.windowBits || (t4.windowBits += 32), 15 < t4.windowBits && t4.windowBits < 48 && 0 == (15 & t4.windowBits) && (t4.windowBits |= 15), this.err = 0, this.msg = "", this.ended = false, this.chunks = [], this.strm = new i3(), this.strm.avail_out = 0;
var r4 = c3.inflateInit2(this.strm, t4.windowBits);
if (r4 !== m2.Z_OK) throw new Error(n3[r4]);
this.header = new s3(), c3.inflateGetHeader(this.strm, this.header);
}
function o2(e4, t4) {
var r4 = new a2(t4);
if (r4.push(e4, true), r4.err) throw r4.msg || n3[r4.err];
return r4.result;
}
a2.prototype.push = function(e4, t4) {
var r4, n4, i4, s4, a3, o3, h3 = this.strm, u2 = this.options.chunkSize, l2 = this.options.dictionary, f3 = false;
if (this.ended) return false;
n4 = t4 === ~~t4 ? t4 : true === t4 ? m2.Z_FINISH : m2.Z_NO_FLUSH, "string" == typeof e4 ? h3.input = p2.binstring2buf(e4) : "[object ArrayBuffer]" === _2.call(e4) ? h3.input = new Uint8Array(e4) : h3.input = e4, h3.next_in = 0, h3.avail_in = h3.input.length;
do {
if (0 === h3.avail_out && (h3.output = new d2.Buf8(u2), h3.next_out = 0, h3.avail_out = u2), (r4 = c3.inflate(h3, m2.Z_NO_FLUSH)) === m2.Z_NEED_DICT && l2 && (o3 = "string" == typeof l2 ? p2.string2buf(l2) : "[object ArrayBuffer]" === _2.call(l2) ? new Uint8Array(l2) : l2, r4 = c3.inflateSetDictionary(this.strm, o3)), r4 === m2.Z_BUF_ERROR && true === f3 && (r4 = m2.Z_OK, f3 = false), r4 !== m2.Z_STREAM_END && r4 !== m2.Z_OK) return this.onEnd(r4), !(this.ended = true);
h3.next_out && (0 !== h3.avail_out && r4 !== m2.Z_STREAM_END && (0 !== h3.avail_in || n4 !== m2.Z_FINISH && n4 !== m2.Z_SYNC_FLUSH) || ("string" === this.options.to ? (i4 = p2.utf8border(h3.output, h3.next_out), s4 = h3.next_out - i4, a3 = p2.buf2string(h3.output, i4), h3.next_out = s4, h3.avail_out = u2 - s4, s4 && d2.arraySet(h3.output, h3.output, i4, s4, 0), this.onData(a3)) : this.onData(d2.shrinkBuf(h3.output, h3.next_out)))), 0 === h3.avail_in && 0 === h3.avail_out && (f3 = true);
} while ((0 < h3.avail_in || 0 === h3.avail_out) && r4 !== m2.Z_STREAM_END);
return r4 === m2.Z_STREAM_END && (n4 = m2.Z_FINISH), n4 === m2.Z_FINISH ? (r4 = c3.inflateEnd(this.strm), this.onEnd(r4), this.ended = true, r4 === m2.Z_OK) : n4 !== m2.Z_SYNC_FLUSH || (this.onEnd(m2.Z_OK), !(h3.avail_out = 0));
}, a2.prototype.onData = function(e4) {
this.chunks.push(e4);
}, a2.prototype.onEnd = function(e4) {
e4 === m2.Z_OK && ("string" === this.options.to ? this.result = this.chunks.join("") : this.result = d2.flattenChunks(this.chunks)), this.chunks = [], this.err = e4, this.msg = this.strm.msg;
}, r3.Inflate = a2, r3.inflate = o2, r3.inflateRaw = function(e4, t4) {
return (t4 = t4 || {}).raw = true, o2(e4, t4);
}, r3.ungzip = o2;
}, { "./utils/common": 41, "./utils/strings": 42, "./zlib/constants": 44, "./zlib/gzheader": 47, "./zlib/inflate": 49, "./zlib/messages": 51, "./zlib/zstream": 53 }], 41: [function(e3, t3, r3) {
var n3 = "undefined" != typeof Uint8Array && "undefined" != typeof Uint16Array && "undefined" != typeof Int32Array;
r3.assign = function(e4) {
for (var t4 = Array.prototype.slice.call(arguments, 1); t4.length; ) {
var r4 = t4.shift();
if (r4) {
if ("object" != typeof r4) throw new TypeError(r4 + "must be non-object");
for (var n4 in r4) r4.hasOwnProperty(n4) && (e4[n4] = r4[n4]);
}
}
return e4;
}, r3.shrinkBuf = function(e4, t4) {
return e4.length === t4 ? e4 : e4.subarray ? e4.subarray(0, t4) : (e4.length = t4, e4);
};
var i3 = { arraySet: function(e4, t4, r4, n4, i4) {
if (t4.subarray && e4.subarray) e4.set(t4.subarray(r4, r4 + n4), i4);
else for (var s4 = 0; s4 < n4; s4++) e4[i4 + s4] = t4[r4 + s4];
}, flattenChunks: function(e4) {
var t4, r4, n4, i4, s4, a2;
for (t4 = n4 = 0, r4 = e4.length; t4 < r4; t4++) n4 += e4[t4].length;
for (a2 = new Uint8Array(n4), t4 = i4 = 0, r4 = e4.length; t4 < r4; t4++) s4 = e4[t4], a2.set(s4, i4), i4 += s4.length;
return a2;
} }, s3 = { arraySet: function(e4, t4, r4, n4, i4) {
for (var s4 = 0; s4 < n4; s4++) e4[i4 + s4] = t4[r4 + s4];
}, flattenChunks: function(e4) {
return [].concat.apply([], e4);
} };
r3.setTyped = function(e4) {
e4 ? (r3.Buf8 = Uint8Array, r3.Buf16 = Uint16Array, r3.Buf32 = Int32Array, r3.assign(r3, i3)) : (r3.Buf8 = Array, r3.Buf16 = Array, r3.Buf32 = Array, r3.assign(r3, s3));
}, r3.setTyped(n3);
}, {}], 42: [function(e3, t3, r3) {
var h3 = e3("./common"), i3 = true, s3 = true;
try {
String.fromCharCode.apply(null, [0]);
} catch (e4) {
i3 = false;
}
try {
String.fromCharCode.apply(null, new Uint8Array(1));
} catch (e4) {
s3 = false;
}
for (var u2 = new h3.Buf8(256), n3 = 0; n3 < 256; n3++) u2[n3] = 252 <= n3 ? 6 : 248 <= n3 ? 5 : 240 <= n3 ? 4 : 224 <= n3 ? 3 : 192 <= n3 ? 2 : 1;
function l2(e4, t4) {
if (t4 < 65537 && (e4.subarray && s3 || !e4.subarray && i3)) return String.fromCharCode.apply(null, h3.shrinkBuf(e4, t4));
for (var r4 = "", n4 = 0; n4 < t4; n4++) r4 += String.fromCharCode(e4[n4]);
return r4;
}
u2[254] = u2[254] = 1, r3.string2buf = function(e4) {
var t4, r4, n4, i4, s4, a2 = e4.length, o2 = 0;
for (i4 = 0; i4 < a2; i4++) 55296 == (64512 & (r4 = e4.charCodeAt(i4))) && i4 + 1 < a2 && 56320 == (64512 & (n4 = e4.charCodeAt(i4 + 1))) && (r4 = 65536 + (r4 - 55296 << 10) + (n4 - 56320), i4++), o2 += r4 < 128 ? 1 : r4 < 2048 ? 2 : r4 < 65536 ? 3 : 4;
for (t4 = new h3.Buf8(o2), i4 = s4 = 0; s4 < o2; i4++) 55296 == (64512 & (r4 = e4.charCodeAt(i4))) && i4 + 1 < a2 && 56320 == (64512 & (n4 = e4.charCodeAt(i4 + 1))) && (r4 = 65536 + (r4 - 55296 << 10) + (n4 - 56320), i4++), r4 < 128 ? t4[s4++] = r4 : (r4 < 2048 ? t4[s4++] = 192 | r4 >>> 6 : (r4 < 65536 ? t4[s4++] = 224 | r4 >>> 12 : (t4[s4++] = 240 | r4 >>> 18, t4[s4++] = 128 | r4 >>> 12 & 63), t4[s4++] = 128 | r4 >>> 6 & 63), t4[s4++] = 128 | 63 & r4);
return t4;
}, r3.buf2binstring = function(e4) {
return l2(e4, e4.length);
}, r3.binstring2buf = function(e4) {
for (var t4 = new h3.Buf8(e4.length), r4 = 0, n4 = t4.length; r4 < n4; r4++) t4[r4] = e4.charCodeAt(r4);
return t4;
}, r3.buf2string = function(e4, t4) {
var r4, n4, i4, s4, a2 = t4 || e4.length, o2 = new Array(2 * a2);
for (r4 = n4 = 0; r4 < a2; ) if ((i4 = e4[r4++]) < 128) o2[n4++] = i4;
else if (4 < (s4 = u2[i4])) o2[n4++] = 65533, r4 += s4 - 1;
else {
for (i4 &= 2 === s4 ? 31 : 3 === s4 ? 15 : 7; 1 < s4 && r4 < a2; ) i4 = i4 << 6 | 63 & e4[r4++], s4--;
1 < s4 ? o2[n4++] = 65533 : i4 < 65536 ? o2[n4++] = i4 : (i4 -= 65536, o2[n4++] = 55296 | i4 >> 10 & 1023, o2[n4++] = 56320 | 1023 & i4);
}
return l2(o2, n4);
}, r3.utf8border = function(e4, t4) {
var r4;
for ((t4 = t4 || e4.length) > e4.length && (t4 = e4.length), r4 = t4 - 1; 0 <= r4 && 128 == (192 & e4[r4]); ) r4--;
return r4 < 0 ? t4 : 0 === r4 ? t4 : r4 + u2[e4[r4]] > t4 ? r4 : t4;
};
}, { "./common": 41 }], 43: [function(e3, t3, r3) {
t3.exports = function(e4, t4, r4, n3) {
for (var i3 = 65535 & e4 | 0, s3 = e4 >>> 16 & 65535 | 0, a2 = 0; 0 !== r4; ) {
for (r4 -= a2 = 2e3 < r4 ? 2e3 : r4; s3 = s3 + (i3 = i3 + t4[n3++] | 0) | 0, --a2; ) ;
i3 %= 65521, s3 %= 65521;
}
return i3 | s3 << 16 | 0;
};
}, {}], 44: [function(e3, t3, r3) {
t3.exports = { Z_NO_FLUSH: 0, Z_PARTIAL_FLUSH: 1, Z_SYNC_FLUSH: 2, Z_FULL_FLUSH: 3, Z_FINISH: 4, Z_BLOCK: 5, Z_TREES: 6, Z_OK: 0, Z_STREAM_END: 1, Z_NEED_DICT: 2, Z_ERRNO: -1, Z_STREAM_ERROR: -2, Z_DATA_ERROR: -3, Z_BUF_ERROR: -5, Z_NO_COMPRESSION: 0, Z_BEST_SPEED: 1, Z_BEST_COMPRESSION: 9, Z_DEFAULT_COMPRESSION: -1, Z_FILTERED: 1, Z_HUFFMAN_ONLY: 2, Z_RLE: 3, Z_FIXED: 4, Z_DEFAULT_STRATEGY: 0, Z_BINARY: 0, Z_TEXT: 1, Z_UNKNOWN: 2, Z_DEFLATED: 8 };
}, {}], 45: [function(e3, t3, r3) {
var o2 = function() {
for (var e4, t4 = [], r4 = 0; r4 < 256; r4++) {
e4 = r4;
for (var n3 = 0; n3 < 8; n3++) e4 = 1 & e4 ? 3988292384 ^ e4 >>> 1 : e4 >>> 1;
t4[r4] = e4;
}
return t4;
}();
t3.exports = function(e4, t4, r4, n3) {
var i3 = o2, s3 = n3 + r4;
e4 ^= -1;
for (var a2 = n3; a2 < s3; a2++) e4 = e4 >>> 8 ^ i3[255 & (e4 ^ t4[a2])];
return -1 ^ e4;
};
}, {}], 46: [function(e3, t3, r3) {
var h3, c3 = e3("../utils/common"), u2 = e3("./trees"), d2 = e3("./adler32"), p2 = e3("./crc32"), n3 = e3("./messages"), l2 = 0, f3 = 4, m2 = 0, _2 = -2, g2 = -1, b3 = 4, i3 = 2, v2 = 8, y2 = 9, s3 = 286, a2 = 30, o2 = 19, w2 = 2 * s3 + 1, k3 = 15, x2 = 3, S2 = 258, z2 = S2 + x2 + 1, C2 = 42, E2 = 113, A2 = 1, I2 = 2, O = 3, B2 = 4;
function R2(e4, t4) {
return e4.msg = n3[t4], t4;
}
function T2(e4) {
return (e4 << 1) - (4 < e4 ? 9 : 0);
}
function D(e4) {
for (var t4 = e4.length; 0 <= --t4; ) e4[t4] = 0;
}
function F(e4) {
var t4 = e4.state, r4 = t4.pending;
r4 > e4.avail_out && (r4 = e4.avail_out), 0 !== r4 && (c3.arraySet(e4.output, t4.pending_buf, t4.pending_out, r4, e4.next_out), e4.next_out += r4, t4.pending_out += r4, e4.total_out += r4, e4.avail_out -= r4, t4.pending -= r4, 0 === t4.pending && (t4.pending_out = 0));
}
function N2(e4, t4) {
u2._tr_flush_block(e4, 0 <= e4.block_start ? e4.block_start : -1, e4.strstart - e4.block_start, t4), e4.block_start = e4.strstart, F(e4.strm);
}
function U(e4, t4) {
e4.pending_buf[e4.pending++] = t4;
}
function P2(e4, t4) {
e4.pending_buf[e4.pending++] = t4 >>> 8 & 255, e4.pending_buf[e4.pending++] = 255 & t4;
}
function L2(e4, t4) {
var r4, n4, i4 = e4.max_chain_length, s4 = e4.strstart, a3 = e4.prev_length, o3 = e4.nice_match, h4 = e4.strstart > e4.w_size - z2 ? e4.strstart - (e4.w_size - z2) : 0, u3 = e4.window, l3 = e4.w_mask, f4 = e4.prev, c4 = e4.strstart + S2, d3 = u3[s4 + a3 - 1], p3 = u3[s4 + a3];
e4.prev_length >= e4.good_match && (i4 >>= 2), o3 > e4.lookahead && (o3 = e4.lookahead);
do {
if (u3[(r4 = t4) + a3] === p3 && u3[r4 + a3 - 1] === d3 && u3[r4] === u3[s4] && u3[++r4] === u3[s4 + 1]) {
s4 += 2, r4++;
do {
} while (u3[++s4] === u3[++r4] && u3[++s4] === u3[++r4] && u3[++s4] === u3[++r4] && u3[++s4] === u3[++r4] && u3[++s4] === u3[++r4] && u3[++s4] === u3[++r4] && u3[++s4] === u3[++r4] && u3[++s4] === u3[++r4] && s4 < c4);
if (n4 = S2 - (c4 - s4), s4 = c4 - S2, a3 < n4) {
if (e4.match_start = t4, o3 <= (a3 = n4)) break;
d3 = u3[s4 + a3 - 1], p3 = u3[s4 + a3];
}
}
} while ((t4 = f4[t4 & l3]) > h4 && 0 != --i4);
return a3 <= e4.lookahead ? a3 : e4.lookahead;
}
function j2(e4) {
var t4, r4, n4, i4, s4, a3, o3, h4, u3, l3, f4 = e4.w_size;
do {
if (i4 = e4.window_size - e4.lookahead - e4.strstart, e4.strstart >= f4 + (f4 - z2)) {
for (c3.arraySet(e4.window, e4.window, f4, f4, 0), e4.match_start -= f4, e4.strstart -= f4, e4.block_start -= f4, t4 = r4 = e4.hash_size; n4 = e4.head[--t4], e4.head[t4] = f4 <= n4 ? n4 - f4 : 0, --r4; ) ;
for (t4 = r4 = f4; n4 = e4.prev[--t4], e4.prev[t4] = f4 <= n4 ? n4 - f4 : 0, --r4; ) ;
i4 += f4;
}
if (0 === e4.strm.avail_in) break;
if (a3 = e4.strm, o3 = e4.window, h4 = e4.strstart + e4.lookahead, u3 = i4, l3 = void 0, l3 = a3.avail_in, u3 < l3 && (l3 = u3), r4 = 0 === l3 ? 0 : (a3.avail_in -= l3, c3.arraySet(o3, a3.input, a3.next_in, l3, h4), 1 === a3.state.wrap ? a3.adler = d2(a3.adler, o3, l3, h4) : 2 === a3.state.wrap && (a3.adler = p2(a3.adler, o3, l3, h4)), a3.next_in += l3, a3.total_in += l3, l3), e4.lookahead += r4, e4.lookahead + e4.insert >= x2) for (s4 = e4.strstart - e4.insert, e4.ins_h = e4.window[s4], e4.ins_h = (e4.ins_h << e4.hash_shift ^ e4.window[s4 + 1]) & e4.hash_mask; e4.insert && (e4.ins_h = (e4.ins_h << e4.hash_shift ^ e4.window[s4 + x2 - 1]) & e4.hash_mask, e4.prev[s4 & e4.w_mask] = e4.head[e4.ins_h], e4.head[e4.ins_h] = s4, s4++, e4.insert--, !(e4.lookahead + e4.insert < x2)); ) ;
} while (e4.lookahead < z2 && 0 !== e4.strm.avail_in);
}
function Z(e4, t4) {
for (var r4, n4; ; ) {
if (e4.lookahead < z2) {
if (j2(e4), e4.lookahead < z2 && t4 === l2) return A2;
if (0 === e4.lookahead) break;
}
if (r4 = 0, e4.lookahead >= x2 && (e4.ins_h = (e4.ins_h << e4.hash_shift ^ e4.window[e4.strstart + x2 - 1]) & e4.hash_mask, r4 = e4.prev[e4.strstart & e4.w_mask] = e4.head[e4.ins_h], e4.head[e4.ins_h] = e4.strstart), 0 !== r4 && e4.strstart - r4 <= e4.w_size - z2 && (e4.match_length = L2(e4, r4)), e4.match_length >= x2) if (n4 = u2._tr_tally(e4, e4.strstart - e4.match_start, e4.match_length - x2), e4.lookahead -= e4.match_length, e4.match_length <= e4.max_lazy_match && e4.lookahead >= x2) {
for (e4.match_length--; e4.strstart++, e4.ins_h = (e4.ins_h << e4.hash_shift ^ e4.window[e4.strstart + x2 - 1]) & e4.hash_mask, r4 = e4.prev[e4.strstart & e4.w_mask] = e4.head[e4.ins_h], e4.head[e4.ins_h] = e4.strstart, 0 != --e4.match_length; ) ;
e4.strstart++;
} else e4.strstart += e4.match_length, e4.match_length = 0, e4.ins_h = e4.window[e4.strstart], e4.ins_h = (e4.ins_h << e4.hash_shift ^ e4.window[e4.strstart + 1]) & e4.hash_mask;
else n4 = u2._tr_tally(e4, 0, e4.window[e4.strstart]), e4.lookahead--, e4.strstart++;
if (n4 && (N2(e4, false), 0 === e4.strm.avail_out)) return A2;
}
return e4.insert = e4.strstart < x2 - 1 ? e4.strstart : x2 - 1, t4 === f3 ? (N2(e4, true), 0 === e4.strm.avail_out ? O : B2) : e4.last_lit && (N2(e4, false), 0 === e4.strm.avail_out) ? A2 : I2;
}
function W(e4, t4) {
for (var r4, n4, i4; ; ) {
if (e4.lookahead < z2) {
if (j2(e4), e4.lookahead < z2 && t4 === l2) return A2;
if (0 === e4.lookahead) break;
}
if (r4 = 0, e4.lookahead >= x2 && (e4.ins_h = (e4.ins_h << e4.hash_shift ^ e4.window[e4.strstart + x2 - 1]) & e4.hash_mask, r4 = e4.prev[e4.strstart & e4.w_mask] = e4.head[e4.ins_h], e4.head[e4.ins_h] = e4.strstart), e4.prev_length = e4.match_length, e4.prev_match = e4.match_start, e4.match_length = x2 - 1, 0 !== r4 && e4.prev_length < e4.max_lazy_match && e4.strstart - r4 <= e4.w_size - z2 && (e4.match_length = L2(e4, r4), e4.match_length <= 5 && (1 === e4.strategy || e4.match_length === x2 && 4096 < e4.strstart - e4.match_start) && (e4.match_length = x2 - 1)), e4.prev_length >= x2 && e4.match_length <= e4.prev_length) {
for (i4 = e4.strstart + e4.lookahead - x2, n4 = u2._tr_tally(e4, e4.strstart - 1 - e4.prev_match, e4.prev_length - x2), e4.lookahead -= e4.prev_length - 1, e4.prev_length -= 2; ++e4.strstart <= i4 && (e4.ins_h = (e4.ins_h << e4.hash_shift ^ e4.window[e4.strstart + x2 - 1]) & e4.hash_mask, r4 = e4.prev[e4.strstart & e4.w_mask] = e4.head[e4.ins_h], e4.head[e4.ins_h] = e4.strstart), 0 != --e4.prev_length; ) ;
if (e4.match_available = 0, e4.match_length = x2 - 1, e4.strstart++, n4 && (N2(e4, false), 0 === e4.strm.avail_out)) return A2;
} else if (e4.match_available) {
if ((n4 = u2._tr_tally(e4, 0, e4.window[e4.strstart - 1])) && N2(e4, false), e4.strstart++, e4.lookahead--, 0 === e4.strm.avail_out) return A2;
} else e4.match_available = 1, e4.strstart++, e4.lookahead--;
}
return e4.match_available && (n4 = u2._tr_tally(e4, 0, e4.window[e4.strstart - 1]), e4.match_available = 0), e4.insert = e4.strstart < x2 - 1 ? e4.strstart : x2 - 1, t4 === f3 ? (N2(e4, true), 0 === e4.strm.avail_out ? O : B2) : e4.last_lit && (N2(e4, false), 0 === e4.strm.avail_out) ? A2 : I2;
}
function M2(e4, t4, r4, n4, i4) {
this.good_length = e4, this.max_lazy = t4, this.nice_length = r4, this.max_chain = n4, this.func = i4;
}
function H2() {
this.strm = null, this.status = 0, this.pending_buf = null, this.pending_buf_size = 0, this.pending_out = 0, this.pending = 0, this.wrap = 0, this.gzhead = null, this.gzindex = 0, this.method = v2, this.last_flush = -1, this.w_size = 0, this.w_bits = 0, this.w_mask = 0, this.window = null, this.window_size = 0, this.prev = null, this.head = null, this.ins_h = 0, this.hash_size = 0, this.hash_bits = 0, this.hash_mask = 0, this.hash_shift = 0, this.block_start = 0, this.match_length = 0, this.prev_match = 0, this.match_available = 0, this.strstart = 0, this.match_start = 0, this.lookahead = 0, this.prev_length = 0, this.max_chain_length = 0, this.max_lazy_match = 0, this.level = 0, this.strategy = 0, this.good_match = 0, this.nice_match = 0, this.dyn_ltree = new c3.Buf16(2 * w2), this.dyn_dtree = new c3.Buf16(2 * (2 * a2 + 1)), this.bl_tree = new c3.Buf16(2 * (2 * o2 + 1)), D(this.dyn_ltree), D(this.dyn_dtree), D(this.bl_tree), this.l_desc = null, this.d_desc = null, this.bl_desc = null, this.bl_count = new c3.Buf16(k3 + 1), this.heap = new c3.Buf16(2 * s3 + 1), D(this.heap), this.heap_len = 0, this.heap_max = 0, this.depth = new c3.Buf16(2 * s3 + 1), D(this.depth), this.l_buf = 0, this.lit_bufsize = 0, this.last_lit = 0, this.d_buf = 0, this.opt_len = 0, this.static_len = 0, this.matches = 0, this.insert = 0, this.bi_buf = 0, this.bi_valid = 0;
}
function G(e4) {
var t4;
return e4 && e4.state ? (e4.total_in = e4.total_out = 0, e4.data_type = i3, (t4 = e4.state).pending = 0, t4.pending_out = 0, t4.wrap < 0 && (t4.wrap = -t4.wrap), t4.status = t4.wrap ? C2 : E2, e4.adler = 2 === t4.wrap ? 0 : 1, t4.last_flush = l2, u2._tr_init(t4), m2) : R2(e4, _2);
}
function K(e4) {
var t4 = G(e4);
return t4 === m2 && function(e5) {
e5.window_size = 2 * e5.w_size, D(e5.head), e5.max_lazy_match = h3[e5.level].max_lazy, e5.good_match = h3[e5.level].good_length, e5.nice_match = h3[e5.level].nice_length, e5.max_chain_length = h3[e5.level].max_chain, e5.strstart = 0, e5.block_start = 0, e5.lookahead = 0, e5.insert = 0, e5.match_length = e5.prev_length = x2 - 1, e5.match_available = 0, e5.ins_h = 0;
}(e4.state), t4;
}
function Y(e4, t4, r4, n4, i4, s4) {
if (!e4) return _2;
var a3 = 1;
if (t4 === g2 && (t4 = 6), n4 < 0 ? (a3 = 0, n4 = -n4) : 15 < n4 && (a3 = 2, n4 -= 16), i4 < 1 || y2 < i4 || r4 !== v2 || n4 < 8 || 15 < n4 || t4 < 0 || 9 < t4 || s4 < 0 || b3 < s4) return R2(e4, _2);
8 === n4 && (n4 = 9);
var o3 = new H2();
return (e4.state = o3).strm = e4, o3.wrap = a3, o3.gzhead = null, o3.w_bits = n4, o3.w_size = 1 << o3.w_bits, o3.w_mask = o3.w_size - 1, o3.hash_bits = i4 + 7, o3.hash_size = 1 << o3.hash_bits, o3.hash_mask = o3.hash_size - 1, o3.hash_shift = ~~((o3.hash_bits + x2 - 1) / x2), o3.window = new c3.Buf8(2 * o3.w_size), o3.head = new c3.Buf16(o3.hash_size), o3.prev = new c3.Buf16(o3.w_size), o3.lit_bufsize = 1 << i4 + 6, o3.pending_buf_size = 4 * o3.lit_bufsize, o3.pending_buf = new c3.Buf8(o3.pending_buf_size), o3.d_buf = 1 * o3.lit_bufsize, o3.l_buf = 3 * o3.lit_bufsize, o3.level = t4, o3.strategy = s4, o3.method = r4, K(e4);
}
h3 = [new M2(0, 0, 0, 0, function(e4, t4) {
var r4 = 65535;
for (r4 > e4.pending_buf_size - 5 && (r4 = e4.pending_buf_size - 5); ; ) {
if (e4.lookahead <= 1) {
if (j2(e4), 0 === e4.lookahead && t4 === l2) return A2;
if (0 === e4.lookahead) break;
}
e4.strstart += e4.lookahead, e4.lookahead = 0;
var n4 = e4.block_start + r4;
if ((0 === e4.strstart || e4.strstart >= n4) && (e4.lookahead = e4.strstart - n4, e4.strstart = n4, N2(e4, false), 0 === e4.strm.avail_out)) return A2;
if (e4.strstart - e4.block_start >= e4.w_size - z2 && (N2(e4, false), 0 === e4.strm.avail_out)) return A2;
}
return e4.insert = 0, t4 === f3 ? (N2(e4, true), 0 === e4.strm.avail_out ? O : B2) : (e4.strstart > e4.block_start && (N2(e4, false), e4.strm.avail_out), A2);
}), new M2(4, 4, 8, 4, Z), new M2(4, 5, 16, 8, Z), new M2(4, 6, 32, 32, Z), new M2(4, 4, 16, 16, W), new M2(8, 16, 32, 32, W), new M2(8, 16, 128, 128, W), new M2(8, 32, 128, 256, W), new M2(32, 128, 258, 1024, W), new M2(32, 258, 258, 4096, W)], r3.deflateInit = function(e4, t4) {
return Y(e4, t4, v2, 15, 8, 0);
}, r3.deflateInit2 = Y, r3.deflateReset = K, r3.deflateResetKeep = G, r3.deflateSetHeader = function(e4, t4) {
return e4 && e4.state ? 2 !== e4.state.wrap ? _2 : (e4.state.gzhead = t4, m2) : _2;
}, r3.deflate = function(e4, t4) {
var r4, n4, i4, s4;
if (!e4 || !e4.state || 5 < t4 || t4 < 0) return e4 ? R2(e4, _2) : _2;
if (n4 = e4.state, !e4.output || !e4.input && 0 !== e4.avail_in || 666 === n4.status && t4 !== f3) return R2(e4, 0 === e4.avail_out ? -5 : _2);
if (n4.strm = e4, r4 = n4.last_flush, n4.last_flush = t4, n4.status === C2) if (2 === n4.wrap) e4.adler = 0, U(n4, 31), U(n4, 139), U(n4, 8), n4.gzhead ? (U(n4, (n4.gzhead.text ? 1 : 0) + (n4.gzhead.hcrc ? 2 : 0) + (n4.gzhead.extra ? 4 : 0) + (n4.gzhead.name ? 8 : 0) + (n4.gzhead.comment ? 16 : 0)), U(n4, 255 & n4.gzhead.time), U(n4, n4.gzhead.time >> 8 & 255), U(n4, n4.gzhead.time >> 16 & 255), U(n4, n4.gzhead.time >> 24 & 255), U(n4, 9 === n4.level ? 2 : 2 <= n4.strategy || n4.level < 2 ? 4 : 0), U(n4, 255 & n4.gzhead.os), n4.gzhead.extra && n4.gzhead.extra.length && (U(n4, 255 & n4.gzhead.extra.length), U(n4, n4.gzhead.extra.length >> 8 & 255)), n4.gzhead.hcrc && (e4.adler = p2(e4.adler, n4.pending_buf, n4.pending, 0)), n4.gzindex = 0, n4.status = 69) : (U(n4, 0), U(n4, 0), U(n4, 0), U(n4, 0), U(n4, 0), U(n4, 9 === n4.level ? 2 : 2 <= n4.strategy || n4.level < 2 ? 4 : 0), U(n4, 3), n4.status = E2);
else {
var a3 = v2 + (n4.w_bits - 8 << 4) << 8;
a3 |= (2 <= n4.strategy || n4.level < 2 ? 0 : n4.level < 6 ? 1 : 6 === n4.level ? 2 : 3) << 6, 0 !== n4.strstart && (a3 |= 32), a3 += 31 - a3 % 31, n4.status = E2, P2(n4, a3), 0 !== n4.strstart && (P2(n4, e4.adler >>> 16), P2(n4, 65535 & e4.adler)), e4.adler = 1;
}
if (69 === n4.status) if (n4.gzhead.extra) {
for (i4 = n4.pending; n4.gzindex < (65535 & n4.gzhead.extra.length) && (n4.pending !== n4.pending_buf_size || (n4.gzhead.hcrc && n4.pending > i4 && (e4.adler = p2(e4.adler, n4.pending_buf, n4.pending - i4, i4)), F(e4), i4 = n4.pending, n4.pending !== n4.pending_buf_size)); ) U(n4, 255 & n4.gzhead.extra[n4.gzindex]), n4.gzindex++;
n4.gzhead.hcrc && n4.pending > i4 && (e4.adler = p2(e4.adler, n4.pending_buf, n4.pending - i4, i4)), n4.gzindex === n4.gzhead.extra.length && (n4.gzindex = 0, n4.status = 73);
} else n4.status = 73;
if (73 === n4.status) if (n4.gzhead.name) {
i4 = n4.pending;
do {
if (n4.pending === n4.pending_buf_size && (n4.gzhead.hcrc && n4.pending > i4 && (e4.adler = p2(e4.adler, n4.pending_buf, n4.pending - i4, i4)), F(e4), i4 = n4.pending, n4.pending === n4.pending_buf_size)) {
s4 = 1;
break;
}
s4 = n4.gzindex < n4.gzhead.name.length ? 255 & n4.gzhead.name.charCodeAt(n4.gzindex++) : 0, U(n4, s4);
} while (0 !== s4);
n4.gzhead.hcrc && n4.pending > i4 && (e4.adler = p2(e4.adler, n4.pending_buf, n4.pending - i4, i4)), 0 === s4 && (n4.gzindex = 0, n4.status = 91);
} else n4.status = 91;
if (91 === n4.status) if (n4.gzhead.comment) {
i4 = n4.pending;
do {
if (n4.pending === n4.pending_buf_size && (n4.gzhead.hcrc && n4.pending > i4 && (e4.adler = p2(e4.adler, n4.pending_buf, n4.pending - i4, i4)), F(e4), i4 = n4.pending, n4.pending === n4.pending_buf_size)) {
s4 = 1;
break;
}
s4 = n4.gzindex < n4.gzhead.comment.length ? 255 & n4.gzhead.comment.charCodeAt(n4.gzindex++) : 0, U(n4, s4);
} while (0 !== s4);
n4.gzhead.hcrc && n4.pending > i4 && (e4.adler = p2(e4.adler, n4.pending_buf, n4.pending - i4, i4)), 0 === s4 && (n4.status = 103);
} else n4.status = 103;
if (103 === n4.status && (n4.gzhead.hcrc ? (n4.pending + 2 > n4.pending_buf_size && F(e4), n4.pending + 2 <= n4.pending_buf_size && (U(n4, 255 & e4.adler), U(n4, e4.adler >> 8 & 255), e4.adler = 0, n4.status = E2)) : n4.status = E2), 0 !== n4.pending) {
if (F(e4), 0 === e4.avail_out) return n4.last_flush = -1, m2;
} else if (0 === e4.avail_in && T2(t4) <= T2(r4) && t4 !== f3) return R2(e4, -5);
if (666 === n4.status && 0 !== e4.avail_in) return R2(e4, -5);
if (0 !== e4.avail_in || 0 !== n4.lookahead || t4 !== l2 && 666 !== n4.status) {
var o3 = 2 === n4.strategy ? function(e5, t5) {
for (var r5; ; ) {
if (0 === e5.lookahead && (j2(e5), 0 === e5.lookahead)) {
if (t5 === l2) return A2;
break;
}
if (e5.match_length = 0, r5 = u2._tr_tally(e5, 0, e5.window[e5.strstart]), e5.lookahead--, e5.strstart++, r5 && (N2(e5, false), 0 === e5.strm.avail_out)) return A2;
}
return e5.insert = 0, t5 === f3 ? (N2(e5, true), 0 === e5.strm.avail_out ? O : B2) : e5.last_lit && (N2(e5, false), 0 === e5.strm.avail_out) ? A2 : I2;
}(n4, t4) : 3 === n4.strategy ? function(e5, t5) {
for (var r5, n5, i5, s5, a4 = e5.window; ; ) {
if (e5.lookahead <= S2) {
if (j2(e5), e5.lookahead <= S2 && t5 === l2) return A2;
if (0 === e5.lookahead) break;
}
if (e5.match_length = 0, e5.lookahead >= x2 && 0 < e5.strstart && (n5 = a4[i5 = e5.strstart - 1]) === a4[++i5] && n5 === a4[++i5] && n5 === a4[++i5]) {
s5 = e5.strstart + S2;
do {
} while (n5 === a4[++i5] && n5 === a4[++i5] && n5 === a4[++i5] && n5 === a4[++i5] && n5 === a4[++i5] && n5 === a4[++i5] && n5 === a4[++i5] && n5 === a4[++i5] && i5 < s5);
e5.match_length = S2 - (s5 - i5), e5.match_length > e5.lookahead && (e5.match_length = e5.lookahead);
}
if (e5.match_length >= x2 ? (r5 = u2._tr_tally(e5, 1, e5.match_length - x2), e5.lookahead -= e5.match_length, e5.strstart += e5.match_length, e5.match_length = 0) : (r5 = u2._tr_tally(e5, 0, e5.window[e5.strstart]), e5.lookahead--, e5.strstart++), r5 && (N2(e5, false), 0 === e5.strm.avail_out)) return A2;
}
return e5.insert = 0, t5 === f3 ? (N2(e5, true), 0 === e5.strm.avail_out ? O : B2) : e5.last_lit && (N2(e5, false), 0 === e5.strm.avail_out) ? A2 : I2;
}(n4, t4) : h3[n4.level].func(n4, t4);
if (o3 !== O && o3 !== B2 || (n4.status = 666), o3 === A2 || o3 === O) return 0 === e4.avail_out && (n4.last_flush = -1), m2;
if (o3 === I2 && (1 === t4 ? u2._tr_align(n4) : 5 !== t4 && (u2._tr_stored_block(n4, 0, 0, false), 3 === t4 && (D(n4.head), 0 === n4.lookahead && (n4.strstart = 0, n4.block_start = 0, n4.insert = 0))), F(e4), 0 === e4.avail_out)) return n4.last_flush = -1, m2;
}
return t4 !== f3 ? m2 : n4.wrap <= 0 ? 1 : (2 === n4.wrap ? (U(n4, 255 & e4.adler), U(n4, e4.adler >> 8 & 255), U(n4, e4.adler >> 16 & 255), U(n4, e4.adler >> 24 & 255), U(n4, 255 & e4.total_in), U(n4, e4.total_in >> 8 & 255), U(n4, e4.total_in >> 16 & 255), U(n4, e4.total_in >> 24 & 255)) : (P2(n4, e4.adler >>> 16), P2(n4, 65535 & e4.adler)), F(e4), 0 < n4.wrap && (n4.wrap = -n4.wrap), 0 !== n4.pending ? m2 : 1);
}, r3.deflateEnd = function(e4) {
var t4;
return e4 && e4.state ? (t4 = e4.state.status) !== C2 && 69 !== t4 && 73 !== t4 && 91 !== t4 && 103 !== t4 && t4 !== E2 && 666 !== t4 ? R2(e4, _2) : (e4.state = null, t4 === E2 ? R2(e4, -3) : m2) : _2;
}, r3.deflateSetDictionary = function(e4, t4) {
var r4, n4, i4, s4, a3, o3, h4, u3, l3 = t4.length;
if (!e4 || !e4.state) return _2;
if (2 === (s4 = (r4 = e4.state).wrap) || 1 === s4 && r4.status !== C2 || r4.lookahead) return _2;
for (1 === s4 && (e4.adler = d2(e4.adler, t4, l3, 0)), r4.wrap = 0, l3 >= r4.w_size && (0 === s4 && (D(r4.head), r4.strstart = 0, r4.block_start = 0, r4.insert = 0), u3 = new c3.Buf8(r4.w_size), c3.arraySet(u3, t4, l3 - r4.w_size, r4.w_size, 0), t4 = u3, l3 = r4.w_size), a3 = e4.avail_in, o3 = e4.next_in, h4 = e4.input, e4.avail_in = l3, e4.next_in = 0, e4.input = t4, j2(r4); r4.lookahead >= x2; ) {
for (n4 = r4.strstart, i4 = r4.lookahead - (x2 - 1); r4.ins_h = (r4.ins_h << r4.hash_shift ^ r4.window[n4 + x2 - 1]) & r4.hash_mask, r4.prev[n4 & r4.w_mask] = r4.head[r4.ins_h], r4.head[r4.ins_h] = n4, n4++, --i4; ) ;
r4.strstart = n4, r4.lookahead = x2 - 1, j2(r4);
}
return r4.strstart += r4.lookahead, r4.block_start = r4.strstart, r4.insert = r4.lookahead, r4.lookahead = 0, r4.match_length = r4.prev_length = x2 - 1, r4.match_available = 0, e4.next_in = o3, e4.input = h4, e4.avail_in = a3, r4.wrap = s4, m2;
}, r3.deflateInfo = "pako deflate (from Nodeca project)";
}, { "../utils/common": 41, "./adler32": 43, "./crc32": 45, "./messages": 51, "./trees": 52 }], 47: [function(e3, t3, r3) {
t3.exports = function() {
this.text = 0, this.time = 0, this.xflags = 0, this.os = 0, this.extra = null, this.extra_len = 0, this.name = "", this.comment = "", this.hcrc = 0, this.done = false;
};
}, {}], 48: [function(e3, t3, r3) {
t3.exports = function(e4, t4) {
var r4, n3, i3, s3, a2, o2, h3, u2, l2, f3, c3, d2, p2, m2, _2, g2, b3, v2, y2, w2, k3, x2, S2, z2, C2;
r4 = e4.state, n3 = e4.next_in, z2 = e4.input, i3 = n3 + (e4.avail_in - 5), s3 = e4.next_out, C2 = e4.output, a2 = s3 - (t4 - e4.avail_out), o2 = s3 + (e4.avail_out - 257), h3 = r4.dmax, u2 = r4.wsize, l2 = r4.whave, f3 = r4.wnext, c3 = r4.window, d2 = r4.hold, p2 = r4.bits, m2 = r4.lencode, _2 = r4.distcode, g2 = (1 << r4.lenbits) - 1, b3 = (1 << r4.distbits) - 1;
e: do {
p2 < 15 && (d2 += z2[n3++] << p2, p2 += 8, d2 += z2[n3++] << p2, p2 += 8), v2 = m2[d2 & g2];
t: for (; ; ) {
if (d2 >>>= y2 = v2 >>> 24, p2 -= y2, 0 === (y2 = v2 >>> 16 & 255)) C2[s3++] = 65535 & v2;
else {
if (!(16 & y2)) {
if (0 == (64 & y2)) {
v2 = m2[(65535 & v2) + (d2 & (1 << y2) - 1)];
continue t;
}
if (32 & y2) {
r4.mode = 12;
break e;
}
e4.msg = "invalid literal/length code", r4.mode = 30;
break e;
}
w2 = 65535 & v2, (y2 &= 15) && (p2 < y2 && (d2 += z2[n3++] << p2, p2 += 8), w2 += d2 & (1 << y2) - 1, d2 >>>= y2, p2 -= y2), p2 < 15 && (d2 += z2[n3++] << p2, p2 += 8, d2 += z2[n3++] << p2, p2 += 8), v2 = _2[d2 & b3];
r: for (; ; ) {
if (d2 >>>= y2 = v2 >>> 24, p2 -= y2, !(16 & (y2 = v2 >>> 16 & 255))) {
if (0 == (64 & y2)) {
v2 = _2[(65535 & v2) + (d2 & (1 << y2) - 1)];
continue r;
}
e4.msg = "invalid distance code", r4.mode = 30;
break e;
}
if (k3 = 65535 & v2, p2 < (y2 &= 15) && (d2 += z2[n3++] << p2, (p2 += 8) < y2 && (d2 += z2[n3++] << p2, p2 += 8)), h3 < (k3 += d2 & (1 << y2) - 1)) {
e4.msg = "invalid distance too far back", r4.mode = 30;
break e;
}
if (d2 >>>= y2, p2 -= y2, (y2 = s3 - a2) < k3) {
if (l2 < (y2 = k3 - y2) && r4.sane) {
e4.msg = "invalid distance too far back", r4.mode = 30;
break e;
}
if (S2 = c3, (x2 = 0) === f3) {
if (x2 += u2 - y2, y2 < w2) {
for (w2 -= y2; C2[s3++] = c3[x2++], --y2; ) ;
x2 = s3 - k3, S2 = C2;
}
} else if (f3 < y2) {
if (x2 += u2 + f3 - y2, (y2 -= f3) < w2) {
for (w2 -= y2; C2[s3++] = c3[x2++], --y2; ) ;
if (x2 = 0, f3 < w2) {
for (w2 -= y2 = f3; C2[s3++] = c3[x2++], --y2; ) ;
x2 = s3 - k3, S2 = C2;
}
}
} else if (x2 += f3 - y2, y2 < w2) {
for (w2 -= y2; C2[s3++] = c3[x2++], --y2; ) ;
x2 = s3 - k3, S2 = C2;
}
for (; 2 < w2; ) C2[s3++] = S2[x2++], C2[s3++] = S2[x2++], C2[s3++] = S2[x2++], w2 -= 3;
w2 && (C2[s3++] = S2[x2++], 1 < w2 && (C2[s3++] = S2[x2++]));
} else {
for (x2 = s3 - k3; C2[s3++] = C2[x2++], C2[s3++] = C2[x2++], C2[s3++] = C2[x2++], 2 < (w2 -= 3); ) ;
w2 && (C2[s3++] = C2[x2++], 1 < w2 && (C2[s3++] = C2[x2++]));
}
break;
}
}
break;
}
} while (n3 < i3 && s3 < o2);
n3 -= w2 = p2 >> 3, d2 &= (1 << (p2 -= w2 << 3)) - 1, e4.next_in = n3, e4.next_out = s3, e4.avail_in = n3 < i3 ? i3 - n3 + 5 : 5 - (n3 - i3), e4.avail_out = s3 < o2 ? o2 - s3 + 257 : 257 - (s3 - o2), r4.hold = d2, r4.bits = p2;
};
}, {}], 49: [function(e3, t3, r3) {
var I2 = e3("../utils/common"), O = e3("./adler32"), B2 = e3("./crc32"), R2 = e3("./inffast"), T2 = e3("./inftrees"), D = 1, F = 2, N2 = 0, U = -2, P2 = 1, n3 = 852, i3 = 592;
function L2(e4) {
return (e4 >>> 24 & 255) + (e4 >>> 8 & 65280) + ((65280 & e4) << 8) + ((255 & e4) << 24);
}
function s3() {
this.mode = 0, this.last = false, this.wrap = 0, this.havedict = false, this.flags = 0, this.dmax = 0, this.check = 0, this.total = 0, this.head = null, this.wbits = 0, this.wsize = 0, this.whave = 0, this.wnext = 0, this.window = null, this.hold = 0, this.bits = 0, this.length = 0, this.offset = 0, this.extra = 0, this.lencode = null, this.distcode = null, this.lenbits = 0, this.distbits = 0, this.ncode = 0, this.nlen = 0, this.ndist = 0, this.have = 0, this.next = null, this.lens = new I2.Buf16(320), this.work = new I2.Buf16(288), this.lendyn = null, this.distdyn = null, this.sane = 0, this.back = 0, this.was = 0;
}
function a2(e4) {
var t4;
return e4 && e4.state ? (t4 = e4.state, e4.total_in = e4.total_out = t4.total = 0, e4.msg = "", t4.wrap && (e4.adler = 1 & t4.wrap), t4.mode = P2, t4.last = 0, t4.havedict = 0, t4.dmax = 32768, t4.head = null, t4.hold = 0, t4.bits = 0, t4.lencode = t4.lendyn = new I2.Buf32(n3), t4.distcode = t4.distdyn = new I2.Buf32(i3), t4.sane = 1, t4.back = -1, N2) : U;
}
function o2(e4) {
var t4;
return e4 && e4.state ? ((t4 = e4.state).wsize = 0, t4.whave = 0, t4.wnext = 0, a2(e4)) : U;
}
function h3(e4, t4) {
var r4, n4;
return e4 && e4.state ? (n4 = e4.state, t4 < 0 ? (r4 = 0, t4 = -t4) : (r4 = 1 + (t4 >> 4), t4 < 48 && (t4 &= 15)), t4 && (t4 < 8 || 15 < t4) ? U : (null !== n4.window && n4.wbits !== t4 && (n4.window = null), n4.wrap = r4, n4.wbits = t4, o2(e4))) : U;
}
function u2(e4, t4) {
var r4, n4;
return e4 ? (n4 = new s3(), (e4.state = n4).window = null, (r4 = h3(e4, t4)) !== N2 && (e4.state = null), r4) : U;
}
var l2, f3, c3 = true;
function j2(e4) {
if (c3) {
var t4;
for (l2 = new I2.Buf32(512), f3 = new I2.Buf32(32), t4 = 0; t4 < 144; ) e4.lens[t4++] = 8;
for (; t4 < 256; ) e4.lens[t4++] = 9;
for (; t4 < 280; ) e4.lens[t4++] = 7;
for (; t4 < 288; ) e4.lens[t4++] = 8;
for (T2(D, e4.lens, 0, 288, l2, 0, e4.work, { bits: 9 }), t4 = 0; t4 < 32; ) e4.lens[t4++] = 5;
T2(F, e4.lens, 0, 32, f3, 0, e4.work, { bits: 5 }), c3 = false;
}
e4.lencode = l2, e4.lenbits = 9, e4.distcode = f3, e4.distbits = 5;
}
function Z(e4, t4, r4, n4) {
var i4, s4 = e4.state;
return null === s4.window && (s4.wsize = 1 << s4.wbits, s4.wnext = 0, s4.whave = 0, s4.window = new I2.Buf8(s4.wsize)), n4 >= s4.wsize ? (I2.arraySet(s4.window, t4, r4 - s4.wsize, s4.wsize, 0), s4.wnext = 0, s4.whave = s4.wsize) : (n4 < (i4 = s4.wsize - s4.wnext) && (i4 = n4), I2.arraySet(s4.window, t4, r4 - n4, i4, s4.wnext), (n4 -= i4) ? (I2.arraySet(s4.window, t4, r4 - n4, n4, 0), s4.wnext = n4, s4.whave = s4.wsize) : (s4.wnext += i4, s4.wnext === s4.wsize && (s4.wnext = 0), s4.whave < s4.wsize && (s4.whave += i4))), 0;
}
r3.inflateReset = o2, r3.inflateReset2 = h3, r3.inflateResetKeep = a2, r3.inflateInit = function(e4) {
return u2(e4, 15);
}, r3.inflateInit2 = u2, r3.inflate = function(e4, t4) {
var r4, n4, i4, s4, a3, o3, h4, u3, l3, f4, c4, d2, p2, m2, _2, g2, b3, v2, y2, w2, k3, x2, S2, z2, C2 = 0, E2 = new I2.Buf8(4), A2 = [16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15];
if (!e4 || !e4.state || !e4.output || !e4.input && 0 !== e4.avail_in) return U;
12 === (r4 = e4.state).mode && (r4.mode = 13), a3 = e4.next_out, i4 = e4.output, h4 = e4.avail_out, s4 = e4.next_in, n4 = e4.input, o3 = e4.avail_in, u3 = r4.hold, l3 = r4.bits, f4 = o3, c4 = h4, x2 = N2;
e: for (; ; ) switch (r4.mode) {
case P2:
if (0 === r4.wrap) {
r4.mode = 13;
break;
}
for (; l3 < 16; ) {
if (0 === o3) break e;
o3--, u3 += n4[s4++] << l3, l3 += 8;
}
if (2 & r4.wrap && 35615 === u3) {
E2[r4.check = 0] = 255 & u3, E2[1] = u3 >>> 8 & 255, r4.check = B2(r4.check, E2, 2, 0), l3 = u3 = 0, r4.mode = 2;
break;
}
if (r4.flags = 0, r4.head && (r4.head.done = false), !(1 & r4.wrap) || (((255 & u3) << 8) + (u3 >> 8)) % 31) {
e4.msg = "incorrect header check", r4.mode = 30;
break;
}
if (8 != (15 & u3)) {
e4.msg = "unknown compression method", r4.mode = 30;
break;
}
if (l3 -= 4, k3 = 8 + (15 & (u3 >>>= 4)), 0 === r4.wbits) r4.wbits = k3;
else if (k3 > r4.wbits) {
e4.msg = "invalid window size", r4.mode = 30;
break;
}
r4.dmax = 1 << k3, e4.adler = r4.check = 1, r4.mode = 512 & u3 ? 10 : 12, l3 = u3 = 0;
break;
case 2:
for (; l3 < 16; ) {
if (0 === o3) break e;
o3--, u3 += n4[s4++] << l3, l3 += 8;
}
if (r4.flags = u3, 8 != (255 & r4.flags)) {
e4.msg = "unknown compression method", r4.mode = 30;
break;
}
if (57344 & r4.flags) {
e4.msg = "unknown header flags set", r4.mode = 30;
break;
}
r4.head && (r4.head.text = u3 >> 8 & 1), 512 & r4.flags && (E2[0] = 255 & u3, E2[1] = u3 >>> 8 & 255, r4.check = B2(r4.check, E2, 2, 0)), l3 = u3 = 0, r4.mode = 3;
case 3:
for (; l3 < 32; ) {
if (0 === o3) break e;
o3--, u3 += n4[s4++] << l3, l3 += 8;
}
r4.head && (r4.head.time = u3), 512 & r4.flags && (E2[0] = 255 & u3, E2[1] = u3 >>> 8 & 255, E2[2] = u3 >>> 16 & 255, E2[3] = u3 >>> 24 & 255, r4.check = B2(r4.check, E2, 4, 0)), l3 = u3 = 0, r4.mode = 4;
case 4:
for (; l3 < 16; ) {
if (0 === o3) break e;
o3--, u3 += n4[s4++] << l3, l3 += 8;
}
r4.head && (r4.head.xflags = 255 & u3, r4.head.os = u3 >> 8), 512 & r4.flags && (E2[0] = 255 & u3, E2[1] = u3 >>> 8 & 255, r4.check = B2(r4.check, E2, 2, 0)), l3 = u3 = 0, r4.mode = 5;
case 5:
if (1024 & r4.flags) {
for (; l3 < 16; ) {
if (0 === o3) break e;
o3--, u3 += n4[s4++] << l3, l3 += 8;
}
r4.length = u3, r4.head && (r4.head.extra_len = u3), 512 & r4.flags && (E2[0] = 255 & u3, E2[1] = u3 >>> 8 & 255, r4.check = B2(r4.check, E2, 2, 0)), l3 = u3 = 0;
} else r4.head && (r4.head.extra = null);
r4.mode = 6;
case 6:
if (1024 & r4.flags && (o3 < (d2 = r4.length) && (d2 = o3), d2 && (r4.head && (k3 = r4.head.extra_len - r4.length, r4.head.extra || (r4.head.extra = new Array(r4.head.extra_len)), I2.arraySet(r4.head.extra, n4, s4, d2, k3)), 512 & r4.flags && (r4.check = B2(r4.check, n4, d2, s4)), o3 -= d2, s4 += d2, r4.length -= d2), r4.length)) break e;
r4.length = 0, r4.mode = 7;
case 7:
if (2048 & r4.flags) {
if (0 === o3) break e;
for (d2 = 0; k3 = n4[s4 + d2++], r4.head && k3 && r4.length < 65536 && (r4.head.name += String.fromCharCode(k3)), k3 && d2 < o3; ) ;
if (512 & r4.flags && (r4.check = B2(r4.check, n4, d2, s4)), o3 -= d2, s4 += d2, k3) break e;
} else r4.head && (r4.head.name = null);
r4.length = 0, r4.mode = 8;
case 8:
if (4096 & r4.flags) {
if (0 === o3) break e;
for (d2 = 0; k3 = n4[s4 + d2++], r4.head && k3 && r4.length < 65536 && (r4.head.comment += String.fromCharCode(k3)), k3 && d2 < o3; ) ;
if (512 & r4.flags && (r4.check = B2(r4.check, n4, d2, s4)), o3 -= d2, s4 += d2, k3) break e;
} else r4.head && (r4.head.comment = null);
r4.mode = 9;
case 9:
if (512 & r4.flags) {
for (; l3 < 16; ) {
if (0 === o3) break e;
o3--, u3 += n4[s4++] << l3, l3 += 8;
}
if (u3 !== (65535 & r4.check)) {
e4.msg = "header crc mismatch", r4.mode = 30;
break;
}
l3 = u3 = 0;
}
r4.head && (r4.head.hcrc = r4.flags >> 9 & 1, r4.head.done = true), e4.adler = r4.check = 0, r4.mode = 12;
break;
case 10:
for (; l3 < 32; ) {
if (0 === o3) break e;
o3--, u3 += n4[s4++] << l3, l3 += 8;
}
e4.adler = r4.check = L2(u3), l3 = u3 = 0, r4.mode = 11;
case 11:
if (0 === r4.havedict) return e4.next_out = a3, e4.avail_out = h4, e4.next_in = s4, e4.avail_in = o3, r4.hold = u3, r4.bits = l3, 2;
e4.adler = r4.check = 1, r4.mode = 12;
case 12:
if (5 === t4 || 6 === t4) break e;
case 13:
if (r4.last) {
u3 >>>= 7 & l3, l3 -= 7 & l3, r4.mode = 27;
break;
}
for (; l3 < 3; ) {
if (0 === o3) break e;
o3--, u3 += n4[s4++] << l3, l3 += 8;
}
switch (r4.last = 1 & u3, l3 -= 1, 3 & (u3 >>>= 1)) {
case 0:
r4.mode = 14;
break;
case 1:
if (j2(r4), r4.mode = 20, 6 !== t4) break;
u3 >>>= 2, l3 -= 2;
break e;
case 2:
r4.mode = 17;
break;
case 3:
e4.msg = "invalid block type", r4.mode = 30;
}
u3 >>>= 2, l3 -= 2;
break;
case 14:
for (u3 >>>= 7 & l3, l3 -= 7 & l3; l3 < 32; ) {
if (0 === o3) break e;
o3--, u3 += n4[s4++] << l3, l3 += 8;
}
if ((65535 & u3) != (u3 >>> 16 ^ 65535)) {
e4.msg = "invalid stored block lengths", r4.mode = 30;
break;
}
if (r4.length = 65535 & u3, l3 = u3 = 0, r4.mode = 15, 6 === t4) break e;
case 15:
r4.mode = 16;
case 16:
if (d2 = r4.length) {
if (o3 < d2 && (d2 = o3), h4 < d2 && (d2 = h4), 0 === d2) break e;
I2.arraySet(i4, n4, s4, d2, a3), o3 -= d2, s4 += d2, h4 -= d2, a3 += d2, r4.length -= d2;
break;
}
r4.mode = 12;
break;
case 17:
for (; l3 < 14; ) {
if (0 === o3) break e;
o3--, u3 += n4[s4++] << l3, l3 += 8;
}
if (r4.nlen = 257 + (31 & u3), u3 >>>= 5, l3 -= 5, r4.ndist = 1 + (31 & u3), u3 >>>= 5, l3 -= 5, r4.ncode = 4 + (15 & u3), u3 >>>= 4, l3 -= 4, 286 < r4.nlen || 30 < r4.ndist) {
e4.msg = "too many length or distance symbols", r4.mode = 30;
break;
}
r4.have = 0, r4.mode = 18;
case 18:
for (; r4.have < r4.ncode; ) {
for (; l3 < 3; ) {
if (0 === o3) break e;
o3--, u3 += n4[s4++] << l3, l3 += 8;
}
r4.lens[A2[r4.have++]] = 7 & u3, u3 >>>= 3, l3 -= 3;
}
for (; r4.have < 19; ) r4.lens[A2[r4.have++]] = 0;
if (r4.lencode = r4.lendyn, r4.lenbits = 7, S2 = { bits: r4.lenbits }, x2 = T2(0, r4.lens, 0, 19, r4.lencode, 0, r4.work, S2), r4.lenbits = S2.bits, x2) {
e4.msg = "invalid code lengths set", r4.mode = 30;
break;
}
r4.have = 0, r4.mode = 19;
case 19:
for (; r4.have < r4.nlen + r4.ndist; ) {
for (; g2 = (C2 = r4.lencode[u3 & (1 << r4.lenbits) - 1]) >>> 16 & 255, b3 = 65535 & C2, !((_2 = C2 >>> 24) <= l3); ) {
if (0 === o3) break e;
o3--, u3 += n4[s4++] << l3, l3 += 8;
}
if (b3 < 16) u3 >>>= _2, l3 -= _2, r4.lens[r4.have++] = b3;
else {
if (16 === b3) {
for (z2 = _2 + 2; l3 < z2; ) {
if (0 === o3) break e;
o3--, u3 += n4[s4++] << l3, l3 += 8;
}
if (u3 >>>= _2, l3 -= _2, 0 === r4.have) {
e4.msg = "invalid bit length repeat", r4.mode = 30;
break;
}
k3 = r4.lens[r4.have - 1], d2 = 3 + (3 & u3), u3 >>>= 2, l3 -= 2;
} else if (17 === b3) {
for (z2 = _2 + 3; l3 < z2; ) {
if (0 === o3) break e;
o3--, u3 += n4[s4++] << l3, l3 += 8;
}
l3 -= _2, k3 = 0, d2 = 3 + (7 & (u3 >>>= _2)), u3 >>>= 3, l3 -= 3;
} else {
for (z2 = _2 + 7; l3 < z2; ) {
if (0 === o3) break e;
o3--, u3 += n4[s4++] << l3, l3 += 8;
}
l3 -= _2, k3 = 0, d2 = 11 + (127 & (u3 >>>= _2)), u3 >>>= 7, l3 -= 7;
}
if (r4.have + d2 > r4.nlen + r4.ndist) {
e4.msg = "invalid bit length repeat", r4.mode = 30;
break;
}
for (; d2--; ) r4.lens[r4.have++] = k3;
}
}
if (30 === r4.mode) break;
if (0 === r4.lens[256]) {
e4.msg = "invalid code -- missing end-of-block", r4.mode = 30;
break;
}
if (r4.lenbits = 9, S2 = { bits: r4.lenbits }, x2 = T2(D, r4.lens, 0, r4.nlen, r4.lencode, 0, r4.work, S2), r4.lenbits = S2.bits, x2) {
e4.msg = "invalid literal/lengths set", r4.mode = 30;
break;
}
if (r4.distbits = 6, r4.distcode = r4.distdyn, S2 = { bits: r4.distbits }, x2 = T2(F, r4.lens, r4.nlen, r4.ndist, r4.distcode, 0, r4.work, S2), r4.distbits = S2.bits, x2) {
e4.msg = "invalid distances set", r4.mode = 30;
break;
}
if (r4.mode = 20, 6 === t4) break e;
case 20:
r4.mode = 21;
case 21:
if (6 <= o3 && 258 <= h4) {
e4.next_out = a3, e4.avail_out = h4, e4.next_in = s4, e4.avail_in = o3, r4.hold = u3, r4.bits = l3, R2(e4, c4), a3 = e4.next_out, i4 = e4.output, h4 = e4.avail_out, s4 = e4.next_in, n4 = e4.input, o3 = e4.avail_in, u3 = r4.hold, l3 = r4.bits, 12 === r4.mode && (r4.back = -1);
break;
}
for (r4.back = 0; g2 = (C2 = r4.lencode[u3 & (1 << r4.lenbits) - 1]) >>> 16 & 255, b3 = 65535 & C2, !((_2 = C2 >>> 24) <= l3); ) {
if (0 === o3) break e;
o3--, u3 += n4[s4++] << l3, l3 += 8;
}
if (g2 && 0 == (240 & g2)) {
for (v2 = _2, y2 = g2, w2 = b3; g2 = (C2 = r4.lencode[w2 + ((u3 & (1 << v2 + y2) - 1) >> v2)]) >>> 16 & 255, b3 = 65535 & C2, !(v2 + (_2 = C2 >>> 24) <= l3); ) {
if (0 === o3) break e;
o3--, u3 += n4[s4++] << l3, l3 += 8;
}
u3 >>>= v2, l3 -= v2, r4.back += v2;
}
if (u3 >>>= _2, l3 -= _2, r4.back += _2, r4.length = b3, 0 === g2) {
r4.mode = 26;
break;
}
if (32 & g2) {
r4.back = -1, r4.mode = 12;
break;
}
if (64 & g2) {
e4.msg = "invalid literal/length code", r4.mode = 30;
break;
}
r4.extra = 15 & g2, r4.mode = 22;
case 22:
if (r4.extra) {
for (z2 = r4.extra; l3 < z2; ) {
if (0 === o3) break e;
o3--, u3 += n4[s4++] << l3, l3 += 8;
}
r4.length += u3 & (1 << r4.extra) - 1, u3 >>>= r4.extra, l3 -= r4.extra, r4.back += r4.extra;
}
r4.was = r4.length, r4.mode = 23;
case 23:
for (; g2 = (C2 = r4.distcode[u3 & (1 << r4.distbits) - 1]) >>> 16 & 255, b3 = 65535 & C2, !((_2 = C2 >>> 24) <= l3); ) {
if (0 === o3) break e;
o3--, u3 += n4[s4++] << l3, l3 += 8;
}
if (0 == (240 & g2)) {
for (v2 = _2, y2 = g2, w2 = b3; g2 = (C2 = r4.distcode[w2 + ((u3 & (1 << v2 + y2) - 1) >> v2)]) >>> 16 & 255, b3 = 65535 & C2, !(v2 + (_2 = C2 >>> 24) <= l3); ) {
if (0 === o3) break e;
o3--, u3 += n4[s4++] << l3, l3 += 8;
}
u3 >>>= v2, l3 -= v2, r4.back += v2;
}
if (u3 >>>= _2, l3 -= _2, r4.back += _2, 64 & g2) {
e4.msg = "invalid distance code", r4.mode = 30;
break;
}
r4.offset = b3, r4.extra = 15 & g2, r4.mode = 24;
case 24:
if (r4.extra) {
for (z2 = r4.extra; l3 < z2; ) {
if (0 === o3) break e;
o3--, u3 += n4[s4++] << l3, l3 += 8;
}
r4.offset += u3 & (1 << r4.extra) - 1, u3 >>>= r4.extra, l3 -= r4.extra, r4.back += r4.extra;
}
if (r4.offset > r4.dmax) {
e4.msg = "invalid distance too far back", r4.mode = 30;
break;
}
r4.mode = 25;
case 25:
if (0 === h4) break e;
if (d2 = c4 - h4, r4.offset > d2) {
if ((d2 = r4.offset - d2) > r4.whave && r4.sane) {
e4.msg = "invalid distance too far back", r4.mode = 30;
break;
}
p2 = d2 > r4.wnext ? (d2 -= r4.wnext, r4.wsize - d2) : r4.wnext - d2, d2 > r4.length && (d2 = r4.length), m2 = r4.window;
} else m2 = i4, p2 = a3 - r4.offset, d2 = r4.length;
for (h4 < d2 && (d2 = h4), h4 -= d2, r4.length -= d2; i4[a3++] = m2[p2++], --d2; ) ;
0 === r4.length && (r4.mode = 21);
break;
case 26:
if (0 === h4) break e;
i4[a3++] = r4.length, h4--, r4.mode = 21;
break;
case 27:
if (r4.wrap) {
for (; l3 < 32; ) {
if (0 === o3) break e;
o3--, u3 |= n4[s4++] << l3, l3 += 8;
}
if (c4 -= h4, e4.total_out += c4, r4.total += c4, c4 && (e4.adler = r4.check = r4.flags ? B2(r4.check, i4, c4, a3 - c4) : O(r4.check, i4, c4, a3 - c4)), c4 = h4, (r4.flags ? u3 : L2(u3)) !== r4.check) {
e4.msg = "incorrect data check", r4.mode = 30;
break;
}
l3 = u3 = 0;
}
r4.mode = 28;
case 28:
if (r4.wrap && r4.flags) {
for (; l3 < 32; ) {
if (0 === o3) break e;
o3--, u3 += n4[s4++] << l3, l3 += 8;
}
if (u3 !== (4294967295 & r4.total)) {
e4.msg = "incorrect length check", r4.mode = 30;
break;
}
l3 = u3 = 0;
}
r4.mode = 29;
case 29:
x2 = 1;
break e;
case 30:
x2 = -3;
break e;
case 31:
return -4;
case 32:
default:
return U;
}
return e4.next_out = a3, e4.avail_out = h4, e4.next_in = s4, e4.avail_in = o3, r4.hold = u3, r4.bits = l3, (r4.wsize || c4 !== e4.avail_out && r4.mode < 30 && (r4.mode < 27 || 4 !== t4)) && Z(e4, e4.output, e4.next_out, c4 - e4.avail_out) ? (r4.mode = 31, -4) : (f4 -= e4.avail_in, c4 -= e4.avail_out, e4.total_in += f4, e4.total_out += c4, r4.total += c4, r4.wrap && c4 && (e4.adler = r4.check = r4.flags ? B2(r4.check, i4, c4, e4.next_out - c4) : O(r4.check, i4, c4, e4.next_out - c4)), e4.data_type = r4.bits + (r4.last ? 64 : 0) + (12 === r4.mode ? 128 : 0) + (20 === r4.mode || 15 === r4.mode ? 256 : 0), (0 == f4 && 0 === c4 || 4 === t4) && x2 === N2 && (x2 = -5), x2);
}, r3.inflateEnd = function(e4) {
if (!e4 || !e4.state) return U;
var t4 = e4.state;
return t4.window && (t4.window = null), e4.state = null, N2;
}, r3.inflateGetHeader = function(e4, t4) {
var r4;
return e4 && e4.state ? 0 == (2 & (r4 = e4.state).wrap) ? U : ((r4.head = t4).done = false, N2) : U;
}, r3.inflateSetDictionary = function(e4, t4) {
var r4, n4 = t4.length;
return e4 && e4.state ? 0 !== (r4 = e4.state).wrap && 11 !== r4.mode ? U : 11 === r4.mode && O(1, t4, n4, 0) !== r4.check ? -3 : Z(e4, t4, n4, n4) ? (r4.mode = 31, -4) : (r4.havedict = 1, N2) : U;
}, r3.inflateInfo = "pako inflate (from Nodeca project)";
}, { "../utils/common": 41, "./adler32": 43, "./crc32": 45, "./inffast": 48, "./inftrees": 50 }], 50: [function(e3, t3, r3) {
var D = e3("../utils/common"), F = [3, 4, 5, 6, 7, 8, 9, 10, 11, 13, 15, 17, 19, 23, 27, 31, 35, 43, 51, 59, 67, 83, 99, 115, 131, 163, 195, 227, 258, 0, 0], N2 = [16, 16, 16, 16, 16, 16, 16, 16, 17, 17, 17, 17, 18, 18, 18, 18, 19, 19, 19, 19, 20, 20, 20, 20, 21, 21, 21, 21, 16, 72, 78], U = [1, 2, 3, 4, 5, 7, 9, 13, 17, 25, 33, 49, 65, 97, 129, 193, 257, 385, 513, 769, 1025, 1537, 2049, 3073, 4097, 6145, 8193, 12289, 16385, 24577, 0, 0], P2 = [16, 16, 16, 16, 17, 17, 18, 18, 19, 19, 20, 20, 21, 21, 22, 22, 23, 23, 24, 24, 25, 25, 26, 26, 27, 27, 28, 28, 29, 29, 64, 64];
t3.exports = function(e4, t4, r4, n3, i3, s3, a2, o2) {
var h3, u2, l2, f3, c3, d2, p2, m2, _2, g2 = o2.bits, b3 = 0, v2 = 0, y2 = 0, w2 = 0, k3 = 0, x2 = 0, S2 = 0, z2 = 0, C2 = 0, E2 = 0, A2 = null, I2 = 0, O = new D.Buf16(16), B2 = new D.Buf16(16), R2 = null, T2 = 0;
for (b3 = 0; b3 <= 15; b3++) O[b3] = 0;
for (v2 = 0; v2 < n3; v2++) O[t4[r4 + v2]]++;
for (k3 = g2, w2 = 15; 1 <= w2 && 0 === O[w2]; w2--) ;
if (w2 < k3 && (k3 = w2), 0 === w2) return i3[s3++] = 20971520, i3[s3++] = 20971520, o2.bits = 1, 0;
for (y2 = 1; y2 < w2 && 0 === O[y2]; y2++) ;
for (k3 < y2 && (k3 = y2), b3 = z2 = 1; b3 <= 15; b3++) if (z2 <<= 1, (z2 -= O[b3]) < 0) return -1;
if (0 < z2 && (0 === e4 || 1 !== w2)) return -1;
for (B2[1] = 0, b3 = 1; b3 < 15; b3++) B2[b3 + 1] = B2[b3] + O[b3];
for (v2 = 0; v2 < n3; v2++) 0 !== t4[r4 + v2] && (a2[B2[t4[r4 + v2]]++] = v2);
if (d2 = 0 === e4 ? (A2 = R2 = a2, 19) : 1 === e4 ? (A2 = F, I2 -= 257, R2 = N2, T2 -= 257, 256) : (A2 = U, R2 = P2, -1), b3 = y2, c3 = s3, S2 = v2 = E2 = 0, l2 = -1, f3 = (C2 = 1 << (x2 = k3)) - 1, 1 === e4 && 852 < C2 || 2 === e4 && 592 < C2) return 1;
for (; ; ) {
for (p2 = b3 - S2, _2 = a2[v2] < d2 ? (m2 = 0, a2[v2]) : a2[v2] > d2 ? (m2 = R2[T2 + a2[v2]], A2[I2 + a2[v2]]) : (m2 = 96, 0), h3 = 1 << b3 - S2, y2 = u2 = 1 << x2; i3[c3 + (E2 >> S2) + (u2 -= h3)] = p2 << 24 | m2 << 16 | _2 | 0, 0 !== u2; ) ;
for (h3 = 1 << b3 - 1; E2 & h3; ) h3 >>= 1;
if (0 !== h3 ? (E2 &= h3 - 1, E2 += h3) : E2 = 0, v2++, 0 == --O[b3]) {
if (b3 === w2) break;
b3 = t4[r4 + a2[v2]];
}
if (k3 < b3 && (E2 & f3) !== l2) {
for (0 === S2 && (S2 = k3), c3 += y2, z2 = 1 << (x2 = b3 - S2); x2 + S2 < w2 && !((z2 -= O[x2 + S2]) <= 0); ) x2++, z2 <<= 1;
if (C2 += 1 << x2, 1 === e4 && 852 < C2 || 2 === e4 && 592 < C2) return 1;
i3[l2 = E2 & f3] = k3 << 24 | x2 << 16 | c3 - s3 | 0;
}
}
return 0 !== E2 && (i3[c3 + E2] = b3 - S2 << 24 | 64 << 16 | 0), o2.bits = k3, 0;
};
}, { "../utils/common": 41 }], 51: [function(e3, t3, r3) {
t3.exports = { 2: "need dictionary", 1: "stream end", 0: "", "-1": "file error", "-2": "stream error", "-3": "data error", "-4": "insufficient memory", "-5": "buffer error", "-6": "incompatible version" };
}, {}], 52: [function(e3, t3, r3) {
var i3 = e3("../utils/common"), o2 = 0, h3 = 1;
function n3(e4) {
for (var t4 = e4.length; 0 <= --t4; ) e4[t4] = 0;
}
var s3 = 0, a2 = 29, u2 = 256, l2 = u2 + 1 + a2, f3 = 30, c3 = 19, _2 = 2 * l2 + 1, g2 = 15, d2 = 16, p2 = 7, m2 = 256, b3 = 16, v2 = 17, y2 = 18, w2 = [0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 2, 2, 2, 2, 3, 3, 3, 3, 4, 4, 4, 4, 5, 5, 5, 5, 0], k3 = [0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13], x2 = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 3, 7], S2 = [16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15], z2 = new Array(2 * (l2 + 2));
n3(z2);
var C2 = new Array(2 * f3);
n3(C2);
var E2 = new Array(512);
n3(E2);
var A2 = new Array(256);
n3(A2);
var I2 = new Array(a2);
n3(I2);
var O, B2, R2, T2 = new Array(f3);
function D(e4, t4, r4, n4, i4) {
this.static_tree = e4, this.extra_bits = t4, this.extra_base = r4, this.elems = n4, this.max_length = i4, this.has_stree = e4 && e4.length;
}
function F(e4, t4) {
this.dyn_tree = e4, this.max_code = 0, this.stat_desc = t4;
}
function N2(e4) {
return e4 < 256 ? E2[e4] : E2[256 + (e4 >>> 7)];
}
function U(e4, t4) {
e4.pending_buf[e4.pending++] = 255 & t4, e4.pending_buf[e4.pending++] = t4 >>> 8 & 255;
}
function P2(e4, t4, r4) {
e4.bi_valid > d2 - r4 ? (e4.bi_buf |= t4 << e4.bi_valid & 65535, U(e4, e4.bi_buf), e4.bi_buf = t4 >> d2 - e4.bi_valid, e4.bi_valid += r4 - d2) : (e4.bi_buf |= t4 << e4.bi_valid & 65535, e4.bi_valid += r4);
}
function L2(e4, t4, r4) {
P2(e4, r4[2 * t4], r4[2 * t4 + 1]);
}
function j2(e4, t4) {
for (var r4 = 0; r4 |= 1 & e4, e4 >>>= 1, r4 <<= 1, 0 < --t4; ) ;
return r4 >>> 1;
}
function Z(e4, t4, r4) {
var n4, i4, s4 = new Array(g2 + 1), a3 = 0;
for (n4 = 1; n4 <= g2; n4++) s4[n4] = a3 = a3 + r4[n4 - 1] << 1;
for (i4 = 0; i4 <= t4; i4++) {
var o3 = e4[2 * i4 + 1];
0 !== o3 && (e4[2 * i4] = j2(s4[o3]++, o3));
}
}
function W(e4) {
var t4;
for (t4 = 0; t4 < l2; t4++) e4.dyn_ltree[2 * t4] = 0;
for (t4 = 0; t4 < f3; t4++) e4.dyn_dtree[2 * t4] = 0;
for (t4 = 0; t4 < c3; t4++) e4.bl_tree[2 * t4] = 0;
e4.dyn_ltree[2 * m2] = 1, e4.opt_len = e4.static_len = 0, e4.last_lit = e4.matches = 0;
}
function M2(e4) {
8 < e4.bi_valid ? U(e4, e4.bi_buf) : 0 < e4.bi_valid && (e4.pending_buf[e4.pending++] = e4.bi_buf), e4.bi_buf = 0, e4.bi_valid = 0;
}
function H2(e4, t4, r4, n4) {
var i4 = 2 * t4, s4 = 2 * r4;
return e4[i4] < e4[s4] || e4[i4] === e4[s4] && n4[t4] <= n4[r4];
}
function G(e4, t4, r4) {
for (var n4 = e4.heap[r4], i4 = r4 << 1; i4 <= e4.heap_len && (i4 < e4.heap_len && H2(t4, e4.heap[i4 + 1], e4.heap[i4], e4.depth) && i4++, !H2(t4, n4, e4.heap[i4], e4.depth)); ) e4.heap[r4] = e4.heap[i4], r4 = i4, i4 <<= 1;
e4.heap[r4] = n4;
}
function K(e4, t4, r4) {
var n4, i4, s4, a3, o3 = 0;
if (0 !== e4.last_lit) for (; n4 = e4.pending_buf[e4.d_buf + 2 * o3] << 8 | e4.pending_buf[e4.d_buf + 2 * o3 + 1], i4 = e4.pending_buf[e4.l_buf + o3], o3++, 0 === n4 ? L2(e4, i4, t4) : (L2(e4, (s4 = A2[i4]) + u2 + 1, t4), 0 !== (a3 = w2[s4]) && P2(e4, i4 -= I2[s4], a3), L2(e4, s4 = N2(--n4), r4), 0 !== (a3 = k3[s4]) && P2(e4, n4 -= T2[s4], a3)), o3 < e4.last_lit; ) ;
L2(e4, m2, t4);
}
function Y(e4, t4) {
var r4, n4, i4, s4 = t4.dyn_tree, a3 = t4.stat_desc.static_tree, o3 = t4.stat_desc.has_stree, h4 = t4.stat_desc.elems, u3 = -1;
for (e4.heap_len = 0, e4.heap_max = _2, r4 = 0; r4 < h4; r4++) 0 !== s4[2 * r4] ? (e4.heap[++e4.heap_len] = u3 = r4, e4.depth[r4] = 0) : s4[2 * r4 + 1] = 0;
for (; e4.heap_len < 2; ) s4[2 * (i4 = e4.heap[++e4.heap_len] = u3 < 2 ? ++u3 : 0)] = 1, e4.depth[i4] = 0, e4.opt_len--, o3 && (e4.static_len -= a3[2 * i4 + 1]);
for (t4.max_code = u3, r4 = e4.heap_len >> 1; 1 <= r4; r4--) G(e4, s4, r4);
for (i4 = h4; r4 = e4.heap[1], e4.heap[1] = e4.heap[e4.heap_len--], G(e4, s4, 1), n4 = e4.heap[1], e4.heap[--e4.heap_max] = r4, e4.heap[--e4.heap_max] = n4, s4[2 * i4] = s4[2 * r4] + s4[2 * n4], e4.depth[i4] = (e4.depth[r4] >= e4.depth[n4] ? e4.depth[r4] : e4.depth[n4]) + 1, s4[2 * r4 + 1] = s4[2 * n4 + 1] = i4, e4.heap[1] = i4++, G(e4, s4, 1), 2 <= e4.heap_len; ) ;
e4.heap[--e4.heap_max] = e4.heap[1], function(e5, t5) {
var r5, n5, i5, s5, a4, o4, h5 = t5.dyn_tree, u4 = t5.max_code, l3 = t5.stat_desc.static_tree, f4 = t5.stat_desc.has_stree, c4 = t5.stat_desc.extra_bits, d3 = t5.stat_desc.extra_base, p3 = t5.stat_desc.max_length, m3 = 0;
for (s5 = 0; s5 <= g2; s5++) e5.bl_count[s5] = 0;
for (h5[2 * e5.heap[e5.heap_max] + 1] = 0, r5 = e5.heap_max + 1; r5 < _2; r5++) p3 < (s5 = h5[2 * h5[2 * (n5 = e5.heap[r5]) + 1] + 1] + 1) && (s5 = p3, m3++), h5[2 * n5 + 1] = s5, u4 < n5 || (e5.bl_count[s5]++, a4 = 0, d3 <= n5 && (a4 = c4[n5 - d3]), o4 = h5[2 * n5], e5.opt_len += o4 * (s5 + a4), f4 && (e5.static_len += o4 * (l3[2 * n5 + 1] + a4)));
if (0 !== m3) {
do {
for (s5 = p3 - 1; 0 === e5.bl_count[s5]; ) s5--;
e5.bl_count[s5]--, e5.bl_count[s5 + 1] += 2, e5.bl_count[p3]--, m3 -= 2;
} while (0 < m3);
for (s5 = p3; 0 !== s5; s5--) for (n5 = e5.bl_count[s5]; 0 !== n5; ) u4 < (i5 = e5.heap[--r5]) || (h5[2 * i5 + 1] !== s5 && (e5.opt_len += (s5 - h5[2 * i5 + 1]) * h5[2 * i5], h5[2 * i5 + 1] = s5), n5--);
}
}(e4, t4), Z(s4, u3, e4.bl_count);
}
function X(e4, t4, r4) {
var n4, i4, s4 = -1, a3 = t4[1], o3 = 0, h4 = 7, u3 = 4;
for (0 === a3 && (h4 = 138, u3 = 3), t4[2 * (r4 + 1) + 1] = 65535, n4 = 0; n4 <= r4; n4++) i4 = a3, a3 = t4[2 * (n4 + 1) + 1], ++o3 < h4 && i4 === a3 || (o3 < u3 ? e4.bl_tree[2 * i4] += o3 : 0 !== i4 ? (i4 !== s4 && e4.bl_tree[2 * i4]++, e4.bl_tree[2 * b3]++) : o3 <= 10 ? e4.bl_tree[2 * v2]++ : e4.bl_tree[2 * y2]++, s4 = i4, u3 = (o3 = 0) === a3 ? (h4 = 138, 3) : i4 === a3 ? (h4 = 6, 3) : (h4 = 7, 4));
}
function V2(e4, t4, r4) {
var n4, i4, s4 = -1, a3 = t4[1], o3 = 0, h4 = 7, u3 = 4;
for (0 === a3 && (h4 = 138, u3 = 3), n4 = 0; n4 <= r4; n4++) if (i4 = a3, a3 = t4[2 * (n4 + 1) + 1], !(++o3 < h4 && i4 === a3)) {
if (o3 < u3) for (; L2(e4, i4, e4.bl_tree), 0 != --o3; ) ;
else 0 !== i4 ? (i4 !== s4 && (L2(e4, i4, e4.bl_tree), o3--), L2(e4, b3, e4.bl_tree), P2(e4, o3 - 3, 2)) : o3 <= 10 ? (L2(e4, v2, e4.bl_tree), P2(e4, o3 - 3, 3)) : (L2(e4, y2, e4.bl_tree), P2(e4, o3 - 11, 7));
s4 = i4, u3 = (o3 = 0) === a3 ? (h4 = 138, 3) : i4 === a3 ? (h4 = 6, 3) : (h4 = 7, 4);
}
}
n3(T2);
var q = false;
function J(e4, t4, r4, n4) {
P2(e4, (s3 << 1) + (n4 ? 1 : 0), 3), function(e5, t5, r5, n5) {
M2(e5), U(e5, r5), U(e5, ~r5), i3.arraySet(e5.pending_buf, e5.window, t5, r5, e5.pending), e5.pending += r5;
}(e4, t4, r4);
}
r3._tr_init = function(e4) {
q || (function() {
var e5, t4, r4, n4, i4, s4 = new Array(g2 + 1);
for (n4 = r4 = 0; n4 < a2 - 1; n4++) for (I2[n4] = r4, e5 = 0; e5 < 1 << w2[n4]; e5++) A2[r4++] = n4;
for (A2[r4 - 1] = n4, n4 = i4 = 0; n4 < 16; n4++) for (T2[n4] = i4, e5 = 0; e5 < 1 << k3[n4]; e5++) E2[i4++] = n4;
for (i4 >>= 7; n4 < f3; n4++) for (T2[n4] = i4 << 7, e5 = 0; e5 < 1 << k3[n4] - 7; e5++) E2[256 + i4++] = n4;
for (t4 = 0; t4 <= g2; t4++) s4[t4] = 0;
for (e5 = 0; e5 <= 143; ) z2[2 * e5 + 1] = 8, e5++, s4[8]++;
for (; e5 <= 255; ) z2[2 * e5 + 1] = 9, e5++, s4[9]++;
for (; e5 <= 279; ) z2[2 * e5 + 1] = 7, e5++, s4[7]++;
for (; e5 <= 287; ) z2[2 * e5 + 1] = 8, e5++, s4[8]++;
for (Z(z2, l2 + 1, s4), e5 = 0; e5 < f3; e5++) C2[2 * e5 + 1] = 5, C2[2 * e5] = j2(e5, 5);
O = new D(z2, w2, u2 + 1, l2, g2), B2 = new D(C2, k3, 0, f3, g2), R2 = new D(new Array(0), x2, 0, c3, p2);
}(), q = true), e4.l_desc = new F(e4.dyn_ltree, O), e4.d_desc = new F(e4.dyn_dtree, B2), e4.bl_desc = new F(e4.bl_tree, R2), e4.bi_buf = 0, e4.bi_valid = 0, W(e4);
}, r3._tr_stored_block = J, r3._tr_flush_block = function(e4, t4, r4, n4) {
var i4, s4, a3 = 0;
0 < e4.level ? (2 === e4.strm.data_type && (e4.strm.data_type = function(e5) {
var t5, r5 = 4093624447;
for (t5 = 0; t5 <= 31; t5++, r5 >>>= 1) if (1 & r5 && 0 !== e5.dyn_ltree[2 * t5]) return o2;
if (0 !== e5.dyn_ltree[18] || 0 !== e5.dyn_ltree[20] || 0 !== e5.dyn_ltree[26]) return h3;
for (t5 = 32; t5 < u2; t5++) if (0 !== e5.dyn_ltree[2 * t5]) return h3;
return o2;
}(e4)), Y(e4, e4.l_desc), Y(e4, e4.d_desc), a3 = function(e5) {
var t5;
for (X(e5, e5.dyn_ltree, e5.l_desc.max_code), X(e5, e5.dyn_dtree, e5.d_desc.max_code), Y(e5, e5.bl_desc), t5 = c3 - 1; 3 <= t5 && 0 === e5.bl_tree[2 * S2[t5] + 1]; t5--) ;
return e5.opt_len += 3 * (t5 + 1) + 5 + 5 + 4, t5;
}(e4), i4 = e4.opt_len + 3 + 7 >>> 3, (s4 = e4.static_len + 3 + 7 >>> 3) <= i4 && (i4 = s4)) : i4 = s4 = r4 + 5, r4 + 4 <= i4 && -1 !== t4 ? J(e4, t4, r4, n4) : 4 === e4.strategy || s4 === i4 ? (P2(e4, 2 + (n4 ? 1 : 0), 3), K(e4, z2, C2)) : (P2(e4, 4 + (n4 ? 1 : 0), 3), function(e5, t5, r5, n5) {
var i5;
for (P2(e5, t5 - 257, 5), P2(e5, r5 - 1, 5), P2(e5, n5 - 4, 4), i5 = 0; i5 < n5; i5++) P2(e5, e5.bl_tree[2 * S2[i5] + 1], 3);
V2(e5, e5.dyn_ltree, t5 - 1), V2(e5, e5.dyn_dtree, r5 - 1);
}(e4, e4.l_desc.max_code + 1, e4.d_desc.max_code + 1, a3 + 1), K(e4, e4.dyn_ltree, e4.dyn_dtree)), W(e4), n4 && M2(e4);
}, r3._tr_tally = function(e4, t4, r4) {
return e4.pending_buf[e4.d_buf + 2 * e4.last_lit] = t4 >>> 8 & 255, e4.pending_buf[e4.d_buf + 2 * e4.last_lit + 1] = 255 & t4, e4.pending_buf[e4.l_buf + e4.last_lit] = 255 & r4, e4.last_lit++, 0 === t4 ? e4.dyn_ltree[2 * r4]++ : (e4.matches++, t4--, e4.dyn_ltree[2 * (A2[r4] + u2 + 1)]++, e4.dyn_dtree[2 * N2(t4)]++), e4.last_lit === e4.lit_bufsize - 1;
}, r3._tr_align = function(e4) {
P2(e4, 2, 3), L2(e4, m2, z2), function(e5) {
16 === e5.bi_valid ? (U(e5, e5.bi_buf), e5.bi_buf = 0, e5.bi_valid = 0) : 8 <= e5.bi_valid && (e5.pending_buf[e5.pending++] = 255 & e5.bi_buf, e5.bi_buf >>= 8, e5.bi_valid -= 8);
}(e4);
};
}, { "../utils/common": 41 }], 53: [function(e3, t3, r3) {
t3.exports = function() {
this.input = null, this.next_in = 0, this.avail_in = 0, this.total_in = 0, this.output = null, this.next_out = 0, this.avail_out = 0, this.total_out = 0, this.msg = "", this.state = null, this.data_type = 2, this.adler = 0;
};
}, {}], 54: [function(e3, t3, r3) {
(function(e4) {
!function(r4, n3) {
if (!r4.setImmediate) {
var i3, s3, t4, a2, o2 = 1, h3 = {}, u2 = false, l2 = r4.document, e5 = Object.getPrototypeOf && Object.getPrototypeOf(r4);
e5 = e5 && e5.setTimeout ? e5 : r4, i3 = "[object process]" === {}.toString.call(r4.process) ? function(e6) {
process.nextTick(function() {
c3(e6);
});
} : function() {
if (r4.postMessage && !r4.importScripts) {
var e6 = true, t5 = r4.onmessage;
return r4.onmessage = function() {
e6 = false;
}, r4.postMessage("", "*"), r4.onmessage = t5, e6;
}
}() ? (a2 = "setImmediate$" + Math.random() + "$", r4.addEventListener ? r4.addEventListener("message", d2, false) : r4.attachEvent("onmessage", d2), function(e6) {
r4.postMessage(a2 + e6, "*");
}) : r4.MessageChannel ? ((t4 = new MessageChannel()).port1.onmessage = function(e6) {
c3(e6.data);
}, function(e6) {
t4.port2.postMessage(e6);
}) : l2 && "onreadystatechange" in l2.createElement("script") ? (s3 = l2.documentElement, function(e6) {
var t5 = l2.createElement("script");
t5.onreadystatechange = function() {
c3(e6), t5.onreadystatechange = null, s3.removeChild(t5), t5 = null;
}, s3.appendChild(t5);
}) : function(e6) {
setTimeout(c3, 0, e6);
}, e5.setImmediate = function(e6) {
"function" != typeof e6 && (e6 = new Function("" + e6));
for (var t5 = new Array(arguments.length - 1), r5 = 0; r5 < t5.length; r5++) t5[r5] = arguments[r5 + 1];
var n4 = { callback: e6, args: t5 };
return h3[o2] = n4, i3(o2), o2++;
}, e5.clearImmediate = f3;
}
function f3(e6) {
delete h3[e6];
}
function c3(e6) {
if (u2) setTimeout(c3, 0, e6);
else {
var t5 = h3[e6];
if (t5) {
u2 = true;
try {
!function(e7) {
var t6 = e7.callback, r5 = e7.args;
switch (r5.length) {
case 0:
t6();
break;
case 1:
t6(r5[0]);
break;
case 2:
t6(r5[0], r5[1]);
break;
case 3:
t6(r5[0], r5[1], r5[2]);
break;
default:
t6.apply(n3, r5);
}
}(t5);
} finally {
f3(e6), u2 = false;
}
}
}
}
function d2(e6) {
e6.source === r4 && "string" == typeof e6.data && 0 === e6.data.indexOf(a2) && c3(+e6.data.slice(a2.length));
}
}("undefined" == typeof self ? void 0 === e4 ? this : e4 : self);
}).call(this, "undefined" != typeof commonjsGlobal ? commonjsGlobal : "undefined" != typeof self ? self : "undefined" != typeof window ? window : {});
}, {}] }, {}, [10])(10);
});
})(jszip_min);
var jszip_minExports = jszip_min.exports;
const JSZip = /* @__PURE__ */ getDefaultExportFromCjs(jszip_minExports);
var FileSaver_min = { exports: {} };
(function(module, exports) {
(function(a2, b3) {
b3();
})(commonjsGlobal, function() {
function b3(a3, b4) {
return "undefined" == typeof b4 ? b4 = { autoBom: false } : "object" != typeof b4 && (console.warn("Deprecated: Expected third argument to be a object"), b4 = { autoBom: !b4 }), b4.autoBom && /^\s*(?:text\/\S*|application\/xml|\S*\/\S*\+xml)\s*;.*charset\s*=\s*utf-8/i.test(a3.type) ? new Blob(["\uFEFF", a3], { type: a3.type }) : a3;
}
function c3(a3, b4, c4) {
var d3 = new XMLHttpRequest();
d3.open("GET", a3), d3.responseType = "blob", d3.onload = function() {
g2(d3.response, b4, c4);
}, d3.onerror = function() {
console.error("could not download file");
}, d3.send();
}
function d2(a3) {
var b4 = new XMLHttpRequest();
b4.open("HEAD", a3, false);
try {
b4.send();
} catch (a4) {
}
return 200 <= b4.status && 299 >= b4.status;
}
function e3(a3) {
try {
a3.dispatchEvent(new MouseEvent("click"));
} catch (c4) {
var b4 = document.createEvent("MouseEvents");
b4.initMouseEvent("click", true, true, window, 0, 0, 0, 80, 20, false, false, false, false, 0, null), a3.dispatchEvent(b4);
}
}
var f3 = "object" == typeof window && window.window === window ? window : "object" == typeof self && self.self === self ? self : "object" == typeof commonjsGlobal && commonjsGlobal.global === commonjsGlobal ? commonjsGlobal : void 0, a2 = f3.navigator && /Macintosh/.test(navigator.userAgent) && /AppleWebKit/.test(navigator.userAgent) && !/Safari/.test(navigator.userAgent), g2 = f3.saveAs || ("object" != typeof window || window !== f3 ? function() {
} : "download" in HTMLAnchorElement.prototype && !a2 ? function(b4, g3, h3) {
var i3 = f3.URL || f3.webkitURL, j2 = document.createElement("a");
g3 = g3 || b4.name || "download", j2.download = g3, j2.rel = "noopener", "string" == typeof b4 ? (j2.href = b4, j2.origin === location.origin ? e3(j2) : d2(j2.href) ? c3(b4, g3, h3) : e3(j2, j2.target = "_blank")) : (j2.href = i3.createObjectURL(b4), setTimeout(function() {
i3.revokeObjectURL(j2.href);
}, 4e4), setTimeout(function() {
e3(j2);
}, 0));
} : "msSaveOrOpenBlob" in navigator ? function(f4, g3, h3) {
if (g3 = g3 || f4.name || "download", "string" != typeof f4) navigator.msSaveOrOpenBlob(b3(f4, h3), g3);
else if (d2(f4)) c3(f4, g3, h3);
else {
var i3 = document.createElement("a");
i3.href = f4, i3.target = "_blank", setTimeout(function() {
e3(i3);
});
}
} : function(b4, d3, e4, g3) {
if (g3 = g3 || open("", "_blank"), g3 && (g3.document.title = g3.document.body.innerText = "downloading..."), "string" == typeof b4) return c3(b4, d3, e4);
var h3 = "application/octet-stream" === b4.type, i3 = /constructor/i.test(f3.HTMLElement) || f3.safari, j2 = /CriOS\/[\d]+/.test(navigator.userAgent);
if ((j2 || h3 && i3 || a2) && "undefined" != typeof FileReader) {
var k3 = new FileReader();
k3.onloadend = function() {
var a3 = k3.result;
a3 = j2 ? a3 : a3.replace(/^data:[^;]*;/, "data:attachment/file;"), g3 ? g3.location.href = a3 : location = a3, g3 = null;
}, k3.readAsDataURL(b4);
} else {
var l2 = f3.URL || f3.webkitURL, m2 = l2.createObjectURL(b4);
g3 ? g3.location = m2 : location.href = m2, g3 = null, setTimeout(function() {
l2.revokeObjectURL(m2);
}, 4e4);
}
});
f3.saveAs = g2.saveAs = g2, module.exports = g2;
});
})(FileSaver_min);
var FileSaver_minExports = FileSaver_min.exports;
const snapshotStorage = localforage.createInstance({
name: "snapshot",
version: 1
});
const screenshotStorage = localforage.createInstance({
name: "screenshot",
version: 1
});
const hanashiroStorage = localforage.createInstance({
name: "Hanashiro"
});
const simplyActivityIds = async (snapshotId) => {
const snapshotInfo = await snapshotStorage.getItem(snapshotId);
if (snapshotInfo == null ? void 0 : snapshotInfo.activityId) {
if (snapshotInfo == null ? void 0 : snapshotInfo.activityId.startsWith(snapshotInfo.appId)) {
const simplyActivityIds2 = snapshotInfo.activityId.replace(snapshotInfo.appId, "");
return simplyActivityIds2;
} else return false;
} else return false;
};
const editNode = async (snapshotId, nodeId, options) => {
try {
const snapshotInfo = await snapshotStorage.getItem(snapshotId);
const nodes = snapshotInfo.nodes;
const nodeAttr = nodes[nodeId].attr;
options.forEach((option) => nodeAttr[option.target] = option.value);
nodes[nodeId].attr = nodeAttr;
snapshotInfo.nodes = nodes;
await snapshotStorage.setItem(snapshotId, snapshotInfo);
return true;
} catch {
return false;
}
};
const getScreenInfo = async (snapshotId) => {
const snapshotInfo = await snapshotStorage.getItem(snapshotId);
return { width: snapshotInfo.screenWidth, height: snapshotInfo.screenHeight };
};
const getScreenshot = async (snapshotId) => {
return await screenshotStorage.getItem(snapshotId);
};
const replaceScreenshot = async (snapshotId, image) => {
await screenshotStorage.setItem(snapshotId, image);
};
const getNodeAttr = async (snapshotId, nodeId, target) => {
const snapshotInfo = await snapshotStorage.getItem(snapshotId);
const nodes = snapshotInfo.nodes;
const nodeAttr = nodes[nodeId].attr;
return nodeAttr[target];
};
const downloadSnapshot = async (snapshotId) => {
const snapshotInfo = await snapshotStorage.getItem(snapshotId);
const screenshot = await screenshotStorage.getItem(snapshotId);
const jszip = new JSZip();
jszip.file(`snapshot-${snapshotId}.json`, JSON.stringify(snapshotInfo, void 0, 2));
jszip.file(`screenshot-${snapshotId}.png`, screenshot);
jszip.generateAsync({ type: "blob" }).then((snapshotFile) => {
FileSaver_minExports.saveAs(snapshotFile, `snapshot-${snapshotId}.zip`);
});
};
const setHanashiroSettings = async (item, value) => {
await hanashiroStorage.setItem(item, value);
};
const getHanashiroSettings = async (item) => {
return await hanashiroStorage.getItem(item);
};
const rulesKeySort = [
"key",
"preKeys",
"fastQuery",
"matchTime",
"actionMaximum",
"resetMatch",
"priorityTime",
"action",
"activityIds",
"position",
"matches",
"exampleUrls",
"snapshotUrls"
];
if (!await( getHanashiroSettings("selectors"))) await( setHanashiroSettings("selectors", []));
if (!await( getHanashiroSettings("rulesKeySort")) || (await( getHanashiroSettings("rulesKeySort"))).length == 0) {
await( setHanashiroSettings("rulesKeySort", rulesKeySort));
}
for (const rulesKey of await( getHanashiroSettings("rulesKeySort"))) {
if (!rulesKeySort.includes(rulesKey)) confirm({
headline: "同步最新rulesKey排序",
description: "检测你的rulesKey排序有多余或缺失字段,可能无法使用最新的功能。是否同步?注意:这会丢失你现有的排序设置。",
closeOnEsc: true,
closeOnOverlayClick: true,
confirmText: "同步",
cancelText: "取消",
onConfirm: async () => await setHanashiroSettings("rulesKeySort", rulesKeySort)
});
}
Object.defineProperty(window, "Hanashiro", {
value: {},
writable: true
});
if (await( getHanashiroSettings("hideLoadSnackbar")) === false) {
snackbar({
message: "绿阴不减来时路,添得黄鹂四五声。",
autoCloseDelay: 2e3,
placement: "top"
});
}
const observeElement = (selector, callback, continuous = false) => {
let elementExists = false;
try {
const timer = setInterval(() => {
const element = document.querySelector(selector);
if (element && !elementExists) {
elementExists = true;
callback();
} else if (!element) elementExists = false;
if (element && !continuous) {
clearInterval(timer);
}
}, 100);
} catch (e3) {
console.log(e3);
}
};
observeElement(".n-message__content", () => {
const isNodeLost = document.querySelector(".n-message__content");
if (isNodeLost) {
const content = isNodeLost.innerHTML;
const searchResult = content.match(/的([0-9])+个/);
if (searchResult) {
const lostNodeNum = Number(searchResult[0].slice(1, -1));
const showSizeURL = new URL(window.location.href);
const currentShowSize = new URL(window.location.href).searchParams.get("showSize");
showSizeURL.searchParams.set("showSize", String(lostNodeNum + (currentShowSize === null ? 2e3 : Number(currentShowSize))));
window.location.href = showSizeURL.toString();
}
}
});
const attrList = [
"id",
"vid",
"text",
"text.length",
"desc",
"desc.length",
"clickable",
"focusable",
"checkable",
"checked",
"editable",
"longClickable",
"visibleToUser",
"left",
"top",
"right",
"bottom",
"width",
"height",
"childCount",
"index"
];
const send = (channal) => {
const event = new Event(channal);
window.dispatchEvent(event);
};
const receive = (channal, callback, once) => {
window.addEventListener(channal, callback, { once });
};
const copyProxy = new Proxy(navigator.clipboard.writeText, {
apply: async (target, thisArg, args) => {
const data2 = args[0];
if (data2.startsWith("{") && data2.endsWith("}")) {
window.Hanashiro.originRule = args[0];
send("copyEvent");
await new Promise((resolve) => {
receive("modifyEnd", async () => {
await Reflect.apply(target, thisArg, [window.Hanashiro.returnResult]);
snackbar({
message: "注入修改成功",
placement: "top",
onClosed: () => resolve(true)
});
}, true);
});
} else if (data2.startsWith("name=")) {
if (await getHanashiroSettings("simplyName") == true) {
const fullname = data2.split('"')[1];
const splitedName = fullname.split(".");
const name = splitedName[splitedName.length - 1];
await Reflect.apply(target, thisArg, [name]);
} else await Reflect.apply(target, thisArg, [data2]);
} else if (attrList.filter((attr) => data2.startsWith(`${attr}=`)).length != 0) {
await Reflect.apply(target, thisArg, [`[${data2}]`]);
} else if (data2.startsWith(window.origin)) {
const selectors = await getHanashiroSettings("selectors");
if (selectors.length != 0) {
const copiedUrl = new URL(data2);
if (copiedUrl.searchParams.has("gkd")) {
const selectorBase64 = copiedUrl.searchParams.get("gkd");
prompt({
headline: "备注",
description: "给该选择器的备注,留空就用默认的了哦~",
confirmText: "就决定是你了!",
cancelText: "这个不要保存!",
closeOnEsc: true,
closeOnOverlayClick: true,
onConfirm: async (value) => {
selectors.push({
name: value ? value : selectorBase64,
base64: selectorBase64,
order: 1
});
selectors.sort((a2, b3) => {
if (a2.order > b3.order) return -1;
else if (a2.order == b3.order) return 0;
else return 1;
});
await setHanashiroSettings("selectors", selectors);
}
}).catch();
}
}
await Reflect.apply(target, thisArg, [data2]);
} else await Reflect.apply(target, thisArg, [data2]);
}
});
navigator.clipboard.writeText = copyProxy;
const getSnapshotId = () => {
return location.pathname.split("/")[2];
};
const replaceNodeInfo = async () => {
const snapshotId = getSnapshotId();
const nodeId = Number(document.querySelectorAll("tr > td > span")[23].textContent);
const text = await getNodeAttr(snapshotId, nodeId, "text");
const desc = await getNodeAttr(snapshotId, nodeId, "desc");
let newText, newDesc;
if (text !== null) {
newText = "";
for (let i3 = 0; i3 < text.length; i3++) {
newText += "*";
}
} else newText = null;
if (desc !== null) {
newDesc = "";
for (let i3 = 0; i3 < desc.length; i3++) {
newDesc += "*";
}
} else newDesc = null;
editNode(snapshotId, nodeId, [
{
target: "text",
value: newText
},
{
target: "desc",
value: newDesc
}
]).then((result) => {
if (result) snackbar({
message: "修改成功!你可以选择上传获取导入链接或下载快照分享",
placement: "top"
});
});
};
const replaceNodeInfo$1 = () => {
dialog({
headline: "确认要对该节点打码吗?",
description: "进行打码操作会对导入的快照造成无法恢复的修改,如需恢复,需要删除当前快照重新导入。建议你先下载备份!",
actions: [
{
text: "我再想想"
},
{
text: "下载快照文件并打码",
onClick: () => {
return new Promise((resolve, reject) => {
snackbar({
message: "开始下载中……下载开始后会自动关闭弹窗",
placement: "top"
});
downloadSnapshot(getSnapshotId()).then(() => {
resolve();
replaceNodeInfo();
}).catch(() => {
snackbar({
message: "下载失败",
placement: "top"
});
reject();
});
});
}
},
{
text: "直接打码",
onClick: () => replaceNodeInfo()
}
],
closeOnEsc: true,
closeOnOverlayClick: true
});
};
observeElement(".n-input-group", () => {
if (!document.querySelector("#iconBar")) {
const inputGroup = document.querySelector(".n-input-group");
const iconBar = document.createElement("div");
iconBar.id = "iconBar";
const UseSelectorIcon = document.createElement("mdui-button-icon");
UseSelectorIcon.icon = "search";
UseSelectorIcon.style.height = "36px";
UseSelectorIcon.style.width = "36px";
UseSelectorIcon.onclick = () => {
send("openUseSelector");
};
const AddSelectorIcon = document.createElement("mdui-button-icon");
AddSelectorIcon.icon = "add";
AddSelectorIcon.style.height = "36px";
AddSelectorIcon.style.width = "36px";
AddSelectorIcon.onclick = () => {
send("openAddSelector");
};
const ManageSelectorsIcon = document.createElement("mdui-button-icon");
ManageSelectorsIcon.icon = "edit";
ManageSelectorsIcon.style.height = "36px";
ManageSelectorsIcon.style.width = "36px";
ManageSelectorsIcon.onclick = () => {
send("openManageSelectors");
};
const ChangeScreenshotIcon = document.createElement("mdui-button-icon");
ChangeScreenshotIcon.icon = "photo";
ChangeScreenshotIcon.style.height = "36px";
ChangeScreenshotIcon.style.width = "36px";
ChangeScreenshotIcon.onclick = () => {
send("openChangeScreenshot");
};
const SettingsIcon = document.createElement("mdui-button-icon");
SettingsIcon.icon = "settings";
SettingsIcon.style.height = "36px";
SettingsIcon.style.width = "36px";
SettingsIcon.onclick = () => {
send("openSettings");
};
const HelpIcon = document.createElement("mdui-button-icon");
HelpIcon.icon = "help";
HelpIcon.style.height = "36px";
HelpIcon.style.width = "36px";
HelpIcon.onclick = () => {
send("openHelp");
};
iconBar.append(UseSelectorIcon, AddSelectorIcon, ManageSelectorsIcon, ChangeScreenshotIcon, SettingsIcon, HelpIcon);
inputGroup.insertAdjacentElement("beforebegin", iconBar);
}
}, true);
observeElement("#app", () => {
const app = document.querySelector("#app");
const editNodeIcon = document.createElement("mdui-fab");
editNodeIcon.icon = "edit";
editNodeIcon.variant = "secondary";
editNodeIcon.extended = true;
editNodeIcon.textContent = "替换当前节点信息";
editNodeIcon.style.right = "16px";
editNodeIcon.style.bottom = "120px";
editNodeIcon.setAttribute("fixed", "");
editNodeIcon.onclick = replaceNodeInfo$1;
const positionIcon = document.createElement("mdui-fab");
positionIcon.icon = "open_with";
positionIcon.variant = "secondary";
positionIcon.extended = true;
positionIcon.textContent = "生成坐标";
positionIcon.style.right = "16px";
positionIcon.style.bottom = "60px";
positionIcon.setAttribute("fixed", "");
positionIcon.onclick = () => send("openGeneratePosition");
app.append(editNodeIcon, positionIcon);
});
var Space_Separator = /[\u1680\u2000-\u200A\u202F\u205F\u3000]/;
var ID_Start = /[\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u048A-\u052F\u0531-\u0556\u0559\u0561-\u0587\u05D0-\u05EA\u05F0-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u0860-\u086A\u08A0-\u08B4\u08B6-\u08BD\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0980\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u09FC\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0AF9\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D\u0C58-\u0C5A\u0C60\u0C61\u0C80\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D\u0D4E\u0D54-\u0D56\u0D5F-\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16EE-\u16F8\u1700-\u170C\u170E-\u1711\u1720-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7\u17DC\u1820-\u1877\u1880-\u1884\u1887-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191E\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u1A00-\u1A16\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4B\u1B83-\u1BA0\u1BAE\u1BAF\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1C80-\u1C88\u1CE9-\u1CEC\u1CEE-\u1CF1\u1CF5\u1CF6\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2160-\u2188\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2E2F\u3005-\u3007\u3021-\u3029\u3031-\u3035\u3038-\u303C\u3041-\u3096\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312E\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FEA\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B\uA640-\uA66E\uA67F-\uA69D\uA6A0-\uA6EF\uA717-\uA71F\uA722-\uA788\uA78B-\uA7AE\uA7B0-\uA7B7\uA7F7-\uA801\uA803-\uA805\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB\uA8FD\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uA9E0-\uA9E4\uA9E6-\uA9EF\uA9FA-\uA9FE\uAA00-\uAA28\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA7E-\uAAAF\uAAB1\uAAB5\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB65\uAB70-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDD40-\uDD74\uDE80-\uDE9C\uDEA0-\uDED0\uDF00-\uDF1F\uDF2D-\uDF4A\uDF50-\uDF75\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF\uDFD1-\uDFD5]|\uD801[\uDC00-\uDC9D\uDCB0-\uDCD3\uDCD8-\uDCFB\uDD00-\uDD27\uDD30-\uDD63\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC60-\uDC76\uDC80-\uDC9E\uDCE0-\uDCF2\uDCF4\uDCF5\uDD00-\uDD15\uDD20-\uDD39\uDD80-\uDDB7\uDDBE\uDDBF\uDE00\uDE10-\uDE13\uDE15-\uDE17\uDE19-\uDE33\uDE60-\uDE7C\uDE80-\uDE9C\uDEC0-\uDEC7\uDEC9-\uDEE4\uDF00-\uDF35\uDF40-\uDF55\uDF60-\uDF72\uDF80-\uDF91]|\uD803[\uDC00-\uDC48\uDC80-\uDCB2\uDCC0-\uDCF2]|\uD804[\uDC03-\uDC37\uDC83-\uDCAF\uDCD0-\uDCE8\uDD03-\uDD26\uDD50-\uDD72\uDD76\uDD83-\uDDB2\uDDC1-\uDDC4\uDDDA\uDDDC\uDE00-\uDE11\uDE13-\uDE2B\uDE80-\uDE86\uDE88\uDE8A-\uDE8D\uDE8F-\uDE9D\uDE9F-\uDEA8\uDEB0-\uDEDE\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3D\uDF50\uDF5D-\uDF61]|\uD805[\uDC00-\uDC34\uDC47-\uDC4A\uDC80-\uDCAF\uDCC4\uDCC5\uDCC7\uDD80-\uDDAE\uDDD8-\uDDDB\uDE00-\uDE2F\uDE44\uDE80-\uDEAA\uDF00-\uDF19]|\uD806[\uDCA0-\uDCDF\uDCFF\uDE00\uDE0B-\uDE32\uDE3A\uDE50\uDE5C-\uDE83\uDE86-\uDE89\uDEC0-\uDEF8]|\uD807[\uDC00-\uDC08\uDC0A-\uDC2E\uDC40\uDC72-\uDC8F\uDD00-\uDD06\uDD08\uDD09\uDD0B-\uDD30\uDD46]|\uD808[\uDC00-\uDF99]|\uD809[\uDC00-\uDC6E\uDC80-\uDD43]|[\uD80C\uD81C-\uD820\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872\uD874-\uD879][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2E]|\uD811[\uDC00-\uDE46]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDED0-\uDEED\uDF00-\uDF2F\uDF40-\uDF43\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDF00-\uDF44\uDF50\uDF93-\uDF9F\uDFE0\uDFE1]|\uD821[\uDC00-\uDFEC]|\uD822[\uDC00-\uDEF2]|\uD82C[\uDC00-\uDD1E\uDD70-\uDEFB]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99]|\uD835[\uDC00-\uDC54\uDC56-\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD1E-\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD52-\uDEA5\uDEA8-\uDEC0\uDEC2-\uDEDA\uDEDC-\uDEFA\uDEFC-\uDF14\uDF16-\uDF34\uDF36-\uDF4E\uDF50-\uDF6E\uDF70-\uDF88\uDF8A-\uDFA8\uDFAA-\uDFC2\uDFC4-\uDFCB]|\uD83A[\uDC00-\uDCC4\uDD00-\uDD43]|\uD83B[\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1\uDEB0-\uDFFF]|\uD87A[\uDC00-\uDFE0]|\uD87E[\uDC00-\uDE1D]/;
var ID_Continue = /[\xAA\xB5\xBA\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0300-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u0483-\u0487\u048A-\u052F\u0531-\u0556\u0559\u0561-\u0587\u0591-\u05BD\u05BF\u05C1\u05C2\u05C4\u05C5\u05C7\u05D0-\u05EA\u05F0-\u05F2\u0610-\u061A\u0620-\u0669\u066E-\u06D3\u06D5-\u06DC\u06DF-\u06E8\u06EA-\u06FC\u06FF\u0710-\u074A\u074D-\u07B1\u07C0-\u07F5\u07FA\u0800-\u082D\u0840-\u085B\u0860-\u086A\u08A0-\u08B4\u08B6-\u08BD\u08D4-\u08E1\u08E3-\u0963\u0966-\u096F\u0971-\u0983\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BC-\u09C4\u09C7\u09C8\u09CB-\u09CE\u09D7\u09DC\u09DD\u09DF-\u09E3\u09E6-\u09F1\u09FC\u0A01-\u0A03\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A3C\u0A3E-\u0A42\u0A47\u0A48\u0A4B-\u0A4D\u0A51\u0A59-\u0A5C\u0A5E\u0A66-\u0A75\u0A81-\u0A83\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABC-\u0AC5\u0AC7-\u0AC9\u0ACB-\u0ACD\u0AD0\u0AE0-\u0AE3\u0AE6-\u0AEF\u0AF9-\u0AFF\u0B01-\u0B03\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3C-\u0B44\u0B47\u0B48\u0B4B-\u0B4D\u0B56\u0B57\u0B5C\u0B5D\u0B5F-\u0B63\u0B66-\u0B6F\u0B71\u0B82\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BBE-\u0BC2\u0BC6-\u0BC8\u0BCA-\u0BCD\u0BD0\u0BD7\u0BE6-\u0BEF\u0C00-\u0C03\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D-\u0C44\u0C46-\u0C48\u0C4A-\u0C4D\u0C55\u0C56\u0C58-\u0C5A\u0C60-\u0C63\u0C66-\u0C6F\u0C80-\u0C83\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBC-\u0CC4\u0CC6-\u0CC8\u0CCA-\u0CCD\u0CD5\u0CD6\u0CDE\u0CE0-\u0CE3\u0CE6-\u0CEF\u0CF1\u0CF2\u0D00-\u0D03\u0D05-\u0D0C\u0D0E-\u0D10\u0D12-\u0D44\u0D46-\u0D48\u0D4A-\u0D4E\u0D54-\u0D57\u0D5F-\u0D63\u0D66-\u0D6F\u0D7A-\u0D7F\u0D82\u0D83\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0DCA\u0DCF-\u0DD4\u0DD6\u0DD8-\u0DDF\u0DE6-\u0DEF\u0DF2\u0DF3\u0E01-\u0E3A\u0E40-\u0E4E\u0E50-\u0E59\u0E81\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB9\u0EBB-\u0EBD\u0EC0-\u0EC4\u0EC6\u0EC8-\u0ECD\u0ED0-\u0ED9\u0EDC-\u0EDF\u0F00\u0F18\u0F19\u0F20-\u0F29\u0F35\u0F37\u0F39\u0F3E-\u0F47\u0F49-\u0F6C\u0F71-\u0F84\u0F86-\u0F97\u0F99-\u0FBC\u0FC6\u1000-\u1049\u1050-\u109D\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u135D-\u135F\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16EE-\u16F8\u1700-\u170C\u170E-\u1714\u1720-\u1734\u1740-\u1753\u1760-\u176C\u176E-\u1770\u1772\u1773\u1780-\u17D3\u17D7\u17DC\u17DD\u17E0-\u17E9\u180B-\u180D\u1810-\u1819\u1820-\u1877\u1880-\u18AA\u18B0-\u18F5\u1900-\u191E\u1920-\u192B\u1930-\u193B\u1946-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u19D0-\u19D9\u1A00-\u1A1B\u1A20-\u1A5E\u1A60-\u1A7C\u1A7F-\u1A89\u1A90-\u1A99\u1AA7\u1AB0-\u1ABD\u1B00-\u1B4B\u1B50-\u1B59\u1B6B-\u1B73\u1B80-\u1BF3\u1C00-\u1C37\u1C40-\u1C49\u1C4D-\u1C7D\u1C80-\u1C88\u1CD0-\u1CD2\u1CD4-\u1CF9\u1D00-\u1DF9\u1DFB-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u203F\u2040\u2054\u2071\u207F\u2090-\u209C\u20D0-\u20DC\u20E1\u20E5-\u20F0\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2160-\u2188\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CF3\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D7F-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2DE0-\u2DFF\u2E2F\u3005-\u3007\u3021-\u302F\u3031-\u3035\u3038-\u303C\u3041-\u3096\u3099\u309A\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312E\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FEA\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA62B\uA640-\uA66F\uA674-\uA67D\uA67F-\uA6F1\uA717-\uA71F\uA722-\uA788\uA78B-\uA7AE\uA7B0-\uA7B7\uA7F7-\uA827\uA840-\uA873\uA880-\uA8C5\uA8D0-\uA8D9\uA8E0-\uA8F7\uA8FB\uA8FD\uA900-\uA92D\uA930-\uA953\uA960-\uA97C\uA980-\uA9C0\uA9CF-\uA9D9\uA9E0-\uA9FE\uAA00-\uAA36\uAA40-\uAA4D\uAA50-\uAA59\uAA60-\uAA76\uAA7A-\uAAC2\uAADB-\uAADD\uAAE0-\uAAEF\uAAF2-\uAAF6\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB65\uAB70-\uABEA\uABEC\uABED\uABF0-\uABF9\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE00-\uFE0F\uFE20-\uFE2F\uFE33\uFE34\uFE4D-\uFE4F\uFE70-\uFE74\uFE76-\uFEFC\uFF10-\uFF19\uFF21-\uFF3A\uFF3F\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDD40-\uDD74\uDDFD\uDE80-\uDE9C\uDEA0-\uDED0\uDEE0\uDF00-\uDF1F\uDF2D-\uDF4A\uDF50-\uDF7A\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF\uDFD1-\uDFD5]|\uD801[\uDC00-\uDC9D\uDCA0-\uDCA9\uDCB0-\uDCD3\uDCD8-\uDCFB\uDD00-\uDD27\uDD30-\uDD63\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC60-\uDC76\uDC80-\uDC9E\uDCE0-\uDCF2\uDCF4\uDCF5\uDD00-\uDD15\uDD20-\uDD39\uDD80-\uDDB7\uDDBE\uDDBF\uDE00-\uDE03\uDE05\uDE06\uDE0C-\uDE13\uDE15-\uDE17\uDE19-\uDE33\uDE38-\uDE3A\uDE3F\uDE60-\uDE7C\uDE80-\uDE9C\uDEC0-\uDEC7\uDEC9-\uDEE6\uDF00-\uDF35\uDF40-\uDF55\uDF60-\uDF72\uDF80-\uDF91]|\uD803[\uDC00-\uDC48\uDC80-\uDCB2\uDCC0-\uDCF2]|\uD804[\uDC00-\uDC46\uDC66-\uDC6F\uDC7F-\uDCBA\uDCD0-\uDCE8\uDCF0-\uDCF9\uDD00-\uDD34\uDD36-\uDD3F\uDD50-\uDD73\uDD76\uDD80-\uDDC4\uDDCA-\uDDCC\uDDD0-\uDDDA\uDDDC\uDE00-\uDE11\uDE13-\uDE37\uDE3E\uDE80-\uDE86\uDE88\uDE8A-\uDE8D\uDE8F-\uDE9D\uDE9F-\uDEA8\uDEB0-\uDEEA\uDEF0-\uDEF9\uDF00-\uDF03\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3C-\uDF44\uDF47\uDF48\uDF4B-\uDF4D\uDF50\uDF57\uDF5D-\uDF63\uDF66-\uDF6C\uDF70-\uDF74]|\uD805[\uDC00-\uDC4A\uDC50-\uDC59\uDC80-\uDCC5\uDCC7\uDCD0-\uDCD9\uDD80-\uDDB5\uDDB8-\uDDC0\uDDD8-\uDDDD\uDE00-\uDE40\uDE44\uDE50-\uDE59\uDE80-\uDEB7\uDEC0-\uDEC9\uDF00-\uDF19\uDF1D-\uDF2B\uDF30-\uDF39]|\uD806[\uDCA0-\uDCE9\uDCFF\uDE00-\uDE3E\uDE47\uDE50-\uDE83\uDE86-\uDE99\uDEC0-\uDEF8]|\uD807[\uDC00-\uDC08\uDC0A-\uDC36\uDC38-\uDC40\uDC50-\uDC59\uDC72-\uDC8F\uDC92-\uDCA7\uDCA9-\uDCB6\uDD00-\uDD06\uDD08\uDD09\uDD0B-\uDD36\uDD3A\uDD3C\uDD3D\uDD3F-\uDD47\uDD50-\uDD59]|\uD808[\uDC00-\uDF99]|\uD809[\uDC00-\uDC6E\uDC80-\uDD43]|[\uD80C\uD81C-\uD820\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872\uD874-\uD879][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2E]|\uD811[\uDC00-\uDE46]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDE60-\uDE69\uDED0-\uDEED\uDEF0-\uDEF4\uDF00-\uDF36\uDF40-\uDF43\uDF50-\uDF59\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDF00-\uDF44\uDF50-\uDF7E\uDF8F-\uDF9F\uDFE0\uDFE1]|\uD821[\uDC00-\uDFEC]|\uD822[\uDC00-\uDEF2]|\uD82C[\uDC00-\uDD1E\uDD70-\uDEFB]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99\uDC9D\uDC9E]|\uD834[\uDD65-\uDD69\uDD6D-\uDD72\uDD7B-\uDD82\uDD85-\uDD8B\uDDAA-\uDDAD\uDE42-\uDE44]|\uD835[\uDC00-\uDC54\uDC56-\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD1E-\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD52-\uDEA5\uDEA8-\uDEC0\uDEC2-\uDEDA\uDEDC-\uDEFA\uDEFC-\uDF14\uDF16-\uDF34\uDF36-\uDF4E\uDF50-\uDF6E\uDF70-\uDF88\uDF8A-\uDFA8\uDFAA-\uDFC2\uDFC4-\uDFCB\uDFCE-\uDFFF]|\uD836[\uDE00-\uDE36\uDE3B-\uDE6C\uDE75\uDE84\uDE9B-\uDE9F\uDEA1-\uDEAF]|\uD838[\uDC00-\uDC06\uDC08-\uDC18\uDC1B-\uDC21\uDC23\uDC24\uDC26-\uDC2A]|\uD83A[\uDC00-\uDCC4\uDCD0-\uDCD6\uDD00-\uDD4A\uDD50-\uDD59]|\uD83B[\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD869[\uDC00-\uDED6\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF34\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1\uDEB0-\uDFFF]|\uD87A[\uDC00-\uDFE0]|\uD87E[\uDC00-\uDE1D]|\uDB40[\uDD00-\uDDEF]/;
var unicode = {
Space_Separator,
ID_Start,
ID_Continue
};
var util = {
isSpaceSeparator(c3) {
return typeof c3 === "string" && unicode.Space_Separator.test(c3);
},
isIdStartChar(c3) {
return typeof c3 === "string" && (c3 >= "a" && c3 <= "z" || c3 >= "A" && c3 <= "Z" || c3 === "$" || c3 === "_" || unicode.ID_Start.test(c3));
},
isIdContinueChar(c3) {
return typeof c3 === "string" && (c3 >= "a" && c3 <= "z" || c3 >= "A" && c3 <= "Z" || c3 >= "0" && c3 <= "9" || c3 === "$" || c3 === "_" || c3 === "" || c3 === "" || unicode.ID_Continue.test(c3));
},
isDigit(c3) {
return typeof c3 === "string" && /[0-9]/.test(c3);
},
isHexDigit(c3) {
return typeof c3 === "string" && /[0-9A-Fa-f]/.test(c3);
}
};
let source;
let parseState;
let stack;
let pos;
let line;
let column;
let token;
let key$1;
let root;
var parse = function parse2(text, reviver) {
source = String(text);
parseState = "start";
stack = [];
pos = 0;
line = 1;
column = 0;
token = void 0;
key$1 = void 0;
root = void 0;
do {
token = lex();
parseStates[parseState]();
} while (token.type !== "eof");
if (typeof reviver === "function") {
return internalize({ "": root }, "", reviver);
}
return root;
};
function internalize(holder, name, reviver) {
const value = holder[name];
if (value != null && typeof value === "object") {
if (Array.isArray(value)) {
for (let i3 = 0; i3 < value.length; i3++) {
const key2 = String(i3);
const replacement = internalize(value, key2, reviver);
if (replacement === void 0) {
delete value[key2];
} else {
Object.defineProperty(value, key2, {
value: replacement,
writable: true,
enumerable: true,
configurable: true
});
}
}
} else {
for (const key2 in value) {
const replacement = internalize(value, key2, reviver);
if (replacement === void 0) {
delete value[key2];
} else {
Object.defineProperty(value, key2, {
value: replacement,
writable: true,
enumerable: true,
configurable: true
});
}
}
}
}
return reviver.call(holder, name, value);
}
let lexState;
let buffer;
let doubleQuote;
let sign;
let c$1;
function lex() {
lexState = "default";
buffer = "";
doubleQuote = false;
sign = 1;
for (; ; ) {
c$1 = peek();
const token2 = lexStates[lexState]();
if (token2) {
return token2;
}
}
}
function peek() {
if (source[pos]) {
return String.fromCodePoint(source.codePointAt(pos));
}
}
function read() {
const c3 = peek();
if (c3 === "\n") {
line++;
column = 0;
} else if (c3) {
column += c3.length;
} else {
column++;
}
if (c3) {
pos += c3.length;
}
return c3;
}
const lexStates = {
default() {
switch (c$1) {
case " ":
case "\v":
case "\f":
case " ":
case " ":
case "\uFEFF":
case "\n":
case "\r":
case "\u2028":
case "\u2029":
read();
return;
case "/":
read();
lexState = "comment";
return;
case void 0:
read();
return newToken("eof");
}
if (util.isSpaceSeparator(c$1)) {
read();
return;
}
return lexStates[parseState]();
},
comment() {
switch (c$1) {
case "*":
read();
lexState = "multiLineComment";
return;
case "/":
read();
lexState = "singleLineComment";
return;
}
throw invalidChar(read());
},
multiLineComment() {
switch (c$1) {
case "*":
read();
lexState = "multiLineCommentAsterisk";
return;
case void 0:
throw invalidChar(read());
}
read();
},
multiLineCommentAsterisk() {
switch (c$1) {
case "*":
read();
return;
case "/":
read();
lexState = "default";
return;
case void 0:
throw invalidChar(read());
}
read();
lexState = "multiLineComment";
},
singleLineComment() {
switch (c$1) {
case "\n":
case "\r":
case "\u2028":
case "\u2029":
read();
lexState = "default";
return;
case void 0:
read();
return newToken("eof");
}
read();
},
value() {
switch (c$1) {
case "{":
case "[":
return newToken("punctuator", read());
case "n":
read();
literal("ull");
return newToken("null", null);
case "t":
read();
literal("rue");
return newToken("boolean", true);
case "f":
read();
literal("alse");
return newToken("boolean", false);
case "-":
case "+":
if (read() === "-") {
sign = -1;
}
lexState = "sign";
return;
case ".":
buffer = read();
lexState = "decimalPointLeading";
return;
case "0":
buffer = read();
lexState = "zero";
return;
case "1":
case "2":
case "3":
case "4":
case "5":
case "6":
case "7":
case "8":
case "9":
buffer = read();
lexState = "decimalInteger";
return;
case "I":
read();
literal("nfinity");
return newToken("numeric", Infinity);
case "N":
read();
literal("aN");
return newToken("numeric", NaN);
case '"':
case "'":
doubleQuote = read() === '"';
buffer = "";
lexState = "string";
return;
}
throw invalidChar(read());
},
identifierNameStartEscape() {
if (c$1 !== "u") {
throw invalidChar(read());
}
read();
const u2 = unicodeEscape();
switch (u2) {
case "$":
case "_":
break;
default:
if (!util.isIdStartChar(u2)) {
throw invalidIdentifier();
}
break;
}
buffer += u2;
lexState = "identifierName";
},
identifierName() {
switch (c$1) {
case "$":
case "_":
case "":
case "":
buffer += read();
return;
case "\\":
read();
lexState = "identifierNameEscape";
return;
}
if (util.isIdContinueChar(c$1)) {
buffer += read();
return;
}
return newToken("identifier", buffer);
},
identifierNameEscape() {
if (c$1 !== "u") {
throw invalidChar(read());
}
read();
const u2 = unicodeEscape();
switch (u2) {
case "$":
case "_":
case "":
case "":
break;
default:
if (!util.isIdContinueChar(u2)) {
throw invalidIdentifier();
}
break;
}
buffer += u2;
lexState = "identifierName";
},
sign() {
switch (c$1) {
case ".":
buffer = read();
lexState = "decimalPointLeading";
return;
case "0":
buffer = read();
lexState = "zero";
return;
case "1":
case "2":
case "3":
case "4":
case "5":
case "6":
case "7":
case "8":
case "9":
buffer = read();
lexState = "decimalInteger";
return;
case "I":
read();
literal("nfinity");
return newToken("numeric", sign * Infinity);
case "N":
read();
literal("aN");
return newToken("numeric", NaN);
}
throw invalidChar(read());
},
zero() {
switch (c$1) {
case ".":
buffer += read();
lexState = "decimalPoint";
return;
case "e":
case "E":
buffer += read();
lexState = "decimalExponent";
return;
case "x":
case "X":
buffer += read();
lexState = "hexadecimal";
return;
}
return newToken("numeric", sign * 0);
},
decimalInteger() {
switch (c$1) {
case ".":
buffer += read();
lexState = "decimalPoint";
return;
case "e":
case "E":
buffer += read();
lexState = "decimalExponent";
return;
}
if (util.isDigit(c$1)) {
buffer += read();
return;
}
return newToken("numeric", sign * Number(buffer));
},
decimalPointLeading() {
if (util.isDigit(c$1)) {
buffer += read();
lexState = "decimalFraction";
return;
}
throw invalidChar(read());
},
decimalPoint() {
switch (c$1) {
case "e":
case "E":
buffer += read();
lexState = "decimalExponent";
return;
}
if (util.isDigit(c$1)) {
buffer += read();
lexState = "decimalFraction";
return;
}
return newToken("numeric", sign * Number(buffer));
},
decimalFraction() {
switch (c$1) {
case "e":
case "E":
buffer += read();
lexState = "decimalExponent";
return;
}
if (util.isDigit(c$1)) {
buffer += read();
return;
}
return newToken("numeric", sign * Number(buffer));
},
decimalExponent() {
switch (c$1) {
case "+":
case "-":
buffer += read();
lexState = "decimalExponentSign";
return;
}
if (util.isDigit(c$1)) {
buffer += read();
lexState = "decimalExponentInteger";
return;
}
throw invalidChar(read());
},
decimalExponentSign() {
if (util.isDigit(c$1)) {
buffer += read();
lexState = "decimalExponentInteger";
return;
}
throw invalidChar(read());
},
decimalExponentInteger() {
if (util.isDigit(c$1)) {
buffer += read();
return;
}
return newToken("numeric", sign * Number(buffer));
},
hexadecimal() {
if (util.isHexDigit(c$1)) {
buffer += read();
lexState = "hexadecimalInteger";
return;
}
throw invalidChar(read());
},
hexadecimalInteger() {
if (util.isHexDigit(c$1)) {
buffer += read();
return;
}
return newToken("numeric", sign * Number(buffer));
},
string() {
switch (c$1) {
case "\\":
read();
buffer += escape();
return;
case '"':
if (doubleQuote) {
read();
return newToken("string", buffer);
}
buffer += read();
return;
case "'":
if (!doubleQuote) {
read();
return newToken("string", buffer);
}
buffer += read();
return;
case "\n":
case "\r":
throw invalidChar(read());
case "\u2028":
case "\u2029":
separatorChar(c$1);
break;
case void 0:
throw invalidChar(read());
}
buffer += read();
},
start() {
switch (c$1) {
case "{":
case "[":
return newToken("punctuator", read());
}
lexState = "value";
},
beforePropertyName() {
switch (c$1) {
case "$":
case "_":
buffer = read();
lexState = "identifierName";
return;
case "\\":
read();
lexState = "identifierNameStartEscape";
return;
case "}":
return newToken("punctuator", read());
case '"':
case "'":
doubleQuote = read() === '"';
lexState = "string";
return;
}
if (util.isIdStartChar(c$1)) {
buffer += read();
lexState = "identifierName";
return;
}
throw invalidChar(read());
},
afterPropertyName() {
if (c$1 === ":") {
return newToken("punctuator", read());
}
throw invalidChar(read());
},
beforePropertyValue() {
lexState = "value";
},
afterPropertyValue() {
switch (c$1) {
case ",":
case "}":
return newToken("punctuator", read());
}
throw invalidChar(read());
},
beforeArrayValue() {
if (c$1 === "]") {
return newToken("punctuator", read());
}
lexState = "value";
},
afterArrayValue() {
switch (c$1) {
case ",":
case "]":
return newToken("punctuator", read());
}
throw invalidChar(read());
},
end() {
throw invalidChar(read());
}
};
function newToken(type, value) {
return {
type,
value,
line,
column
};
}
function literal(s3) {
for (const c3 of s3) {
const p2 = peek();
if (p2 !== c3) {
throw invalidChar(read());
}
read();
}
}
function escape() {
const c3 = peek();
switch (c3) {
case "b":
read();
return "\b";
case "f":
read();
return "\f";
case "n":
read();
return "\n";
case "r":
read();
return "\r";
case "t":
read();
return " ";
case "v":
read();
return "\v";
case "0":
read();
if (util.isDigit(peek())) {
throw invalidChar(read());
}
return "\0";
case "x":
read();
return hexEscape();
case "u":
read();
return unicodeEscape();
case "\n":
case "\u2028":
case "\u2029":
read();
return "";
case "\r":
read();
if (peek() === "\n") {
read();
}
return "";
case "1":
case "2":
case "3":
case "4":
case "5":
case "6":
case "7":
case "8":
case "9":
throw invalidChar(read());
case void 0:
throw invalidChar(read());
}
return read();
}
function hexEscape() {
let buffer2 = "";
let c3 = peek();
if (!util.isHexDigit(c3)) {
throw invalidChar(read());
}
buffer2 += read();
c3 = peek();
if (!util.isHexDigit(c3)) {
throw invalidChar(read());
}
buffer2 += read();
return String.fromCodePoint(parseInt(buffer2, 16));
}
function unicodeEscape() {
let buffer2 = "";
let count = 4;
while (count-- > 0) {
const c3 = peek();
if (!util.isHexDigit(c3)) {
throw invalidChar(read());
}
buffer2 += read();
}
return String.fromCodePoint(parseInt(buffer2, 16));
}
const parseStates = {
start() {
if (token.type === "eof") {
throw invalidEOF();
}
push();
},
beforePropertyName() {
switch (token.type) {
case "identifier":
case "string":
key$1 = token.value;
parseState = "afterPropertyName";
return;
case "punctuator":
pop();
return;
case "eof":
throw invalidEOF();
}
},
afterPropertyName() {
if (token.type === "eof") {
throw invalidEOF();
}
parseState = "beforePropertyValue";
},
beforePropertyValue() {
if (token.type === "eof") {
throw invalidEOF();
}
push();
},
beforeArrayValue() {
if (token.type === "eof") {
throw invalidEOF();
}
if (token.type === "punctuator" && token.value === "]") {
pop();
return;
}
push();
},
afterPropertyValue() {
if (token.type === "eof") {
throw invalidEOF();
}
switch (token.value) {
case ",":
parseState = "beforePropertyName";
return;
case "}":
pop();
}
},
afterArrayValue() {
if (token.type === "eof") {
throw invalidEOF();
}
switch (token.value) {
case ",":
parseState = "beforeArrayValue";
return;
case "]":
pop();
}
},
end() {
}
};
function push() {
let value;
switch (token.type) {
case "punctuator":
switch (token.value) {
case "{":
value = {};
break;
case "[":
value = [];
break;
}
break;
case "null":
case "boolean":
case "numeric":
case "string":
value = token.value;
break;
}
if (root === void 0) {
root = value;
} else {
const parent = stack[stack.length - 1];
if (Array.isArray(parent)) {
parent.push(value);
} else {
Object.defineProperty(parent, key$1, {
value,
writable: true,
enumerable: true,
configurable: true
});
}
}
if (value !== null && typeof value === "object") {
stack.push(value);
if (Array.isArray(value)) {
parseState = "beforeArrayValue";
} else {
parseState = "beforePropertyName";
}
} else {
const current = stack[stack.length - 1];
if (current == null) {
parseState = "end";
} else if (Array.isArray(current)) {
parseState = "afterArrayValue";
} else {
parseState = "afterPropertyValue";
}
}
}
function pop() {
stack.pop();
const current = stack[stack.length - 1];
if (current == null) {
parseState = "end";
} else if (Array.isArray(current)) {
parseState = "afterArrayValue";
} else {
parseState = "afterPropertyValue";
}
}
function invalidChar(c3) {
if (c3 === void 0) {
return syntaxError(`JSON5: invalid end of input at ${line}:${column}`);
}
return syntaxError(`JSON5: invalid character '${formatChar(c3)}' at ${line}:${column}`);
}
function invalidEOF() {
return syntaxError(`JSON5: invalid end of input at ${line}:${column}`);
}
function invalidIdentifier() {
column -= 5;
return syntaxError(`JSON5: invalid identifier character at ${line}:${column}`);
}
function separatorChar(c3) {
console.warn(`JSON5: '${formatChar(c3)}' in strings is not valid ECMAScript; consider escaping`);
}
function formatChar(c3) {
const replacements = {
"'": "\\'",
'"': '\\"',
"\\": "\\\\",
"\b": "\\b",
"\f": "\\f",
"\n": "\\n",
"\r": "\\r",
" ": "\\t",
"\v": "\\v",
"\0": "\\0",
"\u2028": "\\u2028",
"\u2029": "\\u2029"
};
if (replacements[c3]) {
return replacements[c3];
}
if (c3 < " ") {
const hexString = c3.charCodeAt(0).toString(16);
return "\\x" + ("00" + hexString).substring(hexString.length);
}
return c3;
}
function syntaxError(message) {
const err = new SyntaxError(message);
err.lineNumber = line;
err.columnNumber = column;
return err;
}
var stringify = function stringify2(value, replacer, space) {
const stack2 = [];
let indent = "";
let propertyList;
let replacerFunc;
let gap = "";
let quote;
if (replacer != null && typeof replacer === "object" && !Array.isArray(replacer)) {
space = replacer.space;
quote = replacer.quote;
replacer = replacer.replacer;
}
if (typeof replacer === "function") {
replacerFunc = replacer;
} else if (Array.isArray(replacer)) {
propertyList = [];
for (const v2 of replacer) {
let item;
if (typeof v2 === "string") {
item = v2;
} else if (typeof v2 === "number" || v2 instanceof String || v2 instanceof Number) {
item = String(v2);
}
if (item !== void 0 && propertyList.indexOf(item) < 0) {
propertyList.push(item);
}
}
}
if (space instanceof Number) {
space = Number(space);
} else if (space instanceof String) {
space = String(space);
}
if (typeof space === "number") {
if (space > 0) {
space = Math.min(10, Math.floor(space));
gap = " ".substr(0, space);
}
} else if (typeof space === "string") {
gap = space.substr(0, 10);
}
return serializeProperty("", { "": value });
function serializeProperty(key2, holder) {
let value2 = holder[key2];
if (value2 != null) {
if (typeof value2.toJSON5 === "function") {
value2 = value2.toJSON5(key2);
} else if (typeof value2.toJSON === "function") {
value2 = value2.toJSON(key2);
}
}
if (replacerFunc) {
value2 = replacerFunc.call(holder, key2, value2);
}
if (value2 instanceof Number) {
value2 = Number(value2);
} else if (value2 instanceof String) {
value2 = String(value2);
} else if (value2 instanceof Boolean) {
value2 = value2.valueOf();
}
switch (value2) {
case null:
return "null";
case true:
return "true";
case false:
return "false";
}
if (typeof value2 === "string") {
return quoteString(value2);
}
if (typeof value2 === "number") {
return String(value2);
}
if (typeof value2 === "object") {
return Array.isArray(value2) ? serializeArray(value2) : serializeObject(value2);
}
return void 0;
}
function quoteString(value2) {
const quotes = {
"'": 0.1,
'"': 0.2
};
const replacements = {
"'": "\\'",
'"': '\\"',
"\\": "\\\\",
"\b": "\\b",
"\f": "\\f",
"\n": "\\n",
"\r": "\\r",
" ": "\\t",
"\v": "\\v",
"\0": "\\0",
"\u2028": "\\u2028",
"\u2029": "\\u2029"
};
let product = "";
for (let i3 = 0; i3 < value2.length; i3++) {
const c3 = value2[i3];
switch (c3) {
case "'":
case '"':
quotes[c3]++;
product += c3;
continue;
case "\0":
if (util.isDigit(value2[i3 + 1])) {
product += "\\x00";
continue;
}
}
if (replacements[c3]) {
product += replacements[c3];
continue;
}
if (c3 < " ") {
let hexString = c3.charCodeAt(0).toString(16);
product += "\\x" + ("00" + hexString).substring(hexString.length);
continue;
}
product += c3;
}
const quoteChar = quote || Object.keys(quotes).reduce((a2, b3) => quotes[a2] < quotes[b3] ? a2 : b3);
product = product.replace(new RegExp(quoteChar, "g"), replacements[quoteChar]);
return quoteChar + product + quoteChar;
}
function serializeObject(value2) {
if (stack2.indexOf(value2) >= 0) {
throw TypeError("Converting circular structure to JSON5");
}
stack2.push(value2);
let stepback = indent;
indent = indent + gap;
let keys = propertyList || Object.keys(value2);
let partial = [];
for (const key2 of keys) {
const propertyString = serializeProperty(key2, value2);
if (propertyString !== void 0) {
let member = serializeKey(key2) + ":";
if (gap !== "") {
member += " ";
}
member += propertyString;
partial.push(member);
}
}
let final;
if (partial.length === 0) {
final = "{}";
} else {
let properties;
if (gap === "") {
properties = partial.join(",");
final = "{" + properties + "}";
} else {
let separator = ",\n" + indent;
properties = partial.join(separator);
final = "{\n" + indent + properties + ",\n" + stepback + "}";
}
}
stack2.pop();
indent = stepback;
return final;
}
function serializeKey(key2) {
if (key2.length === 0) {
return quoteString(key2);
}
const firstChar = String.fromCodePoint(key2.codePointAt(0));
if (!util.isIdStartChar(firstChar)) {
return quoteString(key2);
}
for (let i3 = firstChar.length; i3 < key2.length; i3++) {
if (!util.isIdContinueChar(String.fromCodePoint(key2.codePointAt(i3)))) {
return quoteString(key2);
}
}
return key2;
}
function serializeArray(value2) {
if (stack2.indexOf(value2) >= 0) {
throw TypeError("Converting circular structure to JSON5");
}
stack2.push(value2);
let stepback = indent;
indent = indent + gap;
let partial = [];
for (let i3 = 0; i3 < value2.length; i3++) {
const propertyString = serializeProperty(String(i3), value2);
partial.push(propertyString !== void 0 ? propertyString : "null");
}
let final;
if (partial.length === 0) {
final = "[]";
} else {
if (gap === "") {
let properties = partial.join(",");
final = "[" + properties + "]";
} else {
let separator = ",\n" + indent;
let properties = partial.join(separator);
final = "[\n" + indent + properties + ",\n" + stepback + "]";
}
}
stack2.pop();
indent = stepback;
return final;
}
};
const JSON5 = {
parse,
stringify
};
var lib = JSON5;
const onChange = (element) => {
if (element.id == "left") {
if (element.value != "") document.querySelector(".position#right").disabled = true;
else document.querySelector(".position#right").disabled = false;
}
if (element.id == "right") {
if (element.value != "") document.querySelector(".position#left").disabled = true;
else document.querySelector(".position#left").disabled = false;
}
if (element.id == "top") {
if (element.value != "") document.querySelector(".position#bottom").disabled = true;
else document.querySelector(".position#bottom").disabled = false;
}
if (element.id == "bottom") {
if (element.value != "") document.querySelector(".position#top").disabled = true;
else document.querySelector(".position#top").disabled = false;
}
};
const constructPositionArray = () => {
const left = document.querySelector(".position#left").value;
const right = document.querySelector(".position#right").value;
const top2 = document.querySelector(".position#top").value;
const bottom = document.querySelector(".position#bottom").value;
if (!left && !right && !top2 && !bottom) return [];
else return [top2, left, right, bottom];
};
const iArrayToArray = (array = []) => {
return Array().concat(array);
};
const groupsKeyOrder = [
"key",
"name",
"desc",
"matchTime",
"actionMaximum",
"resetMatch",
"priorityTime",
"rules"
];
const sort = async (groups) => {
const rulesKeyOrder = await getHanashiroSettings("rulesKeySort");
const groupsKeyValue = [];
const rulesKeyValue = [];
groupsKeyOrder.forEach((groupsKey) => {
if (groups[groupsKey] !== void 0) groupsKeyValue.push(groups[groupsKey]);
else groupsKeyValue.push(void 0);
});
rulesKeyOrder.forEach((rulesKey) => {
if (groups.rules[0][rulesKey] !== void 0) rulesKeyValue.push(groups.rules[0][rulesKey]);
else rulesKeyValue.push(void 0);
});
const sortedRules = {};
rulesKeyOrder.forEach((rulesKey, index) => {
sortedRules[rulesKey] = rulesKeyValue[index];
});
const sortedGroups = {
key: groupsKeyValue[0],
name: groupsKeyValue[1],
desc: groupsKeyValue[2],
matchTime: groupsKeyValue[3],
actionMaximum: groupsKeyValue[4],
resetMatch: groupsKeyValue[5],
priorityTime: groupsKeyValue[6],
rules: [sortedRules]
};
return sortedGroups;
};
const checkPositionLegal = (position) => {
const { top: top2, left, right, bottom } = position;
if (top2) {
if (bottom || !left && !right) {
snackbar({
message: "非法坐标",
placement: "top"
});
return false;
}
}
if (left) {
if (right || !top2 && !bottom) {
snackbar({
message: "非法坐标",
placement: "top"
});
return false;
}
}
if (right) {
if (left || !top2 && !bottom) {
snackbar({
message: "非法坐标",
placement: "top"
});
return false;
}
}
if (bottom) {
if (top2 || !left && !right) {
snackbar({
message: "非法坐标",
placement: "top"
});
return false;
}
}
return true;
};
const finish = async () => {
const mode = document.querySelector("#mode").value;
const action = document.querySelector("#action").value;
const ruleName = document.querySelector("#ruleName").value;
const ruleDesc = document.querySelector("#ruleDesc").value;
const category = window.Hanashiro.currentCategory;
const isLimit = document.querySelector("#limit").checked;
const isNoExample = document.querySelector("#noExample").checked;
const preKeys = document.querySelector("#preKeys").value;
const position = constructPositionArray().length != 0 ? constructPositionArray() : false;
const isSimplyActivityIds = await getHanashiroSettings("activityIdsSimply");
const origin = lib.parse(window.Hanashiro.originRule);
if (ruleName) origin.groups[0].name = ruleName;
else origin.groups[0].name = "";
if (ruleDesc) origin.groups[0].desc = ruleDesc;
else delete origin.groups[0].desc;
if (category) {
if (!ruleName) origin.groups[0].name = category;
else origin.groups[0].name = `${category}-${origin.groups[0].name}`;
if (category == "开屏广告") {
origin.groups[0].priorityTime = 1e4;
const rule = iArrayToArray(origin.groups[0].rules)[0];
delete rule.activityIds;
origin.groups[0].rules = [rule];
}
}
if (action) {
const rule = iArrayToArray(origin.groups[0].rules)[0];
rule.action = action;
origin.groups[0].rules = [rule];
}
if (isLimit) {
if (mode == "rules") {
const rule = iArrayToArray(origin.groups[0].rules)[0];
rule.actionMaximum = 1;
rule.resetMatch = "app";
rule.matchTime = 1e4;
origin.groups[0].rules = [rule];
} else {
origin.groups[0].actionMaximum = 1;
origin.groups[0].resetMatch = "app";
origin.groups[0].matchTime = 1e4;
}
}
if (isNoExample) {
const rule = iArrayToArray(origin.groups[0].rules)[0];
delete rule.exampleUrls;
origin.groups[0].rules = [rule];
}
if (preKeys) {
const preKeysArray = preKeys.split(",");
const preKeysNumberArray = [];
preKeysArray.forEach((preKey) => {
preKeysNumberArray.push(Number(preKey));
});
const rule = iArrayToArray(origin.groups[0].rules)[0];
rule.preKeys = preKeysNumberArray;
origin.groups[0].rules = [rule];
}
if (position) {
const positionName = ["top", "left", "right", "bottom"];
const positionObject = {};
position.forEach((position2, index) => {
if (position2) {
positionObject[positionName[index]] = position2;
}
});
if (!checkPositionLegal(positionObject)) return;
const rule = iArrayToArray(origin.groups[0].rules)[0];
rule.position = positionObject;
origin.groups[0].rules = [rule];
}
if (isSimplyActivityIds === true) {
const snapshotId = getSnapshotId();
const rule = iArrayToArray(origin.groups[0].rules)[0];
const result = await simplyActivityIds(snapshotId);
if (result && rule.activityIds) {
rule.activityIds = result;
origin.groups[0].rules = [rule];
}
}
origin.groups[0] = await sort(origin.groups[0]);
const stringify3 = lib.stringify(origin, null, 2);
if (mode == "ts") {
const text = `import { defineGkdApp } from '@gkd-kit/define';\r\rexport default defineGkdApp(${stringify3});\r`;
window.Hanashiro.returnResult = text;
} else if (mode == "app") window.Hanashiro.returnResult = stringify3;
else if (mode == "groups") window.Hanashiro.returnResult = lib.stringify(origin.groups[0], null, 2);
else if (mode == "rules") window.Hanashiro.returnResult = lib.stringify(iArrayToArray(origin.groups[0].rules)[0], null, 2);
send("closePage");
send("modifyEnd");
};
const key = () => {
const mode = document.querySelector("#mode").value;
const key2 = document.querySelector("#key").value;
const origin = lib.parse(window.Hanashiro.originRule);
if (key2) {
if (mode == "rules") {
const rule = iArrayToArray(origin.groups[0].rules)[0];
rule.key = Number(key2);
origin.groups[0].rules = [rule];
} else origin.groups[0].key = Number(key2);
window.Hanashiro.originRule = lib.stringify(origin, null, 2);
snackbar({
message: "key值修改成功!",
placement: "top"
});
}
};
const renderedCategories = async () => {
const categories = await getHanashiroSettings("categories");
const categoriesGroup = document.querySelector("#category");
if (categories) {
let innerHtmlString = "";
categories.forEach((category) => {
innerHtmlString += `<mdui-radio value=${category.name}>${category.name}</mdui-radio>`;
});
categoriesGroup.innerHTML = innerHtmlString;
}
};
const _sfc_main$8 = vue.defineComponent({
methods: {
async finish() {
await finish();
},
key() {
key();
},
onPositionChange(event) {
onChange(event.target);
},
closeDialog() {
send("closePage");
}
},
data() {
return {
originRule: lib.parse(window.Hanashiro.originRule)
};
},
async mounted() {
window.Hanashiro.currentCategory = "";
await renderedCategories();
document.querySelector("#category").addEventListener("change", (e3) => {
window.Hanashiro.currentCategory = e3.target.value;
});
document.querySelector("#page").open = true;
}
});
const _export_sfc = (sfc, props) => {
const target = sfc.__vccOpts || sfc;
for (const [key2, val] of props) {
target[key2] = val;
}
return target;
};
const _hoisted_1 = ["placeholder"];
function _sfc_render$6(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("mdui-dialog", {
id: "page",
headline: "配置",
"close-on-overlay-click": "",
"close-on-esc": "",
onClosed: _cache[6] || (_cache[6] = (...args) => _ctx.closeDialog && _ctx.closeDialog(...args))
}, [
_cache[14] || (_cache[14] = vue.createStaticVNode('<div><span>选择复制模式:</span><mdui-radio-group id="mode" value="app"><mdui-radio value="ts">ts模式</mdui-radio><mdui-radio value="app">app模式</mdui-radio><mdui-radio value="groups">groups模式</mdui-radio><mdui-radio value="rules">rules模式</mdui-radio></mdui-radio-group></div><div><span>选择分类:</span><mdui-radio-group id="category"></mdui-radio-group></div><div><span>插入action类型:</span><mdui-radio-group id="action"><mdui-radio value="clickCenter">clickCenter</mdui-radio><mdui-radio value="back">back</mdui-radio></mdui-radio-group></div><div><span>插入限制字段:</span><mdui-switch id="limit"></mdui-switch><span class="introduction">插入matchTime、resetMatch和actionMaximum</span></div><div><span>去除exampleUrls:</span><mdui-switch id="noExample"></mdui-switch></div>', 5)),
vue.createElementVNode("div", null, [
_cache[7] || (_cache[7] = vue.createElementVNode("span", null, "修改key值为:", -1)),
vue.createElementVNode("mdui-text-field", {
id: "key",
variant: "filled",
type: "number",
label: "key",
placeholder: "填写一个数字",
helper: "rules模式修改ruleKey,其余修改groupKey。请提前选好模式,失焦保存!",
onChange: _cache[0] || (_cache[0] = (...args) => _ctx.key && _ctx.key(...args))
}, null, 32)
]),
_cache[15] || (_cache[15] = vue.createElementVNode("div", null, [
vue.createElementVNode("span", null, "修改preKeys值为:"),
vue.createElementVNode("mdui-text-field", {
id: "preKeys",
variant: "filled",
label: "preKeys",
placeholder: "填写多个以英文逗号分隔的数字",
helper: "失焦保存"
})
], -1)),
vue.createElementVNode("div", null, [
_cache[8] || (_cache[8] = vue.createElementVNode("span", null, "坐标:", -1)),
_cache[9] || (_cache[9] = vue.createElementVNode("mdui-chip", { variant: "input" }, "左", -1)),
vue.createElementVNode("mdui-text-field", {
variant: "filled",
class: "position",
id: "left",
onChange: _cache[1] || (_cache[1] = (...args) => _ctx.onPositionChange && _ctx.onPositionChange(...args))
}, null, 32),
_cache[10] || (_cache[10] = vue.createElementVNode("mdui-chip", { variant: "input" }, "右", -1)),
vue.createElementVNode("mdui-text-field", {
variant: "filled",
class: "position",
id: "right",
onChange: _cache[2] || (_cache[2] = (...args) => _ctx.onPositionChange && _ctx.onPositionChange(...args))
}, null, 32),
_cache[11] || (_cache[11] = vue.createElementVNode("mdui-chip", { variant: "input" }, "上", -1)),
vue.createElementVNode("mdui-text-field", {
variant: "filled",
class: "position",
id: "top",
onChange: _cache[3] || (_cache[3] = (...args) => _ctx.onPositionChange && _ctx.onPositionChange(...args))
}, null, 32),
_cache[12] || (_cache[12] = vue.createElementVNode("mdui-chip", { variant: "input" }, "下", -1)),
vue.createElementVNode("mdui-text-field", {
variant: "filled",
class: "position",
id: "bottom",
onChange: _cache[4] || (_cache[4] = (...args) => _ctx.onPositionChange && _ctx.onPositionChange(...args))
}, null, 32)
]),
vue.createElementVNode("div", null, [
_cache[13] || (_cache[13] = vue.createElementVNode("span", null, "规则组名称:", -1)),
vue.createElementVNode("mdui-text-field", {
id: "ruleName",
variant: "filled",
label: "名称",
placeholder: _ctx.originRule.groups[0].name
}, null, 8, _hoisted_1)
]),
_cache[16] || (_cache[16] = vue.createElementVNode("div", null, [
vue.createElementVNode("span", null, "规则组描述:"),
vue.createElementVNode("mdui-text-field", {
id: "ruleDesc",
variant: "filled",
label: "描述",
placeholder: "没有描述不填"
})
], -1)),
vue.createElementVNode("div", null, [
vue.createElementVNode("mdui-button", {
slot: "action",
variant: "tonal",
onClick: _cache[5] || (_cache[5] = (...args) => _ctx.finish && _ctx.finish(...args))
}, "确定")
])
], 32);
}
const Main = /* @__PURE__ */ _export_sfc(_sfc_main$8, [["render", _sfc_render$6]]);
const settings = async () => {
const categories = document.querySelector("#categories").value;
const rulesKeySort2 = document.querySelector("#rulesKeySort").value;
const isHideLoadSnackbar = document.querySelector("#hideLoadSnackbar").checked;
const isSimplyName = document.querySelector("#simplyName").checked;
const isAutoAddSelector = document.querySelector("#autoAddSelector").checked;
const isActivityIdsSimply = document.querySelector("#activityIdsSimply").checked;
await setHanashiroSettings("categories", lib.parse(categories ? categories : "[]"));
await setHanashiroSettings("rulesKeySort", lib.parse(rulesKeySort2 ? rulesKeySort2 : "[]"));
await setHanashiroSettings("hideLoadSnackbar", isHideLoadSnackbar);
await setHanashiroSettings("simplyName", isSimplyName);
await setHanashiroSettings("autoAddSelector", isAutoAddSelector);
await setHanashiroSettings("activityIdsSimply", isActivityIdsSimply);
send("closePage");
};
const e2 = (() => {
if ("undefined" == typeof self) return false;
if ("top" in self && self !== top) try {
top.window.document._ = 0;
} catch (e3) {
return false;
}
return "showOpenFilePicker" in self;
})(), t2 = e2 ? Promise.resolve().then(function() {
return l;
}) : Promise.resolve().then(function() {
return v;
});
async function n2(...e3) {
return (await t2).default(...e3);
}
e2 ? Promise.resolve().then(function() {
return y;
}) : Promise.resolve().then(function() {
return b2;
});
e2 ? Promise.resolve().then(function() {
return m;
}) : Promise.resolve().then(function() {
return k2;
});
const s2 = async (e3) => {
const t3 = await e3.getFile();
return t3.handle = e3, t3;
};
var c2 = async (e3 = [{}]) => {
Array.isArray(e3) || (e3 = [e3]);
const t3 = [];
e3.forEach((e4, n4) => {
t3[n4] = { description: e4.description || "Files", accept: {} }, e4.mimeTypes ? e4.mimeTypes.map((r4) => {
t3[n4].accept[r4] = e4.extensions || [];
}) : t3[n4].accept["*/*"] = e4.extensions || [];
});
const n3 = await window.showOpenFilePicker({ id: e3[0].id, startIn: e3[0].startIn, types: t3, multiple: e3[0].multiple || false, excludeAcceptAllOption: e3[0].excludeAcceptAllOption || false }), r3 = await Promise.all(n3.map(s2));
return e3[0].multiple ? r3 : r3[0];
}, l = { __proto__: null, default: c2 };
function u(e3) {
function t3(e4) {
if (Object(e4) !== e4) return Promise.reject(new TypeError(e4 + " is not an object."));
var t4 = e4.done;
return Promise.resolve(e4.value).then(function(e5) {
return { value: e5, done: t4 };
});
}
return u = function(e4) {
this.s = e4, this.n = e4.next;
}, u.prototype = { s: null, n: null, next: function() {
return t3(this.n.apply(this.s, arguments));
}, return: function(e4) {
var n3 = this.s.return;
return void 0 === n3 ? Promise.resolve({ value: e4, done: true }) : t3(n3.apply(this.s, arguments));
}, throw: function(e4) {
var n3 = this.s.return;
return void 0 === n3 ? Promise.reject(e4) : t3(n3.apply(this.s, arguments));
} }, new u(e3);
}
const p = async (e3, t3, n3 = e3.name, r3) => {
const i3 = [], a2 = [];
var o2, s3 = false, c3 = false;
try {
for (var l2, d2 = function(e4) {
var t4, n4, r4, i4 = 2;
for ("undefined" != typeof Symbol && (n4 = Symbol.asyncIterator, r4 = Symbol.iterator); i4--; ) {
if (n4 && null != (t4 = e4[n4])) return t4.call(e4);
if (r4 && null != (t4 = e4[r4])) return new u(t4.call(e4));
n4 = "@@asyncIterator", r4 = "@@iterator";
}
throw new TypeError("Object is not async iterable");
}(e3.values()); s3 = !(l2 = await d2.next()).done; s3 = false) {
const o3 = l2.value, s4 = `${n3}/${o3.name}`;
"file" === o3.kind ? a2.push(o3.getFile().then((t4) => (t4.directoryHandle = e3, t4.handle = o3, Object.defineProperty(t4, "webkitRelativePath", { configurable: true, enumerable: true, get: () => s4 })))) : "directory" !== o3.kind || !t3 || r3 && r3(o3) || i3.push(p(o3, t3, s4, r3));
}
} catch (e4) {
c3 = true, o2 = e4;
} finally {
try {
s3 && null != d2.return && await d2.return();
} finally {
if (c3) throw o2;
}
}
return [...(await Promise.all(i3)).flat(), ...await Promise.all(a2)];
};
var d = async (e3 = {}) => {
e3.recursive = e3.recursive || false, e3.mode = e3.mode || "read";
const t3 = await window.showDirectoryPicker({ id: e3.id, startIn: e3.startIn, mode: e3.mode });
return (await (await t3.values()).next()).done ? [t3] : p(t3, e3.recursive, void 0, e3.skipDirectory);
}, y = { __proto__: null, default: d }, f2 = async (e3, t3 = [{}], n3 = null, r3 = false, i3 = null) => {
Array.isArray(t3) || (t3 = [t3]), t3[0].fileName = t3[0].fileName || "Untitled";
const a2 = [];
let o2 = null;
if (e3 instanceof Blob && e3.type ? o2 = e3.type : e3.headers && e3.headers.get("content-type") && (o2 = e3.headers.get("content-type")), t3.forEach((e4, t4) => {
a2[t4] = { description: e4.description || "Files", accept: {} }, e4.mimeTypes ? (0 === t4 && o2 && e4.mimeTypes.push(o2), e4.mimeTypes.map((n4) => {
a2[t4].accept[n4] = e4.extensions || [];
})) : o2 ? a2[t4].accept[o2] = e4.extensions || [] : a2[t4].accept["*/*"] = e4.extensions || [];
}), n3) try {
await n3.getFile();
} catch (e4) {
if (n3 = null, r3) throw e4;
}
const s3 = n3 || await window.showSaveFilePicker({ suggestedName: t3[0].fileName, id: t3[0].id, startIn: t3[0].startIn, types: a2, excludeAcceptAllOption: t3[0].excludeAcceptAllOption || false });
!n3 && i3 && i3(s3);
const c3 = await s3.createWritable();
if ("stream" in e3) {
const t4 = e3.stream();
return await t4.pipeTo(c3), s3;
}
return "body" in e3 ? (await e3.body.pipeTo(c3), s3) : (await c3.write(await e3), await c3.close(), s3);
}, m = { __proto__: null, default: f2 }, w = async (e3 = [{}]) => (Array.isArray(e3) || (e3 = [e3]), new Promise((t3, n3) => {
const r3 = document.createElement("input");
r3.type = "file";
const i3 = [...e3.map((e4) => e4.mimeTypes || []), ...e3.map((e4) => e4.extensions || [])].join();
r3.multiple = e3[0].multiple || false, r3.accept = i3 || "", r3.style.display = "none", document.body.append(r3);
const a2 = (e4) => {
"function" == typeof o2 && o2(), t3(e4);
}, o2 = e3[0].legacySetup && e3[0].legacySetup(a2, () => o2(n3), r3), s3 = () => {
window.removeEventListener("focus", s3), r3.remove();
};
r3.addEventListener("click", () => {
window.addEventListener("focus", s3);
}), r3.addEventListener("change", () => {
window.removeEventListener("focus", s3), r3.remove(), a2(r3.multiple ? Array.from(r3.files) : r3.files[0]);
}), "showPicker" in HTMLInputElement.prototype ? r3.showPicker() : r3.click();
})), v = { __proto__: null, default: w }, h2 = async (e3 = [{}]) => (Array.isArray(e3) || (e3 = [e3]), e3[0].recursive = e3[0].recursive || false, new Promise((t3, n3) => {
const r3 = document.createElement("input");
r3.type = "file", r3.webkitdirectory = true;
const i3 = (e4) => {
"function" == typeof a2 && a2(), t3(e4);
}, a2 = e3[0].legacySetup && e3[0].legacySetup(i3, () => a2(n3), r3);
r3.addEventListener("change", () => {
let t4 = Array.from(r3.files);
e3[0].recursive ? e3[0].recursive && e3[0].skipDirectory && (t4 = t4.filter((t5) => t5.webkitRelativePath.split("/").every((t6) => !e3[0].skipDirectory({ name: t6, kind: "directory" })))) : t4 = t4.filter((e4) => 2 === e4.webkitRelativePath.split("/").length), i3(t4);
}), "showPicker" in HTMLInputElement.prototype ? r3.showPicker() : r3.click();
})), b2 = { __proto__: null, default: h2 }, P = async (e3, t3 = {}) => {
Array.isArray(t3) && (t3 = t3[0]);
const n3 = document.createElement("a");
let r3 = e3;
"body" in e3 && (r3 = await async function(e4, t4) {
const n4 = e4.getReader(), r4 = new ReadableStream({ start: (e5) => async function t5() {
return n4.read().then(({ done: n5, value: r5 }) => {
if (!n5) return e5.enqueue(r5), t5();
e5.close();
});
}() }), i4 = new Response(r4), a3 = await i4.blob();
return n4.releaseLock(), new Blob([a3], { type: t4 });
}(e3.body, e3.headers.get("content-type"))), n3.download = t3.fileName || "Untitled", n3.href = URL.createObjectURL(await r3);
const i3 = () => {
"function" == typeof a2 && a2();
}, a2 = t3.legacySetup && t3.legacySetup(i3, () => a2(), n3);
return n3.addEventListener("click", () => {
setTimeout(() => URL.revokeObjectURL(n3.href), 3e4), i3();
}), n3.click(), null;
}, k2 = { __proto__: null, default: P };
const setValue$1 = async (settings2) => {
try {
await setHanashiroSettings("activityIdsSimply", settings2.activityIdsSimply);
await setHanashiroSettings("autoAddSelector", settings2.autoAddSelector);
await setHanashiroSettings("categories", settings2.categories);
await setHanashiroSettings("hideLoadSnackbar", settings2.hideLoadSnackbar);
await setHanashiroSettings("rulesKeySort", settings2.rulesKeySort);
await setHanashiroSettings("simplyName", settings2.simplyName);
} catch {
snackbar({
message: "应用设置失败",
placement: "top"
});
return;
}
};
const getRemoteSettings = async (url) => {
let remoteSettings;
try {
remoteSettings = lib.parse(await (await fetch(url)).text());
} catch {
snackbar({
message: "请求失败!",
placement: "top"
});
return;
}
await setValue$1(remoteSettings);
snackbar({
message: "设置应用成功!重新打开页面即可看见更改",
placement: "top"
});
};
const getLocalSettings = async () => {
const file = await n2({
description: "设置文件",
extensions: [".json5"],
excludeAcceptAllOption: true
});
const localSettings = lib.parse(await file.text());
await setValue$1(localSettings);
snackbar({
message: "设置应用成功!重新打开页面即可看见更改",
placement: "top"
});
};
const _import$1 = () => {
dialog({
headline: "选择导入渠道",
description: "选择从本地导入或者远程导入",
closeOnEsc: true,
closeOnOverlayClick: true,
actions: [
{
text: "本地导入",
onClick: async () => await getLocalSettings()
},
{
text: "远程导入",
onClick: () => {
prompt({
headline: "远程设置文件链接",
description: "请输入远程设置文件的链接以导入",
closeOnEsc: true,
closeOnOverlayClick: true,
confirmText: "导入",
cancelText: "取消",
onConfirm: async (value) => {
if (!value) {
snackbar({
message: "请输入链接!",
placement: "top"
});
return new Promise((_2, reject) => reject(false));
} else await getRemoteSettings(value);
}
});
}
}
]
});
};
const _export$1 = async () => {
const activityIdsSimply = await getHanashiroSettings("activityIdsSimply");
const autoAddSelector = await getHanashiroSettings("autoAddSelector");
const categories = await getHanashiroSettings("categories");
const hideLoadSnackbar = await getHanashiroSettings("hideLoadSnackbar");
const rulesKeySort2 = await getHanashiroSettings("rulesKeySort");
const simplyName = await getHanashiroSettings("simplyName");
const settings2 = {
activityIdsSimply: activityIdsSimply ? activityIdsSimply : false,
autoAddSelector: autoAddSelector ? autoAddSelector : false,
categories: categories ? categories : [],
hideLoadSnackbar: hideLoadSnackbar ? hideLoadSnackbar : false,
rulesKeySort: rulesKeySort2,
simplyName: simplyName ? simplyName : false
};
const settingsFile = new Blob([lib.stringify(settings2, void 0, 2)]);
FileSaver_minExports.saveAs(settingsFile, "settings.json5");
};
const _sfc_main$7 = vue.defineComponent({
methods: {
settings() {
settings();
},
async exportSettings() {
await _export$1();
},
importSettings() {
_import$1();
},
closeDialog() {
send("closePage");
}
},
async mounted() {
if (await getHanashiroSettings("categories")) {
document.querySelector("#categories").value = lib.stringify(await getHanashiroSettings("categories"));
}
if (await getHanashiroSettings("rulesKeySort")) {
document.querySelector("#rulesKeySort").value = lib.stringify(await getHanashiroSettings("rulesKeySort"));
}
if (await getHanashiroSettings("hideLoadSnackbar") == true) document.querySelector("#hideLoadSnackbar").checked = true;
if (await getHanashiroSettings("simplyName") == true) document.querySelector("#simplyName").checked = true;
if (await getHanashiroSettings("activityIdsSimply") == true) document.querySelector("#activityIdsSimply").checked = true;
document.querySelector("#page").open = true;
}
});
function _sfc_render$5(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("mdui-dialog", {
id: "page",
headline: "设置",
"close-on-overlay-click": "",
"close-on-esc": "",
onClosed: _cache[3] || (_cache[3] = (...args) => _ctx.closeDialog && _ctx.closeDialog(...args))
}, [
vue.createElementVNode("div", null, [
vue.createElementVNode("mdui-button", {
variant: "tonal",
onClick: _cache[0] || (_cache[0] = (...args) => _ctx.exportSettings && _ctx.exportSettings(...args))
}, "导出"),
vue.createElementVNode("mdui-button", {
variant: "tonal",
onClick: _cache[1] || (_cache[1] = (...args) => _ctx.importSettings && _ctx.importSettings(...args))
}, "导入")
]),
_cache[4] || (_cache[4] = vue.createElementVNode("div", null, [
vue.createElementVNode("span", null, "分类设置:"),
vue.createElementVNode("mdui-text-field", {
variant: "filled",
id: "categories",
label: "分类",
placeholder: "填入合法的分类",
rows: "10"
})
], -1)),
_cache[5] || (_cache[5] = vue.createElementVNode("div", null, [
vue.createElementVNode("span", null, "字段排序设置:"),
vue.createElementVNode("mdui-text-field", {
variant: "filled",
id: "rulesKeySort",
label: "字段排序",
placeholder: "目前仅支持rules内字段",
rows: "10"
}),
vue.createElementVNode("span", { class: "introduction" }, " 接受一个字符串数组,目前支持的字段有: key,preKeys,fastQuery,matchTime,actionMaximum,resetMatch,priorityTime action,activityIds,position,matches,exampleUrls,snapshotUrls ")
], -1)),
_cache[6] || (_cache[6] = vue.createStaticVNode('<div><span>隐藏加载成功提示:</span><mdui-switch id="hideLoadSnackbar"></mdui-switch><span class="introduction">每次脚本加载时会弹出一句诗句,此选项可选择是否弹出</span></div><div><span>name属性复制优化:</span><mdui-switch id="simplyName"></mdui-switch><span class="introduction">在复制name属性时,会自动优化复制的内容。如复制 android.widget.TextView 时会优化为 TextView</span></div><div><span>选择器分享自动添加快捷搜索:</span><mdui-switch id="autoAddSelector"></mdui-switch><span class="introduction">在分享选择器时,自动添加到快捷搜索列表中</span></div><div><span>activityIds规则复制优化:</span><mdui-switch id="activityIdsSimply"></mdui-switch><span class="introduction">在复制规则代码时,若activityIds满足简写条件时,使用简写</span></div>', 4)),
vue.createElementVNode("div", null, [
vue.createElementVNode("mdui-button", {
slot: "action",
variant: "tonal",
onClick: _cache[2] || (_cache[2] = (...args) => _ctx.settings && _ctx.settings(...args))
}, "确定")
])
], 32);
}
const Settings = /* @__PURE__ */ _export_sfc(_sfc_main$7, [["render", _sfc_render$5]]);
const _sfc_main$6 = vue.defineComponent({
methods: {
closeDialog() {
send("closePage");
}
},
mounted() {
document.querySelector("#page").open = true;
}
});
function _sfc_render$4(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("mdui-dialog", {
id: "page",
headline: "帮助",
"close-on-overlay-click": "",
"close-on-esc": "",
onClosed: _cache[0] || (_cache[0] = (...args) => _ctx.closeDialog && _ctx.closeDialog(...args))
}, _cache[1] || (_cache[1] = [
vue.createStaticVNode('<div><p> 本脚本已开源至Github,欢迎反馈:<a href="https://github.com/adproqwq/MakeGKDInspectBetter">Github仓库</a><br><br> 你可以通过以下方式联系我:<br> QQ群:494273126<br> 邮箱:adpro_qwq@qq.com<br> Telegram群组:<a href="https://t.me/+P4y5kLo3UrUxMWY1">Telegram群组</a><br> Telegram频道:<a href="https://t.me/adproqwq">Telegram频道</a><br><br> 如果你觉得脚本好用,可以通过赞助支持我:<br><a href="https://afdian.com/a/Adpro">爱发电</a><br><br> 在这里推荐AIsouler的GKD订阅,特别好用,拥有3.3k+的star!<a href="https://github.com/AIsouler/GKD_subscription">Github仓库</a></p></div>', 1)
]), 32);
}
const Help = /* @__PURE__ */ _export_sfc(_sfc_main$6, [["render", _sfc_render$4]]);
const generateSelectors$1 = async () => {
const selectors = await getHanashiroSettings("selectors");
const selectorsGroup = document.querySelector("#selectors");
let innerHtmlString = "";
selectors.forEach(({ name, base64 }, index) => {
innerHtmlString += `<mdui-radio id="selector" value=${base64} data-index="${String(index)}">${name}</mdui-radio>`;
});
selectorsGroup.innerHTML = innerHtmlString;
document.querySelectorAll("#selector").forEach((radio) => {
radio.addEventListener("click", (e3) => {
window.Hanashiro.currentUseSelectorIndex = Number(e3.target.getAttribute("data-index"));
});
});
};
const search = async () => {
const selectors = await getHanashiroSettings("selectors");
const target = new URL(window.location.href);
target.searchParams.set("gkd", selectors[window.Hanashiro.currentUseSelectorIndex].base64);
window.location.href = target.toString();
};
const _sfc_main$5 = vue.defineComponent({
methods: {
async search() {
await search();
},
closeDialog() {
send("closePage");
}
},
async mounted() {
await generateSelectors$1();
document.querySelector("#page").open = true;
}
});
function _sfc_render$3(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("mdui-dialog", {
id: "page",
headline: "使用选择器",
"close-on-overlay-click": "",
"close-on-esc": "",
onClosed: _cache[1] || (_cache[1] = (...args) => _ctx.closeDialog && _ctx.closeDialog(...args))
}, [
_cache[2] || (_cache[2] = vue.createElementVNode("div", null, [
vue.createElementVNode("span", null, "选择选择器:"),
vue.createElementVNode("mdui-radio-group", { id: "selectors" })
], -1)),
vue.createElementVNode("div", null, [
vue.createElementVNode("mdui-button", {
slot: "action",
variant: "tonal",
onClick: _cache[0] || (_cache[0] = (...args) => _ctx.search && _ctx.search(...args))
}, "搜索")
])
], 32);
}
const UseSelector = /* @__PURE__ */ _export_sfc(_sfc_main$5, [["render", _sfc_render$3]]);
const _hasBuffer = typeof Buffer === "function";
const _TD = typeof TextDecoder === "function" ? new TextDecoder() : void 0;
const _TE = typeof TextEncoder === "function" ? new TextEncoder() : void 0;
const b64ch = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";
const b64chs = Array.prototype.slice.call(b64ch);
const b64tab = ((a2) => {
let tab = {};
a2.forEach((c3, i3) => tab[c3] = i3);
return tab;
})(b64chs);
const b64re = /^(?:[A-Za-z\d+\/]{4})*?(?:[A-Za-z\d+\/]{2}(?:==)?|[A-Za-z\d+\/]{3}=?)?$/;
const _fromCC = String.fromCharCode.bind(String);
const _U8Afrom = typeof Uint8Array.from === "function" ? Uint8Array.from.bind(Uint8Array) : (it) => new Uint8Array(Array.prototype.slice.call(it, 0));
const _mkUriSafe = (src) => src.replace(/=/g, "").replace(/[+\/]/g, (m0) => m0 == "+" ? "-" : "_");
const _tidyB64 = (s3) => s3.replace(/[^A-Za-z0-9\+\/]/g, "");
const btoaPolyfill = (bin) => {
let u32, c0, c1, c22, asc = "";
const pad = bin.length % 3;
for (let i3 = 0; i3 < bin.length; ) {
if ((c0 = bin.charCodeAt(i3++)) > 255 || (c1 = bin.charCodeAt(i3++)) > 255 || (c22 = bin.charCodeAt(i3++)) > 255)
throw new TypeError("invalid character found");
u32 = c0 << 16 | c1 << 8 | c22;
asc += b64chs[u32 >> 18 & 63] + b64chs[u32 >> 12 & 63] + b64chs[u32 >> 6 & 63] + b64chs[u32 & 63];
}
return pad ? asc.slice(0, pad - 3) + "===".substring(pad) : asc;
};
const _btoa = typeof btoa === "function" ? (bin) => btoa(bin) : _hasBuffer ? (bin) => Buffer.from(bin, "binary").toString("base64") : btoaPolyfill;
const _fromUint8Array = _hasBuffer ? (u8a) => Buffer.from(u8a).toString("base64") : (u8a) => {
const maxargs = 4096;
let strs = [];
for (let i3 = 0, l2 = u8a.length; i3 < l2; i3 += maxargs) {
strs.push(_fromCC.apply(null, u8a.subarray(i3, i3 + maxargs)));
}
return _btoa(strs.join(""));
};
const cb_utob = (c3) => {
if (c3.length < 2) {
var cc2 = c3.charCodeAt(0);
return cc2 < 128 ? c3 : cc2 < 2048 ? _fromCC(192 | cc2 >>> 6) + _fromCC(128 | cc2 & 63) : _fromCC(224 | cc2 >>> 12 & 15) + _fromCC(128 | cc2 >>> 6 & 63) + _fromCC(128 | cc2 & 63);
} else {
var cc2 = 65536 + (c3.charCodeAt(0) - 55296) * 1024 + (c3.charCodeAt(1) - 56320);
return _fromCC(240 | cc2 >>> 18 & 7) + _fromCC(128 | cc2 >>> 12 & 63) + _fromCC(128 | cc2 >>> 6 & 63) + _fromCC(128 | cc2 & 63);
}
};
const re_utob = /[\uD800-\uDBFF][\uDC00-\uDFFFF]|[^\x00-\x7F]/g;
const utob = (u2) => u2.replace(re_utob, cb_utob);
const _encode = _hasBuffer ? (s3) => Buffer.from(s3, "utf8").toString("base64") : _TE ? (s3) => _fromUint8Array(_TE.encode(s3)) : (s3) => _btoa(utob(s3));
const encode = (src, urlsafe = false) => urlsafe ? _mkUriSafe(_encode(src)) : _encode(src);
const encodeURI = (src) => encode(src, true);
const re_btou = /[\xC0-\xDF][\x80-\xBF]|[\xE0-\xEF][\x80-\xBF]{2}|[\xF0-\xF7][\x80-\xBF]{3}/g;
const cb_btou = (cccc) => {
switch (cccc.length) {
case 4:
var cp = (7 & cccc.charCodeAt(0)) << 18 | (63 & cccc.charCodeAt(1)) << 12 | (63 & cccc.charCodeAt(2)) << 6 | 63 & cccc.charCodeAt(3), offset = cp - 65536;
return _fromCC((offset >>> 10) + 55296) + _fromCC((offset & 1023) + 56320);
case 3:
return _fromCC((15 & cccc.charCodeAt(0)) << 12 | (63 & cccc.charCodeAt(1)) << 6 | 63 & cccc.charCodeAt(2));
default:
return _fromCC((31 & cccc.charCodeAt(0)) << 6 | 63 & cccc.charCodeAt(1));
}
};
const btou = (b3) => b3.replace(re_btou, cb_btou);
const atobPolyfill = (asc) => {
asc = asc.replace(/\s+/g, "");
if (!b64re.test(asc))
throw new TypeError("malformed base64.");
asc += "==".slice(2 - (asc.length & 3));
let u24, bin = "", r1, r22;
for (let i3 = 0; i3 < asc.length; ) {
u24 = b64tab[asc.charAt(i3++)] << 18 | b64tab[asc.charAt(i3++)] << 12 | (r1 = b64tab[asc.charAt(i3++)]) << 6 | (r22 = b64tab[asc.charAt(i3++)]);
bin += r1 === 64 ? _fromCC(u24 >> 16 & 255) : r22 === 64 ? _fromCC(u24 >> 16 & 255, u24 >> 8 & 255) : _fromCC(u24 >> 16 & 255, u24 >> 8 & 255, u24 & 255);
}
return bin;
};
const _atob = typeof atob === "function" ? (asc) => atob(_tidyB64(asc)) : _hasBuffer ? (asc) => Buffer.from(asc, "base64").toString("binary") : atobPolyfill;
const _toUint8Array = _hasBuffer ? (a2) => _U8Afrom(Buffer.from(a2, "base64")) : (a2) => _U8Afrom(_atob(a2).split("").map((c3) => c3.charCodeAt(0)));
const _decode = _hasBuffer ? (a2) => Buffer.from(a2, "base64").toString("utf8") : _TD ? (a2) => _TD.decode(_toUint8Array(a2)) : (a2) => btou(_atob(a2));
const _unURI = (a2) => _tidyB64(a2.replace(/[-_]/g, (m0) => m0 == "-" ? "+" : "/"));
const decode = (src) => _decode(_unURI(src));
const _sfc_main$4 = vue.defineComponent({
mounted() {
prompt({
headline: "请输入选择器备注",
description: "对该选择器的备注,方便辨认",
confirmText: "就决定是你了!",
cancelText: "算了",
closeOnEsc: true,
closeOnOverlayClick: true,
onConfirm: (name) => {
if (!name) {
snackbar({
message: "请不要留空哦~",
placement: "top"
});
return false;
} else {
prompt({
headline: "请输入选择器",
description: "输入选择器",
confirmText: "好了~",
cancelText: "算了",
closeOnEsc: true,
closeOnOverlayClick: true,
onConfirm: async (selector) => {
if (!selector) {
snackbar({
message: "请不要留空哦~",
placement: "top"
});
return new Promise((_2, reject) => reject(false));
} else {
const savedSelectors = await getHanashiroSettings("selectors");
savedSelectors.push({
name,
base64: encodeURI(selector),
order: 1
});
savedSelectors.sort((a2, b3) => {
if (a2.order > b3.order) return -1;
else if (a2.order == b3.order) return 0;
else return 1;
});
await setHanashiroSettings("selectors", savedSelectors);
send("closePage");
}
},
onCancel: () => send("closePage")
}).catch();
}
},
onCancel: () => send("closePage")
}).catch();
}
});
const generateSelectors = async () => {
const selectors = await getHanashiroSettings("selectors");
const selectorsGroup = document.querySelector("#selectors");
let innerHtmlString = "";
selectors.sort((a2, b3) => {
if (a2.order > b3.order) return -1;
else if (a2.order == b3.order) return 0;
else return 1;
});
selectors.forEach(({ name, base64, order }, index) => {
innerHtmlString += `<mdui-radio id="selectorRadio" value=${base64} data-index="${String(index)}" data-order="${String(order ?? 1)}">${name}</mdui-radio>`;
});
selectorsGroup.innerHTML = innerHtmlString;
document.querySelectorAll("#selectorRadio").forEach((radio) => {
radio.addEventListener("click", (e3) => {
const nameTextField = document.querySelector("#name");
const selectorTextField = document.querySelector("#selector");
const orderTextField = document.querySelector("#order");
nameTextField.value = e3.target.innerText;
selectorTextField.value = decode(e3.target.value);
orderTextField.value = e3.target.getAttribute("data-order");
window.Hanashiro.currentSelector = {
index: Number(e3.target.getAttribute("data-index")),
name: e3.target.innerText,
base64: e3.target.value
};
});
});
};
const editSelector = async () => {
let selectors = await getHanashiroSettings("selectors");
const nameTextField = document.querySelector("#name");
const selectorTextField = document.querySelector("#selector");
const orderTextField = document.querySelector("#order");
if (selectorTextField.value) {
selectors[window.Hanashiro.currentSelector.index] = {
name: nameTextField.value,
base64: encodeURI(selectorTextField.value),
order: Number(orderTextField.value == "" ? 1 : orderTextField.value)
};
} else selectors.splice(window.Hanashiro.currentSelector.index, 1);
await setHanashiroSettings("selectors", selectors);
snackbar({
message: "修改成功!",
placement: "top"
});
};
const setValue = async (selectors, importWay) => {
try {
if (importWay == 0) await setHanashiroSettings("selectors", selectors);
else {
const hadSelectors = await getHanashiroSettings("selectors");
await setHanashiroSettings("selectors", hadSelectors.concat(selectors));
}
} catch {
snackbar({
message: "应用设置失败",
placement: "top"
});
return;
}
};
const getRemoteSelectors = async (url, importWay) => {
let remoteSelectors;
try {
remoteSelectors = lib.parse(await (await fetch(url)).text());
} catch {
snackbar({
message: "请求失败!",
placement: "top"
});
return;
}
await setValue(remoteSelectors, importWay);
snackbar({
message: "设置应用成功!重新打开页面即可看见更改",
placement: "top"
});
};
const getLocalSelectors = async (importWay) => {
const file = await n2({
description: "选择器清单文件",
extensions: [".json5"],
excludeAcceptAllOption: true
});
const localSelectors = lib.parse(await file.text());
await setValue(localSelectors, importWay);
snackbar({
message: "设置应用成功!重新打开页面即可看见更改",
placement: "top"
});
};
const _import = () => {
let importWay = 0;
dialog({
headline: "选择导入方式",
description: "选择覆盖导入或者添加导入",
closeOnEsc: true,
closeOnOverlayClick: true,
actions: [
{
text: "覆盖导入",
onClick: () => {
importWay = 0;
}
},
{
text: "添加导入",
onClick: () => {
importWay = 1;
}
}
]
});
dialog({
headline: "选择导入渠道",
description: "选择从本地导入或者远程导入",
closeOnEsc: true,
closeOnOverlayClick: true,
actions: [
{
text: "本地导入",
onClick: async () => await getLocalSelectors(importWay)
},
{
text: "远程导入",
onClick: () => {
prompt({
headline: "远程设置文件链接",
description: "请输入远程设置文件的链接以导入",
closeOnEsc: true,
closeOnOverlayClick: true,
confirmText: "导入",
cancelText: "取消",
onConfirm: async (value) => {
if (!value) {
snackbar({
message: "请输入链接!",
placement: "top"
});
return new Promise((_2, reject) => reject(false));
} else await getRemoteSelectors(value, importWay);
}
});
}
}
]
});
};
const _export = async () => {
const selectors = await getHanashiroSettings("selectors");
const selectorsFile = new Blob([lib.stringify(selectors, void 0, 2)]);
FileSaver_minExports.saveAs(selectorsFile, "selectors.json5");
};
const _sfc_main$3 = vue.defineComponent({
methods: {
async editSelector() {
await editSelector();
},
async close() {
const selectors = await getHanashiroSettings("selectors");
selectors.sort((a2, b3) => {
if (a2.order > b3.order) return -1;
else if (a2.order == b3.order) return 0;
else return 1;
});
await setHanashiroSettings("selectors", selectors);
send("closePage");
},
async exportSelectors() {
await _export();
},
importSelectors() {
_import();
}
},
async mounted() {
await generateSelectors();
document.querySelector("#page").open = true;
}
});
function _sfc_render$2(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock("mdui-dialog", {
id: "page",
headline: "管理选择器",
"close-on-overlay-click": "",
"close-on-esc": "",
onClosed: _cache[6] || (_cache[6] = (...args) => _ctx.close && _ctx.close(...args))
}, [
vue.createElementVNode("div", null, [
vue.createElementVNode("mdui-button", {
variant: "tonal",
onClick: _cache[0] || (_cache[0] = (...args) => _ctx.exportSelectors && _ctx.exportSelectors(...args))
}, "导出"),
vue.createElementVNode("mdui-button", {
variant: "tonal",
onClick: _cache[1] || (_cache[1] = (...args) => _ctx.importSelectors && _ctx.importSelectors(...args))
}, "导入")
]),
_cache[13] || (_cache[13] = vue.createElementVNode("div", null, [
vue.createElementVNode("span", null, "选择选择器:"),
vue.createElementVNode("mdui-radio-group", { id: "selectors" })
], -1)),
vue.createElementVNode("div", null, [
_cache[7] || (_cache[7] = vue.createElementVNode("span", null, "备注:", -1)),
vue.createElementVNode("mdui-text-field", {
variant: "filled",
id: "name",
label: "备注",
onChange: _cache[2] || (_cache[2] = (...args) => _ctx.editSelector && _ctx.editSelector(...args))
}, null, 32),
_cache[8] || (_cache[8] = vue.createElementVNode("span", { class: "introduction" }, "失焦保存", -1))
]),
vue.createElementVNode("div", null, [
_cache[9] || (_cache[9] = vue.createElementVNode("span", null, "选择器:", -1)),
vue.createElementVNode("mdui-text-field", {
variant: "filled",
id: "selector",
label: "选择器",
onChange: _cache[3] || (_cache[3] = (...args) => _ctx.editSelector && _ctx.editSelector(...args))
}, null, 32),
_cache[10] || (_cache[10] = vue.createElementVNode("span", { class: "introduction" }, "留空删除。失焦保存", -1))
]),
vue.createElementVNode("div", null, [
_cache[11] || (_cache[11] = vue.createElementVNode("span", null, "排序优先值:", -1)),
vue.createElementVNode("mdui-text-field", {
variant: "filled",
id: "order",
label: "排序优先值",
onChange: _cache[4] || (_cache[4] = (...args) => _ctx.editSelector && _ctx.editSelector(...args))
}, null, 32),
_cache[12] || (_cache[12] = vue.createElementVNode("span", { class: "introduction" }, "数字越大,排序越前,最小为1。失焦保存", -1))
]),
vue.createElementVNode("div", null, [
vue.createElementVNode("mdui-button", {
slot: "action",
variant: "tonal",
onClick: _cache[5] || (_cache[5] = (...args) => _ctx.close && _ctx.close(...args))
}, "关闭")
])
], 32);
}
const ManageSelectors = /* @__PURE__ */ _export_sfc(_sfc_main$3, [["render", _sfc_render$2]]);
const _sfc_main$2 = vue.defineComponent({
async mounted() {
const file = await n2({
description: "截图",
extensions: [".png"],
excludeAcceptAllOption: true
});
const imageArrayBuffer = await file.arrayBuffer();
await replaceScreenshot(getSnapshotId(), imageArrayBuffer);
snackbar({
message: "更换截图成功!刷新页面即可看见更改",
placement: "top"
});
send("closePage");
}
});
const arrayBufferToImage = (arrayBuffer) => {
const arrayBufferView = new Uint8Array(arrayBuffer);
const blob = new Blob([arrayBufferView], { type: "image/png" });
const src = (window.URL || window.webkitURL).createObjectURL(blob);
const img = document.createElement("img");
img.src = src;
return img;
};
const generatePosition = async () => {
const canvas = document.querySelector("#canvas");
const ctx = canvas.getContext("2d");
const snapshotId = getSnapshotId();
const screenshot = await getScreenshot(snapshotId);
const nodeId = Number(document.querySelectorAll("tr > td > span")[23].textContent);
const screenWidth = (await getScreenInfo(getSnapshotId())).width;
const screenHeight = (await getScreenInfo(getSnapshotId())).height;
const left = await getNodeAttr(snapshotId, nodeId, "left");
const top2 = await getNodeAttr(snapshotId, nodeId, "top");
const width = await getNodeAttr(snapshotId, nodeId, "width");
const height = await getNodeAttr(snapshotId, nodeId, "height");
canvas.width = width;
canvas.height = height;
const fullImg = arrayBufferToImage(screenshot);
fullImg.onload = () => {
const tampCanvas = document.createElement("canvas");
const tampCtx = tampCanvas.getContext("2d");
tampCanvas.width = screenWidth;
tampCanvas.height = screenHeight;
tampCtx.drawImage(fullImg, 0, 0, screenWidth, screenHeight);
const imgData = tampCtx.getImageData(left, top2, width, height);
ctx.putImageData(imgData, 0, 0);
};
canvas.onclick = (e3) => {
const x2 = e3.clientX - canvas.offsetLeft;
const y2 = e3.clientY - canvas.offsetTop;
const absolutePosition = {
left: left + x2,
top: top2 + y2
};
const relativePosition = {
left: `width * ${String((x2 / width).toFixed(4))}`,
top: `width * ${String((y2 / width).toFixed(4))}`
};
window.Hanashiro.nodePosition = {
absolute: absolutePosition,
relative: relativePosition
};
const result = document.querySelector("#result");
result.open = true;
};
};
const _sfc_main$1 = vue.defineComponent({
methods: {
closeDialog() {
send("closePage");
},
closeResult() {
const result = document.querySelector("#result");
result.open = false;
},
getNewPosition() {
const absolute = window.Hanashiro.nodePosition.absolute;
const relative = window.Hanashiro.nodePosition.relative;
document.querySelector("#absolute").value = lib.stringify({ position: absolute }, void 0, 2);
document.querySelector("#relative").value = lib.stringify({ position: relative }, void 0, 2);
}
},
async mounted() {
await generatePosition();
document.querySelector("#page").open = true;
}
});
function _sfc_render$1(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createElementBlock(vue.Fragment, null, [
vue.createElementVNode("mdui-dialog", {
id: "page",
headline: "选择点击坐标",
"close-on-overlay-click": "",
"close-on-esc": "",
onClosed: _cache[1] || (_cache[1] = (...args) => _ctx.closeDialog && _ctx.closeDialog(...args))
}, [
_cache[4] || (_cache[4] = vue.createElementVNode("div", null, [
vue.createElementVNode("canvas", { id: "canvas" })
], -1)),
vue.createElementVNode("div", null, [
vue.createElementVNode("mdui-button", {
slot: "action",
variant: "tonal",
onClick: _cache[0] || (_cache[0] = (...args) => _ctx.closeDialog && _ctx.closeDialog(...args))
}, "关闭")
])
], 32),
vue.createElementVNode("mdui-dialog", {
id: "result",
headline: "计算结果",
"close-on-esc": "",
"close-on-overlay-click": "",
onOpen: _cache[3] || (_cache[3] = (...args) => _ctx.getNewPosition && _ctx.getNewPosition(...args))
}, [
_cache[5] || (_cache[5] = vue.createElementVNode("div", null, [
vue.createElementVNode("span", null, "绝对坐标:"),
vue.createElementVNode("mdui-text-field", {
id: "absolute",
variant: "filled",
label: "绝对坐标",
rows: "8"
})
], -1)),
_cache[6] || (_cache[6] = vue.createElementVNode("div", null, [
vue.createElementVNode("span", null, "相对坐标:"),
vue.createElementVNode("mdui-text-field", {
id: "relative",
variant: "filled",
label: "相对坐标",
rows: "8"
})
], -1)),
vue.createElementVNode("div", null, [
vue.createElementVNode("mdui-button", {
slot: "action",
variant: "tonal",
onClick: _cache[2] || (_cache[2] = (...args) => _ctx.closeResult && _ctx.closeResult(...args))
}, "关闭")
])
], 32)
], 64);
}
const GeneratePosition = /* @__PURE__ */ _export_sfc(_sfc_main$1, [["render", _sfc_render$1]]);
const _sfc_main = vue.defineComponent({
components: {
Main,
Settings,
Help,
UseSelector,
AddSelector: _sfc_main$4,
ManageSelectors,
ChangeScreenshot: _sfc_main$2,
GeneratePosition
},
data() {
return {
currentComponent: ""
};
},
created() {
receive("copyEvent", () => {
this.currentComponent = "Main";
});
receive("openSettings", () => {
this.currentComponent = "Settings";
});
receive("openHelp", () => {
this.currentComponent = "Help";
});
receive("openUseSelector", () => {
this.currentComponent = "UseSelector";
});
receive("openAddSelector", () => {
this.currentComponent = "AddSelector";
});
receive("openManageSelectors", () => {
this.currentComponent = "ManageSelectors";
});
receive("openChangeScreenshot", () => {
this.currentComponent = "ChangeScreenshot";
});
receive("openGeneratePosition", () => {
this.currentComponent = "GeneratePosition";
});
receive("closePage", () => {
this.currentComponent = "";
});
},
mounted() {
setColorScheme("#847264");
}
});
function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
return vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(_ctx.currentComponent));
}
const App = /* @__PURE__ */ _export_sfc(_sfc_main, [["render", _sfc_render]]);
vue.createApp(App).mount(
(() => {
const icon = document.createElement("link");
icon.rel = "stylesheet";
icon.href = "https://fonts.font.im/icon?family=Material+Icons";
document.head.append(icon);
const app = document.createElement("div");
document.body.append(app);
return app;
})()
);
})(Vue);