// ==UserScript== // @name GKD网页审查工具增强 // @name:en-US Make GKDInspect Better // @namespace https://blog.adproqwq.xyz // @version 2.12.0 // @author Adpro // @description 让GKD网页审查工具再次强大!版本:Neptune // @description:en-US Let GKD Inspect Better Again! Version: Neptune // @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}#categories{width:500px}.position{width:15%;height:var(--mdui-typescale-title-large-line-height)}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 ? "" : 3 === i3 ? "" : "", 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[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 ? "" : 3 === i3 ? "" : "")), 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, EVENT: 5, ELEMENT: 6 }, 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`${name}`; } if (this.src) { return x`${m$1(ajax({ url: this.src }).then(o$3))}`; } return x``; }; return this.hasSlotController.test("[default]") ? x`` : 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`` : this.src ? x`${o$5(this.label)}` : this.icon ? x`` : 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``; } }; 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 = []; } /** * 注册 `` */ registerMain(element) { this.$main = $$1(element); } /** * 取消注册 `` */ unregisterMain() { this.$main = void 0; } /** * 注册新的 `` */ 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(); } /** * 取消注册 `` */ 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); } } /** * 获取所有 `` 元素(按在 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; } /** * 获取 `` 元素 */ getMain() { return this.$main ? this.$main[0] : void 0; } /** * 获取 `` 及 `` 元素 */ 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``; } /** * 滚动行为 * 当前仅支持 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); } }); } /** * 获取当前表单控件关联的 `
` 元素 */ 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(``; } 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`${this.isButton() ? this.renderButton({ className: "button", part: "button", content: this.renderInner() }) : this.disabled || this.loading ? x`${this.renderInner()}` : this.renderAnchor({ className: "button", part: "button", content: this.renderInner() })}`; } renderIcon() { if (this.loading) { return this.renderLoading(); } return x`${this.icon ? x`` : nothingTemplate}`; } renderLabel() { return x``; } renderEndIcon() { return x`${this.endIcon ? x`` : nothingTemplate}`; } 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`${this.isButton() ? this.renderButton({ className: "button", part: "button", content: this.renderIcon() }) : this.disabled || this.loading ? x`${this.renderIcon()}` : this.renderAnchor({ className: "button", part: "button", content: this.renderIcon() })} ${this.renderLoading()}`; } renderIcon() { const icon = () => this.hasSlotController.test("[default]") ? x`` : this.icon ? x`` : nothingTemplate; const selectedIcon = () => this.hasSlotController.test("selected-icon") || this.selectedIcon ? x`` : 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`${this.href && !this.disabled ? this.renderAnchor({ className: "link", content: x`` }) : x``}`; } }; 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`${o$3(svgPaths)}`; let IconCheckBoxOutlineBlank = class IconCheckBoxOutlineBlank2 extends r$3 { render() { return svgTag(''); } }; 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(''); } }; IconCheckBox.styles = style$e; IconCheckBox = __decorate([ t$3("mdui-icon-check-box") ], IconCheckBox); let IconIndeterminateCheckBox = class IconIndeterminateCheckBox2 extends r$3 { render() { return svgTag(''); } }; 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``; } /** * 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(''); } }; IconCheck.styles = style$e; IconCheck = __decorate([ t$3("mdui-icon-check") ], IconCheck); let IconClear = class IconClear2 extends r$3 { render() { return svgTag(''); } }; 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`${this.isButton() ? this.renderButton({ className: className2, part: "button", content: this.renderInner() }) : this.disabled || this.loading ? x`${this.renderInner()}` : 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`` : nothingTemplate; }; const selectedIcon = () => { if (this.selectedIcon) { return x``; } if (this.variant === "assist" || this.variant === "filter") { return x``; } return icon(); }; return !this.selected ? x`${icon()}` : x`${selectedIcon()}`; } renderLabel() { return x``; } renderEndIcon() { return x`${this.endIcon ? x`` : nothingTemplate}`; } renderDeleteIcon() { if (!this.deletable) { return nothingTemplate; } return x`${this.deleteIcon ? x`` : x``}`; } 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``; } 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(); } // 更新 的状态 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`${this.header}`; } 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("
").css({ width: "100%", height: "200px" }); const $outer = $$1("
").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`
${n$1(hasHeader, () => x`${n$1(hasIcon, () => this.renderIcon())} ${n$1(hasHeadline, () => this.renderHeadline())}`)} ${n$1(hasBody, () => x`
${n$1(hasDescription, () => this.renderDescription())}
`)} ${n$1(hasActionSlot, () => x``)}
`; } onOverlayClick() { this.emit("overlay-click"); if (!this.closeOnOverlayClick) { return; } this.open = false; } renderIcon() { return x`${this.icon ? x`` : nothingTemplate}`; } renderHeadline() { return x`${this.headline}`; } renderDescription() { return x`${this.description}`; } }; 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``; } /** * 获取 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`${this.isButton() ? this.renderButton({ className: className2, part: "button", content: this.renderInner() }) : this.disabled || this.loading ? x`${this.renderInner()}` : this.renderAnchor({ className: className2, part: "button", content: this.renderInner() })}`; } renderLabel() { return x``; } renderIcon() { if (this.loading) { return this.renderLoading(); } return x`${this.icon ? x`` : nothingTemplate}`; } 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``; } }; 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``; } }; 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``; } }; 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`
`; } return x`
`; } }; 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`${this.href && !this.disabled ? this.renderAnchor({ className: className2, content: this.renderInner(), part: "container", refDirective: n$2(this.itemRef) }) : x`
${this.renderInner()}
`}`; } renderInner() { const hasDefaultSlot = this.hasSlotController.test("[default]"); return x`${this.icon ? x`` : nothingTemplate}
${hasDefaultSlot ? x`` : x`
${this.headline}
`}${this.description}
${this.endIcon ? x`` : nothingTemplate}
`; } }; 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``; } }; 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``; } }; List.styles = [componentStyle, listStyle]; List = __decorate([ t$3("mdui-list") ], List); let IconArrowRight = class IconArrowRight2 extends r$3 { render() { return svgTag(''); } }; 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`${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`
${this.renderInner(useDefaultEndIcon, hasIcon)}
`} ${n$1(hasSubmenu, () => x``)}`; } /** * 点击子菜单外面的区域,关闭子菜单 */ 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`${this.selected ? x`${this.selectedIcon ? x`` : x``}` : x`${hasIcon ? x`` : nothingTemplate}`}
${this.endText}${useDefaultEndIcon ? x`` : x`${this.endIcon ? x`` : nothingTemplate}`}
`; } }; 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``; } 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`${this.href ? this.renderAnchor({ part: "container", className: className2, content: this.renderInner() }) : x`
${this.renderInner()}
`}`; } renderInner() { return x`
${this.activeIcon ? x`` : nothingTemplate}${this.icon ? x`` : nothingTemplate}
`; } }; 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``; } /** * 滚动行为 * 当前仅支持 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(); } // 更新 的状态 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`
`)}`; } 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``)} ${n$1(hasBottomSlot, () => x``)}`; } 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`
${this.renderInner(hasDefaultSlot)}
`}`; } renderInner(hasDefaultSlot) { return x`
${this.activeIcon ? x`` : nothingTemplate}${this.icon ? x`` : nothingTemplate}
${hasDefaultSlot ? x`` : 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(''); } }; IconCircle.styles = style$e; IconCircle = __decorate([ t$3("mdui-icon-circle") ], IconCircle); let IconRadioButtonUnchecked = class IconRadioButtonUnchecked2 extends r$3 { render() { return svgTag(''); } }; 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`${this.uncheckedIcon ? x`` : x``}${this.checkedIcon ? x`` : x``}`; } 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; } // 为了使 可以不是该组件的直接子元素,这里不用 @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`
`; } // 更新 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(); } /** * 在内部的 `` 上按下按键时,在 `` 之间切换焦点 */ 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(); } // 更新 的状态 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`
${this.labelFormatter(value)}
`); } 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(); } /** * 用于提供拖拽操作 * 用于提供 html5 自带的表单错误提示 */ render() { return x``; } 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`${this.isButton() ? this.renderButton({ className: className2, part: "button", content: this.renderInner() }) : this.isDisabled() || this.loading ? x`${this.renderInner()}` : 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`${this.selectedIcon ? x`` : x``}`; } return x`${this.icon ? x`` : nothingTemplate}`; } renderLabel() { const hasLabel = this.hasSlotController.test("[default]"); if (!hasLabel) { return nothingTemplate; } return x``; } renderEndIcon() { return x`${this.endIcon ? x`` : nothingTemplate}`; } 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; } // 为了使 可以不是该组件的直接子元素,这里不用 @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``)}${n$1(this.isSelectable && this.isMultiple, () => x``)}`; } // 切换一个元素的选中状态 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); } } /** * 在隐藏的 `` 或 `` 或 ``; } renderTextArea(hasInputSlot) { return x``; } /** * @param hasError 是否包含错误提示 * @param hasHelper 是否含 helper 属性或 helper slot */ renderHelper(hasError, hasHelper) { return hasError ? x`
${this.error || this.inputRef.value.validationMessage}
` : hasHelper ? x`${this.helper}` : ( // 右边有 counter,需要占位 x`` ); } renderCounter(hasCounter) { return hasCounter ? x`
${this.value.length}/${this.maxlength}
` : 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`` : x``} `${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`` : E)} ${n$1(this.multiple && this.value.length, () => x`
${o(this.value, (valueItem) => x` `${v2}:chip__${v2}`).join(",")}" variant="input" deletable tabindex="-1" @delete="${() => this.onDeleteOneValue(valueItem)}">${this.getMenuItemLabelByValue(valueItem)}`)}
`)}
`; } 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(); } /** * 用于提供拖拽操作 * 用于提供 html5 自带的表单错误提示 */ render() { return x``; } 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`
${this.action ? x`${this.action}` : nothingTemplate}${n$1(this.closeable, () => x`${this.closeIcon ? x`` : x``}`)}
`; } /** * 重新排序 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``; } /** * 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``; return x`
${n$1(hasIcon || this.icon, renderBadge)}${this.icon ? x`` : nothingTemplate}
${n$1(!hasIcon, renderBadge)}
`; } }; 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``; } }; 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`
`; } 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); } /** * 获取第一个非 `); $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 */ var hasRequiredLocalforage; function requireLocalforage() { if (hasRequiredLocalforage) return localforage$1.exports; hasRequiredLocalforage = 1; (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); return localforage$1.exports; } var localforageExports = requireLocalforage(); const localforage = /* @__PURE__ */ getDefaultExportFromCjs(localforageExports); var jszip_min = { exports: {} }; /*! JSZip v3.10.1 - A JavaScript class for generating and reading zip files (c) 2009-2016 Stuart Knightley 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 */ var hasRequiredJszip_min; function requireJszip_min() { if (hasRequiredJszip_min) return jszip_min.exports; hasRequiredJszip_min = 1; (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); return jszip_min.exports; } var jszip_minExports = requireJszip_min(); const JSZip = /* @__PURE__ */ getDefaultExportFromCjs(jszip_minExports); var FileSaver_min$1 = { exports: {} }; var FileSaver_min = FileSaver_min$1.exports; var hasRequiredFileSaver_min; function requireFileSaver_min() { if (hasRequiredFileSaver_min) return FileSaver_min$1.exports; hasRequiredFileSaver_min = 1; (function(module, exports) { (function(a2, b3) { b3(); })(FileSaver_min, 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$1); return FileSaver_min$1.exports; } var FileSaver_minExports = requireFileSaver_min(); const localStorage$1 = localforage.createInstance({ name: "localforage" }); const snapshotStorage = localforage.createInstance({ name: "snapshot" }); const screenshotStorage = localforage.createInstance({ name: "screenshot" }); const hanashiroStorage = localforage.createInstance({ name: "Hanashiro" }); const simplyActivityIds = async (snapshotId) => { const snapshotInfo = await snapshotStorage.getItem(snapshotId); const activityId = snapshotInfo == null ? void 0 : snapshotInfo.activityId; if (activityId) { const appId = snapshotInfo.appId; if (activityId.startsWith(appId) && activityId[appId.length] === ".") { const simplyActivityIds2 = activityId.replace(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 getInspectSettings = async () => { return await localStorage$1.getItem("settings"); }; const setInspectSettings = async (newSettings) => { await localStorage$1.setItem("settings", newSettings); }; 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) }); } if (!await( getInspectSettings())) await( setInspectSettings({ autoUploadImport: false, ignoreUploadWarn: false, ignoreWasmWarn: false, maxShowNodeSize: 2e3 })); Object.defineProperty(window, "Hanashiro", { value: {}, writable: true }); if (await( getHanashiroSettings("hideLoadSnackbar")) === false) { snackbar({ message: "九月西风兴,月冷露华凝。", autoCloseDelay: 2e3, placement: "top" }); } const send = (eventName) => { const event = new Event(eventName); window.dispatchEvent(event); }; const receive = (eventName, callback, once) => { window.addEventListener(eventName, callback, { once }); }; const createBarIcon = (icon, onclick) => { const iconElement = document.createElement("mdui-button-icon"); iconElement.icon = icon; iconElement.style.height = "36px"; iconElement.style.width = "36px"; iconElement.onclick = onclick; return iconElement; }; 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); } }; const insertBarIcon = (icon) => { const iconBar = document.querySelector("#iconBar"); iconBar.append(icon); }; Object.defineProperty(window, "HatsuneMiku", { value: { event: { send, receive }, utils: { icon: { createBarIcon, insertBarIcon }, common: { observeElement }, storage: { getHanashiroSettings, setHanashiroSettings, getInspectSettings, setInspectSettings }, ui: { snackbar, confirm, dialog } } }, writable: true }); 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 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; observeElement(".n-button.n-button--default-type.n-button--medium-type", () => { const settingsButton = document.querySelectorAll(".n-button.n-button--default-type.n-button--medium-type")[1]; settingsButton.onclick = () => { snackbar({ message: "网页审查工具未实现该功能,脚本粗略替代实现。未来官方实现可能与目前不同,请勿过度依赖。", placement: "top" }); send("openInspectSettings"); }; }); const getSnapshotId = () => { return location.pathname.split("/")[2]; }; const getCurrentNodeId = () => { const currentSelectedNode = document.querySelector(".n-tree-node-wrapper .n-tree-node--selected"); if (!currentSelectedNode) return 0; else return Number(currentSelectedNode.getAttribute("data-node-id")); }; const replaceNodeInfo = async () => { const snapshotId = getSnapshotId(); const nodeId = getCurrentNodeId() == -1 ? 0 : getCurrentNodeId(); 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 = createBarIcon("search", () => { send("openUseSelector"); }); const AddSelectorIcon = createBarIcon("add", () => { send("openAddSelector"); }); const ManageSelectorsIcon = createBarIcon("edit", () => { send("openManageSelectors"); }); const ChangeScreenshotIcon = createBarIcon("photo", () => { send("openChangeScreenshot"); }); const SettingsIcon = createBarIcon("settings", () => { send("openSettings"); }); const HelpIcon = createBarIcon("help", () => { 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 copyDepth = document.querySelector("#copyDepth").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 (copyDepth == "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 (copyDepth == "ts") { const text = `import { defineGkdApp } from '@gkd-kit/define';\r\rexport default defineGkdApp(${stringify3});\r`; window.Hanashiro.returnResult = text; } else if (copyDepth == "app") window.Hanashiro.returnResult = stringify3; else if (copyDepth == "groups") window.Hanashiro.returnResult = lib.stringify(origin.groups[0], null, 2); else if (copyDepth == "rules") window.Hanashiro.returnResult = lib.stringify(iArrayToArray(origin.groups[0].rules)[0], null, 2); send("closePage"); send("modifyEnd"); }; const key = () => { const copyDepth = document.querySelector("#copyDepth").value; const key2 = document.querySelector("#key").value; const origin = lib.parse(window.Hanashiro.originRule); if (key2) { if (copyDepth == "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 += `${category.name}`; }); categoriesGroup.innerHTML = innerHtmlString; } }; const _sfc_main$9 = 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$7(_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('
选择复制深度:ts层app层groups层rules层
选择分类:
插入action类型:clickCenterback
插入限制字段:插入matchTime、resetMatch和actionMaximum
去除exampleUrls:
', 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$9, [["render", _sfc_render$7]]); const settings = async () => { const categories = document.querySelector("#categories").value; const rulesKeySort2 = document.querySelector("#rulesKeySort").value; const maxShowSize = document.querySelector("#maxShowSize").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; const inspectSettings = await getInspectSettings(); 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); inspectSettings.maxShowNodeSize = Number(maxShowSize); await setInspectSettings(inspectSettings); 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$8 = 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 getInspectSettings()) { document.querySelector("#maxShowSize").value = String((await getInspectSettings()).maxShowNodeSize); } 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$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[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.createElementVNode("div", null, [ vue.createElementVNode("span", null, "节点阈值:"), vue.createElementVNode("mdui-text-field", { variant: "filled", id: "maxShowSize", type: "number", label: "节点阈值", placeholder: "填入数字" }), vue.createElementVNode("span", { class: "introduction" }, "最大节点展示数量,超出的节点将被丢弃") ], -1)), _cache[7] || (_cache[7] = vue.createStaticVNode('
隐藏加载成功提示:每次脚本加载时会弹出一句诗句,此选项可选择是否弹出
name属性复制优化:在复制name属性时,会自动优化复制的内容。如复制 android.widget.TextView 时会优化为 TextView
选择器分享自动添加快捷搜索:在分享选择器时,自动添加到快捷搜索列表中
activityIds规则复制优化:在复制规则代码时,若activityIds满足简写条件时,使用简写
', 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$8, [["render", _sfc_render$6]]); const inspect = async () => { const currentInspectSettings = await getInspectSettings(); const isUploadWarn = document.querySelector("#uploadWarn").checked; const isWasmWarn = document.querySelector("#wasmWarn").checked; const isAutoUploadImport = document.querySelector("#autoUploadImport").checked; currentInspectSettings.ignoreUploadWarn = !isUploadWarn; currentInspectSettings.ignoreWasmWarn = !isWasmWarn; currentInspectSettings.autoUploadImport = isAutoUploadImport; await setInspectSettings(currentInspectSettings); send("closePage"); }; const _sfc_main$7 = vue.defineComponent({ methods: { async inspect() { await inspect(); }, closeDialog() { send("closePage"); } }, async mounted() { const currentInspectSettings = await getInspectSettings(); if (currentInspectSettings.ignoreUploadWarn) document.querySelector("#uploadWarn").checked = false; if (currentInspectSettings.ignoreWasmWarn) document.querySelector("#wasmWarn").checked = false; if (currentInspectSettings.autoUploadImport) document.querySelector("#autoUploadImport").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[1] || (_cache[1] = (...args) => _ctx.closeDialog && _ctx.closeDialog(...args)) }, [ _cache[2] || (_cache[2] = vue.createStaticVNode('
生成分享链接弹窗提醒:默认开启。关闭则不会提醒
浏览器版本正则表达式WASM(GC)提醒:默认开启。关闭则不会提醒
打开快照页面自动生成分享链接:请确保不含隐私!
', 3)), vue.createElementVNode("div", null, [ vue.createElementVNode("mdui-button", { slot: "action", variant: "tonal", onClick: _cache[0] || (_cache[0] = (...args) => _ctx.inspect && _ctx.inspect(...args)) }, "确定") ]) ], 32); } const InspectSettings = /* @__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('

本脚本已开源至Github,欢迎反馈:Github仓库

你可以通过以下方式联系我:
QQ群:494273126
邮箱:adpro_qwq@qq.com
Telegram群组:Telegram群组
Telegram频道:Telegram频道

如果你觉得脚本好用,可以通过赞助支持我:
爱发电

在这里推荐AIsouler的GKD订阅,特别好用,受到用户广泛好评!Github仓库

', 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 += `${name}`; }); 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 += `${name}`; }); 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: "排序优先值", type: "number", 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 getInfo = async () => { const canvas = document.querySelector("#canvas"); const snapshotId = getSnapshotId(); const screenshot = await getScreenshot(snapshotId); const nodeId = getCurrentNodeId(); 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"); const fullImg = arrayBufferToImage(screenshot); return [canvas, screenWidth, screenHeight, left, top2, width, height, fullImg]; }; const partialView = (canvas, screenWidth, screenHeight, left, top2, width, height, fullImg) => { window.Hanashiro.currentPositionView = "partial"; const ctx = canvas.getContext("2d"); const tampCanvas = document.createElement("canvas"); const tampCtx = tampCanvas.getContext("2d"); canvas.width = width; canvas.height = height; 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); }; const globalView = (canvas, screenWidth, screenHeight, fullImg) => { window.Hanashiro.currentPositionView = "global"; const ctx = canvas.getContext("2d"); canvas.width = screenWidth; canvas.height = screenHeight; ctx.drawImage(fullImg, 0, 0, screenWidth, screenHeight); }; const generatePosition = async () => { const [canvas, screenWidth, screenHeight, left, top2, width, height, fullImg] = await getInfo(); fullImg.onload = () => partialView(canvas, screenWidth, screenHeight, left, top2, width, height, fullImg); canvas.onclick = (e3) => { let x2 = e3.offsetX, y2 = e3.offsetY; if (window.Hanashiro.currentPositionView == "global") { x2 -= left; y2 -= top2; } 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; }, async partialView() { const [canvas, screenWidth, screenHeight, left, top2, width, height, fullImg] = await getInfo(); fullImg.onload = () => partialView(canvas, screenWidth, screenHeight, left, top2, width, height, fullImg); }, async globalView() { const [canvas, screenWidth, screenHeight, _left, _top, _width, _height, fullImg] = await getInfo(); fullImg.onload = () => globalView(canvas, screenWidth, screenHeight, fullImg); }, 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: "选择点击坐标", fullscreen: "", "close-on-overlay-click": "", "close-on-esc": "", onClosed: _cache[3] || (_cache[3] = (...args) => _ctx.closeDialog && _ctx.closeDialog(...args)) }, [ _cache[6] || (_cache[6] = vue.createElementVNode("div", null, [ vue.createElementVNode("canvas", { id: "canvas" }) ], -1)), vue.createElementVNode("div", null, [ vue.createElementVNode("mdui-button-icon", { icon: "open_in_full", onClick: _cache[0] || (_cache[0] = (...args) => _ctx.globalView && _ctx.globalView(...args)) }), vue.createElementVNode("mdui-button-icon", { icon: "close_fullscreen", onClick: _cache[1] || (_cache[1] = (...args) => _ctx.partialView && _ctx.partialView(...args)) }) ]), vue.createElementVNode("div", null, [ vue.createElementVNode("mdui-button", { slot: "action", variant: "tonal", onClick: _cache[2] || (_cache[2] = (...args) => _ctx.closeDialog && _ctx.closeDialog(...args)) }, "关闭") ]) ], 32), vue.createElementVNode("mdui-dialog", { id: "result", headline: "计算结果", "close-on-esc": "", "close-on-overlay-click": "", onOpen: _cache[5] || (_cache[5] = (...args) => _ctx.getNewPosition && _ctx.getNewPosition(...args)) }, [ _cache[7] || (_cache[7] = vue.createElementVNode("div", null, [ vue.createElementVNode("span", null, "绝对坐标:"), vue.createElementVNode("mdui-text-field", { id: "absolute", variant: "filled", label: "绝对坐标", rows: "8" }) ], -1)), _cache[8] || (_cache[8] = 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[4] || (_cache[4] = (...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, InspectSettings, 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("openInspectSettings", () => { this.currentComponent = "InspectSettings"; }); receive("closePage", () => { this.currentComponent = ""; }); }, mounted() { setColorScheme("#a8d9e5"); } }); 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);